* elflink.c (_bfd_elf_gc_mark_rsec): Mark weakdef syms too.
(_bfd_elf_fix_symbol_flags): When a weakdef is def_regular, clear the correct h->u.weakdef.
This commit is contained in:
parent
4b2d20a563
commit
4e6b54a6ea
2 changed files with 21 additions and 11 deletions
|
@ -1,3 +1,9 @@
|
|||
2012-02-08 Alan Modra <amodra@gmail.com>
|
||||
|
||||
* elflink.c (_bfd_elf_gc_mark_rsec): Mark weakdef syms too.
|
||||
(_bfd_elf_fix_symbol_flags): When a weakdef is def_regular, clear
|
||||
the correct h->u.weakdef.
|
||||
|
||||
2012-02-07 Alan Modra <amodra@gmail.com>
|
||||
|
||||
* elf.c (elf_find_function): Don't use internal_elf_sym.
|
||||
|
|
|
@ -2510,23 +2510,21 @@ _bfd_elf_fix_symbol_flags (struct elf_link_hash_entry *h,
|
|||
over to the real definition. */
|
||||
if (h->u.weakdef != NULL)
|
||||
{
|
||||
struct elf_link_hash_entry *weakdef;
|
||||
/* If the real definition is defined by a regular object file,
|
||||
don't do anything special. See the longer description in
|
||||
_bfd_elf_adjust_dynamic_symbol, below. */
|
||||
if (h->u.weakdef->def_regular)
|
||||
h->u.weakdef = NULL;
|
||||
else
|
||||
{
|
||||
struct elf_link_hash_entry *weakdef = h->u.weakdef;
|
||||
|
||||
weakdef = h->u.weakdef;
|
||||
while (h->root.type == bfd_link_hash_indirect)
|
||||
h = (struct elf_link_hash_entry *) h->root.u.i.link;
|
||||
|
||||
BFD_ASSERT (h->root.type == bfd_link_hash_defined
|
||||
|| h->root.type == bfd_link_hash_defweak);
|
||||
BFD_ASSERT (weakdef->def_dynamic);
|
||||
|
||||
/* If the real definition is defined by a regular object file,
|
||||
don't do anything special. See the longer description in
|
||||
_bfd_elf_adjust_dynamic_symbol, below. */
|
||||
if (weakdef->def_regular)
|
||||
h->u.weakdef = NULL;
|
||||
else
|
||||
{
|
||||
BFD_ASSERT (weakdef->root.type == bfd_link_hash_defined
|
||||
|| weakdef->root.type == bfd_link_hash_defweak);
|
||||
(*bed->elf_backend_copy_indirect_symbol) (eif->info, weakdef, h);
|
||||
|
@ -11575,6 +11573,12 @@ _bfd_elf_gc_mark_rsec (struct bfd_link_info *info, asection *sec,
|
|||
|| h->root.type == bfd_link_hash_warning)
|
||||
h = (struct elf_link_hash_entry *) h->root.u.i.link;
|
||||
h->mark = 1;
|
||||
/* If this symbol is weak and there is a non-weak definition, we
|
||||
keep the non-weak definition because many backends put
|
||||
dynamic reloc info on the non-weak definition for code
|
||||
handling copy relocs. */
|
||||
if (h->u.weakdef != NULL)
|
||||
h->u.weakdef->mark = 1;
|
||||
return (*gc_mark_hook) (sec, info, cookie->rel, h, NULL);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue