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