mirror of
https://github.com/fluencelabs/musl
synced 2025-05-29 07:31:53 +00:00
correct error returns for error-checking mutexes
This commit is contained in:
parent
29fae65780
commit
d4f9e0b364
@ -3,7 +3,11 @@
|
|||||||
int pthread_mutex_lock(pthread_mutex_t *m)
|
int pthread_mutex_lock(pthread_mutex_t *m)
|
||||||
{
|
{
|
||||||
int r;
|
int r;
|
||||||
while ((r=pthread_mutex_trylock(m)) == EBUSY)
|
while ((r=pthread_mutex_trylock(m)) == EBUSY) {
|
||||||
|
if (m->_m_type == PTHREAD_MUTEX_ERRORCHECK
|
||||||
|
&& m->_m_owner == pthread_self()->tid)
|
||||||
|
return EDEADLK;
|
||||||
__wait(&m->_m_lock, &m->_m_waiters, 1, 0);
|
__wait(&m->_m_lock, &m->_m_waiters, 1, 0);
|
||||||
|
}
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
@ -11,7 +11,7 @@ int pthread_mutex_trylock(pthread_mutex_t *m)
|
|||||||
|
|
||||||
if (m->_m_owner == tid) {
|
if (m->_m_owner == tid) {
|
||||||
if (m->_m_type != PTHREAD_MUTEX_RECURSIVE)
|
if (m->_m_type != PTHREAD_MUTEX_RECURSIVE)
|
||||||
return EDEADLK;
|
return EBUSY;
|
||||||
if ((unsigned)m->_m_count >= INT_MAX) return EAGAIN;
|
if ((unsigned)m->_m_count >= INT_MAX) return EAGAIN;
|
||||||
m->_m_count++;
|
m->_m_count++;
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user