aboutsummaryrefslogtreecommitdiff
path: root/elf/tst-sonamemove-runmod1.map
diff options
context:
space:
mode:
authorFlorian Weimer <fweimer@redhat.com>2019-06-28 10:12:50 +0200
committerFlorian Weimer <fweimer@redhat.com>2019-06-28 10:15:38 +0200
commitf0b2132b35248c1f4a80f62a2c38cddcc802aa8c (patch)
tree32e3b30bba3d07b48c40035d8a4011ed39a212ef /elf/tst-sonamemove-runmod1.map
parent17432d7150bdab3bce2ea66c70ad6c920f54077a (diff)
downloadglibc-f0b2132b35248c1f4a80f62a2c38cddcc802aa8c.tar
glibc-f0b2132b35248c1f4a80f62a2c38cddcc802aa8c.tar.gz
glibc-f0b2132b35248c1f4a80f62a2c38cddcc802aa8c.tar.bz2
glibc-f0b2132b35248c1f4a80f62a2c38cddcc802aa8c.zip
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.
Diffstat (limited to 'elf/tst-sonamemove-runmod1.map')
-rw-r--r--elf/tst-sonamemove-runmod1.map3
1 files changed, 3 insertions, 0 deletions
diff --git a/elf/tst-sonamemove-runmod1.map b/elf/tst-sonamemove-runmod1.map
new file mode 100644
index 0000000000..2ea81c6e6f
--- /dev/null
+++ b/elf/tst-sonamemove-runmod1.map
@@ -0,0 +1,3 @@
+SONAME_MOVE {
+ global: other_function;
+};