mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-10 22:00:58 +00:00
fc6ddd62bf
The original change broke clang side tests. I will be submitting those momentarily. This change includes post commit feedback on the original change from from Pete Cooper. Original Submission comments: If a parameter to a function is known non-null, use the existing parameter attributes to record that fact at the call site. This has no optimization benefit by itself - that I know of - but is an enabling change for http://reviews.llvm.org/D9129. Differential Revision: http://reviews.llvm.org/D9132 llvm-svn: 239849
22 lines
686 B
LLVM
22 lines
686 B
LLVM
; RUN: opt < %s -O3 -S | FileCheck %s
|
|
|
|
; Address space intrinsics were erroneously marked NoCapture, leading to bad
|
|
; optimizations (such as the store below being eliminated as dead code). This
|
|
; test makes sure we don't regress.
|
|
|
|
declare void @foo(i32 addrspace(1)*)
|
|
|
|
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-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
|
|
call void @foo(i32 addrspace(1)* %t2)
|
|
ret void
|
|
}
|
|
|