[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / ARM / store-prepostinc.mir
blobb974bc29838ca851f59039d9dca8d369ec6ed8cd
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -run-pass=arm-ldst-opt %s -o - | FileCheck %s
4 --- |
5   target datalayout = "e-m:e-p:32:32-Fi8-i64:64-v128:64:128-a:0:32-n32-S64"
6   target triple = "thumbv7a-none-unknown-eabi"
8   define i8* @STR_pre4(i8* %p, i32 %v) { unreachable }
9   define i8* @STR_pre8(i8* %p, i32 %v) { unreachable }
10   define i8* @STR_pre255(i8* %p, i32 %v) { unreachable }
11   define i8* @STR_pre256(i8* %p, i32 %v) { unreachable }
12   define i8* @STR_pre1024(i8* %p, i32 %v) { unreachable }
13   define i8* @STR_pre4095(i8* %p, i32 %v) { unreachable }
14   define i8* @STR_pre4096(i8* %p, i32 %v) { unreachable }
15   define i8* @STR_prem1024(i8* %p, i32 %v) { unreachable }
16   define i8* @STR_prem4095(i8* %p, i32 %v) { unreachable }
17   define i8* @STR_prem4096(i8* %p, i32 %v) { unreachable }
19   define i8* @STR_post4(i8* %p, i32 %v) { unreachable }
20   define i8* @STR_post8(i8* %p, i32 %v) { unreachable }
21   define i8* @STR_post255(i8* %p, i32 %v) { unreachable }
22   define i8* @STR_post256(i8* %p, i32 %v) { unreachable }
23   define i8* @STR_post1024(i8* %p, i32 %v) { unreachable }
24   define i8* @STR_post4095(i8* %p, i32 %v) { unreachable }
25   define i8* @STR_post4096(i8* %p, i32 %v) { unreachable }
26   define i8* @STR_postm1024(i8* %p, i32 %v) { unreachable }
27   define i8* @STR_postm4095(i8* %p, i32 %v) { unreachable }
28   define i8* @STR_postm4096(i8* %p, i32 %v) { unreachable }
30 ...
31 ---
32 name:            STR_pre4
33 alignment:       4
34 tracksRegLiveness: true
35 liveins:
36   - { reg: '$r0', virtual-reg: '' }
37   - { reg: '$r1', virtual-reg: '' }
38 body:             |
39   bb.0 (%ir-block.0):
40     liveins: $r0, $r1
42     ; CHECK-LABEL: name: STR_pre4
43     ; CHECK: liveins: $r0, $r1
44     ; CHECK: early-clobber $r0 = STR_PRE_IMM killed $r1, $r0, 4, 14 /* CC::al */, $noreg :: (store (s32))
45     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
46     renamable $r0 = nuw ADDri killed renamable $r0, 4, 14 /* CC::al */, $noreg, $noreg
47     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
48     BX_RET 14 /* CC::al */, $noreg, implicit $r0
50 ...
51 ---
52 name:            STR_pre8
53 alignment:       4
54 tracksRegLiveness: true
55 liveins:
56   - { reg: '$r0', virtual-reg: '' }
57   - { reg: '$r1', virtual-reg: '' }
58 body:             |
59   bb.0 (%ir-block.0):
60     liveins: $r0, $r1
62     ; CHECK-LABEL: name: STR_pre8
63     ; CHECK: liveins: $r0, $r1
64     ; CHECK: renamable $r0 = nuw ADDri killed renamable $r0, 8, 14 /* CC::al */, $noreg, $noreg
65     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
66     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
67     renamable $r0 = nuw ADDri killed renamable $r0, 8, 14 /* CC::al */, $noreg, $noreg
68     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
69     BX_RET 14 /* CC::al */, $noreg, implicit $r0
71 ...
72 ---
73 name:            STR_pre255
74 alignment:       4
75 tracksRegLiveness: true
76 liveins:
77   - { reg: '$r0', virtual-reg: '' }
78   - { reg: '$r1', virtual-reg: '' }
79 body:             |
80   bb.0 (%ir-block.0):
81     liveins: $r0, $r1
83     ; CHECK-LABEL: name: STR_pre255
84     ; CHECK: liveins: $r0, $r1
85     ; CHECK: renamable $r0 = nuw ADDri killed renamable $r0, 255, 14 /* CC::al */, $noreg, $noreg
86     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
87     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
88     renamable $r0 = nuw ADDri killed renamable $r0, 255, 14 /* CC::al */, $noreg, $noreg
89     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
90     BX_RET 14 /* CC::al */, $noreg, implicit $r0
92 ...
93 ---
94 name:            STR_pre256
95 alignment:       4
96 tracksRegLiveness: true
97 liveins:
98   - { reg: '$r0', virtual-reg: '' }
99   - { reg: '$r1', virtual-reg: '' }
100 body:             |
101   bb.0 (%ir-block.0):
102     liveins: $r0, $r1
104     ; CHECK-LABEL: name: STR_pre256
105     ; CHECK: liveins: $r0, $r1
106     ; CHECK: renamable $r0 = nuw ADDri killed renamable $r0, 256, 14 /* CC::al */, $noreg, $noreg
107     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
108     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
109     renamable $r0 = nuw ADDri killed renamable $r0, 256, 14 /* CC::al */, $noreg, $noreg
110     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
111     BX_RET 14 /* CC::al */, $noreg, implicit $r0
115 name:            STR_pre1024
116 alignment:       4
117 tracksRegLiveness: true
118 liveins:
119   - { reg: '$r0', virtual-reg: '' }
120   - { reg: '$r1', virtual-reg: '' }
121 body:             |
122   bb.0 (%ir-block.0):
123     liveins: $r0, $r1
125     ; CHECK-LABEL: name: STR_pre1024
126     ; CHECK: liveins: $r0, $r1
127     ; CHECK: renamable $r0 = nuw ADDri killed renamable $r0, 1024, 14 /* CC::al */, $noreg, $noreg
128     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
129     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
130     renamable $r0 = nuw ADDri killed renamable $r0, 1024, 14 /* CC::al */, $noreg, $noreg
131     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
132     BX_RET 14 /* CC::al */, $noreg, implicit $r0
136 name:            STR_pre4095
137 alignment:       4
138 tracksRegLiveness: true
139 liveins:
140   - { reg: '$r0', virtual-reg: '' }
141   - { reg: '$r1', virtual-reg: '' }
142 body:             |
143   bb.0 (%ir-block.0):
144     liveins: $r0, $r1
146     ; CHECK-LABEL: name: STR_pre4095
147     ; CHECK: liveins: $r0, $r1
148     ; CHECK: renamable $r0 = nuw ADDri killed renamable $r0, 4095, 14 /* CC::al */, $noreg, $noreg
149     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
150     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
151     renamable $r0 = nuw ADDri killed renamable $r0, 4095, 14 /* CC::al */, $noreg, $noreg
152     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
153     BX_RET 14 /* CC::al */, $noreg, implicit $r0
157 name:            STR_pre4096
158 alignment:       4
159 tracksRegLiveness: true
160 liveins:
161   - { reg: '$r0', virtual-reg: '' }
162   - { reg: '$r1', virtual-reg: '' }
163 body:             |
164   bb.0 (%ir-block.0):
165     liveins: $r0, $r1
167     ; CHECK-LABEL: name: STR_pre4096
168     ; CHECK: liveins: $r0, $r1
169     ; CHECK: renamable $r0 = nuw ADDri killed renamable $r0, 4096, 14 /* CC::al */, $noreg, $noreg
170     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
171     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
172     renamable $r0 = nuw ADDri killed renamable $r0, 4096, 14 /* CC::al */, $noreg, $noreg
173     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
174     BX_RET 14 /* CC::al */, $noreg, implicit $r0
178 name:            STR_prem1024
179 alignment:       4
180 tracksRegLiveness: true
181 liveins:
182   - { reg: '$r0', virtual-reg: '' }
183   - { reg: '$r1', virtual-reg: '' }
184 body:             |
185   bb.0 (%ir-block.0):
186     liveins: $r0, $r1
188     ; CHECK-LABEL: name: STR_prem1024
189     ; CHECK: liveins: $r0, $r1
190     ; CHECK: renamable $r0 = nuw SUBri killed renamable $r0, 1024, 14 /* CC::al */, $noreg, $noreg
191     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
192     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
193     renamable $r0 = nuw SUBri killed renamable $r0, 1024, 14 /* CC::al */, $noreg, $noreg
194     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
195     BX_RET 14 /* CC::al */, $noreg, implicit $r0
199 name:            STR_prem4095
200 alignment:       4
201 tracksRegLiveness: true
202 liveins:
203   - { reg: '$r0', virtual-reg: '' }
204   - { reg: '$r1', virtual-reg: '' }
205 body:             |
206   bb.0 (%ir-block.0):
207     liveins: $r0, $r1
209     ; CHECK-LABEL: name: STR_prem4095
210     ; CHECK: liveins: $r0, $r1
211     ; CHECK: renamable $r0 = nuw SUBri killed renamable $r0, 4095, 14 /* CC::al */, $noreg, $noreg
212     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
213     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
214     renamable $r0 = nuw SUBri killed renamable $r0, 4095, 14 /* CC::al */, $noreg, $noreg
215     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
216     BX_RET 14 /* CC::al */, $noreg, implicit $r0
220 name:            STR_prem4096
221 alignment:       4
222 tracksRegLiveness: true
223 liveins:
224   - { reg: '$r0', virtual-reg: '' }
225   - { reg: '$r1', virtual-reg: '' }
226 body:             |
227   bb.0 (%ir-block.0):
228     liveins: $r0, $r1
230     ; CHECK-LABEL: name: STR_prem4096
231     ; CHECK: liveins: $r0, $r1
232     ; CHECK: renamable $r0 = nuw SUBri killed renamable $r0, 4096, 14 /* CC::al */, $noreg, $noreg
233     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
234     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
235     renamable $r0 = nuw SUBri killed renamable $r0, 4096, 14 /* CC::al */, $noreg, $noreg
236     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
237     BX_RET 14 /* CC::al */, $noreg, implicit $r0
242 name:            STR_post4
243 alignment:       4
244 tracksRegLiveness: true
245 liveins:
246   - { reg: '$r0', virtual-reg: '' }
247   - { reg: '$r1', virtual-reg: '' }
248 body:             |
249   bb.0 (%ir-block.0):
250     liveins: $r0, $r1
252     ; CHECK-LABEL: name: STR_post4
253     ; CHECK: liveins: $r0, $r1
254     ; CHECK: early-clobber $r0 = STR_POST_IMM killed $r1, $r0, $noreg, 4, 14 /* CC::al */, $noreg :: (store (s32))
255     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
256     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
257     renamable $r0 = nuw ADDri killed renamable $r0, 4, 14 /* CC::al */, $noreg, $noreg
258     BX_RET 14 /* CC::al */, $noreg, implicit $r0
262 name:            STR_post8
263 alignment:       4
264 tracksRegLiveness: true
265 liveins:
266   - { reg: '$r0', virtual-reg: '' }
267   - { reg: '$r1', virtual-reg: '' }
268 body:             |
269   bb.0 (%ir-block.0):
270     liveins: $r0, $r1
272     ; CHECK-LABEL: name: STR_post8
273     ; CHECK: liveins: $r0, $r1
274     ; CHECK: early-clobber $r0 = STR_POST_IMM killed $r1, $r0, $noreg, 8, 14 /* CC::al */, $noreg :: (store (s32))
275     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
276     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
277     renamable $r0 = nuw ADDri killed renamable $r0, 8, 14 /* CC::al */, $noreg, $noreg
278     BX_RET 14 /* CC::al */, $noreg, implicit $r0
282 name:            STR_post255
283 alignment:       4
284 tracksRegLiveness: true
285 liveins:
286   - { reg: '$r0', virtual-reg: '' }
287   - { reg: '$r1', virtual-reg: '' }
288 body:             |
289   bb.0 (%ir-block.0):
290     liveins: $r0, $r1
292     ; CHECK-LABEL: name: STR_post255
293     ; CHECK: liveins: $r0, $r1
294     ; CHECK: early-clobber $r0 = STR_POST_IMM killed $r1, $r0, $noreg, 255, 14 /* CC::al */, $noreg :: (store (s32))
295     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
296     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
297     renamable $r0 = nuw ADDri killed renamable $r0, 255, 14 /* CC::al */, $noreg, $noreg
298     BX_RET 14 /* CC::al */, $noreg, implicit $r0
302 name:            STR_post256
303 alignment:       4
304 tracksRegLiveness: true
305 liveins:
306   - { reg: '$r0', virtual-reg: '' }
307   - { reg: '$r1', virtual-reg: '' }
308 body:             |
309   bb.0 (%ir-block.0):
310     liveins: $r0, $r1
312     ; CHECK-LABEL: name: STR_post256
313     ; CHECK: liveins: $r0, $r1
314     ; CHECK: early-clobber $r0 = STR_POST_IMM killed $r1, $r0, $noreg, 256, 14 /* CC::al */, $noreg :: (store (s32))
315     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
316     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
317     renamable $r0 = nuw ADDri killed renamable $r0, 256, 14 /* CC::al */, $noreg, $noreg
318     BX_RET 14 /* CC::al */, $noreg, implicit $r0
322 name:            STR_post1024
323 alignment:       4
324 tracksRegLiveness: true
325 liveins:
326   - { reg: '$r0', virtual-reg: '' }
327   - { reg: '$r1', virtual-reg: '' }
328 body:             |
329   bb.0 (%ir-block.0):
330     liveins: $r0, $r1
332     ; CHECK-LABEL: name: STR_post1024
333     ; CHECK: liveins: $r0, $r1
334     ; CHECK: early-clobber $r0 = STR_POST_IMM killed $r1, $r0, $noreg, 1024, 14 /* CC::al */, $noreg :: (store (s32))
335     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
336     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
337     renamable $r0 = nuw ADDri killed renamable $r0, 1024, 14 /* CC::al */, $noreg, $noreg
338     BX_RET 14 /* CC::al */, $noreg, implicit $r0
342 name:            STR_post4095
343 alignment:       4
344 tracksRegLiveness: true
345 liveins:
346   - { reg: '$r0', virtual-reg: '' }
347   - { reg: '$r1', virtual-reg: '' }
348 body:             |
349   bb.0 (%ir-block.0):
350     liveins: $r0, $r1
352     ; CHECK-LABEL: name: STR_post4095
353     ; CHECK: liveins: $r0, $r1
354     ; CHECK: early-clobber $r0 = STR_POST_IMM killed $r1, $r0, $noreg, 2095, 14 /* CC::al */, $noreg :: (store (s32))
355     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
356     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
357     renamable $r0 = nuw ADDri killed renamable $r0, 2095, 14 /* CC::al */, $noreg, $noreg
358     BX_RET 14 /* CC::al */, $noreg, implicit $r0
362 name:            STR_post4096
363 alignment:       4
364 tracksRegLiveness: true
365 liveins:
366   - { reg: '$r0', virtual-reg: '' }
367   - { reg: '$r1', virtual-reg: '' }
368 body:             |
369   bb.0 (%ir-block.0):
370     liveins: $r0, $r1
372     ; CHECK-LABEL: name: STR_post4096
373     ; CHECK: liveins: $r0, $r1
374     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
375     ; CHECK: renamable $r0 = nuw ADDri killed renamable $r0, 4096, 14 /* CC::al */, $noreg, $noreg
376     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
377     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
378     renamable $r0 = nuw ADDri killed renamable $r0, 4096, 14 /* CC::al */, $noreg, $noreg
379     BX_RET 14 /* CC::al */, $noreg, implicit $r0
383 name:            STR_postm1024
384 alignment:       4
385 tracksRegLiveness: true
386 liveins:
387   - { reg: '$r0', virtual-reg: '' }
388   - { reg: '$r1', virtual-reg: '' }
389 body:             |
390   bb.0 (%ir-block.0):
391     liveins: $r0, $r1
393     ; CHECK-LABEL: name: STR_postm1024
394     ; CHECK: liveins: $r0, $r1
395     ; CHECK: early-clobber $r0 = STR_POST_IMM killed $r1, $r0, $noreg, 5120, 14 /* CC::al */, $noreg :: (store (s32))
396     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
397     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
398     renamable $r0 = nuw SUBri killed renamable $r0, 1024, 14 /* CC::al */, $noreg, $noreg
399     BX_RET 14 /* CC::al */, $noreg, implicit $r0
403 name:            STR_postm4095
404 alignment:       4
405 tracksRegLiveness: true
406 liveins:
407   - { reg: '$r0', virtual-reg: '' }
408   - { reg: '$r1', virtual-reg: '' }
409 body:             |
410   bb.0 (%ir-block.0):
411     liveins: $r0, $r1
413     ; CHECK-LABEL: name: STR_postm4095
414     ; CHECK: liveins: $r0, $r1
415     ; CHECK: early-clobber $r0 = STR_POST_IMM killed $r1, $r0, $noreg, 6191, 14 /* CC::al */, $noreg :: (store (s32))
416     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
417     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
418     renamable $r0 = nuw SUBri killed renamable $r0, 2095, 14 /* CC::al */, $noreg, $noreg
419     BX_RET 14 /* CC::al */, $noreg, implicit $r0
423 name:            STR_postm4096
424 alignment:       4
425 tracksRegLiveness: true
426 liveins:
427   - { reg: '$r0', virtual-reg: '' }
428   - { reg: '$r1', virtual-reg: '' }
429 body:             |
430   bb.0 (%ir-block.0):
431     liveins: $r0, $r1
433     ; CHECK-LABEL: name: STR_postm4096
434     ; CHECK: liveins: $r0, $r1
435     ; CHECK: STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
436     ; CHECK: renamable $r0 = nuw SUBri killed renamable $r0, 4096, 14 /* CC::al */, $noreg, $noreg
437     ; CHECK: BX_RET 14 /* CC::al */, $noreg, implicit $r0
438     STRi12 killed renamable $r1, renamable $r0, 0, 14 /* CC::al */, $noreg :: (store (s32))
439     renamable $r0 = nuw SUBri killed renamable $r0, 4096, 14 /* CC::al */, $noreg, $noreg
440     BX_RET 14 /* CC::al */, $noreg, implicit $r0