2011-02-12 00:22:29 -05:00
|
|
|
#include "pthread_impl.h"
|
|
|
|
|
|
|
|
int pthread_mutex_trylock(pthread_mutex_t *m)
|
|
|
|
{
|
2011-02-17 17:16:20 -05:00
|
|
|
if (m->_m_type == PTHREAD_MUTEX_RECURSIVE) {
|
2011-02-12 00:22:29 -05:00
|
|
|
pthread_t self = pthread_self();
|
2011-02-17 17:16:20 -05:00
|
|
|
if (m->_m_owner == self->tid) {
|
|
|
|
if ((unsigned)m->_m_lock >= INT_MAX) return EAGAIN;
|
|
|
|
a_inc(&m->_m_lock);
|
2011-02-12 00:22:29 -05:00
|
|
|
return 0;
|
|
|
|
}
|
2011-02-17 17:16:20 -05:00
|
|
|
if (a_fetch_add(&m->_m_lock, 1)) {
|
|
|
|
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 EBUSY;
|
|
|
|
}
|
2011-02-17 17:16:20 -05:00
|
|
|
m->_m_owner = self->tid;
|
2011-02-12 00:22:29 -05:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2011-02-17 17:16:20 -05:00
|
|
|
if (a_xchg(&m->_m_lock, 1))
|
|
|
|
if (m->_m_type == PTHREAD_MUTEX_ERRORCHECK
|
|
|
|
&& m->_m_owner == pthread_self()->tid) return EDEADLK;
|
2011-02-12 00:22:29 -05:00
|
|
|
else return EBUSY;
|
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 0;
|
|
|
|
}
|