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 17628e2..9362d26 100644
--- a/lib/Transforms/Utils/InlineFunction.cpp
+++ b/lib/Transforms/Utils/InlineFunction.cpp
@@ -191,10 +191,14 @@
           
           // Next, create the new invoke instruction, inserting it at the end
           // of the old basic block.
-          new InvokeInst(CI->getCalledValue(), Split, InvokeDest, 
-                         std::vector<Value*>(CI->op_begin()+1, CI->op_end()),
-                         CI->getName(), BB->getTerminator());
-          
+          InvokeInst *II =
+            new InvokeInst(CI->getCalledValue(), Split, InvokeDest, 
+                           std::vector<Value*>(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