xref: /llvm-project/llvm/test/CodeGen/RISCV/zcmp-cm-push-pop.mir (revision a0b049055df592759e4ac1d8032139f385581c63)
1# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 4
2# RUN: llc -mtriple=riscv32 -mattr=+zcmp -x mir -run-pass=prologepilog -verify-machineinstrs -o - %s \
3# RUN: | FileCheck -check-prefixes=CHECK-ZCMP32 %s
4# RUN: llc -mtriple=riscv32 -mattr=+save-restore -x mir -run-pass=prologepilog -verify-machineinstrs -o - %s \
5# RUN: | FileCheck -check-prefixes=CHECK-LIBCALL32 %s
6# RUN: llc -mtriple=riscv64 -mattr=+zcmp -x mir -run-pass=prologepilog -verify-machineinstrs -o - %s \
7# RUN: | FileCheck -check-prefixes=CHECK-ZCMP64 %s
8# RUN: llc -mtriple=riscv64 -mattr=+save-restore -x mir -run-pass=prologepilog -verify-machineinstrs -o - %s \
9# RUN: | FileCheck -check-prefixes=CHECK-LIBCALL64 %s
10# RUN: llc -mtriple=riscv32 -x mir -run-pass=prologepilog -verify-machineinstrs -o - %s \
11# RUN: | FileCheck -check-prefixes=CHECK-NO-ZCMP32 %s
12# RUN: llc -mtriple=riscv64 -x mir -run-pass=prologepilog -verify-machineinstrs -o - %s \
13# RUN: | FileCheck -check-prefixes=CHECK-NO-ZCMP64 %s
14---
15name: push_rvlist15
16tracksRegLiveness: true
17body:                   |
18  bb.0:
19    ; CHECK-ZCMP32-LABEL: name: push_rvlist15
20    ; CHECK-ZCMP32: liveins: $x1, $x8, $x9, $x18, $x19, $x20, $x21, $x22, $x23, $x24, $x25, $x26, $x27
21    ; CHECK-ZCMP32-NEXT: {{  $}}
22    ; CHECK-ZCMP32-NEXT: frame-setup CM_PUSH 15, 0, implicit-def $x2, implicit $x2, implicit $x1, implicit $x8, implicit $x9, implicit $x18, implicit $x19, implicit $x20, implicit $x21, implicit $x22, implicit $x23, implicit $x24, implicit $x25, implicit $x26, implicit $x27
23    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION def_cfa_offset 64
24    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x1, -52
25    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x8, -48
26    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x9, -44
27    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x18, -40
28    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x19, -36
29    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x20, -32
30    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x21, -28
31    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x22, -24
32    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x23, -20
33    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x24, -16
34    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x25, -12
35    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x26, -8
36    ; CHECK-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x27, -4
37    ; CHECK-ZCMP32-NEXT: $x1 = IMPLICIT_DEF
38    ; CHECK-ZCMP32-NEXT: $x8 = IMPLICIT_DEF
39    ; CHECK-ZCMP32-NEXT: $x9 = IMPLICIT_DEF
40    ; CHECK-ZCMP32-NEXT: $x18 = IMPLICIT_DEF
41    ; CHECK-ZCMP32-NEXT: $x19 = IMPLICIT_DEF
42    ; CHECK-ZCMP32-NEXT: $x20 = IMPLICIT_DEF
43    ; CHECK-ZCMP32-NEXT: $x21 = IMPLICIT_DEF
44    ; CHECK-ZCMP32-NEXT: $x22 = IMPLICIT_DEF
45    ; CHECK-ZCMP32-NEXT: $x23 = IMPLICIT_DEF
46    ; CHECK-ZCMP32-NEXT: $x24 = IMPLICIT_DEF
47    ; CHECK-ZCMP32-NEXT: $x25 = IMPLICIT_DEF
48    ; CHECK-ZCMP32-NEXT: $x26 = IMPLICIT_DEF
49    ; CHECK-ZCMP32-NEXT: $x27 = IMPLICIT_DEF
50    ; CHECK-ZCMP32-NEXT: frame-destroy CM_POP 15, 0, implicit-def $x2, implicit $x2, implicit-def $x1, implicit-def $x8, implicit-def $x9, implicit-def $x18, implicit-def $x19, implicit-def $x20, implicit-def $x21, implicit-def $x22, implicit-def $x23, implicit-def $x24, implicit-def $x25, implicit-def $x26, implicit-def $x27
51    ; CHECK-ZCMP32-NEXT: PseudoRET
52    ;
53    ; CHECK-LIBCALL32-LABEL: name: push_rvlist15
54    ; CHECK-LIBCALL32: liveins: $x1, $x8, $x9, $x18, $x19, $x20, $x21, $x22, $x23, $x24, $x25, $x26, $x27
55    ; CHECK-LIBCALL32-NEXT: {{  $}}
56    ; CHECK-LIBCALL32-NEXT: $x5 = frame-setup PseudoCALLReg target-flags(riscv-call) &__riscv_save_12
57    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION def_cfa_offset 64
58    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x1, -4
59    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x8, -8
60    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x9, -12
61    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x18, -16
62    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x19, -20
63    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x20, -24
64    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x21, -28
65    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x22, -32
66    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x23, -36
67    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x24, -40
68    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x25, -44
69    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x26, -48
70    ; CHECK-LIBCALL32-NEXT: frame-setup CFI_INSTRUCTION offset $x27, -52
71    ; CHECK-LIBCALL32-NEXT: $x1 = IMPLICIT_DEF
72    ; CHECK-LIBCALL32-NEXT: $x8 = IMPLICIT_DEF
73    ; CHECK-LIBCALL32-NEXT: $x9 = IMPLICIT_DEF
74    ; CHECK-LIBCALL32-NEXT: $x18 = IMPLICIT_DEF
75    ; CHECK-LIBCALL32-NEXT: $x19 = IMPLICIT_DEF
76    ; CHECK-LIBCALL32-NEXT: $x20 = IMPLICIT_DEF
77    ; CHECK-LIBCALL32-NEXT: $x21 = IMPLICIT_DEF
78    ; CHECK-LIBCALL32-NEXT: $x22 = IMPLICIT_DEF
79    ; CHECK-LIBCALL32-NEXT: $x23 = IMPLICIT_DEF
80    ; CHECK-LIBCALL32-NEXT: $x24 = IMPLICIT_DEF
81    ; CHECK-LIBCALL32-NEXT: $x25 = IMPLICIT_DEF
82    ; CHECK-LIBCALL32-NEXT: $x26 = IMPLICIT_DEF
83    ; CHECK-LIBCALL32-NEXT: $x27 = IMPLICIT_DEF
84    ; CHECK-LIBCALL32-NEXT: frame-destroy PseudoTAIL target-flags(riscv-call) &__riscv_restore_12, implicit $x2
85    ;
86    ; CHECK-ZCMP64-LABEL: name: push_rvlist15
87    ; CHECK-ZCMP64: liveins: $x1, $x8, $x9, $x18, $x19, $x20, $x21, $x22, $x23, $x24, $x25, $x26, $x27
88    ; CHECK-ZCMP64-NEXT: {{  $}}
89    ; CHECK-ZCMP64-NEXT: frame-setup CM_PUSH 15, 0, implicit-def $x2, implicit $x2, implicit $x1, implicit $x8, implicit $x9, implicit $x18, implicit $x19, implicit $x20, implicit $x21, implicit $x22, implicit $x23, implicit $x24, implicit $x25, implicit $x26, implicit $x27
90    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION def_cfa_offset 112
91    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x1, -104
92    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x8, -96
93    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x9, -88
94    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x18, -80
95    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x19, -72
96    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x20, -64
97    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x21, -56
98    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x22, -48
99    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x23, -40
100    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x24, -32
101    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x25, -24
102    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x26, -16
103    ; CHECK-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x27, -8
104    ; CHECK-ZCMP64-NEXT: $x1 = IMPLICIT_DEF
105    ; CHECK-ZCMP64-NEXT: $x8 = IMPLICIT_DEF
106    ; CHECK-ZCMP64-NEXT: $x9 = IMPLICIT_DEF
107    ; CHECK-ZCMP64-NEXT: $x18 = IMPLICIT_DEF
108    ; CHECK-ZCMP64-NEXT: $x19 = IMPLICIT_DEF
109    ; CHECK-ZCMP64-NEXT: $x20 = IMPLICIT_DEF
110    ; CHECK-ZCMP64-NEXT: $x21 = IMPLICIT_DEF
111    ; CHECK-ZCMP64-NEXT: $x22 = IMPLICIT_DEF
112    ; CHECK-ZCMP64-NEXT: $x23 = IMPLICIT_DEF
113    ; CHECK-ZCMP64-NEXT: $x24 = IMPLICIT_DEF
114    ; CHECK-ZCMP64-NEXT: $x25 = IMPLICIT_DEF
115    ; CHECK-ZCMP64-NEXT: $x26 = IMPLICIT_DEF
116    ; CHECK-ZCMP64-NEXT: $x27 = IMPLICIT_DEF
117    ; CHECK-ZCMP64-NEXT: frame-destroy CM_POP 15, 0, implicit-def $x2, implicit $x2, implicit-def $x1, implicit-def $x8, implicit-def $x9, implicit-def $x18, implicit-def $x19, implicit-def $x20, implicit-def $x21, implicit-def $x22, implicit-def $x23, implicit-def $x24, implicit-def $x25, implicit-def $x26, implicit-def $x27
118    ; CHECK-ZCMP64-NEXT: PseudoRET
119    ;
120    ; CHECK-LIBCALL64-LABEL: name: push_rvlist15
121    ; CHECK-LIBCALL64: liveins: $x1, $x8, $x9, $x18, $x19, $x20, $x21, $x22, $x23, $x24, $x25, $x26, $x27
122    ; CHECK-LIBCALL64-NEXT: {{  $}}
123    ; CHECK-LIBCALL64-NEXT: $x5 = frame-setup PseudoCALLReg target-flags(riscv-call) &__riscv_save_12
124    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION def_cfa_offset 112
125    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x1, -8
126    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x8, -16
127    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x9, -24
128    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x18, -32
129    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x19, -40
130    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x20, -48
131    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x21, -56
132    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x22, -64
133    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x23, -72
134    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x24, -80
135    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x25, -88
136    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x26, -96
137    ; CHECK-LIBCALL64-NEXT: frame-setup CFI_INSTRUCTION offset $x27, -104
138    ; CHECK-LIBCALL64-NEXT: $x1 = IMPLICIT_DEF
139    ; CHECK-LIBCALL64-NEXT: $x8 = IMPLICIT_DEF
140    ; CHECK-LIBCALL64-NEXT: $x9 = IMPLICIT_DEF
141    ; CHECK-LIBCALL64-NEXT: $x18 = IMPLICIT_DEF
142    ; CHECK-LIBCALL64-NEXT: $x19 = IMPLICIT_DEF
143    ; CHECK-LIBCALL64-NEXT: $x20 = IMPLICIT_DEF
144    ; CHECK-LIBCALL64-NEXT: $x21 = IMPLICIT_DEF
145    ; CHECK-LIBCALL64-NEXT: $x22 = IMPLICIT_DEF
146    ; CHECK-LIBCALL64-NEXT: $x23 = IMPLICIT_DEF
147    ; CHECK-LIBCALL64-NEXT: $x24 = IMPLICIT_DEF
148    ; CHECK-LIBCALL64-NEXT: $x25 = IMPLICIT_DEF
149    ; CHECK-LIBCALL64-NEXT: $x26 = IMPLICIT_DEF
150    ; CHECK-LIBCALL64-NEXT: $x27 = IMPLICIT_DEF
151    ; CHECK-LIBCALL64-NEXT: frame-destroy PseudoTAIL target-flags(riscv-call) &__riscv_restore_12, implicit $x2
152    ;
153    ; CHECK-NO-ZCMP32-LABEL: name: push_rvlist15
154    ; CHECK-NO-ZCMP32: liveins: $x1, $x8, $x9, $x18, $x19, $x20, $x21, $x22, $x23, $x24, $x25, $x26, $x27
155    ; CHECK-NO-ZCMP32-NEXT: {{  $}}
156    ; CHECK-NO-ZCMP32-NEXT: $x2 = frame-setup ADDI $x2, -64
157    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION def_cfa_offset 64
158    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x1, $x2, 60 :: (store (s32) into %stack.0)
159    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x8, $x2, 56 :: (store (s32) into %stack.1)
160    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x9, $x2, 52 :: (store (s32) into %stack.2)
161    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x18, $x2, 48 :: (store (s32) into %stack.3)
162    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x19, $x2, 44 :: (store (s32) into %stack.4)
163    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x20, $x2, 40 :: (store (s32) into %stack.5)
164    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x21, $x2, 36 :: (store (s32) into %stack.6)
165    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x22, $x2, 32 :: (store (s32) into %stack.7)
166    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x23, $x2, 28 :: (store (s32) into %stack.8)
167    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x24, $x2, 24 :: (store (s32) into %stack.9)
168    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x25, $x2, 20 :: (store (s32) into %stack.10)
169    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x26, $x2, 16 :: (store (s32) into %stack.11)
170    ; CHECK-NO-ZCMP32-NEXT: frame-setup SW killed $x27, $x2, 12 :: (store (s32) into %stack.12)
171    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x1, -4
172    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x8, -8
173    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x9, -12
174    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x18, -16
175    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x19, -20
176    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x20, -24
177    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x21, -28
178    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x22, -32
179    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x23, -36
180    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x24, -40
181    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x25, -44
182    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x26, -48
183    ; CHECK-NO-ZCMP32-NEXT: frame-setup CFI_INSTRUCTION offset $x27, -52
184    ; CHECK-NO-ZCMP32-NEXT: $x1 = IMPLICIT_DEF
185    ; CHECK-NO-ZCMP32-NEXT: $x8 = IMPLICIT_DEF
186    ; CHECK-NO-ZCMP32-NEXT: $x9 = IMPLICIT_DEF
187    ; CHECK-NO-ZCMP32-NEXT: $x18 = IMPLICIT_DEF
188    ; CHECK-NO-ZCMP32-NEXT: $x19 = IMPLICIT_DEF
189    ; CHECK-NO-ZCMP32-NEXT: $x20 = IMPLICIT_DEF
190    ; CHECK-NO-ZCMP32-NEXT: $x21 = IMPLICIT_DEF
191    ; CHECK-NO-ZCMP32-NEXT: $x22 = IMPLICIT_DEF
192    ; CHECK-NO-ZCMP32-NEXT: $x23 = IMPLICIT_DEF
193    ; CHECK-NO-ZCMP32-NEXT: $x24 = IMPLICIT_DEF
194    ; CHECK-NO-ZCMP32-NEXT: $x25 = IMPLICIT_DEF
195    ; CHECK-NO-ZCMP32-NEXT: $x26 = IMPLICIT_DEF
196    ; CHECK-NO-ZCMP32-NEXT: $x27 = IMPLICIT_DEF
197    ; CHECK-NO-ZCMP32-NEXT: $x1 = frame-destroy LW $x2, 60 :: (load (s32) from %stack.0)
198    ; CHECK-NO-ZCMP32-NEXT: $x8 = frame-destroy LW $x2, 56 :: (load (s32) from %stack.1)
199    ; CHECK-NO-ZCMP32-NEXT: $x9 = frame-destroy LW $x2, 52 :: (load (s32) from %stack.2)
200    ; CHECK-NO-ZCMP32-NEXT: $x18 = frame-destroy LW $x2, 48 :: (load (s32) from %stack.3)
201    ; CHECK-NO-ZCMP32-NEXT: $x19 = frame-destroy LW $x2, 44 :: (load (s32) from %stack.4)
202    ; CHECK-NO-ZCMP32-NEXT: $x20 = frame-destroy LW $x2, 40 :: (load (s32) from %stack.5)
203    ; CHECK-NO-ZCMP32-NEXT: $x21 = frame-destroy LW $x2, 36 :: (load (s32) from %stack.6)
204    ; CHECK-NO-ZCMP32-NEXT: $x22 = frame-destroy LW $x2, 32 :: (load (s32) from %stack.7)
205    ; CHECK-NO-ZCMP32-NEXT: $x23 = frame-destroy LW $x2, 28 :: (load (s32) from %stack.8)
206    ; CHECK-NO-ZCMP32-NEXT: $x24 = frame-destroy LW $x2, 24 :: (load (s32) from %stack.9)
207    ; CHECK-NO-ZCMP32-NEXT: $x25 = frame-destroy LW $x2, 20 :: (load (s32) from %stack.10)
208    ; CHECK-NO-ZCMP32-NEXT: $x26 = frame-destroy LW $x2, 16 :: (load (s32) from %stack.11)
209    ; CHECK-NO-ZCMP32-NEXT: $x27 = frame-destroy LW $x2, 12 :: (load (s32) from %stack.12)
210    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x1
211    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x8
212    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x9
213    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x18
214    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x19
215    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x20
216    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x21
217    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x22
218    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x23
219    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x24
220    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x25
221    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x26
222    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION restore $x27
223    ; CHECK-NO-ZCMP32-NEXT: $x2 = frame-destroy ADDI $x2, 64
224    ; CHECK-NO-ZCMP32-NEXT: frame-destroy CFI_INSTRUCTION def_cfa_offset 0
225    ; CHECK-NO-ZCMP32-NEXT: PseudoRET
226    ;
227    ; CHECK-NO-ZCMP64-LABEL: name: push_rvlist15
228    ; CHECK-NO-ZCMP64: liveins: $x1, $x8, $x9, $x18, $x19, $x20, $x21, $x22, $x23, $x24, $x25, $x26, $x27
229    ; CHECK-NO-ZCMP64-NEXT: {{  $}}
230    ; CHECK-NO-ZCMP64-NEXT: $x2 = frame-setup ADDI $x2, -112
231    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION def_cfa_offset 112
232    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x1, $x2, 104 :: (store (s64) into %stack.0)
233    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x8, $x2, 96 :: (store (s64) into %stack.1)
234    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x9, $x2, 88 :: (store (s64) into %stack.2)
235    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x18, $x2, 80 :: (store (s64) into %stack.3)
236    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x19, $x2, 72 :: (store (s64) into %stack.4)
237    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x20, $x2, 64 :: (store (s64) into %stack.5)
238    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x21, $x2, 56 :: (store (s64) into %stack.6)
239    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x22, $x2, 48 :: (store (s64) into %stack.7)
240    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x23, $x2, 40 :: (store (s64) into %stack.8)
241    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x24, $x2, 32 :: (store (s64) into %stack.9)
242    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x25, $x2, 24 :: (store (s64) into %stack.10)
243    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x26, $x2, 16 :: (store (s64) into %stack.11)
244    ; CHECK-NO-ZCMP64-NEXT: frame-setup SD killed $x27, $x2, 8 :: (store (s64) into %stack.12)
245    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x1, -8
246    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x8, -16
247    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x9, -24
248    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x18, -32
249    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x19, -40
250    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x20, -48
251    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x21, -56
252    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x22, -64
253    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x23, -72
254    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x24, -80
255    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x25, -88
256    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x26, -96
257    ; CHECK-NO-ZCMP64-NEXT: frame-setup CFI_INSTRUCTION offset $x27, -104
258    ; CHECK-NO-ZCMP64-NEXT: $x1 = IMPLICIT_DEF
259    ; CHECK-NO-ZCMP64-NEXT: $x8 = IMPLICIT_DEF
260    ; CHECK-NO-ZCMP64-NEXT: $x9 = IMPLICIT_DEF
261    ; CHECK-NO-ZCMP64-NEXT: $x18 = IMPLICIT_DEF
262    ; CHECK-NO-ZCMP64-NEXT: $x19 = IMPLICIT_DEF
263    ; CHECK-NO-ZCMP64-NEXT: $x20 = IMPLICIT_DEF
264    ; CHECK-NO-ZCMP64-NEXT: $x21 = IMPLICIT_DEF
265    ; CHECK-NO-ZCMP64-NEXT: $x22 = IMPLICIT_DEF
266    ; CHECK-NO-ZCMP64-NEXT: $x23 = IMPLICIT_DEF
267    ; CHECK-NO-ZCMP64-NEXT: $x24 = IMPLICIT_DEF
268    ; CHECK-NO-ZCMP64-NEXT: $x25 = IMPLICIT_DEF
269    ; CHECK-NO-ZCMP64-NEXT: $x26 = IMPLICIT_DEF
270    ; CHECK-NO-ZCMP64-NEXT: $x27 = IMPLICIT_DEF
271    ; CHECK-NO-ZCMP64-NEXT: $x1 = frame-destroy LD $x2, 104 :: (load (s64) from %stack.0)
272    ; CHECK-NO-ZCMP64-NEXT: $x8 = frame-destroy LD $x2, 96 :: (load (s64) from %stack.1)
273    ; CHECK-NO-ZCMP64-NEXT: $x9 = frame-destroy LD $x2, 88 :: (load (s64) from %stack.2)
274    ; CHECK-NO-ZCMP64-NEXT: $x18 = frame-destroy LD $x2, 80 :: (load (s64) from %stack.3)
275    ; CHECK-NO-ZCMP64-NEXT: $x19 = frame-destroy LD $x2, 72 :: (load (s64) from %stack.4)
276    ; CHECK-NO-ZCMP64-NEXT: $x20 = frame-destroy LD $x2, 64 :: (load (s64) from %stack.5)
277    ; CHECK-NO-ZCMP64-NEXT: $x21 = frame-destroy LD $x2, 56 :: (load (s64) from %stack.6)
278    ; CHECK-NO-ZCMP64-NEXT: $x22 = frame-destroy LD $x2, 48 :: (load (s64) from %stack.7)
279    ; CHECK-NO-ZCMP64-NEXT: $x23 = frame-destroy LD $x2, 40 :: (load (s64) from %stack.8)
280    ; CHECK-NO-ZCMP64-NEXT: $x24 = frame-destroy LD $x2, 32 :: (load (s64) from %stack.9)
281    ; CHECK-NO-ZCMP64-NEXT: $x25 = frame-destroy LD $x2, 24 :: (load (s64) from %stack.10)
282    ; CHECK-NO-ZCMP64-NEXT: $x26 = frame-destroy LD $x2, 16 :: (load (s64) from %stack.11)
283    ; CHECK-NO-ZCMP64-NEXT: $x27 = frame-destroy LD $x2, 8 :: (load (s64) from %stack.12)
284    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x1
285    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x8
286    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x9
287    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x18
288    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x19
289    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x20
290    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x21
291    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x22
292    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x23
293    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x24
294    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x25
295    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x26
296    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION restore $x27
297    ; CHECK-NO-ZCMP64-NEXT: $x2 = frame-destroy ADDI $x2, 112
298    ; CHECK-NO-ZCMP64-NEXT: frame-destroy CFI_INSTRUCTION def_cfa_offset 0
299    ; CHECK-NO-ZCMP64-NEXT: PseudoRET
300    $x1 = IMPLICIT_DEF
301    $x8 = IMPLICIT_DEF
302    $x9 = IMPLICIT_DEF
303    $x18 = IMPLICIT_DEF
304    $x19 = IMPLICIT_DEF
305    $x20 = IMPLICIT_DEF
306    $x21 = IMPLICIT_DEF
307    $x22 = IMPLICIT_DEF
308    $x23 = IMPLICIT_DEF
309    $x24 = IMPLICIT_DEF
310    $x25 = IMPLICIT_DEF
311    $x26 = IMPLICIT_DEF
312    $x27 = IMPLICIT_DEF
313    PseudoRET
314...
315