tags 209145 +patch
tags 209145 fixed-upstream

It seems fixed in upstream CVS.
Included patch alocates also space for terminating `\0' character.
    
Regards

        Petr


--- rtld.old    2005-01-27 09:37:20.000000000 +0100
+++ rtld.c      2005-01-27 11:41:28.000000000 +0100
@@ -1196,10 +1196,21 @@
          l->l_relocated = 1;
 
          /* Now that we have the info handy, use the DSO image's soname
-            so this object can be looked up by name.  */
+            so this object can be looked up by name.  Note that we do not
+            set l_name here.  That field gives the file name of the DSO,
+            and this DSO is not associated with any file.  */
          if (l->l_info[DT_SONAME] != NULL)
-           l->l_libname->name = ((char *) D_PTR (l, l_info[DT_STRTAB])
-                                 + l->l_info[DT_SONAME]->d_un.d_val);
+           {
+             /* Work around a kernel problem.  The kernel cannot handle
+                addresses in the vsyscall DSO pages in writev() calls.  */
+             const char *dsoname = ((char *) D_PTR (l, l_info[DT_STRTAB])
+                                    + l->l_info[DT_SONAME]->d_un.d_val);
+             size_t len = 1 + strlen (dsoname);
+             char *copy = malloc (len);
+             if (copy == NULL)
+               _dl_fatal_printf ("out of memory\n");
+             l->l_libname->name = memcpy (copy, dsoname, len);
+           }
        }
     }
 #endif

Reply via email to