diff options
| author | Benjamin Kramer <benny.kra@googlemail.com> | 2015-02-28 16:47:27 +0000 | 
|---|---|---|
| committer | Benjamin Kramer <benny.kra@googlemail.com> | 2015-02-28 16:47:27 +0000 | 
| commit | cb570f1bc9ff7488532dd3fec7ecd2b74cafb489 (patch) | |
| tree | 29fab039479913ddceb97d95ce9b983d273b8202 /llvm/lib | |
| parent | 96e68a0c47bfb74d54c4405838c3565f23d6c66f (diff) | |
| download | bcm5719-llvm-cb570f1bc9ff7488532dd3fec7ecd2b74cafb489.tar.gz bcm5719-llvm-cb570f1bc9ff7488532dd3fec7ecd2b74cafb489.zip | |
TRE: Just erase dead BBs and tweak the iteration loop not to increment the deleted BB iterator.
Leaving empty blocks around just opens up a can of bugs like PR22704. Deleting
them early also slightly simplifies code.
Thanks to Sanjay for the IR test case.
llvm-svn: 230856
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp | 26 | 
1 files changed, 7 insertions, 19 deletions
| diff --git a/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp b/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp index 92d94876304..79a96b512bf 100644 --- a/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp +++ b/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp @@ -403,28 +403,19 @@ bool TailCallElim::runTRE(Function &F) {    // alloca' is changed from being a static alloca to being a dynamic alloca.    // Until this is resolved, disable this transformation if that would ever    // happen.  This bug is PR962. -  SmallVector<BasicBlock*, 8> BBToErase; -  for (Function::iterator BB = F.begin(), E = F.end(); BB != E; ++BB) { +  for (Function::iterator BBI = F.begin(), E = F.end(); BBI != E; /*in loop*/) { +    BasicBlock *BB = BBI++; // FoldReturnAndProcessPred may delete BB.      if (ReturnInst *Ret = dyn_cast<ReturnInst>(BB->getTerminator())) {        bool Change = ProcessReturningBlock(Ret, OldEntry, TailCallsAreMarkedTail,                                            ArgumentPHIs, !CanTRETailMarkedCall); -      if (!Change && BB->getFirstNonPHIOrDbg() == Ret) { +      if (!Change && BB->getFirstNonPHIOrDbg() == Ret)          Change = FoldReturnAndProcessPred(BB, Ret, OldEntry,                                            TailCallsAreMarkedTail, ArgumentPHIs,                                            !CanTRETailMarkedCall); -        // FoldReturnAndProcessPred may have emptied some BB. Remember to -        // erase them. -        if (Change && BB->empty()) -          BBToErase.push_back(BB); - -      }        MadeChange |= Change;      }    } -  for (auto BB: BBToErase) -    BB->eraseFromParent(); -    // If we eliminated any tail recursions, it's possible that we inserted some    // silly PHI nodes which just merge an initial value (the incoming operand)    // with themselves.  Check to see if we did and clean up our mess if so.  This @@ -831,14 +822,11 @@ bool TailCallElim::FoldReturnAndProcessPred(BasicBlock *BB,        ReturnInst *RI = FoldReturnIntoUncondBranch(Ret, BB, Pred);        // Cleanup: if all predecessors of BB have been eliminated by -      // FoldReturnIntoUncondBranch, we would like to delete it, but we -      // can not just nuke it as it is being used as an iterator by our caller. -      // Just empty it, and the caller will erase it when it is safe to do so. -      // It is important to empty it, because the ret instruction in there is -      // still using a value which EliminateRecursiveTailCall will attempt -      // to remove. +      // FoldReturnIntoUncondBranch, delete it.  It is important to empty it, +      // because the ret instruction in there is still using a value which +      // EliminateRecursiveTailCall will attempt to remove.        if (!BB->hasAddressTaken() && pred_begin(BB) == pred_end(BB)) -        BB->getInstList().clear(); +        BB->eraseFromParent();        EliminateRecursiveTailCall(CI, RI, OldEntry, TailCallsAreMarkedTail,                                   ArgumentPHIs, | 

