|
@@ -0,0 +1,58 @@
|
|
|
|
+// RUN: %clang_cc1 -triple amdgcn -emit-llvm < %s | FileCheck -check-prefixes=PIZ,COM %s
|
|
|
|
+// RUN: %clang_cc1 -triple amdgcn---amdgiz -emit-llvm < %s | FileCheck -check-prefixes=CHECK,COM %s
|
|
|
|
+
|
|
|
|
+// PIZ-DAG: @foo = common addrspace(4) global i32 0
|
|
|
|
+// CHECK-DAG: @foo = common global i32 0
|
|
|
|
+int foo;
|
|
|
|
+
|
|
|
|
+// PIZ-DAG: @ban = common addrspace(4) global [10 x i32] zeroinitializer
|
|
|
|
+// CHECK-DAG: @ban = common global [10 x i32] zeroinitializer
|
|
|
|
+int ban[10];
|
|
|
|
+
|
|
|
|
+// PIZ-DAG: @A = common addrspace(4) global i32 addrspace(4)* null
|
|
|
|
+// PIZ-DAG: @B = common addrspace(4) global i32 addrspace(4)* null
|
|
|
|
+// CHECK-DAG: @A = common global i32* null
|
|
|
|
+// CHECK-DAG: @B = common global i32* null
|
|
|
|
+int *A;
|
|
|
|
+int *B;
|
|
|
|
+
|
|
|
|
+// COM-LABEL: define i32 @test1()
|
|
|
|
+// PIZ: load i32, i32 addrspace(4)* @foo
|
|
|
|
+// CHECK: load i32, i32* @foo
|
|
|
|
+int test1() { return foo; }
|
|
|
|
+
|
|
|
|
+// COM-LABEL: define i32 @test2(i32 %i)
|
|
|
|
+// PIZ: load i32, i32 addrspace(4)*
|
|
|
|
+// PIZ-NEXT: ret i32
|
|
|
|
+// CHECK: load i32, i32*
|
|
|
|
+// CHECK-NEXT: ret i32
|
|
|
|
+int test2(int i) { return ban[i]; }
|
|
|
|
+
|
|
|
|
+// COM-LABEL: define void @test3()
|
|
|
|
+// PIZ: load i32 addrspace(4)*, i32 addrspace(4)* addrspace(4)* @B
|
|
|
|
+// PIZ: load i32, i32 addrspace(4)*
|
|
|
|
+// PIZ: load i32 addrspace(4)*, i32 addrspace(4)* addrspace(4)* @A
|
|
|
|
+// PIZ: store i32 {{.*}}, i32 addrspace(4)*
|
|
|
|
+// CHECK: load i32*, i32** @B
|
|
|
|
+// CHECK: load i32, i32*
|
|
|
|
+// CHECK: load i32*, i32** @A
|
|
|
|
+// CHECK: store i32 {{.*}}, i32*
|
|
|
|
+void test3() {
|
|
|
|
+ *A = *B;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+// PIZ-LABEL: define void @test4(i32 addrspace(4)* %a)
|
|
|
|
+// PIZ: %[[a_addr:.*]] = alloca i32 addrspace(4)*
|
|
|
|
+// PIZ: store i32 addrspace(4)* %a, i32 addrspace(4)** %[[a_addr]]
|
|
|
|
+// PIZ: %[[r0:.*]] = load i32 addrspace(4)*, i32 addrspace(4)** %[[a_addr]]
|
|
|
|
+// PIZ: %[[arrayidx:.*]] = getelementptr inbounds i32, i32 addrspace(4)* %[[r0]]
|
|
|
|
+// PIZ: store i32 0, i32 addrspace(4)* %[[arrayidx]]
|
|
|
|
+// CHECK-LABEL: define void @test4(i32* %a)
|
|
|
|
+// CHECK: %[[a_addr:.*]] = alloca i32*, align 4, addrspace(5)
|
|
|
|
+// CHECK: store i32* %a, i32* addrspace(5)* %[[a_addr]]
|
|
|
|
+// CHECK: %[[r0:.*]] = load i32*, i32* addrspace(5)* %[[a_addr]]
|
|
|
|
+// CHECK: %[[arrayidx:.*]] = getelementptr inbounds i32, i32* %[[r0]]
|
|
|
|
+// CHECK: store i32 0, i32* %[[arrayidx]]
|
|
|
|
+void test4(int *a) {
|
|
|
|
+ a[0] = 0;
|
|
|
|
+}
|