X-Git-Url: http://git.silcnet.org/gitweb/?p=silc.git;a=blobdiff_plain;f=lib%2Fsilcutil%2Funix%2Fsilcunixmutex.c;h=d6eb0f233f973dd63e51d183b29b5ad577fb4696;hp=6b92ee3286d7a6c56cc79cee37607639e7f61aa4;hb=382d15d447b7a95390decfa783836ae4fe255b3d;hpb=3cf38201f9ffaad2da53757ed48a5546e1d03636 diff --git a/lib/silcutil/unix/silcunixmutex.c b/lib/silcutil/unix/silcunixmutex.c index 6b92ee32..d6eb0f23 100644 --- a/lib/silcutil/unix/silcunixmutex.c +++ b/lib/silcutil/unix/silcunixmutex.c @@ -25,6 +25,7 @@ struct SilcMutexStruct { #ifdef SILC_THREADS pthread_mutex_t mutex; + unsigned int locked : 1; #else void *tmp; #endif /* SILC_THREADS */ @@ -36,7 +37,6 @@ bool silc_mutex_alloc(SilcMutex *mutex) *mutex = silc_calloc(1, sizeof(**mutex)); if (*mutex == NULL) return FALSE; - pthread_mutex_init(&(*mutex)->mutex, NULL); #endif /* SILC_THREADS */ return TRUE; @@ -55,12 +55,16 @@ 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 */