From 15b43f483cb30a12d97cbc8d10465e130dd92de6 Mon Sep 17 00:00:00 2001 From: Alan Modra Date: Thu, 15 Apr 2004 02:55:20 +0000 Subject: [PATCH] * elflink.c (_bfd_elf_merge_symbol): Treat weak as strong only when it is a definition. --- bfd/ChangeLog | 5 +++++ bfd/elflink.c | 22 +++++++++++++--------- 2 files changed, 18 insertions(+), 9 deletions(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 7aff007df50..e7148cbe79a 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2004-04-15 H.J. Lu + + * elflink.c (_bfd_elf_merge_symbol): Treat weak as strong only + when it is a definition. + 2004-04-14 Alan Modra * elf32-sparc.c (elf32_sparc_relocate_section): Don't abort diff --git a/bfd/elflink.c b/bfd/elflink.c index 4c27f8840e6..6628db34cce 100644 --- a/bfd/elflink.c +++ b/bfd/elflink.c @@ -887,16 +887,20 @@ _bfd_elf_merge_symbol (bfd *abfd, oldweak = (h->root.type == bfd_link_hash_defweak || h->root.type == bfd_link_hash_undefweak); - /* If a new weak symbol comes from a regular file and the old symbol - comes from a dynamic library, we treat the new one as strong. - Similarly, an old weak symbol from a regular file is treated as - strong when the new symbol comes from a dynamic library. Further, - an old weak symbol from a dynamic library is treated as strong if - the new symbol is from a dynamic library. This reflects the way - glibc's ld.so works. */ - if (!newdyn && olddyn) + /* If a new weak symbol definition comes from a regular file and the + old symbol comes from a dynamic library, we treat the new one as + strong. Similarly, an old weak symbol definition from a regular + file is treated as strong when the new symbol comes from a dynamic + library. Further, an old weak symbol from a dynamic library is + treated as strong if the new symbol is from a dynamic library. + This reflects the way glibc's ld.so works. + + Do this before setting *type_change_ok or *size_change_ok so that + we warn properly when dynamic library symbols are overridden. */ + + if (newdef && !newdyn && olddyn) newweak = FALSE; - if (newdyn) + if (olddef && newdyn) oldweak = FALSE; /* It's OK to change the type if either the existing symbol or the -- 2.30.2