cheap trick to further optimize locking normal mutexes
authorRich Felker <dalias@aerifal.cx>
Thu, 14 Apr 2011 18:39:57 +0000 (14:39 -0400)
committerRich Felker <dalias@aerifal.cx>
Thu, 14 Apr 2011 18:39:57 +0000 (14:39 -0400)
src/thread/pthread_mutex_lock.c
src/thread/pthread_mutex_trylock.c

index 87b1975..99c15bd 100644 (file)
@@ -4,7 +4,7 @@ int pthread_mutex_lock(pthread_mutex_t *m)
 {
        int r;
 
 {
        int r;
 
-       if (m->_m_type == PTHREAD_MUTEX_NORMAL && !a_swap(&m->_m_lock, 1))
+       if (m->_m_type == PTHREAD_MUTEX_NORMAL && !a_swap(&m->_m_lock, EBUSY))
                return 0;
 
        while ((r=pthread_mutex_trylock(m)) == EBUSY) {
                return 0;
 
        while ((r=pthread_mutex_trylock(m)) == EBUSY) {
index 50a815a..ea1fa80 100644 (file)
@@ -7,7 +7,7 @@ int pthread_mutex_trylock(pthread_mutex_t *m)
        pthread_t self;
 
        if (m->_m_type == PTHREAD_MUTEX_NORMAL)
        pthread_t self;
 
        if (m->_m_type == PTHREAD_MUTEX_NORMAL)
-               return -a_swap(&m->_m_lock, 1) & EBUSY;
+               return a_swap(&m->_m_lock, EBUSY);
 
        self = pthread_self();
        tid = self->tid | 0x80000000;
 
        self = pthread_self();
        tid = self->tid | 0x80000000;