From: Andrew Goedhart Date: Tue, 9 May 2017 11:14:48 +0000 (+0100) Subject: Fix resolution of R_ARM_THM_ALU_PREL_11_0 relocation against Thumb symbols. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=e645cf40b111daef4518a58547de577eb9379ccb;p=binutils-gdb.git Fix resolution of R_ARM_THM_ALU_PREL_11_0 relocation against Thumb symbols. PR ld/21458 * elf32-arm.c (elf32_arm_final_link_relocate): Set the bottom bit of the value when resolving a R_ARM_THM_ALU_PREL_11_0 relocation and the destination is a Thumb symbol. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 5205548a236..917a34977e3 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,10 @@ +2017-05-09 Andrew Goedhart + + PR ld/21458 + * elf32-arm.c (elf32_arm_final_link_relocate): Set the bottom bit + of the value when resolving a R_ARM_THM_ALU_PREL_11_0 relocation + and the destination is a Thumb symbol. + 2017-05-08 H.J. Lu * elf32-i386.c (elf_i386_get_synthetic_symtab): Add missing diff --git a/bfd/elf32-arm.c b/bfd/elf32-arm.c index 8dcaf45523e..23a02c03f21 100644 --- a/bfd/elf32-arm.c +++ b/bfd/elf32-arm.c @@ -10511,6 +10511,10 @@ elf32_arm_final_link_relocate (reloc_howto_type * howto, if (value >= 0x1000) return bfd_reloc_overflow; + /* Destination is Thumb. Force bit 0 to 1 to reflect this. */ + if (branch_type == ST_BRANCH_TO_THUMB) + value |= 1; + insn = (insn & 0xfb0f8f00) | (value & 0xff) | ((value & 0x700) << 4) | ((value & 0x800) << 15);