bfd/ChangeLog:
authorWill Newton <willnewton@sourceware.org>
Wed, 27 Mar 2013 09:48:46 +0000 (09:48 +0000)
committerWill Newton <willnewton@sourceware.org>
Wed, 27 Mar 2013 09:48:46 +0000 (09:48 +0000)
2013-03-20  Will Newton  <will.newton@linaro.org>

* elf32-arm.c (elf32_arm_final_link_relocate): Avoid emitting a
dynamic reloc for symbols with dynindx == -1.
(allocate_dynrelocs_for_symbol): Avoid allocating space for a
dynamic reloc for symbols with dynindx == -1.

bfd/ChangeLog
bfd/elf32-arm.c

index e6e6c77..47f757d 100644 (file)
@@ -1,3 +1,10 @@
+2013-03-27  Will Newton  <will.newton@linaro.org>
+
+       * elf32-arm.c (elf32_arm_final_link_relocate): Avoid emitting a
+       dynamic reloc for non-default visibility undefined weaks.
+       (allocate_dynrelocs_for_symbol): Avoid allocating space for a
+       dynamic reloc for non-default visibility undefined weaks.
+
 2013-03-26  Alan Modra  <amodra@gmail.com>
 
        * elflink.c (_bfd_elf_add_default_symbol): Preserve section
index 78c2d1d..ec33916 100644 (file)
@@ -9158,7 +9158,9 @@ 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 (info->shared)
+                 else if (info->shared &&
+                          (ELF_ST_VISIBILITY (h->other) == STV_DEFAULT
+                           || h->root.type != bfd_link_hash_undefweak))
                    outrel.r_info = ELF32_R_INFO (0, R_ARM_RELATIVE);
                  else
                    outrel.r_info = 0;
@@ -13284,7 +13286,8 @@ allocate_dynrelocs_for_symbol (struct elf_link_hash_entry *h, void * inf)
               they all resolve dynamically instead.  Reserve room for the
               GOT entry's R_ARM_IRELATIVE relocation.  */
            elf32_arm_allocate_irelocs (info, htab->root.srelgot, 1);
-         else if (info->shared)
+         else if (info->shared && (ELF_ST_VISIBILITY (h->other) == STV_DEFAULT
+                                   || h->root.type != bfd_link_hash_undefweak))
            /* Reserve room for the GOT entry's R_ARM_RELATIVE relocation.  */
            elf32_arm_allocate_dynrelocs (info, htab->root.srelgot, 1);
        }