fix failure-to-wake in rwlock unlock
authorRich Felker <dalias@aerifal.cx>
Sat, 1 Oct 2011 13:11:35 +0000 (09:11 -0400)
committerRich Felker <dalias@aerifal.cx>
Sat, 1 Oct 2011 13:11:35 +0000 (09:11 -0400)
a reader unlocking the lock need only wake one waiter (necessarily a
writer, but a writer unlocking the lock must wake all waiters
(necessarily readers). if it only wakes one, the remainder can remain
blocked indefinitely, or at least until the first reader unlocks (in
which case the whole lock becomes serialized and behaves as a mutex
rather than a read lock).

src/thread/pthread_rwlock_unlock.c

index 5edca63..a6d2085 100644 (file)
@@ -12,7 +12,7 @@ int pthread_rwlock_unlock(pthread_rwlock_t *rw)
        } while (a_cas(&rw->_rw_lock, val, new) != val);
 
        if (!new && (waiters || val<0))
-               __wake(&rw->_rw_lock, 1, 0);
+               __wake(&rw->_rw_lock, cnt, 0);
 
        return 0;
 }