The "landingpad" instruction will never be "trivially" dead.
authorBill Wendling <isanbard@gmail.com>
Mon, 15 Aug 2011 20:10:51 +0000 (20:10 +0000)
committerBill Wendling <isanbard@gmail.com>
Mon, 15 Aug 2011 20:10:51 +0000 (20:10 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@137642 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Utils/Local.cpp

index 60dc15d642510f2d1c596481b1b2691238f244aa..be0aa82500160abd31ff692dcf88e9ee11574a84 100644 (file)
@@ -226,6 +226,10 @@ bool llvm::ConstantFoldTerminator(BasicBlock *BB, bool DeleteDeadConditions) {
 bool llvm::isInstructionTriviallyDead(Instruction *I) {
   if (!I->use_empty() || isa<TerminatorInst>(I)) return false;
 
+  // We don't want the landingpad instruction removed by anything this general.
+  if (isa<LandingPadInst>(I))
+    return false;
+
   // We don't want debug info removed by anything this general, unless
   // debug info is empty.
   if (DbgDeclareInst *DDI = dyn_cast<DbgDeclareInst>(I)) {