diff options
| author | Rich Felker <dalias@aerifal.cx> | 2011-03-16 16:25:00 -0400 | 
|---|---|---|
| committer | Rich Felker <dalias@aerifal.cx> | 2011-03-16 16:25:00 -0400 | 
| commit | d4f9e0b3642a81d07c95302cd9aa0dcaf7de1a05 (patch) | |
| tree | 8bb9017678027a5f7c0b461fc9e246d34d0ebd1d /src | |
| parent | 29fae65780f4c5ccda3758828da7a83073297ccc (diff) | |
| download | musl-d4f9e0b3642a81d07c95302cd9aa0dcaf7de1a05.tar.gz | |
correct error returns for error-checking mutexes
Diffstat (limited to 'src')
| -rw-r--r-- | src/thread/pthread_mutex_lock.c | 6 | ||||
| -rw-r--r-- | 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; | 
