diff options
author | Rich Felker <dalias@aerifal.cx> | 2011-07-30 00:24:26 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2011-07-30 00:24:26 -0400 |
commit | 7dd60b80f965af451f952b9f45bd9b6aec0fae74 (patch) | |
tree | f166001b5f5ef541cfcbc34155a7f27bd8d21120 /src/thread/synccall.c | |
parent | afade2356ea148e715307be8f7334b790282341e (diff) | |
download | musl-7dd60b80f965af451f952b9f45bd9b6aec0fae74.tar.gz musl-7dd60b80f965af451f952b9f45bd9b6aec0fae74.tar.bz2 musl-7dd60b80f965af451f952b9f45bd9b6aec0fae74.tar.xz musl-7dd60b80f965af451f952b9f45bd9b6aec0fae74.zip |
fix bug in synccall with no threads: lock was taken but never released
Diffstat (limited to 'src/thread/synccall.c')
-rw-r--r-- | src/thread/synccall.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/src/thread/synccall.c b/src/thread/synccall.c index 7c4f92bf..91ac5eb7 100644 --- a/src/thread/synccall.c +++ b/src/thread/synccall.c @@ -54,15 +54,15 @@ void __synccall(void (*func)(void *), void *ctx) struct chain *cur, *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; } + pthread_rwlock_wrlock(&lock); + + __syscall(SYS_rt_sigprocmask, SIG_BLOCK, (uint64_t[]){-1}, &oldmask, 8); + sem_init(&chaindone, 0, 0); sem_init(&chainlock, 0, 1); chainlen = 0; |