diff options
author | willnewton <willnewton> | 2013-03-27 09:51:45 +0000 |
---|---|---|
committer | willnewton <willnewton> | 2013-03-27 09:51:45 +0000 |
commit | f0fd45ddaac94179e9385f6cdc6e4ccc61a3f50b (patch) | |
tree | e75925ff25983c365cd144418623d78bdc34d964 /bfd/elf32-arm.c | |
parent | 552640e00eb7292cc452ab12caf019f6b8270e1a (diff) | |
download | binutils-redhat-f0fd45ddaac94179e9385f6cdc6e4ccc61a3f50b.tar.gz |
bfd/ChangeLog:
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.
Diffstat (limited to 'bfd/elf32-arm.c')
-rw-r--r-- | bfd/elf32-arm.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/bfd/elf32-arm.c b/bfd/elf32-arm.c index ec339169e5..9a97cbfc9a 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. */ |