X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Fthread%2Fsynccall.c;h=2b7eac259ce2f3332a09cf3398014d8b99b5e426;hp=7c4f92bfdb77307338778a27adca3e9dd5ca07ad;hb=dcd60371500a74d489372cac7240674c992c2484;hpb=acb04806628990ad2430e04261dd20f23babde5e diff --git a/src/thread/synccall.c b/src/thread/synccall.c index 7c4f92bf..2b7eac25 100644 --- a/src/thread/synccall.c +++ b/src/thread/synccall.c @@ -4,12 +4,11 @@ static struct chain { struct chain *next; sem_t sem, sem2; -} *head; +} *head, *cur; static void (*callback)(void *), *context; static int chainlen; static sem_t chainlock, chaindone; -static pthread_rwlock_t lock = PTHREAD_RWLOCK_INITIALIZER; static void handler(int sig, siginfo_t *si, void *ctx) { @@ -51,18 +50,19 @@ void __synccall(void (*func)(void *), void *ctx) { pthread_t self; struct sigaction sa; - struct chain *cur, *next; + struct chain *next; uint64_t oldmask; - pthread_rwlock_wrlock(&lock); - - __syscall(SYS_rt_sigprocmask, SIG_BLOCK, (uint64_t[]){-1}, &oldmask, 8); - if (!libc.threads_minus_1) { func(ctx); return; } + __inhibit_ptc(); + + __syscall(SYS_rt_sigprocmask, SIG_BLOCK, SIGALL_SET, + &oldmask, __SYSCALL_SSLEN); + sem_init(&chaindone, 0, 0); sem_init(&chainlock, 0, 1); chainlen = 0; @@ -93,17 +93,8 @@ void __synccall(void (*func)(void *), void *ctx) sa.sa_handler = SIG_IGN; __libc_sigaction(SIGSYNCCALL, &sa, 0); - __syscall(SYS_rt_sigprocmask, SIG_SETMASK, &oldmask, 0, 8); + __syscall(SYS_rt_sigprocmask, SIG_SETMASK, + &oldmask, 0, __SYSCALL_SSLEN); - pthread_rwlock_unlock(&lock); -} - -void __synccall_lock() -{ - pthread_rwlock_rdlock(&lock); -} - -void __synccall_unlock() -{ - pthread_rwlock_unlock(&lock); + __release_ptc(); }