summaryrefslogtreecommitdiff
path: root/src
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
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')
-rw-r--r--src/core/hle/kernel/kernel.cpp13
-rw-r--r--src/core/hle/kernel/kernel.h8
2 files changed, 17 insertions, 4 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
diff --git a/src/core/hle/kernel/kernel.h b/src/core/hle/kernel/kernel.h
index a9af9de88..53b3f9143 100644
--- a/src/core/hle/kernel/kernel.h
+++ b/src/core/hle/kernel/kernel.h
@@ -105,7 +105,13 @@ public:
105 void AddWaitingThread(Thread* thread); 105 void AddWaitingThread(Thread* thread);
106 106
107 /** 107 /**
108 * Resumes the next thread waiting on this object 108 * Removes a thread from waiting on this object (e.g. if it was resumed already)
109 * @param thread Pointer to thread to remove
110 */
111 void RemoveWaitingThread(Thread* thead);
112
113 /**
114 * Resumes (and removes) the next thread waiting on this object
109 * @return Pointer to the thread that was resumed, nullptr if no threads are waiting 115 * @return Pointer to the thread that was resumed, nullptr if no threads are waiting
110 */ 116 */
111 Thread* ResumeNextThread(); 117 Thread* ResumeNextThread();