|
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 |
| 2 | +; RUN: llc -O0 -o - %s | FileCheck %s |
| 3 | +target datalayout = "e-m:o-i64:64-i128:128-n32:64-S128-Fn32" |
| 4 | +target triple = "arm64e-apple-macosx10.15.0" |
| 5 | + |
| 6 | +; Check we don't crash here when selecting an anyextending FP load. |
| 7 | + |
| 8 | +define i32 @test() { |
| 9 | +; CHECK-LABEL: test: |
| 10 | +; CHECK: ; %bb.0: ; %entry |
| 11 | +; CHECK-NEXT: sub sp, sp, #80 |
| 12 | +; CHECK-NEXT: stp x29, x30, [sp, #64] ; 16-byte Folded Spill |
| 13 | +; CHECK-NEXT: .cfi_def_cfa_offset 80 |
| 14 | +; CHECK-NEXT: .cfi_offset w30, -8 |
| 15 | +; CHECK-NEXT: .cfi_offset w29, -16 |
| 16 | +; CHECK-NEXT: mov x8, #0 ; =0x0 |
| 17 | +; CHECK-NEXT: ldr s0, [x8] |
| 18 | +; CHECK-NEXT: ; kill: def $d0 killed $s0 |
| 19 | +; CHECK-NEXT: mov x8, sp |
| 20 | +; CHECK-NEXT: mov w9, #0 ; =0x0 |
| 21 | +; CHECK-NEXT: str w9, [sp, #60] ; 4-byte Folded Spill |
| 22 | +; CHECK-NEXT: str xzr, [x8] |
| 23 | +; CHECK-NEXT: str xzr, [x8, #8] |
| 24 | +; CHECK-NEXT: str xzr, [x8, #16] |
| 25 | +; CHECK-NEXT: str xzr, [x8, #24] |
| 26 | +; CHECK-NEXT: str d0, [x8, #32] |
| 27 | +; CHECK-NEXT: str xzr, [x8, #40] |
| 28 | +; CHECK-NEXT: mov x8, #0 ; =0x0 |
| 29 | +; CHECK-NEXT: mov x0, x8 |
| 30 | +; CHECK-NEXT: blr x8 |
| 31 | +; CHECK-NEXT: ldr w0, [sp, #60] ; 4-byte Folded Reload |
| 32 | +; CHECK-NEXT: ldp x29, x30, [sp, #64] ; 16-byte Folded Reload |
| 33 | +; CHECK-NEXT: add sp, sp, #80 |
| 34 | +; CHECK-NEXT: ret |
| 35 | +entry: |
| 36 | + %0 = inttoptr i64 0 to ptr |
| 37 | + %1 = load i32, ptr %0, align 4 |
| 38 | + %call86 = call i32 (ptr, ...) null(ptr null, i32 0, i32 0, i32 0, i32 0, i32 %1, i32 0) |
| 39 | + %2 = load float, ptr %0, align 4 |
| 40 | + ret i32 0 |
| 41 | +} |
| 42 | + |
0 commit comments