From: H.J. Lu Date: Thu, 7 Jul 2005 17:44:58 +0000 (+0000) Subject: 2005-07-07 H.J. Lu X-Git-Tag: gdb-csl-arm-20051020-branchpoint~802 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=9968d831f9298e2dc60de7a77013c7b173441951;p=external%2Fbinutils.git 2005-07-07 H.J. Lu PR 975 * elflink.c (_bfd_elf_symbol_refs_local_p): Only undefined symbol with default visibility is local. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 04421f4..8bc7644 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2005-07-07 H.J. Lu + + PR 975 + * elflink.c (_bfd_elf_symbol_refs_local_p): Only undefined + symbol with default visibility is local. + 2005-07-07 Ben Elliston * config.bfd: Mark m68*-*-rtemscoff as obsolete. diff --git a/bfd/elflink.c b/bfd/elflink.c index 6177f53..4fac5ae 100644 --- a/bfd/elflink.c +++ b/bfd/elflink.c @@ -2572,8 +2572,10 @@ _bfd_elf_symbol_refs_local_p (struct elf_link_hash_entry *h, if (ELF_COMMON_DEF_P (h)) /* Do nothing. */; /* If we don't have a definition in a regular file, then we can't - resolve locally. The sym is either undefined or dynamic. */ - else if (!h->def_regular) + resolve locally unless it has non-default visibility . The sym + is either undefined or dynamic. */ + else if (!h->def_regular + && ELF_ST_VISIBILITY (h->other) == STV_DEFAULT) return FALSE; /* Forced local symbols resolve locally. */