friend class IPCChannel;
protected:
- volatile bool initialized;
+ QAtomicInt initialized;
QScopedPointer<QSharedMemory> sharedmem;
QScopedPointer<QSystemSemaphore> semaphore_rd;
QScopedPointer<QSystemSemaphore> semaphore_wr;
m_appVersionNo(appVersionNo),
m_headerStr(QCryptographicHash::hash(MAKE_ID(applicationId, appVersionNo, channelId, "header").toLatin1(), QCryptographicHash::Sha1).toHex())
{
- p->initialized = false;
if(m_headerStr.length() != Internal::HDR_LEN)
{
MUTILS_THROW("Invalid header length has been detected!");
MUtils::IPCChannel::~IPCChannel(void)
{
- if(p->initialized)
+ if(MUTILS_BOOLIFY(p->initialized))
{
if(p->sharedmem->isAttached())
{
{
QWriteLocker writeLock(&p->lock);
- if(p->initialized)
+ if(MUTILS_BOOLIFY(p->initialized))
{
return RET_ALREADY_INITIALIZED;
}
qWarning("Failed to access shared memory: %s", MUTILS_UTF8(errorMessage));
return RET_FAILURE;
}
- p->initialized = true;
+ p->initialized.ref();
return RET_SUCCESS_SLAVE;
}
else
//qDebug("IPC KEY #2: %s", MUTILS_UTF8(p->semaphore_rd->key()));
//qDebug("IPC KEY #3: %s", MUTILS_UTF8(p->semaphore_wr->key()));
- p->initialized = true;
+ p->initialized.ref();
return RET_SUCCESS_MASTER;
}
///////////////////////////////////////////////////////////////////////////////
static MUtils::Internal::CriticalSection g_fatal_exit_lock;
-static volatile bool g_fatal_exit_flag = true;
+static QAtomicInt g_fatal_exit_flag;
static DWORD WINAPI fatal_exit_helper(LPVOID lpParameter)
{
{
g_fatal_exit_lock.enter();
- if(!g_fatal_exit_flag)
+ if(!g_fatal_exit_flag.testAndSetOrdered(0, 1))
{
return; /*prevent recursive invocation*/
}
- g_fatal_exit_flag = false;
-
if(g_main_thread_id != GetCurrentThreadId())
{
if(HANDLE hThreadMain = OpenThread(THREAD_SUSPEND_RESUME, FALSE, g_main_thread_id))
}
}
- if(HANDLE hThread = CreateThread(NULL, 0, fatal_exit_helper, (LPVOID) errorMessage, 0, NULL))
+ if(HANDLE hThread = CreateThread(NULL, 0, fatal_exit_helper, (LPVOID)errorMessage, 0, NULL))
{
WaitForSingleObject(hThread, INFINITE);
}
+ else
+ {
+ fatal_exit_helper((LPVOID)errorMessage);
+ }
for(;;)
{