diff options
author | bnicholes <bnicholes@13f79535-47bb-0310-9956-ffa450edef68> | 2002-02-20 19:58:57 +0000 |
---|---|---|
committer | bnicholes <bnicholes@13f79535-47bb-0310-9956-ffa450edef68> | 2002-02-20 19:58:57 +0000 |
commit | 761f48b0f90ace7d345a7e68f652d336026a63a2 (patch) | |
tree | 4fc22f8e244b71dc27ef4e4fddd7d8be7005c151 /locks | |
parent | c604230c8124148f16d9726fd971a835b83846e5 (diff) | |
download | libapr-761f48b0f90ace7d345a7e68f652d336026a63a2.tar.gz |
Implementation of the global mutex APIs
git-svn-id: http://svn.apache.org/repos/asf/apr/apr/trunk@63033 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'locks')
-rw-r--r-- | locks/netware/global_mutex.c | 36 |
1 files changed, 30 insertions, 6 deletions
diff --git a/locks/netware/global_mutex.c b/locks/netware/global_mutex.c index 24f73b1c2..ef385bb81 100644 --- a/locks/netware/global_mutex.c +++ b/locks/netware/global_mutex.c @@ -54,13 +54,29 @@ #include "apr.h" #include "apr_strings.h" +#include "global_mutex.h" +#include "apr_thread_mutex.h" APR_DECLARE(apr_status_t) apr_global_mutex_create(apr_global_mutex_t **mutex, const char *fname, apr_lockmech_e mech, apr_pool_t *pool) { - return APR_ENOTIMPL; + apr_status_t ret; + apr_global_mutex_t *new_mutex = NULL; + new_mutex = (apr_global_mutex_t *)apr_pcalloc(pool, sizeof(apr_global_mutex_t)); + + if(new_mutex ==NULL) { + return APR_ENOMEM; + } + + new_mutex->pool = pool; + ret = apr_thread_mutex_create(&(new_mutex->mutex), APR_THREAD_MUTEX_DEFAULT, pool); + + if (ret == APR_SUCCESS) + *mutex = new_mutex; + + return ret; } APR_DECLARE(apr_status_t) apr_global_mutex_child_init( @@ -68,27 +84,35 @@ APR_DECLARE(apr_status_t) apr_global_mutex_child_init( const char *fname, apr_pool_t *pool) { - return APR_ENOTIMPL; + return APR_SUCCESS; } APR_DECLARE(apr_status_t) apr_global_mutex_lock(apr_global_mutex_t *mutex) { - return APR_ENOTIMPL; + if (mutex) + return apr_thread_mutex_lock(mutex->mutex); + return APR_ENOLOCK; } APR_DECLARE(apr_status_t) apr_global_mutex_trylock(apr_global_mutex_t *mutex) { - return APR_ENOTIMPL; + if (mutex) + return apr_thread_mutex_trylock(mutex->mutex); + return APR_ENOLOCK; } APR_DECLARE(apr_status_t) apr_global_mutex_unlock(apr_global_mutex_t *mutex) { - return APR_ENOTIMPL; + if (mutex) + return apr_thread_mutex_unlock(mutex->mutex); + return APR_ENOLOCK; } APR_DECLARE(apr_status_t) apr_global_mutex_destroy(apr_global_mutex_t *mutex) { - return APR_ENOTIMPL; + if (mutex) + return apr_thread_mutex_destroy(mutex->mutex); + return APR_ENOLOCK; } APR_POOL_IMPLEMENT_ACCESSOR(global_mutex) |