1 ; RUN: llc -march=amdgcn < %s | FileCheck -check-prefixes=GCN,SI %s
2 ; RUN: llc -march=amdgcn -mcpu=tonga < %s | FileCheck -check-prefixes=GCN,VI %s
3 ; RUN: llc -march=amdgcn -mcpu=gfx900 < %s | FileCheck -check-prefixes=GCN,GFX9 %s
5 ; GCN-LABEL: {{^}}v_test_imin3_slt_i32:
7 define amdgpu_kernel void @v_test_imin3_slt_i32(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
8 %tid = call i32 @llvm.amdgcn.workitem.id.x()
9 %gep0 = getelementptr i32, ptr addrspace(1) %aptr, i32 %tid
10 %gep1 = getelementptr i32, ptr addrspace(1) %bptr, i32 %tid
11 %gep2 = getelementptr i32, ptr addrspace(1) %cptr, i32 %tid
12 %outgep = getelementptr i32, ptr addrspace(1) %out, i32 %tid
13 %a = load i32, ptr addrspace(1) %gep0
14 %b = load i32, ptr addrspace(1) %gep1
15 %c = load i32, ptr addrspace(1) %gep2
16 %icmp0 = icmp slt i32 %a, %b
17 %i0 = select i1 %icmp0, i32 %a, i32 %b
18 %icmp1 = icmp slt i32 %i0, %c
19 %i1 = select i1 %icmp1, i32 %i0, i32 %c
20 store i32 %i1, ptr addrspace(1) %outgep
24 ; GCN-LABEL: {{^}}v_test_umin3_ult_i32:
26 define amdgpu_kernel void @v_test_umin3_ult_i32(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
27 %tid = call i32 @llvm.amdgcn.workitem.id.x()
28 %gep0 = getelementptr i32, ptr addrspace(1) %aptr, i32 %tid
29 %gep1 = getelementptr i32, ptr addrspace(1) %bptr, i32 %tid
30 %gep2 = getelementptr i32, ptr addrspace(1) %cptr, i32 %tid
31 %outgep = getelementptr i32, ptr addrspace(1) %out, i32 %tid
32 %a = load i32, ptr addrspace(1) %gep0
33 %b = load i32, ptr addrspace(1) %gep1
34 %c = load i32, ptr addrspace(1) %gep2
35 %icmp0 = icmp ult i32 %a, %b
36 %i0 = select i1 %icmp0, i32 %a, i32 %b
37 %icmp1 = icmp ult i32 %i0, %c
38 %i1 = select i1 %icmp1, i32 %i0, i32 %c
39 store i32 %i1, ptr addrspace(1) %outgep
43 ; GCN-LABEL: {{^}}v_test_umin_umin_umin:
46 define amdgpu_kernel void @v_test_umin_umin_umin(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
47 %tid = call i32 @llvm.amdgcn.workitem.id.x()
48 %tid2 = mul i32 %tid, 2
49 %gep0 = getelementptr i32, ptr addrspace(1) %aptr, i32 %tid
50 %gep1 = getelementptr i32, ptr addrspace(1) %bptr, i32 %tid
51 %gep2 = getelementptr i32, ptr addrspace(1) %cptr, i32 %tid
53 %gep3 = getelementptr i32, ptr addrspace(1) %aptr, i32 %tid2
54 %gep4 = getelementptr i32, ptr addrspace(1) %bptr, i32 %tid2
55 %gep5 = getelementptr i32, ptr addrspace(1) %cptr, i32 %tid2
57 %outgep0 = getelementptr i32, ptr addrspace(1) %out, i32 %tid
58 %outgep1 = getelementptr i32, ptr addrspace(1) %out, i32 %tid2
60 %a = load i32, ptr addrspace(1) %gep0
61 %b = load i32, ptr addrspace(1) %gep1
62 %c = load i32, ptr addrspace(1) %gep2
63 %d = load i32, ptr addrspace(1) %gep3
65 %icmp0 = icmp slt i32 %a, %b
66 %i0 = select i1 %icmp0, i32 %a, i32 %b
68 %icmp1 = icmp slt i32 %c, %d
69 %i1 = select i1 %icmp1, i32 %c, i32 %d
71 %icmp2 = icmp slt i32 %i0, %i1
72 %i2 = select i1 %icmp2, i32 %i0, i32 %i1
74 store i32 %i2, ptr addrspace(1) %outgep1
78 ; GCN-LABEL: {{^}}v_test_umin3_2_uses:
80 define amdgpu_kernel void @v_test_umin3_2_uses(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
81 %tid = call i32 @llvm.amdgcn.workitem.id.x()
82 %tid2 = mul i32 %tid, 2
83 %gep0 = getelementptr i32, ptr addrspace(1) %aptr, i32 %tid
84 %gep1 = getelementptr i32, ptr addrspace(1) %bptr, i32 %tid
85 %gep2 = getelementptr i32, ptr addrspace(1) %cptr, i32 %tid
87 %gep3 = getelementptr i32, ptr addrspace(1) %aptr, i32 %tid2
88 %gep4 = getelementptr i32, ptr addrspace(1) %bptr, i32 %tid2
89 %gep5 = getelementptr i32, ptr addrspace(1) %cptr, i32 %tid2
91 %outgep0 = getelementptr i32, ptr addrspace(1) %out, i32 %tid
92 %outgep1 = getelementptr i32, ptr addrspace(1) %out, i32 %tid2
94 %a = load i32, ptr addrspace(1) %gep0
95 %b = load i32, ptr addrspace(1) %gep1
96 %c = load i32, ptr addrspace(1) %gep2
97 %d = load i32, ptr addrspace(1) %gep3
99 %icmp0 = icmp slt i32 %a, %b
100 %i0 = select i1 %icmp0, i32 %a, i32 %b
102 %icmp1 = icmp slt i32 %c, %d
103 %i1 = select i1 %icmp1, i32 %c, i32 %d
105 %icmp2 = icmp slt i32 %i0, %c
106 %i2 = select i1 %icmp2, i32 %i0, i32 %c
108 store i32 %i2, ptr addrspace(1) %outgep0
109 store i32 %i0, ptr addrspace(1) %outgep1
113 ; GCN-LABEL: {{^}}v_test_imin3_slt_i16:
120 define amdgpu_kernel void @v_test_imin3_slt_i16(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
121 %tid = call i32 @llvm.amdgcn.workitem.id.x()
122 %gep0 = getelementptr i16, ptr addrspace(1) %aptr, i32 %tid
123 %gep1 = getelementptr i16, ptr addrspace(1) %bptr, i32 %tid
124 %gep2 = getelementptr i16, ptr addrspace(1) %cptr, i32 %tid
125 %outgep = getelementptr i16, ptr addrspace(1) %out, i32 %tid
126 %a = load i16, ptr addrspace(1) %gep0
127 %b = load i16, ptr addrspace(1) %gep1
128 %c = load i16, ptr addrspace(1) %gep2
129 %icmp0 = icmp slt i16 %a, %b
130 %i0 = select i1 %icmp0, i16 %a, i16 %b
131 %icmp1 = icmp slt i16 %i0, %c
132 %i1 = select i1 %icmp1, i16 %i0, i16 %c
133 store i16 %i1, ptr addrspace(1) %outgep
137 ; GCN-LABEL: {{^}}v_test_umin3_ult_i16:
144 define amdgpu_kernel void @v_test_umin3_ult_i16(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
145 %tid = call i32 @llvm.amdgcn.workitem.id.x()
146 %gep0 = getelementptr i16, ptr addrspace(1) %aptr, i32 %tid
147 %gep1 = getelementptr i16, ptr addrspace(1) %bptr, i32 %tid
148 %gep2 = getelementptr i16, ptr addrspace(1) %cptr, i32 %tid
149 %outgep = getelementptr i16, ptr addrspace(1) %out, i32 %tid
150 %a = load i16, ptr addrspace(1) %gep0
151 %b = load i16, ptr addrspace(1) %gep1
152 %c = load i16, ptr addrspace(1) %gep2
153 %icmp0 = icmp ult i16 %a, %b
154 %i0 = select i1 %icmp0, i16 %a, i16 %b
155 %icmp1 = icmp ult i16 %i0, %c
156 %i1 = select i1 %icmp1, i16 %i0, i16 %c
157 store i16 %i1, ptr addrspace(1) %outgep
161 ; GCN-LABEL: {{^}}v_test_imin3_slt_i8:
168 define amdgpu_kernel void @v_test_imin3_slt_i8(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
169 %tid = call i32 @llvm.amdgcn.workitem.id.x()
170 %gep0 = getelementptr i8, ptr addrspace(1) %aptr, i32 %tid
171 %gep1 = getelementptr i8, ptr addrspace(1) %bptr, i32 %tid
172 %gep2 = getelementptr i8, ptr addrspace(1) %cptr, i32 %tid
173 %outgep = getelementptr i8, ptr addrspace(1) %out, i32 %tid
174 %a = load i8, ptr addrspace(1) %gep0
175 %b = load i8, ptr addrspace(1) %gep1
176 %c = load i8, ptr addrspace(1) %gep2
177 %icmp0 = icmp slt i8 %a, %b
178 %i0 = select i1 %icmp0, i8 %a, i8 %b
179 %icmp1 = icmp slt i8 %i0, %c
180 %i1 = select i1 %icmp1, i8 %i0, i8 %c
181 store i8 %i1, ptr addrspace(1) %outgep
185 ; GCN-LABEL: {{^}}v_test_umin3_ult_i8:
192 define amdgpu_kernel void @v_test_umin3_ult_i8(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
193 %tid = call i32 @llvm.amdgcn.workitem.id.x()
194 %gep0 = getelementptr i8, ptr addrspace(1) %aptr, i32 %tid
195 %gep1 = getelementptr i8, ptr addrspace(1) %bptr, i32 %tid
196 %gep2 = getelementptr i8, ptr addrspace(1) %cptr, i32 %tid
197 %outgep = getelementptr i8, ptr addrspace(1) %out, i32 %tid
198 %a = load i8, ptr addrspace(1) %gep0
199 %b = load i8, ptr addrspace(1) %gep1
200 %c = load i8, ptr addrspace(1) %gep2
201 %icmp0 = icmp ult i8 %a, %b
202 %i0 = select i1 %icmp0, i8 %a, i8 %b
203 %icmp1 = icmp ult i8 %i0, %c
204 %i1 = select i1 %icmp1, i8 %i0, i8 %c
205 store i8 %i1, ptr addrspace(1) %outgep
209 ; GCN-LABEL: {{^}}v_test_imin3_slt_i7:
216 define amdgpu_kernel void @v_test_imin3_slt_i7(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
217 %tid = call i32 @llvm.amdgcn.workitem.id.x()
218 %gep0 = getelementptr i7, ptr addrspace(1) %aptr, i32 %tid
219 %gep1 = getelementptr i7, ptr addrspace(1) %bptr, i32 %tid
220 %gep2 = getelementptr i7, ptr addrspace(1) %cptr, i32 %tid
221 %outgep = getelementptr i7, ptr addrspace(1) %out, i32 %tid
222 %a = load i7, ptr addrspace(1) %gep0
223 %b = load i7, ptr addrspace(1) %gep1
224 %c = load i7, ptr addrspace(1) %gep2
225 %icmp0 = icmp slt i7 %a, %b
226 %i0 = select i1 %icmp0, i7 %a, i7 %b
227 %icmp1 = icmp slt i7 %i0, %c
228 %i1 = select i1 %icmp1, i7 %i0, i7 %c
229 store i7 %i1, ptr addrspace(1) %outgep
233 ; GCN-LABEL: {{^}}v_test_umin3_ult_i7:
240 define amdgpu_kernel void @v_test_umin3_ult_i7(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
241 %tid = call i32 @llvm.amdgcn.workitem.id.x()
242 %gep0 = getelementptr i7, ptr addrspace(1) %aptr, i32 %tid
243 %gep1 = getelementptr i7, ptr addrspace(1) %bptr, i32 %tid
244 %gep2 = getelementptr i7, ptr addrspace(1) %cptr, i32 %tid
245 %outgep = getelementptr i7, ptr addrspace(1) %out, i32 %tid
246 %a = load i7, ptr addrspace(1) %gep0
247 %b = load i7, ptr addrspace(1) %gep1
248 %c = load i7, ptr addrspace(1) %gep2
249 %icmp0 = icmp ult i7 %a, %b
250 %i0 = select i1 %icmp0, i7 %a, i7 %b
251 %icmp1 = icmp ult i7 %i0, %c
252 %i1 = select i1 %icmp1, i7 %i0, i7 %c
253 store i7 %i1, ptr addrspace(1) %outgep
257 ; GCN-LABEL: {{^}}v_test_imin3_slt_i33:
259 define amdgpu_kernel void @v_test_imin3_slt_i33(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
260 %tid = call i32 @llvm.amdgcn.workitem.id.x()
261 %gep0 = getelementptr i33, ptr addrspace(1) %aptr, i32 %tid
262 %gep1 = getelementptr i33, ptr addrspace(1) %bptr, i32 %tid
263 %gep2 = getelementptr i33, ptr addrspace(1) %cptr, i32 %tid
264 %outgep = getelementptr i33, ptr addrspace(1) %out, i32 %tid
265 %a = load i33, ptr addrspace(1) %gep0
266 %b = load i33, ptr addrspace(1) %gep1
267 %c = load i33, ptr addrspace(1) %gep2
268 %icmp0 = icmp slt i33 %a, %b
269 %i0 = select i1 %icmp0, i33 %a, i33 %b
270 %icmp1 = icmp slt i33 %i0, %c
271 %i1 = select i1 %icmp1, i33 %i0, i33 %c
272 store i33 %i1, ptr addrspace(1) %outgep
276 ; GCN-LABEL: {{^}}v_test_umin3_ult_i33:
278 define amdgpu_kernel void @v_test_umin3_ult_i33(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
279 %tid = call i32 @llvm.amdgcn.workitem.id.x()
280 %gep0 = getelementptr i33, ptr addrspace(1) %aptr, i32 %tid
281 %gep1 = getelementptr i33, ptr addrspace(1) %bptr, i32 %tid
282 %gep2 = getelementptr i33, ptr addrspace(1) %cptr, i32 %tid
283 %outgep = getelementptr i33, ptr addrspace(1) %out, i32 %tid
284 %a = load i33, ptr addrspace(1) %gep0
285 %b = load i33, ptr addrspace(1) %gep1
286 %c = load i33, ptr addrspace(1) %gep2
287 %icmp0 = icmp ult i33 %a, %b
288 %i0 = select i1 %icmp0, i33 %a, i33 %b
289 %icmp1 = icmp ult i33 %i0, %c
290 %i1 = select i1 %icmp1, i33 %i0, i33 %c
291 store i33 %i1, ptr addrspace(1) %outgep
295 ; GCN-LABEL: {{^}}v_test_imin3_slt_i64:
297 define amdgpu_kernel void @v_test_imin3_slt_i64(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
298 %tid = call i32 @llvm.amdgcn.workitem.id.x()
299 %gep0 = getelementptr i64, ptr addrspace(1) %aptr, i32 %tid
300 %gep1 = getelementptr i64, ptr addrspace(1) %bptr, i32 %tid
301 %gep2 = getelementptr i64, ptr addrspace(1) %cptr, i32 %tid
302 %outgep = getelementptr i64, ptr addrspace(1) %out, i32 %tid
303 %a = load i64, ptr addrspace(1) %gep0
304 %b = load i64, ptr addrspace(1) %gep1
305 %c = load i64, ptr addrspace(1) %gep2
306 %icmp0 = icmp slt i64 %a, %b
307 %i0 = select i1 %icmp0, i64 %a, i64 %b
308 %icmp1 = icmp slt i64 %i0, %c
309 %i1 = select i1 %icmp1, i64 %i0, i64 %c
310 store i64 %i1, ptr addrspace(1) %outgep
314 ; GCN-LABEL: {{^}}v_test_umin3_ult_i64:
316 define amdgpu_kernel void @v_test_umin3_ult_i64(ptr addrspace(1) %out, ptr addrspace(1) %aptr, ptr addrspace(1) %bptr, ptr addrspace(1) %cptr) #0 {
317 %tid = call i32 @llvm.amdgcn.workitem.id.x()
318 %gep0 = getelementptr i64, ptr addrspace(1) %aptr, i32 %tid
319 %gep1 = getelementptr i64, ptr addrspace(1) %bptr, i32 %tid
320 %gep2 = getelementptr i64, ptr addrspace(1) %cptr, i32 %tid
321 %outgep = getelementptr i64, ptr addrspace(1) %out, i32 %tid
322 %a = load i64, ptr addrspace(1) %gep0
323 %b = load i64, ptr addrspace(1) %gep1
324 %c = load i64, ptr addrspace(1) %gep2
325 %icmp0 = icmp ult i64 %a, %b
326 %i0 = select i1 %icmp0, i64 %a, i64 %b
327 %icmp1 = icmp ult i64 %i0, %c
328 %i1 = select i1 %icmp1, i64 %i0, i64 %c
329 store i64 %i1, ptr addrspace(1) %outgep
333 declare i32 @llvm.amdgcn.workitem.id.x() #1
335 attributes #0 = { nounwind }
336 attributes #1 = { nounwind readnone speculatable }