1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -O0 -mtriple=aarch64-apple-ios -run-pass=regbankselect -verify-machineinstrs %s -o - | FileCheck %s -check-prefix=CHECK
5 target datalayout = "e-m:o-i64:64-i128:128-n32:64-S128"
7 @var_fp = global float 0.0
8 @var_int = global i32 0
10 define float @fp_load_phi() { ret float undef }
11 define i32 @int_load_phi_gpr() { ret i32 undef }
12 define i32 @int_load_phi_fpr() { ret i32 undef }
15 @array_double = dso_local global [32000 x double] zeroinitializer, align 8
16 @struct_array_double = dso_local global { [32000 x double] } zeroinitializer, align 8
17 @struct_struct_array_double = dso_local global {{ [32000 x double] }} zeroinitializer, align 8
19 define float @array_load_double() { ret float undef }
20 define float @struct_array_load_double() { ret float undef }
21 define float @struct_struct_array_load_double() { ret float undef }
23 @array_int = dso_local global [32000 x i32] zeroinitializer, align 8
24 @struct_array_int = dso_local global { [32000 x i32] } zeroinitializer, align 8
25 @struct_struct_array_int = dso_local global {{ [32000 x i32] }} zeroinitializer, align 8
27 define i32 @array_load_int_gpr() { ret i32 undef }
28 define i32 @array_load_int_fpr() { ret i32 undef }
29 define i32 @struct_array_load_int_gpr() { ret i32 undef }
30 define i32 @struct_array_load_int_fpr() { ret i32 undef }
31 define i32 @struct_struct_array_load_int_gpr() { ret i32 undef }
32 define i32 @struct_struct_array_load_int_fpr() { ret i32 undef }
38 regBankSelected: false
39 tracksRegLiveness: true
41 ; CHECK-LABEL: name: fp_load_phi
43 ; CHECK-NEXT: successors: %bb.1(0x80000000)
44 ; CHECK-NEXT: liveins: $w0
46 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
47 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @var_fp
48 ; CHECK-NEXT: %fp_load:fpr(s32) = G_LOAD [[GV]](p0) :: (load (s32) from @var_fp)
51 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
53 ; CHECK-NEXT: [[PHI:%[0-9]+]]:fpr(s32) = PHI %fp_load(s32), %bb.0, [[PHI]](s32), %bb.1
54 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
57 ; CHECK-NEXT: $s0 = COPY [[PHI]](s32)
58 ; CHECK-NEXT: RET_ReallyLR implicit $s0
63 %1:_(p0) = G_GLOBAL_VALUE @var_fp
64 %fp_load:_(s32) = G_LOAD %1 :: (load 4 from @var_fp)
67 successors: %bb.1, %bb.2
68 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
73 RET_ReallyLR implicit $s0
77 name: int_load_phi_gpr
79 regBankSelected: false
80 tracksRegLiveness: true
82 ; CHECK-LABEL: name: int_load_phi_gpr
84 ; CHECK-NEXT: successors: %bb.1(0x80000000)
85 ; CHECK-NEXT: liveins: $w0
87 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
88 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @var_fp
89 ; CHECK-NEXT: %fp_load:gpr(s32) = G_LOAD [[GV]](p0) :: (load (s32) from @var_int)
92 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
94 ; CHECK-NEXT: [[PHI:%[0-9]+]]:gpr(s32) = PHI %fp_load(s32), %bb.0, [[PHI]](s32), %bb.1
95 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
98 ; CHECK-NEXT: $w1 = COPY [[PHI]](s32)
99 ; CHECK-NEXT: RET_ReallyLR implicit $w1
104 %1:_(p0) = G_GLOBAL_VALUE @var_fp
105 %fp_load:_(s32) = G_LOAD %1 :: (load 4 from @var_int)
108 successors: %bb.1, %bb.2
109 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
114 RET_ReallyLR implicit $w1
118 name: int_load_phi_fpr
120 regBankSelected: false
121 tracksRegLiveness: true
123 ; CHECK-LABEL: name: int_load_phi_fpr
125 ; CHECK-NEXT: successors: %bb.1(0x80000000)
126 ; CHECK-NEXT: liveins: $w0
128 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
129 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @var_fp
130 ; CHECK-NEXT: %fp_load:fpr(s32) = G_LOAD [[GV]](p0) :: (load (s32) from @var_int)
133 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
135 ; CHECK-NEXT: [[PHI:%[0-9]+]]:fpr(s32) = PHI %fp_load(s32), %bb.0, [[PHI]](s32), %bb.1
136 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
139 ; CHECK-NEXT: $s0 = COPY [[PHI]](s32)
140 ; CHECK-NEXT: RET_ReallyLR implicit $s0
145 %1:_(p0) = G_GLOBAL_VALUE @var_fp
146 %fp_load:_(s32) = G_LOAD %1 :: (load 4 from @var_int)
149 successors: %bb.1, %bb.2
150 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
155 RET_ReallyLR implicit $s0
159 name: array_load_double
161 regBankSelected: false
162 tracksRegLiveness: true
164 ; CHECK-LABEL: name: array_load_double
166 ; CHECK-NEXT: successors: %bb.1(0x80000000)
167 ; CHECK-NEXT: liveins: $w0
169 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
170 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @array_double
171 ; CHECK-NEXT: %fp_load:fpr(s64) = G_LOAD [[GV]](p0) :: (dereferenceable load (s64) from @array_double)
174 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
176 ; CHECK-NEXT: [[PHI:%[0-9]+]]:fpr(s32) = PHI %fp_load(s64), %bb.0, [[PHI]](s32), %bb.1
177 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
180 ; CHECK-NEXT: $s0 = COPY [[PHI]](s32)
181 ; CHECK-NEXT: RET_ReallyLR implicit $s0
186 %1:_(p0) = G_GLOBAL_VALUE @array_double
187 %fp_load:_(s64) = G_LOAD %1(p0) :: (dereferenceable load (s64) from @array_double)
190 successors: %bb.1, %bb.2
191 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
196 RET_ReallyLR implicit $s0
200 name: struct_array_load_double
202 regBankSelected: false
203 tracksRegLiveness: true
205 ; CHECK-LABEL: name: struct_array_load_double
207 ; CHECK-NEXT: successors: %bb.1(0x80000000)
208 ; CHECK-NEXT: liveins: $w0
210 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
211 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @struct_array_double
212 ; CHECK-NEXT: %fp_load:fpr(s64) = G_LOAD [[GV]](p0) :: (dereferenceable load (s64) from @struct_array_double)
215 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
217 ; CHECK-NEXT: [[PHI:%[0-9]+]]:fpr(s32) = PHI %fp_load(s64), %bb.0, [[PHI]](s32), %bb.1
218 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
221 ; CHECK-NEXT: $s0 = COPY [[PHI]](s32)
222 ; CHECK-NEXT: RET_ReallyLR implicit $s0
227 %1:_(p0) = G_GLOBAL_VALUE @struct_array_double
228 %fp_load:_(s64) = G_LOAD %1(p0) :: (dereferenceable load (s64) from @struct_array_double)
231 successors: %bb.1, %bb.2
232 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
237 RET_ReallyLR implicit $s0
241 name: struct_struct_array_load_double
243 regBankSelected: false
244 tracksRegLiveness: true
246 ; CHECK-LABEL: name: struct_struct_array_load_double
248 ; CHECK-NEXT: successors: %bb.1(0x80000000)
249 ; CHECK-NEXT: liveins: $w0
251 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
252 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @struct_struct_array_double
253 ; CHECK-NEXT: %fp_load:fpr(s64) = G_LOAD [[GV]](p0) :: (dereferenceable load (s64) from @struct_struct_array_double)
256 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
258 ; CHECK-NEXT: [[PHI:%[0-9]+]]:fpr(s32) = PHI %fp_load(s64), %bb.0, [[PHI]](s32), %bb.1
259 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
262 ; CHECK-NEXT: $s0 = COPY [[PHI]](s32)
263 ; CHECK-NEXT: RET_ReallyLR implicit $s0
268 %1:_(p0) = G_GLOBAL_VALUE @struct_struct_array_double
269 %fp_load:_(s64) = G_LOAD %1(p0) :: (dereferenceable load (s64) from @struct_struct_array_double)
272 successors: %bb.1, %bb.2
273 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
278 RET_ReallyLR implicit $s0
282 name: array_load_int_gpr
284 regBankSelected: false
285 tracksRegLiveness: true
287 ; CHECK-LABEL: name: array_load_int_gpr
289 ; CHECK-NEXT: successors: %bb.1(0x80000000)
290 ; CHECK-NEXT: liveins: $w0
292 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
293 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @array_int
294 ; CHECK-NEXT: %fp_load:gpr(s64) = G_LOAD [[GV]](p0) :: (dereferenceable load (s64) from @array_int)
297 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
299 ; CHECK-NEXT: [[PHI:%[0-9]+]]:gpr(s32) = PHI %fp_load(s64), %bb.0, [[PHI]](s32), %bb.1
300 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
303 ; CHECK-NEXT: $w1 = COPY [[PHI]](s32)
304 ; CHECK-NEXT: RET_ReallyLR implicit $w1
309 %1:_(p0) = G_GLOBAL_VALUE @array_int
310 %fp_load:_(s64) = G_LOAD %1(p0) :: (dereferenceable load (s64) from @array_int)
313 successors: %bb.1, %bb.2
314 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
319 RET_ReallyLR implicit $w1
323 name: array_load_int_fpr
325 regBankSelected: false
326 tracksRegLiveness: true
328 ; CHECK-LABEL: name: array_load_int_fpr
330 ; CHECK-NEXT: successors: %bb.1(0x80000000)
331 ; CHECK-NEXT: liveins: $w0
333 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
334 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @array_int
335 ; CHECK-NEXT: %fp_load:fpr(s64) = G_LOAD [[GV]](p0) :: (dereferenceable load (s64) from @array_int)
338 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
340 ; CHECK-NEXT: [[PHI:%[0-9]+]]:fpr(s32) = PHI %fp_load(s64), %bb.0, [[PHI]](s32), %bb.1
341 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
344 ; CHECK-NEXT: $s0 = COPY [[PHI]](s32)
345 ; CHECK-NEXT: RET_ReallyLR implicit $s0
350 %1:_(p0) = G_GLOBAL_VALUE @array_int
351 %fp_load:_(s64) = G_LOAD %1(p0) :: (dereferenceable load (s64) from @array_int)
354 successors: %bb.1, %bb.2
355 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
360 RET_ReallyLR implicit $s0
364 name: struct_array_load_int_gpr
366 regBankSelected: false
367 tracksRegLiveness: true
369 ; CHECK-LABEL: name: struct_array_load_int_gpr
371 ; CHECK-NEXT: successors: %bb.1(0x80000000)
372 ; CHECK-NEXT: liveins: $w0
374 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
375 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @struct_array_int
376 ; CHECK-NEXT: %fp_load:gpr(s64) = G_LOAD [[GV]](p0) :: (dereferenceable load (s64) from @struct_array_int)
379 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
381 ; CHECK-NEXT: [[PHI:%[0-9]+]]:gpr(s32) = PHI %fp_load(s64), %bb.0, [[PHI]](s32), %bb.1
382 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
385 ; CHECK-NEXT: $w1 = COPY [[PHI]](s32)
386 ; CHECK-NEXT: RET_ReallyLR implicit $w1
391 %1:_(p0) = G_GLOBAL_VALUE @struct_array_int
392 %fp_load:_(s64) = G_LOAD %1(p0) :: (dereferenceable load (s64) from @struct_array_int)
395 successors: %bb.1, %bb.2
396 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
401 RET_ReallyLR implicit $w1
405 name: struct_array_load_int_fpr
407 regBankSelected: false
408 tracksRegLiveness: true
410 ; CHECK-LABEL: name: struct_array_load_int_fpr
412 ; CHECK-NEXT: successors: %bb.1(0x80000000)
413 ; CHECK-NEXT: liveins: $w0
415 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
416 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @struct_array_int
417 ; CHECK-NEXT: %fp_load:fpr(s64) = G_LOAD [[GV]](p0) :: (dereferenceable load (s64) from @struct_array_int)
420 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
422 ; CHECK-NEXT: [[PHI:%[0-9]+]]:fpr(s32) = PHI %fp_load(s64), %bb.0, [[PHI]](s32), %bb.1
423 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
426 ; CHECK-NEXT: $s0 = COPY [[PHI]](s32)
427 ; CHECK-NEXT: RET_ReallyLR implicit $s0
432 %1:_(p0) = G_GLOBAL_VALUE @struct_array_int
433 %fp_load:_(s64) = G_LOAD %1(p0) :: (dereferenceable load (s64) from @struct_array_int)
436 successors: %bb.1, %bb.2
437 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
442 RET_ReallyLR implicit $s0
446 name: struct_struct_array_load_int_gpr
448 regBankSelected: false
449 tracksRegLiveness: true
451 ; CHECK-LABEL: name: struct_struct_array_load_int_gpr
453 ; CHECK-NEXT: successors: %bb.1(0x80000000)
454 ; CHECK-NEXT: liveins: $w0
456 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
457 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @struct_struct_array_int
458 ; CHECK-NEXT: %fp_load:gpr(s64) = G_LOAD [[GV]](p0) :: (dereferenceable load (s64) from @struct_struct_array_int)
461 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
463 ; CHECK-NEXT: [[PHI:%[0-9]+]]:gpr(s32) = PHI %fp_load(s64), %bb.0, [[PHI]](s32), %bb.1
464 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
467 ; CHECK-NEXT: $w1 = COPY [[PHI]](s32)
468 ; CHECK-NEXT: RET_ReallyLR implicit $w1
473 %1:_(p0) = G_GLOBAL_VALUE @struct_struct_array_int
474 %fp_load:_(s64) = G_LOAD %1(p0) :: (dereferenceable load (s64) from @struct_struct_array_int)
477 successors: %bb.1, %bb.2
478 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
483 RET_ReallyLR implicit $w1
487 name: struct_struct_array_load_int_fpr
489 regBankSelected: false
490 tracksRegLiveness: true
492 ; CHECK-LABEL: name: struct_struct_array_load_int_fpr
494 ; CHECK-NEXT: successors: %bb.1(0x80000000)
495 ; CHECK-NEXT: liveins: $w0
497 ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr(s32) = COPY $w0
498 ; CHECK-NEXT: [[GV:%[0-9]+]]:gpr(p0) = G_GLOBAL_VALUE @struct_struct_array_int
499 ; CHECK-NEXT: %fp_load:fpr(s64) = G_LOAD [[GV]](p0) :: (dereferenceable load (s64) from @struct_struct_array_int)
502 ; CHECK-NEXT: successors: %bb.1(0x40000000), %bb.2(0x40000000)
504 ; CHECK-NEXT: [[PHI:%[0-9]+]]:fpr(s32) = PHI %fp_load(s64), %bb.0, [[PHI]](s32), %bb.1
505 ; CHECK-NEXT: G_BRCOND [[COPY]](s32), %bb.1
508 ; CHECK-NEXT: $s0 = COPY [[PHI]](s32)
509 ; CHECK-NEXT: RET_ReallyLR implicit $s0
514 %1:_(p0) = G_GLOBAL_VALUE @struct_struct_array_int
515 %fp_load:_(s64) = G_LOAD %1(p0) :: (dereferenceable load (s64) from @struct_struct_array_int)
518 successors: %bb.1, %bb.2
519 %2:_(s32) = PHI %fp_load, %bb.0, %2, %bb.1
524 RET_ReallyLR implicit $s0