From 10be1b6abecee852928787c0f92356ec3eb38dce Mon Sep 17 00:00:00 2001 From: Dave Korn Date: Thu, 10 Mar 2011 10:27:50 +0000 Subject: [PATCH] [PATCH] Respect symbol wrappers when computing symbol resolutions. ld/ChangeLog: 2011-03-10 Dave Korn * plugin.c (get_symbols): Use wrapped lookup for undefined symbols. --- ld/ChangeLog | 4 ++++ ld/plugin.c | 9 ++++++--- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/ld/ChangeLog b/ld/ChangeLog index 8283becc8dc..cdc9198d8e6 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,7 @@ +2011-03-10 Dave Korn + + * plugin.c (get_symbols): Use wrapped lookup for undefined symbols. + 2011-03-10 Dave Korn * ldlang.c (lang_check): Don't run checks on dummy IR BFDs. diff --git a/ld/plugin.c b/ld/plugin.c index 2fd82910c5d..d4bbfe78520 100644 --- a/ld/plugin.c +++ b/ld/plugin.c @@ -456,9 +456,12 @@ get_symbols (const void *handle, int nsyms, struct ld_plugin_symbol *syms) struct bfd_link_hash_entry *blhe; bfd_boolean ironly; asection *owner_sec; - - blhe = bfd_link_hash_lookup (link_info.hash, syms[n].name, - FALSE, FALSE, TRUE); + if (syms[n].def != LDPK_UNDEF) + blhe = bfd_link_hash_lookup (link_info.hash, syms[n].name, + FALSE, FALSE, TRUE); + else + blhe = bfd_wrapped_link_hash_lookup (link_info.output_bfd, &link_info, + syms[n].name, FALSE, FALSE, TRUE); if (!blhe) { syms[n].resolution = LDPR_UNKNOWN; -- 2.30.2