diff options
author | Tim Northover <tnorthover@apple.com> | 2013-10-09 07:53:49 +0000 |
---|---|---|
committer | Tim Northover <tnorthover@apple.com> | 2013-10-09 07:53:49 +0000 |
commit | ccb06ae8f3ef0135d4bddf4f0f61f619c3ce3f1e (patch) | |
tree | d2308fbad810e29a8c05be4394790d822ea5a4f8 /test/MC | |
parent | 5747f946ec810d22d36260a4b18114d5673fd55f (diff) | |
download | external_llvm-ccb06ae8f3ef0135d4bddf4f0f61f619c3ce3f1e.zip external_llvm-ccb06ae8f3ef0135d4bddf4f0f61f619c3ce3f1e.tar.gz external_llvm-ccb06ae8f3ef0135d4bddf4f0f61f619c3ce3f1e.tar.bz2 |
AArch64: migrate ADRP relaxation test to be llvm-mc only.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@192281 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/MC')
-rw-r--r-- | test/MC/AArch64/adrp-relocation.s | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/test/MC/AArch64/adrp-relocation.s b/test/MC/AArch64/adrp-relocation.s new file mode 100644 index 0000000..3bcef34 --- /dev/null +++ b/test/MC/AArch64/adrp-relocation.s @@ -0,0 +1,18 @@ +// RUN: llvm-mc -triple=aarch64-linux-gnu -filetype=obj -o - %s| llvm-readobj -r - | FileCheck %s + .text +// These should produce an ADRP/ADD pair to calculate the address of +// testfn. The important point is that LLVM shouldn't think it can deal with the +// relocation on the ADRP itself (even though it knows everything about the +// relative offsets of testfn and foo) because its value depends on where this +// object file's .text section gets relocated in memory. + adrp x0, sym + adrp x0, :got:sym + adrp x0, :gottprel:sym + adrp x0, :tlsdesc:sym + + .global sym +sym: +// CHECK: R_AARCH64_ADR_PREL_PG_HI21 sym +// CHECK: R_AARCH64_ADR_GOT_PAGE sym +// CHECK: R_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21 sym +// CHECK: R_AARCH64_TLSDESC_ADR_PAGE sym |