From a728ddc81586c7fb881a1b429d169d1004f8c74b Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Fri, 13 Jan 2006 21:28:09 +0000 Subject: Do a simple instcombine xforms to delete llvm.stackrestore cases. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25294 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Scalar/InstructionCombining.cpp | 33 ++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) (limited to 'lib') diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp index b326220..cbfb81b 100644 --- a/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/lib/Transforms/Scalar/InstructionCombining.cpp @@ -4671,6 +4671,39 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) { SPI->replaceAllUsesWith(PrevSPI); return EraseInstFromFunction(CI); } + } else { + switch (II->getIntrinsicID()) { + default: break; + case Intrinsic::stackrestore: { + // If the save is right next to the restore, remove the restore. This can + // happen when variable allocas are DCE'd. + if (IntrinsicInst *SS = dyn_cast(II->getOperand(1))) { + if (SS->getIntrinsicID() == Intrinsic::stacksave) { + BasicBlock::iterator BI = SS; + if (&*++BI == II) + return EraseInstFromFunction(CI); + } + } + + // If the stack restore is in a return/unwind block and if there are no + // allocas or calls between the restore and the return, nuke the restore. + TerminatorInst *TI = II->getParent()->getTerminator(); + if (isa(TI) || isa(TI)) { + BasicBlock::iterator BI = II; + bool CannotRemove = false; + for (++BI; &*BI != TI; ++BI) { + if (isa(BI) || + (isa(BI) && !isa(BI))) { + CannotRemove = true; + break; + } + } + if (!CannotRemove) + return EraseInstFromFunction(CI); + } + break; + } + } } return visitCallSite(II); -- cgit v1.1