2011-02-12 00:22:29 -05:00
|
|
|
#include "pthread_impl.h"
|
|
|
|
|
|
|
|
int pthread_mutex_unlock(pthread_mutex_t *m)
|
|
|
|
{
|
2011-02-17 17:16:20 -05:00
|
|
|
if (m->_m_type == PTHREAD_MUTEX_RECURSIVE) {
|
|
|
|
if (a_fetch_add(&m->_m_lock, -1)==1 && m->_m_waiters)
|
|
|
|
__wake(&m->_m_lock, 1, 0);
|
2011-02-12 00:22:29 -05:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2011-02-17 17:16:20 -05:00
|
|
|
if (m->_m_type == PTHREAD_MUTEX_ERRORCHECK
|
|
|
|
&& m->_m_owner != pthread_self()->tid)
|
2011-02-12 00:22:29 -05:00
|
|
|
return EPERM;
|
|
|
|
|
2011-02-17 17:16:20 -05:00
|
|
|
m->_m_owner = 0;
|
|
|
|
m->_m_lock = 0;
|
|
|
|
if (m->_m_waiters) __wake(&m->_m_lock, 1, 0);
|
2011-02-12 00:22:29 -05:00
|
|
|
return 0;
|
|
|
|
}
|