mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-19 14:34:07 +08:00
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.
This commit is contained in:
parent
826ecc4da3
commit
319438823f
@ -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
|
||||
|
@ -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);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user