mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-08 21:47:57 +00:00
dmnt: fix edge case in debug events thread
This commit is contained in:
parent
8abee1bdaa
commit
fe2dd671fb
1 changed files with 15 additions and 6 deletions
|
@ -200,7 +200,7 @@ namespace sts::dmnt::cheat::impl {
|
||||||
/* Spawn application detection thread, spawn cheat vm thread. */
|
/* Spawn application detection thread, spawn cheat vm thread. */
|
||||||
R_ASSERT(this->detect_thread.Initialize(&CheatProcessManager::DetectLaunchThread, this, 0x4000, 39));
|
R_ASSERT(this->detect_thread.Initialize(&CheatProcessManager::DetectLaunchThread, this, 0x4000, 39));
|
||||||
R_ASSERT(this->vm_thread.Initialize(&CheatProcessManager::VirtualMachineThread, this, 0x4000, 48));
|
R_ASSERT(this->vm_thread.Initialize(&CheatProcessManager::VirtualMachineThread, this, 0x4000, 48));
|
||||||
R_ASSERT(this->debug_events_thread.Initialize(&CheatProcessManager::DebugEventsThread, this, 0x4000, 48));
|
R_ASSERT(this->debug_events_thread.Initialize(&CheatProcessManager::DebugEventsThread, this, 0x4000, 24));
|
||||||
|
|
||||||
/* Start threads. */
|
/* Start threads. */
|
||||||
R_ASSERT(this->detect_thread.Start());
|
R_ASSERT(this->detect_thread.Start());
|
||||||
|
@ -547,12 +547,21 @@ namespace sts::dmnt::cheat::impl {
|
||||||
while (true) {
|
while (true) {
|
||||||
/* Atomically wait (and clear) signal for new process. */
|
/* Atomically wait (and clear) signal for new process. */
|
||||||
this_ptr->debug_events_signal.Wait(true);
|
this_ptr->debug_events_signal.Wait(true);
|
||||||
while (R_SUCCEEDED(svcWaitSynchronizationSingle(this_ptr->GetCheatProcessHandle(), U64_MAX))) {
|
while (true) {
|
||||||
std::scoped_lock lk(this_ptr->cheat_lock);
|
while (R_SUCCEEDED(svcWaitSynchronizationSingle(this_ptr->GetCheatProcessHandle(), U64_MAX))) {
|
||||||
|
std::scoped_lock lk(this_ptr->cheat_lock);
|
||||||
|
|
||||||
/* Handle any pending debug events. */
|
/* Handle any pending debug events. */
|
||||||
if (this_ptr->HasActiveCheatProcess()) {
|
if (this_ptr->HasActiveCheatProcess()) {
|
||||||
dmnt::cheat::impl::ContinueCheatProcess(this_ptr->GetCheatProcessHandle());
|
dmnt::cheat::impl::ContinueCheatProcess(this_ptr->GetCheatProcessHandle());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* WaitSynchronization failed. This means someone canceled our synchronization, possibly us. */
|
||||||
|
/* Let's check if we should quit! */
|
||||||
|
std::scoped_lock lk(this_ptr->cheat_lock);
|
||||||
|
if (!this_ptr->HasActiveCheatProcess()) {
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue