From e98c54c47ca09207ef2d2d6065a512a6b0ed1f0d Mon Sep 17 00:00:00 2001 From: Owen Anderson Date: Fri, 18 Jul 2008 18:03:38 +0000 Subject: [PATCH] Make PRE actually handle critical edges (by splitting them). Confirmed that bootstrap passes with this change. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@53762 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Scalar/GVN.cpp | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/lib/Transforms/Scalar/GVN.cpp b/lib/Transforms/Scalar/GVN.cpp index 4e4d8c127e3..c6645463655 100644 --- a/lib/Transforms/Scalar/GVN.cpp +++ b/lib/Transforms/Scalar/GVN.cpp @@ -1136,8 +1136,11 @@ bool GVN::runOnFunction(Function& F) { changed |= shouldContinue; } - if (EnablePRE) - changed |= performPRE(F); + if (EnablePRE) { + bool PREChanged = false; + while (PREChanged = performPRE(F)) + changed |= PREChanged; + } return changed; } @@ -1336,7 +1339,7 @@ bool GVN::performPRE(Function& F) { I = toSplit.begin(), E = toSplit.end(); I != E; ++I) SplitCriticalEdge(I->first, I->second, this); - return changed; + return changed || toSplit.size(); } // iterateOnFunction - Executes one iteration of GVN -- 2.34.1