diff options
author | Alan Modra <amodra@gmail.com> | 2013-11-05 12:38:51 +1030 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2013-11-15 16:30:18 +1030 |
commit | 3943c5e736b0efccbdc881ddfe589ff86d7e78e2 (patch) | |
tree | b4ecebc5f992fb4fb9d0b1acfadf8c005ce36485 | |
parent | 7d4e3df0837834fa3a5e47d58e6bf3539f4efc22 (diff) | |
download | ppe42-binutils-3943c5e736b0efccbdc881ddfe589ff86d7e78e2.tar.gz ppe42-binutils-3943c5e736b0efccbdc881ddfe589ff86d7e78e2.zip |
Hide ppc64 .TOC. from --export-dynamic
(cherry picked from commit dba6fa9bce92c9f9fcca07269ac8443797bd9338)
-rw-r--r-- | bfd/ChangeLog | 5 | ||||
-rw-r--r-- | bfd/elf64-ppc.c | 15 |
2 files changed, 17 insertions, 3 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 8401292872..fd128199dd 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -2,6 +2,11 @@ Apply changes from mainline to 2.24 2013-11-05 Alan Modra <amodra@gmail.com> + * elf64-ppc.c (ppc64_elf_func_desc_adjust): Make .TOC. defined and + hidden. + (ppc64_elf_set_toc): Adjust. + + 2013-11-05 Alan Modra <amodra@gmail.com> * elf64-ppc.c (struct ppc_link_hash_table): Remove got, plt, relplt, iplt, reliplt. Update all references to use elf.sgot, elf.splt, elf.srelplt, elf.iplt and elf.irelplt. diff --git a/bfd/elf64-ppc.c b/bfd/elf64-ppc.c index adc285f487..136887f25e 100644 --- a/bfd/elf64-ppc.c +++ b/bfd/elf64-ppc.c @@ -6837,7 +6837,18 @@ ppc64_elf_func_desc_adjust (bfd *obfd ATTRIBUTE_UNUSED, if (!info->relocatable && htab->elf.hgot != NULL) - _bfd_elf_link_hash_hide_symbol (info, htab->elf.hgot, TRUE); + { + _bfd_elf_link_hash_hide_symbol (info, htab->elf.hgot, TRUE); + /* Make .TOC. defined so as to prevent it being made dynamic. + The wrong value here is fixed later in ppc64_elf_set_toc. */ + htab->elf.hgot->type = STT_OBJECT; + htab->elf.hgot->root.type = bfd_link_hash_defined; + htab->elf.hgot->root.u.def.value = 0; + htab->elf.hgot->root.u.def.section = bfd_abs_section_ptr; + htab->elf.hgot->def_regular = 1; + htab->elf.hgot->other = ((htab->elf.hgot->other & ~ELF_ST_VISIBILITY (-1)) + | STV_HIDDEN); + } if (htab->sfpr == NULL) /* We don't have any relocs. */ @@ -12329,8 +12340,6 @@ ppc64_elf_set_toc (struct bfd_link_info *info, bfd *obfd) if (htab != NULL && htab->elf.hgot != NULL) { - htab->elf.hgot->type = STT_OBJECT; - htab->elf.hgot->root.type = bfd_link_hash_defined; htab->elf.hgot->root.u.def.value = TOC_BASE_OFF; htab->elf.hgot->root.u.def.section = s; } |