[*] Move setjmp to beginning of task invoker function for Linux thread kills
This commit is contained in:
parent
e30e004d04
commit
58d53c92c1
@ -84,7 +84,7 @@ static void RuntimeLateClean();
|
|||||||
|
|
||||||
static void Deinit()
|
static void Deinit()
|
||||||
{
|
{
|
||||||
tlsHackIsMainThread = true;
|
//tlsHackIsMainThread = true;
|
||||||
gRuntimeRunLevel = 3;
|
gRuntimeRunLevel = 3;
|
||||||
Aurora::Exit::PostLevel(AuThreads::GetThread(), Aurora::Exit::ETriggerLevel::eSafeTermination);
|
Aurora::Exit::PostLevel(AuThreads::GetThread(), Aurora::Exit::ETriggerLevel::eSafeTermination);
|
||||||
gRuntimeRunLevel = 4;
|
gRuntimeRunLevel = 4;
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
|
|
||||||
#if defined(AURORA_IS_LINUX_DERIVED)
|
#if defined(AURORA_IS_LINUX_DERIVED)
|
||||||
#include <sys/resource.h>
|
#include <sys/resource.h>
|
||||||
|
#include <cxxabi.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(AURORA_HAS_PTHREADS)
|
#if defined(AURORA_HAS_PTHREADS)
|
||||||
@ -97,6 +98,13 @@ namespace Aurora::Threading::Threads
|
|||||||
bool bDetached {};
|
bool bDetached {};
|
||||||
bool bDetachedSuccess {};
|
bool bDetachedSuccess {};
|
||||||
|
|
||||||
|
#if defined(AURORA_IS_POSIX_DERIVED)
|
||||||
|
if (getpid() == gettid())
|
||||||
|
{
|
||||||
|
RuntimeLateClean();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (this->bNotOwned)
|
if (this->bNotOwned)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
@ -113,7 +121,6 @@ namespace Aurora::Threading::Threads
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (this->contextUsed_)
|
if (this->contextUsed_)
|
||||||
{
|
{
|
||||||
if (this->detached_)
|
if (this->detached_)
|
||||||
@ -122,39 +129,38 @@ namespace Aurora::Threading::Threads
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (gRuntimeRunLevel < 3)
|
if (gRuntimeRunLevel <= 3)
|
||||||
{
|
{
|
||||||
Exit();
|
Exit();
|
||||||
}
|
}
|
||||||
else if (gRuntimeRunLevel >= 5)
|
else if (gRuntimeRunLevel >= 5)
|
||||||
{
|
{
|
||||||
|
|
||||||
// Application is dead
|
// Application is dead
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (RuntimeIsMainThread())
|
|
||||||
{
|
|
||||||
HookReleaseThreadResources();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// Kill the current OS thread instance
|
// Kill the current OS thread instance
|
||||||
TeminateOSContext(false);
|
TeminateOSContext(false);
|
||||||
|
|
||||||
if (this->exitOnlyOnce_)
|
if (this->exitOnlyOnce_)
|
||||||
{
|
{
|
||||||
this->exitOnlyOnce_->Unlock();
|
this->exitOnlyOnce_->Unlock();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
#if defined(AURORA_IS_POSIX_DERIVED)
|
||||||
if (gRuntimeRunLevel < 4) // minimum: async deinit level
|
if (this->terminated_)
|
||||||
{
|
{
|
||||||
WaitFor(this->terminated_.get());
|
WaitFor(this->terminated_.get());
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this->terminated_.reset();
|
this->terminated_.reset();
|
||||||
FreeOSContext();
|
FreeOSContext();
|
||||||
|
|
||||||
if (bDetached)
|
if (bDetached)
|
||||||
{
|
{
|
||||||
if (this->tlsReferenceThread_)
|
if (this->tlsReferenceThread_)
|
||||||
@ -446,6 +452,15 @@ namespace Aurora::Threading::Threads
|
|||||||
bool bFailing {};
|
bool bFailing {};
|
||||||
|
|
||||||
OSAttach();
|
OSAttach();
|
||||||
|
|
||||||
|
#if defined(AURORA_IS_POSIX_DERIVED)
|
||||||
|
this->bLongJmpOnce = false;
|
||||||
|
if (setjmp(env) != 0)
|
||||||
|
{
|
||||||
|
Exit(true);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (task_)
|
if (task_)
|
||||||
@ -461,6 +476,12 @@ namespace Aurora::Threading::Threads
|
|||||||
}
|
}
|
||||||
Exit(true);
|
Exit(true);
|
||||||
#else
|
#else
|
||||||
|
#if defined(AURORA_COMPILER_GCC)
|
||||||
|
catch (abi::__forced_unwind&)
|
||||||
|
{
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
catch (...)
|
catch (...)
|
||||||
{
|
{
|
||||||
bFailing = true;
|
bFailing = true;
|
||||||
@ -474,7 +495,10 @@ namespace Aurora::Threading::Threads
|
|||||||
|
|
||||||
if (this->terminated_)
|
if (this->terminated_)
|
||||||
{
|
{
|
||||||
this->exitOnlyOnce_->Unlock();
|
if (this->exitOnlyOnce_)
|
||||||
|
{
|
||||||
|
this->exitOnlyOnce_->Unlock();
|
||||||
|
}
|
||||||
this->terminated_->Set();
|
this->terminated_->Set();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -624,13 +648,6 @@ namespace Aurora::Threading::Threads
|
|||||||
this->unixThreadId_ = 0; // !!!!
|
this->unixThreadId_ = 0; // !!!!
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(AURORA_IS_POSIX_DERIVED)
|
|
||||||
if (setjmp(env) != 0)
|
|
||||||
{
|
|
||||||
pthread_exit(nullptr);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
UpdatePrio(this->throttle_, this->prio_);
|
UpdatePrio(this->throttle_, this->prio_);
|
||||||
SetAffinity(this->mask_);
|
SetAffinity(this->mask_);
|
||||||
UpdateName();
|
UpdateName();
|
||||||
@ -1077,7 +1094,7 @@ namespace Aurora::Threading::Threads
|
|||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
//::pthread_exit(nullptr);
|
::pthread_exit(nullptr);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user