2014-11-01 03:46:33 +00:00
|
|
|
/* radare - LGPL - Copyright 2009-2014 - pancake */
|
2009-07-21 11:13:24 +00:00
|
|
|
|
|
|
|
#include <r_th.h>
|
|
|
|
|
|
|
|
/* locks/mutex/sems */
|
|
|
|
|
2014-11-01 03:46:33 +00:00
|
|
|
R_API RThreadLock *r_th_lock_new() {
|
2010-06-27 20:14:06 +00:00
|
|
|
RThreadLock *thl = R_NEW(RThreadLock);
|
2010-05-20 15:40:58 +00:00
|
|
|
if (thl) {
|
|
|
|
thl->refs = 0;
|
2009-07-21 11:13:24 +00:00
|
|
|
#if HAVE_PTHREAD
|
2010-05-20 15:40:58 +00:00
|
|
|
pthread_mutex_init (&thl->lock, NULL);
|
2015-04-04 22:19:28 +00:00
|
|
|
#elif __WIN32__ || __WINDOWS__ && !defined(__CYGWIN__)
|
2010-05-20 15:40:58 +00:00
|
|
|
//thl->lock = CreateSemaphore(NULL, 0, 1, NULL);
|
|
|
|
InitializeCriticalSection(&thl->lock);
|
2009-07-21 11:13:24 +00:00
|
|
|
#endif
|
2010-05-20 15:40:58 +00:00
|
|
|
}
|
2009-07-21 11:13:24 +00:00
|
|
|
return thl;
|
|
|
|
}
|
|
|
|
|
2014-11-01 03:46:33 +00:00
|
|
|
R_API int r_th_lock_wait(RThreadLock *thl) {
|
2009-07-21 11:13:24 +00:00
|
|
|
#if HAVE_PTHREAD
|
2010-06-27 20:14:06 +00:00
|
|
|
r_th_lock_enter (thl); // locks here
|
|
|
|
r_th_lock_leave (thl); // releases previous mutex
|
2015-04-04 22:19:28 +00:00
|
|
|
#elif __WIN32__ || __WINDOWS__ && !defined(__CYGWIN__)
|
2010-03-25 09:18:59 +00:00
|
|
|
WaitForSingleObject (thl->lock, INFINITE);
|
2009-07-21 11:13:24 +00:00
|
|
|
#else
|
2015-04-04 22:26:06 +00:00
|
|
|
while (r_th_lock_check (thl));
|
2009-07-21 11:13:24 +00:00
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2014-11-01 03:46:33 +00:00
|
|
|
R_API int r_th_lock_enter(RThreadLock *thl) {
|
2009-07-21 11:13:24 +00:00
|
|
|
#if HAVE_PTHREAD
|
|
|
|
pthread_mutex_lock(&thl->lock);
|
2015-04-04 22:19:28 +00:00
|
|
|
#elif __WIN32__ || __WINDOWS__ && !defined(__CYGWIN__)
|
2014-11-01 03:46:33 +00:00
|
|
|
EnterCriticalSection (&thl->lock);
|
2009-07-21 11:13:24 +00:00
|
|
|
#endif
|
|
|
|
return ++thl->refs;
|
|
|
|
}
|
|
|
|
|
2014-11-01 03:46:33 +00:00
|
|
|
R_API int r_th_lock_leave(RThreadLock *thl) {
|
2009-07-21 11:13:24 +00:00
|
|
|
#if HAVE_PTHREAD
|
2014-11-01 03:46:33 +00:00
|
|
|
pthread_mutex_unlock (&thl->lock);
|
2015-04-04 22:19:28 +00:00
|
|
|
#elif __WIN32__ || __WINDOWS__ && !defined(__CYGWIN__)
|
2014-11-01 03:46:33 +00:00
|
|
|
LeaveCriticalSection (&thl->lock);
|
2009-07-21 11:13:24 +00:00
|
|
|
//ReleaseSemaphore (thl->lock, 1, NULL);
|
|
|
|
#endif
|
|
|
|
if (thl->refs>0)
|
|
|
|
thl->refs--;
|
|
|
|
return thl->refs;
|
|
|
|
}
|
|
|
|
|
2014-11-01 03:46:33 +00:00
|
|
|
R_API int r_th_lock_check(RThreadLock *thl) {
|
2009-07-21 11:13:24 +00:00
|
|
|
//w32 // TryEnterCriticalSection(&thl->lock);
|
|
|
|
return thl->refs;
|
|
|
|
}
|
|
|
|
|
2014-11-01 03:46:33 +00:00
|
|
|
R_API void *r_th_lock_free(RThreadLock *thl) {
|
2009-07-21 11:13:24 +00:00
|
|
|
if (thl) {
|
|
|
|
#if HAVE_PTHREAD
|
2010-06-27 20:14:06 +00:00
|
|
|
pthread_mutex_destroy (&thl->lock);
|
2015-04-04 22:19:28 +00:00
|
|
|
#elif __WIN32__ || __WINDOWS__ && !defined(__CYGWIN__)
|
2010-06-27 20:14:06 +00:00
|
|
|
DeleteCriticalSection (&thl->lock);
|
|
|
|
CloseHandle (thl->lock);
|
2009-07-21 11:13:24 +00:00
|
|
|
#endif
|
2014-11-01 03:46:33 +00:00
|
|
|
free (thl);
|
2009-07-21 11:13:24 +00:00
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|