From: Alan Modra Date: Tue, 7 Mar 2017 00:34:19 +0000 (+1030) Subject: PowerPC64 abort due to dynamic relocs on hidden undefweak X-Git-Tag: gdb-8.0-release~473 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b1b07054c08eea65ba8d1a9f771796d686f337e5;p=external%2Fbinutils.git PowerPC64 abort due to dynamic relocs on hidden undefweak ppc64_elf_relocate_section lacked a check which meant that it emitted dynamic relocs against a hidden undefweak symbol for which no dynamic relocs had been allocated. PR 21224 PR 20519 * elf64-ppc.c (ppc64_elf_relocate_section): Add missing dyn_relocs check. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 92682d5..9560ad2 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,10 @@ +2017-03-07 Alan Modra + + PR 21224 + PR 20519 + * elf64-ppc.c (ppc64_elf_relocate_section): Add missing + dyn_relocs check. + 2017-03-05 Alan Modra * elf-bfd.h (struct eh_cie_fde): Add u.cie.per_encoding_aligned8. diff --git a/bfd/elf64-ppc.c b/bfd/elf64-ppc.c index 84cb214..d0673c9 100644 --- a/bfd/elf64-ppc.c +++ b/bfd/elf64-ppc.c @@ -14804,8 +14804,10 @@ ppc64_elf_relocate_section (bfd *output_bfd, break; if (bfd_link_pic (info) - ? ((h != NULL && pc_dynrelocs (h)) - || must_be_dyn_reloc (info, r_type)) + ? ((h == NULL + || h->dyn_relocs != NULL) + && ((h != NULL && pc_dynrelocs (h)) + || must_be_dyn_reloc (info, r_type))) : (h != NULL ? h->dyn_relocs != NULL : ELF_ST_TYPE (sym->st_info) == STT_GNU_IFUNC))