1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=riscv64 -run-pass=instruction-select %s -o - \
5 name: const_i64_INT_MIN
8 tracksRegLiveness: true
13 ; CHECK-LABEL: name: const_i64_INT_MIN
14 ; CHECK: liveins: $x10
16 ; CHECK-NEXT: [[ADDI:%[0-9]+]]:gpr = ADDI $x0, -1
17 ; CHECK-NEXT: [[SLLI:%[0-9]+]]:gpr = SLLI [[ADDI]], 63
18 ; CHECK-NEXT: $x10 = COPY [[SLLI]]
19 ; CHECK-NEXT: PseudoRET implicit $x10
20 %0:gprb(s64) = G_CONSTANT i64 -9223372036854775808
22 PseudoRET implicit $x10
26 name: const_i64_neg_9223372036854775000
29 tracksRegLiveness: true
34 ; CHECK-LABEL: name: const_i64_neg_9223372036854775000
35 ; CHECK: liveins: $x10
37 ; CHECK-NEXT: [[ADDI:%[0-9]+]]:gpr = ADDI $x0, -1
38 ; CHECK-NEXT: [[SLLI:%[0-9]+]]:gpr = SLLI [[ADDI]], 63
39 ; CHECK-NEXT: [[ADDI1:%[0-9]+]]:gpr = ADDI [[SLLI]], 808
40 ; CHECK-NEXT: $x10 = COPY [[ADDI1]]
41 ; CHECK-NEXT: PseudoRET implicit $x10
42 %0:gprb(s64) = G_CONSTANT i64 -9223372036854775000
44 PseudoRET implicit $x10
48 name: const_i64_INT_MAX
51 tracksRegLiveness: true
56 ; CHECK-LABEL: name: const_i64_INT_MAX
57 ; CHECK: liveins: $x10
59 ; CHECK-NEXT: [[ADDI:%[0-9]+]]:gpr = ADDI $x0, -1
60 ; CHECK-NEXT: [[SRLI:%[0-9]+]]:gpr = SRLI [[ADDI]], 1
61 ; CHECK-NEXT: $x10 = COPY [[SRLI]]
62 ; CHECK-NEXT: PseudoRET implicit $x10
63 %0:gprb(s64) = G_CONSTANT i64 9223372036854775807
65 PseudoRET implicit $x10
69 name: const_i64_9223372036854775000
72 tracksRegLiveness: true
77 ; CHECK-LABEL: name: const_i64_9223372036854775000
78 ; CHECK: liveins: $x10
80 ; CHECK-NEXT: [[ADDI:%[0-9]+]]:gpr = ADDI $x0, -1615
81 ; CHECK-NEXT: [[SRLI:%[0-9]+]]:gpr = SRLI [[ADDI]], 1
82 ; CHECK-NEXT: $x10 = COPY [[SRLI]]
83 ; CHECK-NEXT: PseudoRET implicit $x10
84 %0:gprb(s64) = G_CONSTANT i64 9223372036854775000
86 PseudoRET implicit $x10
93 tracksRegLiveness: true
98 ; CHECK-LABEL: name: const_i64_256
99 ; CHECK: liveins: $x10
101 ; CHECK-NEXT: [[ADDI:%[0-9]+]]:gpr = ADDI $x0, 256
102 ; CHECK-NEXT: $x10 = COPY [[ADDI]]
103 ; CHECK-NEXT: PseudoRET implicit $x10
104 %0:gprb(s64) = G_CONSTANT i64 256
106 PseudoRET implicit $x10
112 regBankSelected: true
113 tracksRegLiveness: true
118 ; CHECK-LABEL: name: const_i64_0
119 ; CHECK: liveins: $x10
121 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x0
122 ; CHECK-NEXT: $x10 = COPY [[COPY]]
123 ; CHECK-NEXT: PseudoRET implicit $x10
124 %0:gprb(s64) = G_CONSTANT i64 0
126 PseudoRET implicit $x10
130 name: const_i32_INT_MIN
132 regBankSelected: true
133 tracksRegLiveness: true
138 ; CHECK-LABEL: name: const_i32_INT_MIN
139 ; CHECK: liveins: $x10
141 ; CHECK-NEXT: [[LUI:%[0-9]+]]:gpr = LUI 524288
142 ; CHECK-NEXT: $x10 = COPY [[LUI]]
143 ; CHECK-NEXT: PseudoRET implicit $x10
144 %0:gprb(s32) = G_CONSTANT i32 -2147483648
145 %1:gprb(s64) = G_ANYEXT %0(s32)
147 PseudoRET implicit $x10
151 name: const_i32_neg_2147483000
153 regBankSelected: true
154 tracksRegLiveness: true
159 ; CHECK-LABEL: name: const_i32_neg_2147483000
160 ; CHECK: liveins: $x10
162 ; CHECK-NEXT: [[LUI:%[0-9]+]]:gpr = LUI 524288
163 ; CHECK-NEXT: [[ADDIW:%[0-9]+]]:gpr = ADDIW [[LUI]], 648
164 ; CHECK-NEXT: $x10 = COPY [[ADDIW]]
165 ; CHECK-NEXT: PseudoRET implicit $x10
166 %0:gprb(s32) = G_CONSTANT i32 -2147483000
167 %1:gprb(s64) = G_ANYEXT %0(s32)
169 PseudoRET implicit $x10
173 name: const_i32_INT_MAX
175 regBankSelected: true
176 tracksRegLiveness: true
181 ; CHECK-LABEL: name: const_i32_INT_MAX
182 ; CHECK: liveins: $x10
184 ; CHECK-NEXT: [[LUI:%[0-9]+]]:gpr = LUI 524288
185 ; CHECK-NEXT: $x10 = COPY [[LUI]]
186 ; CHECK-NEXT: PseudoRET implicit $x10
187 %0:gprb(s32) = G_CONSTANT i32 2147483648
188 %1:gprb(s64) = G_ANYEXT %0(s32)
190 PseudoRET implicit $x10
194 name: const_i32_2147483000
196 regBankSelected: true
197 tracksRegLiveness: true
202 ; CHECK-LABEL: name: const_i32_2147483000
203 ; CHECK: liveins: $x10
205 ; CHECK-NEXT: [[LUI:%[0-9]+]]:gpr = LUI 524288
206 ; CHECK-NEXT: [[ADDIW:%[0-9]+]]:gpr = ADDIW [[LUI]], -648
207 ; CHECK-NEXT: $x10 = COPY [[ADDIW]]
208 ; CHECK-NEXT: PseudoRET implicit $x10
209 %0:gprb(s32) = G_CONSTANT i32 2147483000
210 %1:gprb(s64) = G_ANYEXT %0(s32)
212 PseudoRET implicit $x10
218 regBankSelected: true
219 tracksRegLiveness: true
224 ; CHECK-LABEL: name: const_i32_256
225 ; CHECK: liveins: $x10
227 ; CHECK-NEXT: [[ADDI:%[0-9]+]]:gpr = ADDI $x0, 256
228 ; CHECK-NEXT: $x10 = COPY [[ADDI]]
229 ; CHECK-NEXT: PseudoRET implicit $x10
230 %0:gprb(s32) = G_CONSTANT i32 256
231 %1:gprb(s64) = G_ANYEXT %0(s32)
233 PseudoRET implicit $x10
239 regBankSelected: true
240 tracksRegLiveness: true
245 ; CHECK-LABEL: name: const_i32_0
246 ; CHECK: liveins: $x10
248 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x0
249 ; CHECK-NEXT: $x10 = COPY [[COPY]]
250 ; CHECK-NEXT: PseudoRET implicit $x10
251 %0:gprb(s32) = G_CONSTANT i32 0
252 %1:gprb(s64) = G_ANYEXT %0(s32)
254 PseudoRET implicit $x10