@@ -7,7 +7,7 @@ int pthread_rwlock_tryrdlock(pthread_rwlock_t *rw)
a_dec(&rw->_rw_readers);
if (rw->_rw_waiters && !rw->_rw_readers)
__wake(&rw->_rw_readers, 1, 0);
- return EAGAIN;
+ return EBUSY;
}
return 0;
@@ -3,10 +3,10 @@
int pthread_rwlock_trywrlock(pthread_rwlock_t *rw)
{
if (a_xchg(&rw->_rw_wrlock, 1))
if (rw->_rw_readers) {
a_store(&rw->_rw_wrlock, 0);
rw->_rw_owner = pthread_self()->tid;