diff --git a/FEXCore/Source/Interface/Core/Core.cpp b/FEXCore/Source/Interface/Core/Core.cpp index fa3009b758..0dc9ed9de7 100644 --- a/FEXCore/Source/Interface/Core/Core.cpp +++ b/FEXCore/Source/Interface/Core/Core.cpp @@ -873,9 +873,6 @@ uintptr_t ContextImpl::CompileBlock(FEXCore::Core::CpuStateFrame* Frame, uint64_ void ContextImpl::ExecutionThread(FEXCore::Core::InternalThreadState* Thread) { Thread->ExitReason = FEXCore::Context::ExitReason::EXIT_WAITING; - // Now notify the thread that we are initialized - Thread->ThreadWaiting.NotifyAll(); - if (Thread->StartPaused) { // Parent thread doesn't need to wait to run Thread->StartRunning.Wait(); diff --git a/FEXCore/include/FEXCore/Debug/InternalThreadState.h b/FEXCore/include/FEXCore/Debug/InternalThreadState.h index a15453996f..5ce663de39 100644 --- a/FEXCore/include/FEXCore/Debug/InternalThreadState.h +++ b/FEXCore/include/FEXCore/Debug/InternalThreadState.h @@ -91,7 +91,6 @@ struct InternalThreadState : public FEXCore::Allocator::FEXAllocOperators { NonMovableUniquePtr ExecutionThread; bool StartPaused {false}; InterruptableConditionVariable StartRunning; - Event ThreadWaiting; NonMovableUniquePtr OpDispatcher; diff --git a/Source/Tools/LinuxEmulation/LinuxSyscalls/Syscalls/Thread.cpp b/Source/Tools/LinuxEmulation/LinuxSyscalls/Syscalls/Thread.cpp index d7b8407ea8..0a9e8c234e 100644 --- a/Source/Tools/LinuxEmulation/LinuxSyscalls/Syscalls/Thread.cpp +++ b/Source/Tools/LinuxEmulation/LinuxSyscalls/Syscalls/Thread.cpp @@ -47,18 +47,24 @@ namespace FEX::HLE { struct ExecutionThreadHandler { FEXCore::Context::Context* CTX; FEX::HLE::ThreadStateObject* Thread; + Event* ThreadWaiting; }; static void* ThreadHandler(void* Data) { ExecutionThreadHandler* Handler = reinterpret_cast(Data); auto CTX = Handler->CTX; auto Thread = Handler->Thread; + auto ThreadWaiting = Handler->ThreadWaiting; FEXCore::Allocator::free(Handler); Thread->ThreadInfo.PID = ::getpid(); Thread->ThreadInfo.TID = FHU::Syscalls::gettid(); FEX::HLE::_SyscallHandler->RegisterTLSState(Thread); + + // Now notify the thread that we are initialized + ThreadWaiting->NotifyOne(); + CTX->ExecutionThread(Thread->Thread); FEX::HLE::_SyscallHandler->UninstallTLSState(Thread); FEX::HLE::_SyscallHandler->TM.DestroyThread(Thread); @@ -96,13 +102,15 @@ FEX::HLE::ThreadStateObject* CreateNewThread(FEXCore::Context::Context* CTX, FEX NewThread->Thread->StartPaused = true; // Initialize a new thread for execution. + Event ThreadWaitingEvent {}; ExecutionThreadHandler* Arg = reinterpret_cast(FEXCore::Allocator::malloc(sizeof(ExecutionThreadHandler))); Arg->CTX = CTX; Arg->Thread = NewThread; + Arg->ThreadWaiting = &ThreadWaitingEvent; NewThread->Thread->ExecutionThread = FEXCore::Threads::Thread::Create(ThreadHandler, Arg); // Wait for the thread to have started. - NewThread->Thread->ThreadWaiting.Wait(); + ThreadWaitingEvent.Wait(); if (FEX::HLE::_SyscallHandler->NeedXIDCheck()) { // The first time an application creates a thread, GLIBC installs their SETXID signal handler.