diff options
author | Owen Anderson <resistor@mac.com> | 2008-10-03 06:55:35 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2008-10-03 06:55:35 +0000 |
commit | cb4f156b6b39f803f7c0a7d417dd8b242b0b6d28 (patch) | |
tree | 5a7a29782e428af71b45c29d944af81831d0d398 /llvm/lib/Transforms/Utils/BasicBlockUtils.cpp | |
parent | 4d601119c3593e5ca222d473a79b87d51d54381b (diff) | |
download | llvm-cb4f156b6b39f803f7c0a7d417dd8b242b0b6d28.zip llvm-cb4f156b6b39f803f7c0a7d417dd8b242b0b6d28.tar.gz llvm-cb4f156b6b39f803f7c0a7d417dd8b242b0b6d28.tar.bz2 |
SplitBlock should only attempt to update LoopInfo if it is actually being used.
llvm-svn: 56994
Diffstat (limited to 'llvm/lib/Transforms/Utils/BasicBlockUtils.cpp')
-rw-r--r-- | llvm/lib/Transforms/Utils/BasicBlockUtils.cpp | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/llvm/lib/Transforms/Utils/BasicBlockUtils.cpp b/llvm/lib/Transforms/Utils/BasicBlockUtils.cpp index a98e135..1b018cb 100644 --- a/llvm/lib/Transforms/Utils/BasicBlockUtils.cpp +++ b/llvm/lib/Transforms/Utils/BasicBlockUtils.cpp @@ -240,16 +240,15 @@ BasicBlock *llvm::SplitEdge(BasicBlock *BB, BasicBlock *Succ, Pass *P) { /// the loop info is updated. /// BasicBlock *llvm::SplitBlock(BasicBlock *Old, Instruction *SplitPt, Pass *P) { - - LoopInfo &LI = P->getAnalysis<LoopInfo>(); BasicBlock::iterator SplitIt = SplitPt; while (isa<PHINode>(SplitIt)) ++SplitIt; BasicBlock *New = Old->splitBasicBlock(SplitIt, Old->getName()+".split"); // The new block lives in whichever loop the old one did. - if (Loop *L = LI.getLoopFor(Old)) - L->addBasicBlockToLoop(New, LI.getBase()); + if (LoopInfo* LI = P->getAnalysisToUpdate<LoopInfo>()) + if (Loop *L = LI->getLoopFor(Old)) + L->addBasicBlockToLoop(New, LI->getBase()); if (DominatorTree *DT = P->getAnalysisToUpdate<DominatorTree>()) { |