Critical sections aren't heap-allocated in linux anymore.
git-svn-id: http://mc-server.googlecode.com/svn/trunk@1012 0a769ca7-a7f5-676a-18bf-c427514a06d6
This commit is contained in:
parent
403ef6bcdc
commit
31a326382a
@ -11,19 +11,17 @@
|
|||||||
|
|
||||||
cCriticalSection::cCriticalSection()
|
cCriticalSection::cCriticalSection()
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
InitializeCriticalSection( &m_CriticalSection );
|
InitializeCriticalSection(&m_CriticalSection);
|
||||||
#else
|
#else
|
||||||
m_Attributes = new pthread_mutexattr_t;
|
pthread_mutexattr_init(&m_Attributes);
|
||||||
pthread_mutexattr_init((pthread_mutexattr_t*)m_Attributes);
|
pthread_mutexattr_settype(&m_Attributes, PTHREAD_MUTEX_RECURSIVE);
|
||||||
pthread_mutexattr_settype((pthread_mutexattr_t*)m_Attributes, PTHREAD_MUTEX_RECURSIVE);
|
|
||||||
|
|
||||||
m_CriticalSectionPtr = new pthread_mutex_t;
|
if (pthread_mutex_init(&m_CriticalSection, &m_Attributes) != 0)
|
||||||
if( pthread_mutex_init( (pthread_mutex_t*)m_CriticalSectionPtr, (pthread_mutexattr_t*)m_Attributes ) != 0 )
|
|
||||||
{
|
{
|
||||||
LOG("ERROR: Could not initialize Critical Section!");
|
LOGERROR("Could not initialize Critical Section!");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -32,17 +30,15 @@ cCriticalSection::cCriticalSection()
|
|||||||
|
|
||||||
cCriticalSection::~cCriticalSection()
|
cCriticalSection::~cCriticalSection()
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
DeleteCriticalSection( &m_CriticalSection );
|
DeleteCriticalSection(&m_CriticalSection);
|
||||||
#else
|
#else
|
||||||
if( pthread_mutex_destroy( (pthread_mutex_t*)m_CriticalSectionPtr ) != 0 )
|
if (pthread_mutex_destroy(&m_CriticalSection) != 0)
|
||||||
{
|
{
|
||||||
LOG("ERROR: Could not destroy Critical Section!");
|
LOGWARNING("Could not destroy Critical Section!");
|
||||||
}
|
}
|
||||||
delete (pthread_mutex_t*)m_CriticalSectionPtr;
|
pthread_mutexattr_destroy(&m_Attributes);
|
||||||
pthread_mutexattr_destroy( (pthread_mutexattr_t*)m_Attributes );
|
#endif
|
||||||
delete (pthread_mutexattr_t*)m_Attributes;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -52,9 +48,9 @@ cCriticalSection::~cCriticalSection()
|
|||||||
void cCriticalSection::Lock()
|
void cCriticalSection::Lock()
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
EnterCriticalSection( &m_CriticalSection );
|
EnterCriticalSection(&m_CriticalSection);
|
||||||
#else
|
#else
|
||||||
pthread_mutex_lock( (pthread_mutex_t*)m_CriticalSectionPtr );
|
pthread_mutex_lock(&m_CriticalSection);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
@ -74,9 +70,9 @@ void cCriticalSection::Unlock()
|
|||||||
#endif // _DEBUG
|
#endif // _DEBUG
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
LeaveCriticalSection( &m_CriticalSection );
|
LeaveCriticalSection(&m_CriticalSection);
|
||||||
#else
|
#else
|
||||||
pthread_mutex_unlock( (pthread_mutex_t*)m_CriticalSectionPtr );
|
pthread_mutex_unlock(&m_CriticalSection);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -96,7 +92,7 @@ bool cCriticalSection::IsLocked(void)
|
|||||||
|
|
||||||
bool cCriticalSection::IsLockedByCurrentThread(void)
|
bool cCriticalSection::IsLockedByCurrentThread(void)
|
||||||
{
|
{
|
||||||
return m_IsLocked && (m_OwningThreadID == cIsThread::GetCurrentID());
|
return (m_IsLocked && (m_OwningThreadID == cIsThread::GetCurrentID()));
|
||||||
}
|
}
|
||||||
#endif // _DEBUG
|
#endif // _DEBUG
|
||||||
|
|
||||||
|
@ -28,8 +28,8 @@ private:
|
|||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
CRITICAL_SECTION m_CriticalSection;
|
CRITICAL_SECTION m_CriticalSection;
|
||||||
#else // _WIN32
|
#else // _WIN32
|
||||||
void* m_CriticalSectionPtr ALIGN_8; // Pointer to a CRITICAL_SECTION object
|
pthread_mutex_t m_CriticalSection;
|
||||||
void* m_Attributes ALIGN_8;
|
pthread_mutexattr_t m_Attributes;
|
||||||
#endif // else _WIN32
|
#endif // else _WIN32
|
||||||
} ALIGN_8;
|
} ALIGN_8;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user