| #include "pthread_impl.h" | |
| int pthread_rwlock_unlock(pthread_rwlock_t *rw) | |
| { | |
| int val, cnt, waiters, new, priv = rw->_rw_shared^128; | |
| do { | |
| val = rw->_rw_lock; | |
| cnt = val & 0x7fffffff; | |
| waiters = rw->_rw_waiters; | |
| new = (cnt == 0x7fffffff || cnt == 1) ? 0 : val-1; | |
| } while (a_cas(&rw->_rw_lock, val, new) != val); | |
| if (!new && (waiters || val<0)) | |
| __wake(&rw->_rw_lock, cnt, priv); | |
| return 0; | |
| } |