]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
[PR ld/22269] arm: Avoid dynamic relocs for undefweak symbols in static PIE
authorSzabolcs Nagy <szabolcs.nagy@arm.com>
Thu, 9 Jan 2020 17:20:56 +0000 (17:20 +0000)
committerSzabolcs Nagy <szabolcs.nagy@arm.com>
Mon, 13 Jan 2020 15:52:58 +0000 (15:52 +0000)
With static PIE linking undefined weak symbols are resolved to 0, so no
dynamic relocation is needed for them. The UNDEFWEAK_NO_DYNAMIC_RELOC
macro was introduced so this case can be handled easily, but it was not
applied consistently in the first attempt to fix ld/22269 for arm:

  commit 95b03e4ad68e7a90f5096b47df595636344b783a
  arm: Check UNDEFWEAK_NO_DYNAMIC_RELOC

This patch fixes spurious relative relocs in static PIE binaries against
GOT entries created for undefined weak symbols on arm*-*, this fixes

FAIL: pr22269-1 (static pie undefined weak)

bfd/ChangeLog:

Backported from master
2020-01-10  Szabolcs Nagy  <szabolcs.nagy@arm.com>

PR ld/22269
* elf32-arm.c (elf32_arm_final_link_relocate): Use
UNDEFWEAK_NO_DYNAMIC_RELOC.
(allocate_dynrelocs_for_symbol): Likewise.

bfd/ChangeLog
bfd/elf32-arm.c

index 86ce07a1c17abe9cd3a18e427aee1867217ce306..198abd027f0bba95974de33df478ea38d1e0d494 100644 (file)
@@ -1,3 +1,13 @@
+2020-01-13  Szabolcs Nagy  <szabolcs.nagy@arm.com>
+
+       Backported from master
+       2020-01-10  Szabolcs Nagy  <szabolcs.nagy@arm.com>
+
+       PR ld/22269
+       * elf32-arm.c (elf32_arm_final_link_relocate): Use
+       UNDEFWEAK_NO_DYNAMIC_RELOC.
+       (allocate_dynrelocs_for_symbol): Likewise.
+
 2019-10-20  John David Anglin  <danglin@gcc.gnu.org>
 
        * elf32-hppa.c (elf32_hppa_size_dynamic_sections): Provide 8-byte
index cce796dafd9457c520799ada452b2548a1f6c266..21cf4b08fd1fbbf8acb4b40c41b6e0006d491ac1 100644 (file)
@@ -11572,8 +11572,7 @@ elf32_arm_final_link_relocate (reloc_howto_type *           howto,
                  if (dynreloc_st_type == STT_GNU_IFUNC)
                    outrel.r_info = ELF32_R_INFO (0, R_ARM_IRELATIVE);
                  else if (bfd_link_pic (info)
-                          && (ELF_ST_VISIBILITY (h->other) == STV_DEFAULT
-                              || h->root.type != bfd_link_hash_undefweak))
+                          && !UNDEFWEAK_NO_DYNAMIC_RELOC (info, h))
                    outrel.r_info = ELF32_R_INFO (0, R_ARM_RELATIVE);
                  else
                    {
@@ -16527,8 +16526,7 @@ allocate_dynrelocs_for_symbol (struct elf_link_hash_entry *h, void * inf)
               GOT entry's R_ARM_IRELATIVE relocation.  */
            elf32_arm_allocate_irelocs (info, htab->root.srelgot, 1);
          else if (bfd_link_pic (info)
-                  && (ELF_ST_VISIBILITY (h->other) == STV_DEFAULT
-                      || h->root.type != bfd_link_hash_undefweak))
+                  && !UNDEFWEAK_NO_DYNAMIC_RELOC (info, h))
            /* Reserve room for the GOT entry's R_ARM_RELATIVE relocation.  */
            elf32_arm_allocate_dynrelocs (info, htab->root.srelgot, 1);
          else if (htab->fdpic_p && tls_type == GOT_NORMAL)