blob: 301eee43d33e6902b14b22be8fa3f69e913f8bcc [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4
; RUN: llc -mtriple=aarch64 -O0 -mattr=+sme < %s | FileCheck %s
target triple = "aarch64-linux-gnu"
; This test checks that with only +sme (no SVE), LLVM sets up the base-pointer
; (x19) in functions with dynamic allocas and SVE stack objects.
define void @quux(i64 %n) "aarch64_new_za" "aarch64_pstate_sm_enabled" {
; CHECK-LABEL: quux:
; CHECK: // %bb.0:
; CHECK-NEXT: stp x29, x30, [sp, #-32]! // 16-byte Folded Spill
; CHECK-NEXT: str x19, [sp, #16] // 8-byte Spill
; CHECK-NEXT: mov x29, sp
; CHECK-NEXT: addvl sp, sp, #-1
; CHECK-NEXT: mov x19, sp
; CHECK-NEXT: .cfi_def_cfa w29, 32
; CHECK-NEXT: .cfi_offset w19, -16
; CHECK-NEXT: .cfi_offset w30, -24
; CHECK-NEXT: .cfi_offset w29, -32
; CHECK-NEXT: add x8, x0, #15
; CHECK-NEXT: and x9, x8, #0xfffffffffffffff0
; CHECK-NEXT: mov x8, sp
; CHECK-NEXT: subs x8, x8, x9
; CHECK-NEXT: mov sp, x8
; CHECK-NEXT: // fake_use: $x8
; CHECK-NEXT: mov sp, x29
; CHECK-NEXT: ldr x19, [sp, #16] // 8-byte Reload
; CHECK-NEXT: ldp x29, x30, [sp], #32 // 16-byte Folded Reload
; CHECK-NEXT: ret
%zpr_local = alloca <vscale x 16 x i8>
%dyn_alloc = alloca i8, i64 %n, align 1
call void (...) @llvm.fake.use(ptr %dyn_alloc)
call void (...) @llvm.fake.use(ptr %zpr_local)
ret void
}