From: Alan Modra Date: Tue, 12 Apr 2005 12:22:11 +0000 (+0000) Subject: * emultempl/elf32.em (gld${EMULATION_NAME}_stat_needed): Ignore X-Git-Tag: binutils-2_16~48 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=959c0beba7a19da1fbc5cb643c6550cfaa56000a;p=thirdparty%2Fbinutils-gdb.git * emultempl/elf32.em (gld${EMULATION_NAME}_stat_needed): Ignore as_needed libs that were not needed. (gld${EMULATION_NAME}_check_needed): Likewise. --- diff --git a/ld/ChangeLog b/ld/ChangeLog index 8e3f5cb65e6..5d223140962 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,9 @@ +2005-04-12 Alan Modra + + * emultempl/elf32.em (gld${EMULATION_NAME}_stat_needed): Ignore + as_needed libs that were not needed. + (gld${EMULATION_NAME}_check_needed): Likewise. + 2005-03-24 Nick Clifton * po/fr.po: Updated French translation. diff --git a/ld/emultempl/elf32.em b/ld/emultempl/elf32.em index 8bdf88d5fcb..a5e6739e3fd 100644 --- a/ld/emultempl/elf32.em +++ b/ld/emultempl/elf32.em @@ -226,6 +226,9 @@ gld${EMULATION_NAME}_stat_needed (lang_input_statement_type *s) return; if (s->the_bfd == NULL) return; + if (s->as_needed + && (bfd_elf_get_dyn_lib_class (s->the_bfd) & DYN_AS_NEEDED) != 0) + return; if (bfd_stat (s->the_bfd, &st) != 0) { @@ -733,6 +736,13 @@ gld${EMULATION_NAME}_check_needed (lang_input_statement_type *s) if (global_found) return; + /* If this input file was an as-needed entry, and wasn't found to be + needed at the stage it was linked, then don't say we have loaded it. */ + if (s->as_needed + && (s->the_bfd == NULL + || (bfd_elf_get_dyn_lib_class (s->the_bfd) & DYN_AS_NEEDED) != 0)) + return; + if (s->filename != NULL) { const char *f;