xref: /freebsd/sys/contrib/zstd/lib/common/threading.h (revision 37f1f2684f2670b204080ef2d6c303becd28545f)
10c16b537SWarner Losh /**
20c16b537SWarner Losh  * Copyright (c) 2016 Tino Reichardt
30c16b537SWarner Losh  * All rights reserved.
40c16b537SWarner Losh  *
5*37f1f268SConrad Meyer  * You can contact the author at:
6*37f1f268SConrad Meyer  * - zstdmt source repository: https://github.com/mcmilk/zstdmt
7*37f1f268SConrad Meyer  *
80c16b537SWarner Losh  * This source code is licensed under both the BSD-style license (found in the
90c16b537SWarner Losh  * LICENSE file in the root directory of this source tree) and the GPLv2 (found
100c16b537SWarner Losh  * in the COPYING file in the root directory of this source tree).
11*37f1f268SConrad Meyer  * You may select, at your option, one of the above-listed licenses.
120c16b537SWarner Losh  */
130c16b537SWarner Losh 
140c16b537SWarner Losh #ifndef THREADING_H_938743
150c16b537SWarner Losh #define THREADING_H_938743
160c16b537SWarner Losh 
179cbefe25SConrad Meyer #include "debug.h"
189cbefe25SConrad Meyer 
190c16b537SWarner Losh #if defined (__cplusplus)
200c16b537SWarner Losh extern "C" {
210c16b537SWarner Losh #endif
220c16b537SWarner Losh 
230c16b537SWarner Losh #if defined(ZSTD_MULTITHREAD) && defined(_WIN32)
240c16b537SWarner Losh 
250c16b537SWarner Losh /**
260c16b537SWarner Losh  * Windows minimalist Pthread Wrapper, based on :
270c16b537SWarner Losh  * http://www.cse.wustl.edu/~schmidt/win32-cv-1.html
280c16b537SWarner Losh  */
290c16b537SWarner Losh #ifdef WINVER
300c16b537SWarner Losh #  undef WINVER
310c16b537SWarner Losh #endif
320c16b537SWarner Losh #define WINVER       0x0600
330c16b537SWarner Losh 
340c16b537SWarner Losh #ifdef _WIN32_WINNT
350c16b537SWarner Losh #  undef _WIN32_WINNT
360c16b537SWarner Losh #endif
370c16b537SWarner Losh #define _WIN32_WINNT 0x0600
380c16b537SWarner Losh 
390c16b537SWarner Losh #ifndef WIN32_LEAN_AND_MEAN
400c16b537SWarner Losh #  define WIN32_LEAN_AND_MEAN
410c16b537SWarner Losh #endif
420c16b537SWarner Losh 
430c16b537SWarner Losh #undef ERROR   /* reported already defined on VS 2015 (Rich Geldreich) */
440c16b537SWarner Losh #include <windows.h>
450c16b537SWarner Losh #undef ERROR
460c16b537SWarner Losh #define ERROR(name) ZSTD_ERROR(name)
470c16b537SWarner Losh 
480c16b537SWarner Losh 
490c16b537SWarner Losh /* mutex */
500c16b537SWarner Losh #define ZSTD_pthread_mutex_t           CRITICAL_SECTION
5119fcbaf1SConrad Meyer #define ZSTD_pthread_mutex_init(a, b)  ((void)(b), InitializeCriticalSection((a)), 0)
520c16b537SWarner Losh #define ZSTD_pthread_mutex_destroy(a)  DeleteCriticalSection((a))
530c16b537SWarner Losh #define ZSTD_pthread_mutex_lock(a)     EnterCriticalSection((a))
540c16b537SWarner Losh #define ZSTD_pthread_mutex_unlock(a)   LeaveCriticalSection((a))
550c16b537SWarner Losh 
560c16b537SWarner Losh /* condition variable */
570c16b537SWarner Losh #define ZSTD_pthread_cond_t             CONDITION_VARIABLE
5819fcbaf1SConrad Meyer #define ZSTD_pthread_cond_init(a, b)    ((void)(b), InitializeConditionVariable((a)), 0)
5919fcbaf1SConrad Meyer #define ZSTD_pthread_cond_destroy(a)    ((void)(a))
600c16b537SWarner Losh #define ZSTD_pthread_cond_wait(a, b)    SleepConditionVariableCS((a), (b), INFINITE)
610c16b537SWarner Losh #define ZSTD_pthread_cond_signal(a)     WakeConditionVariable((a))
620c16b537SWarner Losh #define ZSTD_pthread_cond_broadcast(a)  WakeAllConditionVariable((a))
630c16b537SWarner Losh 
640c16b537SWarner Losh /* ZSTD_pthread_create() and ZSTD_pthread_join() */
650c16b537SWarner Losh typedef struct {
660c16b537SWarner Losh     HANDLE handle;
670c16b537SWarner Losh     void* (*start_routine)(void*);
680c16b537SWarner Losh     void* arg;
690c16b537SWarner Losh } ZSTD_pthread_t;
700c16b537SWarner Losh 
710c16b537SWarner Losh int ZSTD_pthread_create(ZSTD_pthread_t* thread, const void* unused,
720c16b537SWarner Losh                    void* (*start_routine) (void*), void* arg);
730c16b537SWarner Losh 
740c16b537SWarner Losh int ZSTD_pthread_join(ZSTD_pthread_t thread, void** value_ptr);
750c16b537SWarner Losh 
760c16b537SWarner Losh /**
770c16b537SWarner Losh  * add here more wrappers as required
780c16b537SWarner Losh  */
790c16b537SWarner Losh 
800c16b537SWarner Losh 
810c16b537SWarner Losh #elif defined(ZSTD_MULTITHREAD)    /* posix assumed ; need a better detection method */
820c16b537SWarner Losh /* ===   POSIX Systems   === */
830c16b537SWarner Losh #  include <pthread.h>
840c16b537SWarner Losh 
859cbefe25SConrad Meyer #if DEBUGLEVEL < 1
869cbefe25SConrad Meyer 
870c16b537SWarner Losh #define ZSTD_pthread_mutex_t            pthread_mutex_t
880c16b537SWarner Losh #define ZSTD_pthread_mutex_init(a, b)   pthread_mutex_init((a), (b))
890c16b537SWarner Losh #define ZSTD_pthread_mutex_destroy(a)   pthread_mutex_destroy((a))
900c16b537SWarner Losh #define ZSTD_pthread_mutex_lock(a)      pthread_mutex_lock((a))
910c16b537SWarner Losh #define ZSTD_pthread_mutex_unlock(a)    pthread_mutex_unlock((a))
920c16b537SWarner Losh 
930c16b537SWarner Losh #define ZSTD_pthread_cond_t             pthread_cond_t
940c16b537SWarner Losh #define ZSTD_pthread_cond_init(a, b)    pthread_cond_init((a), (b))
950c16b537SWarner Losh #define ZSTD_pthread_cond_destroy(a)    pthread_cond_destroy((a))
960c16b537SWarner Losh #define ZSTD_pthread_cond_wait(a, b)    pthread_cond_wait((a), (b))
970c16b537SWarner Losh #define ZSTD_pthread_cond_signal(a)     pthread_cond_signal((a))
980c16b537SWarner Losh #define ZSTD_pthread_cond_broadcast(a)  pthread_cond_broadcast((a))
990c16b537SWarner Losh 
1000c16b537SWarner Losh #define ZSTD_pthread_t                  pthread_t
1010c16b537SWarner Losh #define ZSTD_pthread_create(a, b, c, d) pthread_create((a), (b), (c), (d))
1020c16b537SWarner Losh #define ZSTD_pthread_join(a, b)         pthread_join((a),(b))
1030c16b537SWarner Losh 
1049cbefe25SConrad Meyer #else /* DEBUGLEVEL >= 1 */
1059cbefe25SConrad Meyer 
1069cbefe25SConrad Meyer /* Debug implementation of threading.
1079cbefe25SConrad Meyer  * In this implementation we use pointers for mutexes and condition variables.
1089cbefe25SConrad Meyer  * This way, if we forget to init/destroy them the program will crash or ASAN
1099cbefe25SConrad Meyer  * will report leaks.
1109cbefe25SConrad Meyer  */
1119cbefe25SConrad Meyer 
1129cbefe25SConrad Meyer #define ZSTD_pthread_mutex_t            pthread_mutex_t*
1139cbefe25SConrad Meyer int ZSTD_pthread_mutex_init(ZSTD_pthread_mutex_t* mutex, pthread_mutexattr_t const* attr);
1149cbefe25SConrad Meyer int ZSTD_pthread_mutex_destroy(ZSTD_pthread_mutex_t* mutex);
1159cbefe25SConrad Meyer #define ZSTD_pthread_mutex_lock(a)      pthread_mutex_lock(*(a))
1169cbefe25SConrad Meyer #define ZSTD_pthread_mutex_unlock(a)    pthread_mutex_unlock(*(a))
1179cbefe25SConrad Meyer 
1189cbefe25SConrad Meyer #define ZSTD_pthread_cond_t             pthread_cond_t*
1199cbefe25SConrad Meyer int ZSTD_pthread_cond_init(ZSTD_pthread_cond_t* cond, pthread_condattr_t const* attr);
1209cbefe25SConrad Meyer int ZSTD_pthread_cond_destroy(ZSTD_pthread_cond_t* cond);
1219cbefe25SConrad Meyer #define ZSTD_pthread_cond_wait(a, b)    pthread_cond_wait(*(a), *(b))
1229cbefe25SConrad Meyer #define ZSTD_pthread_cond_signal(a)     pthread_cond_signal(*(a))
1239cbefe25SConrad Meyer #define ZSTD_pthread_cond_broadcast(a)  pthread_cond_broadcast(*(a))
1249cbefe25SConrad Meyer 
1259cbefe25SConrad Meyer #define ZSTD_pthread_t                  pthread_t
1269cbefe25SConrad Meyer #define ZSTD_pthread_create(a, b, c, d) pthread_create((a), (b), (c), (d))
1279cbefe25SConrad Meyer #define ZSTD_pthread_join(a, b)         pthread_join((a),(b))
1289cbefe25SConrad Meyer 
1299cbefe25SConrad Meyer #endif
1309cbefe25SConrad Meyer 
1310c16b537SWarner Losh #else  /* ZSTD_MULTITHREAD not defined */
1320c16b537SWarner Losh /* No multithreading support */
1330c16b537SWarner Losh 
1340c16b537SWarner Losh typedef int ZSTD_pthread_mutex_t;
13519fcbaf1SConrad Meyer #define ZSTD_pthread_mutex_init(a, b)   ((void)(a), (void)(b), 0)
13619fcbaf1SConrad Meyer #define ZSTD_pthread_mutex_destroy(a)   ((void)(a))
13719fcbaf1SConrad Meyer #define ZSTD_pthread_mutex_lock(a)      ((void)(a))
13819fcbaf1SConrad Meyer #define ZSTD_pthread_mutex_unlock(a)    ((void)(a))
1390c16b537SWarner Losh 
1400c16b537SWarner Losh typedef int ZSTD_pthread_cond_t;
14119fcbaf1SConrad Meyer #define ZSTD_pthread_cond_init(a, b)    ((void)(a), (void)(b), 0)
14219fcbaf1SConrad Meyer #define ZSTD_pthread_cond_destroy(a)    ((void)(a))
14319fcbaf1SConrad Meyer #define ZSTD_pthread_cond_wait(a, b)    ((void)(a), (void)(b))
14419fcbaf1SConrad Meyer #define ZSTD_pthread_cond_signal(a)     ((void)(a))
14519fcbaf1SConrad Meyer #define ZSTD_pthread_cond_broadcast(a)  ((void)(a))
1460c16b537SWarner Losh 
1470c16b537SWarner Losh /* do not use ZSTD_pthread_t */
1480c16b537SWarner Losh 
1490c16b537SWarner Losh #endif /* ZSTD_MULTITHREAD */
1500c16b537SWarner Losh 
1510c16b537SWarner Losh #if defined (__cplusplus)
1520c16b537SWarner Losh }
1530c16b537SWarner Losh #endif
1540c16b537SWarner Losh 
1550c16b537SWarner Losh #endif /* THREADING_H_938743 */
156