c5d972
commit 88361b408b9dbd313f15413cc2e6be0f1cafb01a
c5d972
Author: H.J. Lu <hjl.tools@gmail.com>
c5d972
Date:   Tue Aug 17 19:36:04 2021 -0700
c5d972
c5d972
    elf: Copy l_addr/l_ld when adding ld.so to a new namespace
c5d972
    
c5d972
    When add ld.so to a new namespace, we don't actually load ld.so.  We
c5d972
    create a new link map and refers the real one for almost everything.
c5d972
    Copy l_addr and l_ld from the real ld.so link map to avoid GDB warning:
c5d972
    
c5d972
    warning: .dynamic section for ".../elf/ld-linux-x86-64.so.2" is not at the expected address (wrong library or version mismatch?)
c5d972
    
c5d972
    when handling shared library loaded by dlmopen.
c5d972
    
c5d972
    Reviewed-by: Adhemerval Zanella  <adhemerval.zanella@linaro.org>
c5d972
c5d972
diff --git a/elf/dl-load.c b/elf/dl-load.c
c5d972
index cdb5d4b5b67f1ca1..303e6594f9af9b7e 100644
c5d972
--- a/elf/dl-load.c
c5d972
+++ b/elf/dl-load.c
c5d972
@@ -932,6 +932,10 @@ _dl_map_object_from_fd (const char *name, const char *origname, int fd,
c5d972
       /* Refer to the real descriptor.  */
c5d972
       l->l_real = &GL(dl_rtld_map);
c5d972
 
c5d972
+      /* Copy l_addr and l_ld to avoid a GDB warning with dlmopen().  */
c5d972
+      l->l_addr = l->l_real->l_addr;
c5d972
+      l->l_ld = l->l_real->l_ld;
c5d972
+
c5d972
       /* No need to bump the refcount of the real object, ld.so will
c5d972
 	 never be unloaded.  */
c5d972
       __close_nocancel (fd);