From: Alan Modra Date: Wed, 19 Jan 2022 00:23:53 +0000 (+1030) Subject: PowerPC64 DT_RELR local GOT X-Git-Tag: binutils-2_38~65 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=8f22c9532b0a568046b8d05aa90631be822bba5f;p=thirdparty%2Fbinutils-gdb.git PowerPC64 DT_RELR local GOT Fixes another case where we end up with superfluous R_PPC64_NONE. * elf64-ppc.c (ppc64_elf_size_dynamic_sections): Don't allocate space for GOT relocs against non-TLS local syms when enable_dt_relr. (ppc64_elf_layout_multitoc): Likewise. --- diff --git a/bfd/elf64-ppc.c b/bfd/elf64-ppc.c index aeae3b7e640..0ac96afe5a3 100644 --- a/bfd/elf64-ppc.c +++ b/bfd/elf64-ppc.c @@ -10318,8 +10318,9 @@ ppc64_elf_size_dynamic_sections (bfd *output_bfd, htab->got_reli_size += rel_size; } else if (bfd_link_pic (info) - && !(ent->tls_type != 0 - && bfd_link_executable (info))) + && (ent->tls_type == 0 + ? !info->enable_dt_relr + : !bfd_link_executable (info))) { asection *srel = ppc64_elf_tdata (ibfd)->relgot; srel->size += rel_size; @@ -12815,8 +12816,9 @@ ppc64_elf_layout_multitoc (struct bfd_link_info *info) htab->got_reli_size += rel_size; } else if (bfd_link_pic (info) - && !(ent->tls_type != 0 - && bfd_link_executable (info))) + && (ent->tls_type == 0 + ? !info->enable_dt_relr + : !bfd_link_executable (info))) { asection *srel = ppc64_elf_tdata (ibfd)->relgot; srel->size += rel_size;