diff options
author | Jean-Francois Mauguit <jfmauguit@mac.com> | 2024-09-24 09:03:25 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-24 09:03:25 -0400 |
commit | bab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch) | |
tree | 12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/Wasabi/bfc/critsec.cpp | |
parent | 4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff) | |
parent | 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff) | |
download | winamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz |
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/Wasabi/bfc/critsec.cpp')
-rw-r--r-- | Src/Wasabi/bfc/critsec.cpp | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/Src/Wasabi/bfc/critsec.cpp b/Src/Wasabi/bfc/critsec.cpp new file mode 100644 index 00000000..e7506371 --- /dev/null +++ b/Src/Wasabi/bfc/critsec.cpp @@ -0,0 +1,73 @@ +#include "precomp_wasabi_bfc.h" +#include "critsec.h" +// uncomment this if needed +//#define CS_DEBUG + +CriticalSection::CriticalSection() { +#ifdef WIN32 + InitializeCriticalSection(&cs); +#elif defined(__APPLE__) + MPCreateCriticalRegion(&cr); +#elif defined(LINUX) + pthread_mutex_t recursive = PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP; + cs.mutex = recursive; +#endif + +#ifdef ASSERTS_ENABLED +#ifdef CS_DEBUG + within = 0; +#endif +#endif +} + +CriticalSection::~CriticalSection() { +#ifdef CS_DEBUG +#ifdef ASSERTS_ENABLED + ASSERT(!within); +#endif +#endif +#ifdef WIN32 + DeleteCriticalSection(&cs); +#elif defined(__APPLE__) + MPDeleteCriticalRegion(cr); +#elif defined(LINUX) + pthread_mutex_destroy(&cs.mutex); +#endif +} + +void CriticalSection::enter() { +#ifdef WIN32 + EnterCriticalSection(&cs); +#elif defined(__APPLE__) + MPEnterCriticalRegion(cr, kDurationForever); +#elif defined(LINUX) + pthread_mutex_lock(&cs.mutex); +#endif + +#ifdef CS_DEBUG +#ifdef ASSERTS_ENABLED + ASSERT(!within); + within = 1; +#endif +#endif +} + +void CriticalSection::leave() { +#if defined(CS_DEBUG) && defined(ASSERTS_ENABLED) + ASSERT(within); + within = 0; +#endif + +#ifdef WIN32 + LeaveCriticalSection(&cs); +#elif defined(__APPLE__) + MPExitCriticalRegion(cr); +#elif defined(LINUX) + pthread_mutex_unlock(&cs.mutex); +#endif +} + +void CriticalSection::inout() { + enter(); + leave(); +} |