27 #if defined(_THREAD_SAFE) && defined(TDS_HAVE_PTHREAD_MUTEX) 32 #include <freetds/pushvis.h> 35 #define TDS_RAW_MUTEX_INITIALIZER PTHREAD_MUTEX_INITIALIZER 39 pthread_mutex_lock(mtx);
44 return pthread_mutex_trylock(mtx);
49 pthread_mutex_unlock(mtx);
54 return pthread_mutex_init(mtx, NULL);
59 pthread_mutex_destroy(mtx);
67 return pthread_cond_destroy(cond);
71 return pthread_cond_signal(cond);
75 return pthread_cond_wait(cond, mtx);
79 #define TDS_HAVE_MUTEX 1 82 typedef pthread_t tds_thread_id;
83 typedef void *(*tds_thread_proc)(
void *arg);
84 #define TDS_THREAD_PROC_DECLARE(name, arg) \ 87 static inline int tds_thread_create(
tds_thread *ret, tds_thread_proc proc,
void *arg)
89 return pthread_create(ret, NULL, proc, arg);
92 static inline int tds_thread_create_detached(tds_thread_proc proc,
void *arg)
95 int ret = pthread_create(&th, NULL, proc, arg);
101 static inline int tds_thread_join(
tds_thread th,
void **ret)
103 return pthread_join(th, ret);
106 static inline tds_thread_id tds_thread_get_current_id(
void)
108 return pthread_self();
111 static inline int tds_thread_is_current(tds_thread_id th)
113 return pthread_equal(th, pthread_self());
116 #include <freetds/popvis.h> 118 #elif defined(_WIN32) 125 #define ETIMEDOUT 138 134 CRITICAL_SECTION crit;
137 #define TDS_RAW_MUTEX_INITIALIZER { NULL, 0, 0 } 153 EnterCriticalSection(&mtx->crit);
154 mtx->thread_id = GetCurrentThreadId();
156 tds_win_mutex_lock(mtx);
165 LeaveCriticalSection(&mtx->crit);
171 DeleteCriticalSection(&mtx->crit);
176 #define TDS_HAVE_MUTEX 1 179 typedef void *TDS_CONDITION_VARIABLE;
182 TDS_CONDITION_VARIABLE cv;
191 return tds_raw_cond_timedwait(cond, mtx, -1);
195 typedef DWORD tds_thread_id;
196 typedef void *(WINAPI *tds_thread_proc)(
void *arg);
197 #define TDS_THREAD_PROC_DECLARE(name, arg) \ 198 void *WINAPI name(void *arg) 200 static inline int tds_thread_create(tds_thread *ret, tds_thread_proc proc,
void *arg)
202 *ret = CreateThread(NULL, 0, (DWORD (WINAPI *)(
void*)) proc, arg, 0, NULL);
203 return *ret != NULL ? 0 : 11 ;
206 static inline int tds_thread_create_detached(tds_thread_proc proc,
void *arg)
208 HANDLE h = CreateThread(NULL, 0, (DWORD (WINAPI *)(
void*)) proc, arg, 0, NULL);
215 static inline int tds_thread_join(tds_thread th,
void **ret)
217 if (WaitForSingleObject(th, INFINITE) == WAIT_OBJECT_0) {
219 if (ret && GetExitCodeThread(th, &r))
220 *ret = (
void*) (((
char*)0) + r);
229 static inline tds_thread_id tds_thread_get_current_id(
void)
231 return GetCurrentThreadId();
234 static inline int tds_thread_is_current(tds_thread_id th)
236 return th == GetCurrentThreadId();
245 #define TDS_RAW_MUTEX_INITIALIZER {} 247 static inline void tds_raw_mutex_lock(tds_raw_mutex *mtx)
251 static inline int tds_raw_mutex_trylock(tds_raw_mutex *mtx)
256 static inline void tds_raw_mutex_unlock(tds_raw_mutex *mtx)
260 static inline int tds_raw_mutex_init(tds_raw_mutex *mtx)
265 static inline void tds_raw_mutex_free(tds_raw_mutex *mtx)
272 static inline int tds_raw_cond_init(tds_condition *cond)
276 static inline int tds_raw_cond_destroy(tds_condition *cond)
280 #define tds_raw_cond_signal(cond) \ 281 FreeTDS_Condition_not_compiled 283 #define tds_raw_cond_wait(cond, mtx) \ 284 FreeTDS_Condition_not_compiled 286 #define tds_raw_cond_timedwait(cond, mtx, timeout_sec) \ 287 FreeTDS_Condition_not_compiled 291 typedef int tds_thread_id;
293 typedef void *(*tds_thread_proc)(
void *arg);
294 #define TDS_THREAD_PROC_DECLARE(name, arg) \ 295 void *name(void *arg) 297 #define tds_thread_create(ret, proc, arg) \ 298 FreeTDS_Thread_not_compiled 300 #define tds_thread_create_detached(proc, arg) \ 301 FreeTDS_Thread_not_compiled 303 #define tds_thread_join(th, ret) \ 304 FreeTDS_Thread_not_compiled 306 static inline tds_thread_id tds_thread_get_current_id(
void)
311 static inline int tds_thread_is_current(tds_thread_id th)
319 #ifdef TDS_HAVE_MUTEX 320 # define tds_cond_init tds_raw_cond_init 321 # define tds_cond_destroy tds_raw_cond_destroy 322 # define tds_cond_signal tds_raw_cond_signal 323 # if !ENABLE_EXTRA_CHECKS 324 # define TDS_MUTEX_INITIALIZER TDS_RAW_MUTEX_INITIALIZER 325 # define tds_mutex tds_raw_mutex 326 # define tds_mutex_lock tds_raw_mutex_lock 327 # define tds_mutex_trylock tds_raw_mutex_trylock 328 # define tds_mutex_unlock tds_raw_mutex_unlock 329 # define tds_mutex_check_owned(mtx) do {} while(0) 330 # define tds_mutex_init tds_raw_mutex_init 331 # define tds_mutex_free tds_raw_mutex_free 332 # define tds_cond_wait tds_raw_cond_wait 333 # define tds_cond_timedwait tds_raw_cond_timedwait 337 typedef struct tds_mutex
341 volatile tds_thread_id locked_by;
344 # define TDS_MUTEX_INITIALIZER { TDS_RAW_MUTEX_INITIALIZER, 0 } 346 static inline void tds_mutex_lock(tds_mutex *mtx)
349 tds_raw_mutex_lock(&mtx->mtx);
350 assert(!mtx->locked);
352 mtx->locked_by = tds_thread_get_current_id();
355 static inline int tds_mutex_trylock(tds_mutex *mtx)
359 ret = tds_raw_mutex_trylock(&mtx->mtx);
361 assert(!mtx->locked);
363 mtx->locked_by = tds_thread_get_current_id();
368 static inline void tds_mutex_unlock(tds_mutex *mtx)
370 assert(mtx && mtx->locked);
372 tds_raw_mutex_unlock(&mtx->mtx);
375 static inline void tds_mutex_check_owned(tds_mutex *mtx)
379 ret = tds_raw_mutex_trylock(&mtx->mtx);
382 assert(tds_thread_is_current(mtx->locked_by));
385 static inline int tds_mutex_init(tds_mutex *mtx)
388 return tds_raw_mutex_init(&mtx->mtx);
391 static inline void tds_mutex_free(tds_mutex *mtx)
393 assert(mtx && !mtx->locked);
394 tds_raw_mutex_free(&mtx->mtx);
397 static inline int tds_cond_wait(tds_condition *cond, tds_mutex *mtx)
400 assert(mtx && mtx->locked);
402 ret = tds_raw_cond_wait(cond, &mtx->mtx);
404 mtx->locked_by = tds_thread_get_current_id();
408 static inline int tds_cond_timedwait(tds_condition *cond, tds_mutex *mtx,
int timeout_sec)
411 assert(mtx && mtx->locked);
413 ret = tds_raw_cond_timedwait(cond, &mtx->mtx, timeout_sec);
415 mtx->locked_by = tds_thread_get_current_id();
Definition: ptw32_MCS_lock.c:97