Removing a dead debug intrinsic shouldn't trigger
authorDale Johannesen <dalej@apple.com>
Tue, 10 Mar 2009 21:19:49 +0000 (21:19 +0000)
committerDale Johannesen <dalej@apple.com>
Tue, 10 Mar 2009 21:19:49 +0000 (21:19 +0000)
another instcombine pass if we weren't going to make
one without debug info.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@66576 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Scalar/InstructionCombining.cpp

index 86048e6a15e12e881f4b25222071b97295fd8423..2bf87c0045d8dc81212810338a2fb00663823b1e 100644 (file)
@@ -12566,12 +12566,15 @@ bool InstCombiner::DoOneIteration(Function &F, unsigned Iteration) {
           BasicBlock::iterator I = Term; --I;
 
           DOUT << "IC: DCE: " << *I;
-          ++NumDeadInst;
-
+          // A debug intrinsic shouldn't force another iteration if we weren't
+          // going to do one without it.
+          if (!isa<DbgInfoIntrinsic>(I)) {
+            ++NumDeadInst;
+            Changed = true;
+          }
           if (!I->use_empty())
             I->replaceAllUsesWith(UndefValue::get(I->getType()));
           I->eraseFromParent();
-          Changed = true;
         }
       }
   }