summaryrefslogtreecommitdiff
path: root/lib/Transforms/Scalar/JumpThreading.cpp
diff options
context:
space:
mode:
authorBenjamin Kramer <benny.kra@googlemail.com>2010-01-07 13:50:07 +0000
committerBenjamin Kramer <benny.kra@googlemail.com>2010-01-07 13:50:07 +0000
commit66b581ef4965ca3a6c72450ee9916a5c2ab44461 (patch)
tree877e5bc63e930dccefaf372fce64757ce793ab45 /lib/Transforms/Scalar/JumpThreading.cpp
parent452394d812816b05f626d414ce6dbd3b87d45a73 (diff)
downloadllvm-66b581ef4965ca3a6c72450ee9916a5c2ab44461.tar.gz
llvm-66b581ef4965ca3a6c72450ee9916a5c2ab44461.tar.bz2
llvm-66b581ef4965ca3a6c72450ee9916a5c2ab44461.tar.xz
Use a do-while loop instead of while + boolean.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@92912 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/Scalar/JumpThreading.cpp')
-rw-r--r--lib/Transforms/Scalar/JumpThreading.cpp10
1 files changed, 4 insertions, 6 deletions
diff --git a/lib/Transforms/Scalar/JumpThreading.cpp b/lib/Transforms/Scalar/JumpThreading.cpp
index fadbec58d7..ab7d9718ed 100644
--- a/lib/Transforms/Scalar/JumpThreading.cpp
+++ b/lib/Transforms/Scalar/JumpThreading.cpp
@@ -124,10 +124,9 @@ bool JumpThreading::runOnFunction(Function &F) {
FindLoopHeaders(F);
- bool AnotherIteration = true, EverChanged = false;
- while (AnotherIteration) {
- AnotherIteration = false;
- bool Changed = false;
+ bool Changed, EverChanged = false;
+ do {
+ Changed = false;
for (Function::iterator I = F.begin(), E = F.end(); I != E;) {
BasicBlock *BB = I;
// Thread all of the branches we can over this block.
@@ -176,9 +175,8 @@ bool JumpThreading::runOnFunction(Function &F) {
}
}
}
- AnotherIteration = Changed;
EverChanged |= Changed;
- }
+ } while (Changed);
LoopHeaders.clear();
return EverChanged;