diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2018-03-17 01:28:41 +0100 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2018-03-25 00:52:39 +0100 |
commit | bcfa607b26c2399d4fda88705d40978d62af8bf3 (patch) | |
tree | b13774ef00a4531ba760954a1d3cc9f7e48731cb /sysdeps/mach/hurd/i386/init-first.c | |
parent | fa97d2ab5b19de0ca3cd02471d0bbf4f09b5032d (diff) | |
download | glibc-bcfa607b26c2399d4fda88705d40978d62af8bf3.tar glibc-bcfa607b26c2399d4fda88705d40978d62af8bf3.tar.gz glibc-bcfa607b26c2399d4fda88705d40978d62af8bf3.tar.bz2 glibc-bcfa607b26c2399d4fda88705d40978d62af8bf3.zip |
hurd: Initialize TLS and libpthread before signal thread start
* sysdeps/generic/libc-start.h [!SHARED] (ARCH_SETUP_TLS): Define to
__libc_setup_tls.
* sysdeps/unix/sysv/linux/powerpc/libc-start.h [!SHARED]
(ARCH_SETUP_TLS): Likewise.
* sysdeps/mach/hurd/libc-start.h: New file copied from
sysdeps/generic/libc-start.h, but define ARCH_SETUP_TLS to empty.
* csu/libc-start.c [!SHARED] (LIBC_START_MAIN): Call ARCH_SETUP_TLS instead
of __libc_setup_tls.
* sysdeps/mach/hurd/i386/init-first.c [!SHARED] (init1): Call
__libc_setup_tls before initializing libpthread and running _hurd_init which
starts the signal thread.
Diffstat (limited to 'sysdeps/mach/hurd/i386/init-first.c')
-rw-r--r-- | sysdeps/mach/hurd/i386/init-first.c | 25 |
1 files changed, 17 insertions, 8 deletions
diff --git a/sysdeps/mach/hurd/i386/init-first.c b/sysdeps/mach/hurd/i386/init-first.c index e272e329ad..8b6e62be14 100644 --- a/sysdeps/mach/hurd/i386/init-first.c +++ b/sysdeps/mach/hurd/i386/init-first.c @@ -104,12 +104,12 @@ init1 (int argc, char *arg0, ...) ++envp; d = (void *) ++envp; +#ifndef SHARED /* 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] || d->phdr == 0) { -#ifndef SHARED /* With a new enough linker (binutils-2.23 or better), the magic __ehdr_start symbol will be available and __libc_start_main will have done this that way already. */ @@ -124,18 +124,27 @@ init1 (int argc, char *arg0, ...) _dl_phnum = ehdr->e_phnum; assert (ehdr->e_phentsize == sizeof (ElfW(Phdr))); } -#endif - return; } + else + { + __libc_enable_secure = d->flags & EXEC_SECURE; -#ifndef SHARED - __libc_enable_secure = d->flags & EXEC_SECURE; + _dl_phdr = (ElfW(Phdr) *) d->phdr; + _dl_phnum = d->phdrsz / sizeof (ElfW(Phdr)); + assert (d->phdrsz % sizeof (ElfW(Phdr)) == 0); + } - _dl_phdr = (ElfW(Phdr) *) d->phdr; - _dl_phnum = d->phdrsz / sizeof (ElfW(Phdr)); - assert (d->phdrsz % sizeof (ElfW(Phdr)) == 0); + __libc_setup_tls (); #endif + /* Initialize libpthread if linked in. */ + if (__pthread_initialize_minimal != NULL) + __pthread_initialize_minimal (); + + if ((void *) d == argv[0]) + /* No Hurd data block to process. */ + return; + _hurd_init_dtable = d->dtable; _hurd_init_dtablesize = d->dtablesize; |