From: Alan Modra Date: Tue, 25 Oct 2011 02:52:23 +0000 (+0000) Subject: Apply mainline patches X-Git-Tag: binutils-2_22~60 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=fac68c2951e62ed105258b64bcda367fdedc9dd0;p=thirdparty%2Fbinutils-gdb.git Apply mainline patches 2011-10-08 Alan Modra * elflink.c (elf_link_output_extsym): Strip defined plugin symbols even when strip_discarded is false. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index b4ee5865910..1399037e781 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,6 +1,10 @@ 2011-10-25 Alan Modra Apply mainline patches + 2011-10-08 Alan Modra + * elflink.c (elf_link_output_extsym): Strip defined plugin symbols + even when strip_discarded is false. + 2011-09-30 Alan Modra PR ld/13235 * elf64-ppc.c (struct ppc64_elf_obj_tdata): Add ha_relocs_not_using_r2. diff --git a/bfd/elflink.c b/bfd/elflink.c index 33a1a63cb42..c1b5bee357b 100644 --- a/bfd/elflink.c +++ b/bfd/elflink.c @@ -8679,10 +8679,12 @@ elf_link_output_extsym (struct bfd_hash_entry *bh, void *data) && bfd_hash_lookup (finfo->info->keep_hash, h->root.root.string, FALSE, FALSE) == NULL) strip = TRUE; - else if (finfo->info->strip_discarded - && (h->root.type == bfd_link_hash_defined - || h->root.type == bfd_link_hash_defweak) - && elf_discarded_section (h->root.u.def.section)) + else if ((h->root.type == bfd_link_hash_defined + || h->root.type == bfd_link_hash_defweak) + && ((finfo->info->strip_discarded + && elf_discarded_section (h->root.u.def.section)) + || (h->root.u.def.section->owner != NULL + && (h->root.u.def.section->owner->flags & BFD_PLUGIN) != 0))) strip = TRUE; else if ((h->root.type == bfd_link_hash_undefined || h->root.type == bfd_link_hash_undefweak)