From 8f22c9532b0a568046b8d05aa90631be822bba5f Mon Sep 17 00:00:00 2001 From: Alan Modra Date: Wed, 19 Jan 2022 10:53:53 +1030 Subject: [PATCH] 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. --- bfd/elf64-ppc.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) 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; -- 2.30.2