diff options
author | Subv <subv2112@gmail.com> | 2018-01-08 17:35:03 +0100 |
---|---|---|
committer | bunnei <bunneidev@gmail.com> | 2018-01-09 03:12:49 +0100 |
commit | 2a3f8e8484fca54767c9874cc21f5985d2be1463 (patch) | |
tree | 0976e02e0b495f07b11a51811618199d791d4c4e /src/core/hle/kernel/wait_object.cpp | |
parent | cmake: Use LIBUNICORN_* on Windows. (diff) | |
download | yuzu-2a3f8e8484fca54767c9874cc21f5985d2be1463.tar yuzu-2a3f8e8484fca54767c9874cc21f5985d2be1463.tar.gz yuzu-2a3f8e8484fca54767c9874cc21f5985d2be1463.tar.bz2 yuzu-2a3f8e8484fca54767c9874cc21f5985d2be1463.tar.lz yuzu-2a3f8e8484fca54767c9874cc21f5985d2be1463.tar.xz yuzu-2a3f8e8484fca54767c9874cc21f5985d2be1463.tar.zst yuzu-2a3f8e8484fca54767c9874cc21f5985d2be1463.zip |
Diffstat (limited to 'src/core/hle/kernel/wait_object.cpp')
-rw-r--r-- | src/core/hle/kernel/wait_object.cpp | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/src/core/hle/kernel/wait_object.cpp b/src/core/hle/kernel/wait_object.cpp index c942a40fa..ec147b84c 100644 --- a/src/core/hle/kernel/wait_object.cpp +++ b/src/core/hle/kernel/wait_object.cpp @@ -68,6 +68,8 @@ SharedPtr<Thread> WaitObject::GetHighestPriorityReadyThread() { } void WaitObject::WakeupWaitingThread(SharedPtr<Thread> thread) { + ASSERT(!ShouldWait(thread.get())); + if (!thread) return; @@ -75,19 +77,26 @@ void WaitObject::WakeupWaitingThread(SharedPtr<Thread> thread) { Acquire(thread.get()); } else { for (auto& object : thread->wait_objects) { + ASSERT(!object->ShouldWait(thread.get())); object->Acquire(thread.get()); } } - // Invoke the wakeup callback before clearing the wait objects - if (thread->wakeup_callback) - thread->wakeup_callback(ThreadWakeupReason::Signal, thread, this); + size_t index = thread->GetWaitObjectIndex(this); for (auto& object : thread->wait_objects) object->RemoveWaitingThread(thread.get()); thread->wait_objects.clear(); - thread->ResumeFromWait(); + thread->CancelWakeupTimer(); + + bool resume = true; + + if (thread->wakeup_callback) + resume = thread->wakeup_callback(ThreadWakeupReason::Signal, thread, this, index); + + if (resume) + thread->ResumeFromWait(); } void WaitObject::WakeupAllWaitingThreads() { |