* emultempl/elf32.em (gld${EMULATION_NAME}_after_open): Test
authorAlan Modra <amodra@gmail.com>
Fri, 26 Apr 2013 01:26:45 +0000 (01:26 +0000)
committerAlan Modra <amodra@gmail.com>
Fri, 26 Apr 2013 01:26:45 +0000 (01:26 +0000)
unresolved_syms_in_shared_libs rather than !executable to
determine whether to load DT_NEEDED libraries.

ld/ChangeLog
ld/emultempl/elf32.em

index ff69706efc67a3ebe97a89515e9ee1d67f4c8019..7f94840db3404fdd5c50e099ee5b8857e321a4dd 100644 (file)
@@ -1,3 +1,9 @@
+2013-04-26  Alan Modra  <amodra@gmail.com>
+
+       * emultempl/elf32.em (gld${EMULATION_NAME}_after_open): Test
+       unresolved_syms_in_shared_libs rather than !executable to
+       determine whether to load DT_NEEDED libraries.
+
 2013-04-25  Alan Modra  <amodra@gmail.com>
 
        * Makefile.am (ALL_EMULATION_SOURCES): Add eelf32lppclinux.c.
index ea7bad08e7ef189bfb2a66d9b7d65ebe69bce4f6..83a554fa7495e169e02f9157ac7bffc1609282b7 100644 (file)
@@ -1178,13 +1178,16 @@ gld${EMULATION_NAME}_after_open (void)
       int force;
 
       /* If the lib that needs this one was --as-needed and wasn't
-        found to be needed, then this lib isn't needed either.  Skip
-        the lib when creating a shared object unless we are copying
-        DT_NEEDED entres.  */
+        found to be needed, then this lib isn't needed either.  */
       if (l->by != NULL
-         && ((bfd_elf_get_dyn_lib_class (l->by) & DYN_AS_NEEDED) != 0
-             || (!link_info.executable
-                 && bfd_elf_get_dyn_lib_class (l->by) & DYN_NO_ADD_NEEDED) != 0))
+         && (bfd_elf_get_dyn_lib_class (l->by) & DYN_AS_NEEDED) != 0)
+       continue;
+
+      /* Skip the lib if --no-copy-dt-needed-entries and
+        --allow-shlib-undefined is in effect.  */
+      if (l->by != NULL
+         && link_info.unresolved_syms_in_shared_libs == RM_IGNORE
+         && (bfd_elf_get_dyn_lib_class (l->by) & DYN_NO_ADD_NEEDED) != 0)
        continue;
 
       /* If we've already seen this file, skip it.  */