X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Fthread%2Fpthread_create.c;fp=src%2Fthread%2Fpthread_create.c;h=0cd2d6c29260d5f92f0b13f5ca8e82f596be770c;hp=e6760abb0dbae6ee8746b65f68b76c42aeaeedf0;hb=23f21c304fd6a7592b70927e247129c5a2bc2390;hpb=a0473a0c826016aec1181819fcd4fff5c074f042 diff --git a/src/thread/pthread_create.c b/src/thread/pthread_create.c index e6760abb..0cd2d6c2 100644 --- a/src/thread/pthread_create.c +++ b/src/thread/pthread_create.c @@ -32,6 +32,8 @@ _Noreturn void pthread_exit(void *result) self->dead = 1; __unlock(self->killlock); + __syscall(SYS_rt_sigprocmask, SIG_BLOCK, SIGALL_SET, 0, _NSIG/8); + do n = libc.threads_minus_1; while (n && a_cas(&libc.threads_minus_1, n, n-1)!=n); if (!n) exit(0); @@ -39,8 +41,6 @@ _Noreturn void pthread_exit(void *result) if (self->detached && self->map_base) { if (self->detached == 2) __syscall(SYS_set_tid_address, 0); - __syscall(SYS_rt_sigprocmask, SIG_BLOCK, - SIGALL_SET, 0, _NSIG/8); __unmapself(self->map_base, self->map_size); }