OSDN Git Service

[PATCH] Respect symbol wrappers when computing symbol resolutions.
authordavek <davek>
Thu, 10 Mar 2011 10:27:50 +0000 (10:27 +0000)
committerdavek <davek>
Thu, 10 Mar 2011 10:27:50 +0000 (10:27 +0000)
ld/ChangeLog:

2011-03-10  Dave Korn  <dave.korn.cygwin@gmail.com>

* plugin.c (get_symbols): Use wrapped lookup for undefined symbols.

ld/ChangeLog
ld/plugin.c

index 8283bec..cdc9198 100644 (file)
@@ -1,5 +1,9 @@
 2011-03-10  Dave Korn  <dave.korn.cygwin@gmail.com>
 
+       * plugin.c (get_symbols): Use wrapped lookup for undefined symbols.
+
+2011-03-10  Dave Korn  <dave.korn.cygwin@gmail.com>
+
        * ldlang.c (lang_check): Don't run checks on dummy IR BFDs.
 
 2011-03-10  Dave Korn  <dave.korn.cygwin@gmail.com>
index 2fd8291..d4bbfe7 100644 (file)
@@ -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;