diff options
author | Nick Lewycky <nicholas@mxc.ca> | 2006-10-03 14:52:23 +0000 |
---|---|---|
committer | Nick Lewycky <nicholas@mxc.ca> | 2006-10-03 14:52:23 +0000 |
commit | 5c8c5d9ace43643190b3650ab8cb5a7f911f50ea (patch) | |
tree | bb4df15d36cea7e7b69e96a158c28c32f777f723 /lib/Transforms/Scalar/PredicateSimplifier.cpp | |
parent | 99435d32b3318f1b2f593f484ea9ba26804bf56c (diff) |
Move break-crit-edges before the predicate simplifier. Allows us to
optimize in more cases.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30699 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/Scalar/PredicateSimplifier.cpp')
-rw-r--r-- | lib/Transforms/Scalar/PredicateSimplifier.cpp | 10 |
1 files changed, 3 insertions, 7 deletions
diff --git a/lib/Transforms/Scalar/PredicateSimplifier.cpp b/lib/Transforms/Scalar/PredicateSimplifier.cpp index 715818c686..b6de61bacd 100644 --- a/lib/Transforms/Scalar/PredicateSimplifier.cpp +++ b/lib/Transforms/Scalar/PredicateSimplifier.cpp @@ -500,8 +500,10 @@ bool PredicateSimplifier::runOnFunction(Function &F) { } void PredicateSimplifier::getAnalysisUsage(AnalysisUsage &AU) const { + AU.addRequiredID(BreakCriticalEdgesID); AU.addRequired<DominatorTree>(); AU.setPreservesCFG(); + AU.addPreservedID(BreakCriticalEdgesID); } // resolve catches cases addProperty won't because it wasn't used as a @@ -622,13 +624,7 @@ void PredicateSimplifier::proceedToSuccessor(TerminatorInst *TI, PropertySet &NextPS) { assert(edge < TI->getNumSuccessors() && "Invalid index for edge."); - BasicBlock *BB = TI->getParent(), - *BBNext = TI->getSuccessor(edge); - - if (BBNext->getSinglePredecessor() == BB) - visitBasicBlock(BBNext, NextPS); - else - visitBasicBlock(BBNext, CurrentPS); + visitBasicBlock(TI->getSuccessor(edge), NextPS); } void PredicateSimplifier::proceedToSuccessors(PropertySet &KP, |