Add support for removing invoke instructions
authorChris Lattner <sabre@nondot.org>
Mon, 12 Apr 2004 05:15:13 +0000 (05:15 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 12 Apr 2004 05:15:13 +0000 (05:15 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12858 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Scalar/GCSE.cpp

index bbefe8157f4acead1cf28a2a6f4be96edbec2e71..7db7d4dcde71601ef8660ac6fca68ddbfb42d2bf 100644 (file)
@@ -167,6 +167,13 @@ void GCSE::ReplaceInstructionWith(Instruction *I, Value *V) {
   // anything special.
   if (!isa<Constant>(V)) {
     I->replaceAllUsesWith(V);
   // anything special.
   if (!isa<Constant>(V)) {
     I->replaceAllUsesWith(V);
+
+    if (InvokeInst *II = dyn_cast<InvokeInst>(I)) {
+      // Removing an invoke instruction requires adding a branch to the normal
+      // destination and removing PHI node entries in the exception destination.
+      new BranchInst(II->getNormalDest(), II);
+      II->getUnwindDest()->removePredecessor(II->getParent());
+    }
     
     // Erase the instruction from the program.
     I->getParent()->getInstList().erase(I);
     
     // Erase the instruction from the program.
     I->getParent()->getInstList().erase(I);
@@ -179,6 +186,13 @@ void GCSE::ReplaceInstructionWith(Instruction *I, Value *V) {
   // Perform the replacement.
   I->replaceAllUsesWith(C);
 
   // Perform the replacement.
   I->replaceAllUsesWith(C);
 
+  if (InvokeInst *II = dyn_cast<InvokeInst>(I)) {
+    // Removing an invoke instruction requires adding a branch to the normal
+    // destination and removing PHI node entries in the exception destination.
+    new BranchInst(II->getNormalDest(), II);
+    II->getUnwindDest()->removePredecessor(II->getParent());
+  }
+
   // Erase the instruction from the program.
   I->getParent()->getInstList().erase(I);
   
   // Erase the instruction from the program.
   I->getParent()->getInstList().erase(I);