From: Alan Modra Date: Thu, 4 Oct 2001 16:09:03 +0000 (+0000) Subject: * elf32-mips.c (_bfd_mips_elf_copy_indirect_symbol): Bail out after X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=58e3d09d2a5873fe862f5d080786a09801cadc7c;p=binutils-gdb.git * elf32-mips.c (_bfd_mips_elf_copy_indirect_symbol): Bail out after copying flags if this is a weakdef. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 1f058878cec..e97b1b85742 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2001-10-04 Alan Modra + + * elf32-mips.c (_bfd_mips_elf_copy_indirect_symbol): Bail out after + copying flags if this is a weakdef. + 2001-10-04 Alan Modra * elf-bfd.h (struct elf_link_hash_entry): Reorganise for better diff --git a/bfd/elf32-mips.c b/bfd/elf32-mips.c index fd79bbaec62..6f39d9f2b75 100644 --- a/bfd/elf32-mips.c +++ b/bfd/elf32-mips.c @@ -8074,7 +8074,8 @@ _bfd_mips_elf_gc_sweep_hook (abfd, info, sec, relocs) /* Copy data from a MIPS ELF indirect symbol to its direct symbol, hiding the old indirect symbol. Process additional relocation - information. */ + information. Also called for weakdefs, in which case we just let + _bfd_elf_link_hach_copy_indirect copy the flags for us. */ static void _bfd_mips_elf_copy_indirect_symbol (dir, ind) @@ -8084,6 +8085,9 @@ _bfd_mips_elf_copy_indirect_symbol (dir, ind) _bfd_elf_link_hash_copy_indirect (dir, ind); + if (dir == ind->weakdef) + return; + dirmips = (struct mips_elf_link_hash_entry *) dir; indmips = (struct mips_elf_link_hash_entry *) ind; dirmips->possibly_dynamic_relocs += indmips->possibly_dynamic_relocs;