| 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 |
| 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 |