From: Alan Modra Date: Fri, 15 Apr 2005 03:52:53 +0000 (+0000) Subject: PR ld/815 X-Git-Tag: binutils-2_16~38 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d395e2c30db8bd4ad1961c2aee1ed1b432d293f6;p=thirdparty%2Fbinutils-gdb.git PR ld/815 * elflink.c (elf_smash_syms): Clear undef.next if it's not being used as a list pointer. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index b8e236bbd7f..36945c61c54 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2005-04-15 Alan Modra + + PR ld/815 + * elflink.c (elf_smash_syms): Clear undef.next if it's not being + used as a list pointer. + 2005-04-05 Richard Sandiford * elfxx-mips.c (MIPS_ELF_OPTIONS_SECTION_NAME_P): New macro. diff --git a/bfd/elflink.c b/bfd/elflink.c index 0554a0fdc32..914096c017f 100644 --- a/bfd/elflink.c +++ b/bfd/elflink.c @@ -2932,8 +2932,11 @@ elf_smash_syms (struct elf_link_hash_entry *h, void *data) if (h->ref_regular) abort (); - /* Set sym back to newly created state, but keep undefs list pointer. */ + /* Set sym back to newly created state, but keep undef.next if it is + being used as a list pointer. */ bh = h->root.u.undef.next; + if (bh == &h->root) + bh = NULL; if (bh != NULL || inf->htab->root.undefs_tail == &h->root) inf->twiddled = TRUE; (*inf->htab->root.table.newfunc) (&h->root.root,