mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-05-28 15:38:57 +00:00
Fix bug: TailDup/2003-07-22-InfiniteLoop.ll
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7243 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e1a875ef29
commit
00f185fbfd
@ -76,6 +76,11 @@ bool TailDup::shouldEliminateUnconditionalBranch(TerminatorInst *TI) {
|
|||||||
BasicBlock *Dest = BI->getSuccessor(0);
|
BasicBlock *Dest = BI->getSuccessor(0);
|
||||||
if (Dest == BI->getParent()) return false; // Do not loop infinitely!
|
if (Dest == BI->getParent()) return false; // Do not loop infinitely!
|
||||||
|
|
||||||
|
// Do not inline a block if we will just get another branch to the same block!
|
||||||
|
if (BranchInst *DBI = dyn_cast<BranchInst>(Dest->getTerminator()))
|
||||||
|
if (DBI->isUnconditional() && DBI->getSuccessor(0) == Dest)
|
||||||
|
return false; // Do not loop infinitely!
|
||||||
|
|
||||||
// Do not bother working on dead blocks...
|
// Do not bother working on dead blocks...
|
||||||
pred_iterator PI = pred_begin(Dest), PE = pred_end(Dest);
|
pred_iterator PI = pred_begin(Dest), PE = pred_end(Dest);
|
||||||
if (PI == PE && Dest != Dest->getParent()->begin())
|
if (PI == PE && Dest != Dest->getParent()->begin())
|
||||||
|
Loading…
x
Reference in New Issue
Block a user