[llvm] r325301 - [DCE] Salvage debug info from dead insts

Vedant Kumar via llvm-commits llvm-commits at lists.llvm.org
Thu Feb 15 14:26:18 PST 2018


Author: vedantk
Date: Thu Feb 15 14:26:18 2018
New Revision: 325301

URL: http://llvm.org/viewvc/llvm-project?rev=325301&view=rev
Log:
[DCE] Salvage debug info from dead insts

This results in small increases in the size of the .debug_loc section
and the number of unique source variables in a stage2 build of opt.

Modified:
    llvm/trunk/lib/Transforms/Scalar/DCE.cpp
    llvm/trunk/test/Transforms/DCE/basic.ll

Modified: llvm/trunk/lib/Transforms/Scalar/DCE.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/DCE.cpp?rev=325301&r1=325300&r2=325301&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/DCE.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/DCE.cpp Thu Feb 15 14:26:18 2018
@@ -50,6 +50,7 @@ namespace {
       for (BasicBlock::iterator DI = BB.begin(); DI != BB.end(); ) {
         Instruction *Inst = &*DI++;
         if (isInstructionTriviallyDead(Inst, TLI)) {
+          salvageDebugInfo(*Inst);
           Inst->eraseFromParent();
           Changed = true;
           ++DIEEliminated;
@@ -76,6 +77,8 @@ static bool DCEInstruction(Instruction *
                            SmallSetVector<Instruction *, 16> &WorkList,
                            const TargetLibraryInfo *TLI) {
   if (isInstructionTriviallyDead(I, TLI)) {
+    salvageDebugInfo(*I);
+
     // Null out all of the instruction's operands to see if any operand becomes
     // dead as we go.
     for (unsigned i = 0, e = I->getNumOperands(); i != e; ++i) {

Modified: llvm/trunk/test/Transforms/DCE/basic.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/DCE/basic.ll?rev=325301&r1=325300&r2=325301&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/DCE/basic.ll (original)
+++ llvm/trunk/test/Transforms/DCE/basic.ll Thu Feb 15 14:26:18 2018
@@ -1,11 +1,15 @@
-; RUN: opt -dce -S < %s | FileCheck %s
-; RUN: opt -passes=dce -S < %s | FileCheck %s
+; RUN: opt -debugify -dce -S < %s | FileCheck %s
+; RUN: opt -passes='module(debugify),function(dce)' -S < %s | FileCheck %s
 
 ; CHECK-LABEL: @test
 define void @test() {
-; CHECK-NOT: add
   %add = add i32 1, 2
-; CHECK-NOT: sub
+; CHECK-NEXT: call void @llvm.dbg.value(metadata i32 1, metadata [[add:![0-9]+]], metadata !DIExpression(DW_OP_plus_uconst, 2, DW_OP_stack_value))
   %sub = sub i32 %add, 1
+; CHECK-NEXT: call void @llvm.dbg.value(metadata i32 1, metadata [[sub:![0-9]+]], metadata !DIExpression(DW_OP_plus_uconst, 2, DW_OP_constu, 1, DW_OP_minus, DW_OP_stack_value))
+; CHECK-NEXT: ret void
   ret void
 }
+
+; CHECK: [[add]] = !DILocalVariable
+; CHECK: [[sub]] = !DILocalVariable




More information about the llvm-commits mailing list