Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / PowerPC / select.ll
blob49d55c7df524af63ef8f6e2dc6461dcbc5ee5161
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -ppc-asm-full-reg-names -verify-machineinstrs \
3 ; RUN:   -mtriple=powerpc64le-linux-gnu < %s | FileCheck \
4 ; RUN:   -check-prefix=CHECK-LE %s
5 ; RUN: llc -ppc-asm-full-reg-names -verify-machineinstrs \
6 ; RUN:   -mtriple=powerpc-linux-gnu < %s | FileCheck \
7 ; RUN:   -check-prefix=CHECK-32 %s
9 define i64 @f0(i64 %x) {
10 ; CHECK-LE-LABEL: f0:
11 ; CHECK-LE:       # %bb.0:
12 ; CHECK-LE-NEXT:    cmpdi r3, 0
13 ; CHECK-LE-NEXT:    li r3, 125
14 ; CHECK-LE-NEXT:    li r4, -3
15 ; CHECK-LE-NEXT:    isellt r3, r4, r3
16 ; CHECK-LE-NEXT:    blr
18 ; CHECK-32-LABEL: f0:
19 ; CHECK-32:       # %bb.0:
20 ; CHECK-32-NEXT:    li r4, 125
21 ; CHECK-32-NEXT:    li r5, -3
22 ; CHECK-32-NEXT:    cmpwi r3, 0
23 ; CHECK-32-NEXT:    bc 12, lt, .LBB0_1
24 ; CHECK-32-NEXT:    b .LBB0_2
25 ; CHECK-32-NEXT:  .LBB0_1:
26 ; CHECK-32-NEXT:    addi r4, r5, 0
27 ; CHECK-32-NEXT:  .LBB0_2:
28 ; CHECK-32-NEXT:    srawi r3, r3, 31
29 ; CHECK-32-NEXT:    blr
30   %c = icmp slt i64 %x, 0
31   %r = select i1 %c, i64 -3, i64 125
32   ret i64 %r
35 define i64 @f1(i64 %x) {
36 ; CHECK-LE-LABEL: f1:
37 ; CHECK-LE:       # %bb.0:
38 ; CHECK-LE-NEXT:    cmpdi r3, 0
39 ; CHECK-LE-NEXT:    li r3, 512
40 ; CHECK-LE-NEXT:    li r4, 64
41 ; CHECK-LE-NEXT:    isellt r3, r4, r3
42 ; CHECK-LE-NEXT:    blr
44 ; CHECK-32-LABEL: f1:
45 ; CHECK-32:       # %bb.0:
46 ; CHECK-32-NEXT:    li r4, 512
47 ; CHECK-32-NEXT:    cmpwi r3, 0
48 ; CHECK-32-NEXT:    li r3, 64
49 ; CHECK-32-NEXT:    bc 12, lt, .LBB1_1
50 ; CHECK-32-NEXT:    b .LBB1_2
51 ; CHECK-32-NEXT:  .LBB1_1:
52 ; CHECK-32-NEXT:    addi r4, r3, 0
53 ; CHECK-32-NEXT:  .LBB1_2:
54 ; CHECK-32-NEXT:    li r3, 0
55 ; CHECK-32-NEXT:    blr
56   %c = icmp slt i64 %x, 0
57   %r = select i1 %c, i64 64, i64 512
58   ret i64 %r
61 define i64 @f2(i64 %x) {
62 ; CHECK-LE-LABEL: f2:
63 ; CHECK-LE:       # %bb.0:
64 ; CHECK-LE-NEXT:    cmpdi r3, 0
65 ; CHECK-LE-NEXT:    li r3, 1024
66 ; CHECK-LE-NEXT:    iseleq r3, 0, r3
67 ; CHECK-LE-NEXT:    blr
69 ; CHECK-32-LABEL: f2:
70 ; CHECK-32:       # %bb.0:
71 ; CHECK-32-NEXT:    or. r3, r4, r3
72 ; CHECK-32-NEXT:    li r3, 1024
73 ; CHECK-32-NEXT:    bc 12, eq, .LBB2_2
74 ; CHECK-32-NEXT:  # %bb.1:
75 ; CHECK-32-NEXT:    ori r4, r3, 0
76 ; CHECK-32-NEXT:    b .LBB2_3
77 ; CHECK-32-NEXT:  .LBB2_2:
78 ; CHECK-32-NEXT:    li r4, 0
79 ; CHECK-32-NEXT:  .LBB2_3:
80 ; CHECK-32-NEXT:    li r3, 0
81 ; CHECK-32-NEXT:    blr
82   %c = icmp eq i64 %x, 0
83   %r = select i1 %c, i64 0, i64 1024
84   ret i64 %r
87 define i64 @f3(i64 %x, i64 %y) {
88 ; CHECK-LE-LABEL: f3:
89 ; CHECK-LE:       # %bb.0:
90 ; CHECK-LE-NEXT:    cmpldi r3, 0
91 ; CHECK-LE-NEXT:    iseleq r3, 0, r4
92 ; CHECK-LE-NEXT:    blr
94 ; CHECK-32-LABEL: f3:
95 ; CHECK-32:       # %bb.0:
96 ; CHECK-32-NEXT:    or. r3, r4, r3
97 ; CHECK-32-NEXT:    bc 12, eq, .LBB3_2
98 ; CHECK-32-NEXT:  # %bb.1:
99 ; CHECK-32-NEXT:    ori r3, r5, 0
100 ; CHECK-32-NEXT:    ori r4, r6, 0
101 ; CHECK-32-NEXT:    blr
102 ; CHECK-32-NEXT:  .LBB3_2:
103 ; CHECK-32-NEXT:    li r3, 0
104 ; CHECK-32-NEXT:    li r4, 0
105 ; CHECK-32-NEXT:    blr
106   %c = icmp eq i64 %x, 0
107   %r = select i1 %c, i64 0, i64 %y
108   ret i64 %r
111 define i64 @f4(i64 %x) {
112 ; CHECK-LE-LABEL: f4:
113 ; CHECK-LE:       # %bb.0:
114 ; CHECK-LE-NEXT:    sradi r4, r3, 63
115 ; CHECK-LE-NEXT:    xor r3, r3, r4
116 ; CHECK-LE-NEXT:    sub r3, r4, r3
117 ; CHECK-LE-NEXT:    blr
119 ; CHECK-32-LABEL: f4:
120 ; CHECK-32:       # %bb.0:
121 ; CHECK-32-NEXT:    srawi r5, r3, 31
122 ; CHECK-32-NEXT:    xor r4, r4, r5
123 ; CHECK-32-NEXT:    xor r3, r3, r5
124 ; CHECK-32-NEXT:    subc r4, r5, r4
125 ; CHECK-32-NEXT:    subfe r3, r3, r5
126 ; CHECK-32-NEXT:    blr
127   %c = icmp sgt i64 %x, 0
128   %x.neg = sub i64 0, %x
129   %r = select i1 %c, i64 %x.neg, i64 %x
130   ret i64 %r
133 define i64 @f4_sge_0(i64 %x) {
134 ; CHECK-LE-LABEL: f4_sge_0:
135 ; CHECK-LE:       # %bb.0:
136 ; CHECK-LE-NEXT:    cmpdi r3, -1
137 ; CHECK-LE-NEXT:    neg r4, r3
138 ; CHECK-LE-NEXT:    iselgt r3, r4, r3
139 ; CHECK-LE-NEXT:    blr
141 ; CHECK-32-LABEL: f4_sge_0:
142 ; CHECK-32:       # %bb.0:
143 ; CHECK-32-NEXT:    subfic r5, r4, 0
144 ; CHECK-32-NEXT:    subfze r6, r3
145 ; CHECK-32-NEXT:    cmpwi r3, -1
146 ; CHECK-32-NEXT:    bc 12, gt, .LBB5_1
147 ; CHECK-32-NEXT:    blr
148 ; CHECK-32-NEXT:  .LBB5_1:
149 ; CHECK-32-NEXT:    addi r3, r6, 0
150 ; CHECK-32-NEXT:    addi r4, r5, 0
151 ; CHECK-32-NEXT:    blr
152   %c = icmp sge i64 %x, 0
153   %x.neg = sub i64 0, %x
154   %r = select i1 %c, i64 %x.neg, i64 %x
155   ret i64 %r
158 define i64 @f4_slt_0(i64 %x) {
159 ; CHECK-LE-LABEL: f4_slt_0:
160 ; CHECK-LE:       # %bb.0:
161 ; CHECK-LE-NEXT:    sradi r4, r3, 63
162 ; CHECK-LE-NEXT:    xor r3, r3, r4
163 ; CHECK-LE-NEXT:    sub r3, r4, r3
164 ; CHECK-LE-NEXT:    blr
166 ; CHECK-32-LABEL: f4_slt_0:
167 ; CHECK-32:       # %bb.0:
168 ; CHECK-32-NEXT:    srawi r5, r3, 31
169 ; CHECK-32-NEXT:    xor r4, r4, r5
170 ; CHECK-32-NEXT:    xor r3, r3, r5
171 ; CHECK-32-NEXT:    subc r4, r5, r4
172 ; CHECK-32-NEXT:    subfe r3, r3, r5
173 ; CHECK-32-NEXT:    blr
174   %c = icmp slt i64 %x, 0
175   %x.neg = sub i64 0, %x
176   %r = select i1 %c, i64 %x, i64 %x.neg
177   ret i64 %r
180 define i64 @f4_sle_0(i64 %x) {
181 ; CHECK-LE-LABEL: f4_sle_0:
182 ; CHECK-LE:       # %bb.0:
183 ; CHECK-LE-NEXT:    cmpdi r3, 1
184 ; CHECK-LE-NEXT:    neg r4, r3
185 ; CHECK-LE-NEXT:    isellt r3, r3, r4
186 ; CHECK-LE-NEXT:    blr
188 ; CHECK-32-LABEL: f4_sle_0:
189 ; CHECK-32:       # %bb.0:
190 ; CHECK-32-NEXT:    cmplwi r3, 0
191 ; CHECK-32-NEXT:    cmpwi cr1, r3, 0
192 ; CHECK-32-NEXT:    crandc 4*cr5+lt, 4*cr1+lt, eq
193 ; CHECK-32-NEXT:    cmpwi cr1, r4, 0
194 ; CHECK-32-NEXT:    subfic r5, r4, 0
195 ; CHECK-32-NEXT:    crand 4*cr5+gt, eq, 4*cr1+eq
196 ; CHECK-32-NEXT:    cror 4*cr5+lt, 4*cr5+gt, 4*cr5+lt
197 ; CHECK-32-NEXT:    subfze r6, r3
198 ; CHECK-32-NEXT:    bclr 12, 4*cr5+lt, 0
199 ; CHECK-32-NEXT:  # %bb.1:
200 ; CHECK-32-NEXT:    ori r3, r6, 0
201 ; CHECK-32-NEXT:    ori r4, r5, 0
202 ; CHECK-32-NEXT:    blr
203   %c = icmp sle i64 %x, 0
204   %x.neg = sub i64 0, %x
205   %r = select i1 %c, i64 %x, i64 %x.neg
206   ret i64 %r
209 define i64 @f4_sgt_m1(i64 %x) {
210 ; CHECK-LE-LABEL: f4_sgt_m1:
211 ; CHECK-LE:       # %bb.0:
212 ; CHECK-LE-NEXT:    sradi r4, r3, 63
213 ; CHECK-LE-NEXT:    xor r3, r3, r4
214 ; CHECK-LE-NEXT:    sub r3, r4, r3
215 ; CHECK-LE-NEXT:    blr
217 ; CHECK-32-LABEL: f4_sgt_m1:
218 ; CHECK-32:       # %bb.0:
219 ; CHECK-32-NEXT:    srawi r5, r3, 31
220 ; CHECK-32-NEXT:    xor r4, r4, r5
221 ; CHECK-32-NEXT:    xor r3, r3, r5
222 ; CHECK-32-NEXT:    subc r4, r5, r4
223 ; CHECK-32-NEXT:    subfe r3, r3, r5
224 ; CHECK-32-NEXT:    blr
225   %c = icmp sgt i64 %x, -1
226   %x.neg = sub i64 0, %x
227   %r = select i1 %c, i64 %x.neg, i64 %x
228   ret i64 %r
231 define i64 @f5(i64 %x, i64 %y) {
232 ; CHECK-LE-LABEL: f5:
233 ; CHECK-LE:       # %bb.0:
234 ; CHECK-LE-NEXT:    cmpldi r3, 0
235 ; CHECK-LE-NEXT:    li r3, 0
236 ; CHECK-LE-NEXT:    iseleq r3, r4, r3
237 ; CHECK-LE-NEXT:    blr
239 ; CHECK-32-LABEL: f5:
240 ; CHECK-32:       # %bb.0:
241 ; CHECK-32-NEXT:    li r7, 0
242 ; CHECK-32-NEXT:    or. r3, r4, r3
243 ; CHECK-32-NEXT:    bc 12, eq, .LBB9_2
244 ; CHECK-32-NEXT:  # %bb.1:
245 ; CHECK-32-NEXT:    ori r3, r7, 0
246 ; CHECK-32-NEXT:    ori r4, r7, 0
247 ; CHECK-32-NEXT:    blr
248 ; CHECK-32-NEXT:  .LBB9_2:
249 ; CHECK-32-NEXT:    addi r3, r5, 0
250 ; CHECK-32-NEXT:    addi r4, r6, 0
251 ; CHECK-32-NEXT:    blr
252   %c = icmp eq i64 %x, 0
253   %r = select i1 %c, i64 %y, i64 0
254   ret i64 %r
257 define i32 @f5_i32(i32 %x, i32 %y) {
258 ; CHECK-LE-LABEL: f5_i32:
259 ; CHECK-LE:       # %bb.0:
260 ; CHECK-LE-NEXT:    cmplwi r3, 0
261 ; CHECK-LE-NEXT:    li r3, 0
262 ; CHECK-LE-NEXT:    iseleq r3, r4, r3
263 ; CHECK-LE-NEXT:    blr
265 ; CHECK-32-LABEL: f5_i32:
266 ; CHECK-32:       # %bb.0:
267 ; CHECK-32-NEXT:    li r5, 0
268 ; CHECK-32-NEXT:    cmplwi r3, 0
269 ; CHECK-32-NEXT:    bc 12, eq, .LBB10_2
270 ; CHECK-32-NEXT:  # %bb.1:
271 ; CHECK-32-NEXT:    ori r3, r5, 0
272 ; CHECK-32-NEXT:    blr
273 ; CHECK-32-NEXT:  .LBB10_2:
274 ; CHECK-32-NEXT:    addi r3, r4, 0
275 ; CHECK-32-NEXT:    blr
276   %c = icmp eq i32 %x, 0
277   %r = select i1 %c, i32 %y, i32 0
278   ret i32 %r
281 define i64 @f6(i64 %x) {
282 ; CHECK-LE-LABEL: f6:
283 ; CHECK-LE:       # %bb.0:
284 ; CHECK-LE-NEXT:    cntlzd r3, r3
285 ; CHECK-LE-NEXT:    rldicl r3, r3, 58, 63
286 ; CHECK-LE-NEXT:    blr
288 ; CHECK-32-LABEL: f6:
289 ; CHECK-32:       # %bb.0:
290 ; CHECK-32-NEXT:    or r3, r4, r3
291 ; CHECK-32-NEXT:    cntlzw r3, r3
292 ; CHECK-32-NEXT:    rlwinm r4, r3, 27, 31, 31
293 ; CHECK-32-NEXT:    li r3, 0
294 ; CHECK-32-NEXT:    blr
295   %c = icmp ne i64 %x, 0
296   %r = select i1 %c, i64 0, i64 1
297   ret i64 %r
300 define i32 @f6_i32(i32 %x) {
301 ; CHECK-LE-LABEL: f6_i32:
302 ; CHECK-LE:       # %bb.0:
303 ; CHECK-LE-NEXT:    cntlzw r3, r3
304 ; CHECK-LE-NEXT:    srwi r3, r3, 5
305 ; CHECK-LE-NEXT:    blr
307 ; CHECK-32-LABEL: f6_i32:
308 ; CHECK-32:       # %bb.0:
309 ; CHECK-32-NEXT:    cntlzw r3, r3
310 ; CHECK-32-NEXT:    rlwinm r3, r3, 27, 31, 31
311 ; CHECK-32-NEXT:    blr
312   %c = icmp ne i32 %x, 0
313   %r = select i1 %c, i32 0, i32 1
314   ret i32 %r