X-Git-Url: http://git.silcnet.org/gitweb/?p=silc.git;a=blobdiff_plain;f=lib%2Fsilcutil%2Funix%2Fsilcunixmutex.c;h=d6eb0f233f973dd63e51d183b29b5ad577fb4696;hp=7875eb80a303391279de87512c8e0a717f58c806;hb=382d15d447b7a95390decfa783836ae4fe255b3d;hpb=1c2e84130f2ea435bef9dbfe0becbd6b696e8048 diff --git a/lib/silcutil/unix/silcunixmutex.c b/lib/silcutil/unix/silcunixmutex.c index 7875eb80..d6eb0f23 100644 --- a/lib/silcutil/unix/silcunixmutex.c +++ b/lib/silcutil/unix/silcunixmutex.c @@ -21,36 +21,51 @@ #include "silcincludes.h" -#ifdef SILC_THREADS - /* SILC Mutex structure */ struct SilcMutexStruct { +#ifdef SILC_THREADS pthread_mutex_t mutex; + unsigned int locked : 1; +#else + void *tmp; +#endif /* SILC_THREADS */ }; -SilcMutex silc_mutex_alloc(void) +bool silc_mutex_alloc(SilcMutex *mutex) { - SilcMutex mutex = silc_calloc(1, sizeof(*mutex)); - pthread_mutex_init(&mutex->mutex, NULL); - return mutex; +#ifdef SILC_THREADS + *mutex = silc_calloc(1, sizeof(**mutex)); + if (*mutex == NULL) + return FALSE; + pthread_mutex_init(&(*mutex)->mutex, NULL); +#endif /* SILC_THREADS */ + return TRUE; } void silc_mutex_free(SilcMutex mutex) { +#ifdef SILC_THREADS pthread_mutex_destroy(&mutex->mutex); silc_free(mutex); +#endif /* SILC_THREADS */ } void silc_mutex_lock(SilcMutex mutex) { +#ifdef SILC_THREADS if (pthread_mutex_lock(&mutex->mutex)) assert(FALSE); + assert(mutex->locked == 0); + mutex->locked = 1; +#endif /* SILC_THREADS */ } void silc_mutex_unlock(SilcMutex mutex) { +#ifdef SILC_THREADS + assert(mutex->locked == 1); + mutex->locked = 0; if (pthread_mutex_unlock(&mutex->mutex)) assert(FALSE); -} - #endif /* SILC_THREADS */ +}