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