mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-12 13:38:21 +00:00
Make LoopInfoBase more generic, in preparation for having MachineLoopInfo. This involves a small interface change.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@44348 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -250,13 +250,13 @@ bool llvm::SplitCriticalEdge(TerminatorInst *TI, unsigned SuccNum, Pass *P,
|
||||
if (Loop *DestLoop = LI->getLoopFor(DestBB)) {
|
||||
if (TIL == DestLoop) {
|
||||
// Both in the same loop, the NewBB joins loop.
|
||||
DestLoop->addBasicBlockToLoop(NewBB, *LI);
|
||||
DestLoop->addBasicBlockToLoop(NewBB, LI->getBase());
|
||||
} else if (TIL->contains(DestLoop->getHeader())) {
|
||||
// Edge from an outer loop to an inner loop. Add to the outer loop.
|
||||
TIL->addBasicBlockToLoop(NewBB, *LI);
|
||||
TIL->addBasicBlockToLoop(NewBB, LI->getBase());
|
||||
} else if (DestLoop->contains(TIL->getHeader())) {
|
||||
// Edge from an inner loop to an outer loop. Add to the outer loop.
|
||||
DestLoop->addBasicBlockToLoop(NewBB, *LI);
|
||||
DestLoop->addBasicBlockToLoop(NewBB, LI->getBase());
|
||||
} else {
|
||||
// Edge from two loops with no containment relation. Because these
|
||||
// are natural loops, we know that the destination block must be the
|
||||
@ -265,7 +265,7 @@ bool llvm::SplitCriticalEdge(TerminatorInst *TI, unsigned SuccNum, Pass *P,
|
||||
assert(DestLoop->getHeader() == DestBB &&
|
||||
"Should not create irreducible loops!");
|
||||
if (Loop *P = DestLoop->getParentLoop())
|
||||
P->addBasicBlockToLoop(NewBB, *LI);
|
||||
P->addBasicBlockToLoop(NewBB, LI->getBase());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user