summaryrefslogtreecommitdiff
path: root/src/core/hle/kernel/kernel.cpp
diff options
context:
space:
mode:
authorGravatar bunnei2015-01-14 23:19:22 -0500
committerGravatar bunnei2015-01-21 18:41:58 -0500
commit5e77e2e1de73ce7786f52f2a74c28182fa4aa845 (patch)
treed874f351cd8bc11757d50deba4fea1abefd323d2 /src/core/hle/kernel/kernel.cpp
parentKernel: Added WaitObject and changed "waitable" objects inherit from it. (diff)
downloadyuzu-5e77e2e1de73ce7786f52f2a74c28182fa4aa845.tar.gz
yuzu-5e77e2e1de73ce7786f52f2a74c28182fa4aa845.tar.xz
yuzu-5e77e2e1de73ce7786f52f2a74c28182fa4aa845.zip
WaitObject: Added RemoveWaitingThread, fixed a bug, and cleanup.
Diffstat (limited to 'src/core/hle/kernel/kernel.cpp')
-rw-r--r--src/core/hle/kernel/kernel.cpp13
1 files changed, 10 insertions, 3 deletions
diff --git a/src/core/hle/kernel/kernel.cpp b/src/core/hle/kernel/kernel.cpp
index 07e96e633..1dba85939 100644
--- a/src/core/hle/kernel/kernel.cpp
+++ b/src/core/hle/kernel/kernel.cpp
@@ -19,13 +19,20 @@ HandleTable g_handle_table;
19u64 g_program_id = 0; 19u64 g_program_id = 0;
20 20
21void WaitObject::AddWaitingThread(Thread* thread) { 21void WaitObject::AddWaitingThread(Thread* thread) {
22 if (std::find(waiting_threads.begin(), waiting_threads.end(), thread) == waiting_threads.end()) { 22 auto itr = std::find(waiting_threads.begin(), waiting_threads.end(), thread);
23 if (itr == waiting_threads.end())
23 waiting_threads.push_back(thread); 24 waiting_threads.push_back(thread);
24 } 25}
26
27void WaitObject::RemoveWaitingThread(Thread* thread) {
28 auto itr = std::find(waiting_threads.begin(), waiting_threads.end(), thread);
29 if (itr != waiting_threads.end())
30 waiting_threads.erase(itr);
25} 31}
26 32
27Thread* WaitObject::ResumeNextThread() { 33Thread* WaitObject::ResumeNextThread() {
28 if (waiting_threads.empty()) return nullptr; 34 if (waiting_threads.empty())
35 return nullptr;
29 36
30 auto next_thread = waiting_threads.front(); 37 auto next_thread = waiting_threads.front();
31 38