diff options
author | Mark Kettenis <kettenis@cvs.openbsd.org> | 2019-02-05 21:23:02 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@cvs.openbsd.org> | 2019-02-05 21:23:02 +0000 |
commit | 0722f2b58a9e37122c399a8a085bfe1a6ad9f39a (patch) | |
tree | fdabea2a0f10ba69225a064c9840bcbc7e429e48 | |
parent | 2fb3e1484aaf551916ad2e144a75149b73bcd2e2 (diff) |
Fix addend handling for relaxing R_PPC_PLTREL24 relocations. This issue has
been fixed in a much more complicated way upstream which we can't easily
backport and involves GPLv3 code as well. So instead simply nuke the addend
in the most convenient spot. Makes -Wl,-relax work well enough to link
base clang.
ok guenther@
-rw-r--r-- | gnu/usr.bin/binutils-2.17/bfd/elf32-ppc.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/gnu/usr.bin/binutils-2.17/bfd/elf32-ppc.c b/gnu/usr.bin/binutils-2.17/bfd/elf32-ppc.c index d4f4cf2bf8e..328031bbe7e 100644 --- a/gnu/usr.bin/binutils-2.17/bfd/elf32-ppc.c +++ b/gnu/usr.bin/binutils-2.17/bfd/elf32-ppc.c @@ -5235,6 +5235,9 @@ ppc_elf_relax_section (bfd *abfd, irel->r_info = ELF32_R_INFO (ELF32_R_SYM (irel->r_info), stub_rtype); irel->r_offset = trampoff + insn_offset; + if (r_type == R_PPC_PLTREL24 && + (stub_rtype == R_PPC_RELAX32 || stub_rtype == R_PPC_RELAX32PC)) + irel->r_addend = 0; /* Record the fixup so we don't do it again this section. */ f = bfd_malloc (sizeof (*f)); |