xref: /aosp_15_r20/external/llvm/test/CodeGen/MIR/AArch64/stack-object-local-offset.mir (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker# RUN: llc -mtriple=aarch64-none-linux-gnu -start-after machine-sink -stop-after machine-sink -o - %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker--- |
4*9880d681SAndroid Build Coastguard Worker  @var = global i64 0
5*9880d681SAndroid Build Coastguard Worker  @local_addr = global i64* null
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Worker  define void @stack_local() {
8*9880d681SAndroid Build Coastguard Worker  entry:
9*9880d681SAndroid Build Coastguard Worker    %local_var = alloca i64
10*9880d681SAndroid Build Coastguard Worker    %val = load i64, i64* @var
11*9880d681SAndroid Build Coastguard Worker    store i64 %val, i64* %local_var
12*9880d681SAndroid Build Coastguard Worker    store i64* %local_var, i64** @local_addr
13*9880d681SAndroid Build Coastguard Worker    ret void
14*9880d681SAndroid Build Coastguard Worker  }
15*9880d681SAndroid Build Coastguard Worker...
16*9880d681SAndroid Build Coastguard Worker---
17*9880d681SAndroid Build Coastguard Workername:            stack_local
18*9880d681SAndroid Build Coastguard WorkerisSSA:           true
19*9880d681SAndroid Build Coastguard WorkertracksRegLiveness: true
20*9880d681SAndroid Build Coastguard Workerregisters:
21*9880d681SAndroid Build Coastguard Worker  - { id: 0, class: gpr64common }
22*9880d681SAndroid Build Coastguard Worker  - { id: 1, class: gpr64 }
23*9880d681SAndroid Build Coastguard Worker  - { id: 2, class: gpr64common }
24*9880d681SAndroid Build Coastguard Worker  - { id: 3, class: gpr64common }
25*9880d681SAndroid Build Coastguard WorkerframeInfo:
26*9880d681SAndroid Build Coastguard Worker  maxAlignment:    8
27*9880d681SAndroid Build Coastguard Worker# CHECK-LABEL: stack_local
28*9880d681SAndroid Build Coastguard Worker# CHECK: stack:
29*9880d681SAndroid Build Coastguard Worker# CHECK-NEXT: { id: 0, name: local_var, offset: 0, size: 8, alignment: 8, local-offset: -8 }
30*9880d681SAndroid Build Coastguard Workerstack:
31*9880d681SAndroid Build Coastguard Worker  - { id: 0,name: local_var,offset: 0,size: 8,alignment: 8, local-offset: -8 }
32*9880d681SAndroid Build Coastguard Workerbody: |
33*9880d681SAndroid Build Coastguard Worker  bb.0.entry:
34*9880d681SAndroid Build Coastguard Worker    %0 = ADRP @var
35*9880d681SAndroid Build Coastguard Worker    %1 = LDRXui killed %0, @var :: (load 8 from @var)
36*9880d681SAndroid Build Coastguard Worker    STRXui killed %1, %stack.0.local_var, 0 :: (store 8 into %ir.local_var)
37*9880d681SAndroid Build Coastguard Worker    %2 = ADRP @local_addr
38*9880d681SAndroid Build Coastguard Worker    %3 = ADDXri %stack.0.local_var, 0, 0
39*9880d681SAndroid Build Coastguard Worker    STRXui killed %3, killed %2, @local_addr :: (store 8 into @local_addr)
40*9880d681SAndroid Build Coastguard Worker    RET_ReallyLR
41*9880d681SAndroid Build Coastguard Worker...
42