From: Will Newton Date: Wed, 27 Mar 2013 09:51:46 +0000 (+0000) Subject: bfd/ChangeLog: X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=6f820c855cf3f858cea1d9284de4e925889476bf;p=binutils-gdb.git bfd/ChangeLog: 2013-03-20 Will Newton * 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. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 47f757ddf96..6d3e973fbab 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,10 @@ +2013-03-27 Will Newton + + * 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. + 2013-03-27 Will Newton * elf32-arm.c (elf32_arm_final_link_relocate): Avoid emitting a diff --git a/bfd/elf32-arm.c b/bfd/elf32-arm.c index ec339169e52..9a97cbfc9a8 100644 --- a/bfd/elf32-arm.c +++ b/bfd/elf32-arm.c @@ -9139,7 +9139,7 @@ elf32_arm_final_link_relocate (reloc_howto_type * howto, { Elf_Internal_Rela outrel; - if (!SYMBOL_REFERENCES_LOCAL (info, h)) + if (h->dynindx != -1 && !SYMBOL_REFERENCES_LOCAL (info, h)) { /* If the symbol doesn't resolve locally in a static object, we have an undefined reference. If the @@ -13274,7 +13274,7 @@ allocate_dynrelocs_for_symbol (struct elf_link_hash_entry *h, void * inf) if ((tls_type & GOT_TLS_GD) && indx != 0) elf32_arm_allocate_dynrelocs (info, htab->root.srelgot, 1); } - else if (!SYMBOL_REFERENCES_LOCAL (info, h)) + else if (indx != -1 && !SYMBOL_REFERENCES_LOCAL (info, h)) { if (htab->root.dynamic_sections_created) /* Reserve room for the GOT entry's R_ARM_GLOB_DAT relocation. */