]> sourceware.org Git - glibc.git/commit
hppa: Fix bind-now audit (BZ #28857)
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>
Fri, 4 Feb 2022 18:54:59 +0000 (15:54 -0300)
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>
Wed, 9 Feb 2022 11:47:42 +0000 (08:47 -0300)
commit9e94f57484a2aba0fe67ea2059b5843f651887c2
tree5a3bc4b7d6190b91fe7ad8f36ae5c61c4a6a6396
parent3d9f171bfb5325bd5f427e9fc386453358c6e840
hppa: Fix bind-now audit (BZ #28857)

On hppa, a function pointer returned by la_symbind is actually a function
descriptor has the plabel bit set (bit 30).  This must be cleared to get
the actual address of the descriptor.  If the descriptor has been bound,
the first word of the descriptor is the physical address of theA function,
otherwise, the first word of the descriptor points to a trampoline in the
PLT.

This patch also adds a workaround on tests because on hppa (and it seems
to be the only ABI I have see it), some shared library adds a dynamic PLT
relocation to am empty symbol name:

$ readelf -r elf/tst-audit25mod1.so
[...]
Relocation section '.rela.plt' at offset 0x464 contains 6 entries:
 Offset     Info    Type            Sym.Value  Sym. Name + Addend
00002008  00000081 R_PARISC_IPLT                508
[...]

It breaks some assumptions on the test, where a symbol with an empty
name ("") is passed on la_symbind.

Checked on x86_64-linux-gnu and hppa-linux-gnu.
elf/Makefile
elf/dl-audit.c
elf/tst-auditmod24a.c
elf/tst-auditmod24d.c
elf/tst-auditmod25.c
sysdeps/hppa/dl-lookupcfg.h
This page took 0.04296 seconds and 5 git commands to generate.