diff options
Diffstat (limited to 'test/ELF/got-aarch64.s')
-rw-r--r-- | test/ELF/got-aarch64.s | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/test/ELF/got-aarch64.s b/test/ELF/got-aarch64.s new file mode 100644 index 0000000000000..b4aa456b4e817 --- /dev/null +++ b/test/ELF/got-aarch64.s @@ -0,0 +1,40 @@ +// RUN: llvm-mc -filetype=obj -triple=aarch64-unknown-linux %s -o %t.o +// RUN: ld.lld -shared %t.o -o %t.so +// RUN: llvm-readobj -s -r %t.so | FileCheck %s +// RUN: llvm-objdump -d %t.so | FileCheck --check-prefix=DISASM %s +// REQUIRES: aarch64 + +// CHECK: Name: .got +// CHECK-NEXT: Type: SHT_PROGBITS +// CHECK-NEXT: Flags [ +// CHECK-NEXT: SHF_ALLOC +// CHECK-NEXT: SHF_WRITE +// CHECK-NEXT: ] +// CHECK-NEXT: Address: 0x2090 +// CHECK-NEXT: Offset: +// CHECK-NEXT: Size: 8 +// CHECK-NEXT: Link: 0 +// CHECK-NEXT: Info: 0 +// CHECK-NEXT: AddressAlignment: 8 + +// CHECK: Relocations [ +// CHECK-NEXT: Section ({{.*}}) .rela.dyn { +// CHECK-NEXT: 0x2090 R_AARCH64_GLOB_DAT dat 0x0 +// CHECK-NEXT: } +// CHECK-NEXT: ] + +// Page(0x2098) - Page(0x1000) = 0x1000 = 4096 +// 0x2098 & 0xff8 = 0x98 = 152 + +// DISASM: main: +// DISASM-NEXT: 1000: {{.*}} adrp x0, #4096 +// DISASM-NEXT: 1004: {{.*}} ldr x0, [x0, #144] + +.global main,foo,dat +.text +main: + adrp x0, :got:dat + ldr x0, [x0, :got_lo12:dat] +.data +dat: + .word 42 |