From 8cce15af83c04d8965561439f0a80a451a9b1af0 Mon Sep 17 00:00:00 2001 From: Rich Felker Date: Fri, 25 May 2012 22:34:09 -0400 Subject: [PATCH] ensure pthread-internal signals are unblocked before threads are used if the process started with these signals blocked, cancellation could fail or setxid could deadlock. there is no way to globally unblock them after threads have been created. by unblocking them in the pthread_self initialization for the main thread, we ensure that they're unblocked before any other threads are created and also outside of any signal handler context (sigaction initialized pthread_self), which is important so that return from a signal handler won't re-block them. --- src/thread/pthread_self.c | 1 + 1 file changed, 1 insertion(+) diff --git a/src/thread/pthread_self.c b/src/thread/pthread_self.c index 51f12bb3..f68896f7 100644 --- a/src/thread/pthread_self.c +++ b/src/thread/pthread_self.c @@ -8,6 +8,7 @@ weak_alias(dummy, __pthread_tsd_main); static int init_main_thread() { + __syscall(SYS_rt_sigprocmask, SIG_UNBLOCK, SIGPT_SET, 0, 8); if (__set_thread_area(&main_thread) < 0) return -1; main_thread.canceldisable = libc.canceldisable; main_thread.tsd = (void **)__pthread_tsd_main; -- 2.20.1