Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / AMDGPU / hsa-metadata-hostcall-v5.ll
blobbc9b43716642d78142b2bc183d976dcd89371c9a
1 ; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx900 -filetype=obj -o - < %s | llvm-readelf --notes - | FileCheck %s
2 ; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx900 < %s | FileCheck --check-prefix=CHECK %s
4 declare void @function1()
6 declare void @function2() #0
8 ; Function Attrs: noinline
9 define void @function3(ptr addrspace(4) %argptr, ptr addrspace(1) %sink) #2 {
10   store ptr addrspace(4) %argptr, ptr addrspace(1) %sink, align 8
11   ret void
14 ; Function Attrs: noinline
15 define void @function4(i64 %arg, ptr %a) #2 {
16   store i64 %arg, ptr %a
17   ret void
20 ; Function Attrs: noinline
21 define void @function5(ptr addrspace(4) %ptr, ptr %sink) #2 {
22   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 64
23   %x = load i64, ptr addrspace(4) %gep
24   store i64 %x, ptr %sink
25   ret void
28 ; Function Attrs: nounwind readnone speculatable willreturn
29 declare align 4 ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr() #1
31 ; CHECK: amdhsa.kernels:
32 ; CHECK:  - .args:
33 ; CHECK-NOT: hidden_hostcall_buffer
34 ; CHECK-LABEL:    .name:           test_kernel10
35 define amdgpu_kernel void @test_kernel10(ptr %a) {
36   store i8 3, ptr %a, align 1
37   ret void
40 ; Call to an extern function
42 ; CHECK:  - .args:
43 ; CHECK: hidden_hostcall_buffer
44 ; CHECK-LABEL:    .name:           test_kernel20
45 define amdgpu_kernel void @test_kernel20(ptr %a) {
46   call void @function1()
47   store i8 3, ptr %a, align 1
48   ret void
51 ; Explicit attribute on kernel
53 ; CHECK:  - .args:
54 ; CHECK-NOT: hidden_hostcall_buffer
55 ; CHECK-LABEL:    .name:           test_kernel21
56 define amdgpu_kernel void @test_kernel21(ptr %a) #0 {
57   call void @function1()
58   store i8 3, ptr %a, align 1
59   ret void
62 ; Explicit attribute on extern callee
64 ; CHECK:  - .args:
65 ; CHECK-NOT: hidden_hostcall_buffer
66 ; CHECK-LABEL:    .name:           test_kernel22
67 define amdgpu_kernel void @test_kernel22(ptr %a) {
68   call void @function2()
69   store i8 3, ptr %a, align 1
70   ret void
73 ; Access more bytes than the pointer size
75 ; CHECK:  - .args:
76 ; CHECK: hidden_hostcall_buffer
77 ; CHECK-LABEL:    .name:           test_kernel30
78 define amdgpu_kernel void @test_kernel30(ptr %a) {
79   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
80   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 72
81   %x = load i128, ptr addrspace(4) %gep
82   store i128 %x, ptr %a
83   ret void
86 ; Typical load of hostcall buffer pointer
88 ; CHECK:  - .args:
89 ; CHECK: hidden_hostcall_buffer
90 ; CHECK-LABEL:    .name:           test_kernel40
91 define amdgpu_kernel void @test_kernel40(ptr %a) {
92   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
93   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 80
94   %x = load i64, ptr addrspace(4) %gep
95   store i64 %x, ptr %a
96   ret void
99 ; Typical usage, overriden by explicit attribute on kernel
101 ; CHECK:  - .args:
102 ; CHECK-NOT: hidden_hostcall_buffer
103 ; CHECK-LABEL:    .name:           test_kernel41
104 define amdgpu_kernel void @test_kernel41(ptr %a) #0 {
105   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
106   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 80
107   %x = load i64, ptr addrspace(4) %gep
108   store i64 %x, ptr %a
109   ret void
112 ; Access to implicit arg before the hostcall pointer
114 ; CHECK:  - .args:
115 ; CHECK-NOT: hidden_hostcall_buffer
116 ; CHECK-LABEL:    .name:           test_kernel42
117 define amdgpu_kernel void @test_kernel42(ptr %a) {
118   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
119   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 72
120   %x = load i64, ptr addrspace(4) %gep
121   store i64 %x, ptr %a
122   ret void
125 ; Access to implicit arg after the hostcall pointer
127 ; CHECK:  - .args:
128 ; CHECK-NOT: hidden_hostcall_buffer
129 ; CHECK-LABEL:    .name:           test_kernel43
130 define amdgpu_kernel void @test_kernel43(ptr %a) {
131   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
132   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 88
133   %x = load i64, ptr addrspace(4) %gep
134   store i64 %x, ptr %a
135   ret void
138 ; Accessing a byte just before the hostcall pointer
140 ; CHECK:  - .args:
141 ; CHECK-NOT: hidden_hostcall_buffer
142 ; CHECK-LABEL:    .name:           test_kernel44
143 define amdgpu_kernel void @test_kernel44(ptr %a) {
144   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
145   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 79
146   %x = load i8, ptr addrspace(4) %gep, align 1
147   store i8 %x, ptr %a, align 1
148   ret void
151 ; Accessing a byte inside the hostcall pointer
153 ; CHECK:  - .args:
154 ; CHECK: hidden_hostcall_buffer
155 ; CHECK-LABEL:    .name:           test_kernel45
156 define amdgpu_kernel void @test_kernel45(ptr %a) {
157   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
158   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 80
159   %x = load i8, ptr addrspace(4) %gep, align 1
160   store i8 %x, ptr %a, align 1
161   ret void
164 ; Accessing a byte inside the hostcall pointer
166 ; CHECK:  - .args:
167 ; CHECK: hidden_hostcall_buffer
168 ; CHECK-LABEL:    .name:           test_kernel46
169 define amdgpu_kernel void @test_kernel46(ptr %a) {
170   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
171   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 87
172   %x = load i8, ptr addrspace(4) %gep, align 1
173   store i8 %x, ptr %a, align 1
174   ret void
177 ; Accessing a byte just after the hostcall pointer
179 ; CHECK:  - .args:
180 ; CHECK-NOT: hidden_hostcall_buffer
181 ; CHECK-LABEL:    .name:           test_kernel47
182 define amdgpu_kernel void @test_kernel47(ptr %a) {
183   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
184   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 88
185   %x = load i8, ptr addrspace(4) %gep, align 1
186   store i8 %x, ptr %a, align 1
187   ret void
190 ; Access with an unknown offset
192 ; CHECK:  - .args:
193 ; CHECK: hidden_hostcall_buffer
194 ; CHECK-LABEL:    .name:           test_kernel50
195 define amdgpu_kernel void @test_kernel50(ptr %a, i32 %b) {
196   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
197   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i32 %b
198   %x = load i8, ptr addrspace(4) %gep, align 1
199   store i8 %x, ptr %a, align 1
200   ret void
203 ; Multiple geps reaching the hostcall pointer argument.
205 ; CHECK:  - .args:
206 ; CHECK: hidden_hostcall_buffer
207 ; CHECK-LABEL:    .name:           test_kernel51
208 define amdgpu_kernel void @test_kernel51(ptr %a) {
209   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
210   %gep1 = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 16
211   %gep2 = getelementptr inbounds i8, ptr addrspace(4) %gep1, i64 64
212   %x = load i8, ptr addrspace(4) %gep2, align 1
213   store i8 %x, ptr %a, align 1
214   ret void
217 ; Multiple geps not reaching the hostcall pointer argument.
219 ; CHECK:  - .args:
220 ; CHECK-NOT: hidden_hostcall_buffer
221 ; CHECK-LABEL:    .name:           test_kernel52
222 define amdgpu_kernel void @test_kernel52(ptr %a) {
223   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
224   %gep1 = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 16
225   %gep2 = getelementptr inbounds i8, ptr addrspace(4) %gep1, i64 16
226   %x = load i8, ptr addrspace(4) %gep2, align 1
227   store i8 %x, ptr %a, align 1
228   ret void
231 ; Hostcall pointer used inside a function call
233 ; CHECK:  - .args:
234 ; CHECK: hidden_hostcall_buffer
235 ; CHECK-LABEL:    .name:           test_kernel60
236 define amdgpu_kernel void @test_kernel60(ptr %a) #2 {
237   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
238   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 80
239   %x = load i64, ptr addrspace(4) %gep
240   call void @function4(i64 %x, ptr %a)
241   ret void
244 ; Hostcall pointer retrieved inside a function call; chain of geps
246 ; CHECK:  - .args:
247 ; CHECK: hidden_hostcall_buffer
248 ; CHECK-LABEL:    .name:           test_kernel61
249 define amdgpu_kernel void @test_kernel61(ptr %a) #2 {
250   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
251   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i64 16
252   call void @function5(ptr addrspace(4) %gep, ptr %a)
253   ret void
256 ; Pointer captured
258 ; CHECK:  - .args:
259 ; CHECK: hidden_hostcall_buffer
260 ; CHECK-LABEL:    .name:           test_kernel70
261 define amdgpu_kernel void @test_kernel70(ptr addrspace(1) %sink) #2 {
262   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
263   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i32 42
264   store ptr addrspace(4) %gep, ptr addrspace(1) %sink, align 8
265   ret void
268 ; Pointer captured inside function call
270 ; CHECK:  - .args:
271 ; CHECK: hidden_hostcall_buffer
272 ; CHECK-LABEL:    .name:           test_kernel71
273 define amdgpu_kernel void @test_kernel71(ptr addrspace(1) %sink) #2 {
274   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
275   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i32 42
276   call void @function3(ptr addrspace(4) %gep, ptr addrspace(1) %sink)
277   ret void
280 ; Ineffective pointer capture
282 ; CHECK:  - .args:
283 ; CHECK-NOT: hidden_hostcall_buffer
284 ; CHECK-LABEL:    .name:           test_kernel72
285 define amdgpu_kernel void @test_kernel72() #2 {
286   %ptr = tail call ptr addrspace(4) @llvm.amdgcn.implicitarg.ptr()
287   %gep = getelementptr inbounds i8, ptr addrspace(4) %ptr, i32 42
288   store ptr addrspace(4) %gep, ptr addrspace(1) undef, align 8
289   ret void
292 attributes #0 = { "amdgpu-no-hostcall-ptr" }
293 attributes #1 = { nounwind readnone speculatable willreturn }
294 attributes #2 = { noinline }
296 !llvm.module.flags = !{!0}
297 !0 = !{i32 1, !"amdgpu_code_object_version", i32 500}