diff options
author | David Leonard <d@cvs.openbsd.org> | 1998-12-10 00:40:20 +0000 |
---|---|---|
committer | David Leonard <d@cvs.openbsd.org> | 1998-12-10 00:40:20 +0000 |
commit | 2f669072197e7ccdad929030e83c697fe9e47d38 (patch) | |
tree | 4135a2aef7d23fdb401e5e09e0af80aeb71d3bd5 /lib/libc_r/uthread/uthread_mutex.c | |
parent | 2ae7d9d676817895acb58a95f45ed88e4626c04d (diff) |
sync with FreeBSD
Diffstat (limited to 'lib/libc_r/uthread/uthread_mutex.c')
-rw-r--r-- | lib/libc_r/uthread/uthread_mutex.c | 67 |
1 files changed, 47 insertions, 20 deletions
diff --git a/lib/libc_r/uthread/uthread_mutex.c b/lib/libc_r/uthread/uthread_mutex.c index a7e8dfee6b5..d3801f1750c 100644 --- a/lib/libc_r/uthread/uthread_mutex.c +++ b/lib/libc_r/uthread/uthread_mutex.c @@ -53,7 +53,7 @@ pthread_mutex_init(pthread_mutex_t * mutex, /* Check if default mutex attributes: */ if (mutex_attr == NULL || *mutex_attr == NULL) /* Default to a fast mutex: */ - type = MUTEX_TYPE_FAST; + type = PTHREAD_MUTEX_DEFAULT; else if ((*mutex_attr)->m_type >= MUTEX_TYPE_MAX) /* Return an invalid argument error: */ @@ -74,12 +74,14 @@ pthread_mutex_init(pthread_mutex_t * mutex, /* Process according to mutex type: */ switch (type) { /* Fast mutex: */ - case MUTEX_TYPE_FAST: + case PTHREAD_MUTEX_DEFAULT: + case PTHREAD_MUTEX_NORMAL: + case PTHREAD_MUTEX_ERRORCHECK: /* Nothing to do here. */ break; /* Counting mutex: */ - case MUTEX_TYPE_COUNTING_FAST: + case PTHREAD_MUTEX_RECURSIVE: /* Reset the mutex count: */ pmutex->m_data.m_count = 0; break; @@ -174,7 +176,9 @@ pthread_mutex_trylock(pthread_mutex_t * mutex) /* Process according to mutex type: */ switch ((*mutex)->m_type) { /* Fast mutex: */ - case MUTEX_TYPE_FAST: + case PTHREAD_MUTEX_NORMAL: + case PTHREAD_MUTEX_DEFAULT: + case PTHREAD_MUTEX_ERRORCHECK: /* Check if this mutex is not locked: */ if ((*mutex)->m_owner == NULL) { /* Lock the mutex for the running thread: */ @@ -186,7 +190,7 @@ pthread_mutex_trylock(pthread_mutex_t * mutex) break; /* Counting mutex: */ - case MUTEX_TYPE_COUNTING_FAST: + case PTHREAD_MUTEX_RECURSIVE: /* Check if this mutex is locked: */ if ((*mutex)->m_owner != NULL) { /* @@ -239,8 +243,26 @@ pthread_mutex_lock(pthread_mutex_t * mutex) /* Process according to mutex type: */ switch ((*mutex)->m_type) { + /* What SS2 define as a 'normal' mutex. This has to deadlock + on attempts to get a lock you already own. */ + case PTHREAD_MUTEX_NORMAL: + if ((*mutex)->m_owner == _thread_run) { + /* Intetionally deadlock */ + for (;;) + _thread_kern_sched_state(PS_MUTEX_WAIT, __FILE__, __LINE__); + } + goto COMMON_LOCK; + + /* Return error (not OK) on attempting to re-lock */ + case PTHREAD_MUTEX_ERRORCHECK: + if ((*mutex)->m_owner == _thread_run) { + ret = EDEADLK; + break; + } + /* Fast mutexes do not check for any error conditions: */ - case MUTEX_TYPE_FAST: + case PTHREAD_MUTEX_DEFAULT: + COMMON_LOCK: /* * Enter a loop to wait for the mutex to be locked by the * current thread: @@ -269,7 +291,7 @@ pthread_mutex_lock(pthread_mutex_t * mutex) break; /* Counting mutex: */ - case MUTEX_TYPE_COUNTING_FAST: + case PTHREAD_MUTEX_RECURSIVE: /* * Enter a loop to wait for the mutex to be locked by the * current thread: @@ -331,12 +353,15 @@ pthread_mutex_unlock(pthread_mutex_t * mutex) /* Process according to mutex type: */ switch ((*mutex)->m_type) { - /* Fast mutexes do not check for any error conditions: */ - case MUTEX_TYPE_FAST: + /* Default & normal mutexes do not really need to check for + any error conditions: */ + case PTHREAD_MUTEX_NORMAL: + case PTHREAD_MUTEX_DEFAULT: + case PTHREAD_MUTEX_ERRORCHECK: /* Check if the running thread is not the owner of the mutex: */ if ((*mutex)->m_owner != _thread_run) { /* Return an invalid argument error: */ - ret = EINVAL; + ret = (*mutex)->m_owner ? EPERM : EINVAL; } /* * Get the next thread from the queue of threads waiting on @@ -349,24 +374,26 @@ pthread_mutex_unlock(pthread_mutex_t * mutex) break; /* Counting mutex: */ - case MUTEX_TYPE_COUNTING_FAST: + case PTHREAD_MUTEX_RECURSIVE: /* Check if the running thread is not the owner of the mutex: */ if ((*mutex)->m_owner != _thread_run) { /* Return an invalid argument error: */ ret = EINVAL; } /* Check if there are still counts: */ - else if ((*mutex)->m_data.m_count) { + else if ((*mutex)->m_data.m_count > 1) { /* Decrement the count: */ (*mutex)->m_data.m_count--; - } - /* - * Get the next thread from the queue of threads waiting on - * the mutex: - */ - else if (((*mutex)->m_owner = _thread_queue_deq(&(*mutex)->m_queue)) != NULL) { - /* Allow the new owner of the mutex to run: */ - PTHREAD_NEW_STATE((*mutex)->m_owner,PS_RUNNING); + } else { + (*mutex)->m_data.m_count = 0; + /* + * Get the next thread from the queue of threads waiting on + * the mutex: + */ + if (((*mutex)->m_owner = _thread_queue_deq(&(*mutex)->m_queue)) != NULL) { + /* Allow the new owner of the mutex to run: */ + PTHREAD_NEW_STATE((*mutex)->m_owner,PS_RUNNING); + } } break; |