aboutsummaryrefslogtreecommitdiff
path: root/include/llvm/Transforms/Utils/BasicBlockUtils.h
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2006-02-10 21:32:11 +0000
committerChris Lattner <sabre@nondot.org>2006-02-10 21:32:11 +0000
commitebccc040e569106b949733d5eb929f75a72dd16c (patch)
tree430162a9c46d553144b469961a97c1a159dc282a /include/llvm/Transforms/Utils/BasicBlockUtils.h
parent81be2e961be525834d2ac1ee37c880286a508151 (diff)
Remove a level of indirection.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@26109 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/Transforms/Utils/BasicBlockUtils.h')
-rw-r--r--include/llvm/Transforms/Utils/BasicBlockUtils.h17
1 files changed, 8 insertions, 9 deletions
diff --git a/include/llvm/Transforms/Utils/BasicBlockUtils.h b/include/llvm/Transforms/Utils/BasicBlockUtils.h
index 7a67df537f..9fe7e47fe8 100644
--- a/include/llvm/Transforms/Utils/BasicBlockUtils.h
+++ b/include/llvm/Transforms/Utils/BasicBlockUtils.h
@@ -76,20 +76,19 @@ inline bool SplitCriticalEdge(BasicBlock *BB, succ_iterator SI, Pass *P = 0) {
/// This updates all of the same analyses as the other SplitCriticalEdge
/// function.
inline bool SplitCriticalEdge(BasicBlock *Succ, pred_iterator PI, Pass *P = 0) {
- BasicBlock *Pred = *PI;
bool MadeChange = false;
- for (succ_iterator SI = succ_begin(Pred), E = succ_end(Pred); SI != E; ++SI)
- if (*SI == Succ)
- MadeChange |= SplitCriticalEdge(Pred, SI, P);
+ TerminatorInst *TI = (*PI)->getTerminator();
+ for (unsigned i = 0, e = TI->getNumSuccessors(); i != e; ++i)
+ if (TI->getSuccessor(i) == Succ)
+ MadeChange |= SplitCriticalEdge(TI, i, P);
return MadeChange;
}
inline bool SplitCriticalEdge(BasicBlock *Src, BasicBlock *Dst, Pass *P = 0) {
- for (succ_iterator SI = succ_begin(Src); ; ++SI) {
- assert(SI != succ_end(Src) && "Edge doesn't exist");
- if (*SI == Dst)
- return SplitCriticalEdge(Src, SI, P);
- }
+ TerminatorInst *TI = Src->getTerminator();
+ for (unsigned i = 0, e = TI->getNumSuccessors(); ; ++i)
+ if (TI->getSuccessor(i) == Dst)
+ return SplitCriticalEdge(TI, i, P);
}
} // End llvm namespace