23 changes: 23 additions & 0 deletions lld/test/ELF/riscv32-reloc-32-pic.s
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# 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
23 changes: 23 additions & 0 deletions lld/test/ELF/riscv64-reloc-64-pic.s
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# REQUIRES: riscv
# RUN: llvm-mc -filetype=obj -triple=riscv64 %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_64 is an absolute relocation type.
## In PIC mode, it creates a relative relocation if the symbol is non-preemptable.

# NM: 0000000000002008 d b

# RELOC: .rela.dyn {
# RELOC-NEXT: 0x2008 R_RISCV_RELATIVE - 0x2008
# RELOC-NEXT: 0x2000 R_RISCV_64 a 0
# RELOC-NEXT: }

.globl a, b
.hidden b

.data
.quad a
b:
.quad b