diff options
author | Weiming Zhao <weimingz@codeaurora.org> | 2013-10-29 17:01:29 +0000 |
---|---|---|
committer | Weiming Zhao <weimingz@codeaurora.org> | 2013-10-29 17:01:29 +0000 |
commit | a72ec5517f95616ac133d266b29f1840ce922492 (patch) | |
tree | a05d2517cf08be4af4364c54df00ec1ebd3945c9 /test | |
parent | 160a14e2b1b3bfd2bd67cb03a7ae213fb35211cc (diff) | |
download | llvm-a72ec5517f95616ac133d266b29f1840ce922492.tar.gz llvm-a72ec5517f95616ac133d266b29f1840ce922492.tar.bz2 llvm-a72ec5517f95616ac133d266b29f1840ce922492.tar.xz |
add test cases for frameaddr and returnaddr for aarch64
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@193626 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test')
-rw-r--r-- | test/CodeGen/AArch64/frameaddr.ll | 20 | ||||
-rw-r--r-- | test/CodeGen/AArch64/returnaddr.ll | 21 |
2 files changed, 41 insertions, 0 deletions
diff --git a/test/CodeGen/AArch64/frameaddr.ll b/test/CodeGen/AArch64/frameaddr.ll new file mode 100644 index 0000000000..182704bd65 --- /dev/null +++ b/test/CodeGen/AArch64/frameaddr.ll @@ -0,0 +1,20 @@ +; RUN: llc < %s -mtriple=aarch64-none-linux-gnu | FileCheck %s + +define i8* @t() nounwind { +entry: +; CHECK-LABEL: t: +; CHECK: mov x0, x29 + %0 = call i8* @llvm.frameaddress(i32 0) + ret i8* %0 +} + +define i8* @t2() nounwind { +entry: +; CHECK-LABEL: t2: +; CHECK: ldr x[[reg:[0-9]+]], [x29] +; CHECK: ldr x[[reg]], [x[[reg]]] + %0 = call i8* @llvm.frameaddress(i32 2) + ret i8* %0 +} + +declare i8* @llvm.frameaddress(i32) nounwind readnone diff --git a/test/CodeGen/AArch64/returnaddr.ll b/test/CodeGen/AArch64/returnaddr.ll new file mode 100644 index 0000000000..c85f9ec4ff --- /dev/null +++ b/test/CodeGen/AArch64/returnaddr.ll @@ -0,0 +1,21 @@ +; RUN: llc < %s -mtriple=aarch64-none-linux-gnu | FileCheck %s + +define i8* @rt0(i32 %x) nounwind readnone { +entry: +; CHECK-LABEL: rt0: +; CHECK: mov x0, x30 + %0 = tail call i8* @llvm.returnaddress(i32 0) + ret i8* %0 +} + +define i8* @rt2() nounwind readnone { +entry: +; CHECK-LABEL: rt2: +; CHECK: ldr x[[reg:[0-9]+]], [x29] +; CHECK: ldr x[[reg]], [x[[reg]]] +; CHECK: ldr x0, [x[[reg]], #8] + %0 = tail call i8* @llvm.returnaddress(i32 2) + ret i8* %0 +} + +declare i8* @llvm.returnaddress(i32) nounwind readnone |