[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / CodeGen / AMDGPU / combine_andor_with_cmps.ll
blob6efbd6ce87385ee03006f9594ed22cb6728d4927
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
2 ; RUN: llc -march=amdgcn -mcpu=gfx1100 -verify-machineinstrs -amdgpu-enable-delay-alu=0 < %s | FileCheck %s -check-prefixes=GCN,GFX11
3 ; RUN: llc -march=amdgcn -mcpu=gfx1100 -verify-machineinstrs -amdgpu-enable-delay-alu=0 -enable-no-nans-fp-math < %s | FileCheck %s -check-prefixes=GCN,GFX11NONANS
5 ; The tests check the following optimization of DAGCombiner:
6 ; CMP(A,C)||CMP(B,C) => CMP(MIN/MAX(A,B), C)
7 ; CMP(A,C)&&CMP(B,C) => CMP(MIN/MAX(A,B), C)
9 define i1 @test1(i32 %arg1, i32 %arg2) {
10 ; GCN-LABEL: test1:
11 ; GCN:       ; %bb.0:
12 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
13 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
14 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, 0x3e8, v0
15 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
16 ; GCN-NEXT:    s_setpc_b64 s[30:31]
17   %cmp1 = icmp slt i32 %arg1, 1000
18   %cmp2 = icmp slt i32 %arg2, 1000
19   %or  = or i1 %cmp1, %cmp2
20   ret i1 %or
23 define i1 @test2(i32 %arg1, i32 %arg2) {
24 ; GCN-LABEL: test2:
25 ; GCN:       ; %bb.0:
26 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
27 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
28 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, 0x3e8, v0
29 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
30 ; GCN-NEXT:    s_setpc_b64 s[30:31]
31   %cmp1 = icmp ult i32 %arg1, 1000
32   %cmp2 = icmp ult i32 %arg2, 1000
33   %or = or i1 %cmp1, %cmp2
34   ret i1 %or
37 define i1 @test3(i32 %arg1, i32 %arg2) {
38 ; GCN-LABEL: test3:
39 ; GCN:       ; %bb.0:
40 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
41 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
42 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, 0x3e9, v0
43 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
44 ; GCN-NEXT:    s_setpc_b64 s[30:31]
45   %cmp1 = icmp sle i32 %arg1, 1000
46   %cmp2 = icmp sle i32 %arg2, 1000
47   %or = or i1 %cmp1, %cmp2
48   ret i1 %or
51 define i1 @test4(i32 %arg1, i32 %arg2) {
52 ; GCN-LABEL: test4:
53 ; GCN:       ; %bb.0:
54 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
55 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
56 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, 0x3e9, v0
57 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
58 ; GCN-NEXT:    s_setpc_b64 s[30:31]
59   %cmp1 = icmp ule i32 %arg1, 1000
60   %cmp2 = icmp ule i32 %arg2, 1000
61   %or = or i1 %cmp1, %cmp2
62   ret i1 %or
65 define i1 @test5(i32 %arg1, i32 %arg2) {
66 ; GCN-LABEL: test5:
67 ; GCN:       ; %bb.0:
68 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
69 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
70 ; GCN-NEXT:    v_cmp_lt_i32_e32 vcc_lo, 0x3e8, v0
71 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
72 ; GCN-NEXT:    s_setpc_b64 s[30:31]
73   %cmp1 = icmp sgt i32 %arg1, 1000
74   %cmp2 = icmp sgt i32 %arg2, 1000
75   %or = or i1 %cmp1, %cmp2
76   ret i1 %or
79 define i1 @test6(i32 %arg1, i32 %arg2) {
80 ; GCN-LABEL: test6:
81 ; GCN:       ; %bb.0:
82 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
83 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
84 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, 0x3e8, v0
85 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
86 ; GCN-NEXT:    s_setpc_b64 s[30:31]
87   %cmp1 = icmp ugt i32 %arg1, 1000
88   %cmp2 = icmp ugt i32 %arg2, 1000
89   %or = or i1 %cmp1, %cmp2
90   ret i1 %or
93 define i1 @test7(i32 %arg1, i32 %arg2) {
94 ; GCN-LABEL: test7:
95 ; GCN:       ; %bb.0:
96 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
97 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
98 ; GCN-NEXT:    v_cmp_lt_i32_e32 vcc_lo, 0x3e7, v0
99 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
100 ; GCN-NEXT:    s_setpc_b64 s[30:31]
101   %cmp1 = icmp sge i32 %arg1, 1000
102   %cmp2 = icmp sge i32 %arg2, 1000
103   %or = or i1 %cmp1, %cmp2
104   ret i1 %or
107 define i1 @test8(i32 %arg1, i32 %arg2) {
108 ; GCN-LABEL: test8:
109 ; GCN:       ; %bb.0:
110 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
111 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
112 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, 0x3e7, v0
113 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
114 ; GCN-NEXT:    s_setpc_b64 s[30:31]
115   %cmp1 = icmp uge i32 %arg1, 1000
116   %cmp2 = icmp uge i32 %arg2, 1000
117   %or = or i1 %cmp1, %cmp2
118   ret i1 %or
121 define i1 @test9(i32 %arg1, i32 %arg2, i32 %arg3) {
122 ; GCN-LABEL: test9:
123 ; GCN:       ; %bb.0:
124 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
125 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
126 ; GCN-NEXT:    v_cmp_lt_i32_e32 vcc_lo, v0, v2
127 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
128 ; GCN-NEXT:    s_setpc_b64 s[30:31]
129   %cmp1 = icmp slt i32 %arg1, %arg3
130   %cmp2 = icmp slt i32 %arg2, %arg3
131   %or = or i1 %cmp1, %cmp2
132   ret i1 %or
135 define i1 @test10(i32 %arg1, i32 %arg2, i32 %arg3) {
136 ; GCN-LABEL: test10:
137 ; GCN:       ; %bb.0:
138 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
139 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
140 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v2
141 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
142 ; GCN-NEXT:    s_setpc_b64 s[30:31]
143   %cmp1 = icmp ult i32 %arg1, %arg3
144   %cmp2 = icmp ult i32 %arg2, %arg3
145   %or = or i1 %cmp1, %cmp2
146   ret i1 %or
149 define i1 @test11(i32 %arg1, i32 %arg2, i32 %arg3) {
150 ; GCN-LABEL: test11:
151 ; GCN:       ; %bb.0:
152 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
153 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
154 ; GCN-NEXT:    v_cmp_le_i32_e32 vcc_lo, v0, v2
155 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
156 ; GCN-NEXT:    s_setpc_b64 s[30:31]
157   %cmp1 = icmp sle i32 %arg1, %arg3
158   %cmp2 = icmp sle i32 %arg2, %arg3
159   %or = or i1 %cmp1, %cmp2
160   ret i1 %or
163 define i1 @test12(i32 %arg1, i32 %arg2, i32 %arg3) {
164 ; GCN-LABEL: test12:
165 ; GCN:       ; %bb.0:
166 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
167 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
168 ; GCN-NEXT:    v_cmp_le_u32_e32 vcc_lo, v0, v2
169 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
170 ; GCN-NEXT:    s_setpc_b64 s[30:31]
171   %cmp1 = icmp ule i32 %arg1, %arg3
172   %cmp2 = icmp ule i32 %arg2, %arg3
173   %or = or i1 %cmp1, %cmp2
174   ret i1 %or
177 define i1 @test13(i32 %arg1, i32 %arg2, i32 %arg3) {
178 ; GCN-LABEL: test13:
179 ; GCN:       ; %bb.0:
180 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
181 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
182 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, v0, v2
183 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
184 ; GCN-NEXT:    s_setpc_b64 s[30:31]
185   %cmp1 = icmp sgt i32 %arg1, %arg3
186   %cmp2 = icmp sgt i32 %arg2, %arg3
187   %or = or i1 %cmp1, %cmp2
188   ret i1 %or
191 define i1 @test14(i32 %arg1, i32 %arg2, i32 %arg3) {
192 ; GCN-LABEL: test14:
193 ; GCN:       ; %bb.0:
194 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
195 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
196 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, v0, v2
197 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
198 ; GCN-NEXT:    s_setpc_b64 s[30:31]
199   %cmp1 = icmp ugt i32 %arg1, %arg3
200   %cmp2 = icmp ugt i32 %arg2, %arg3
201   %or = or i1 %cmp1, %cmp2
202   ret i1 %or
205 define i1 @test15(i32 %arg1, i32 %arg2, i32 %arg3) {
206 ; GCN-LABEL: test15:
207 ; GCN:       ; %bb.0:
208 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
209 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
210 ; GCN-NEXT:    v_cmp_ge_i32_e32 vcc_lo, v0, v2
211 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
212 ; GCN-NEXT:    s_setpc_b64 s[30:31]
213   %cmp1 = icmp sge i32 %arg1, %arg3
214   %cmp2 = icmp sge i32 %arg2, %arg3
215   %or = or i1 %cmp1, %cmp2
216   ret i1 %or
219 define i1 @test16(i32 %arg1, i32 %arg2, i32 %arg3) {
220 ; GCN-LABEL: test16:
221 ; GCN:       ; %bb.0:
222 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
223 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
224 ; GCN-NEXT:    v_cmp_ge_u32_e32 vcc_lo, v0, v2
225 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
226 ; GCN-NEXT:    s_setpc_b64 s[30:31]
227   %cmp1 = icmp uge i32 %arg1, %arg3
228   %cmp2 = icmp uge i32 %arg2, %arg3
229   %or = or i1 %cmp1, %cmp2
230   ret i1 %or
233 define i1 @test17(i32 %arg1, i32 %arg2) {
234 ; GCN-LABEL: test17:
235 ; GCN:       ; %bb.0:
236 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
237 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
238 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, 0x3e8, v0
239 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
240 ; GCN-NEXT:    s_setpc_b64 s[30:31]
241   %cmp1 = icmp slt i32 %arg1, 1000
242   %cmp2 = icmp slt i32 %arg2, 1000
243   %and  = and i1 %cmp1, %cmp2
244   ret i1 %and
247 define i1 @test18(i32 %arg1, i32 %arg2) {
248 ; GCN-LABEL: test18:
249 ; GCN:       ; %bb.0:
250 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
251 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
252 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, 0x3e8, v0
253 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
254 ; GCN-NEXT:    s_setpc_b64 s[30:31]
255   %cmp1 = icmp ult i32 %arg1, 1000
256   %cmp2 = icmp ult i32 %arg2, 1000
257   %and = and i1 %cmp1, %cmp2
258   ret i1 %and
261 define i1 @test19(i32 %arg1, i32 %arg2) {
262 ; GCN-LABEL: test19:
263 ; GCN:       ; %bb.0:
264 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
265 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
266 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, 0x3e9, v0
267 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
268 ; GCN-NEXT:    s_setpc_b64 s[30:31]
269   %cmp1 = icmp sle i32 %arg1, 1000
270   %cmp2 = icmp sle i32 %arg2, 1000
271   %and = and i1 %cmp1, %cmp2
272   ret i1 %and
275 define i1 @test20(i32 %arg1, i32 %arg2) {
276 ; GCN-LABEL: test20:
277 ; GCN:       ; %bb.0:
278 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
279 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
280 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, 0x3e9, v0
281 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
282 ; GCN-NEXT:    s_setpc_b64 s[30:31]
283   %cmp1 = icmp ule i32 %arg1, 1000
284   %cmp2 = icmp ule i32 %arg2, 1000
285   %and = and i1 %cmp1, %cmp2
286   ret i1 %and
289 define i1 @test21(i32 %arg1, i32 %arg2) {
290 ; GCN-LABEL: test21:
291 ; GCN:       ; %bb.0:
292 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
293 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
294 ; GCN-NEXT:    v_cmp_lt_i32_e32 vcc_lo, 0x3e8, v0
295 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
296 ; GCN-NEXT:    s_setpc_b64 s[30:31]
297   %cmp1 = icmp sgt i32 %arg1, 1000
298   %cmp2 = icmp sgt i32 %arg2, 1000
299   %and = and i1 %cmp1, %cmp2
300   ret i1 %and
303 define i1 @test22(i32 %arg1, i32 %arg2) {
304 ; GCN-LABEL: test22:
305 ; GCN:       ; %bb.0:
306 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
307 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
308 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, 0x3e8, v0
309 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
310 ; GCN-NEXT:    s_setpc_b64 s[30:31]
311   %cmp1 = icmp ugt i32 %arg1, 1000
312   %cmp2 = icmp ugt i32 %arg2, 1000
313   %and = and i1 %cmp1, %cmp2
314   ret i1 %and
317 define i1 @test23(i32 %arg1, i32 %arg2) {
318 ; GCN-LABEL: test23:
319 ; GCN:       ; %bb.0:
320 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
321 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
322 ; GCN-NEXT:    v_cmp_lt_i32_e32 vcc_lo, 0x3e7, v0
323 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
324 ; GCN-NEXT:    s_setpc_b64 s[30:31]
325   %cmp1 = icmp sge i32 %arg1, 1000
326   %cmp2 = icmp sge i32 %arg2, 1000
327   %and = and i1 %cmp1, %cmp2
328   ret i1 %and
331 define i1 @test24(i32 %arg1, i32 %arg2) {
332 ; GCN-LABEL: test24:
333 ; GCN:       ; %bb.0:
334 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
335 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
336 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, 0x3e7, v0
337 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
338 ; GCN-NEXT:    s_setpc_b64 s[30:31]
339   %cmp1 = icmp uge i32 %arg1, 1000
340   %cmp2 = icmp uge i32 %arg2, 1000
341   %and = and i1 %cmp1, %cmp2
342   ret i1 %and
345 define i1 @test25(i32 %arg1, i32 %arg2, i32 %arg3) {
346 ; GCN-LABEL: test25:
347 ; GCN:       ; %bb.0:
348 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
349 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
350 ; GCN-NEXT:    v_cmp_lt_i32_e32 vcc_lo, v0, v2
351 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
352 ; GCN-NEXT:    s_setpc_b64 s[30:31]
353   %cmp1 = icmp slt i32 %arg1, %arg3
354   %cmp2 = icmp slt i32 %arg2, %arg3
355   %and = and i1 %cmp1, %cmp2
356   ret i1 %and
359 define i1 @test26(i32 %arg1, i32 %arg2, i32 %arg3) {
360 ; GCN-LABEL: test26:
361 ; GCN:       ; %bb.0:
362 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
363 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
364 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v2
365 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
366 ; GCN-NEXT:    s_setpc_b64 s[30:31]
367   %cmp1 = icmp ult i32 %arg1, %arg3
368   %cmp2 = icmp ult i32 %arg2, %arg3
369   %and = and i1 %cmp1, %cmp2
370   ret i1 %and
373 define i1 @test27(i32 %arg1, i32 %arg2, i32 %arg3) {
374 ; GCN-LABEL: test27:
375 ; GCN:       ; %bb.0:
376 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
377 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
378 ; GCN-NEXT:    v_cmp_le_i32_e32 vcc_lo, v0, v2
379 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
380 ; GCN-NEXT:    s_setpc_b64 s[30:31]
381   %cmp1 = icmp sle i32 %arg1, %arg3
382   %cmp2 = icmp sle i32 %arg2, %arg3
383   %and = and i1 %cmp1, %cmp2
384   ret i1 %and
387 define i1 @test28(i32 %arg1, i32 %arg2, i32 %arg3) {
388 ; GCN-LABEL: test28:
389 ; GCN:       ; %bb.0:
390 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
391 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
392 ; GCN-NEXT:    v_cmp_le_u32_e32 vcc_lo, v0, v2
393 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
394 ; GCN-NEXT:    s_setpc_b64 s[30:31]
395   %cmp1 = icmp ule i32 %arg1, %arg3
396   %cmp2 = icmp ule i32 %arg2, %arg3
397   %and = and i1 %cmp1, %cmp2
398   ret i1 %and
401 define i1 @test29(i32 %arg1, i32 %arg2, i32 %arg3) {
402 ; GCN-LABEL: test29:
403 ; GCN:       ; %bb.0:
404 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
405 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
406 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, v0, v2
407 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
408 ; GCN-NEXT:    s_setpc_b64 s[30:31]
409   %cmp1 = icmp sgt i32 %arg1, %arg3
410   %cmp2 = icmp sgt i32 %arg2, %arg3
411   %and = and i1 %cmp1, %cmp2
412   ret i1 %and
415 define i1 @test30(i32 %arg1, i32 %arg2, i32 %arg3) {
416 ; GCN-LABEL: test30:
417 ; GCN:       ; %bb.0:
418 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
419 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
420 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, v0, v2
421 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
422 ; GCN-NEXT:    s_setpc_b64 s[30:31]
423   %cmp1 = icmp ugt i32 %arg1, %arg3
424   %cmp2 = icmp ugt i32 %arg2, %arg3
425   %and = and i1 %cmp1, %cmp2
426   ret i1 %and
429 define i1 @test31(i32 %arg1, i32 %arg2, i32 %arg3) {
430 ; GCN-LABEL: test31:
431 ; GCN:       ; %bb.0:
432 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
433 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
434 ; GCN-NEXT:    v_cmp_ge_i32_e32 vcc_lo, v0, v2
435 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
436 ; GCN-NEXT:    s_setpc_b64 s[30:31]
437   %cmp1 = icmp sge i32 %arg1, %arg3
438   %cmp2 = icmp sge i32 %arg2, %arg3
439   %and = and i1 %cmp1, %cmp2
440   ret i1 %and
443 define i1 @test32(i32 %arg1, i32 %arg2, i32 %arg3) {
444 ; GCN-LABEL: test32:
445 ; GCN:       ; %bb.0:
446 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
447 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
448 ; GCN-NEXT:    v_cmp_ge_u32_e32 vcc_lo, v0, v2
449 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
450 ; GCN-NEXT:    s_setpc_b64 s[30:31]
451   %cmp1 = icmp uge i32 %arg1, %arg3
452   %cmp2 = icmp uge i32 %arg2, %arg3
453   %and = and i1 %cmp1, %cmp2
454   ret i1 %and
457 define i1 @test33(i32 %arg1, i32 %arg2) {
458 ; GCN-LABEL: test33:
459 ; GCN:       ; %bb.0:
460 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
461 ; GCN-NEXT:    v_max_i32_e32 v1, 0x3e8, v1
462 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, v1, v0
463 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
464 ; GCN-NEXT:    s_setpc_b64 s[30:31]
465   %cmp1 = icmp slt i32 %arg1, %arg2
466   %cmp2 = icmp slt i32 %arg1, 1000
467   %or  = or i1 %cmp1, %cmp2
468   ret i1 %or
471 define amdgpu_gfx void @test34(i32 inreg %arg1, i32 inreg %arg2) {
472 ; GCN-LABEL: test34:
473 ; GCN:       ; %bb.0:
474 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
475 ; GCN-NEXT:    s_min_i32 s0, s4, s5
476 ; GCN-NEXT:    v_mov_b32_e32 v0, 0
477 ; GCN-NEXT:    s_cmpk_lt_i32 s0, 0x3e9
478 ; GCN-NEXT:    v_mov_b32_e32 v1, 0
479 ; GCN-NEXT:    s_cselect_b32 s0, -1, 0
480 ; GCN-NEXT:    v_cndmask_b32_e64 v2, 0, 1, s0
481 ; GCN-NEXT:    global_store_b8 v[0:1], v2, off dlc
482 ; GCN-NEXT:    s_waitcnt_vscnt null, 0x0
483 ; GCN-NEXT:    s_setpc_b64 s[30:31]
484   %cmp1 = icmp sle i32 %arg1, 1000
485   %cmp2 = icmp sle i32 %arg2, 1000
486   %or = or i1 %cmp1, %cmp2
487   store volatile i1 %or, ptr addrspace(1) null
488   ret void
491 define amdgpu_gfx void @test35(i32 inreg %arg1, i32 inreg %arg2) {
492 ; GCN-LABEL: test35:
493 ; GCN:       ; %bb.0:
494 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
495 ; GCN-NEXT:    s_max_i32 s0, s4, s5
496 ; GCN-NEXT:    v_mov_b32_e32 v0, 0
497 ; GCN-NEXT:    s_cmpk_gt_i32 s0, 0x3e8
498 ; GCN-NEXT:    v_mov_b32_e32 v1, 0
499 ; GCN-NEXT:    s_cselect_b32 s0, -1, 0
500 ; GCN-NEXT:    v_cndmask_b32_e64 v2, 0, 1, s0
501 ; GCN-NEXT:    global_store_b8 v[0:1], v2, off dlc
502 ; GCN-NEXT:    s_waitcnt_vscnt null, 0x0
503 ; GCN-NEXT:    s_setpc_b64 s[30:31]
504   %cmp1 = icmp sgt i32 %arg1, 1000
505   %cmp2 = icmp sgt i32 %arg2, 1000
506   %or = or i1 %cmp1, %cmp2
507   store volatile i1 %or, ptr addrspace(1) null
508   ret void
511 define amdgpu_gfx void @test36(i32 inreg %arg1, i32 inreg %arg2, i32 inreg %arg3) {
512 ; GCN-LABEL: test36:
513 ; GCN:       ; %bb.0:
514 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
515 ; GCN-NEXT:    s_min_u32 s0, s4, s5
516 ; GCN-NEXT:    v_mov_b32_e32 v0, 0
517 ; GCN-NEXT:    s_cmp_lt_u32 s0, s6
518 ; GCN-NEXT:    v_mov_b32_e32 v1, 0
519 ; GCN-NEXT:    s_cselect_b32 s0, -1, 0
520 ; GCN-NEXT:    v_cndmask_b32_e64 v2, 0, 1, s0
521 ; GCN-NEXT:    global_store_b8 v[0:1], v2, off dlc
522 ; GCN-NEXT:    s_waitcnt_vscnt null, 0x0
523 ; GCN-NEXT:    s_setpc_b64 s[30:31]
524   %cmp1 = icmp ult i32 %arg1, %arg3
525   %cmp2 = icmp ult i32 %arg2, %arg3
526   %or = or i1 %cmp1, %cmp2
527   store volatile i1 %or, ptr addrspace(1) null
528   ret void
531 define amdgpu_gfx void @test37(i32 inreg %arg1, i32 inreg %arg2, i32 inreg %arg3) {
532 ; GCN-LABEL: test37:
533 ; GCN:       ; %bb.0:
534 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
535 ; GCN-NEXT:    s_max_i32 s0, s4, s5
536 ; GCN-NEXT:    v_mov_b32_e32 v0, 0
537 ; GCN-NEXT:    s_cmp_ge_i32 s0, s6
538 ; GCN-NEXT:    v_mov_b32_e32 v1, 0
539 ; GCN-NEXT:    s_cselect_b32 s0, -1, 0
540 ; GCN-NEXT:    v_cndmask_b32_e64 v2, 0, 1, s0
541 ; GCN-NEXT:    global_store_b8 v[0:1], v2, off dlc
542 ; GCN-NEXT:    s_waitcnt_vscnt null, 0x0
543 ; GCN-NEXT:    s_setpc_b64 s[30:31]
544   %cmp1 = icmp sge i32 %arg1, %arg3
545   %cmp2 = icmp sge i32 %arg2, %arg3
546   %or = or i1 %cmp1, %cmp2
547   store volatile i1 %or, ptr addrspace(1) null
548   ret void
551 define amdgpu_gfx void @test38(i32 inreg %arg1, i32 inreg %arg2) {
552 ; GCN-LABEL: test38:
553 ; GCN:       ; %bb.0:
554 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
555 ; GCN-NEXT:    s_max_u32 s0, s4, s5
556 ; GCN-NEXT:    v_mov_b32_e32 v0, 0
557 ; GCN-NEXT:    s_cmpk_lt_u32 s0, 0x3e9
558 ; GCN-NEXT:    v_mov_b32_e32 v1, 0
559 ; GCN-NEXT:    s_cselect_b32 s0, -1, 0
560 ; GCN-NEXT:    v_cndmask_b32_e64 v2, 0, 1, s0
561 ; GCN-NEXT:    global_store_b8 v[0:1], v2, off dlc
562 ; GCN-NEXT:    s_waitcnt_vscnt null, 0x0
563 ; GCN-NEXT:    s_setpc_b64 s[30:31]
564   %cmp1 = icmp ule i32 %arg1, 1000
565   %cmp2 = icmp ule i32 %arg2, 1000
566   %and = and i1 %cmp1, %cmp2
567   store volatile i1 %and, ptr addrspace(1) null
568   ret void
571 define amdgpu_gfx void @test39(i32 inreg %arg1, i32 inreg %arg2) {
572 ; GCN-LABEL: test39:
573 ; GCN:       ; %bb.0:
574 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
575 ; GCN-NEXT:    s_min_i32 s0, s4, s5
576 ; GCN-NEXT:    v_mov_b32_e32 v0, 0
577 ; GCN-NEXT:    s_cmpk_gt_i32 s0, 0x3e7
578 ; GCN-NEXT:    v_mov_b32_e32 v1, 0
579 ; GCN-NEXT:    s_cselect_b32 s0, -1, 0
580 ; GCN-NEXT:    v_cndmask_b32_e64 v2, 0, 1, s0
581 ; GCN-NEXT:    global_store_b8 v[0:1], v2, off dlc
582 ; GCN-NEXT:    s_waitcnt_vscnt null, 0x0
583 ; GCN-NEXT:    s_setpc_b64 s[30:31]
584   %cmp1 = icmp sge i32 %arg1, 1000
585   %cmp2 = icmp sge i32 %arg2, 1000
586   %and = and i1 %cmp1, %cmp2
587   store volatile i1 %and, ptr addrspace(1) null
588   ret void
591 define amdgpu_gfx void @test40(i32 inreg %arg1, i32 inreg %arg2, i32 inreg %arg3) {
592 ; GCN-LABEL: test40:
593 ; GCN:       ; %bb.0:
594 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
595 ; GCN-NEXT:    s_max_i32 s0, s4, s5
596 ; GCN-NEXT:    v_mov_b32_e32 v0, 0
597 ; GCN-NEXT:    s_cmp_le_i32 s0, s6
598 ; GCN-NEXT:    v_mov_b32_e32 v1, 0
599 ; GCN-NEXT:    s_cselect_b32 s0, -1, 0
600 ; GCN-NEXT:    v_cndmask_b32_e64 v2, 0, 1, s0
601 ; GCN-NEXT:    global_store_b8 v[0:1], v2, off dlc
602 ; GCN-NEXT:    s_waitcnt_vscnt null, 0x0
603 ; GCN-NEXT:    s_setpc_b64 s[30:31]
604   %cmp1 = icmp sle i32 %arg1, %arg3
605   %cmp2 = icmp sle i32 %arg2, %arg3
606   %and = and i1 %cmp1, %cmp2
607   store volatile i1 %and, ptr addrspace(1) null
608   ret void
611 define amdgpu_gfx void @test41(i32 inreg %arg1, i32 inreg %arg2, i32 inreg %arg3) {
612 ; GCN-LABEL: test41:
613 ; GCN:       ; %bb.0:
614 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
615 ; GCN-NEXT:    s_min_u32 s0, s4, s5
616 ; GCN-NEXT:    v_mov_b32_e32 v0, 0
617 ; GCN-NEXT:    s_cmp_ge_u32 s0, s6
618 ; GCN-NEXT:    v_mov_b32_e32 v1, 0
619 ; GCN-NEXT:    s_cselect_b32 s0, -1, 0
620 ; GCN-NEXT:    v_cndmask_b32_e64 v2, 0, 1, s0
621 ; GCN-NEXT:    global_store_b8 v[0:1], v2, off dlc
622 ; GCN-NEXT:    s_waitcnt_vscnt null, 0x0
623 ; GCN-NEXT:    s_setpc_b64 s[30:31]
624   %cmp1 = icmp uge i32 %arg1, %arg3
625   %cmp2 = icmp uge i32 %arg2, %arg3
626   %and = and i1 %cmp1, %cmp2
627   store volatile i1 %and, ptr addrspace(1) null
628   ret void
631 define i1 @test42(i32 %arg1, i32 %arg2, i32 %arg3) {
632 ; GCN-LABEL: test42:
633 ; GCN:       ; %bb.0:
634 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
635 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
636 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, v0, v2
637 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
638 ; GCN-NEXT:    s_setpc_b64 s[30:31]
639   %cmp1 = icmp ult i32 %arg3, %arg1
640   %cmp2 = icmp ult i32 %arg3, %arg2
641   %or = and i1 %cmp1, %cmp2
642   ret i1 %or
645 define i1 @test43(i32 %arg1, i32 %arg2, i32 %arg3) {
646 ; GCN-LABEL: test43:
647 ; GCN:       ; %bb.0:
648 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
649 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
650 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, v0, v2
651 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
652 ; GCN-NEXT:    s_setpc_b64 s[30:31]
653   %cmp1 = icmp ult i32 %arg3, %arg1
654   %cmp2 = icmp ult i32 %arg3, %arg2
655   %or = or i1 %cmp1, %cmp2
656   ret i1 %or
659 define i1 @test44(i32 %arg1, i32 %arg2, i32 %arg3) {
660 ; GCN-LABEL: test44:
661 ; GCN:       ; %bb.0:
662 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
663 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
664 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v2
665 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
666 ; GCN-NEXT:    s_setpc_b64 s[30:31]
667   %cmp1 = icmp ugt i32 %arg3, %arg1
668   %cmp2 = icmp ugt i32 %arg3, %arg2
669   %or = and i1 %cmp1, %cmp2
670   ret i1 %or
673 define i1 @test45(i32 %arg1, i32 %arg2, i32 %arg3) {
674 ; GCN-LABEL: test45:
675 ; GCN:       ; %bb.0:
676 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
677 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
678 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v2
679 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
680 ; GCN-NEXT:    s_setpc_b64 s[30:31]
681   %cmp1 = icmp ugt i32 %arg3, %arg1
682   %cmp2 = icmp ugt i32 %arg3, %arg2
683   %or = or i1 %cmp1, %cmp2
684   ret i1 %or
687 define i1 @test46(i32 %arg1, i32 %arg2, i32 %arg3) {
688 ; GCN-LABEL: test46:
689 ; GCN:       ; %bb.0:
690 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
691 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
692 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, v0, v2
693 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
694 ; GCN-NEXT:    s_setpc_b64 s[30:31]
695   %cmp1 = icmp slt i32 %arg3, %arg1
696   %cmp2 = icmp sgt i32 %arg2, %arg3
697   %or  = or i1 %cmp1, %cmp2
698   ret i1 %or
701 define i1 @test47(i32 %arg1, i32 %arg2, i32 %arg3) {
702 ; GCN-LABEL: test47:
703 ; GCN:       ; %bb.0:
704 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
705 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
706 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, v0, v2
707 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
708 ; GCN-NEXT:    s_setpc_b64 s[30:31]
709   %cmp1 = icmp sgt i32 %arg1, %arg3
710   %cmp2 = icmp slt i32 %arg3, %arg2
711   %or  = or i1 %cmp1, %cmp2
712   ret i1 %or
715 define i1 @test48(i32 %arg1, i32 %arg2, i32 %arg3) {
716 ; GCN-LABEL: test48:
717 ; GCN:       ; %bb.0:
718 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
719 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
720 ; GCN-NEXT:    v_cmp_lt_i32_e32 vcc_lo, v0, v2
721 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
722 ; GCN-NEXT:    s_setpc_b64 s[30:31]
723   %cmp1 = icmp slt i32 %arg1, %arg3
724   %cmp2 = icmp sgt i32 %arg3, %arg2
725   %or  = or i1 %cmp1, %cmp2
726   ret i1 %or
729 define i1 @test49(i32 %arg1, i32 %arg2, i32 %arg3) {
730 ; GCN-LABEL: test49:
731 ; GCN:       ; %bb.0:
732 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
733 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
734 ; GCN-NEXT:    v_cmp_lt_i32_e32 vcc_lo, v0, v2
735 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
736 ; GCN-NEXT:    s_setpc_b64 s[30:31]
737   %cmp1 = icmp sgt i32 %arg3, %arg1
738   %cmp2 = icmp slt i32 %arg2, %arg3
739   %or  = or i1 %cmp1, %cmp2
740   ret i1 %or
743 define i1 @test50(i32 %arg1, i32 %arg2, i32 %arg3) {
744 ; GCN-LABEL: test50:
745 ; GCN:       ; %bb.0:
746 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
747 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
748 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, v0, v2
749 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
750 ; GCN-NEXT:    s_setpc_b64 s[30:31]
751   %cmp1 = icmp slt i32 %arg3, %arg1
752   %cmp2 = icmp sgt i32 %arg2, %arg3
753   %and  = and i1 %cmp1, %cmp2
754   ret i1 %and
757 define i1 @test51(i32 %arg1, i32 %arg2, i32 %arg3) {
758 ; GCN-LABEL: test51:
759 ; GCN:       ; %bb.0:
760 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
761 ; GCN-NEXT:    v_min_i32_e32 v0, v0, v1
762 ; GCN-NEXT:    v_cmp_gt_i32_e32 vcc_lo, v0, v2
763 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
764 ; GCN-NEXT:    s_setpc_b64 s[30:31]
765   %cmp1 = icmp sgt i32 %arg1, %arg3
766   %cmp2 = icmp slt i32 %arg3, %arg2
767   %and  = and i1 %cmp1, %cmp2
768   ret i1 %and
771 define i1 @test52(i32 %arg1, i32 %arg2, i32 %arg3) {
772 ; GCN-LABEL: test52:
773 ; GCN:       ; %bb.0:
774 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
775 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
776 ; GCN-NEXT:    v_cmp_lt_i32_e32 vcc_lo, v0, v2
777 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
778 ; GCN-NEXT:    s_setpc_b64 s[30:31]
779   %cmp1 = icmp slt i32 %arg1, %arg3
780   %cmp2 = icmp sgt i32 %arg3, %arg2
781   %and  = and i1 %cmp1, %cmp2
782   ret i1 %and
785 define i1 @test53(i32 %arg1, i32 %arg2, i32 %arg3) {
786 ; GCN-LABEL: test53:
787 ; GCN:       ; %bb.0:
788 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
789 ; GCN-NEXT:    v_max_i32_e32 v0, v0, v1
790 ; GCN-NEXT:    v_cmp_lt_i32_e32 vcc_lo, v0, v2
791 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
792 ; GCN-NEXT:    s_setpc_b64 s[30:31]
793   %cmp1 = icmp sgt i32 %arg3, %arg1
794   %cmp2 = icmp slt i32 %arg2, %arg3
795   %and  = and i1 %cmp1, %cmp2
796   ret i1 %and
799 define i1 @test54(float %arg1, float %arg2, float %arg3) #0 {
800 ; GCN-LABEL: test54:
801 ; GCN:       ; %bb.0:
802 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
803 ; GCN-NEXT:    v_min_f32_e32 v0, v0, v1
804 ; GCN-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
805 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
806 ; GCN-NEXT:    s_setpc_b64 s[30:31]
807   %cmp1 = fcmp olt float %arg1, %arg3
808   %cmp2 = fcmp olt float %arg2, %arg3
809   %or1  = or i1 %cmp1, %cmp2
810   ret i1 %or1
813 define i1 @test55(double %arg1, double %arg2, double %arg3) #0 {
814 ; GCN-LABEL: test55:
815 ; GCN:       ; %bb.0:
816 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
817 ; GCN-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
818 ; GCN-NEXT:    v_cmp_le_f64_e32 vcc_lo, v[0:1], v[4:5]
819 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
820 ; GCN-NEXT:    s_setpc_b64 s[30:31]
821   %cmp1 = fcmp ole double %arg1, %arg3
822   %cmp2 = fcmp ole double %arg2, %arg3
823   %or1  = or i1 %cmp1, %cmp2
824   ret i1 %or1
827 define i1 @test56(double %arg1, double %arg2, double %arg3) #0 {
828 ; GCN-LABEL: test56:
829 ; GCN:       ; %bb.0:
830 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
831 ; GCN-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
832 ; GCN-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
833 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
834 ; GCN-NEXT:    s_setpc_b64 s[30:31]
835   %cmp1 = fcmp ogt double %arg1, %arg3
836   %cmp2 = fcmp ogt double %arg2, %arg3
837   %or1  = or i1 %cmp1, %cmp2
838   ret i1 %or1
841 define i1 @test57(float %arg1, float %arg2, float %arg3) #0 {
842 ; GCN-LABEL: test57:
843 ; GCN:       ; %bb.0:
844 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
845 ; GCN-NEXT:    v_max_f32_e32 v0, v0, v1
846 ; GCN-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
847 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
848 ; GCN-NEXT:    s_setpc_b64 s[30:31]
849   %cmp1 = fcmp oge float %arg1, %arg3
850   %cmp2 = fcmp oge float %arg2, %arg3
851   %or1  = or i1 %cmp1, %cmp2
852   ret i1 %or1
855 define i1 @test58(double %arg1, double %arg2, double %arg3) #0 {
856 ; GFX11-LABEL: test58:
857 ; GFX11:       ; %bb.0:
858 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
859 ; GFX11-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
860 ; GFX11-NEXT:    v_cmp_nle_f64_e32 vcc_lo, v[0:1], v[4:5]
861 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
862 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
864 ; GFX11NONANS-LABEL: test58:
865 ; GFX11NONANS:       ; %bb.0:
866 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
867 ; GFX11NONANS-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
868 ; GFX11NONANS-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
869 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
870 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
871   %cmp1 = fcmp ugt double %arg1, %arg3
872   %cmp2 = fcmp ugt double %arg2, %arg3
873   %and1  = and i1 %cmp1, %cmp2
874   ret i1 %and1
877 define i1 @test59(float %arg1, float %arg2, float %arg3) #0 {
878 ; GFX11-LABEL: test59:
879 ; GFX11:       ; %bb.0:
880 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
881 ; GFX11-NEXT:    v_min_f32_e32 v0, v0, v1
882 ; GFX11-NEXT:    v_cmp_nlt_f32_e32 vcc_lo, v0, v2
883 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
884 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
886 ; GFX11NONANS-LABEL: test59:
887 ; GFX11NONANS:       ; %bb.0:
888 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
889 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v1
890 ; GFX11NONANS-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
891 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
892 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
893   %cmp1 = fcmp uge float %arg1, %arg3
894   %cmp2 = fcmp uge float %arg2, %arg3
895   %and1  = and i1 %cmp1, %cmp2
896   ret i1 %and1
899 define i1 @test60(float %arg1, float %arg2, float %arg3) #0 {
900 ; GFX11-LABEL: test60:
901 ; GFX11:       ; %bb.0:
902 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
903 ; GFX11-NEXT:    v_max_f32_e32 v0, v0, v1
904 ; GFX11-NEXT:    v_cmp_ngt_f32_e32 vcc_lo, v0, v2
905 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
906 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
908 ; GFX11NONANS-LABEL: test60:
909 ; GFX11NONANS:       ; %bb.0:
910 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
911 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
912 ; GFX11NONANS-NEXT:    v_cmp_le_f32_e32 vcc_lo, v0, v2
913 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
914 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
915   %cmp1 = fcmp ule float %arg1, %arg3
916   %cmp2 = fcmp ule float %arg2, %arg3
917   %and1  = and i1 %cmp1, %cmp2
918   ret i1 %and1
921 define i1 @test61(double %arg1, double %arg2, double %arg3) #0 {
922 ; GFX11-LABEL: test61:
923 ; GFX11:       ; %bb.0:
924 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
925 ; GFX11-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
926 ; GFX11-NEXT:    v_cmp_nge_f64_e32 vcc_lo, v[0:1], v[4:5]
927 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
928 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
930 ; GFX11NONANS-LABEL: test61:
931 ; GFX11NONANS:       ; %bb.0:
932 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
933 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
934 ; GFX11NONANS-NEXT:    v_cmp_lt_f64_e32 vcc_lo, v[0:1], v[4:5]
935 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
936 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
937   %cmp1 = fcmp ult double %arg1, %arg3
938   %cmp2 = fcmp ult double %arg2, %arg3
939   %and1 = and i1 %cmp1, %cmp2
940   ret i1 %and1
943 define i1 @test62(float %arg1, float %arg2, float %arg3) {
944 ; GCN-LABEL: test62:
945 ; GCN:       ; %bb.0:
946 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
947 ; GCN-NEXT:    v_dual_add_f32 v0, 1.0, v0 :: v_dual_add_f32 v1, 2.0, v1
948 ; GCN-NEXT:    v_min_f32_e32 v0, v0, v1
949 ; GCN-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
950 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
951 ; GCN-NEXT:    s_setpc_b64 s[30:31]
952   %add1 = fadd nnan float %arg1, 1.0
953   %add2 = fadd nnan float %arg2, 2.0
954   %cmp1 = fcmp nnan olt float %add1, %arg3
955   %cmp2 = fcmp nnan olt float %add2, %arg3
956   %or1  = or i1 %cmp1, %cmp2
957   ret i1 %or1
960 define i1 @test63(double %arg1, double %arg2, double %arg3) #0 {
961 ; GCN-LABEL: test63:
962 ; GCN:       ; %bb.0:
963 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
964 ; GCN-NEXT:    v_add_f64 v[0:1], v[0:1], 1.0
965 ; GCN-NEXT:    v_add_f64 v[2:3], v[2:3], 2.0
966 ; GCN-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
967 ; GCN-NEXT:    v_cmp_le_f64_e32 vcc_lo, v[0:1], v[4:5]
968 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
969 ; GCN-NEXT:    s_setpc_b64 s[30:31]
970   %add1 = fadd nnan double %arg1, 1.0
971   %add2 = fadd nnan double %arg2, 2.0
972   %cmp1 = fcmp nnan ole double %add1, %arg3
973   %cmp2 = fcmp nnan ole double %add2, %arg3
974   %or1  = or i1 %cmp1, %cmp2
975   ret i1 %or1
978 define i1 @test64(double %arg1, double %arg2, double %arg3) #0 {
979 ; GCN-LABEL: test64:
980 ; GCN:       ; %bb.0:
981 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
982 ; GCN-NEXT:    v_add_f64 v[0:1], v[0:1], 1.0
983 ; GCN-NEXT:    v_add_f64 v[2:3], v[2:3], 2.0
984 ; GCN-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
985 ; GCN-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
986 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
987 ; GCN-NEXT:    s_setpc_b64 s[30:31]
988   %add1 = fadd nnan double %arg1, 1.0
989   %add2 = fadd nnan double %arg2, 2.0
990   %cmp1 = fcmp nnan ogt double %add1, %arg3
991   %cmp2 = fcmp nnan ogt double %add2, %arg3
992   %or1  = or i1 %cmp1, %cmp2
993   ret i1 %or1
996 define i1 @test65(float %arg1, float %arg2, float %arg3) {
997 ; GCN-LABEL: test65:
998 ; GCN:       ; %bb.0:
999 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1000 ; GCN-NEXT:    v_dual_add_f32 v0, 1.0, v0 :: v_dual_add_f32 v1, 2.0, v1
1001 ; GCN-NEXT:    v_max_f32_e32 v0, v0, v1
1002 ; GCN-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
1003 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1004 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1005   %add1 = fadd nnan float %arg1, 1.0
1006   %add2 = fadd nnan float %arg2, 2.0
1007   %cmp1 = fcmp nnan oge float %add1, %arg3
1008   %cmp2 = fcmp nnan oge float %add2, %arg3
1009   %or1  = or i1 %cmp1, %cmp2
1010   ret i1 %or1
1013 define i1 @test66(double %arg1, double %arg2, double %arg3) {
1014 ; GCN-LABEL: test66:
1015 ; GCN:       ; %bb.0:
1016 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1017 ; GCN-NEXT:    v_add_f64 v[0:1], v[0:1], 1.0
1018 ; GCN-NEXT:    v_add_f64 v[2:3], v[2:3], 2.0
1019 ; GCN-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
1020 ; GCN-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
1021 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1022 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1023   %add1 = fadd nnan double %arg1, 1.0
1024   %add2 = fadd nnan double %arg2, 2.0
1025   %cmp1 = fcmp nnan ugt double %add1, %arg3
1026   %cmp2 = fcmp nnan ugt double %add2, %arg3
1027   %and1  = and i1 %cmp1, %cmp2
1028   ret i1 %and1
1031 define i1 @test67(float %arg1, float %arg2, float %arg3) #0 {
1032 ; GCN-LABEL: test67:
1033 ; GCN:       ; %bb.0:
1034 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1035 ; GCN-NEXT:    v_dual_add_f32 v0, 1.0, v0 :: v_dual_add_f32 v1, 2.0, v1
1036 ; GCN-NEXT:    v_min_f32_e32 v0, v0, v1
1037 ; GCN-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
1038 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1039 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1040   %add1 = fadd nnan float %arg1, 1.0
1041   %add2 = fadd nnan float %arg2, 2.0
1042   %cmp1 = fcmp nnan uge float %add1, %arg3
1043   %cmp2 = fcmp nnan uge float %add2, %arg3
1044   %and1  = and i1 %cmp1, %cmp2
1045   ret i1 %and1
1048 define i1 @test68(float %arg1, float %arg2, float %arg3) #0 {
1049 ; GCN-LABEL: test68:
1050 ; GCN:       ; %bb.0:
1051 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1052 ; GCN-NEXT:    v_dual_add_f32 v0, 1.0, v0 :: v_dual_add_f32 v1, 2.0, v1
1053 ; GCN-NEXT:    v_max_f32_e32 v0, v0, v1
1054 ; GCN-NEXT:    v_cmp_le_f32_e32 vcc_lo, v0, v2
1055 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1056 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1057   %add1 = fadd nnan float %arg1, 1.0
1058   %add2 = fadd nnan float %arg2, 2.0
1059   %cmp1 = fcmp nnan ule float %add1, %arg3
1060   %cmp2 = fcmp nnan ule float %add2, %arg3
1061   %and1  = and i1 %cmp1, %cmp2
1062   ret i1 %and1
1065 define i1 @test69(double %arg1, double %arg2, double %arg3) {
1066 ; GCN-LABEL: test69:
1067 ; GCN:       ; %bb.0:
1068 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1069 ; GCN-NEXT:    v_add_f64 v[0:1], v[0:1], 1.0
1070 ; GCN-NEXT:    v_add_f64 v[2:3], v[2:3], 2.0
1071 ; GCN-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
1072 ; GCN-NEXT:    v_cmp_lt_f64_e32 vcc_lo, v[0:1], v[4:5]
1073 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1074 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1075   %add1 = fadd nnan double %arg1, 1.0
1076   %add2 = fadd nnan double %arg2, 2.0
1077   %cmp1 = fcmp nnan ult double %add1, %arg3
1078   %cmp2 = fcmp nnan ult double %add2, %arg3
1079   %and1 = and i1 %cmp1, %cmp2
1080   ret i1 %and1
1083 define i1 @test70(float %arg1, float %arg2, float %arg3) {
1084 ; GFX11-LABEL: test70:
1085 ; GFX11:       ; %bb.0:
1086 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1087 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v1, v1, v1
1088 ; GFX11-NEXT:    v_min_f32_e32 v0, v0, v1
1089 ; GFX11-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
1090 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1091 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1093 ; GFX11NONANS-LABEL: test70:
1094 ; GFX11NONANS:       ; %bb.0:
1095 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1096 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v1
1097 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
1098 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1099 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1100   %var1 = call float @llvm.canonicalize.f32(float %arg1)
1101   %var2 = call float @llvm.canonicalize.f32(float %arg2)
1102   %cmp1 = fcmp olt float %var1, %arg3
1103   %cmp2 = fcmp olt float %var2, %arg3
1104   %or1  = or i1 %cmp1, %cmp2
1105   ret i1 %or1
1108 define i1 @test71(double %arg1, double %arg2, double %arg3) {
1109 ; GCN-LABEL: test71:
1110 ; GCN:       ; %bb.0:
1111 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1112 ; GCN-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
1113 ; GCN-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
1114 ; GCN-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
1115 ; GCN-NEXT:    v_cmp_le_f64_e32 vcc_lo, v[0:1], v[4:5]
1116 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1117 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1118   %var1 = call double @llvm.canonicalize.f64(double %arg1)
1119   %var2 = call double @llvm.canonicalize.f64(double %arg2)
1120   %cmp1 = fcmp ole double %var1, %arg3
1121   %cmp2 = fcmp ole double %var2, %arg3
1122   %or1  = or i1 %cmp1, %cmp2
1123   ret i1 %or1
1126 define i1 @test72(double %arg1, double %arg2, double %arg3) {
1127 ; GCN-LABEL: test72:
1128 ; GCN:       ; %bb.0:
1129 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1130 ; GCN-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
1131 ; GCN-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
1132 ; GCN-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
1133 ; GCN-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
1134 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1135 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1136   %var1 = call double @llvm.canonicalize.f64(double %arg1)
1137   %var2 = call double @llvm.canonicalize.f64(double %arg2)
1138   %cmp1 = fcmp ogt double %var1, %arg3
1139   %cmp2 = fcmp ogt double %var2, %arg3
1140   %or1  = or i1 %cmp1, %cmp2
1141   ret i1 %or1
1144 define i1 @test73(float %arg1, float %arg2, float %arg3) {
1145 ; GFX11-LABEL: test73:
1146 ; GFX11:       ; %bb.0:
1147 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1148 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v1, v1, v1
1149 ; GFX11-NEXT:    v_max_f32_e32 v0, v0, v1
1150 ; GFX11-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
1151 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1152 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1154 ; GFX11NONANS-LABEL: test73:
1155 ; GFX11NONANS:       ; %bb.0:
1156 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1157 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
1158 ; GFX11NONANS-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
1159 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1160 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1161   %var1 = call float @llvm.canonicalize.f32(float %arg1)
1162   %var2 = call float @llvm.canonicalize.f32(float %arg2)
1163   %cmp1 = fcmp oge float %var1, %arg3
1164   %cmp2 = fcmp oge float %var2, %arg3
1165   %or1  = or i1 %cmp1, %cmp2
1166   ret i1 %or1
1169 define i1 @test74(double %arg1, double %arg2, double %arg3) {
1170 ; GFX11-LABEL: test74:
1171 ; GFX11:       ; %bb.0:
1172 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1173 ; GFX11-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
1174 ; GFX11-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
1175 ; GFX11-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
1176 ; GFX11-NEXT:    v_cmp_nle_f64_e32 vcc_lo, v[0:1], v[4:5]
1177 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1178 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1180 ; GFX11NONANS-LABEL: test74:
1181 ; GFX11NONANS:       ; %bb.0:
1182 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1183 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
1184 ; GFX11NONANS-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
1185 ; GFX11NONANS-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
1186 ; GFX11NONANS-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
1187 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1188 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1189   %var1 = call double @llvm.canonicalize.f64(double %arg1)
1190   %var2 = call double @llvm.canonicalize.f64(double %arg2)
1191   %cmp1 = fcmp ugt double %var1, %arg3
1192   %cmp2 = fcmp ugt double %var2, %arg3
1193   %and1  = and i1 %cmp1, %cmp2
1194   ret i1 %and1
1197 define i1 @test75(float %arg1, float %arg2, float %arg3) {
1198 ; GFX11-LABEL: test75:
1199 ; GFX11:       ; %bb.0:
1200 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1201 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v1, v1, v1
1202 ; GFX11-NEXT:    v_min_f32_e32 v0, v0, v1
1203 ; GFX11-NEXT:    v_cmp_nlt_f32_e32 vcc_lo, v0, v2
1204 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1205 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1207 ; GFX11NONANS-LABEL: test75:
1208 ; GFX11NONANS:       ; %bb.0:
1209 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1210 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v1
1211 ; GFX11NONANS-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
1212 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1213 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1214   %var1 = call float @llvm.canonicalize.f32(float %arg1)
1215   %var2 = call float @llvm.canonicalize.f32(float %arg2)
1216   %cmp1 = fcmp uge float %var1, %arg3
1217   %cmp2 = fcmp uge float %var2, %arg3
1218   %and1  = and i1 %cmp1, %cmp2
1219   ret i1 %and1
1222 define i1 @test76(float %arg1, float %arg2, float %arg3) {
1223 ; GFX11-LABEL: test76:
1224 ; GFX11:       ; %bb.0:
1225 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1226 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v1, v1, v1
1227 ; GFX11-NEXT:    v_max_f32_e32 v0, v0, v1
1228 ; GFX11-NEXT:    v_cmp_ngt_f32_e32 vcc_lo, v0, v2
1229 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1230 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1232 ; GFX11NONANS-LABEL: test76:
1233 ; GFX11NONANS:       ; %bb.0:
1234 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1235 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
1236 ; GFX11NONANS-NEXT:    v_cmp_le_f32_e32 vcc_lo, v0, v2
1237 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1238 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1239   %var1 = call float @llvm.canonicalize.f32(float %arg1)
1240   %var2 = call float @llvm.canonicalize.f32(float %arg2)
1241   %cmp1 = fcmp ule float %var1, %arg3
1242   %cmp2 = fcmp ule float %var2, %arg3
1243   %and1  = and i1 %cmp1, %cmp2
1244   ret i1 %and1
1247 define i1 @test77(double %arg1, double %arg2, double %arg3) {
1248 ; GFX11-LABEL: test77:
1249 ; GFX11:       ; %bb.0:
1250 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1251 ; GFX11-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
1252 ; GFX11-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
1253 ; GFX11-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
1254 ; GFX11-NEXT:    v_cmp_nge_f64_e32 vcc_lo, v[0:1], v[4:5]
1255 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1256 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1258 ; GFX11NONANS-LABEL: test77:
1259 ; GFX11NONANS:       ; %bb.0:
1260 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1261 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
1262 ; GFX11NONANS-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
1263 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
1264 ; GFX11NONANS-NEXT:    v_cmp_lt_f64_e32 vcc_lo, v[0:1], v[4:5]
1265 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1266 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1267   %var1 = call double @llvm.canonicalize.f64(double %arg1)
1268   %var2 = call double @llvm.canonicalize.f64(double %arg2)
1269   %cmp1 = fcmp ult double %var1, %arg3
1270   %cmp2 = fcmp ult double %var2, %arg3
1271   %and1 = and i1 %cmp1, %cmp2
1272   ret i1 %and1
1275 define i1 @test78(float %arg1, float %arg2, float %arg3) #0 {
1276 ; GCN-LABEL: test78:
1277 ; GCN:       ; %bb.0:
1278 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1279 ; GCN-NEXT:    v_min_f32_e32 v0, v0, v1
1280 ; GCN-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
1281 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1282 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1283   %cmp1 = fcmp olt float %arg1, %arg3
1284   %cmp2 = fcmp ogt float %arg3, %arg2
1285   %or1  = or i1 %cmp1, %cmp2
1286   ret i1 %or1
1289 define i1 @test79(float %arg1, float %arg2, float %arg3) #0 {
1290 ; GFX11-LABEL: test79:
1291 ; GFX11:       ; %bb.0:
1292 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1293 ; GFX11-NEXT:    v_max_f32_e32 v0, v0, v1
1294 ; GFX11-NEXT:    v_cmp_nge_f32_e32 vcc_lo, v0, v2
1295 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1296 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1298 ; GFX11NONANS-LABEL: test79:
1299 ; GFX11NONANS:       ; %bb.0:
1300 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1301 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
1302 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
1303 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1304 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1305   %cmp1 = fcmp ult float %arg1, %arg3
1306   %cmp2 = fcmp ugt float %arg3, %arg2
1307   %and1  = and i1 %cmp1, %cmp2
1308   ret i1 %and1
1311 define i1 @test80(float %arg1, float %arg2, float %arg3) {
1312 ; GCN-LABEL: test80:
1313 ; GCN:       ; %bb.0:
1314 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1315 ; GCN-NEXT:    v_dual_add_f32 v0, 1.0, v0 :: v_dual_add_f32 v1, 2.0, v1
1316 ; GCN-NEXT:    v_max_f32_e32 v0, v0, v1
1317 ; GCN-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
1318 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1319 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1320   %add1 = fadd nnan float %arg1, 1.0
1321   %add2 = fadd nnan float %arg2, 2.0
1322   %cmp1 = fcmp nnan oge float %add1, %arg3
1323   %cmp2 = fcmp nnan ole float %arg3, %add2
1324   %or1  = or i1 %cmp1, %cmp2
1325   ret i1 %or1
1328 define i1 @test81(double %arg1, double %arg2, double %arg3) {
1329 ; GCN-LABEL: test81:
1330 ; GCN:       ; %bb.0:
1331 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1332 ; GCN-NEXT:    v_add_f64 v[0:1], v[0:1], 1.0
1333 ; GCN-NEXT:    v_add_f64 v[2:3], v[2:3], 2.0
1334 ; GCN-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
1335 ; GCN-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
1336 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1337 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1338   %add1 = fadd nnan double %arg1, 1.0
1339   %add2 = fadd nnan double %arg2, 2.0
1340   %cmp1 = fcmp nnan ugt double %add1, %arg3
1341   %cmp2 = fcmp nnan ult double %arg3, %add2
1342   %and1  = and i1 %cmp1, %cmp2
1343   ret i1 %and1
1346 define i1 @test82(double %arg1, double %arg2, double %arg3) {
1347 ; GCN-LABEL: test82:
1348 ; GCN:       ; %bb.0:
1349 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1350 ; GCN-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
1351 ; GCN-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
1352 ; GCN-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
1353 ; GCN-NEXT:    v_cmp_le_f64_e32 vcc_lo, v[0:1], v[4:5]
1354 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1355 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1356   %var1 = call double @llvm.canonicalize.f64(double %arg1)
1357   %var2 = call double @llvm.canonicalize.f64(double %arg2)
1358   %cmp1 = fcmp ole double %var1, %arg3
1359   %cmp2 = fcmp oge double %arg3, %var2
1360   %or1  = or i1 %cmp1, %cmp2
1361   ret i1 %or1
1364 define i1 @test83(float %arg1, float %arg2, float %arg3) {
1365 ; GFX11-LABEL: test83:
1366 ; GFX11:       ; %bb.0:
1367 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1368 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v1, v1, v1
1369 ; GFX11-NEXT:    v_max_f32_e32 v0, v0, v1
1370 ; GFX11-NEXT:    v_cmp_ngt_f32_e32 vcc_lo, v0, v2
1371 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1372 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1374 ; GFX11NONANS-LABEL: test83:
1375 ; GFX11NONANS:       ; %bb.0:
1376 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1377 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
1378 ; GFX11NONANS-NEXT:    v_cmp_le_f32_e32 vcc_lo, v0, v2
1379 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1380 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1381   %var1 = call float @llvm.canonicalize.f32(float %arg1)
1382   %var2 = call float @llvm.canonicalize.f32(float %arg2)
1383   %cmp1 = fcmp ule float %var1, %arg3
1384   %cmp2 = fcmp uge float %arg3, %var2
1385   %and1  = and i1 %cmp1, %cmp2
1386   ret i1 %and1
1389 define i1 @test84(half %arg1, half %arg2, half %arg3) {
1390 ; GFX11-LABEL: test84:
1391 ; GFX11:       ; %bb.0:
1392 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1393 ; GFX11-NEXT:    v_max_f16_e32 v0, v0, v0
1394 ; GFX11-NEXT:    v_max_f16_e32 v1, v1, v1
1395 ; GFX11-NEXT:    v_min_f16_e32 v0, v0, v1
1396 ; GFX11-NEXT:    v_cmp_lt_f16_e32 vcc_lo, v0, v2
1397 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1398 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1400 ; GFX11NONANS-LABEL: test84:
1401 ; GFX11NONANS:       ; %bb.0:
1402 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1403 ; GFX11NONANS-NEXT:    v_min_f16_e32 v0, v0, v1
1404 ; GFX11NONANS-NEXT:    v_cmp_lt_f16_e32 vcc_lo, v0, v2
1405 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1406 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1407   %var1 = call half @llvm.canonicalize.f16(half %arg1)
1408   %var2 = call half @llvm.canonicalize.f16(half %arg2)
1409   %cmp1 = fcmp olt half %var1, %arg3
1410   %cmp2 = fcmp olt half %var2, %arg3
1411   %or1  = or i1 %cmp1, %cmp2
1412   ret i1 %or1
1415 define <2 x i1> @test85(<2 x half> %arg1, <2 x half> %arg2, <2 x half> %arg3) {
1416 ; GFX11-LABEL: test85:
1417 ; GFX11:       ; %bb.0:
1418 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1419 ; GFX11-NEXT:    v_pk_max_f16 v0, v0, v0
1420 ; GFX11-NEXT:    v_pk_max_f16 v1, v1, v1
1421 ; GFX11-NEXT:    v_pk_min_f16 v0, v0, v1
1422 ; GFX11-NEXT:    v_lshrrev_b32_e32 v1, 16, v2
1423 ; GFX11-NEXT:    v_lshrrev_b32_e32 v3, 16, v0
1424 ; GFX11-NEXT:    v_cmp_le_f16_e32 vcc_lo, v0, v2
1425 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1426 ; GFX11-NEXT:    v_cmp_le_f16_e32 vcc_lo, v3, v1
1427 ; GFX11-NEXT:    v_cndmask_b32_e64 v1, 0, 1, vcc_lo
1428 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1430 ; GFX11NONANS-LABEL: test85:
1431 ; GFX11NONANS:       ; %bb.0:
1432 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1433 ; GFX11NONANS-NEXT:    v_pk_min_f16 v0, v0, v1
1434 ; GFX11NONANS-NEXT:    v_lshrrev_b32_e32 v1, 16, v2
1435 ; GFX11NONANS-NEXT:    v_lshrrev_b32_e32 v3, 16, v0
1436 ; GFX11NONANS-NEXT:    v_cmp_le_f16_e32 vcc_lo, v0, v2
1437 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1438 ; GFX11NONANS-NEXT:    v_cmp_le_f16_e32 vcc_lo, v3, v1
1439 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v1, 0, 1, vcc_lo
1440 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1441   %var1 = call <2 x half> @llvm.canonicalize.v2f16(<2 x half> %arg1)
1442   %var2 = call <2 x half> @llvm.canonicalize.v2f16(<2 x half> %arg2)
1443   %cmp1 = fcmp ole <2 x half> %var1, %arg3
1444   %cmp2 = fcmp ole <2 x half> %var2, %arg3
1445   %or1  = or <2 x i1> %cmp1, %cmp2
1446   ret <2 x i1> %or1
1449 define <2 x i1> @test86(<2 x half> %arg1, <2 x half> %arg2, <2 x half> %arg3) {
1450 ; GFX11-LABEL: test86:
1451 ; GFX11:       ; %bb.0:
1452 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1453 ; GFX11-NEXT:    v_pk_max_f16 v0, v0, v0
1454 ; GFX11-NEXT:    v_pk_max_f16 v1, v1, v1
1455 ; GFX11-NEXT:    v_pk_max_f16 v0, v0, v1
1456 ; GFX11-NEXT:    v_lshrrev_b32_e32 v1, 16, v2
1457 ; GFX11-NEXT:    v_lshrrev_b32_e32 v3, 16, v0
1458 ; GFX11-NEXT:    v_cmp_gt_f16_e32 vcc_lo, v0, v2
1459 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1460 ; GFX11-NEXT:    v_cmp_gt_f16_e32 vcc_lo, v3, v1
1461 ; GFX11-NEXT:    v_cndmask_b32_e64 v1, 0, 1, vcc_lo
1462 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1464 ; GFX11NONANS-LABEL: test86:
1465 ; GFX11NONANS:       ; %bb.0:
1466 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1467 ; GFX11NONANS-NEXT:    v_pk_max_f16 v0, v0, v1
1468 ; GFX11NONANS-NEXT:    v_lshrrev_b32_e32 v1, 16, v2
1469 ; GFX11NONANS-NEXT:    v_lshrrev_b32_e32 v3, 16, v0
1470 ; GFX11NONANS-NEXT:    v_cmp_gt_f16_e32 vcc_lo, v0, v2
1471 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1472 ; GFX11NONANS-NEXT:    v_cmp_gt_f16_e32 vcc_lo, v3, v1
1473 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v1, 0, 1, vcc_lo
1474 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1475   %var1 = call <2 x half> @llvm.canonicalize.v2f16(<2 x half> %arg1)
1476   %var2 = call <2 x half> @llvm.canonicalize.v2f16(<2 x half> %arg2)
1477   %cmp1 = fcmp ogt <2 x half> %var1, %arg3
1478   %cmp2 = fcmp ogt <2 x half> %var2, %arg3
1479   %or1  = or <2 x i1> %cmp1, %cmp2
1480   ret <2 x i1> %or1
1483 define i1 @test87(half %arg1, half %arg2, half %arg3) {
1484 ; GFX11-LABEL: test87:
1485 ; GFX11:       ; %bb.0:
1486 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1487 ; GFX11-NEXT:    v_max_f16_e32 v0, v0, v0
1488 ; GFX11-NEXT:    v_max_f16_e32 v1, v1, v1
1489 ; GFX11-NEXT:    v_max_f16_e32 v0, v0, v1
1490 ; GFX11-NEXT:    v_cmp_ge_f16_e32 vcc_lo, v0, v2
1491 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1492 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1494 ; GFX11NONANS-LABEL: test87:
1495 ; GFX11NONANS:       ; %bb.0:
1496 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1497 ; GFX11NONANS-NEXT:    v_max_f16_e32 v0, v0, v1
1498 ; GFX11NONANS-NEXT:    v_cmp_ge_f16_e32 vcc_lo, v0, v2
1499 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1500 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1501   %var1 = call half @llvm.canonicalize.f16(half %arg1)
1502   %var2 = call half @llvm.canonicalize.f16(half %arg2)
1503   %cmp1 = fcmp oge half %var1, %arg3
1504   %cmp2 = fcmp oge half %var2, %arg3
1505   %or1  = or i1 %cmp1, %cmp2
1506   ret i1 %or1
1509 define <2 x i1> @test88(<2 x half> %arg1, <2 x half> %arg2, <2 x half> %arg3) {
1510 ; GFX11-LABEL: test88:
1511 ; GFX11:       ; %bb.0:
1512 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1513 ; GFX11-NEXT:    v_pk_max_f16 v0, v0, v0
1514 ; GFX11-NEXT:    v_pk_max_f16 v1, v1, v1
1515 ; GFX11-NEXT:    v_pk_min_f16 v0, v0, v1
1516 ; GFX11-NEXT:    v_lshrrev_b32_e32 v1, 16, v2
1517 ; GFX11-NEXT:    v_lshrrev_b32_e32 v3, 16, v0
1518 ; GFX11-NEXT:    v_cmp_nle_f16_e32 vcc_lo, v0, v2
1519 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1520 ; GFX11-NEXT:    v_cmp_nle_f16_e32 vcc_lo, v3, v1
1521 ; GFX11-NEXT:    v_cndmask_b32_e64 v1, 0, 1, vcc_lo
1522 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1524 ; GFX11NONANS-LABEL: test88:
1525 ; GFX11NONANS:       ; %bb.0:
1526 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1527 ; GFX11NONANS-NEXT:    v_pk_min_f16 v0, v0, v1
1528 ; GFX11NONANS-NEXT:    v_lshrrev_b32_e32 v1, 16, v2
1529 ; GFX11NONANS-NEXT:    v_lshrrev_b32_e32 v3, 16, v0
1530 ; GFX11NONANS-NEXT:    v_cmp_gt_f16_e32 vcc_lo, v0, v2
1531 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1532 ; GFX11NONANS-NEXT:    v_cmp_gt_f16_e32 vcc_lo, v3, v1
1533 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v1, 0, 1, vcc_lo
1534 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1535   %var1 = call <2 x half> @llvm.canonicalize.v2f16(<2 x half> %arg1)
1536   %var2 = call <2 x half> @llvm.canonicalize.v2f16(<2 x half> %arg2)
1537   %cmp1 = fcmp ugt <2 x half> %var1, %arg3
1538   %cmp2 = fcmp ugt <2 x half> %var2, %arg3
1539   %and1  = and <2 x i1> %cmp1, %cmp2
1540   ret <2 x i1> %and1
1543 define i1 @test89(half %arg1, half %arg2, half %arg3) {
1544 ; GFX11-LABEL: test89:
1545 ; GFX11:       ; %bb.0:
1546 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1547 ; GFX11-NEXT:    v_max_f16_e32 v0, v0, v0
1548 ; GFX11-NEXT:    v_max_f16_e32 v1, v1, v1
1549 ; GFX11-NEXT:    v_min_f16_e32 v0, v0, v1
1550 ; GFX11-NEXT:    v_cmp_nlt_f16_e32 vcc_lo, v0, v2
1551 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1552 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1554 ; GFX11NONANS-LABEL: test89:
1555 ; GFX11NONANS:       ; %bb.0:
1556 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1557 ; GFX11NONANS-NEXT:    v_min_f16_e32 v0, v0, v1
1558 ; GFX11NONANS-NEXT:    v_cmp_ge_f16_e32 vcc_lo, v0, v2
1559 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1560 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1561   %var1 = call half @llvm.canonicalize.f16(half %arg1)
1562   %var2 = call half @llvm.canonicalize.f16(half %arg2)
1563   %cmp1 = fcmp uge half %var1, %arg3
1564   %cmp2 = fcmp uge half %var2, %arg3
1565   %and1  = and i1 %cmp1, %cmp2
1566   ret i1 %and1
1569 define i1 @test90(half %arg1, half %arg2, half %arg3) {
1570 ; GFX11-LABEL: test90:
1571 ; GFX11:       ; %bb.0:
1572 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1573 ; GFX11-NEXT:    v_max_f16_e32 v0, v0, v0
1574 ; GFX11-NEXT:    v_max_f16_e32 v1, v1, v1
1575 ; GFX11-NEXT:    v_max_f16_e32 v0, v0, v1
1576 ; GFX11-NEXT:    v_cmp_ngt_f16_e32 vcc_lo, v0, v2
1577 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1578 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1580 ; GFX11NONANS-LABEL: test90:
1581 ; GFX11NONANS:       ; %bb.0:
1582 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1583 ; GFX11NONANS-NEXT:    v_max_f16_e32 v0, v0, v1
1584 ; GFX11NONANS-NEXT:    v_cmp_le_f16_e32 vcc_lo, v0, v2
1585 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1586 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1587   %var1 = call half @llvm.canonicalize.f16(half %arg1)
1588   %var2 = call half @llvm.canonicalize.f16(half %arg2)
1589   %cmp1 = fcmp ule half %var1, %arg3
1590   %cmp2 = fcmp ule half %var2, %arg3
1591   %and1  = and i1 %cmp1, %cmp2
1592   ret i1 %and1
1595 define <2 x i1> @test91(<2 x half> %arg1, <2 x half> %arg2, <2 x half> %arg3) {
1596 ; GFX11-LABEL: test91:
1597 ; GFX11:       ; %bb.0:
1598 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1599 ; GFX11-NEXT:    v_pk_max_f16 v0, v0, v0
1600 ; GFX11-NEXT:    v_pk_max_f16 v1, v1, v1
1601 ; GFX11-NEXT:    v_pk_max_f16 v0, v0, v1
1602 ; GFX11-NEXT:    v_lshrrev_b32_e32 v1, 16, v2
1603 ; GFX11-NEXT:    v_lshrrev_b32_e32 v3, 16, v0
1604 ; GFX11-NEXT:    v_cmp_nge_f16_e32 vcc_lo, v0, v2
1605 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1606 ; GFX11-NEXT:    v_cmp_nge_f16_e32 vcc_lo, v3, v1
1607 ; GFX11-NEXT:    v_cndmask_b32_e64 v1, 0, 1, vcc_lo
1608 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
1610 ; GFX11NONANS-LABEL: test91:
1611 ; GFX11NONANS:       ; %bb.0:
1612 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1613 ; GFX11NONANS-NEXT:    v_pk_max_f16 v0, v0, v1
1614 ; GFX11NONANS-NEXT:    v_lshrrev_b32_e32 v1, 16, v2
1615 ; GFX11NONANS-NEXT:    v_lshrrev_b32_e32 v3, 16, v0
1616 ; GFX11NONANS-NEXT:    v_cmp_lt_f16_e32 vcc_lo, v0, v2
1617 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1618 ; GFX11NONANS-NEXT:    v_cmp_lt_f16_e32 vcc_lo, v3, v1
1619 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v1, 0, 1, vcc_lo
1620 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
1621   %var1 = call <2 x half> @llvm.canonicalize.v2f16(<2 x half> %arg1)
1622   %var2 = call <2 x half> @llvm.canonicalize.v2f16(<2 x half> %arg2)
1623   %cmp1 = fcmp ult <2 x half> %var1, %arg3
1624   %cmp2 = fcmp ult <2 x half> %var2, %arg3
1625   %and1 = and <2 x i1> %cmp1, %cmp2
1626   ret <2 x i1> %and1
1629 define i1 @test92(i32 %arg1, i32 %arg2, i32 %arg3, i32 %C) {
1630 ; GCN-LABEL: test92:
1631 ; GCN:       ; %bb.0:
1632 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1633 ; GCN-NEXT:    v_min3_u32 v0, v0, v1, v2
1634 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v3
1635 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1636 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1637   %cmp1 = icmp ult i32 %arg1, %C
1638   %cmp2 = icmp ult i32 %arg2, %C
1639   %cmp3 = icmp ult i32 %arg3, %C
1640   %or1 = or i1 %cmp1, %cmp2
1641   %or2 = or i1 %or1, %cmp3
1642   ret i1 %or2
1645 define i1 @test93(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %C) {
1646 ; GCN-LABEL: test93:
1647 ; GCN:       ; %bb.0:
1648 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1649 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
1650 ; GCN-NEXT:    v_max_u32_e32 v1, v2, v3
1651 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v4
1652 ; GCN-NEXT:    v_cmp_gt_u32_e64 s0, v1, v4
1653 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
1654 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
1655 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1656   %cmp1 = icmp ult i32 %arg1, %C
1657   %cmp2 = icmp ult i32 %arg2, %C
1658   %cmp3 = icmp ugt i32 %arg3, %C
1659   %cmp4 = icmp ugt i32 %arg4, %C
1660   %or1 = or i1 %cmp1, %cmp2
1661   %or2 = or i1 %cmp3, %cmp4
1662   %or3 = or i1 %or1, %or2
1663   ret i1 %or3
1666 define i1 @test94(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %arg5, i32 %arg6, i32 %arg7, i32 %arg8, i32 %C) {
1667 ; GCN-LABEL: test94:
1668 ; GCN:       ; %bb.0:
1669 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1670 ; GCN-NEXT:    v_min_u32_e32 v2, v2, v3
1671 ; GCN-NEXT:    v_min3_u32 v0, v0, v1, v2
1672 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v4
1673 ; GCN-NEXT:    v_min3_u32 v0, v5, v6, v0
1674 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v8
1675 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1676 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1677   %cmp1 = icmp ult i32 %arg1, %C
1678   %cmp2 = icmp ult i32 %arg2, %C
1679   %or1  = or i1 %cmp1, %cmp2
1680   %cmp3 = icmp ult i32 %arg3, %C
1681   %cmp4 = icmp ult i32 %arg4, %C
1682   %or2  = or i1 %cmp3, %cmp4
1683   %cmp5 = icmp ult i32 %arg5, %C
1684   %or3 = or i1 %or1, %or2
1685   %or4 = or i1 %or3, %cmp5
1686   %cmp6 = icmp ult i32 %arg6, %C
1687   %cmp7 = icmp ult i32 %arg7, %C
1688   %or5 = or i1 %cmp6, %cmp7
1689   %cmp8 = icmp ult i32 %arg8, %C
1690   %or6 = or i1 %or5, %or4
1691   %or7 = or i1 %or6, %cmp8
1692   ret i1 %or6
1695 define i1 @test95(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %C) {
1696 ; GCN-LABEL: test95:
1697 ; GCN:       ; %bb.0:
1698 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1699 ; GCN-NEXT:    v_maxmin_u32 v0, v0, v1, v2
1700 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v4
1701 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1702 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1703   %cmp1 = icmp ult i32 %arg1, %C
1704   %cmp2 = icmp ult i32 %arg2, %C
1705   %cmp3 = icmp ult i32 %arg3, %C
1706   %and1 = and i1 %cmp1, %cmp2
1707   %or1 = or i1 %and1, %cmp3
1708   ret i1 %or1
1711 define i1 @test96(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %C) {
1712 ; GCN-LABEL: test96:
1713 ; GCN:       ; %bb.0:
1714 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1715 ; GCN-NEXT:    v_minmax_u32 v0, v0, v1, v2
1716 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v4
1717 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1718 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1719   %cmp1 = icmp ult i32 %arg1, %C
1720   %cmp2 = icmp ult i32 %arg2, %C
1721   %cmp3 = icmp ult i32 %arg3, %C
1722   %and1 = or i1 %cmp1, %cmp2
1723   %or1 = and i1 %and1, %cmp3
1724   ret i1 %or1
1727 define i1 @test97(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %C) {
1728 ; GCN-LABEL: test97:
1729 ; GCN:       ; %bb.0:
1730 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1731 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
1732 ; GCN-NEXT:    v_max3_u32 v0, v0, v2, v3
1733 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v4
1734 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1735 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1736   %cmp1 = icmp ult i32 %arg1, %C
1737   %cmp2 = icmp ult i32 %arg2, %C
1738   %cmp3 = icmp ult i32 %arg3, %C
1739   %cmp4 = icmp ult i32 %arg4, %C
1740   %or1 = or i1 %cmp1, %cmp2
1741   %and1 = and i1 %cmp3, %cmp4
1742   %and2 = and i1 %or1, %and1
1743   ret i1 %and2
1746 define i1 @test98(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %C) {
1747 ; GCN-LABEL: test98:
1748 ; GCN:       ; %bb.0:
1749 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1750 ; GCN-NEXT:    v_min_u32_e32 v2, v2, v3
1751 ; GCN-NEXT:    v_minmax_u32 v0, v0, v1, v2
1752 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v4
1753 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1754 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1755   %cmp1 = icmp ult i32 %arg1, %C
1756   %cmp2 = icmp ult i32 %arg2, %C
1757   %cmp3 = icmp ult i32 %arg3, %C
1758   %cmp4 = icmp ult i32 %arg4, %C
1759   %or1 = or i1 %cmp1, %cmp2
1760   %or2 = or i1 %cmp3, %cmp4
1761   %and1 = and i1 %or1, %or2
1762   ret i1 %and1
1765 define i1 @test99(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %C) {
1766 ; GCN-LABEL: test99:
1767 ; GCN:       ; %bb.0:
1768 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1769 ; GCN-NEXT:    v_max_u32_e32 v2, v2, v3
1770 ; GCN-NEXT:    v_min3_u32 v0, v0, v1, v2
1771 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v4
1772 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1773 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1774   %cmp1 = icmp ult i32 %arg1, %C
1775   %cmp2 = icmp ult i32 %arg2, %C
1776   %cmp3 = icmp ult i32 %arg3, %C
1777   %cmp4 = icmp ult i32 %arg4, %C
1778   %or1 = or i1 %cmp1, %cmp2
1779   %and1 = and i1 %cmp3, %cmp4
1780   %or2 = or i1 %or1, %and1
1781   ret i1 %or2
1784 define i1 @test100(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %C) {
1785 ; GCN-LABEL: test100:
1786 ; GCN:       ; %bb.0:
1787 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1788 ; GCN-NEXT:    v_max_u32_e32 v2, v2, v3
1789 ; GCN-NEXT:    v_maxmin_u32 v0, v0, v1, v2
1790 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v4
1791 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1792 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1793   %cmp1 = icmp ult i32 %arg1, %C
1794   %cmp2 = icmp ult i32 %arg2, %C
1795   %cmp3 = icmp ult i32 %arg3, %C
1796   %cmp4 = icmp ult i32 %arg4, %C
1797   %and1 = and i1 %cmp1, %cmp2
1798   %and2 = and i1 %cmp3, %cmp4
1799   %or1 = or i1 %and1, %and2
1800   ret i1 %or1
1803 define i1 @test101(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %arg5, i32 %arg6, i32 %C) {
1804 ; GCN-LABEL: test101:
1805 ; GCN:       ; %bb.0:
1806 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1807 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
1808 ; GCN-NEXT:    v_minmax_u32 v1, v3, v4, v5
1809 ; GCN-NEXT:    v_min3_u32 v0, v0, v2, v1
1810 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v6
1811 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1812 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1813   %cmp1 = icmp ult i32 %arg1, %C
1814   %cmp2 = icmp ult i32 %arg2, %C
1815   %cmp3 = icmp ult i32 %arg3, %C
1816   %and1 = and i1 %cmp1, %cmp2
1817   %or1 = or i1 %and1, %cmp3
1818   %cmp4 = icmp ult i32 %arg4, %C
1819   %cmp5 = icmp ult i32 %arg5, %C
1820   %cmp6 = icmp ult i32 %arg6, %C
1821   %or2 = or i1 %cmp4, %cmp5
1822   %and2 = and i1 %or2, %cmp6
1823   %or3 = or i1 %or1, %and2
1824   ret i1 %or3
1827 define i1 @test102(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %arg5, i32 %arg6, i32 %C) {
1828 ; GCN-LABEL: test102:
1829 ; GCN:       ; %bb.0:
1830 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1831 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
1832 ; GCN-NEXT:    v_min_u32_e32 v1, v2, v3
1833 ; GCN-NEXT:    v_min3_u32 v0, v0, v5, v1
1834 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v6
1835 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
1836 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1837   %cmp1 = icmp ult i32 %arg1, %C
1838   %cmp2 = icmp ult i32 %arg2, %C
1839   %cmp3 = icmp ult i32 %arg3, %C
1840   %cmp4 = icmp ult i32 %arg4, %C
1841   %cmp5 = icmp ult i32 %arg5, %C
1842   %cmp6 = icmp ult i32 %arg6, %C
1843   %and1 = and i1 %cmp1, %cmp2
1844   %or1 = or i1 %cmp3, %cmp4
1845   %and2 = and i1 %cmp4, %cmp5
1846   %or2 = or i1 %and1, %cmp6
1847   %or3 = or i1 %or1, %and2
1848   %or4 = or i1 %or2, %or3
1849   ret i1 %or4
1852 define i1 @test103(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %arg5, i32 %arg6, i32 %C) {
1853 ; GCN-LABEL: test103:
1854 ; GCN:       ; %bb.0:
1855 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1856 ; GCN-NEXT:    v_max_u32_e32 v4, v4, v5
1857 ; GCN-NEXT:    v_max_u32_e32 v2, v2, v3
1858 ; GCN-NEXT:    v_maxmin_u32 v0, v0, v1, v4
1859 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, v2, v6
1860 ; GCN-NEXT:    v_cmp_lt_u32_e64 s0, v0, v6
1861 ; GCN-NEXT:    s_or_b32 s0, s0, vcc_lo
1862 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
1863 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1864   %cmp1 = icmp ult i32 %arg1, %C
1865   %cmp2 = icmp ult i32 %arg2, %C
1866   %cmp3 = icmp ugt i32 %arg3, %C
1867   %cmp4 = icmp ugt i32 %arg4, %C
1868   %cmp5 = icmp ult i32 %arg5, %C
1869   %cmp6 = icmp ult i32 %arg6, %C
1870   %and1 = and i1 %cmp1, %cmp2
1871   %or1 = or i1 %cmp3, %cmp4
1872   %and2 = and i1 %cmp5, %cmp6
1873   %or2 = or i1 %and1, %or1
1874   %or3 = or i1 %or2, %and2
1875   ret i1 %or3
1879 define i1 @test104(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %arg5, i32 %arg6, i32 %arg7, i32 %arg8, i32 %arg9, i32 %arg10, i32 %C) {
1880 ; GCN-LABEL: test104:
1881 ; GCN:       ; %bb.0:
1882 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1883 ; GCN-NEXT:    v_min_u32_e32 v8, v8, v9
1884 ; GCN-NEXT:    v_max_u32_e32 v2, v2, v3
1885 ; GCN-NEXT:    v_min_u32_e32 v3, v4, v5
1886 ; GCN-NEXT:    v_max_u32_e32 v4, v6, v7
1887 ; GCN-NEXT:    v_min3_u32 v0, v0, v1, v8
1888 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, v2, v10
1889 ; GCN-NEXT:    v_cmp_lt_u32_e64 s0, v3, v10
1890 ; GCN-NEXT:    v_cmp_gt_u32_e64 s1, v4, v10
1891 ; GCN-NEXT:    v_cmp_lt_u32_e64 s2, v0, v10
1892 ; GCN-NEXT:    s_or_b32 s0, s0, s1
1893 ; GCN-NEXT:    s_or_b32 s1, s2, vcc_lo
1894 ; GCN-NEXT:    s_or_b32 s0, s0, s1
1895 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
1896 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1897   %cmp1 = icmp ult i32 %arg1, %C
1898   %cmp2 = icmp ult i32 %arg2, %C
1899   %cmp3 = icmp ugt i32 %arg3, %C
1900   %cmp4 = icmp ugt i32 %arg4, %C
1901   %cmp5 = icmp ult i32 %arg5, %C
1902   %cmp6 = icmp ult i32 %arg6, %C
1903   %cmp7 = icmp ugt i32 %arg7, %C
1904   %cmp8 = icmp ugt i32 %arg8, %C
1905   %cmp9 = icmp ult i32 %arg9, %C
1906   %cmp10 = icmp ult i32 %arg10, %C
1907   %or1 = or i1 %cmp1, %cmp2
1908   %or2 = or i1 %cmp3, %cmp4
1909   %or3 = or i1 %cmp5, %cmp6
1910   %or4 = or i1 %cmp7, %cmp8
1911   %or5 = or i1 %cmp9, %cmp10
1912   %or6 = or i1 %or1, %or2
1913   %or7 = or i1 %or3, %or4
1914   %or8 = or i1 %or5, %or6
1915   %or9 = or i1 %or7, %or8
1916   ret i1 %or9
1919 define i1 @test105(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %arg5, i32 %arg6, i32 %arg7, i32 %arg8, i32 %arg9, i32 %arg10, i32 %C) {
1920 ; GCN-LABEL: test105:
1921 ; GCN:       ; %bb.0:
1922 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1923 ; GCN-NEXT:    v_max_u32_e32 v0, v0, v1
1924 ; GCN-NEXT:    v_max_u32_e32 v1, v2, v3
1925 ; GCN-NEXT:    v_max_u32_e32 v2, v4, v5
1926 ; GCN-NEXT:    v_max_u32_e32 v3, v6, v7
1927 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v10
1928 ; GCN-NEXT:    v_cmp_gt_u32_e64 s0, v1, v10
1929 ; GCN-NEXT:    v_cmp_lt_u32_e64 s1, v2, v10
1930 ; GCN-NEXT:    v_cmp_gt_u32_e64 s2, v3, v10
1931 ; GCN-NEXT:    s_and_b32 s0, vcc_lo, s0
1932 ; GCN-NEXT:    s_or_b32 s1, s2, s1
1933 ; GCN-NEXT:    s_and_b32 s0, s0, s1
1934 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
1935 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1936   %cmp1 = icmp ult i32 %arg1, %C
1937   %cmp2 = icmp ult i32 %arg2, %C
1938   %cmp3 = icmp ugt i32 %arg3, %C
1939   %cmp4 = icmp ugt i32 %arg4, %C
1940   %cmp5 = icmp ult i32 %arg5, %C
1941   %cmp6 = icmp ult i32 %arg6, %C
1942   %cmp7 = icmp ugt i32 %arg7, %C
1943   %cmp8 = icmp ugt i32 %arg8, %C
1944   %and1 = and i1 %cmp1, %cmp2
1945   %or1 = or i1 %cmp3, %cmp4
1946   %and2 = and i1 %cmp5, %cmp6
1947   %or2 = or i1 %cmp7, %cmp8
1948   %and3 = and i1 %and1, %or1
1949   %or3 = or i1 %or2, %and2
1950   %or4 = and i1 %and3, %or3
1951   ret i1 %or4
1954 define i1 @test106(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4, i32 %arg5, i32 %arg6, i32 %arg7, i32 %arg8, i32 %arg9, i32 %arg10, i32 %arg11, i32 %arg12, i32 %C1, i32 %C2) {
1955 ; GCN-LABEL: test106:
1956 ; GCN:       ; %bb.0:
1957 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1958 ; GCN-NEXT:    v_min_u32_e32 v6, v6, v7
1959 ; GCN-NEXT:    v_min_u32_e32 v0, v0, v1
1960 ; GCN-NEXT:    v_min_u32_e32 v1, v10, v11
1961 ; GCN-NEXT:    v_min_u32_e32 v2, v2, v3
1962 ; GCN-NEXT:    v_min3_u32 v3, v4, v5, v6
1963 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v12
1964 ; GCN-NEXT:    v_min3_u32 v0, v8, v9, v1
1965 ; GCN-NEXT:    v_cmp_lt_u32_e64 s0, v2, v13
1966 ; GCN-NEXT:    v_cmp_lt_u32_e64 s1, v3, v13
1967 ; GCN-NEXT:    v_cmp_lt_u32_e64 s2, v0, v12
1968 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
1969 ; GCN-NEXT:    s_or_b32 s0, s0, s1
1970 ; GCN-NEXT:    s_or_b32 s0, s2, s0
1971 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
1972 ; GCN-NEXT:    s_setpc_b64 s[30:31]
1973   %cmp1 = icmp ult i32 %arg1, %C1
1974   %cmp2 = icmp ult i32 %arg2, %C1
1975   %cmp3 = icmp ult i32 %arg3, %C2
1976   %cmp4 = icmp ult i32 %arg4, %C2
1977   %cmp5 = icmp ult i32 %arg5, %C2
1978   %cmp6 = icmp ult i32 %arg6, %C2
1979   %cmp7 = icmp ult i32 %arg7, %C2
1980   %cmp8 = icmp ult i32 %arg8, %C2
1981   %cmp9 = icmp ult i32 %arg9, %C1
1982   %cmp10 = icmp ult i32 %arg10, %C1
1983   %cmp11 = icmp ult i32 %arg11, %C1
1984   %cmp12 = icmp ult i32 %arg12, %C1
1985   %or1 = or i1 %cmp1, %cmp2
1986   %or2 = or i1 %cmp3, %cmp4
1987   %or3 = or i1 %cmp5, %cmp6
1988   %or4 = or i1 %cmp7, %cmp8
1989   %or5 = or i1 %cmp9, %cmp10
1990   %or6 = or i1 %cmp11, %cmp12
1991   %or7 = or i1 %or1, %or2
1992   %or8 = or i1 %or3, %or4
1993   %or9 = or i1 %or5, %or6
1994   %or10 = or i1 %or7, %or8
1995   %or11 = or i1 %or9, %or10
1996   ret i1 %or11
1999 define i1 @test107(float %arg1, float %arg2, float %arg3, float %C) {
2000 ; GCN-LABEL: test107:
2001 ; GCN:       ; %bb.0:
2002 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2003 ; GCN-NEXT:    v_min3_f32 v0, v0, v1, v2
2004 ; GCN-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v3
2005 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2006 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2007   %cmp1 = fcmp olt float %arg1, %C
2008   %cmp2 = fcmp olt float %arg2, %C
2009   %cmp3 = fcmp olt float %arg3, %C
2010   %or1 = or i1 %cmp1, %cmp2
2011   %or2 = or i1 %or1, %cmp3
2012   ret i1 %or2
2015 define i1 @test108(float %arg1, float %arg2, float %arg3, float %C) {
2016 ; GFX11-LABEL: test108:
2017 ; GFX11:       ; %bb.0:
2018 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2019 ; GFX11-NEXT:    v_max3_f32 v0, v0, v1, v2
2020 ; GFX11-NEXT:    v_cmp_nge_f32_e32 vcc_lo, v0, v3
2021 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2022 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2024 ; GFX11NONANS-LABEL: test108:
2025 ; GFX11NONANS:       ; %bb.0:
2026 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2027 ; GFX11NONANS-NEXT:    v_max3_f32 v0, v0, v1, v2
2028 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v3
2029 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2030 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2031   %cmp1 = fcmp ult float %arg1, %C
2032   %cmp2 = fcmp ult float %arg2, %C
2033   %cmp3 = fcmp ult float %arg3, %C
2034   %and1 = and i1 %cmp1, %cmp2
2035   %and2 = and i1 %and1, %cmp3
2036   ret i1 %and2
2039 define i1 @test109(float %arg1, float %arg2, float %arg3, float %arg4, float %C) {
2040 ; GFX11-LABEL: test109:
2041 ; GFX11:       ; %bb.0:
2042 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2043 ; GFX11-NEXT:    v_dual_max_f32 v1, v1, v1 :: v_dual_max_f32 v0, v0, v0
2044 ; GFX11-NEXT:    v_dual_max_f32 v3, v3, v3 :: v_dual_max_f32 v2, v2, v2
2045 ; GFX11-NEXT:    v_dual_min_f32 v0, v0, v1 :: v_dual_max_f32 v1, v2, v3
2046 ; GFX11-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v4
2047 ; GFX11-NEXT:    v_cmp_gt_f32_e64 s0, v1, v4
2048 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
2049 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2050 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2052 ; GFX11NONANS-LABEL: test109:
2053 ; GFX11NONANS:       ; %bb.0:
2054 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2055 ; GFX11NONANS-NEXT:    v_dual_min_f32 v0, v0, v1 :: v_dual_max_f32 v1, v2, v3
2056 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v4
2057 ; GFX11NONANS-NEXT:    v_cmp_gt_f32_e64 s0, v1, v4
2058 ; GFX11NONANS-NEXT:    s_or_b32 s0, vcc_lo, s0
2059 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2060 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2061   %cmp1 = fcmp olt float %arg1, %C
2062   %cmp2 = fcmp olt float %arg2, %C
2063   %cmp3 = fcmp ogt float %arg3, %C
2064   %cmp4 = fcmp ogt float %arg4, %C
2065   %or1 = or i1 %cmp1, %cmp2
2066   %or2 = or i1 %cmp3, %cmp4
2067   %or3 = or i1 %or1, %or2
2068   ret i1 %or3
2071 define i1 @test110(float %arg1, float %arg2, float %arg3, float %arg4, float %C1, float %C2, float %C3, float %C4, float %C) #0 {
2072 ; GCN-LABEL: test110:
2073 ; GCN:       ; %bb.0:
2074 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2075 ; GCN-NEXT:    v_dual_add_f32 v0, v0, v4 :: v_dual_add_f32 v1, v1, v5
2076 ; GCN-NEXT:    v_dual_add_f32 v2, v2, v6 :: v_dual_add_f32 v3, v3, v7
2077 ; GCN-NEXT:    v_dual_max_f32 v0, v0, v1 :: v_dual_min_f32 v1, v2, v3
2078 ; GCN-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v8
2079 ; GCN-NEXT:    v_cmp_gt_f32_e64 s0, v1, v8
2080 ; GCN-NEXT:    s_and_b32 s0, vcc_lo, s0
2081 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2082 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2083   %add1 = fadd nnan float %arg1, %C1
2084   %add2 = fadd nnan float %arg2, %C2
2085   %add3 = fadd nnan float %arg3, %C3
2086   %add4 = fadd nnan float %arg4, %C4
2087   %cmp1 = fcmp nnan ult float %add1, %C
2088   %cmp2 = fcmp nnan ult float %add2, %C
2089   %cmp3 = fcmp nnan ugt float %add3, %C
2090   %cmp4 = fcmp nnan ugt float %add4, %C
2091   %or1 = and i1 %cmp1, %cmp2
2092   %or2 = and i1 %cmp3, %cmp4
2093   %or3 = and i1 %or1, %or2
2094   ret i1 %or3
2097 define i1 @test111(float %arg1, float %arg2, float %arg3, float %arg4, float %arg5, float %arg6, float %arg7, float %arg8, float %C) {
2098 ; GFX11-LABEL: test111:
2099 ; GFX11:       ; %bb.0:
2100 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2101 ; GFX11-NEXT:    v_dual_max_f32 v3, v3, v3 :: v_dual_max_f32 v2, v2, v2
2102 ; GFX11-NEXT:    v_dual_min_f32 v2, v2, v3 :: v_dual_max_f32 v3, v4, v4
2103 ; GFX11-NEXT:    v_min3_f32 v0, v0, v1, v2
2104 ; GFX11-NEXT:    v_min_f32_e32 v0, v0, v3
2105 ; GFX11-NEXT:    v_min3_f32 v0, v5, v6, v0
2106 ; GFX11-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v8
2107 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2108 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2110 ; GFX11NONANS-LABEL: test111:
2111 ; GFX11NONANS:       ; %bb.0:
2112 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2113 ; GFX11NONANS-NEXT:    v_min_f32_e32 v2, v2, v3
2114 ; GFX11NONANS-NEXT:    v_min3_f32 v0, v0, v1, v2
2115 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v4
2116 ; GFX11NONANS-NEXT:    v_min3_f32 v0, v5, v6, v0
2117 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v8
2118 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2119 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2120   %cmp1 = fcmp olt float %arg1, %C
2121   %cmp2 = fcmp olt float %arg2, %C
2122   %or1  = or i1 %cmp1, %cmp2
2123   %cmp3 = fcmp olt float %arg3, %C
2124   %cmp4 = fcmp olt float %arg4, %C
2125   %or2  = or i1 %cmp3, %cmp4
2126   %cmp5 = fcmp olt float %arg5, %C
2127   %or3 = or i1 %or1, %or2
2128   %or4 = or i1 %or3, %cmp5
2129   %cmp6 = fcmp olt float %arg6, %C
2130   %cmp7 = fcmp olt float %arg7, %C
2131   %or5 = or i1 %cmp6, %cmp7
2132   %cmp8 = fcmp olt float %arg8, %C
2133   %or6 = or i1 %or5, %or4
2134   %or7 = or i1 %or6, %cmp8
2135   ret i1 %or6
2138 define i1 @test112(float %arg1, float %arg2, float %arg3, float %arg4, float %arg5, float %arg6, float %arg7, float %arg8, float %C) {
2139 ; GFX11-LABEL: test112:
2140 ; GFX11:       ; %bb.0:
2141 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2142 ; GFX11-NEXT:    v_dual_max_f32 v3, v3, v3 :: v_dual_max_f32 v2, v2, v2
2143 ; GFX11-NEXT:    v_cmp_nge_f32_e32 vcc_lo, v4, v8
2144 ; GFX11-NEXT:    v_dual_max_f32 v5, v5, v5 :: v_dual_min_f32 v2, v2, v3
2145 ; GFX11-NEXT:    v_max_f32_e32 v3, v6, v6
2146 ; GFX11-NEXT:    v_min3_f32 v0, v0, v1, v2
2147 ; GFX11-NEXT:    v_min3_f32 v0, v0, v5, v3
2148 ; GFX11-NEXT:    v_cmp_lt_f32_e64 s0, v0, v8
2149 ; GFX11-NEXT:    s_or_b32 s0, s0, vcc_lo
2150 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2151 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2153 ; GFX11NONANS-LABEL: test112:
2154 ; GFX11NONANS:       ; %bb.0:
2155 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2156 ; GFX11NONANS-NEXT:    v_min_f32_e32 v2, v2, v3
2157 ; GFX11NONANS-NEXT:    v_min3_f32 v0, v0, v1, v2
2158 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v4
2159 ; GFX11NONANS-NEXT:    v_min3_f32 v0, v5, v6, v0
2160 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v8
2161 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2162 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2163   %cmp1 = fcmp olt float %arg1, %C
2164   %cmp2 = fcmp olt float %arg2, %C
2165   %or1  = or i1 %cmp1, %cmp2
2166   %cmp3 = fcmp olt float %arg3, %C
2167   %cmp4 = fcmp olt float %arg4, %C
2168   %or2  = or i1 %cmp3, %cmp4
2169   %cmp5 = fcmp ult float %arg5, %C
2170   %or3 = or i1 %or1, %or2
2171   %or4 = or i1 %or3, %cmp5
2172   %cmp6 = fcmp olt float %arg6, %C
2173   %cmp7 = fcmp olt float %arg7, %C
2174   %or5 = or i1 %cmp6, %cmp7
2175   %cmp8 = fcmp ult float %arg8, %C
2176   %or6 = or i1 %or5, %or4
2177   %or7 = or i1 %or6, %cmp8
2178   ret i1 %or6
2181 define i1 @test113(float %arg1, float %arg2, float %arg3, float %C) {
2182 ; GFX11-LABEL: test113:
2183 ; GFX11:       ; %bb.0:
2184 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2185 ; GFX11-NEXT:    v_dual_max_f32 v1, v1, v1 :: v_dual_max_f32 v0, v0, v0
2186 ; GFX11-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v2, v3
2187 ; GFX11-NEXT:    v_max_f32_e32 v0, v0, v1
2188 ; GFX11-NEXT:    v_cmp_nge_f32_e64 s0, v0, v3
2189 ; GFX11-NEXT:    s_or_b32 s0, s0, vcc_lo
2190 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2191 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2193 ; GFX11NONANS-LABEL: test113:
2194 ; GFX11NONANS:       ; %bb.0:
2195 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2196 ; GFX11NONANS-NEXT:    v_maxmin_f32 v0, v0, v1, v2
2197 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v3
2198 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2199 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2200   %cmp1 = fcmp ult float %arg1, %C
2201   %cmp2 = fcmp ult float %arg2, %C
2202   %cmp3 = fcmp olt float %arg3, %C
2203   %and1 = and i1 %cmp1, %cmp2
2204   %or1 = or i1 %and1, %cmp3
2205   ret i1 %or1
2208 define i1 @test114(float %arg1, float %arg2, float %arg3, float %C) {
2209 ; GFX11-LABEL: test114:
2210 ; GFX11:       ; %bb.0:
2211 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2212 ; GFX11-NEXT:    v_dual_max_f32 v1, v1, v1 :: v_dual_max_f32 v0, v0, v0
2213 ; GFX11-NEXT:    v_cmp_nge_f32_e32 vcc_lo, v2, v3
2214 ; GFX11-NEXT:    v_max_f32_e32 v0, v0, v1
2215 ; GFX11-NEXT:    v_cmp_gt_f32_e64 s0, v0, v3
2216 ; GFX11-NEXT:    s_and_b32 s0, s0, vcc_lo
2217 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2218 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2220 ; GFX11NONANS-LABEL: test114:
2221 ; GFX11NONANS:       ; %bb.0:
2222 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2223 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
2224 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v2, v3
2225 ; GFX11NONANS-NEXT:    v_cmp_gt_f32_e64 s0, v0, v3
2226 ; GFX11NONANS-NEXT:    s_and_b32 s0, s0, vcc_lo
2227 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2228 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2229   %cmp1 = fcmp ogt float %arg1, %C
2230   %cmp2 = fcmp ogt float %arg2, %C
2231   %cmp3 = fcmp ult float %arg3, %C
2232   %and1 = or i1 %cmp1, %cmp2
2233   %or1 = and i1 %and1, %cmp3
2234   ret i1 %or1
2237 define i1 @test115(float %arg1, float %arg2, float %arg3, float %arg4, float %C) {
2238 ; GFX11-LABEL: test115:
2239 ; GFX11:       ; %bb.0:
2240 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2241 ; GFX11-NEXT:    v_dual_max_f32 v2, v2, v2 :: v_dual_max_f32 v1, v1, v1
2242 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v3, v3, v3
2243 ; GFX11-NEXT:    v_dual_min_f32 v0, v0, v1 :: v_dual_max_f32 v1, v2, v3
2244 ; GFX11-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v4
2245 ; GFX11-NEXT:    v_cmp_nge_f32_e64 s0, v1, v4
2246 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
2247 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2248 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2250 ; GFX11NONANS-LABEL: test115:
2251 ; GFX11NONANS:       ; %bb.0:
2252 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2253 ; GFX11NONANS-NEXT:    v_max_f32_e32 v2, v2, v3
2254 ; GFX11NONANS-NEXT:    v_min3_f32 v0, v0, v1, v2
2255 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v4
2256 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2257 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2258   %cmp1 = fcmp olt float %arg1, %C
2259   %cmp2 = fcmp olt float %arg2, %C
2260   %var3 = call float @llvm.canonicalize.f32(float %arg3)
2261   %var4 = call float @llvm.canonicalize.f32(float %arg4)
2262   %cmp3 = fcmp ult float %var3, %C
2263   %cmp4 = fcmp ult float %var4, %C
2264   %or1 = or i1 %cmp1, %cmp2
2265   %and1 = and i1 %cmp3, %cmp4
2266   %or2 = or i1 %or1, %and1
2267   ret i1 %or2
2270 define i1 @test116(float %arg1, float %arg2, float %arg3, float %arg4, float %arg5, float %arg6, float %arg7, float %arg8, float %arg9, float %arg10, float %C) {
2271 ; GFX11-LABEL: test116:
2272 ; GFX11:       ; %bb.0:
2273 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2274 ; GFX11-NEXT:    v_dual_max_f32 v9, v9, v9 :: v_dual_max_f32 v8, v8, v8
2275 ; GFX11-NEXT:    v_dual_max_f32 v1, v1, v1 :: v_dual_max_f32 v0, v0, v0
2276 ; GFX11-NEXT:    v_dual_max_f32 v3, v3, v3 :: v_dual_max_f32 v2, v2, v2
2277 ; GFX11-NEXT:    v_dual_max_f32 v5, v5, v5 :: v_dual_max_f32 v4, v4, v4
2278 ; GFX11-NEXT:    v_dual_max_f32 v7, v7, v7 :: v_dual_max_f32 v6, v6, v6
2279 ; GFX11-NEXT:    v_min_f32_e32 v8, v8, v9
2280 ; GFX11-NEXT:    v_dual_max_f32 v2, v2, v3 :: v_dual_min_f32 v3, v4, v5
2281 ; GFX11-NEXT:    v_max_f32_e32 v4, v6, v7
2282 ; GFX11-NEXT:    v_min3_f32 v0, v0, v1, v8
2283 ; GFX11-NEXT:    v_cmp_gt_f32_e32 vcc_lo, v2, v10
2284 ; GFX11-NEXT:    v_cmp_lt_f32_e64 s0, v3, v10
2285 ; GFX11-NEXT:    v_cmp_gt_f32_e64 s1, v4, v10
2286 ; GFX11-NEXT:    v_cmp_lt_f32_e64 s2, v0, v10
2287 ; GFX11-NEXT:    s_or_b32 s0, s0, s1
2288 ; GFX11-NEXT:    s_or_b32 s1, s2, vcc_lo
2289 ; GFX11-NEXT:    s_or_b32 s0, s0, s1
2290 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2291 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2293 ; GFX11NONANS-LABEL: test116:
2294 ; GFX11NONANS:       ; %bb.0:
2295 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2296 ; GFX11NONANS-NEXT:    v_min_f32_e32 v8, v8, v9
2297 ; GFX11NONANS-NEXT:    v_dual_max_f32 v2, v2, v3 :: v_dual_min_f32 v3, v4, v5
2298 ; GFX11NONANS-NEXT:    v_max_f32_e32 v4, v6, v7
2299 ; GFX11NONANS-NEXT:    v_min3_f32 v0, v0, v1, v8
2300 ; GFX11NONANS-NEXT:    v_cmp_gt_f32_e32 vcc_lo, v2, v10
2301 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e64 s0, v3, v10
2302 ; GFX11NONANS-NEXT:    v_cmp_gt_f32_e64 s1, v4, v10
2303 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e64 s2, v0, v10
2304 ; GFX11NONANS-NEXT:    s_or_b32 s0, s0, s1
2305 ; GFX11NONANS-NEXT:    s_or_b32 s1, s2, vcc_lo
2306 ; GFX11NONANS-NEXT:    s_or_b32 s0, s0, s1
2307 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2308 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2309   %cmp1 = fcmp olt float %arg1, %C
2310   %cmp2 = fcmp olt float %arg2, %C
2311   %cmp3 = fcmp ogt float %arg3, %C
2312   %cmp4 = fcmp ogt float %arg4, %C
2313   %cmp5 = fcmp olt float %arg5, %C
2314   %cmp6 = fcmp olt float %arg6, %C
2315   %cmp7 = fcmp ogt float %arg7, %C
2316   %cmp8 = fcmp ogt float %arg8, %C
2317   %cmp9 = fcmp olt float %arg9, %C
2318   %cmp10 = fcmp olt float %arg10, %C
2319   %or1 = or i1 %cmp1, %cmp2
2320   %or2 = or i1 %cmp3, %cmp4
2321   %or3 = or i1 %cmp5, %cmp6
2322   %or4 = or i1 %cmp7, %cmp8
2323   %or5 = or i1 %cmp9, %cmp10
2324   %or6 = or i1 %or1, %or2
2325   %or7 = or i1 %or3, %or4
2326   %or8 = or i1 %or5, %or6
2327   %or9 = or i1 %or7, %or8
2328   ret i1 %or9
2331 define i1 @test117(float %arg1, float %arg2, float %arg3, float %arg4, float %arg5, float %arg6, float %arg7, float %arg8, float %arg9, float %arg10, float %arg11, float %arg12, float %C1, float %C2) {
2332 ; GFX11-LABEL: test117:
2333 ; GFX11:       ; %bb.0:
2334 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2335 ; GFX11-NEXT:    v_dual_max_f32 v3, v3, v3 :: v_dual_max_f32 v6, v6, v6
2336 ; GFX11-NEXT:    v_dual_max_f32 v7, v7, v7 :: v_dual_max_f32 v10, v10, v10
2337 ; GFX11-NEXT:    v_dual_max_f32 v1, v1, v1 :: v_dual_max_f32 v0, v0, v0
2338 ; GFX11-NEXT:    v_dual_max_f32 v11, v11, v11 :: v_dual_max_f32 v2, v2, v2
2339 ; GFX11-NEXT:    v_min_f32_e32 v6, v6, v7
2340 ; GFX11-NEXT:    v_dual_min_f32 v0, v0, v1 :: v_dual_min_f32 v1, v10, v11
2341 ; GFX11-NEXT:    v_min_f32_e32 v2, v2, v3
2342 ; GFX11-NEXT:    v_min3_f32 v3, v4, v5, v6
2343 ; GFX11-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v12
2344 ; GFX11-NEXT:    v_min3_f32 v0, v8, v9, v1
2345 ; GFX11-NEXT:    v_cmp_lt_f32_e64 s0, v2, v13
2346 ; GFX11-NEXT:    v_cmp_lt_f32_e64 s1, v3, v13
2347 ; GFX11-NEXT:    v_cmp_lt_f32_e64 s2, v0, v12
2348 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
2349 ; GFX11-NEXT:    s_or_b32 s0, s0, s1
2350 ; GFX11-NEXT:    s_or_b32 s0, s2, s0
2351 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2352 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2354 ; GFX11NONANS-LABEL: test117:
2355 ; GFX11NONANS:       ; %bb.0:
2356 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2357 ; GFX11NONANS-NEXT:    v_min_f32_e32 v6, v6, v7
2358 ; GFX11NONANS-NEXT:    v_dual_min_f32 v0, v0, v1 :: v_dual_min_f32 v1, v10, v11
2359 ; GFX11NONANS-NEXT:    v_min_f32_e32 v2, v2, v3
2360 ; GFX11NONANS-NEXT:    v_min3_f32 v3, v4, v5, v6
2361 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v12
2362 ; GFX11NONANS-NEXT:    v_min3_f32 v0, v8, v9, v1
2363 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e64 s0, v2, v13
2364 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e64 s1, v3, v13
2365 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e64 s2, v0, v12
2366 ; GFX11NONANS-NEXT:    s_or_b32 s0, vcc_lo, s0
2367 ; GFX11NONANS-NEXT:    s_or_b32 s0, s0, s1
2368 ; GFX11NONANS-NEXT:    s_or_b32 s0, s2, s0
2369 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2370 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2371   %cmp1 = fcmp olt float %arg1, %C1
2372   %cmp2 = fcmp olt float %arg2, %C1
2373   %cmp3 = fcmp olt float %arg3, %C2
2374   %cmp4 = fcmp olt float %arg4, %C2
2375   %cmp5 = fcmp olt float %arg5, %C2
2376   %cmp6 = fcmp olt float %arg6, %C2
2377   %cmp7 = fcmp olt float %arg7, %C2
2378   %cmp8 = fcmp olt float %arg8, %C2
2379   %cmp9 = fcmp olt float %arg9, %C1
2380   %cmp10 = fcmp olt float %arg10, %C1
2381   %cmp11 = fcmp olt float %arg11, %C1
2382   %cmp12 = fcmp olt float %arg12, %C1
2383   %or1 = or i1 %cmp1, %cmp2
2384   %or2 = or i1 %cmp3, %cmp4
2385   %or3 = or i1 %cmp5, %cmp6
2386   %or4 = or i1 %cmp7, %cmp8
2387   %or5 = or i1 %cmp9, %cmp10
2388   %or6 = or i1 %cmp11, %cmp12
2389   %or7 = or i1 %or1, %or2
2390   %or8 = or i1 %or3, %or4
2391   %or9 = or i1 %or5, %or6
2392   %or10 = or i1 %or7, %or8
2393   %or11 = or i1 %or9, %or10
2394   ret i1 %or11
2398 define i1 @test118(float %arg1, float %arg2, float %arg3, float %arg4, float %C1, float %C2, float %C3, float %C4, float %C) #0 {
2399 ; GCN-LABEL: test118:
2400 ; GCN:       ; %bb.0:
2401 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2402 ; GCN-NEXT:    v_dual_add_f32 v0, v0, v4 :: v_dual_add_f32 v1, v1, v5
2403 ; GCN-NEXT:    v_dual_add_f32 v2, v2, v6 :: v_dual_add_f32 v3, v3, v7
2404 ; GCN-NEXT:    v_min_f32_e32 v0, v0, v1
2405 ; GCN-NEXT:    v_max3_f32 v0, v0, v2, v3
2406 ; GCN-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v8
2407 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2408 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2409   %add1 = fadd nnan float %arg1, %C1
2410   %add2 = fadd nnan float %arg2, %C2
2411   %add3 = fadd nnan float %arg3, %C3
2412   %add4 = fadd nnan float %arg4, %C4
2413   %cmp1 = fcmp nnan ult float %add1, %C
2414   %cmp2 = fcmp nnan ult float %add2, %C
2415   %cmp3 = fcmp nnan ult float %add3, %C
2416   %cmp4 = fcmp nnan ult float %add4, %C
2417   %or1 = or i1 %cmp1, %cmp2
2418   %and1 = and i1 %cmp3, %cmp4
2419   %and2 = and i1 %or1, %and1
2420   ret i1 %and2
2423 define i1 @test119(float %arg1, float %arg2, float %arg3, float %arg4, float %C1, float %C2, float %C3, float %C4, float %C) #0 {
2424 ; GCN-LABEL: test119:
2425 ; GCN:       ; %bb.0:
2426 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2427 ; GCN-NEXT:    v_dual_add_f32 v2, v2, v6 :: v_dual_add_f32 v3, v3, v7
2428 ; GCN-NEXT:    v_dual_add_f32 v0, v0, v4 :: v_dual_add_f32 v1, v1, v5
2429 ; GCN-NEXT:    v_min_f32_e32 v2, v2, v3
2430 ; GCN-NEXT:    v_minmax_f32 v0, v0, v1, v2
2431 ; GCN-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v8
2432 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2433 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2434   %add1 = fadd nnan float %arg1, %C1
2435   %add2 = fadd nnan float %arg2, %C2
2436   %add3 = fadd nnan float %arg3, %C3
2437   %add4 = fadd nnan float %arg4, %C4
2438   %cmp1 = fcmp nnan ult float %add1, %C
2439   %cmp2 = fcmp nnan ult float %add2, %C
2440   %cmp3 = fcmp nnan ult float %add3, %C
2441   %cmp4 = fcmp nnan ult float %add4, %C
2442   %or1 = or i1 %cmp1, %cmp2
2443   %and1 = or i1 %cmp3, %cmp4
2444   %and2 = and i1 %or1, %and1
2445   ret i1 %and2
2448 define i1 @test120(float %arg1, float %arg2, float %arg3, float %arg4, float %C1, float %C2, float %C3, float %C4, float %C) #0 {
2449 ; GCN-LABEL: test120:
2450 ; GCN:       ; %bb.0:
2451 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2452 ; GCN-NEXT:    v_dual_add_f32 v2, v2, v6 :: v_dual_add_f32 v3, v3, v7
2453 ; GCN-NEXT:    v_dual_add_f32 v0, v0, v4 :: v_dual_add_f32 v1, v1, v5
2454 ; GCN-NEXT:    v_max_f32_e32 v2, v2, v3
2455 ; GCN-NEXT:    v_min3_f32 v0, v0, v1, v2
2456 ; GCN-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v8
2457 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2458 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2459   %add1 = fadd nnan float %arg1, %C1
2460   %add2 = fadd nnan float %arg2, %C2
2461   %add3 = fadd nnan float %arg3, %C3
2462   %add4 = fadd nnan float %arg4, %C4
2463   %cmp1 = fcmp nnan ult float %add1, %C
2464   %cmp2 = fcmp nnan ult float %add2, %C
2465   %cmp3 = fcmp nnan ult float %add3, %C
2466   %cmp4 = fcmp nnan ult float %add4, %C
2467   %or1 = or i1 %cmp1, %cmp2
2468   %and1 = and i1 %cmp3, %cmp4
2469   %and2 = or i1 %or1, %and1
2470   ret i1 %and2
2473 define i1 @test121(float %arg1, float %arg2, float %arg3, float %arg4, float %C1, float %C2, float %C3, float %C4, float %C) #0 {
2474 ; GCN-LABEL: test121:
2475 ; GCN:       ; %bb.0:
2476 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2477 ; GCN-NEXT:    v_dual_add_f32 v2, v2, v6 :: v_dual_add_f32 v3, v3, v7
2478 ; GCN-NEXT:    v_dual_add_f32 v0, v0, v4 :: v_dual_add_f32 v1, v1, v5
2479 ; GCN-NEXT:    v_max_f32_e32 v2, v2, v3
2480 ; GCN-NEXT:    v_maxmin_f32 v0, v0, v1, v2
2481 ; GCN-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v8
2482 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2483 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2484   %add1 = fadd nnan float %arg1, %C1
2485   %add2 = fadd nnan float %arg2, %C2
2486   %add3 = fadd nnan float %arg3, %C3
2487   %add4 = fadd nnan float %arg4, %C4
2488   %cmp1 = fcmp nnan ult float %add1, %C
2489   %cmp2 = fcmp nnan ult float %add2, %C
2490   %cmp3 = fcmp nnan ult float %add3, %C
2491   %cmp4 = fcmp nnan ult float %add4, %C
2492   %or1 = and i1 %cmp1, %cmp2
2493   %and1 = and i1 %cmp3, %cmp4
2494   %and2 = or i1 %or1, %and1
2495   ret i1 %and2
2498 define i1 @test122(double %arg1, double %arg2, double %arg3) #1 {
2499 ; GCN-LABEL: test122:
2500 ; GCN:       ; %bb.0:
2501 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2502 ; GCN-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
2503 ; GCN-NEXT:    v_cmp_lt_f64_e32 vcc_lo, v[0:1], v[4:5]
2504 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2505 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2506   %cmp1 = fcmp ult double %arg1, %arg3
2507   %cmp2 = fcmp ult double %arg2, %arg3
2508   %or1 = or i1 %cmp1, %cmp2
2509   ret i1 %or1
2512 define i1 @test123(double %arg1, double %arg2, double %arg3) #1 {
2513 ; GCN-LABEL: test123:
2514 ; GCN:       ; %bb.0:
2515 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2516 ; GCN-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
2517 ; GCN-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
2518 ; GCN-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
2519 ; GCN-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
2520 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2521 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2522   %var1 = call double @llvm.canonicalize.f64(double %arg1)
2523   %var2 = call double @llvm.canonicalize.f64(double %arg2)
2524   %cmp1 = fcmp ogt double %var1, %arg3
2525   %cmp2 = fcmp ogt double %var2, %arg3
2526   %or1 = and i1 %cmp1, %cmp2
2527  ret i1 %or1
2530 ; The optimization does not apply to the following tests.
2532 define i1 @test124(i32 %arg1, i64 %arg2) {
2533 ; GCN-LABEL: test124:
2534 ; GCN:       ; %bb.0:
2535 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2536 ; GCN-NEXT:    s_mov_b64 s[0:1], 0x3e8
2537 ; GCN-NEXT:    v_cmp_gt_i64_e32 vcc_lo, s[0:1], v[1:2]
2538 ; GCN-NEXT:    v_cmp_gt_i32_e64 s0, 0x3e8, v0
2539 ; GCN-NEXT:    s_or_b32 s0, s0, vcc_lo
2540 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2541 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2542   %cmp1 = icmp slt i32 %arg1, 1000
2543   %cmp2 = icmp slt i64 %arg2, 1000
2544   %or  = or i1 %cmp1, %cmp2
2545   ret i1 %or
2548 define i1 @test125(i32 %arg1, i32 %arg2) {
2549 ; GCN-LABEL: test125:
2550 ; GCN:       ; %bb.0:
2551 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2552 ; GCN-NEXT:    v_cmp_eq_u32_e32 vcc_lo, 0x3e8, v0
2553 ; GCN-NEXT:    v_cmp_eq_u32_e64 s0, 0x3e8, v1
2554 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
2555 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2556 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2557   %cmp1 = icmp eq i32 %arg1, 1000
2558   %cmp2 = icmp eq i32 %arg2, 1000
2559   %or  = or i1 %cmp1, %cmp2
2560   ret i1 %or
2563 define i1 @test126(i32 %arg1, i32 %arg2) {
2564 ; GCN-LABEL: test126:
2565 ; GCN:       ; %bb.0:
2566 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2567 ; GCN-NEXT:    v_cmp_ne_u32_e32 vcc_lo, 0x3e8, v0
2568 ; GCN-NEXT:    v_cmp_ne_u32_e64 s0, 0x3e8, v1
2569 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
2570 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2571 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2572   %cmp1 = icmp ne i32 %arg1, 1000
2573   %cmp2 = icmp ne i32 %arg2, 1000
2574   %or  = or i1 %cmp1, %cmp2
2575   ret i1 %or
2578 define i1 @test127(i64 %arg1, i64 %arg2, i64 %arg3) {
2579 ; GCN-LABEL: test127:
2580 ; GCN:       ; %bb.0:
2581 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2582 ; GCN-NEXT:    v_cmp_lt_u64_e32 vcc_lo, v[0:1], v[4:5]
2583 ; GCN-NEXT:    v_cmp_lt_u64_e64 s0, v[2:3], v[4:5]
2584 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
2585 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2586 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2587    %cmp1 = icmp ult i64 %arg1, %arg3
2588    %cmp2 = icmp ult i64 %arg2, %arg3
2589    %or = or i1 %cmp1, %cmp2
2590    ret i1 %or
2593 define i1 @test128(i32 %arg1, i32 %arg2, i32 %arg3) {
2594 ; GCN-LABEL: test128:
2595 ; GCN:       ; %bb.0:
2596 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2597 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v2
2598 ; GCN-NEXT:    v_cmp_lt_u32_e64 s0, v2, v1
2599 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
2600 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2601 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2602   %cmp1 = icmp ult i32 %arg1, %arg3
2603   %cmp2 = icmp ult i32 %arg3, %arg2
2604   %or = or i1 %cmp1, %cmp2
2605   ret i1 %or
2608 define i1 @test129(i32 %arg1, i32 %arg2, i32 %arg3) {
2609 ; GCN-LABEL: test129:
2610 ; GCN:       ; %bb.0:
2611 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2612 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v2
2613 ; GCN-NEXT:    v_cmp_le_u32_e64 s0, v1, v2
2614 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
2615 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2616 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2617   %cmp1 = icmp ult i32 %arg1, %arg3
2618   %cmp2 = icmp ule i32 %arg2, %arg3
2619   %or = or i1 %cmp1, %cmp2
2620   ret i1 %or
2623 define i1 @test130(i32 %arg1, i32 %arg2, i32 %arg3) {
2624 ; GCN-LABEL: test130:
2625 ; GCN:       ; %bb.0:
2626 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2627 ; GCN-NEXT:    v_cmp_le_u32_e32 vcc_lo, v2, v0
2628 ; GCN-NEXT:    v_cmp_gt_u32_e64 s0, v1, v2
2629 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
2630 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2631 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2632   %cmp1 = icmp ule i32 %arg3, %arg1
2633   %cmp2 = icmp ugt i32 %arg2, %arg3
2634   %or = or i1 %cmp1, %cmp2
2635   ret i1 %or
2638 define i1 @test131(i16 %arg1, i32 %arg2) {
2639 ; GCN-LABEL: test131:
2640 ; GCN:       ; %bb.0:
2641 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2642 ; GCN-NEXT:    v_cmp_gt_u16_e32 vcc_lo, 10, v0
2643 ; GCN-NEXT:    v_cmp_gt_u32_e64 s0, 10, v1
2644 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
2645 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2646 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2647   %cmp1 = icmp ult i16 %arg1, 10
2648   %cmp2 = icmp ult i32 %arg2, 10
2649   %or = or i1 %cmp1, %cmp2
2650   ret i1 %or
2653 define i1 @test132(i32 %arg1, i32 %arg2, i32 %arg3, i32 %arg4) {
2654 ; GCN-LABEL: test132:
2655 ; GCN:       ; %bb.0:
2656 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2657 ; GCN-NEXT:    v_cmp_lt_u32_e32 vcc_lo, v0, v2
2658 ; GCN-NEXT:    v_cmp_lt_u32_e64 s0, v1, v2
2659 ; GCN-NEXT:    v_cmp_lt_u32_e64 s1, v0, v3
2660 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
2661 ; GCN-NEXT:    s_or_b32 s1, s1, vcc_lo
2662 ; GCN-NEXT:    s_or_b32 s0, s0, s1
2663 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2664 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2665   %cmp1 = icmp ult i32 %arg1, %arg3
2666   %cmp2 = icmp ult i32 %arg2, %arg3
2667   %or1 = or i1 %cmp1, %cmp2
2668   %cmp3 = icmp ult i32 %arg1, %arg4
2669   %or2 = or i1 %cmp3, %cmp1
2670   %or3 = or i1 %or1, %or2
2671   ret i1 %or3
2674 define i1 @test133(i32 %arg1, i32 %arg2) {
2675 ; GCN-LABEL: test133:
2676 ; GCN:       ; %bb.0:
2677 ; GCN-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2678 ; GCN-NEXT:    v_cmp_gt_u32_e32 vcc_lo, 0x64, v0
2679 ; GCN-NEXT:    v_cmp_gt_u32_e64 s0, 0x3e8, v1
2680 ; GCN-NEXT:    s_or_b32 s0, vcc_lo, s0
2681 ; GCN-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2682 ; GCN-NEXT:    s_setpc_b64 s[30:31]
2683   %cmp1 = icmp ult i32 %arg1, 100
2684   %cmp2 = icmp ult i32 %arg2, 1000
2685   %or = or i1 %cmp1, %cmp2
2686   ret i1 %or
2689 define i1 @test134(float %arg1, float %arg2, float %arg3) #0 {
2690 ; GFX11-LABEL: test134:
2691 ; GFX11:       ; %bb.0:
2692 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2693 ; GFX11-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
2694 ; GFX11-NEXT:    v_cmp_gt_f32_e64 s0, v2, v1
2695 ; GFX11-NEXT:    s_and_b32 s0, vcc_lo, s0
2696 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2697 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2699 ; GFX11NONANS-LABEL: test134:
2700 ; GFX11NONANS:       ; %bb.0:
2701 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2702 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
2703 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
2704 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2705 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2706   %cmp1 = fcmp olt float %arg1, %arg3
2707   %cmp2 = fcmp ogt float %arg3, %arg2
2708   %and1  = and i1 %cmp1, %cmp2
2709   ret i1 %and1
2712 define i1 @test135(float %arg1, float %arg2, float %arg3) #0 {
2713 ; GFX11-LABEL: test135:
2714 ; GFX11:       ; %bb.0:
2715 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2716 ; GFX11-NEXT:    v_cmp_nge_f32_e32 vcc_lo, v0, v2
2717 ; GFX11-NEXT:    v_cmp_nle_f32_e64 s0, v2, v1
2718 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
2719 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2720 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2722 ; GFX11NONANS-LABEL: test135:
2723 ; GFX11NONANS:       ; %bb.0:
2724 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2725 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v1
2726 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
2727 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2728 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2729   %cmp1 = fcmp ult float %arg1, %arg3
2730   %cmp2 = fcmp ugt float %arg3, %arg2
2731   %or1  = or i1 %cmp1, %cmp2
2732   ret i1 %or1
2735 define i1 @test136(double %arg1, double %arg2, double %arg3) {
2736 ; GFX11-LABEL: test136:
2737 ; GFX11:       ; %bb.0:
2738 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2739 ; GFX11-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
2740 ; GFX11-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
2741 ; GFX11-NEXT:    v_cmp_le_f64_e32 vcc_lo, v[0:1], v[4:5]
2742 ; GFX11-NEXT:    v_cmp_ge_f64_e64 s0, v[4:5], v[2:3]
2743 ; GFX11-NEXT:    s_and_b32 s0, vcc_lo, s0
2744 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2745 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2747 ; GFX11NONANS-LABEL: test136:
2748 ; GFX11NONANS:       ; %bb.0:
2749 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2750 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
2751 ; GFX11NONANS-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
2752 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
2753 ; GFX11NONANS-NEXT:    v_cmp_le_f64_e32 vcc_lo, v[0:1], v[4:5]
2754 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2755 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2756   %var1 = call double @llvm.canonicalize.f64(double %arg1)
2757   %var2 = call double @llvm.canonicalize.f64(double %arg2)
2758   %cmp1 = fcmp ole double %var1, %arg3
2759   %cmp2 = fcmp oge double %arg3, %var2
2760   %and1  = and i1 %cmp1, %cmp2
2761   ret i1 %and1
2764 define i1 @test137(float %arg1, float %arg2, float %arg3) {
2765 ; GFX11-LABEL: test137:
2766 ; GFX11:       ; %bb.0:
2767 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2768 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v1, v1, v1
2769 ; GFX11-NEXT:    v_cmp_ngt_f32_e32 vcc_lo, v0, v2
2770 ; GFX11-NEXT:    v_cmp_nlt_f32_e64 s0, v2, v1
2771 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
2772 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2773 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2775 ; GFX11NONANS-LABEL: test137:
2776 ; GFX11NONANS:       ; %bb.0:
2777 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2778 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v1
2779 ; GFX11NONANS-NEXT:    v_cmp_le_f32_e32 vcc_lo, v0, v2
2780 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2781 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2782   %var1 = call float @llvm.canonicalize.f32(float %arg1)
2783   %var2 = call float @llvm.canonicalize.f32(float %arg2)
2784   %cmp1 = fcmp ule float %var1, %arg3
2785   %cmp2 = fcmp uge float %arg3, %var2
2786   %or1  = or i1 %cmp1, %cmp2
2787   ret i1 %or1
2790 define i1 @test138(float %arg1, float %arg2, float %arg3) #0 {
2791 ; GFX11-LABEL: test138:
2792 ; GFX11:       ; %bb.0:
2793 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2794 ; GFX11-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
2795 ; GFX11-NEXT:    v_cmp_lt_f32_e64 s0, v1, v2
2796 ; GFX11-NEXT:    s_and_b32 s0, vcc_lo, s0
2797 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2798 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2800 ; GFX11NONANS-LABEL: test138:
2801 ; GFX11NONANS:       ; %bb.0:
2802 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2803 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
2804 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
2805 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2806 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2807   %cmp1 = fcmp olt float %arg1, %arg3
2808   %cmp2 = fcmp olt float %arg2, %arg3
2809   %and1  = and i1 %cmp1, %cmp2
2810   ret i1 %and1
2813 define i1 @test139(double %arg1, double %arg2, double %arg3) #0 {
2814 ; GFX11-LABEL: test139:
2815 ; GFX11:       ; %bb.0:
2816 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2817 ; GFX11-NEXT:    v_cmp_le_f64_e32 vcc_lo, v[0:1], v[4:5]
2818 ; GFX11-NEXT:    v_cmp_le_f64_e64 s0, v[2:3], v[4:5]
2819 ; GFX11-NEXT:    s_and_b32 s0, vcc_lo, s0
2820 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2821 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2823 ; GFX11NONANS-LABEL: test139:
2824 ; GFX11NONANS:       ; %bb.0:
2825 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2826 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
2827 ; GFX11NONANS-NEXT:    v_cmp_le_f64_e32 vcc_lo, v[0:1], v[4:5]
2828 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2829 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2830   %cmp1 = fcmp ole double %arg1, %arg3
2831   %cmp2 = fcmp ole double %arg2, %arg3
2832   %and1  = and i1 %cmp1, %cmp2
2833   ret i1 %and1
2836 define i1 @test140(double %arg1, double %arg2, double %arg3) #0 {
2837 ; GFX11-LABEL: test140:
2838 ; GFX11:       ; %bb.0:
2839 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2840 ; GFX11-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
2841 ; GFX11-NEXT:    v_cmp_gt_f64_e64 s0, v[2:3], v[4:5]
2842 ; GFX11-NEXT:    s_and_b32 s0, vcc_lo, s0
2843 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2844 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2846 ; GFX11NONANS-LABEL: test140:
2847 ; GFX11NONANS:       ; %bb.0:
2848 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2849 ; GFX11NONANS-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
2850 ; GFX11NONANS-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
2851 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2852 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2853   %cmp1 = fcmp ogt double %arg1, %arg3
2854   %cmp2 = fcmp ogt double %arg2, %arg3
2855   %and1  = and i1 %cmp1, %cmp2
2856   ret i1 %and1
2859 define i1 @test141(float %arg1, float %arg2, float %arg3) #0 {
2860 ; GFX11-LABEL: test141:
2861 ; GFX11:       ; %bb.0:
2862 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2863 ; GFX11-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
2864 ; GFX11-NEXT:    v_cmp_ge_f32_e64 s0, v1, v2
2865 ; GFX11-NEXT:    s_and_b32 s0, vcc_lo, s0
2866 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2867 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2869 ; GFX11NONANS-LABEL: test141:
2870 ; GFX11NONANS:       ; %bb.0:
2871 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2872 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v1
2873 ; GFX11NONANS-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
2874 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2875 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2876   %cmp1 = fcmp oge float %arg1, %arg3
2877   %cmp2 = fcmp oge float %arg2, %arg3
2878   %and1  = and i1 %cmp1, %cmp2
2879   ret i1 %and1
2882 define i1 @test142(double %arg1, double %arg2, double %arg3) #0 {
2883 ; GFX11-LABEL: test142:
2884 ; GFX11:       ; %bb.0:
2885 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2886 ; GFX11-NEXT:    v_cmp_nle_f64_e32 vcc_lo, v[0:1], v[4:5]
2887 ; GFX11-NEXT:    v_cmp_nle_f64_e64 s0, v[2:3], v[4:5]
2888 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
2889 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2890 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2892 ; GFX11NONANS-LABEL: test142:
2893 ; GFX11NONANS:       ; %bb.0:
2894 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2895 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
2896 ; GFX11NONANS-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
2897 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2898 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2899   %cmp1 = fcmp ugt double %arg1, %arg3
2900   %cmp2 = fcmp ugt double %arg2, %arg3
2901   %or1  = or i1 %cmp1, %cmp2
2902   ret i1 %or1
2905 define i1 @test143(float %arg1, float %arg2, float %arg3) #0 {
2906 ; GFX11-LABEL: test143:
2907 ; GFX11:       ; %bb.0:
2908 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2909 ; GFX11-NEXT:    v_cmp_nlt_f32_e32 vcc_lo, v0, v2
2910 ; GFX11-NEXT:    v_cmp_nlt_f32_e64 s0, v1, v2
2911 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
2912 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2913 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2915 ; GFX11NONANS-LABEL: test143:
2916 ; GFX11NONANS:       ; %bb.0:
2917 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2918 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
2919 ; GFX11NONANS-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
2920 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2921 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2922   %cmp1 = fcmp uge float %arg1, %arg3
2923   %cmp2 = fcmp uge float %arg2, %arg3
2924   %or1  = or i1 %cmp1, %cmp2
2925   ret i1 %or1
2928 define i1 @test144(float %arg1, float %arg2, float %arg3) #0 {
2929 ; GFX11-LABEL: test144:
2930 ; GFX11:       ; %bb.0:
2931 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2932 ; GFX11-NEXT:    v_cmp_ngt_f32_e32 vcc_lo, v0, v2
2933 ; GFX11-NEXT:    v_cmp_ngt_f32_e64 s0, v1, v2
2934 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
2935 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2936 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2938 ; GFX11NONANS-LABEL: test144:
2939 ; GFX11NONANS:       ; %bb.0:
2940 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2941 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v1
2942 ; GFX11NONANS-NEXT:    v_cmp_le_f32_e32 vcc_lo, v0, v2
2943 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2944 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2945   %cmp1 = fcmp ule float %arg1, %arg3
2946   %cmp2 = fcmp ule float %arg2, %arg3
2947   %or1  = or i1 %cmp1, %cmp2
2948   ret i1 %or1
2951 define i1 @test145(double %arg1, double %arg2, double %arg3) #0 {
2952 ; GFX11-LABEL: test145:
2953 ; GFX11:       ; %bb.0:
2954 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2955 ; GFX11-NEXT:    v_cmp_nge_f64_e32 vcc_lo, v[0:1], v[4:5]
2956 ; GFX11-NEXT:    v_cmp_nge_f64_e64 s0, v[2:3], v[4:5]
2957 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
2958 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2959 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2961 ; GFX11NONANS-LABEL: test145:
2962 ; GFX11NONANS:       ; %bb.0:
2963 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2964 ; GFX11NONANS-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
2965 ; GFX11NONANS-NEXT:    v_cmp_lt_f64_e32 vcc_lo, v[0:1], v[4:5]
2966 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2967 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2968   %cmp1 = fcmp ult double %arg1, %arg3
2969   %cmp2 = fcmp ult double %arg2, %arg3
2970   %or1 = or i1 %cmp1, %cmp2
2971   ret i1 %or1
2974 define i1 @test146(float %arg1, float %arg2, float %arg3) {
2975 ; GFX11-LABEL: test146:
2976 ; GFX11:       ; %bb.0:
2977 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2978 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v1, v1, v1
2979 ; GFX11-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
2980 ; GFX11-NEXT:    v_cmp_lt_f32_e64 s0, v1, v2
2981 ; GFX11-NEXT:    s_and_b32 s0, vcc_lo, s0
2982 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
2983 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
2985 ; GFX11NONANS-LABEL: test146:
2986 ; GFX11NONANS:       ; %bb.0:
2987 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2988 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
2989 ; GFX11NONANS-NEXT:    v_cmp_lt_f32_e32 vcc_lo, v0, v2
2990 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
2991 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
2992   %var1 = call float @llvm.canonicalize.f32(float %arg1)
2993   %var2 = call float @llvm.canonicalize.f32(float %arg2)
2994   %cmp1 = fcmp olt float %var1, %arg3
2995   %cmp2 = fcmp olt float %var2, %arg3
2996   %and1  = and i1 %cmp1, %cmp2
2997   ret i1 %and1
3000 define i1 @test147(double %arg1, double %arg2, double %arg3) {
3001 ; GFX11-LABEL: test147:
3002 ; GFX11:       ; %bb.0:
3003 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3004 ; GFX11-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
3005 ; GFX11-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
3006 ; GFX11-NEXT:    v_cmp_le_f64_e32 vcc_lo, v[0:1], v[4:5]
3007 ; GFX11-NEXT:    v_cmp_le_f64_e64 s0, v[2:3], v[4:5]
3008 ; GFX11-NEXT:    s_and_b32 s0, vcc_lo, s0
3009 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
3010 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
3012 ; GFX11NONANS-LABEL: test147:
3013 ; GFX11NONANS:       ; %bb.0:
3014 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3015 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
3016 ; GFX11NONANS-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
3017 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
3018 ; GFX11NONANS-NEXT:    v_cmp_le_f64_e32 vcc_lo, v[0:1], v[4:5]
3019 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
3020 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
3021   %var1 = call double @llvm.canonicalize.f64(double %arg1)
3022   %var2 = call double @llvm.canonicalize.f64(double %arg2)
3023   %cmp1 = fcmp ole double %var1, %arg3
3024   %cmp2 = fcmp ole double %var2, %arg3
3025   %and1  = and i1 %cmp1, %cmp2
3026   ret i1 %and1
3029 define i1 @test148(double %arg1, double %arg2, double %arg3) {
3030 ; GFX11-LABEL: test148:
3031 ; GFX11:       ; %bb.0:
3032 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3033 ; GFX11-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
3034 ; GFX11-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
3035 ; GFX11-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
3036 ; GFX11-NEXT:    v_cmp_gt_f64_e64 s0, v[2:3], v[4:5]
3037 ; GFX11-NEXT:    s_and_b32 s0, vcc_lo, s0
3038 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
3039 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
3041 ; GFX11NONANS-LABEL: test148:
3042 ; GFX11NONANS:       ; %bb.0:
3043 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3044 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
3045 ; GFX11NONANS-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
3046 ; GFX11NONANS-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
3047 ; GFX11NONANS-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
3048 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
3049 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
3050   %var1 = call double @llvm.canonicalize.f64(double %arg1)
3051   %var2 = call double @llvm.canonicalize.f64(double %arg2)
3052   %cmp1 = fcmp ogt double %var1, %arg3
3053   %cmp2 = fcmp ogt double %var2, %arg3
3054   %and1  = and i1 %cmp1, %cmp2
3055   ret i1 %and1
3058 define i1 @test149(float %arg1, float %arg2, float %arg3) {
3059 ; GFX11-LABEL: test149:
3060 ; GFX11:       ; %bb.0:
3061 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3062 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v1, v1, v1
3063 ; GFX11-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
3064 ; GFX11-NEXT:    v_cmp_ge_f32_e64 s0, v1, v2
3065 ; GFX11-NEXT:    s_and_b32 s0, vcc_lo, s0
3066 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
3067 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
3069 ; GFX11NONANS-LABEL: test149:
3070 ; GFX11NONANS:       ; %bb.0:
3071 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3072 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v1
3073 ; GFX11NONANS-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
3074 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
3075 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
3076   %var1 = call float @llvm.canonicalize.f32(float %arg1)
3077   %var2 = call float @llvm.canonicalize.f32(float %arg2)
3078   %cmp1 = fcmp oge float %var1, %arg3
3079   %cmp2 = fcmp oge float %var2, %arg3
3080   %and1  = and i1 %cmp1, %cmp2
3081   ret i1 %and1
3084 define i1 @test150(double %arg1, double %arg2, double %arg3) {
3085 ; GFX11-LABEL: test150:
3086 ; GFX11:       ; %bb.0:
3087 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3088 ; GFX11-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
3089 ; GFX11-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
3090 ; GFX11-NEXT:    v_cmp_nle_f64_e32 vcc_lo, v[0:1], v[4:5]
3091 ; GFX11-NEXT:    v_cmp_nle_f64_e64 s0, v[2:3], v[4:5]
3092 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
3093 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
3094 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
3096 ; GFX11NONANS-LABEL: test150:
3097 ; GFX11NONANS:       ; %bb.0:
3098 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3099 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
3100 ; GFX11NONANS-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
3101 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[2:3]
3102 ; GFX11NONANS-NEXT:    v_cmp_gt_f64_e32 vcc_lo, v[0:1], v[4:5]
3103 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
3104 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
3105   %var1 = call double @llvm.canonicalize.f64(double %arg1)
3106   %var2 = call double @llvm.canonicalize.f64(double %arg2)
3107   %cmp1 = fcmp ugt double %var1, %arg3
3108   %cmp2 = fcmp ugt double %var2, %arg3
3109   %or1  = or i1 %cmp1, %cmp2
3110   ret i1 %or1
3113 define i1 @test151(float %arg1, float %arg2, float %arg3) {
3114 ; GFX11-LABEL: test151:
3115 ; GFX11:       ; %bb.0:
3116 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3117 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v1, v1, v1
3118 ; GFX11-NEXT:    v_cmp_nlt_f32_e32 vcc_lo, v0, v2
3119 ; GFX11-NEXT:    v_cmp_nlt_f32_e64 s0, v1, v2
3120 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
3121 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
3122 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
3124 ; GFX11NONANS-LABEL: test151:
3125 ; GFX11NONANS:       ; %bb.0:
3126 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3127 ; GFX11NONANS-NEXT:    v_max_f32_e32 v0, v0, v1
3128 ; GFX11NONANS-NEXT:    v_cmp_ge_f32_e32 vcc_lo, v0, v2
3129 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
3130 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
3131   %var1 = call float @llvm.canonicalize.f32(float %arg1)
3132   %var2 = call float @llvm.canonicalize.f32(float %arg2)
3133   %cmp1 = fcmp uge float %var1, %arg3
3134   %cmp2 = fcmp uge float %var2, %arg3
3135   %or1  = or i1 %cmp1, %cmp2
3136   ret i1 %or1
3139 define i1 @test152(float %arg1, float %arg2, float %arg3) {
3140 ; GFX11-LABEL: test152:
3141 ; GFX11:       ; %bb.0:
3142 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3143 ; GFX11-NEXT:    v_dual_max_f32 v0, v0, v0 :: v_dual_max_f32 v1, v1, v1
3144 ; GFX11-NEXT:    v_cmp_ngt_f32_e32 vcc_lo, v0, v2
3145 ; GFX11-NEXT:    v_cmp_ngt_f32_e64 s0, v1, v2
3146 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
3147 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
3148 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
3150 ; GFX11NONANS-LABEL: test152:
3151 ; GFX11NONANS:       ; %bb.0:
3152 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3153 ; GFX11NONANS-NEXT:    v_min_f32_e32 v0, v0, v1
3154 ; GFX11NONANS-NEXT:    v_cmp_le_f32_e32 vcc_lo, v0, v2
3155 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
3156 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
3157   %var1 = call float @llvm.canonicalize.f32(float %arg1)
3158   %var2 = call float @llvm.canonicalize.f32(float %arg2)
3159   %cmp1 = fcmp ule float %var1, %arg3
3160   %cmp2 = fcmp ule float %var2, %arg3
3161   %or1  = or i1 %cmp1, %cmp2
3162   ret i1 %or1
3165 define i1 @test153(double %arg1, double %arg2, double %arg3) {
3166 ; GFX11-LABEL: test153:
3167 ; GFX11:       ; %bb.0:
3168 ; GFX11-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3169 ; GFX11-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
3170 ; GFX11-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
3171 ; GFX11-NEXT:    v_cmp_nge_f64_e32 vcc_lo, v[0:1], v[4:5]
3172 ; GFX11-NEXT:    v_cmp_nge_f64_e64 s0, v[2:3], v[4:5]
3173 ; GFX11-NEXT:    s_or_b32 s0, vcc_lo, s0
3174 ; GFX11-NEXT:    v_cndmask_b32_e64 v0, 0, 1, s0
3175 ; GFX11-NEXT:    s_setpc_b64 s[30:31]
3177 ; GFX11NONANS-LABEL: test153:
3178 ; GFX11NONANS:       ; %bb.0:
3179 ; GFX11NONANS-NEXT:    s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
3180 ; GFX11NONANS-NEXT:    v_max_f64 v[0:1], v[0:1], v[0:1]
3181 ; GFX11NONANS-NEXT:    v_max_f64 v[2:3], v[2:3], v[2:3]
3182 ; GFX11NONANS-NEXT:    v_min_f64 v[0:1], v[0:1], v[2:3]
3183 ; GFX11NONANS-NEXT:    v_cmp_lt_f64_e32 vcc_lo, v[0:1], v[4:5]
3184 ; GFX11NONANS-NEXT:    v_cndmask_b32_e64 v0, 0, 1, vcc_lo
3185 ; GFX11NONANS-NEXT:    s_setpc_b64 s[30:31]
3186   %var1 = call double @llvm.canonicalize.f64(double %arg1)
3187   %var2 = call double @llvm.canonicalize.f64(double %arg2)
3188   %cmp1 = fcmp ult double %var1, %arg3
3189   %cmp2 = fcmp ult double %var2, %arg3
3190   %or1 = or i1 %cmp1, %cmp2
3191   ret i1 %or1
3194 declare double @llvm.canonicalize.f64(double)
3195 declare float @llvm.canonicalize.f32(float)
3196 declare half @llvm.canonicalize.f16(half)
3197 declare <2 x half> @llvm.canonicalize.v2f16(<2 x half>)
3199 attributes #0 = { nounwind "amdgpu-ieee"="false" }
3200 attributes #1 = { nounwind "unsafe-fp-math"="true" "no-nans-fp-math"="true" }