Revert 239795
authorPhilip Reames <listmail@philipreames.com>
Tue, 16 Jun 2015 01:20:53 +0000 (01:20 +0000)
committerPhilip Reames <listmail@philipreames.com>
Tue, 16 Jun 2015 01:20:53 +0000 (01:20 +0000)
I forgot to update some clang test cases.  I'll fix and resubmit tomorrow.

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

include/llvm/IR/CallSite.h
lib/Transforms/InstCombine/InstCombineCalls.cpp
test/CodeGen/NVPTX/intrin-nocapture.ll
test/Transforms/Inline/byval-tail-call.ll
test/Transforms/InstCombine/nonnull-param.ll [deleted file]
test/Transforms/InstCombine/select.ll

index 1da025f802f34504f3244cb64fe22ddd657dc1b5..170d263dfc79e1fb627bd8e92a12711001d5a306 100644 (file)
@@ -27,7 +27,6 @@
 #define LLVM_IR_CALLSITE_H
 
 #include "llvm/ADT/PointerIntPair.h"
-#include "llvm/ADT/iterator_range.h"
 #include "llvm/IR/Attributes.h"
 #include "llvm/IR/CallingConv.h"
 #include "llvm/IR/Instructions.h"
@@ -151,9 +150,6 @@ public:
   }
 
   IterTy arg_end() const { return (*this)->op_end() - getArgumentEndOffset(); }
-  iterator_range<IterTy> args() const {
-    return iterator_range<IterTy>(arg_begin(), arg_end());
-  }
   bool arg_empty() const { return arg_end() == arg_begin(); }
   unsigned arg_size() const { return unsigned(arg_end() - arg_begin()); }
 
index 85270cfca3bb6879d0324207c9d0857a5057501d..e83b9dd36ae8f0697273b55d075bf2047529b6a3 100644 (file)
@@ -1391,24 +1391,6 @@ static IntrinsicInst *FindInitTrampoline(Value *Callee) {
 // visitCallSite - Improvements for call and invoke instructions.
 //
 Instruction *InstCombiner::visitCallSite(CallSite CS) {
-
-  // Mark any parameters that are known to be non-null with the nonnull
-  // attribute.  This is helpful for inlining calls to functions with null
-  // checks on their arguments.
-  unsigned ArgNo = 0;
-  for (Value *V : CS.args()) {
-    if (!CS.paramHasAttr(ArgNo+1, Attribute::NonNull) &&
-        isKnownNonNull(V)) {
-      AttributeSet AS = CS.getAttributes();
-      AS = AS.addAttribute(CS.getInstruction()->getContext(), ArgNo+1,
-                           Attribute::NonNull);
-      CS.setAttributes(AS);
-      return CS.getInstruction();
-    }
-    ArgNo++;
-  }
-  assert(ArgNo == CS.arg_size() && "sanity check");
-  
   if (isAllocLikeFn(CS.getInstruction(), TLI))
     return visitAllocSite(*CS.getInstruction());
 
index 2dbd29f616f88a012dc6091d90b3f97b2ee33d36..55781bb15a0b896139cae8837b4121d63c8adcec 100644 (file)
@@ -11,7 +11,7 @@ declare i32 addrspace(1)* @llvm.nvvm.ptr.gen.to.global.p1i32.p0i32(i32*)
 ; CHECK: @bar
 define void @bar() {
   %t1 = alloca i32
-; CHECK: call i32 addrspace(1)* @llvm.nvvm.ptr.gen.to.global.p1i32.p0i32(i32* nonnull %t1)
+; CHECK: call i32 addrspace(1)* @llvm.nvvm.ptr.gen.to.global.p1i32.p0i32(i32* %t1)
 ; CHECK-NEXT: store i32 10, i32* %t1
   %t2 = call i32 addrspace(1)* @llvm.nvvm.ptr.gen.to.global.p1i32.p0i32(i32* %t1)
   store i32 10, i32* %t1
index 7553b76cf15f2248510e91c022e3687d24131970..1e50463ed80caf00f64f0b96e215dffb55533e2c 100644 (file)
@@ -33,7 +33,7 @@ define void @frob(i32* %x) {
 ; CHECK: %[[POS:.*]] = alloca i32
 ; CHECK: %[[VAL:.*]] = load i32, i32* %x
 ; CHECK: store i32 %[[VAL]], i32* %[[POS]]
-; CHECK: {{^ *}}call void @ext(i32* nonnull %[[POS]]
+; CHECK: {{^ *}}call void @ext(i32* %[[POS]]
 ; CHECK: tail call void @ext(i32* null)
 ; CHECK: ret void
   tail call void @qux(i32* byval %x)
diff --git a/test/Transforms/InstCombine/nonnull-param.ll b/test/Transforms/InstCombine/nonnull-param.ll
deleted file mode 100644 (file)
index d9a84ee..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-; RUN: opt -S -instcombine < %s | FileCheck %s
-
-declare void @callee(i8* %arg)
-
-; Positive test - arg is known non null
-define void @test(i8* nonnull %arg) {
-; CHECK-LABEL: @test
-; CHECK: call void @callee(i8* nonnull %arg)
-  call void @callee(i8* %arg)
-  ret void
-}
-
-
-; Negative test - arg is not known to be non null
-define void @test2(i8* %arg) {
-; CHECK-LABEL: @test2
-; CHECK: call void @callee(i8* %arg)
-  call void @callee(i8* %arg)
-  ret void
-}
-
-declare void @callee2(i8*, i8*, i8*)
-
-; Sanity check arg indexing
-define void @test3(i8* %arg1, i8* nonnull %arg2, i8* %arg3) {
-; CHECK-LABEL: @test3
-; CHECK: call void @callee2(i8* %arg1, i8* nonnull %arg2, i8* %arg3)
-  call void @callee2(i8* %arg1, i8* %arg2, i8* %arg3)
-  ret void
-}
-
-; Because of the way CallSite::paramHasAttribute looks at the callee 
-; directly, we will not set the attribute on the CallSite.  That's 
-; fine as long as all consumers use the same check. 
-define void @test4(i8* nonnull %arg) {
-; CHECK-LABEL: @test4
-; CHECK: call void @test4(i8* %arg)
-  call void @test4(i8* %arg)
-  ret void
-}
-
-
index 8be247228b8efb606feefec3eaa982a28b0f5848..27e487b4815e5e052ff476ad6cd0198b8e066572 100644 (file)
@@ -1265,7 +1265,7 @@ define i32 @test77(i1 %flag, i32* %x) {
 ; load does.
 ; CHECK-LABEL: @test77(
 ; CHECK: %[[A:.*]] = alloca i32, align 1
-; CHECK: call void @scribble_on_i32(i32* nonnull %[[A]])
+; CHECK: call void @scribble_on_i32(i32* %[[A]])
 ; CHECK: store i32 0, i32* %x
 ; CHECK: %[[P:.*]] = select i1 %flag, i32* %[[A]], i32* %x
 ; CHECK: load i32, i32* %[[P]]