aboutsummaryrefslogtreecommitdiff
path: root/bfd/elf32-cris.c
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2005-02-01 01:11:27 +0000
committerAlan Modra <amodra@gmail.com>2005-02-01 01:11:27 +0000
commit77cfaee698fa7e54d8d7ff28f433fcfaeaf5acef (patch)
treeb003dfda8247b72ef7ccbc0c8b48e4048be8f6a7 /bfd/elf32-cris.c
parentc4db44a43fdfc8eab01846bcb89204002cde2de3 (diff)
downloadfsf-binutils-gdb-77cfaee698fa7e54d8d7ff28f433fcfaeaf5acef.zip
fsf-binutils-gdb-77cfaee698fa7e54d8d7ff28f433fcfaeaf5acef.tar.gz
fsf-binutils-gdb-77cfaee698fa7e54d8d7ff28f433fcfaeaf5acef.tar.bz2
include/
* bfdlink.h (bfd_link_repair_undef_list): Declare. bfd/ * elf64-ppc.c (ppc64_elf_check_directives): Move undefs list fixup.. * linker.c (bfd_link_repair_undef_list): ..to new function, but don't remove anything but new and undefweak. * elflink.c (_bfd_elf_link_create_dynamic_sections): Override any existing _DYNAMIC. (_bfd_elf_create_dynamic_sections): Formatting. (bfd_elf_record_link_assignment): Call bfd_link_repair_undef_list. (_bfd_elf_merge_symbol): Don't handle as-needed syms here. (struct elf_smash_data): New. (elf_smash_syms): New function. (elf_link_add_object_symbols): Call elf_smash_syms. Don't add unneeded dynamic objects to loaded list. (elf_link_output_extsym): Don't handle as-needed here. Strip bfd_link_hash_new symbols. * elf32-cris.c (elf_cris_discard_excess_program_dynamics): Don't delref when dynindx is already -1. * elf64-alpha.c (elf64_alpha_output_extsym): Strip bfd_link_hash_new symbols. * elfxx-mips.c (mips_elf_output_extsym): Likewise. ld/ * ld.texinfo: Clarify --as-needed operation.
Diffstat (limited to 'bfd/elf32-cris.c')
-rw-r--r--bfd/elf32-cris.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/bfd/elf32-cris.c b/bfd/elf32-cris.c
index 44cae03..c80146b 100644
--- a/bfd/elf32-cris.c
+++ b/bfd/elf32-cris.c
@@ -3130,6 +3130,7 @@ elf_cris_discard_excess_program_dynamics (h, inf)
introduce new problems. Of course we don't do this if we're
exporting all dynamic symbols. */
if (! info->export_dynamic
+ && h->root.dynindx != -1
&& !h->root.def_dynamic
&& !h->root.ref_dynamic)
{