From: H.J. Lu Date: Wed, 18 Aug 2021 02:36:04 +0000 (-0700) Subject: elf: Copy l_addr/l_ld when adding ld.so to a new namespace X-Git-Tag: glibc-2.35~470 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=88361b408b9dbd313f15413cc2e6be0f1cafb01a;p=thirdparty%2Fglibc.git elf: Copy l_addr/l_ld when adding ld.so to a new namespace When add ld.so to a new namespace, we don't actually load ld.so. We create a new link map and refers the real one for almost everything. Copy l_addr and l_ld from the real ld.so link map to avoid GDB warning: warning: .dynamic section for ".../elf/ld-linux-x86-64.so.2" is not at the expected address (wrong library or version mismatch?) when handling shared library loaded by dlmopen. Reviewed-by: Adhemerval Zanella --- diff --git a/elf/dl-load.c b/elf/dl-load.c index 6ea71077afc..99c5ab83b3d 100644 --- a/elf/dl-load.c +++ b/elf/dl-load.c @@ -1026,6 +1026,10 @@ _dl_map_object_from_fd (const char *name, const char *origname, int fd, /* Refer to the real descriptor. */ l->l_real = &GL(dl_rtld_map); + /* Copy l_addr and l_ld to avoid a GDB warning with dlmopen(). */ + l->l_addr = l->l_real->l_addr; + l->l_ld = l->l_real->l_ld; + /* No need to bump the refcount of the real object, ld.so will never be unloaded. */ __close_nocancel (fd);