# REQUIRES: aarch64
## Prior to Android V, there was a bug that caused RELR relocations to be
## applied after packed relocations. This meant that resolvers referenced by
## IRELATIVE relocations in the packed relocation section would read unrelocated
## globals when --pack-relative-relocs=android+relr is enabled. Work around this
## by placing IRELATIVE in .rela.plt.
# RUN: rm -rf %t && split-file %s %t && cd %t
# RUN: llvm-mc -filetype=obj -triple=aarch64-linux-android a.s -o a.o
# RUN: llvm-mc -filetype=obj -triple=aarch64-linux-android b.s -o b.o
# RUN: ld.lld -shared b.o -o b.so
# RUN: ld.lld -pie --pack-dyn-relocs=android+relr -z separate-loadable-segments a.o b.so -o a
# RUN: llvm-readobj -r a | FileCheck %s
# RUN: llvm-objdump -d a | FileCheck %s --check-prefix=ASM
# CHECK: .relr.dyn {
# CHECK-NEXT: 0x30000 R_AARCH64_RELATIVE -
# CHECK-NEXT: }
# CHECK: .rela.plt {
# CHECK-NEXT: 0x30020 R_AARCH64_JUMP_SLOT bar 0x0
# CHECK-NEXT: 0x30028 R_AARCH64_IRELATIVE - 0x10000
# CHECK-NEXT: }
# ASM: <.iplt>:
# ASM-NEXT: adrp x16, 0x30000
# ASM-NEXT: ldr x17, [x16, #0x28]
# ASM-NEXT: add x16, x16, #0x28
# ASM-NEXT: br x17
#--- a.s
.text
.type foo, %gnu_indirect_function
.globl foo
foo:
ret
.globl _start
_start:
bl foo
bl bar
.data
.balign 8
.quad .data
#--- b.s
.globl bar
bar:
ret