diff options
| author | 2015-01-14 23:19:22 -0500 | |
|---|---|---|
| committer | 2015-01-21 18:41:58 -0500 | |
| commit | 5e77e2e1de73ce7786f52f2a74c28182fa4aa845 (patch) | |
| tree | d874f351cd8bc11757d50deba4fea1abefd323d2 /src/core/hle/kernel/kernel.cpp | |
| parent | Kernel: Added WaitObject and changed "waitable" objects inherit from it. (diff) | |
| download | yuzu-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.cpp | 13 |
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; | |||
| 19 | u64 g_program_id = 0; | 19 | u64 g_program_id = 0; |
| 20 | 20 | ||
| 21 | void WaitObject::AddWaitingThread(Thread* thread) { | 21 | void 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 | |||
| 27 | void 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 | ||
| 27 | Thread* WaitObject::ResumeNextThread() { | 33 | Thread* 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 | ||