8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-24 09:23:03 +01:00

Mac port - use dispatch semaphores

This commit is contained in:
alexpeshkoff 2010-06-08 13:18:45 +00:00
parent 7a69886c3b
commit ef56abd46e
2 changed files with 10 additions and 18 deletions

View File

@ -33,23 +33,18 @@ namespace Firebird {
#ifdef COMMON_CLASSES_SEMAPHORE_MACH #ifdef COMMON_CLASSES_SEMAPHORE_MACH
void SignalSafeSemaphore::machErrorCheck(kern_return_t rc, const char* fun)
{
if (rc != KERN_SUCCESS)
{
(Arg::Gds(isc_sys_request) << fun << Arg::Mach(static_cast<ISC_STATUS>(rc))).raise();
}
}
void SignalSafeSemaphore::init() void SignalSafeSemaphore::init()
{ {
machErrorCheck(semaphore_create(mach_task_self(), &sem, SYNC_POLICY_FIFO, 0), semaphore = dispatch_semaphore_create(0);
"semaphore_create"); if (!semaphore) // With const zero parameter this means OOM
{
BadAlloc::raise();
}
} }
SignalSafeSemaphore::~SignalSafeSemaphore() SignalSafeSemaphore::~SignalSafeSemaphore()
{ {
machErrorCheck(semaphore_destroy(mach_task_self(), sem), "semaphore_destroy"); dispatch_release(semaphore);
} }
#endif // COMMON_CLASSES_SEMAPHORE_MACH #endif // COMMON_CLASSES_SEMAPHORE_MACH

View File

@ -93,9 +93,7 @@ public:
// Mach semaphore // Mach semaphore
#define COMMON_CLASSES_SEMAPHORE_MACH #define COMMON_CLASSES_SEMAPHORE_MACH
#include <mach/mach.h> #include <dispatch/dispatch.h>
#include <mach/semaphore.h>
#include <mach/task.h>
namespace Firebird namespace Firebird
{ {
@ -105,9 +103,8 @@ class MemoryPool;
class SignalSafeSemaphore class SignalSafeSemaphore
{ {
private: private:
semaphore_t sem; dispatch_semaphore_t semaphore;
static void machErrorCheck(kern_return_t rc, const char* function);
void init(); void init();
public: public:
@ -118,7 +115,7 @@ public:
void enter() void enter()
{ {
machErrorCheck(semaphore_wait(sem), "semaphore_wait"); dispatch_semaphore_wait(semaphore);
} }
void release(SLONG count = 1) void release(SLONG count = 1)
@ -126,7 +123,7 @@ public:
fb_assert(count >= 0); fb_assert(count >= 0);
while (count--) while (count--)
{ {
machErrorCheck(semaphore_signal(sem), "semaphore_signal"); dispatch_semaphore_signal(semaphore);
} }
} }
}; };