Re: PowerPC64 DT_RELR
authorAlan Modra <amodra@gmail.com>
Tue, 18 Jan 2022 23:05:00 +0000 (09:35 +1030)
committerAlan Modra <amodra@gmail.com>
Tue, 18 Jan 2022 23:14:15 +0000 (09:44 +1030)
HJ: "There are 238 R_PPC64_NONEs in libc.so.6 alone."
Indeed, let's make them go away.  I had the SYMBOL_REFERENCES_LOCAL
test in the wrong place.  check_relocs is too early to know whether a
symbol is dynamic in a shared library.  Lots of glibc symbols are made
local by version script, but that doesn't happen until
size_dynamic_sections.

* elf64-ppc.c (ppc64_elf_check_relocs): Don't count relative relocs
here depending on SYMBOL_REFERENCES_LOCAL.
(dec_dynrel_count): Likewise.
(allocate_dynrelocs): Do so here instead.

bfd/elf64-ppc.c

index 923c7a3b4073ea39c8e2b6695d227f86703576f9..aeae3b7e640556b9f943eecd45da2be704ac0e76 100644 (file)
@@ -5390,8 +5390,7 @@ ppc64_elf_check_relocs (bfd *abfd, struct bfd_link_info *info,
                  if ((r_type == R_PPC64_ADDR64 || r_type == R_PPC64_TOC)
                      && rel->r_offset % 2 == 0
                      && sec->alignment_power != 0
-                     && ((!NO_OPD_RELOCS && is_opd)
-                         || (!ifunc && SYMBOL_REFERENCES_LOCAL (info, h))))
+                     && ((!NO_OPD_RELOCS && is_opd) || !ifunc))
                    p->rel_count += 1;
                }
              else
@@ -7287,8 +7286,7 @@ dec_dynrel_count (const Elf_Internal_Rela *rel,
                  && sec->alignment_power != 0
                  && ((!NO_OPD_RELOCS
                       && ppc64_elf_section_data (sec)->sec_type == sec_opd)
-                     || (h->type != STT_GNU_IFUNC
-                         && SYMBOL_REFERENCES_LOCAL (info, h))))
+                     || h->type != STT_GNU_IFUNC))
                p->rel_count -= 1;
              p->count -= 1;
              if (p->count == 0)
@@ -10016,7 +10014,7 @@ allocate_dynrelocs (struct elf_link_hash_entry *h, void *inf)
          if (eh->elf.type == STT_GNU_IFUNC)
            sreloc = htab->elf.irelplt;
          count = p->count;
-         if (info->enable_dt_relr)
+         if (info->enable_dt_relr && SYMBOL_REFERENCES_LOCAL (info, h))
            count -= p->rel_count;
          sreloc->size += count * sizeof (Elf64_External_Rela);
        }