From: Samuel Thibault Date: Sun, 18 Mar 2018 18:52:39 +0000 (+0100) Subject: hurd: Fix boot with statically-linked exec server X-Git-Tag: glibc-2.28~450 X-Git-Url: https://sourceware.org/git/?a=commitdiff_plain;h=aa2189295e4e531d05733d60bfd697c7a962b100;p=glibc.git hurd: Fix boot with statically-linked exec server * sysdeps/mach/hurd/i386/init-first.c (init): Also find ELF headers by oneself when the pointer given in D is nul (as set by ext2fs). --- diff --git a/ChangeLog b/ChangeLog index a02f9017de..e090c75b74 100644 --- a/ChangeLog +++ b/ChangeLog @@ -68,6 +68,8 @@ path when flags contains O_NOFOLLOW. * hurd/lookup-retry.c (__hurd_file_name_lookup_retry): Return ENOTDIR if flags contains O_DIRECTORY and the result is a directory. + * sysdeps/mach/hurd/i386/init-first.c (init): Also find ELF headers by + oneself when the pointer given in D is nul (as set by ext2fs). 2018-03-17 Samuel Thibault diff --git a/sysdeps/mach/hurd/i386/init-first.c b/sysdeps/mach/hurd/i386/init-first.c index f4a4df33de..226de02a99 100644 --- a/sysdeps/mach/hurd/i386/init-first.c +++ b/sysdeps/mach/hurd/i386/init-first.c @@ -107,7 +107,7 @@ init1 (int argc, char *arg0, ...) /* If we are the bootstrap task started by the kernel, then after the environment pointers there is no Hurd data block; the argument strings start there. */ - if ((void *) d == argv[0]) + if ((void *) d == argv[0] || d->phdr == NULL) { #ifndef SHARED /* With a new enough linker (binutils-2.23 or better),