; RUN: llc < %s -march=xcore | FileCheck %s
declare void @g()
declare ptr @llvm.stacksave() nounwind
declare void @llvm.stackrestore(ptr) nounwind
define void @f(ptr %p, i32 %size) {
allocas:
%0 = call ptr @llvm.stacksave()
%a = alloca i32, i32 %size
store ptr %a, ptr %p
call void @g()
call void @llvm.stackrestore(ptr %0)
ret void
}
; CHECK-LABEL: f:
; CHECK: ldaw [[REGISTER:r[0-9]+]], {{r[0-9]+}}[-r1]
; CHECK: set sp, [[REGISTER]]
; CHECK: extsp 1
; CHECK: bl g