forked from OSchip/llvm-project
LoopIndexSplit can sometimes result in cases where a block in its own domfrontier.
Don't crash when we encounter one of these. llvm-svn: 51915
This commit is contained in:
parent
ec62418fc5
commit
2df82e7cec
|
@ -235,9 +235,12 @@ bool llvm::SplitCriticalEdge(TerminatorInst *TI, unsigned SuccNum, Pass *P,
|
||||||
DominanceFrontier::iterator I = DF->find(DestBB);
|
DominanceFrontier::iterator I = DF->find(DestBB);
|
||||||
if (I != DF->end()) {
|
if (I != DF->end()) {
|
||||||
DF->addBasicBlock(NewBB, I->second);
|
DF->addBasicBlock(NewBB, I->second);
|
||||||
// However NewBB's frontier does not include DestBB.
|
|
||||||
DominanceFrontier::iterator NF = DF->find(NewBB);
|
if (I->second.count(DestBB)) {
|
||||||
DF->removeFromFrontier(NF, DestBB);
|
// However NewBB's frontier does not include DestBB.
|
||||||
|
DominanceFrontier::iterator NF = DF->find(NewBB);
|
||||||
|
DF->removeFromFrontier(NF, DestBB);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
DF->addBasicBlock(NewBB, DominanceFrontier::DomSetType());
|
DF->addBasicBlock(NewBB, DominanceFrontier::DomSetType());
|
||||||
|
|
Loading…
Reference in New Issue