]> sourceware.org Git - glibc.git/commit
elf: Fix localplt.awk for DT_RELR-enabled builds (BZ 31978)
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>
Tue, 16 Jul 2024 10:57:45 +0000 (07:57 -0300)
committerAndreas K. Hüttel <dilfridge@gentoo.org>
Fri, 19 Jul 2024 20:50:26 +0000 (22:50 +0200)
commit4f047d9edecb1a9b796a9a904dcd42bd3cc3d3b6
tree174897a8837194f98e53508a9df9ec94d05b4d1b
parent6b7e2e1d6139b1fb61b911ab897a956042bf7f89
elf: Fix localplt.awk for DT_RELR-enabled builds (BZ 31978)

For each input readelf output, localplt.awk parses each 'Relocation
section' entry, checks its offset against the dynamic section entry, and
saves each DT_JMPREL, DT_RELA, and DT_REL offset value it finds. After
all lines are read, the script checks if any segment offset differed
from 0, meaning at least one 'Relocation section' was matched.

However, if the shared object was built with RELR support and the static
linker could place all the relocation on DT_RELR, there would be no
DT_JMPREL, DT_RELA, and DT_REL entries; only a DT_RELR.

For the current three ABIs that support (aarch64, x86, and powerpc64),
the powerpc64 ld.so shows the behavior above. Both x86_64 and aarch64
show extra relocations on '.rela.dyn', which makes the script check to
succeed.

This patch fixes by handling DT_RELR, where the offset is checked
against the dynamic section entries and if the shared object contains an
entry it means that there are no extra PLT entries (since all
relocations are relative).

It fixes the elf/check-localplt failure on powerpc.

Checked with a build/check for aarch64-linux-gnu, x86_64-linux-gnu,
i686-linux-gnu, arm-linux-gnueabihf, s390x-linux-gnu, powerpc-linux-gnu,
powerpc64-linux-gnu, and powerpc64le-linux-gnu.
Reviewed-by: Carlos O'Donell <carlos@redhat.com>
scripts/localplt.awk
This page took 0.036082 seconds and 5 git commands to generate.