llvm-toolchain-9/lld/test/ELF/riscv32-reloc-32-pic.s

24 lines
558 B
ArmAsm

# REQUIRES: riscv
# RUN: llvm-mc -filetype=obj -triple=riscv32 %s -o %t.o
# RUN: ld.lld -shared %t.o -o %t.so
# RUN: llvm-nm %t.so | FileCheck --check-prefix=NM %s
# RUN: llvm-readobj -r %t.so | FileCheck --check-prefix=RELOC %s
## R_RISCV_32 is an absolute relocation type.
## In PIC mode, it creates a relative relocation if the symbol is non-preemptable.
# NM: 00002004 d b
# RELOC: .rela.dyn {
# RELOC-NEXT: 0x2004 R_RISCV_RELATIVE - 0x2004
# RELOC-NEXT: 0x2000 R_RISCV_32 a 0
# RELOC-NEXT: }
.globl a, b
.hidden b
.data
.long a
b:
.long b