diff options
author | Will Newton <willnewton@sourceware.org> | 2013-03-27 09:48:46 +0000 |
---|---|---|
committer | Will Newton <willnewton@sourceware.org> | 2013-03-27 09:48:46 +0000 |
commit | 319438823faf122665c28991f1e2ef5718458d69 (patch) | |
tree | 8376d3c267d26e759a70f0688b42bf43c89fd23d /bfd/elf32-arm.c | |
parent | 826ecc4da3e4c9a2aac873e7f4cc28cde946476a (diff) | |
download | gdb-319438823faf122665c28991f1e2ef5718458d69.zip gdb-319438823faf122665c28991f1e2ef5718458d69.tar.gz gdb-319438823faf122665c28991f1e2ef5718458d69.tar.bz2 |
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 | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/bfd/elf32-arm.c b/bfd/elf32-arm.c index 78c2d1d..ec33916 100644 --- a/bfd/elf32-arm.c +++ b/bfd/elf32-arm.c @@ -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); } |