From d4f9e0b3642a81d07c95302cd9aa0dcaf7de1a05 Mon Sep 17 00:00:00 2001 From: Rich Felker Date: Wed, 16 Mar 2011 16:25:00 -0400 Subject: correct error returns for error-checking mutexes --- src/thread/pthread_mutex_lock.c | 6 +++++- src/thread/pthread_mutex_trylock.c | 2 +- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/src/thread/pthread_mutex_lock.c b/src/thread/pthread_mutex_lock.c index 15ede3f5..82556141 100644 --- a/src/thread/pthread_mutex_lock.c +++ b/src/thread/pthread_mutex_lock.c @@ -3,7 +3,11 @@ int pthread_mutex_lock(pthread_mutex_t *m) { 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); + } return r; } diff --git a/src/thread/pthread_mutex_trylock.c b/src/thread/pthread_mutex_trylock.c index 2dad7bbf..25b9e869 100644 --- a/src/thread/pthread_mutex_trylock.c +++ b/src/thread/pthread_mutex_trylock.c @@ -11,7 +11,7 @@ int pthread_mutex_trylock(pthread_mutex_t *m) if (m->_m_owner == tid) { if (m->_m_type != PTHREAD_MUTEX_RECURSIVE) - return EDEADLK; + return EBUSY; if ((unsigned)m->_m_count >= INT_MAX) return EAGAIN; m->_m_count++; return 0; -- cgit v1.2.1