From: Chris Lattner Date: Mon, 15 Sep 2003 02:10:16 +0000 (+0000) Subject: Fix bug: Inline/2003-09-14-InlineValue.ll X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=e07007c2bd0dcb775ff3eecabb4c31ce8dc5fab0;p=oota-llvm.git Fix bug: Inline/2003-09-14-InlineValue.ll git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@8514 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Utils/InlineFunction.cpp b/lib/Transforms/Utils/InlineFunction.cpp index 17628e22537..9362d26e2b2 100644 --- a/lib/Transforms/Utils/InlineFunction.cpp +++ b/lib/Transforms/Utils/InlineFunction.cpp @@ -191,10 +191,14 @@ bool InlineFunction(CallSite CS) { // Next, create the new invoke instruction, inserting it at the end // of the old basic block. - new InvokeInst(CI->getCalledValue(), Split, InvokeDest, - std::vector(CI->op_begin()+1, CI->op_end()), - CI->getName(), BB->getTerminator()); - + InvokeInst *II = + new InvokeInst(CI->getCalledValue(), Split, InvokeDest, + std::vector(CI->op_begin()+1, CI->op_end()), + CI->getName(), BB->getTerminator()); + + // Make sure that anything using the call now uses the invoke! + CI->replaceAllUsesWith(II); + // Delete the unconditional branch inserted by splitBasicBlock BB->getInstList().pop_back(); Split->getInstList().pop_front(); // Delete the original call