[MIPS GlobalISel] ClampScalar and select pointer G_ICMP
[llvm-complete.git] / test / CodeGen / Mips / GlobalISel / llvm-ir / icmp.ll
blobbb098761f33487b0fcf5b68d48f45a5d7c48f7f7
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc  -O0 -mtriple=mipsel-linux-gnu -global-isel  -verify-machineinstrs %s -o -| FileCheck %s -check-prefixes=MIPS32
4 define i1 @eq_i32(i32 %a, i32 %b){
5 ; MIPS32-LABEL: eq_i32:
6 ; MIPS32:       # %bb.0: # %entry
7 ; MIPS32-NEXT:    xor $1, $4, $5
8 ; MIPS32-NEXT:    sltiu $2, $1, 1
9 ; MIPS32-NEXT:    jr $ra
10 ; MIPS32-NEXT:    nop
11 entry:
12   %cmp = icmp eq i32 %a, %b
13   ret i1 %cmp
16 define i1 @ne_i32(i32 %a, i32 %b) {
17 ; MIPS32-LABEL: ne_i32:
18 ; MIPS32:       # %bb.0: # %entry
19 ; MIPS32-NEXT:    xor $1, $4, $5
20 ; MIPS32-NEXT:    sltu $2, $zero, $1
21 ; MIPS32-NEXT:    jr $ra
22 ; MIPS32-NEXT:    nop
23 entry:
24   %cmp = icmp ne i32 %a, %b
25   ret i1 %cmp
28 define i1 @sgt_i32(i32 %a, i32 %b) {
29 ; MIPS32-LABEL: sgt_i32:
30 ; MIPS32:       # %bb.0: # %entry
31 ; MIPS32-NEXT:    slt $2, $5, $4
32 ; MIPS32-NEXT:    jr $ra
33 ; MIPS32-NEXT:    nop
34 entry:
35   %cmp = icmp sgt i32 %a, %b
36   ret i1 %cmp
39 define i1 @sge_i32(i32 %a, i32 %b) {
40 ; MIPS32-LABEL: sge_i32:
41 ; MIPS32:       # %bb.0: # %entry
42 ; MIPS32-NEXT:    slt $1, $4, $5
43 ; MIPS32-NEXT:    xori $2, $1, 1
44 ; MIPS32-NEXT:    jr $ra
45 ; MIPS32-NEXT:    nop
46 entry:
47   %cmp = icmp sge i32 %a, %b
48   ret i1 %cmp
51 define i1 @slt_i32(i32 %a, i32 %b) {
52 ; MIPS32-LABEL: slt_i32:
53 ; MIPS32:       # %bb.0: # %entry
54 ; MIPS32-NEXT:    slt $2, $4, $5
55 ; MIPS32-NEXT:    jr $ra
56 ; MIPS32-NEXT:    nop
57 entry:
58   %cmp = icmp slt i32 %a, %b
59   ret i1 %cmp
62 define i1 @sle_i32(i32 %a, i32 %b) {
63 ; MIPS32-LABEL: sle_i32:
64 ; MIPS32:       # %bb.0: # %entry
65 ; MIPS32-NEXT:    slt $1, $5, $4
66 ; MIPS32-NEXT:    xori $2, $1, 1
67 ; MIPS32-NEXT:    jr $ra
68 ; MIPS32-NEXT:    nop
69 entry:
70   %cmp = icmp sle i32 %a, %b
71   ret i1 %cmp
74 define i1 @ugt_i32(i32 %a, i32 %b) {
75 ; MIPS32-LABEL: ugt_i32:
76 ; MIPS32:       # %bb.0: # %entry
77 ; MIPS32-NEXT:    sltu $2, $5, $4
78 ; MIPS32-NEXT:    jr $ra
79 ; MIPS32-NEXT:    nop
80 entry:
81   %cmp = icmp ugt i32 %a, %b
82   ret i1 %cmp
85 define i1 @uge_i32(i32 %a, i32 %b) {
86 ; MIPS32-LABEL: uge_i32:
87 ; MIPS32:       # %bb.0: # %entry
88 ; MIPS32-NEXT:    sltu $1, $4, $5
89 ; MIPS32-NEXT:    xori $2, $1, 1
90 ; MIPS32-NEXT:    jr $ra
91 ; MIPS32-NEXT:    nop
92 entry:
93   %cmp = icmp uge i32 %a, %b
94   ret i1 %cmp
97 define i1 @ult_i32(i32 %a, i32 %b) {
98 ; MIPS32-LABEL: ult_i32:
99 ; MIPS32:       # %bb.0: # %entry
100 ; MIPS32-NEXT:    sltu $2, $4, $5
101 ; MIPS32-NEXT:    jr $ra
102 ; MIPS32-NEXT:    nop
103 entry:
104   %cmp = icmp ult i32 %a, %b
105   ret i1 %cmp
108 define i1 @ule_i32(i32 %a, i32 %b) {
109 ; MIPS32-LABEL: ule_i32:
110 ; MIPS32:       # %bb.0: # %entry
111 ; MIPS32-NEXT:    sltu $1, $5, $4
112 ; MIPS32-NEXT:    xori $2, $1, 1
113 ; MIPS32-NEXT:    jr $ra
114 ; MIPS32-NEXT:    nop
115 entry:
116   %cmp = icmp ule i32 %a, %b
117   ret i1 %cmp
120 define i1 @eq_ptr(i32* %a, i32* %b){
121 ; MIPS32-LABEL: eq_ptr:
122 ; MIPS32:       # %bb.0: # %entry
123 ; MIPS32-NEXT:    xor $1, $4, $5
124 ; MIPS32-NEXT:    sltiu $2, $1, 1
125 ; MIPS32-NEXT:    jr $ra
126 ; MIPS32-NEXT:    nop
127 entry:
128   %cmp = icmp eq i32* %a, %b
129   ret i1 %cmp
132 define i1 @ult_i8(i8 %a, i8 %b) {
133 ; MIPS32-LABEL: ult_i8:
134 ; MIPS32:       # %bb.0: # %entry
135 ; MIPS32-NEXT:    ori $1, $zero, 255
136 ; MIPS32-NEXT:    and $2, $4, $1
137 ; MIPS32-NEXT:    and $1, $5, $1
138 ; MIPS32-NEXT:    sltu $2, $2, $1
139 ; MIPS32-NEXT:    jr $ra
140 ; MIPS32-NEXT:    nop
141 entry:
142   %cmp = icmp ult i8 %a, %b
143   ret i1 %cmp
146 define i1 @slt_i16(i16 %a, i16 %b) {
147 ; MIPS32-LABEL: slt_i16:
148 ; MIPS32:       # %bb.0: # %entry
149 ; MIPS32-NEXT:    sll $1, $4, 16
150 ; MIPS32-NEXT:    sra $1, $1, 16
151 ; MIPS32-NEXT:    sll $2, $5, 16
152 ; MIPS32-NEXT:    sra $2, $2, 16
153 ; MIPS32-NEXT:    slt $2, $1, $2
154 ; MIPS32-NEXT:    jr $ra
155 ; MIPS32-NEXT:    nop
156 entry:
157   %cmp = icmp slt i16 %a, %b
158   ret i1 %cmp
161 define i1 @eq_i64(i64 %a, i64 %b){
162 ; MIPS32-LABEL: eq_i64:
163 ; MIPS32:       # %bb.0: # %entry
164 ; MIPS32-NEXT:    xor $1, $4, $6
165 ; MIPS32-NEXT:    xor $2, $5, $7
166 ; MIPS32-NEXT:    or $1, $1, $2
167 ; MIPS32-NEXT:    ori $2, $zero, 0
168 ; MIPS32-NEXT:    xor $1, $1, $2
169 ; MIPS32-NEXT:    sltiu $2, $1, 1
170 ; MIPS32-NEXT:    jr $ra
171 ; MIPS32-NEXT:    nop
172 entry:
173   %cmp = icmp eq i64 %a, %b
174   ret i1 %cmp
177 define i1 @ne_i64(i64 %a, i64 %b) {
178 ; MIPS32-LABEL: ne_i64:
179 ; MIPS32:       # %bb.0: # %entry
180 ; MIPS32-NEXT:    xor $1, $4, $6
181 ; MIPS32-NEXT:    xor $2, $5, $7
182 ; MIPS32-NEXT:    or $1, $1, $2
183 ; MIPS32-NEXT:    ori $2, $zero, 0
184 ; MIPS32-NEXT:    xor $1, $1, $2
185 ; MIPS32-NEXT:    sltu $2, $zero, $1
186 ; MIPS32-NEXT:    jr $ra
187 ; MIPS32-NEXT:    nop
188 entry:
189   %cmp = icmp ne i64 %a, %b
190   ret i1 %cmp
193 define i1 @sgt_i64(i64 %a, i64 %b) {
194 ; MIPS32-LABEL: sgt_i64:
195 ; MIPS32:       # %bb.0: # %entry
196 ; MIPS32-NEXT:    slt $1, $7, $5
197 ; MIPS32-NEXT:    xor $2, $5, $7
198 ; MIPS32-NEXT:    sltiu $2, $2, 1
199 ; MIPS32-NEXT:    sltu $3, $6, $4
200 ; MIPS32-NEXT:    ori $4, $zero, 1
201 ; MIPS32-NEXT:    and $2, $2, $4
202 ; MIPS32-NEXT:    movn $1, $3, $2
203 ; MIPS32-NEXT:    move $2, $1
204 ; MIPS32-NEXT:    jr $ra
205 ; MIPS32-NEXT:    nop
206 entry:
207   %cmp = icmp sgt i64 %a, %b
208   ret i1 %cmp
211 define i1 @sge_i64(i64 %a, i64 %b) {
212 ; MIPS32-LABEL: sge_i64:
213 ; MIPS32:       # %bb.0: # %entry
214 ; MIPS32-NEXT:    slt $1, $5, $7
215 ; MIPS32-NEXT:    xori $1, $1, 1
216 ; MIPS32-NEXT:    xor $2, $5, $7
217 ; MIPS32-NEXT:    sltiu $2, $2, 1
218 ; MIPS32-NEXT:    sltu $3, $4, $6
219 ; MIPS32-NEXT:    xori $3, $3, 1
220 ; MIPS32-NEXT:    ori $4, $zero, 1
221 ; MIPS32-NEXT:    and $2, $2, $4
222 ; MIPS32-NEXT:    movn $1, $3, $2
223 ; MIPS32-NEXT:    move $2, $1
224 ; MIPS32-NEXT:    jr $ra
225 ; MIPS32-NEXT:    nop
226 entry:
227   %cmp = icmp sge i64 %a, %b
228   ret i1 %cmp
231 define i1 @slt_i64(i64 %a, i64 %b) {
232 ; MIPS32-LABEL: slt_i64:
233 ; MIPS32:       # %bb.0: # %entry
234 ; MIPS32-NEXT:    slt $1, $5, $7
235 ; MIPS32-NEXT:    xor $2, $5, $7
236 ; MIPS32-NEXT:    sltiu $2, $2, 1
237 ; MIPS32-NEXT:    sltu $3, $4, $6
238 ; MIPS32-NEXT:    ori $4, $zero, 1
239 ; MIPS32-NEXT:    and $2, $2, $4
240 ; MIPS32-NEXT:    movn $1, $3, $2
241 ; MIPS32-NEXT:    move $2, $1
242 ; MIPS32-NEXT:    jr $ra
243 ; MIPS32-NEXT:    nop
244 entry:
245   %cmp = icmp slt i64 %a, %b
246   ret i1 %cmp
249 define i1 @sle_i64(i64 %a, i64 %b) {
250 ; MIPS32-LABEL: sle_i64:
251 ; MIPS32:       # %bb.0: # %entry
252 ; MIPS32-NEXT:    slt $1, $7, $5
253 ; MIPS32-NEXT:    xori $1, $1, 1
254 ; MIPS32-NEXT:    xor $2, $5, $7
255 ; MIPS32-NEXT:    sltiu $2, $2, 1
256 ; MIPS32-NEXT:    sltu $3, $6, $4
257 ; MIPS32-NEXT:    xori $3, $3, 1
258 ; MIPS32-NEXT:    ori $4, $zero, 1
259 ; MIPS32-NEXT:    and $2, $2, $4
260 ; MIPS32-NEXT:    movn $1, $3, $2
261 ; MIPS32-NEXT:    move $2, $1
262 ; MIPS32-NEXT:    jr $ra
263 ; MIPS32-NEXT:    nop
264 entry:
265   %cmp = icmp sle i64 %a, %b
266   ret i1 %cmp
269 define i1 @ugt_i64(i64 %a, i64 %b) {
270 ; MIPS32-LABEL: ugt_i64:
271 ; MIPS32:       # %bb.0: # %entry
272 ; MIPS32-NEXT:    sltu $1, $7, $5
273 ; MIPS32-NEXT:    xor $2, $5, $7
274 ; MIPS32-NEXT:    sltiu $2, $2, 1
275 ; MIPS32-NEXT:    sltu $3, $6, $4
276 ; MIPS32-NEXT:    ori $4, $zero, 1
277 ; MIPS32-NEXT:    and $2, $2, $4
278 ; MIPS32-NEXT:    movn $1, $3, $2
279 ; MIPS32-NEXT:    move $2, $1
280 ; MIPS32-NEXT:    jr $ra
281 ; MIPS32-NEXT:    nop
282 entry:
283   %cmp = icmp ugt i64 %a, %b
284   ret i1 %cmp
287 define i1 @uge_i64(i64 %a, i64 %b) {
288 ; MIPS32-LABEL: uge_i64:
289 ; MIPS32:       # %bb.0: # %entry
290 ; MIPS32-NEXT:    sltu $1, $5, $7
291 ; MIPS32-NEXT:    xori $1, $1, 1
292 ; MIPS32-NEXT:    xor $2, $5, $7
293 ; MIPS32-NEXT:    sltiu $2, $2, 1
294 ; MIPS32-NEXT:    sltu $3, $4, $6
295 ; MIPS32-NEXT:    xori $3, $3, 1
296 ; MIPS32-NEXT:    ori $4, $zero, 1
297 ; MIPS32-NEXT:    and $2, $2, $4
298 ; MIPS32-NEXT:    movn $1, $3, $2
299 ; MIPS32-NEXT:    move $2, $1
300 ; MIPS32-NEXT:    jr $ra
301 ; MIPS32-NEXT:    nop
302 entry:
303   %cmp = icmp uge i64 %a, %b
304   ret i1 %cmp
307 define i1 @ult_i64(i64 %a, i64 %b) {
308 ; MIPS32-LABEL: ult_i64:
309 ; MIPS32:       # %bb.0: # %entry
310 ; MIPS32-NEXT:    sltu $1, $5, $7
311 ; MIPS32-NEXT:    xor $2, $5, $7
312 ; MIPS32-NEXT:    sltiu $2, $2, 1
313 ; MIPS32-NEXT:    sltu $3, $4, $6
314 ; MIPS32-NEXT:    ori $4, $zero, 1
315 ; MIPS32-NEXT:    and $2, $2, $4
316 ; MIPS32-NEXT:    movn $1, $3, $2
317 ; MIPS32-NEXT:    move $2, $1
318 ; MIPS32-NEXT:    jr $ra
319 ; MIPS32-NEXT:    nop
320 entry:
321   %cmp = icmp ult i64 %a, %b
322   ret i1 %cmp
325 define i1 @ule_i64(i64 %a, i64 %b) {
326 ; MIPS32-LABEL: ule_i64:
327 ; MIPS32:       # %bb.0: # %entry
328 ; MIPS32-NEXT:    sltu $1, $7, $5
329 ; MIPS32-NEXT:    xori $1, $1, 1
330 ; MIPS32-NEXT:    xor $2, $5, $7
331 ; MIPS32-NEXT:    sltiu $2, $2, 1
332 ; MIPS32-NEXT:    sltu $3, $6, $4
333 ; MIPS32-NEXT:    xori $3, $3, 1
334 ; MIPS32-NEXT:    ori $4, $zero, 1
335 ; MIPS32-NEXT:    and $2, $2, $4
336 ; MIPS32-NEXT:    movn $1, $3, $2
337 ; MIPS32-NEXT:    move $2, $1
338 ; MIPS32-NEXT:    jr $ra
339 ; MIPS32-NEXT:    nop
340 entry:
341   %cmp = icmp ule i64 %a, %b
342   ret i1 %cmp