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