diff options
| author | 2019-02-27 00:50:09 +0100 | |
|---|---|---|
| committer | 2019-02-27 00:50:09 +0100 | |
| commit | dc90b02fa522c7c10d91715303d2fdec2da41005 (patch) | |
| tree | 1ba747ccbfc206ab72d2a2e28f73d93788f2372a /common/thread.c | |
| parent | c644d6634fbf71306455bd0e15dd3e1f96ac249d (diff) | |
| download | libusbmuxd-dc90b02fa522c7c10d91715303d2fdec2da41005.tar.gz libusbmuxd-dc90b02fa522c7c10d91715303d2fdec2da41005.tar.bz2 | |
Use common thread implementation as used in other libimobiledevice libraries
Diffstat (limited to 'common/thread.c')
| -rw-r--r-- | common/thread.c | 140 | 
1 files changed, 140 insertions, 0 deletions
| diff --git a/common/thread.c b/common/thread.c new file mode 100644 index 0000000..da7eb21 --- /dev/null +++ b/common/thread.c @@ -0,0 +1,140 @@ +/* + * thread.c + * + * 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 + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + */ + +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif +#include "thread.h" + +int thread_new(THREAD_T *thread, thread_func_t thread_func, void* data) +{ +#ifdef WIN32 +	HANDLE th = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)thread_func, data, 0, NULL); +	if (th == NULL) { +		return -1; +	} +	*thread = th; +	return 0; +#else +	int res = pthread_create(thread, NULL, thread_func, data); +	return res; +#endif +} + +void thread_detach(THREAD_T thread) +{ +#ifdef WIN32 +	CloseHandle(thread); +#else +	pthread_detach(thread); +#endif +} + +void thread_free(THREAD_T thread) +{ +#ifdef WIN32 +	CloseHandle(thread); +#endif +} + +int thread_join(THREAD_T thread) +{ +	/* wait for thread to complete */ +#ifdef WIN32 +	return (int)WaitForSingleObject(thread, INFINITE); +#else +	return pthread_join(thread, NULL); +#endif +} + +int thread_alive(THREAD_T thread) +{ +#ifdef WIN32 +	return WaitForSingleObject(thread, 0) == WAIT_TIMEOUT; +#else +	return pthread_kill(thread, 0) == 0; +#endif +} + +int thread_cancel(THREAD_T thread) +{ +#ifdef WIN32 +	return 0; +#else +#ifdef HAVE_PTHREAD_CANCEL +	return pthread_cancel(thread); +#else +	return 0; +#endif +#endif +} + +void mutex_init(mutex_t* mutex) +{ +#ifdef WIN32 +	InitializeCriticalSection(mutex); +#else +	pthread_mutex_init(mutex, NULL); +#endif +} + +void mutex_destroy(mutex_t* mutex) +{ +#ifdef WIN32 +	DeleteCriticalSection(mutex); +#else +	pthread_mutex_destroy(mutex); +#endif +} + +void mutex_lock(mutex_t* mutex) +{ +#ifdef WIN32 +	EnterCriticalSection(mutex); +#else +	pthread_mutex_lock(mutex); +#endif +} + +void mutex_unlock(mutex_t* mutex) +{ +#ifdef WIN32 +	LeaveCriticalSection(mutex); +#else +	pthread_mutex_unlock(mutex); +#endif +} + +void thread_once(thread_once_t *once_control, void (*init_routine)(void)) +{ +#ifdef WIN32 +	while (InterlockedExchange(&(once_control->lock), 1) != 0) { +		Sleep(1); +	} +	if (!once_control->state) { +		once_control->state = 1; +		init_routine(); +	} +	InterlockedExchange(&(once_control->lock), 0); +#else +	pthread_once(once_control, init_routine); +#endif +} | 
