From 59adbacef6d400d4c6458f26daddda24bcdfd635 Mon Sep 17 00:00:00 2001 From: Nikias Bassen Date: Tue, 11 Jun 2019 01:12:49 +0200 Subject: common: Update thread.c/.h to match the one from libusbmuxd --- common/thread.h | 33 ++++++++++++++++++++++++++------- 1 file changed, 26 insertions(+), 7 deletions(-) (limited to 'common/thread.h') diff --git a/common/thread.h b/common/thread.h index bd53c5b..23e4510 100644 --- a/common/thread.h +++ b/common/thread.h @@ -1,8 +1,8 @@ /* * thread.h * - * Copyright (c) 2012 Martin Szulecki All Rights Reserved. - * Copyright (c) 2012 Nikias Bassen All Rights Reserved. + * Copyright (c) 2012-2019 Nikias Bassen, All Rights Reserved. + * Copyright (c) 2012 Martin Szulecki, All Rights Reserved. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public @@ -22,9 +22,11 @@ #ifndef __THREAD_H #define __THREAD_H +#include + #ifdef WIN32 #include -typedef HANDLE thread_t; +typedef HANDLE THREAD_T; typedef CRITICAL_SECTION mutex_t; typedef volatile struct { LONG lock; @@ -32,20 +34,37 @@ typedef volatile struct { } thread_once_t; #define THREAD_ONCE_INIT {0, 0} #define THREAD_ID GetCurrentThreadId() +#define THREAD_T_NULL (THREAD_T)NULL #else #include -typedef pthread_t thread_t; +#include +typedef pthread_t THREAD_T; typedef pthread_mutex_t mutex_t; typedef pthread_once_t thread_once_t; #define THREAD_ONCE_INIT PTHREAD_ONCE_INIT #define THREAD_ID pthread_self() +#define THREAD_T_NULL (THREAD_T)NULL #endif typedef void* (*thread_func_t)(void* data); -int thread_new(thread_t* thread, thread_func_t thread_func, void* data); -void thread_free(thread_t thread); -void thread_join(thread_t thread); +int thread_new(THREAD_T* thread, thread_func_t thread_func, void* data); +void thread_detach(THREAD_T thread); +void thread_free(THREAD_T thread); +int thread_join(THREAD_T thread); +int thread_alive(THREAD_T thread); + +int thread_cancel(THREAD_T thread); + +#ifdef WIN32 +#undef HAVE_THREAD_CLEANUP +#else +#ifdef HAVE_PTHREAD_CANCEL +#define HAVE_THREAD_CLEANUP 1 +#define thread_cleanup_push(routine, arg) pthread_cleanup_push(routine, arg) +#define thread_cleanup_pop(execute) pthread_cleanup_pop(execute) +#endif +#endif void mutex_init(mutex_t* mutex); void mutex_destroy(mutex_t* mutex); -- cgit v1.1-32-gdbae