diff options
Diffstat (limited to 'test/CodeGen/AArch64/frameaddr.ll')
-rw-r--r-- | test/CodeGen/AArch64/frameaddr.ll | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/test/CodeGen/AArch64/frameaddr.ll b/test/CodeGen/AArch64/frameaddr.ll index 85d95e2..d6bb50e 100644 --- a/test/CodeGen/AArch64/frameaddr.ll +++ b/test/CodeGen/AArch64/frameaddr.ll @@ -1,20 +1,29 @@ -; RUN: llc -o - %s -mtriple=arm64-apple-ios7.0 | FileCheck %s +; RUN: llc -mtriple=aarch64-apple-darwin -verify-machineinstrs < %s | FileCheck %s +; RUN: llc -mtriple=aarch64-apple-darwin -fast-isel -fast-isel-abort -verify-machineinstrs < %s | FileCheck %s -define i8* @t() nounwind { +define i8* @test_frameaddress0() nounwind { entry: -; CHECK-LABEL: t: +; CHECK-LABEL: test_frameaddress0: +; CHECK: stp x29, x30, [sp, #-16]! +; CHECK: mov x29, sp ; CHECK: mov x0, x29 - %0 = call i8* @llvm.frameaddress(i32 0) - ret i8* %0 +; CHECK: ldp x29, x30, [sp], #16 +; CHECK: ret + %0 = call i8* @llvm.frameaddress(i32 0) + ret i8* %0 } -define i8* @t2() nounwind { +define i8* @test_frameaddress2() nounwind { entry: -; CHECK-LABEL: t2: +; CHECK-LABEL: test_frameaddress2: +; CHECK: stp x29, x30, [sp, #-16]! +; CHECK: mov x29, sp ; CHECK: ldr x[[reg:[0-9]+]], [x29] -; CHECK: ldr {{x[0-9]+}}, [x[[reg]]] - %0 = call i8* @llvm.frameaddress(i32 2) - ret i8* %0 +; CHECK: ldr x0, [x[[reg]]] +; CHECK: ldp x29, x30, [sp], #16 +; CHECK: ret + %0 = call i8* @llvm.frameaddress(i32 2) + ret i8* %0 } declare i8* @llvm.frameaddress(i32) nounwind readnone |