diff options
author | Owen Anderson <resistor@mac.com> | 2008-09-03 23:06:07 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2008-09-03 23:06:07 +0000 |
commit | 2fbfb7053025775272c82ec53a6658b927d63f65 (patch) | |
tree | 4443af2bde40ccaf4411b878c90dc7ae255de635 | |
parent | 397d895bb8f1fbb7fd8551f58864c488c0a439e0 (diff) | |
download | bcm5719-llvm-2fbfb7053025775272c82ec53a6658b927d63f65.tar.gz bcm5719-llvm-2fbfb7053025775272c82ec53a6658b927d63f65.zip |
Fix a bug that prevented PRE from applying in some cases.
llvm-svn: 55744
-rw-r--r-- | llvm/lib/Transforms/Scalar/GVN.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/llvm/lib/Transforms/Scalar/GVN.cpp b/llvm/lib/Transforms/Scalar/GVN.cpp index 42fbc78671e..b258fcc08c0 100644 --- a/llvm/lib/Transforms/Scalar/GVN.cpp +++ b/llvm/lib/Transforms/Scalar/GVN.cpp @@ -1131,9 +1131,11 @@ bool GVN::runOnFunction(Function& F) { } if (EnablePRE) { - bool PREChanged = false; - while ((PREChanged = performPRE(F))) + bool PREChanged = true; + while (PREChanged) { + PREChanged = performPRE(F); changed |= PREChanged; + } } return changed; @@ -1256,7 +1258,7 @@ bool GVN::performPRE(Function& F) { unsigned succNum = 0; for (unsigned i = 0, e = PREPred->getTerminator()->getNumSuccessors(); i != e; ++i) - if (PREPred->getTerminator()->getSuccessor(i) == PREPred) { + if (PREPred->getTerminator()->getSuccessor(i) == CurrentBlock) { succNum = i; break; } |