aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/hle/kernel/thread.cpp
diff options
context:
space:
mode:
authorGravatar bunnei <bunneidev@gmail.com>2015-01-11 13:39:23 -0500
committerGravatar bunnei <bunneidev@gmail.com>2015-01-11 13:39:23 -0500
commit542b0b0057fcfa54ecc31dfe30d9bb435ca8f722 (patch)
tree9ca12fd4e5f5b13b4a75495c276a1b869670f542 /src/core/hle/kernel/thread.cpp
parent63d05fca367227f32c80098270725e06c2eb3531 (diff)
parentb68d51ed3047fe45e270b6d23de615c3f8c4b58b (diff)
Merge pull request #466 from Subv/wake
Thread: Prevent waking a thread multiple times.
Diffstat (limited to 'src/core/hle/kernel/thread.cpp')
-rw-r--r--src/core/hle/kernel/thread.cpp3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/core/hle/kernel/thread.cpp b/src/core/hle/kernel/thread.cpp
index dd20ca30..bc86a7c5 100644
--- a/src/core/hle/kernel/thread.cpp
+++ b/src/core/hle/kernel/thread.cpp
@@ -263,6 +263,9 @@ void WakeThreadAfterDelay(Thread* thread, s64 nanoseconds) {
/// Resumes a thread from waiting by marking it as "ready"
void Thread::ResumeFromWait() {
+ // Cancel any outstanding wakeup events
+ CoreTiming::UnscheduleEvent(ThreadWakeupEventType, GetHandle());
+
status &= ~THREADSTATUS_WAIT;
wait_object = nullptr;
wait_type = WAITTYPE_NONE;