diff options
author | Adhemerval Zanella <adhemerval.zanella@linaro.org> | 2019-04-26 14:08:20 +0200 |
---|---|---|
committer | Florian Weimer <fweimer@redhat.com> | 2019-04-26 14:08:20 +0200 |
commit | 5cbb73004b635e762e20b447c2d93c307cb40f41 (patch) | |
tree | 166775784cb61c04cdda5c9c9a1b9df5ff740dd2 /sysdeps/unix/sysv/linux/socket.c | |
parent | 9b3aac586964f7aee071aa25fef86d53b05d16b2 (diff) | |
download | glibc-5cbb73004b635e762e20b447c2d93c307cb40f41.tar glibc-5cbb73004b635e762e20b447c2d93c307cb40f41.tar.gz glibc-5cbb73004b635e762e20b447c2d93c307cb40f41.tar.bz2 glibc-5cbb73004b635e762e20b447c2d93c307cb40f41.zip |
elf: Fix pldd (BZ#18035)
Since 9182aa67994 (Fix vDSO l_name for GDB's, BZ#387) the initial link_map
for executable itself and loader will have both l_name and l_libname->name
holding the same value due:
elf/dl-object.c
95 new->l_name = *realname ? realname : (char *) newname->name + libname_len - 1;
Since newname->name points to new->l_libname->name.
This leads to pldd to an infinite call at:
elf/pldd-xx.c
203 again:
204 while (1)
205 {
206 ssize_t n = pread64 (memfd, tmpbuf.data, tmpbuf.length, name_offset);
228 /* Try the l_libname element. */
229 struct E(libname_list) ln;
230 if (pread64 (memfd, &ln, sizeof (ln), m.l_libname) == sizeof (ln))
231 {
232 name_offset = ln.name;
233 goto again;
234 }
Since the value at ln.name (l_libname->name) will be the same as previously
read. The straightforward fix is just avoid the check and read the new list
entry.
I checked also against binaries issues with old loaders with fix for BZ#387,
and pldd could dump the shared objects.
Checked on x86_64-linux-gnu, i686-linux-gnu, aarch64-linux-gnu, and
powerpc64le-linux-gnu.
[BZ #18035]
* elf/Makefile (tests-container): Add tst-pldd.
* elf/pldd-xx.c: Use _Static_assert in of pldd_assert.
(E(find_maps)): Avoid use alloca, use default read file operations
instead of explicit LFS names, and fix infinite loop.
* elf/pldd.c: Explicit set _FILE_OFFSET_BITS, cleanup headers.
(get_process_info): Use _Static_assert instead of assert, use default
directory operations instead of explicit LFS names, and free some
leadek pointers.
* elf/tst-pldd.c: New file.
(cherry picked from commit 1a4c27355e146b6d8cc6487b998462c7fdd1048f)
(Backported without the test case due to lack of test-in-container
support.)
Diffstat (limited to 'sysdeps/unix/sysv/linux/socket.c')
0 files changed, 0 insertions, 0 deletions