about summary refs log tree commit diff
path: root/csu
diff options
context:
space:
mode:
authorSamuel Thibault <samuel.thibault@ens-lyon.org>2018-03-17 01:28:41 +0100
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2018-03-25 00:52:39 +0100
commitbcfa607b26c2399d4fda88705d40978d62af8bf3 (patch)
treeb13774ef00a4531ba760954a1d3cc9f7e48731cb /csu
parentfa97d2ab5b19de0ca3cd02471d0bbf4f09b5032d (diff)
downloadglibc-bcfa607b26c2399d4fda88705d40978d62af8bf3.tar.gz
glibc-bcfa607b26c2399d4fda88705d40978d62af8bf3.tar.xz
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 'csu')
-rw-r--r--csu/libc-start.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/csu/libc-start.c b/csu/libc-start.c
index 605222fa3f..494132368f 100644
--- a/csu/libc-start.c
+++ b/csu/libc-start.c
@@ -194,7 +194,7 @@ LIBC_START_MAIN (int (*main) (int, char **, char ** MAIN_AUXVEC_DECL),
   ARCH_SETUP_IREL ();
 
   /* The stack guard goes into the TCB, so initialize it early.  */
-  __libc_setup_tls ();
+  ARCH_SETUP_TLS ();
 
   /* In some architectures, IREL{,A} relocations happen after TLS setup in
      order to let IFUNC resolvers benefit from TCB information, e.g. powerpc's