1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 3
2 # RUN: llc -mtriple=riscv64 -mattr='+zba' -run-pass=instruction-select -simplify-mir -verify-machineinstrs %s -o - \
9 tracksRegLiveness: true
14 ; CHECK-LABEL: name: sh1add
15 ; CHECK: liveins: $x10, $x11
17 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
18 ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x11
19 ; CHECK-NEXT: [[SH1ADD:%[0-9]+]]:gpr = SH1ADD [[COPY]], [[COPY1]]
20 ; CHECK-NEXT: $x10 = COPY [[SH1ADD]]
21 %0:gprb(s64) = COPY $x10
22 %1:gprb(s64) = COPY $x11
23 %2:gprb(s64) = G_CONSTANT i64 1
24 %3:gprb(s64) = G_SHL %0, %2
25 %4:gprb(s64) = G_ADD %3, %1
32 tracksRegLiveness: true
37 ; CHECK-LABEL: name: sh2add
38 ; CHECK: liveins: $x10, $x11
40 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
41 ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x11
42 ; CHECK-NEXT: [[SH2ADD:%[0-9]+]]:gpr = SH2ADD [[COPY]], [[COPY1]]
43 ; CHECK-NEXT: $x10 = COPY [[SH2ADD]]
44 %0:gprb(s64) = COPY $x10
45 %1:gprb(s64) = COPY $x11
46 %2:gprb(s64) = G_CONSTANT i64 2
47 %3:gprb(s64) = G_SHL %0, %2
48 %4:gprb(s64) = G_ADD %3, %1
55 tracksRegLiveness: true
60 ; CHECK-LABEL: name: sh3add
61 ; CHECK: liveins: $x10, $x11
63 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
64 ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x11
65 ; CHECK-NEXT: [[SH3ADD:%[0-9]+]]:gpr = SH3ADD [[COPY]], [[COPY1]]
66 ; CHECK-NEXT: $x10 = COPY [[SH3ADD]]
67 %0:gprb(s64) = COPY $x10
68 %1:gprb(s64) = COPY $x11
69 %2:gprb(s64) = G_CONSTANT i64 3
70 %3:gprb(s64) = G_SHL %0, %2
71 %4:gprb(s64) = G_ADD %3, %1
78 tracksRegLiveness: true
83 ; CHECK-LABEL: name: no_sh1add
84 ; CHECK: liveins: $x10, $x11
86 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
87 ; CHECK-NEXT: [[SLLI:%[0-9]+]]:gpr = SLLI [[COPY]], 1
88 ; CHECK-NEXT: [[ADDI:%[0-9]+]]:gpr = ADDI [[SLLI]], 37
89 ; CHECK-NEXT: $x10 = COPY [[ADDI]]
90 %0:gprb(s64) = COPY $x10
91 %1:gprb(s64) = G_CONSTANT i64 37
92 %2:gprb(s64) = G_CONSTANT i64 1
93 %3:gprb(s64) = G_SHL %0, %2
94 %4:gprb(s64) = G_ADD %3, %1
98 name: shXadd_complex_and_shl
100 regBankSelected: true
101 tracksRegLiveness: true
106 ; CHECK-LABEL: name: shXadd_complex_and_shl
107 ; CHECK: liveins: $x10, $x11
109 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
110 ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x11
111 ; CHECK-NEXT: [[SRLIW:%[0-9]+]]:gpr = SRLIW [[COPY]], 1
112 ; CHECK-NEXT: [[SH3ADD:%[0-9]+]]:gpr = SH3ADD [[SRLIW]], [[COPY1]]
113 ; CHECK-NEXT: $x10 = COPY [[SH3ADD]]
114 %0:gprb(s64) = COPY $x10
115 %1:gprb(s64) = COPY $x11
117 %2:gprb(s64) = G_CONSTANT i64 4294967294
118 %3:gprb(s64) = G_AND %0, %2
119 %4:gprb(s64) = G_CONSTANT i64 2
120 %5:gprb(s64) = G_SHL %3, %4
122 %6:gprb(s64) = G_ADD %5, %1
126 name: shXadd_complex_and_lshr
128 regBankSelected: true
129 tracksRegLiveness: true
134 ; CHECK-LABEL: name: shXadd_complex_and_lshr
135 ; CHECK: liveins: $x10, $x11
137 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
138 ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x11
139 ; CHECK-NEXT: [[SRLIW:%[0-9]+]]:gpr = SRLIW [[COPY]], 2
140 ; CHECK-NEXT: [[SH1ADD:%[0-9]+]]:gpr = SH1ADD [[SRLIW]], [[COPY1]]
141 ; CHECK-NEXT: $x10 = COPY [[SH1ADD]]
142 %0:gprb(s64) = COPY $x10
143 %1:gprb(s64) = COPY $x11
145 %2:gprb(s64) = G_CONSTANT i64 4294967292
146 %3:gprb(s64) = G_AND %0, %2
147 %4:gprb(s64) = G_CONSTANT i64 1
148 %5:gprb(s64) = G_LSHR %3, %4
150 %6:gprb(s64) = G_ADD %5, %1
154 name: shXadd_uw_complex_shl_and
156 regBankSelected: true
157 tracksRegLiveness: true
162 ; CHECK-LABEL: name: shXadd_uw_complex_shl_and
163 ; CHECK: liveins: $x10, $x11
165 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
166 ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x11
167 ; CHECK-NEXT: [[SLLI:%[0-9]+]]:gpr = SLLI [[COPY]], 1
168 ; CHECK-NEXT: [[SH2ADD_UW:%[0-9]+]]:gpr = SH2ADD_UW [[SLLI]], [[COPY1]]
169 ; CHECK-NEXT: $x10 = COPY [[SH2ADD_UW]]
170 %0:gprb(s64) = COPY $x10
171 %1:gprb(s64) = COPY $x11
173 %2:gprb(s64) = G_CONSTANT i64 3
174 %3:gprb(s64) = G_SHL %0, %2
175 %4:gprb(s64) = G_CONSTANT i64 17179869183
176 %5:gprb(s64) = G_AND %3, %4
178 %6:gprb(s64) = G_ADD %5, %1
184 regBankSelected: true
185 tracksRegLiveness: true
190 ; CHECK-LABEL: name: slli_uw
191 ; CHECK: liveins: $x10
193 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
194 ; CHECK-NEXT: [[SLLI_UW:%[0-9]+]]:gpr = SLLI_UW [[COPY]], 7
195 ; CHECK-NEXT: $x10 = COPY [[SLLI_UW]]
196 %0:gprb(s64) = COPY $x10
198 %1:gprb(s64) = G_CONSTANT i64 4294967295
199 %2:gprb(s64) = G_AND %0, %1
200 %3:gprb(s64) = G_CONSTANT i64 7
201 %4:gprb(s64) = G_SHL %2, %3
208 regBankSelected: true
209 tracksRegLiveness: true
214 ; CHECK-LABEL: name: slli_uw_s32
215 ; CHECK: liveins: $x10
217 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
218 ; CHECK-NEXT: [[SLLI_UW:%[0-9]+]]:gpr = SLLI_UW [[COPY]], 7
219 ; CHECK-NEXT: $x10 = COPY [[SLLI_UW]]
220 %0:gprb(s64) = COPY $x10
221 %1:gprb(s32) = G_TRUNC %0(s64)
223 %2:gprb(s64) = G_ZEXT %1(s32)
224 %3:gprb(s64) = G_CONSTANT i64 7
225 %4:gprb(s64) = G_SHL %2, %3
230 name: slli_uw_complex
232 regBankSelected: true
233 tracksRegLiveness: true
238 ; CHECK-LABEL: name: slli_uw_complex
239 ; CHECK: liveins: $x10
241 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
242 ; CHECK-NEXT: [[SRLI:%[0-9]+]]:gpr = SRLI [[COPY]], 2
243 ; CHECK-NEXT: [[SLLI_UW:%[0-9]+]]:gpr = SLLI_UW [[SRLI]], 2
244 ; CHECK-NEXT: $x10 = COPY [[SLLI_UW]]
245 %0:gprb(s64) = COPY $x10
247 %1:gprb(s64) = G_CONSTANT i64 17179869180
248 %2:gprb(s64) = G_AND %0, %1
255 regBankSelected: true
256 tracksRegLiveness: true
261 ; CHECK-LABEL: name: sh1add_s32
262 ; CHECK: liveins: $x10, $x11
264 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
265 ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x11
266 ; CHECK-NEXT: [[SH1ADD:%[0-9]+]]:gpr = SH1ADD [[COPY]], [[COPY1]]
267 ; CHECK-NEXT: $x10 = COPY [[SH1ADD]]
268 %0:gprb(s64) = COPY $x10
269 %1:gprb(s64) = COPY $x11
270 %2:gprb(s32) = G_TRUNC %0
271 %3:gprb(s32) = G_TRUNC %1
272 %4:gprb(s64) = G_CONSTANT i64 1
273 %5:gprb(s32) = G_SHL %2, %4
274 %6:gprb(s32) = G_ADD %5, %3
275 %7:gprb(s64) = G_ANYEXT %6
281 regBankSelected: true
282 tracksRegLiveness: true
287 ; CHECK-LABEL: name: sh2add_s32
288 ; CHECK: liveins: $x10, $x11
290 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
291 ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x11
292 ; CHECK-NEXT: [[SH2ADD:%[0-9]+]]:gpr = SH2ADD [[COPY]], [[COPY1]]
293 ; CHECK-NEXT: $x10 = COPY [[SH2ADD]]
294 %0:gprb(s64) = COPY $x10
295 %1:gprb(s64) = COPY $x11
296 %2:gprb(s32) = G_TRUNC %0
297 %3:gprb(s32) = G_TRUNC %1
298 %4:gprb(s64) = G_CONSTANT i64 2
299 %5:gprb(s32) = G_SHL %2, %4
300 %6:gprb(s32) = G_ADD %5, %3
301 %7:gprb(s64) = G_ANYEXT %6
307 regBankSelected: true
308 tracksRegLiveness: true
313 ; CHECK-LABEL: name: sh3add_s32
314 ; CHECK: liveins: $x10, $x11
316 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
317 ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x11
318 ; CHECK-NEXT: [[SH3ADD:%[0-9]+]]:gpr = SH3ADD [[COPY]], [[COPY1]]
319 ; CHECK-NEXT: $x10 = COPY [[SH3ADD]]
320 %0:gprb(s64) = COPY $x10
321 %1:gprb(s64) = COPY $x11
322 %2:gprb(s32) = G_TRUNC %0
323 %3:gprb(s32) = G_TRUNC %1
324 %4:gprb(s64) = G_CONSTANT i64 3
325 %5:gprb(s32) = G_SHL %2, %4
326 %6:gprb(s32) = G_ADD %5, %3
327 %7:gprb(s64) = G_ANYEXT %6
333 regBankSelected: true
334 tracksRegLiveness: true
339 ; CHECK-LABEL: name: adduw
340 ; CHECK: liveins: $x10, $x11
342 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10
343 ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x11
344 ; CHECK-NEXT: [[ADD_UW:%[0-9]+]]:gpr = ADD_UW [[COPY]], [[COPY1]]
345 ; CHECK-NEXT: $x10 = COPY [[ADD_UW]]
346 %0:gprb(s64) = COPY $x10
347 %1:gprb(s64) = COPY $x11
348 %2:gprb(s32) = G_TRUNC %0
349 %3:gprb(s64) = G_ZEXT %2
350 %4:gprb(s64) = G_ADD %3, %1