diff options
author | Alan Modra <amodra@bigpond.net.au> | 2005-06-02 13:13:54 +0000 |
---|---|---|
committer | Alan Modra <amodra@bigpond.net.au> | 2005-06-02 13:13:54 +0000 |
commit | 4fe3ce0a828f6650087e5a0d3f147d5fe5d83fd5 (patch) | |
tree | 00cbcac33cd3153f1e487353d06ecd9bf668787b /bfd | |
parent | aa9744dea6e55a058bc8130d39a761135acdd43b (diff) | |
download | binutils-redhat-4fe3ce0a828f6650087e5a0d3f147d5fe5d83fd5.tar.gz |
* elf64-ppc.c (add_symbol_adjust): Set sym visibility to most
restrictive of func code and func descr for undefined syms as well
as defined.
Diffstat (limited to 'bfd')
-rw-r--r-- | bfd/ChangeLog | 6 | ||||
-rw-r--r-- | bfd/elf64-ppc.c | 8 |
2 files changed, 10 insertions, 4 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index cc4031e13a..a37d99c407 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2005-06-02 Alan Modra <amodra@bigpond.net.au> + + * elf64-ppc.c (add_symbol_adjust): Set sym visibility to most + restrictive of func code and func descr for undefined syms as well + as defined. + 2005-05-31 Jim Blandy <jimb@redhat.com> * Makefile.am: Regenerate dependencies with 'make dep-am'. diff --git a/bfd/elf64-ppc.c b/bfd/elf64-ppc.c index 9052a233ea..04fcdc9166 100644 --- a/bfd/elf64-ppc.c +++ b/bfd/elf64-ppc.c @@ -4159,9 +4159,7 @@ add_symbol_adjust (struct elf_link_hash_entry *h, void *inf) else fdh->elf.ref_regular = 1; } - else if (fdh != NULL - && (fdh->elf.root.type == bfd_link_hash_defined - || fdh->elf.root.type == bfd_link_hash_defweak)) + else if (fdh != NULL) { unsigned entry_vis = ELF_ST_VISIBILITY (eh->elf.other) - 1; unsigned descr_vis = ELF_ST_VISIBILITY (fdh->elf.other) - 1; @@ -4170,7 +4168,9 @@ add_symbol_adjust (struct elf_link_hash_entry *h, void *inf) else if (entry_vis > descr_vis) eh->elf.other += descr_vis - entry_vis; - if (eh->elf.root.type == bfd_link_hash_undefined) + if ((fdh->elf.root.type == bfd_link_hash_defined + || fdh->elf.root.type == bfd_link_hash_defweak) + && eh->elf.root.type == bfd_link_hash_undefined) { eh->elf.root.type = bfd_link_hash_undefweak; eh->was_undefined = 1; |