[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / Transforms / Attributor / value-simplify-gpu.ll
bloba7e0a92912090eb37d23fc05e403371c6edc1084
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --function-signature --check-attributes --check-globals
2 ; RUN: opt -aa-pipeline=basic-aa -passes=attributor -attributor-manifest-internal  -attributor-annotate-decl-cs  -S < %s | FileCheck %s --check-prefixes=CHECK,TUNIT
3 ; RUN: opt -aa-pipeline=basic-aa -passes=attributor-cgscc -attributor-manifest-internal  -attributor-annotate-decl-cs -S < %s | FileCheck %s --check-prefixes=CHECK,CGSCC
5 target triple = "amdgcn-amd-amdhsa"
7 %struct.ident_t = type { i32, i32, i32, i32, ptr }
8 @ReachableKernel = internal addrspace(3) global i32 3, align 4
9 @UnreachableKernel = internal addrspace(3) global i32 42, align 4
10 @ReachableKernelAS0 = internal global i32 7, align 4
11 @AS3OneKernelAtATime = internal addrspace(3) global i32 42, align 4
14 ; CHECK: @[[REACHABLEKERNEL:[a-zA-Z0-9_$"\\.-]+]] = internal addrspace(3) global i32 3, align 4
15 ; CHECK: @[[UNREACHABLEKERNEL:[a-zA-Z0-9_$"\\.-]+]] = internal addrspace(3) global i32 42, align 4
16 ; CHECK: @[[REACHABLEKERNELAS0:[a-zA-Z0-9_$"\\.-]+]] = internal global i32 7, align 4
17 ; CHECK: @[[AS3ONEKERNELATATIME:[a-zA-Z0-9_$"\\.-]+]] = internal addrspace(3) global i32 42, align 4
18 ; CHECK: @[[REACHABLENONKERNEL:[a-zA-Z0-9_$"\\.-]+]] = internal addrspace(3) global i32 0, align 4
19 ; CHECK: @[[UNREACHABLENONKERNEL:[a-zA-Z0-9_$"\\.-]+]] = internal addrspace(3) global i32 0, align 4
21 define dso_local void @kernel(i32 %C) norecurse "kernel" {
22 ; TUNIT: Function Attrs: norecurse nosync nounwind
23 ; TUNIT-LABEL: define {{[^@]+}}@kernel
24 ; TUNIT-SAME: (i32 [[C:%.*]]) #[[ATTR0:[0-9]+]] {
25 ; TUNIT-NEXT:  entry:
26 ; TUNIT-NEXT:    call void @level1Kernel(i32 [[C]]) #[[ATTR1:[0-9]+]]
27 ; TUNIT-NEXT:    ret void
29 ; CGSCC: Function Attrs: norecurse nosync nounwind
30 ; CGSCC-LABEL: define {{[^@]+}}@kernel
31 ; CGSCC-SAME: (i32 [[C:%.*]]) #[[ATTR0:[0-9]+]] {
32 ; CGSCC-NEXT:  entry:
33 ; CGSCC-NEXT:    call void @level1Kernel(i32 [[C]]) #[[ATTR4:[0-9]+]]
34 ; CGSCC-NEXT:    ret void
36 entry:
37   call void @level1Kernel(i32 %C)
38   ret void
41 define internal void @level1Kernel(i32 %C) {
42 ; TUNIT: Function Attrs: norecurse nosync nounwind
43 ; TUNIT-LABEL: define {{[^@]+}}@level1Kernel
44 ; TUNIT-SAME: (i32 [[C:%.*]]) #[[ATTR1]] {
45 ; TUNIT-NEXT:  entry:
46 ; TUNIT-NEXT:    call void @level2Kernelall_early() #[[ATTR4:[0-9]+]]
47 ; TUNIT-NEXT:    [[TOBOOL:%.*]] = icmp ne i32 [[C]], 0
48 ; TUNIT-NEXT:    br i1 [[TOBOOL]], label [[IF_THEN:%.*]], label [[IF_ELSE:%.*]]
49 ; TUNIT:       if.then:
50 ; TUNIT-NEXT:    call void @level2Kernela() #[[ATTR5:[0-9]+]]
51 ; TUNIT-NEXT:    br label [[IF_END:%.*]]
52 ; TUNIT:       if.else:
53 ; TUNIT-NEXT:    call void @level2Kernelb() #[[ATTR5]]
54 ; TUNIT-NEXT:    br label [[IF_END]]
55 ; TUNIT:       if.end:
56 ; TUNIT-NEXT:    call void @level2Kernelall_late() #[[ATTR6:[0-9]+]]
57 ; TUNIT-NEXT:    ret void
59 ; CGSCC: Function Attrs: norecurse nosync nounwind
60 ; CGSCC-LABEL: define {{[^@]+}}@level1Kernel
61 ; CGSCC-SAME: (i32 [[C:%.*]]) #[[ATTR1:[0-9]+]] {
62 ; CGSCC-NEXT:  entry:
63 ; CGSCC-NEXT:    call void @level2Kernelall_early() #[[ATTR5:[0-9]+]]
64 ; CGSCC-NEXT:    [[TOBOOL:%.*]] = icmp ne i32 [[C]], 0
65 ; CGSCC-NEXT:    br i1 [[TOBOOL]], label [[IF_THEN:%.*]], label [[IF_ELSE:%.*]]
66 ; CGSCC:       if.then:
67 ; CGSCC-NEXT:    call void @level2Kernela() #[[ATTR4]]
68 ; CGSCC-NEXT:    br label [[IF_END:%.*]]
69 ; CGSCC:       if.else:
70 ; CGSCC-NEXT:    call void @level2Kernelb() #[[ATTR4]]
71 ; CGSCC-NEXT:    br label [[IF_END]]
72 ; CGSCC:       if.end:
73 ; CGSCC-NEXT:    call void @level2Kernelall_late() #[[ATTR6:[0-9]+]]
74 ; CGSCC-NEXT:    ret void
76 entry:
77   call void @level2Kernelall_early()
78   %tobool = icmp ne i32 %C, 0
79   br i1 %tobool, label %if.then, label %if.else
81 if.then:                                          ; preds = %entry
82   call void @level2Kernela()
83   br label %if.end
85 if.else:                                          ; preds = %entry
86   call void @level2Kernelb()
87   br label %if.end
89 if.end:                                           ; preds = %if.else, %if.then
90   call void @level2Kernelall_late()
91   ret void
94 define internal void @level2Kernelall_early() {
95 ; CHECK: Function Attrs: mustprogress nofree norecurse nosync nounwind willreturn memory(write)
96 ; CHECK-LABEL: define {{[^@]+}}@level2Kernelall_early
97 ; CHECK-SAME: () #[[ATTR2:[0-9]+]] {
98 ; CHECK-NEXT:  entry:
99 ; CHECK-NEXT:    store i32 1, ptr @ReachableKernelAS0, align 4
100 ; CHECK-NEXT:    store i32 1, ptr addrspace(3) @ReachableKernel, align 4
101 ; CHECK-NEXT:    ret void
103 entry:
104   store i32 1, ptr @ReachableKernelAS0, align 4
105   store i32 1, ptr addrspacecast (ptr addrspace(3) @ReachableKernel to ptr), align 4
106   ret void
109 define internal void @level2Kernela() {
110 ; TUNIT: Function Attrs: norecurse nosync nounwind
111 ; TUNIT-LABEL: define {{[^@]+}}@level2Kernela
112 ; TUNIT-SAME: () #[[ATTR1]] {
113 ; TUNIT-NEXT:  entry:
114 ; TUNIT-NEXT:    [[TMP0:%.*]] = load i32, ptr addrspace(3) @ReachableKernel, align 4
115 ; TUNIT-NEXT:    [[TMP1:%.*]] = load i32, ptr @ReachableKernelAS0, align 4
116 ; TUNIT-NEXT:    [[TMP2:%.*]] = load i32, ptr addrspace(3) @UnreachableKernel, align 4
117 ; TUNIT-NEXT:    call void @use(i32 noundef [[TMP0]], i32 noundef [[TMP1]], i32 noundef [[TMP2]]) #[[ATTR7:[0-9]+]]
118 ; TUNIT-NEXT:    ret void
120 ; CGSCC: Function Attrs: nosync nounwind
121 ; CGSCC-LABEL: define {{[^@]+}}@level2Kernela
122 ; CGSCC-SAME: () #[[ATTR3:[0-9]+]] {
123 ; CGSCC-NEXT:  entry:
124 ; CGSCC-NEXT:    [[TMP0:%.*]] = load i32, ptr addrspace(3) @ReachableKernel, align 4
125 ; CGSCC-NEXT:    [[TMP1:%.*]] = load i32, ptr @ReachableKernelAS0, align 4
126 ; CGSCC-NEXT:    [[TMP2:%.*]] = load i32, ptr addrspace(3) @UnreachableKernel, align 4
127 ; CGSCC-NEXT:    call void @use(i32 noundef [[TMP0]], i32 noundef [[TMP1]], i32 noundef [[TMP2]]) #[[ATTR4]]
128 ; CGSCC-NEXT:    ret void
130 entry:
131   %0 = load i32, ptr addrspacecast (ptr addrspace(3) @ReachableKernel to ptr), align 4
132   %1 = load i32, ptr @ReachableKernelAS0, align 4
133   %2 = load i32, ptr addrspacecast (ptr addrspace(3) @UnreachableKernel to ptr), align 4
134   call void @use(i32 %0, i32 %1, i32 %2)
135   ret void
138 define internal void @level2Kernelb() {
139 ; TUNIT: Function Attrs: norecurse nosync nounwind
140 ; TUNIT-LABEL: define {{[^@]+}}@level2Kernelb
141 ; TUNIT-SAME: () #[[ATTR1]] {
142 ; TUNIT-NEXT:  entry:
143 ; TUNIT-NEXT:    [[TMP0:%.*]] = load i32, ptr addrspace(3) @ReachableKernel, align 4
144 ; TUNIT-NEXT:    [[TMP1:%.*]] = load i32, ptr @ReachableKernelAS0, align 4
145 ; TUNIT-NEXT:    [[TMP2:%.*]] = load i32, ptr addrspace(3) @UnreachableKernel, align 4
146 ; TUNIT-NEXT:    call void @use(i32 noundef [[TMP0]], i32 noundef [[TMP1]], i32 noundef [[TMP2]]) #[[ATTR7]]
147 ; TUNIT-NEXT:    ret void
149 ; CGSCC: Function Attrs: nosync nounwind
150 ; CGSCC-LABEL: define {{[^@]+}}@level2Kernelb
151 ; CGSCC-SAME: () #[[ATTR3]] {
152 ; CGSCC-NEXT:  entry:
153 ; CGSCC-NEXT:    [[TMP0:%.*]] = load i32, ptr addrspace(3) @ReachableKernel, align 4
154 ; CGSCC-NEXT:    [[TMP1:%.*]] = load i32, ptr @ReachableKernelAS0, align 4
155 ; CGSCC-NEXT:    [[TMP2:%.*]] = load i32, ptr addrspace(3) @UnreachableKernel, align 4
156 ; CGSCC-NEXT:    call void @use(i32 noundef [[TMP0]], i32 noundef [[TMP1]], i32 noundef [[TMP2]]) #[[ATTR4]]
157 ; CGSCC-NEXT:    ret void
159 entry:
160   %0 = load i32, ptr addrspacecast (ptr addrspace(3) @ReachableKernel to ptr), align 4
161   %1 = load i32, ptr @ReachableKernelAS0, align 4
162   %2 = load i32, ptr addrspacecast (ptr addrspace(3) @UnreachableKernel to ptr), align 4
163   call void @use(i32 %0, i32 %1, i32 %2)
164   ret void
167 define internal void @level2Kernelall_late() {
168 ; CHECK: Function Attrs: mustprogress nofree norecurse nosync nounwind willreturn memory(write)
169 ; CHECK-LABEL: define {{[^@]+}}@level2Kernelall_late
170 ; CHECK-SAME: () #[[ATTR2]] {
171 ; CHECK-NEXT:  entry:
172 ; CHECK-NEXT:    store i32 1, ptr addrspace(3) @UnreachableKernel, align 4
173 ; CHECK-NEXT:    ret void
175 entry:
176   store i32 1, ptr addrspacecast (ptr addrspace(3) @UnreachableKernel to ptr), align 4
177   ret void
180 @ReachableNonKernel = internal addrspace(3) global i32 0, align 4
181 @UnreachableNonKernel = internal addrspace(3) global i32 0, align 4
183 define dso_local void @non_kernel(i32 %C) norecurse {
184 ; TUNIT: Function Attrs: norecurse nosync nounwind
185 ; TUNIT-LABEL: define {{[^@]+}}@non_kernel
186 ; TUNIT-SAME: (i32 [[C:%.*]]) #[[ATTR1]] {
187 ; TUNIT-NEXT:  entry:
188 ; TUNIT-NEXT:    call void @level1(i32 [[C]]) #[[ATTR1]]
189 ; TUNIT-NEXT:    ret void
191 ; CGSCC: Function Attrs: norecurse nosync nounwind
192 ; CGSCC-LABEL: define {{[^@]+}}@non_kernel
193 ; CGSCC-SAME: (i32 [[C:%.*]]) #[[ATTR1]] {
194 ; CGSCC-NEXT:  entry:
195 ; CGSCC-NEXT:    call void @level1(i32 [[C]]) #[[ATTR4]]
196 ; CGSCC-NEXT:    ret void
198 entry:
199   call void @level1(i32 %C)
200   ret void
203 define internal void @level1(i32 %C) {
204 ; TUNIT: Function Attrs: norecurse nosync nounwind
205 ; TUNIT-LABEL: define {{[^@]+}}@level1
206 ; TUNIT-SAME: (i32 [[C:%.*]]) #[[ATTR1]] {
207 ; TUNIT-NEXT:  entry:
208 ; TUNIT-NEXT:    [[LOCAL:%.*]] = alloca i32, align 4
209 ; TUNIT-NEXT:    call void @level2all_early(ptr noalias nocapture nofree noundef nonnull writeonly align 4 dereferenceable(4) [[LOCAL]]) #[[ATTR4]]
210 ; TUNIT-NEXT:    [[TOBOOL:%.*]] = icmp ne i32 [[C]], 0
211 ; TUNIT-NEXT:    br i1 [[TOBOOL]], label [[IF_THEN:%.*]], label [[IF_ELSE:%.*]]
212 ; TUNIT:       if.then:
213 ; TUNIT-NEXT:    call void @level2a() #[[ATTR5]]
214 ; TUNIT-NEXT:    br label [[IF_END:%.*]]
215 ; TUNIT:       if.else:
216 ; TUNIT-NEXT:    call void @level2b() #[[ATTR5]]
217 ; TUNIT-NEXT:    br label [[IF_END]]
218 ; TUNIT:       if.end:
219 ; TUNIT-NEXT:    call void @level2all_late(ptr noalias nocapture nofree noundef nonnull writeonly align 4 dereferenceable(4) [[LOCAL]]) #[[ATTR6]]
220 ; TUNIT-NEXT:    ret void
222 ; CGSCC: Function Attrs: norecurse nosync nounwind
223 ; CGSCC-LABEL: define {{[^@]+}}@level1
224 ; CGSCC-SAME: (i32 [[C:%.*]]) #[[ATTR1]] {
225 ; CGSCC-NEXT:  entry:
226 ; CGSCC-NEXT:    [[LOCAL:%.*]] = alloca i32, align 4
227 ; CGSCC-NEXT:    call void @level2all_early(ptr noalias nocapture nofree noundef nonnull writeonly align 4 dereferenceable(4) [[LOCAL]]) #[[ATTR5]]
228 ; CGSCC-NEXT:    [[TOBOOL:%.*]] = icmp ne i32 [[C]], 0
229 ; CGSCC-NEXT:    br i1 [[TOBOOL]], label [[IF_THEN:%.*]], label [[IF_ELSE:%.*]]
230 ; CGSCC:       if.then:
231 ; CGSCC-NEXT:    call void @level2a(ptr noalias nocapture nofree noundef nonnull readonly align 4 dereferenceable(4) [[LOCAL]]) #[[ATTR4]]
232 ; CGSCC-NEXT:    br label [[IF_END:%.*]]
233 ; CGSCC:       if.else:
234 ; CGSCC-NEXT:    call void @level2b(ptr noalias nocapture nofree noundef nonnull readonly align 4 dereferenceable(4) [[LOCAL]]) #[[ATTR4]]
235 ; CGSCC-NEXT:    br label [[IF_END]]
236 ; CGSCC:       if.end:
237 ; CGSCC-NEXT:    call void @level2all_late(ptr noalias nocapture nofree noundef nonnull writeonly align 4 dereferenceable(4) [[LOCAL]]) #[[ATTR6]]
238 ; CGSCC-NEXT:    ret void
240 entry:
241   %local = alloca i32
242   call void @level2all_early(ptr %local)
243   %tobool = icmp ne i32 %C, 0
244   br i1 %tobool, label %if.then, label %if.else
246 if.then:                                          ; preds = %entry
247   call void @level2a(ptr %local)
248   br label %if.end
250 if.else:                                          ; preds = %entry
251   call void @level2b(ptr %local)
252   br label %if.end
254 if.end:                                           ; preds = %if.else, %if.then
255   call void @level2all_late(ptr %local)
256   ret void
259 define internal void @level2all_early(ptr %addr) {
260 ; TUNIT: Function Attrs: mustprogress nofree norecurse nosync nounwind willreturn memory(write)
261 ; TUNIT-LABEL: define {{[^@]+}}@level2all_early
262 ; TUNIT-SAME: (ptr noalias nocapture nofree noundef nonnull writeonly align 4 dereferenceable(4) [[ADDR:%.*]]) #[[ATTR2]] {
263 ; TUNIT-NEXT:  entry:
264 ; TUNIT-NEXT:    store i32 1, ptr addrspace(3) @ReachableNonKernel, align 4
265 ; TUNIT-NEXT:    ret void
267 ; CGSCC: Function Attrs: mustprogress nofree norecurse nosync nounwind willreturn memory(write)
268 ; CGSCC-LABEL: define {{[^@]+}}@level2all_early
269 ; CGSCC-SAME: (ptr nocapture nofree noundef nonnull writeonly align 4 dereferenceable(4) [[ADDR:%.*]]) #[[ATTR2]] {
270 ; CGSCC-NEXT:  entry:
271 ; CGSCC-NEXT:    store i32 1, ptr addrspace(3) @ReachableNonKernel, align 4
272 ; CGSCC-NEXT:    store i32 17, ptr [[ADDR]], align 4
273 ; CGSCC-NEXT:    ret void
275 entry:
276   store i32 1, ptr addrspacecast (ptr addrspace(3) @ReachableNonKernel to ptr), align 4
277   store i32 17, ptr %addr, align 4
278   ret void
281 define internal void @level2a(ptr %addr) {
282 ; TUNIT: Function Attrs: norecurse nosync nounwind memory(readwrite, argmem: none)
283 ; TUNIT-LABEL: define {{[^@]+}}@level2a
284 ; TUNIT-SAME: () #[[ATTR3:[0-9]+]] {
285 ; TUNIT-NEXT:  entry:
286 ; TUNIT-NEXT:    [[TMP0:%.*]] = load i32, ptr addrspace(3) @ReachableNonKernel, align 4
287 ; TUNIT-NEXT:    [[TMP1:%.*]] = load i32, ptr addrspace(3) @UnreachableNonKernel, align 4
288 ; TUNIT-NEXT:    call void @use(i32 noundef [[TMP0]], i32 noundef [[TMP1]], i32 17) #[[ATTR7]]
289 ; TUNIT-NEXT:    ret void
291 ; CGSCC: Function Attrs: nosync nounwind
292 ; CGSCC-LABEL: define {{[^@]+}}@level2a
293 ; CGSCC-SAME: (ptr nocapture nofree noundef nonnull readonly align 4 dereferenceable(4) [[ADDR:%.*]]) #[[ATTR3]] {
294 ; CGSCC-NEXT:  entry:
295 ; CGSCC-NEXT:    [[TMP0:%.*]] = load i32, ptr addrspace(3) @ReachableNonKernel, align 4
296 ; CGSCC-NEXT:    [[TMP1:%.*]] = load i32, ptr addrspace(3) @UnreachableNonKernel, align 4
297 ; CGSCC-NEXT:    [[QQQQ2:%.*]] = load i32, ptr [[ADDR]], align 4
298 ; CGSCC-NEXT:    call void @use(i32 noundef [[TMP0]], i32 noundef [[TMP1]], i32 [[QQQQ2]]) #[[ATTR4]]
299 ; CGSCC-NEXT:    ret void
301 entry:
302   %0 = load i32, ptr addrspacecast (ptr addrspace(3) @ReachableNonKernel to ptr), align 4
303   %1 = load i32, ptr addrspacecast (ptr addrspace(3) @UnreachableNonKernel to ptr), align 4
304   %qqqq2 = load i32, ptr %addr
305   call void @use(i32 %0, i32 %1, i32 %qqqq2)
306   ret void
309 define internal void @level2b(ptr %addr) {
310 ; TUNIT: Function Attrs: norecurse nosync nounwind memory(readwrite, argmem: none)
311 ; TUNIT-LABEL: define {{[^@]+}}@level2b
312 ; TUNIT-SAME: () #[[ATTR3]] {
313 ; TUNIT-NEXT:  entry:
314 ; TUNIT-NEXT:    [[TMP0:%.*]] = load i32, ptr addrspace(3) @ReachableNonKernel, align 4
315 ; TUNIT-NEXT:    [[TMP1:%.*]] = load i32, ptr addrspace(3) @UnreachableNonKernel, align 4
316 ; TUNIT-NEXT:    call void @use(i32 noundef [[TMP0]], i32 noundef [[TMP1]], i32 17) #[[ATTR7]]
317 ; TUNIT-NEXT:    ret void
319 ; CGSCC: Function Attrs: nosync nounwind
320 ; CGSCC-LABEL: define {{[^@]+}}@level2b
321 ; CGSCC-SAME: (ptr nocapture nofree noundef nonnull readonly align 4 dereferenceable(4) [[ADDR:%.*]]) #[[ATTR3]] {
322 ; CGSCC-NEXT:  entry:
323 ; CGSCC-NEXT:    [[TMP0:%.*]] = load i32, ptr addrspace(3) @ReachableNonKernel, align 4
324 ; CGSCC-NEXT:    [[TMP1:%.*]] = load i32, ptr addrspace(3) @UnreachableNonKernel, align 4
325 ; CGSCC-NEXT:    [[TMP2:%.*]] = load i32, ptr [[ADDR]], align 4
326 ; CGSCC-NEXT:    call void @use(i32 noundef [[TMP0]], i32 noundef [[TMP1]], i32 [[TMP2]]) #[[ATTR4]]
327 ; CGSCC-NEXT:    ret void
329 entry:
330   %0 = load i32, ptr addrspacecast (ptr addrspace(3) @ReachableNonKernel to ptr), align 4
331   %1 = load i32, ptr addrspacecast (ptr addrspace(3) @UnreachableNonKernel to ptr), align 4
332   %2 = load i32, ptr %addr
333   call void @use(i32 %0, i32 %1, i32 %2)
334   ret void
337 define internal void @level2all_late(ptr %addr) {
338 ; TUNIT: Function Attrs: mustprogress nofree norecurse nosync nounwind willreturn memory(write)
339 ; TUNIT-LABEL: define {{[^@]+}}@level2all_late
340 ; TUNIT-SAME: (ptr noalias nocapture nofree noundef nonnull writeonly align 4 dereferenceable(4) [[ADDR:%.*]]) #[[ATTR2]] {
341 ; TUNIT-NEXT:  entry:
342 ; TUNIT-NEXT:    store i32 1, ptr addrspace(3) @UnreachableNonKernel, align 4
343 ; TUNIT-NEXT:    ret void
345 ; CGSCC: Function Attrs: mustprogress nofree norecurse nosync nounwind willreturn memory(write)
346 ; CGSCC-LABEL: define {{[^@]+}}@level2all_late
347 ; CGSCC-SAME: (ptr noalias nocapture nofree noundef nonnull writeonly align 4 dereferenceable(4) [[ADDR:%.*]]) #[[ATTR2]] {
348 ; CGSCC-NEXT:  entry:
349 ; CGSCC-NEXT:    store i32 1, ptr addrspace(3) @UnreachableNonKernel, align 4
350 ; CGSCC-NEXT:    store i32 5, ptr [[ADDR]], align 4
351 ; CGSCC-NEXT:    ret void
353 entry:
354   store i32 1, ptr addrspacecast (ptr addrspace(3) @UnreachableNonKernel to ptr), align 4
355   store i32 5, ptr %addr, align 4
356   ret void
359 define dso_local void @kernel2(i32 %C) norecurse "kernel" {
360 ; TUNIT: Function Attrs: norecurse nosync nounwind
361 ; TUNIT-LABEL: define {{[^@]+}}@kernel2
362 ; TUNIT-SAME: (i32 [[C:%.*]]) #[[ATTR0]] {
363 ; TUNIT-NEXT:    [[I:%.*]] = icmp eq i32 [[C]], 42
364 ; TUNIT-NEXT:    br i1 [[I]], label [[T:%.*]], label [[F:%.*]]
365 ; TUNIT:       t:
366 ; TUNIT-NEXT:    store i32 333, ptr addrspace(3) @AS3OneKernelAtATime, align 4
367 ; TUNIT-NEXT:    br label [[F]]
368 ; TUNIT:       f:
369 ; TUNIT-NEXT:    [[L:%.*]] = load i32, ptr addrspace(3) @AS3OneKernelAtATime, align 4
370 ; TUNIT-NEXT:    call void @use(i32 noundef [[L]], i32 noundef [[L]], i32 noundef [[L]]) #[[ATTR7]]
371 ; TUNIT-NEXT:    ret void
373 ; CGSCC: Function Attrs: norecurse nosync nounwind
374 ; CGSCC-LABEL: define {{[^@]+}}@kernel2
375 ; CGSCC-SAME: (i32 [[C:%.*]]) #[[ATTR0]] {
376 ; CGSCC-NEXT:    [[I:%.*]] = icmp eq i32 [[C]], 42
377 ; CGSCC-NEXT:    br i1 [[I]], label [[T:%.*]], label [[F:%.*]]
378 ; CGSCC:       t:
379 ; CGSCC-NEXT:    store i32 333, ptr addrspace(3) @AS3OneKernelAtATime, align 4
380 ; CGSCC-NEXT:    br label [[F]]
381 ; CGSCC:       f:
382 ; CGSCC-NEXT:    [[L:%.*]] = load i32, ptr addrspace(3) @AS3OneKernelAtATime, align 4
383 ; CGSCC-NEXT:    call void @use(i32 noundef [[L]], i32 noundef [[L]], i32 noundef [[L]]) #[[ATTR4]]
384 ; CGSCC-NEXT:    ret void
386   %i = icmp eq i32 %C, 42
387   br i1 %i, label %t, label %f
389   store i32 333, ptr addrspace(3) @AS3OneKernelAtATime
390   br label %f
392   %l = load i32, ptr addrspace(3) @AS3OneKernelAtATime
393   call void @use(i32 %l,i32 %l, i32 %l)
394   ret void
397 define dso_local void @kernel3(i32 %C) norecurse "kernel" {
398 ; TUNIT: Function Attrs: norecurse nosync nounwind
399 ; TUNIT-LABEL: define {{[^@]+}}@kernel3
400 ; TUNIT-SAME: (i32 [[C:%.*]]) #[[ATTR0]] {
401 ; TUNIT-NEXT:    [[I:%.*]] = icmp eq i32 [[C]], 42
402 ; TUNIT-NEXT:    br i1 [[I]], label [[T:%.*]], label [[F:%.*]]
403 ; TUNIT:       t:
404 ; TUNIT-NEXT:    call void @use(i32 noundef 42, i32 noundef 42, i32 noundef 42) #[[ATTR7]]
405 ; TUNIT-NEXT:    ret void
406 ; TUNIT:       f:
407 ; TUNIT-NEXT:    ret void
409 ; CGSCC: Function Attrs: norecurse nosync nounwind
410 ; CGSCC-LABEL: define {{[^@]+}}@kernel3
411 ; CGSCC-SAME: (i32 [[C:%.*]]) #[[ATTR0]] {
412 ; CGSCC-NEXT:    [[I:%.*]] = icmp eq i32 [[C]], 42
413 ; CGSCC-NEXT:    br i1 [[I]], label [[T:%.*]], label [[F:%.*]]
414 ; CGSCC:       t:
415 ; CGSCC-NEXT:    call void @use(i32 noundef 42, i32 noundef 42, i32 noundef 42) #[[ATTR4]]
416 ; CGSCC-NEXT:    ret void
417 ; CGSCC:       f:
418 ; CGSCC-NEXT:    ret void
420   %i = icmp eq i32 %C, 42
421   br i1 %i, label %t, label %f
423   %l = load i32, ptr addrspace(3) @AS3OneKernelAtATime
424   call void @use(i32 %l,i32 %l, i32 %l)
425   ret void
427   ret void
430 declare dso_local void @use(i32, i32, i32) nosync norecurse nounwind
433 ; TUNIT: attributes #[[ATTR0]] = { norecurse nosync nounwind "kernel" }
434 ; TUNIT: attributes #[[ATTR1]] = { norecurse nosync nounwind }
435 ; TUNIT: attributes #[[ATTR2]] = { mustprogress nofree norecurse nosync nounwind willreturn memory(write) }
436 ; TUNIT: attributes #[[ATTR3]] = { norecurse nosync nounwind memory(readwrite, argmem: none) }
437 ; TUNIT: attributes #[[ATTR4]] = { nofree nosync nounwind willreturn memory(write) }
438 ; TUNIT: attributes #[[ATTR5]] = { nosync nounwind }
439 ; TUNIT: attributes #[[ATTR6]] = { nosync nounwind memory(write) }
440 ; TUNIT: attributes #[[ATTR7]] = { nounwind }
442 ; CGSCC: attributes #[[ATTR0]] = { norecurse nosync nounwind "kernel" }
443 ; CGSCC: attributes #[[ATTR1]] = { norecurse nosync nounwind }
444 ; CGSCC: attributes #[[ATTR2]] = { mustprogress nofree norecurse nosync nounwind willreturn memory(write) }
445 ; CGSCC: attributes #[[ATTR3]] = { nosync nounwind }
446 ; CGSCC: attributes #[[ATTR4]] = { nounwind }
447 ; CGSCC: attributes #[[ATTR5]] = { nofree nounwind willreturn memory(write) }
448 ; CGSCC: attributes #[[ATTR6]] = { nounwind memory(write) }