[PATCH] D50092: Introduce DebugCounter into DCE pass

George Burgess IV via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Thu Sep 13 13:31:08 PDT 2018


This revision was automatically updated to reflect the committed changes.
Closed by commit rL342170: [DCE] Add DebugCounter support (authored by gbiv, committed by ).

Changed prior to commit:
  https://reviews.llvm.org/D50092?vs=158828&id=165368#toc

Repository:
  rL LLVM

https://reviews.llvm.org/D50092

Files:
  llvm/trunk/lib/Transforms/Scalar/DCE.cpp
  llvm/trunk/test/Other/debugcounter-dce.ll


Index: llvm/trunk/lib/Transforms/Scalar/DCE.cpp
===================================================================
--- llvm/trunk/lib/Transforms/Scalar/DCE.cpp
+++ llvm/trunk/lib/Transforms/Scalar/DCE.cpp
@@ -24,13 +24,16 @@
 #include "llvm/IR/InstIterator.h"
 #include "llvm/IR/Instruction.h"
 #include "llvm/Pass.h"
+#include "llvm/Support/DebugCounter.h"
 #include "llvm/Transforms/Scalar.h"
 using namespace llvm;
 
 #define DEBUG_TYPE "dce"
 
 STATISTIC(DIEEliminated, "Number of insts removed by DIE pass");
 STATISTIC(DCEEliminated, "Number of insts removed");
+DEBUG_COUNTER(DCECounter, "dce-transform",
+              "Controls which instructions are eliminated");
 
 namespace {
   //===--------------------------------------------------------------------===//
@@ -50,6 +53,8 @@
       for (BasicBlock::iterator DI = BB.begin(); DI != BB.end(); ) {
         Instruction *Inst = &*DI++;
         if (isInstructionTriviallyDead(Inst, TLI)) {
+          if (!DebugCounter::shouldExecute(DCECounter))
+            continue;
           salvageDebugInfo(*Inst);
           Inst->eraseFromParent();
           Changed = true;
@@ -77,6 +82,9 @@
                            SmallSetVector<Instruction *, 16> &WorkList,
                            const TargetLibraryInfo *TLI) {
   if (isInstructionTriviallyDead(I, TLI)) {
+    if (!DebugCounter::shouldExecute(DCECounter))
+      return false;
+
     salvageDebugInfo(*I);
 
     // Null out all of the instruction's operands to see if any operand becomes
Index: llvm/trunk/test/Other/debugcounter-dce.ll
===================================================================
--- llvm/trunk/test/Other/debugcounter-dce.ll
+++ llvm/trunk/test/Other/debugcounter-dce.ll
@@ -0,0 +1,20 @@
+; REQUIRES: asserts
+; RUN: opt -dce -S -debug-counter=dce-transform-skip=1,dce-transform-count=2  < %s | FileCheck %s
+;; Test that, with debug counters on, we will skip the first DCE opportunity, perform next 2,
+;; and ignore all the others left.
+
+; CHECK-LABEL: @test
+; CHECK-NEXT: %add1 = add i32 1, 2
+; CHECK-NEXT: %sub1 = sub i32 %add1, 1
+; CHECK-NEXT: %add2 = add i32 1, 2
+; CHECK-NEXT: %add3 = add i32 1, 2
+; CHECK-NEXT: ret void
+define void @test() {
+  %add1 = add i32 1, 2
+  %sub1 = sub i32 %add1, 1
+  %add2 = add i32 1, 2
+  %sub2 = sub i32 %add2, 1
+  %add3 = add i32 1, 2
+  %sub3 = sub i32 %add3, 1
+  ret void
+}


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D50092.165368.patch
Type: text/x-patch
Size: 2377 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180913/b1934df9/attachment.bin>


More information about the llvm-commits mailing list