diff options
author | Maciej W. Rozycki <macro@linux-mips.org> | 2012-08-28 20:13:27 +0000 |
---|---|---|
committer | Maciej W. Rozycki <macro@linux-mips.org> | 2012-08-28 20:13:27 +0000 |
commit | aed81c4e9cc4f24eba4da3564f0e99bd667188c7 (patch) | |
tree | b3df06fec4f5c3ee4d457bae3020283f5b1357ef /bfd/elflink.c | |
parent | 18c1b81abee59b25ba6b68f7c715843b870f9bc6 (diff) | |
download | gdb-aed81c4e9cc4f24eba4da3564f0e99bd667188c7.zip gdb-aed81c4e9cc4f24eba4da3564f0e99bd667188c7.tar.gz gdb-aed81c4e9cc4f24eba4da3564f0e99bd667188c7.tar.bz2 |
* elflink.c (_bfd_elf_merge_symbol): Also override the version
a dynamic symbol defaulted to if preempted with a hidden or
internal definition.
Diffstat (limited to 'bfd/elflink.c')
-rw-r--r-- | bfd/elflink.c | 30 |
1 files changed, 16 insertions, 14 deletions
diff --git a/bfd/elflink.c b/bfd/elflink.c index 7335114..3ef3f9b 100644 --- a/bfd/elflink.c +++ b/bfd/elflink.c @@ -1210,23 +1210,25 @@ _bfd_elf_merge_symbol (bfd *abfd, vh->root.type = h->root.type; h->root.type = bfd_link_hash_indirect; (*bed->elf_backend_copy_indirect_symbol) (info, vh, h); - /* Protected symbols will override the dynamic definition - with default version. */ - if (ELF_ST_VISIBILITY (sym->st_other) == STV_PROTECTED) + + h->root.u.i.link = (struct bfd_link_hash_entry *) vh; + if (ELF_ST_VISIBILITY (sym->st_other) != STV_PROTECTED) { - h->root.u.i.link = (struct bfd_link_hash_entry *) vh; - vh->dynamic_def = 1; - vh->ref_dynamic = 1; + /* If the new symbol is hidden or internal, completely undo + any dynamic link state. */ + (*bed->elf_backend_hide_symbol) (info, h, TRUE); + h->forced_local = 0; + h->ref_dynamic = 0; } else - { - h->root.type = vh->root.type; - vh->ref_dynamic = 0; - /* We have to hide it here since it was made dynamic - global with extra bits when the symbol info was - copied from the old dynamic definition. */ - (*bed->elf_backend_hide_symbol) (info, vh, TRUE); - } + h->ref_dynamic = 1; + + h->def_dynamic = 0; + h->dynamic_def = 0; + /* FIXME: Should we check type and size for protected symbol? */ + h->size = 0; + h->type = 0; + h = vh; } else |