diff options
author | Nelson Chu <nelson.chu@sifive.com> | 2020-08-26 01:19:13 -0700 |
---|---|---|
committer | Nelson Chu <nelson.chu@sifive.com> | 2020-08-28 09:37:35 +0800 |
commit | 3b1450b38c644f99aa2e211747b428b9f8d15cca (patch) | |
tree | a75075ca5c25bb1bbe1b2e3a5138f6cb0d8f3280 /ld | |
parent | f2f08254b11c2248dc3fd9440b2bad29c74357e4 (diff) | |
download | fsf-binutils-gdb-3b1450b38c644f99aa2e211747b428b9f8d15cca.zip fsf-binutils-gdb-3b1450b38c644f99aa2e211747b428b9f8d15cca.tar.gz fsf-binutils-gdb-3b1450b38c644f99aa2e211747b428b9f8d15cca.tar.bz2 |
RISC-V: Treat R_RISCV_CALL and R_RISCV_CALL_PLT as the same in check_relocs.
In fact, we can treate these two relocation as the same one in the
riscv_elf_check_relocs. I have heard that RISC-V lld had made this
improvement, and so had GNU AARCH64, they only need R_AARCH64_CALL26
for calls rather than two seperate relocations.
Beside, the following PLT issue for RISC-V 32-bit glibc seems to be
fixed by applying at least this patch.
<https://sourceware.org/pipermail/libc-alpha/2020-August/117214.html>
I have ran the toolchain regression, and everything seems fine for now.
bfd/
* elfnn-riscv.c (riscv_elf_check_relocs): Treat R_RISCV_CALL
and R_RISCV_CALL_PLT as the same in the riscv_elf_check_relocs.
(riscv_elf_relocate_section): Remove the R_RISCV_CALL for the
unresolved reloc checks.
ld/
testsuite/ld-riscv-elf/lib-nopic-01a.s: Use R_RISCV_JAL rather
than R_RISCV_CALL.
testsuite/ld-riscv-elf/lib-nopic-01b.d: Likewise.
testsuite/ld-riscv-elf/lib-nopic-01b.s: Likewise.
Diffstat (limited to 'ld')
-rw-r--r-- | ld/ChangeLog | 7 | ||||
-rw-r--r-- | ld/testsuite/ld-riscv-elf/lib-nopic-01a.s | 2 | ||||
-rw-r--r-- | ld/testsuite/ld-riscv-elf/lib-nopic-01b.d | 2 | ||||
-rw-r--r-- | ld/testsuite/ld-riscv-elf/lib-nopic-01b.s | 2 |
4 files changed, 10 insertions, 3 deletions
diff --git a/ld/ChangeLog b/ld/ChangeLog index 7881dd1..787d760 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,10 @@ +2020-08-28 Nelson Chu <nelson.chu@sifive.com> + + testsuite/ld-riscv-elf/lib-nopic-01a.s: Use R_RISCV_JAL rather + than R_RISCV_CALL. + testsuite/ld-riscv-elf/lib-nopic-01b.d: Likewise. + testsuite/ld-riscv-elf/lib-nopic-01b.s: Likewise. + 2020-08-27 Jozef Lawrynowicz <jozef.l@mittosystems.com> * emultempl/msp430.em: Remove unused variable "buf". diff --git a/ld/testsuite/ld-riscv-elf/lib-nopic-01a.s b/ld/testsuite/ld-riscv-elf/lib-nopic-01a.s index c95cda0..632875d 100644 --- a/ld/testsuite/ld-riscv-elf/lib-nopic-01a.s +++ b/ld/testsuite/ld-riscv-elf/lib-nopic-01a.s @@ -4,6 +4,6 @@ .globl func1 .type func1, @function func1: - call func2 + jal func2 jr ra .size func1, .-func1 diff --git a/ld/testsuite/ld-riscv-elf/lib-nopic-01b.d b/ld/testsuite/ld-riscv-elf/lib-nopic-01b.d index 0d758a4..1c2c907 100644 --- a/ld/testsuite/ld-riscv-elf/lib-nopic-01b.d +++ b/ld/testsuite/ld-riscv-elf/lib-nopic-01b.d @@ -2,4 +2,4 @@ #source: lib-nopic-01b.s #as: #ld: -shared tmpdir/lib-nopic-01a.so -#error: .*relocation R_RISCV_CALL against `func1' can not be used when making a shared object; recompile with -fPIC +#error: .*relocation R_RISCV_JAL against `func1' can not be used when making a shared object; recompile with -fPIC diff --git a/ld/testsuite/ld-riscv-elf/lib-nopic-01b.s b/ld/testsuite/ld-riscv-elf/lib-nopic-01b.s index 97fe137..ea7b029 100644 --- a/ld/testsuite/ld-riscv-elf/lib-nopic-01b.s +++ b/ld/testsuite/ld-riscv-elf/lib-nopic-01b.s @@ -4,6 +4,6 @@ .globl func2 .type func2, @function func2: - call func1 + jal func1 jr ra .size func2, .-func2 |