Make bugpoint dead-argument-hacking actually work, and actually test it.
authorDan Gohman <gohman@apple.com>
Mon, 7 Jun 2010 20:20:33 +0000 (20:20 +0000)
committerDan Gohman <gohman@apple.com>
Mon, 7 Jun 2010 20:20:33 +0000 (20:20 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105551 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/IPO/DeadArgumentElimination.cpp
test/BugPoint/remove_arguments_test.ll

index 692e47da71c39967db79533e84881f382a6b38ce..475eee8b19e4bc0bb1639fc126d280ebd52ed1d2 100644 (file)
@@ -120,9 +120,14 @@ namespace {
 
     typedef SmallVector<RetOrArg, 5> UseVector;
 
+  protected:
+    // DAH uses this to specify a different ID.
+    explicit DAE(void *ID) : ModulePass(ID) {}
+
   public:
     static char ID; // Pass identification, replacement for typeid
     DAE() : ModulePass(&ID) {}
+
     bool runOnModule(Module &M);
 
     virtual bool ShouldHackArguments() const { return false; }
@@ -155,6 +160,8 @@ namespace {
   /// by bugpoint.
   struct DAH : public DAE {
     static char ID;
+    DAH() : DAE(&ID) {}
+
     virtual bool ShouldHackArguments() const { return true; }
   };
 }
index fb17c78a140bca215ceba72ab4b64f640e991d72..39a1371640f60c30d67539d53a84208ea7ffb1e9 100644 (file)
@@ -1,10 +1,12 @@
 ; RUN: bugpoint %s -output-prefix %t -bugpoint-crashcalls -silence-passes
+; RUN: llvm-dis remove_arguments_test.ll.tmp-reduced-simplified.bc -o - | FileCheck %s
 
 ; Test to make sure that arguments are removed from the function if they are 
 ; unnecessary.
 
 declare i32 @test2()
 
+; CHECK: define void @test() {
 define i32 @test(i32 %A, i32 %B, float %C) {
        call i32 @test2()
        ret i32 %1