summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms
diff options
context:
space:
mode:
authorNick Lewycky <nicholas@mxc.ca>2006-10-03 14:52:23 +0000
committerNick Lewycky <nicholas@mxc.ca>2006-10-03 14:52:23 +0000
commit755f801adcb0a6d7c4ee787d91c3f8442d25fb05 (patch)
tree0fd64af2388ef4440265a40b37e6f78f2a695a0a /llvm/lib/Transforms
parentff510a58c2ebaa806828047a7cf1e1daa5266999 (diff)
downloadbcm5719-llvm-755f801adcb0a6d7c4ee787d91c3f8442d25fb05.tar.gz
bcm5719-llvm-755f801adcb0a6d7c4ee787d91c3f8442d25fb05.zip
Move break-crit-edges before the predicate simplifier. Allows us to
optimize in more cases. llvm-svn: 30699
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r--llvm/lib/Transforms/Scalar/PredicateSimplifier.cpp10
1 files changed, 3 insertions, 7 deletions
diff --git a/llvm/lib/Transforms/Scalar/PredicateSimplifier.cpp b/llvm/lib/Transforms/Scalar/PredicateSimplifier.cpp
index 715818c6861..b6de61bacd1 100644
--- a/llvm/lib/Transforms/Scalar/PredicateSimplifier.cpp
+++ b/llvm/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,
OpenPOWER on IntegriCloud