Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / PowerPC / p10-constants.ll
blob77472afd9c3d4d55cc374cff9c66adc82d77c8ae
1 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \
2 ; RUN:   -mcpu=pwr10 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr < %s | \
3 ; RUN:   FileCheck %s
4 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu \
5 ; RUN:   -mcpu=pwr10 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr < %s | \
6 ; RUN:   FileCheck %s
7 ; RUN: llc -verify-machineinstrs -mtriple=powerpc-unknown-linux-gnu \
8 ; RUN:   -mcpu=pwr10 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr < %s | \
9 ; RUN:   FileCheck %s --check-prefix=CHECK32
11 ; These test cases aim to test constant materialization using the pli instruction on Power10.
13 define  signext i32 @t_16BitsMinRequiring34Bits() {
14 ; CHECK-LABEL: t_16BitsMinRequiring34Bits:
15 ; CHECK:        pli r3, 32768
16 ; CHECK-NEXT:   blr
17 ; CHECK32-LABEL: t_16BitsMinRequiring34Bits:
18 ; CHECK32:      pli r3, 32768
19 ; CHECK32-NEXT: blr
21 entry:
22   ret i32 32768
25 define  signext i32 @t_16Bits() {
26 ; CHECK-LABEL: t_16Bits:
27 ; CHECK:        pli r3, 62004
28 ; CHECK-NEXT:   blr
29 ; CHECK32-LABEL: t_16Bits:
30 ; CHECK32:      pli r3, 62004
31 ; CHECK32-NEXT: blr
33 entry:
34   ret i32 62004
37 define  signext i32 @t_lt32gt16BitsNonShiftable() {
38 ; CHECK-LABEL: t_lt32gt16BitsNonShiftable:
39 ; CHECK:        pli r3, 1193046
40 ; CHECK-NEXT:   blr
41 ; CHECK32-LABEL: t_lt32gt16BitsNonShiftable:
42 ; CHECK32:      pli r3, 1193046
43 ; CHECK32-NEXT: blr
45 entry:
46   ret i32 1193046
49 define  signext i32 @t_32Bits() {
50 ; CHECK-LABEL: t_32Bits:
51 ; CHECK:        pli r3, -231451016
52 ; CHECK-NEXT:   blr
53 ; CHECK32-LABEL: t_32Bits:
54 ; CHECK32:      pli r3, -231451016
55 ; CHECK32-NEXT: blr
57 entry:
58   ret i32 -231451016
61 define  i64 @t_34BitsLargestPositive() {
62 ; CHECK-LABEL: t_34BitsLargestPositive:
63 ; CHECK:        pli r3, 8589934591
64 ; CHECK-NEXT:   blr
65 ; CHECK32-LABEL: t_34BitsLargestPositive:
66 ; CHECK32:      li r3, 1
67 ; CHECK32-NEXT: li r4, -1
68 ; CHECK32-NEXT: blr
70 entry:
71   ret i64 8589934591
74 define  i64 @t_neg34Bits() {
75 ; CHECK-LABEL: t_neg34Bits:
76 ; CHECK:        pli r3, -8284514696
77 ; CHECK-NEXT:   blr
78 ; CHECK32-LABEL: t_neg34Bits:
79 ; CHECK32:      li r3, -2
80 ; CHECK32-NEXT: pli r4, 305419896
81 ; CHECK32-NEXT: blr
83 entry:
84   ret i64 -8284514696
87 define  signext i32 @t_16BitsMinRequiring34BitsMinusOne() {
88 ; CHECK-LABEL: t_16BitsMinRequiring34BitsMinusOne:
89 ; CHECK:        li r3, 32767
90 ; CHECK-NEXT:   blr
91 ; CHECK32-LABEL: t_16BitsMinRequiring34BitsMinusOne:
92 ; CHECK32:      li r3, 32767
93 ; CHECK32-NEXT: blr
95 entry:
96   ret i32 32767
99 define  signext i32 @t_lt16Bits() {
100 ; CHECK-LABEL: t_lt16Bits:
101 ; CHECK:        li r3, 291
102 ; CHECK-NEXT:   blr
103 ; CHECK32-LABEL: t_lt16Bits:
104 ; CHECK32:      li r3, 291
105 ; CHECK32-NEXT: blr
107 entry:
108   ret i32 291
111 define  signext i32 @t_neglt16Bits() {
112 ; CHECK-LABEL: t_neglt16Bits:
113 ; CHECK:        li r3, -3805
114 ; CHECK-NEXT:   blr
115 ; CHECK32-LABEL: t_neglt16Bits:
116 ; CHECK32:      li r3, -3805
117 ; CHECK32-NEXT: blr
119 entry:
120   ret i32 -3805
123 define  signext i32 @t_neg16Bits() {
124 ; CHECK-LABEL: t_neg16Bits:
125 ; CHECK:        li r3, -32204
126 ; CHECK-NEXT:   blr
127 ; CHECK32-LABEL: t_neg16Bits:
128 ; CHECK32:      li r3, -32204
129 ; CHECK32-NEXT: blr
131 entry:
132   ret i32 -32204
135 define  signext i32 @t_lt32gt16BitsShiftable() {
136 ; CHECK-LABEL: t_lt32gt16BitsShiftable:
137 ; CHECK:        lis r3, 18
138 ; CHECK-NEXT:   blr
139 ; CHECK32-LABEL: t_lt32gt16BitsShiftable:
140 ; CHECK32:      lis r3, 18
141 ; CHECK32-NEXT: blr
143 entry:
144   ret i32 1179648
147 define  signext i32 @t_32gt16BitsShiftable() {
148 ; CHECK-LABEL: t_32gt16BitsShiftable:
149 ; CHECK:        lis r3, -3532
150 ; CHECK-NEXT:   blr
151 ; CHECK32-LABEL: t_32gt16BitsShiftable:
152 ; CHECK32:      lis r3, -3532
153 ; CHECK32-NEXT: blr
155 entry:
156   ret i32 -231473152
159 define  signext i32 @t_32BitsZero() {
160 ; CHECK-LABEL: t_32BitsZero:
161 ; CHECK:        li r3, 0
162 ; CHECK-NEXT:   blr
163 ; CHECK32-LABEL: t_32BitsZero:
164 ; CHECK32:      li r3, 0
165 ; CHECK32-NEXT: blr
167 entry:
168   ret i32 0
171 define  signext i32 @t_32BitsAllOnes() {
172 ; CHECK-LABEL: t_32BitsAllOnes:
173 ; CHECK:        li r3, -1
174 ; CHECK-NEXT:   blr
175 ; CHECK32-LABEL: t_32BitsAllOnes:
176 ; CHECK32:      li r3, -1
177 ; CHECK32-NEXT: blr
179 entry:
180   ret i32 -1
183 define  i64 @t_34BitsLargestPositivePlus() {
184 ; CHECK-LABEL: t_34BitsLargestPositivePlus:
185 ; CHECK:        li r3, 1
186 ; CHECK-NEXT:   rldic r3, r3, 33, 30
187 ; CHECK-NEXT:   blr
188 ; CHECK32-LABEL: t_34BitsLargestPositivePlus:
189 ; CHECK32:      li r3, 2
190 ; CHECK32-NEXT: li r4, 0
191 ; CHECK32-NEXT: blr
193 entry:
194   ret i64 8589934592
197 define  i64 @t_34Bits() {
198 ; CHECK-LABEL: t_34Bits:
199 ; CHECK:        pli r3, 1648790223
200 ; CHECK-NEXT:   rldic r3, r3, 3, 30
201 ; CHECK-NEXT:   blr
202 ; CHECK32-LABEL: t_34Bits:
203 ; CHECK32:      li r3, 3
204 ; CHECK32-NEXT: pli r4, 305419896
205 ; CHECK32-NEXT: blr
207 entry:
208   ret i64 13190321784
211 define  i64 @t_35Bits() {
212 ; CHECK-LABEL: t_35Bits:
213 ; CHECK:        pli r3, 4266035919
214 ; CHECK-NEXT:   rldic r3, r3, 3, 29
215 ; CHECK-NEXT:   blr
216 ; CHECK32-LABEL: t_35Bits:
217 ; CHECK32:      li r3, 7
218 ; CHECK32-NEXT: pli r4, -231451016
219 ; CHECK32-NEXT: blr
221 entry:
222   ret i64 34128287352
225 ; (Value >> Shift) can be expressed in 34 bits
226 define  i64 @t_Shift() {
227 ; CHECK-LABEL: t_Shift:
228 ; CHECK:         pli r3, 8522759166
229 ; CHECK-NEXT:    rotldi r3, r3, 48
230 ; CHECK-NEXT:    blr
232 entry:
233   ; 0xFBFE00000001FBFE
234   ret i64 18157950747604548606
237 ; Leading Zeros + Following Ones + Trailing Zeros > 30
238 define  i64 @t_LZFOTZ() {
239 ; CHECK-LABEL: t_LZFOTZ:
240 ; CHECK:         pli r3, -349233
241 ; CHECK-NEXT:    rldic r3, r3, 4, 12
242 ; CHECK-NEXT:    blr
244 entry:
245   ; 0x000FFFFFFFAABCF0
246   ret i64 4503599621782768
249 ; Leading Zeros + Trailing Ones > 30
250 define  i64 @t_LZTO() {
251 ; CHECK-LABEL: t_LZTO:
252 ; CHECK:         pli r3, -2684406441
253 ; CHECK-NEXT:    rldicl r3, r3, 11, 19
254 ; CHECK-NEXT:    blr
255 entry:
256   ; 0x00001AFFF9AABFFF
257   ret i64 29686707699711
260 ; Leading Zeros + Trailing Ones + Following Zeros > 30
261 define  i64 @t_LZTOFO() {
262 ; CHECK-LABEL: t_LZTOFO:
263 ; CHECK:         pli r3, -5720033968
264 ; CHECK-NEXT:    rldicl r3, r3, 11, 12
265 ; CHECK-NEXT:    blr
266 entry:
267   ; 0x000FF55879AA87FF
268   ret i64 4491884997806079
271 ; Requires full expansion
272 define  i64 @t_Full64Bits1() {
273 ; CHECK-LABEL: t_Full64Bits1:
274 ; CHECK:         pli r4, 2146500607
275 ; CHECK-NEXT:    pli r3, 4043305214
276 ; CHECK-NEXT:    rldimi r3, r4, 32, 0
277 ; CHECK-NEXT:    blr
278 entry:
279   ; 0x7FF0FFFFF0FFF0FE
280   ret i64 9219149911952453886
283 ; Requires full expansion
284 define  i64 @t_Ful64Bits2() {
285 ; CHECK-LABEL: t_Ful64Bits2:
286 ; CHECK:         pli r4, 4042326015
287 ; CHECK-NEXT:    pli r3, 4043305214
288 ; CHECK-NEXT:    rldimi r3, r4, 32, 0
289 ; CHECK-NEXT:    blr
290 entry:
291   ; 0xF0F0FFFFF0FFF0FE
292   ret i64 17361658038238310654
295 ; A splat of 32 bits: 32 Bits Low == 32 Bits High
296 define  i64 @t_Splat32Bits() {
297 ; CHECK-LABEL: t_Splat32Bits:
298 ; CHECK:         pli r3, 262916796
299 ; CHECK-NEXT:    rldimi r3, r3, 32, 0
300 ; CHECK-NEXT:    blr
301 entry:
302   ; 0x0FABCABC0FABCABC
303   ret i64 1129219040652020412
306 ; Producing `pli` when the constant fits within 34-bits and the constant
307 ; is being produced in other transformations (such as complex bit permutations).
308 define i64 @t_34Bits_Complex(i64 %a, i64 %b) {
309 ; CHECK-LABEL: t_34Bits_Complex:
310 ; CHECK:       # %bb.0: # %entry
311 ; CHECK-NEXT:    rotldi r4, r4, 30
312 ; CHECK-NEXT:    rldimi r3, r4, 34, 31
313 ; CHECK-NEXT:    pli r4, -268435457
314 ; CHECK-NEXT:    and r3, r3, r4
315 ; CHECK-NEXT:    blr
317 ; CHECK32-LABEL: t_34Bits_Complex:
318 ; CHECK32:       # %bb.0: # %entry
319 ; CHECK32-NEXT:    rlwinm r4, r6, 0, 4, 2
320 ; CHECK32-NEXT:    rlwimi r3, r5, 0, 31, 29
321 ; CHECK32-NEXT:    blr
322 entry:
323   %and = and i64 %a, 8589934592
324   %and1 = and i64 %b, -8858370049
325   %or = or i64 %and1, %and
326   ret i64 %or
329 ; The load immediates resulting from phi-nodes are needed to test whether
330 ; li/lis is preferred to pli by the instruction selector.
331 define dso_local void @t_phiNode() {
332 ; CHECK-LABEL: t_phiNode:
333 ; CHECK:        lis r6, 18
334 ; CHECK-NEXT:   li r5, 291
335 ; CHECK-NEXT:   li r4, 0
336 ; CHECK-NEXT:   cmpwi r3, 1
337 ; CHECK-NEXT:   li r3, -1
338 ; CHECK:        pli r6, 2147483647
339 ; CHECK-NEXT:   pli r5, 1193046
340 ; CHECK-NEXT:   pli r4, 32768
341 ; CHECK-NEXT:   pli r3, -231451016
342 ; CHECK32-LABEL: t_phiNode:
343 ; CHECK32:      lis r6, 18
344 ; CHECK32-NEXT: li r5, 291
345 ; CHECK32-NEXT: li r4, 0
346 ; CHECK32-NEXT:   cmpwi r3, 1
347 ; CHECK32-NEXT: li r3, -1
348 ; CHECK32:      pli r6, 2147483647
349 ; CHECK32-NEXT: pli r5, 1193046
350 ; CHECK32-NEXT: pli r4, 32768
351 ; CHECK32-NEXT: pli r3, -231451016
353 entry:
354   br label %while.body
356 while.body:                                       ; preds = %if.else.i, %entry
357   br label %while.body.i
359 while.body.i:                                     ; preds = %sw.epilog.i, %while.body
360   %a.1.i = phi i32 [ %a.2.i, %sw.epilog.i ], [ -1, %while.body ]
361   %b.1.i = phi i32 [ %b.2.i, %sw.epilog.i ], [ 0, %while.body ]
362   %c.1.i = phi i32 [ %c.2.i, %sw.epilog.i ], [ 291, %while.body ]
363   %d.1.i = phi i32 [ %d.2.i, %sw.epilog.i ], [ 1179648, %while.body ]
364   %0 = load i8, ptr null, align 1
365   %cmp1.i = icmp eq i8 %0, 1
366   br i1 %cmp1.i, label %if.then.i, label %if.else.i
368 if.then.i:                                        ; preds = %while.body.i
369   switch i8 undef, label %sw.default.i [
370     i8 3, label %sw.epilog.i
371     i8 2, label %sw.bb1.i
372   ]
374 sw.bb1.i:                                        ; preds = %if.then.i
375   br label %sw.epilog.i
377 sw.default.i:                                     ; preds = %if.then.i
378   unreachable
380 sw.epilog.i:                                      ; preds = %sw.bb2.i, %sw.bb1.i, %if.then.i
381   %a.2.i = phi i32 [ -231451016, %sw.bb1.i ], [ %a.1.i, %if.then.i ]
382   %b.2.i = phi i32 [ 32768, %sw.bb1.i ], [ %b.1.i, %if.then.i ]
383   %c.2.i = phi i32 [ 1193046, %sw.bb1.i ], [ %c.1.i, %if.then.i ]
384   %d.2.i = phi i32 [ 2147483647, %sw.bb1.i ], [ %d.1.i, %if.then.i ]
385   br label %while.body.i
387 if.else.i:                                     ; preds = %while.body.i
388   call void @func2(i32 signext %a.1.i, i32 signext %b.1.i, i32 signext %c.1.i, i32 signext %d.1.i)
389   br label %while.body
392 declare void @func2(i32, i32, i32, i32)