diff options
author | Devang Patel <dpatel@apple.com> | 2007-08-13 21:59:17 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2007-08-13 21:59:17 +0000 |
commit | da48cf40db3945c6d0ca0dc20f8eba027fc6e6f7 (patch) | |
tree | 98c49ada775e70f68deb56aed4b5b6b85aa25ced /llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp | |
parent | 2b40caa861160c82b40fd35d248cd8b6d1f09ef4 (diff) | |
download | bcm5719-llvm-da48cf40db3945c6d0ca0dc20f8eba027fc6e6f7.tar.gz bcm5719-llvm-da48cf40db3945c6d0ca0dc20f8eba027fc6e6f7.zip |
If NewBB dominates DestBB then DestBB is not part of NewBB's dominance frontier.
llvm-svn: 41051
Diffstat (limited to 'llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp')
-rw-r--r-- | llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp b/llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp index af9a114bbeb..e28d59d7c3a 100644 --- a/llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp +++ b/llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp @@ -227,8 +227,12 @@ bool llvm::SplitCriticalEdge(TerminatorInst *TI, unsigned SuccNum, Pass *P, DominanceFrontier::DomSetType NewDFSet; if (NewBBDominatesDestBB) { DominanceFrontier::iterator I = DF->find(DestBB); - if (I != DF->end()) + if (I != DF->end()) { DF->addBasicBlock(NewBB, I->second); + // However NewBB's frontier does not include DestBB. + DominanceFrontier::iterator NF = DF->find(NewBB); + DF->removeFromFrontier(NF, DestBB); + } else DF->addBasicBlock(NewBB, DominanceFrontier::DomSetType()); } else { |