From: Alan Modra Date: Wed, 3 Jul 2013 09:42:56 +0000 (+0000) Subject: * elf64-ppc.c (ppc64_elf_func_desc_adjust): Don't hide .TOC. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=5295321caf668a06255f545b8deb1fe97a9357d6;p=binutils-gdb.git * elf64-ppc.c (ppc64_elf_func_desc_adjust): Don't hide .TOC. when relocatable. Don't change root.type or type here. (ppc64_elf_set_toc): Set type of .TOC. to STT_OBJECT. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 7511c6cac82..45604ebf661 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2013-07-03 Alan Modra + + * elf64-ppc.c (ppc64_elf_func_desc_adjust): Don't hide .TOC. + when relocatable. Don't change root.type or type here. + (ppc64_elf_set_toc): Set type of .TOC. to STT_OBJECT. + 2013-07-03 Alan Modra * elf64-ppc.c (struct ppc_stub_hash_entry): Delete "addend". diff --git a/bfd/elf64-ppc.c b/bfd/elf64-ppc.c index 21d8263948e..b0a9afb1a96 100644 --- a/bfd/elf64-ppc.c +++ b/bfd/elf64-ppc.c @@ -6547,12 +6547,9 @@ ppc64_elf_func_desc_adjust (bfd *obfd ATTRIBUTE_UNUSED, if (htab == NULL) return FALSE; - if (htab->elf.hgot != NULL) - { - htab->elf.hgot->root.type = bfd_link_hash_new; - htab->elf.hgot->type = STT_OBJECT; - _bfd_elf_link_hash_hide_symbol (info, htab->elf.hgot, TRUE); - } + if (!info->relocatable + && htab->elf.hgot != NULL) + _bfd_elf_link_hash_hide_symbol (info, htab->elf.hgot, TRUE); if (htab->sfpr == NULL) /* We don't have any relocs. */ @@ -11917,6 +11914,7 @@ 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;