ld.so: Support moving versioned symbols between sonames [BZ #24741]
authorFlorian Weimer <fweimer@redhat.com>
Fri, 28 Jun 2019 08:12:50 +0000 (10:12 +0200)
committerFlorian Weimer <fweimer@redhat.com>
Fri, 28 Jun 2019 08:15:38 +0000 (10:15 +0200)
commitf0b2132b35248c1f4a80f62a2c38cddcc802aa8c
tree32e3b30bba3d07b48c40035d8a4011ed39a212ef
parent17432d7150bdab3bce2ea66c70ad6c920f54077a
ld.so: Support moving versioned symbols between sonames [BZ #24741]

This change should be fully backwards-compatible because the old
code aborted the load if a soname mismatch was encountered
(instead of searching further for a matching symbol).  This means
that no different symbols are found.

The soname check was explicitly disabled for the skip_map != NULL
case.  However, this only happens with dl(v)sym and RTLD_NEXT,
and those lookups do not come with a verneed entry that could be used
for the check.

The error check was already explicitly disabled for the skip_map !=
NULL case, that is, when dl(v)sym was called with RTLD_NEXT.  But
_dl_vsym always sets filename in the struct r_found_version argument
to NULL, so the check was not active anyway.  This means that
symbol lookup results for the skip_map != NULL case do not change,
either.
12 files changed:
ChangeLog
NEWS
elf/Makefile
elf/dl-lookup.c
elf/tst-sonamemove-dlopen.c [new file with mode: 0644]
elf/tst-sonamemove-link.c [new file with mode: 0644]
elf/tst-sonamemove-linkmod1.c [new file with mode: 0644]
elf/tst-sonamemove-linkmod1.map [new file with mode: 0644]
elf/tst-sonamemove-runmod1.c [new file with mode: 0644]
elf/tst-sonamemove-runmod1.map [new file with mode: 0644]
elf/tst-sonamemove-runmod2.c [new file with mode: 0644]
elf/tst-sonamemove-runmod2.map [new file with mode: 0644]