blob: 5450609e06bb8cb07c42e622afc6ba22cb411fdc [file] [log] [blame]
Yaxun Liub34ec822017-04-11 17:24:23 +00001// RUN: %clang_cc1 -triple amdgcn---amdgiz -emit-llvm < %s | FileCheck -check-prefixes=CHECK,COM %s
2
Yaxun Liucbf647c2017-07-08 13:24:52 +00003// CHECK-DAG: @foo = common addrspace(1) global i32 0
Yaxun Liub34ec822017-04-11 17:24:23 +00004int foo;
5
Yaxun Liucbf647c2017-07-08 13:24:52 +00006// CHECK-DAG: @ban = common addrspace(1) global [10 x i32] zeroinitializer
Yaxun Liub34ec822017-04-11 17:24:23 +00007int ban[10];
8
Yaxun Liucbf647c2017-07-08 13:24:52 +00009// CHECK-DAG: @A = common addrspace(1) global i32* null
10// CHECK-DAG: @B = common addrspace(1) global i32* null
Yaxun Liub34ec822017-04-11 17:24:23 +000011int *A;
12int *B;
13
14// COM-LABEL: define i32 @test1()
Yaxun Liucbf647c2017-07-08 13:24:52 +000015// CHECK: load i32, i32* addrspacecast{{[^@]+}} @foo
Yaxun Liub34ec822017-04-11 17:24:23 +000016int test1() { return foo; }
17
18// COM-LABEL: define i32 @test2(i32 %i)
Yaxun Liu84744c12017-06-19 17:03:41 +000019// COM: %[[addr:.*]] = getelementptr
Yaxun Liu84744c12017-06-19 17:03:41 +000020// CHECK: load i32, i32* %[[addr]]
Yaxun Liub34ec822017-04-11 17:24:23 +000021// CHECK-NEXT: ret i32
22int test2(int i) { return ban[i]; }
23
24// COM-LABEL: define void @test3()
Yaxun Liucbf647c2017-07-08 13:24:52 +000025// CHECK: load i32*, i32** addrspacecast{{.*}} @B
Yaxun Liub34ec822017-04-11 17:24:23 +000026// CHECK: load i32, i32*
Yaxun Liucbf647c2017-07-08 13:24:52 +000027// CHECK: load i32*, i32** addrspacecast{{.*}} @A
Yaxun Liub34ec822017-04-11 17:24:23 +000028// CHECK: store i32 {{.*}}, i32*
29void test3() {
30 *A = *B;
31}
32
Yaxun Liub34ec822017-04-11 17:24:23 +000033// CHECK-LABEL: define void @test4(i32* %a)
Yaxun Liu25d1b432017-07-05 04:58:24 +000034// CHECK: %[[alloca:.*]] = alloca i32*, align 8, addrspace(5)
Yaxun Liu84744c12017-06-19 17:03:41 +000035// CHECK: %[[a_addr:.*]] = addrspacecast{{.*}} %[[alloca]] to i32**
36// CHECK: store i32* %a, i32** %[[a_addr]]
37// CHECK: %[[r0:.*]] = load i32*, i32** %[[a_addr]]
Yaxun Liub34ec822017-04-11 17:24:23 +000038// CHECK: %[[arrayidx:.*]] = getelementptr inbounds i32, i32* %[[r0]]
39// CHECK: store i32 0, i32* %[[arrayidx]]
40void test4(int *a) {
41 a[0] = 0;
42}