Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / CodeGen / CellSPU / icmp16.ll
blob32b12617cfc38b652626ea1fcf4933efc8520ce0
1 ; RUN: llc < %s -march=cellspu > %t1.s
2 ; RUN: grep ilh                                %t1.s | count 15
3 ; RUN: grep ceqh                               %t1.s | count 29
4 ; RUN: grep ceqhi                              %t1.s | count 13
5 ; RUN: grep clgth                              %t1.s | count 15
6 ; RUN: grep cgth                               %t1.s | count 14
7 ; RUN: grep cgthi                              %t1.s | count 6
8 ; RUN: grep {selb\t\\\$3, \\\$6, \\\$5, \\\$3} %t1.s | count 7
9 ; RUN: grep {selb\t\\\$3, \\\$5, \\\$6, \\\$3} %t1.s | count 3
10 ; RUN: grep {selb\t\\\$3, \\\$5, \\\$4, \\\$3} %t1.s | count 17
11 ; RUN: grep {selb\t\\\$3, \\\$4, \\\$5, \\\$3} %t1.s | count 6
13 target datalayout = "E-p:32:32:128-f64:64:128-f32:32:128-i64:32:128-i32:32:128-i16:16:128-i8:8:128-i1:8:128-a0:0:128-v128:128:128-s0:128:128"
14 target triple = "spu"
16 ; $3 = %arg1, $4 = %arg2, $5 = %val1, $6 = %val2
17 ; $3 = %arg1, $4 = %val1, $5 = %val2
19 ; For "positive" comparisons:
20 ; selb $3, $6, $5, <i1>
21 ; selb $3, $5, $4, <i1>
23 ; For "negative" comparisons, i.e., those where the result of the comparison
24 ; must be inverted (setne, for example):
25 ; selb $3, $5, $6, <i1>
26 ; selb $3, $4, $5, <i1>
28 ; i16 integer comparisons:
29 define i16 @icmp_eq_select_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
30 entry:
31        %A = icmp eq i16 %arg1, %arg2
32        %B = select i1 %A, i16 %val1, i16 %val2
33        ret i16 %B
36 define i1 @icmp_eq_setcc_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
37 entry:
38        %A = icmp eq i16 %arg1, %arg2
39        ret i1 %A
42 define i16 @icmp_eq_immed01_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
43 entry:
44        %A = icmp eq i16 %arg1, 511
45        %B = select i1 %A, i16 %val1, i16 %val2
46        ret i16 %B
49 define i16 @icmp_eq_immed02_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
50 entry:
51        %A = icmp eq i16 %arg1, -512
52        %B = select i1 %A, i16 %val1, i16 %val2
53        ret i16 %B
56 define i16 @icmp_eq_immed03_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
57 entry:
58        %A = icmp eq i16 %arg1, -1
59        %B = select i1 %A, i16 %val1, i16 %val2
60        ret i16 %B
63 define i16 @icmp_eq_immed04_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
64 entry:
65        %A = icmp eq i16 %arg1, 32768
66        %B = select i1 %A, i16 %val1, i16 %val2
67        ret i16 %B
70 define i16 @icmp_ne_select_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
71 entry:
72        %A = icmp ne i16 %arg1, %arg2
73        %B = select i1 %A, i16 %val1, i16 %val2
74        ret i16 %B
77 define i1 @icmp_ne_setcc_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
78 entry:
79        %A = icmp ne i16 %arg1, %arg2
80        ret i1 %A
83 define i16 @icmp_ne_immed01_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
84 entry:
85        %A = icmp ne i16 %arg1, 511
86        %B = select i1 %A, i16 %val1, i16 %val2
87        ret i16 %B
90 define i16 @icmp_ne_immed02_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
91 entry:
92        %A = icmp ne i16 %arg1, -512
93        %B = select i1 %A, i16 %val1, i16 %val2
94        ret i16 %B
97 define i16 @icmp_ne_immed03_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
98 entry:
99        %A = icmp ne i16 %arg1, -1
100        %B = select i1 %A, i16 %val1, i16 %val2
101        ret i16 %B
104 define i16 @icmp_ne_immed04_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
105 entry:
106        %A = icmp ne i16 %arg1, 32768
107        %B = select i1 %A, i16 %val1, i16 %val2
108        ret i16 %B
111 define i16 @icmp_ugt_select_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
112 entry:
113        %A = icmp ugt i16 %arg1, %arg2
114        %B = select i1 %A, i16 %val1, i16 %val2
115        ret i16 %B
118 define i1 @icmp_ugt_setcc_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
119 entry:
120        %A = icmp ugt i16 %arg1, %arg2
121        ret i1 %A
124 define i16 @icmp_ugt_immed01_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
125 entry:
126        %A = icmp ugt i16 %arg1, 500
127        %B = select i1 %A, i16 %val1, i16 %val2
128        ret i16 %B
131 define i16 @icmp_ugt_immed02_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
132 entry:
133        %A = icmp ugt i16 %arg1, 0
134        %B = select i1 %A, i16 %val1, i16 %val2
135        ret i16 %B
138 define i16 @icmp_ugt_immed03_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
139 entry:
140        %A = icmp ugt i16 %arg1, 65024
141        %B = select i1 %A, i16 %val1, i16 %val2
142        ret i16 %B
145 define i16 @icmp_ugt_immed04_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
146 entry:
147        %A = icmp ugt i16 %arg1, 32768
148        %B = select i1 %A, i16 %val1, i16 %val2
149        ret i16 %B
152 define i16 @icmp_uge_select_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
153 entry:
154        %A = icmp uge i16 %arg1, %arg2
155        %B = select i1 %A, i16 %val1, i16 %val2
156        ret i16 %B
159 define i1 @icmp_uge_setcc_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
160 entry:
161        %A = icmp uge i16 %arg1, %arg2
162        ret i1 %A
165 ;; Note: icmp uge i16 %arg1, <immed> can always be transformed into
166 ;;       icmp ugt i16 %arg1, <immed>-1
168 ;; Consequently, even though the patterns exist to match, it's unlikely
169 ;; they'll ever be generated.
171 define i16 @icmp_ult_select_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
172 entry:
173        %A = icmp ult i16 %arg1, %arg2
174        %B = select i1 %A, i16 %val1, i16 %val2
175        ret i16 %B
178 define i1 @icmp_ult_setcc_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
179 entry:
180        %A = icmp ult i16 %arg1, %arg2
181        ret i1 %A
184 define i16 @icmp_ult_immed01_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
185 entry:
186        %A = icmp ult i16 %arg1, 511
187        %B = select i1 %A, i16 %val1, i16 %val2
188        ret i16 %B
191 define i16 @icmp_ult_immed02_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
192 entry:
193        %A = icmp ult i16 %arg1, 65534
194        %B = select i1 %A, i16 %val1, i16 %val2
195        ret i16 %B
198 define i16 @icmp_ult_immed03_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
199 entry:
200        %A = icmp ult i16 %arg1, 65024
201        %B = select i1 %A, i16 %val1, i16 %val2
202        ret i16 %B
205 define i16 @icmp_ult_immed04_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
206 entry:
207        %A = icmp ult i16 %arg1, 32769
208        %B = select i1 %A, i16 %val1, i16 %val2
209        ret i16 %B
212 define i16 @icmp_ule_select_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
213 entry:
214        %A = icmp ule i16 %arg1, %arg2
215        %B = select i1 %A, i16 %val1, i16 %val2
216        ret i16 %B
219 define i1 @icmp_ule_setcc_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
220 entry:
221        %A = icmp ule i16 %arg1, %arg2
222        ret i1 %A
225 ;; Note: icmp ule i16 %arg1, <immed> can always be transformed into
226 ;;       icmp ult i16 %arg1, <immed>+1
228 ;; Consequently, even though the patterns exist to match, it's unlikely
229 ;; they'll ever be generated.
231 define i16 @icmp_sgt_select_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
232 entry:
233        %A = icmp sgt i16 %arg1, %arg2
234        %B = select i1 %A, i16 %val1, i16 %val2
235        ret i16 %B
238 define i1 @icmp_sgt_setcc_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
239 entry:
240        %A = icmp sgt i16 %arg1, %arg2
241        ret i1 %A
244 define i16 @icmp_sgt_immed01_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
245 entry:
246        %A = icmp sgt i16 %arg1, 511
247        %B = select i1 %A, i16 %val1, i16 %val2
248        ret i16 %B
251 define i16 @icmp_sgt_immed02_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
252 entry:
253        %A = icmp sgt i16 %arg1, -1
254        %B = select i1 %A, i16 %val1, i16 %val2
255        ret i16 %B
258 define i16 @icmp_sgt_immed03_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
259 entry:
260        %A = icmp sgt i16 %arg1, -512
261        %B = select i1 %A, i16 %val1, i16 %val2
262        ret i16 %B
265 define i16 @icmp_sgt_immed04_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
266 entry:
267        %A = icmp sgt i16 %arg1, 32768
268        %B = select i1 %A, i16 %val1, i16 %val2
269        ret i16 %B
272 define i16 @icmp_sge_select_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
273 entry:
274        %A = icmp sge i16 %arg1, %arg2
275        %B = select i1 %A, i16 %val1, i16 %val2
276        ret i16 %B
279 define i1 @icmp_sge_setcc_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
280 entry:
281        %A = icmp sge i16 %arg1, %arg2
282        ret i1 %A
285 ;; Note: icmp sge i16 %arg1, <immed> can always be transformed into
286 ;;       icmp sgt i16 %arg1, <immed>-1
288 ;; Consequently, even though the patterns exist to match, it's unlikely
289 ;; they'll ever be generated.
291 define i16 @icmp_slt_select_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
292 entry:
293        %A = icmp slt i16 %arg1, %arg2
294        %B = select i1 %A, i16 %val1, i16 %val2
295        ret i16 %B
298 define i1 @icmp_slt_setcc_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
299 entry:
300        %A = icmp slt i16 %arg1, %arg2
301        ret i1 %A
304 define i16 @icmp_slt_immed01_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
305 entry:
306        %A = icmp slt i16 %arg1, 511
307        %B = select i1 %A, i16 %val1, i16 %val2
308        ret i16 %B
311 define i16 @icmp_slt_immed02_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
312 entry:
313        %A = icmp slt i16 %arg1, -512
314        %B = select i1 %A, i16 %val1, i16 %val2
315        ret i16 %B
318 define i16 @icmp_slt_immed03_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
319 entry:
320        %A = icmp slt i16 %arg1, -1
321        %B = select i1 %A, i16 %val1, i16 %val2
322        ret i16 %B
325 define i16 @icmp_slt_immed04_i16(i16 %arg1, i16 %val1, i16 %val2) nounwind {
326 entry:
327        %A = icmp slt i16 %arg1, 32768
328        %B = select i1 %A, i16 %val1, i16 %val2
329        ret i16 %B
332 define i16 @icmp_sle_select_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
333 entry:
334        %A = icmp sle i16 %arg1, %arg2
335        %B = select i1 %A, i16 %val1, i16 %val2
336        ret i16 %B
339 define i1 @icmp_sle_setcc_i16(i16 %arg1, i16 %arg2, i16 %val1, i16 %val2) nounwind {
340 entry:
341        %A = icmp sle i16 %arg1, %arg2
342        ret i1 %A
345 ;; Note: icmp sle i16 %arg1, <immed> can always be transformed into
346 ;;       icmp slt i16 %arg1, <immed>+1
348 ;; Consequently, even though the patterns exist to match, it's unlikely
349 ;; they'll ever be generated.