summaryrefslogtreecommitdiff
path: root/test/ELF/aarch64-combined-dynrel.s
diff options
context:
space:
mode:
Diffstat (limited to 'test/ELF/aarch64-combined-dynrel.s')
-rw-r--r--test/ELF/aarch64-combined-dynrel.s41
1 files changed, 0 insertions, 41 deletions
diff --git a/test/ELF/aarch64-combined-dynrel.s b/test/ELF/aarch64-combined-dynrel.s
deleted file mode 100644
index 438c2509906e6..0000000000000
--- a/test/ELF/aarch64-combined-dynrel.s
+++ /dev/null
@@ -1,41 +0,0 @@
-// REQUIRES: AArch64
-// RUN: llvm-mc --triple=aarch64-linux-gnu -filetype=obj -o %t.o %s
-// RUN: echo "SECTIONS { \
-// RUN: .text : { *(.text) } \
-// RUN: .rela.dyn : { *(.rela.dyn) *(.rela.plt) } \
-// RUN: } " > %t.script
-// RUN: ld.lld %t.o -o %t.so --shared --script %t.script
-// RUN: llvm-readobj --section-headers --dynamic-table %t.so | FileCheck %s
-
-// The linker script above combines the .rela.dyn and .rela.plt into a single
-// table. ELF is clear that the DT_PLTRELSZ should match the subset of
-// relocations that is associated with the PLT. It is less clear about what
-// the value of DT_RELASZ should be. ELF implies that it should be the size
-// of the single table so that DT_RELASZ includes DT_PLTRELSZ. The loader in
-// glibc permits this as long as .rela.plt comes after .rela.dyn in the
-// combined table.
- .text
- .globl func
- .type func, %function
- .globl foo
- .type foo, %object
-
- .globl _start
- .type _start, %function
-_start:
- bl func
- adrp x8, :got:foo
- ldr x8, [x8, :got_lo12:foo]
- ret
-
-// CHECK: Name: .rela.dyn
-// CHECK-NEXT: Type: SHT_RELA
-// CHECK-NEXT: Flags [
-// CHECK-NEXT: SHF_ALLOC
-// CHECK-NEXT: ]
-// CHECK-NEXT: Address:
-// CHECK-NEXT: Offset:
-// CHECK-NEXT: Size: 48
-
-// CHECK: 0x0000000000000008 RELASZ 48
-// CHECK: 0x0000000000000002 PLTRELSZ 24