summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlan Modra <amodra@bigpond.net.au>2011-10-25 02:52:23 +0000
committerAlan Modra <amodra@bigpond.net.au>2011-10-25 02:52:23 +0000
commit018eb75ad364893ea051314d971b23d50d483eff (patch)
tree58a4ffdda97e8793c8d45c5f1e1c2b31f6b53f73
parenta5922217f9fc547da9768a5ad3738488c0771d2b (diff)
downloadgdb-018eb75ad364893ea051314d971b23d50d483eff.tar.gz
Apply mainline patches
2011-10-08 Alan Modra <amodra@gmail.com> * elflink.c (elf_link_output_extsym): Strip defined plugin symbols even when strip_discarded is false.
-rw-r--r--bfd/ChangeLog4
-rw-r--r--bfd/elflink.c10
2 files changed, 10 insertions, 4 deletions
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 <amodra@gmail.com>
Apply mainline patches
+ 2011-10-08 Alan Modra <amodra@gmail.com>
+ * elflink.c (elf_link_output_extsym): Strip defined plugin symbols
+ even when strip_discarded is false.
+
2011-09-30 Alan Modra <amodra@gmail.com>
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)