mirror of
https://github.com/PabloMK7/citra.git
synced 2025-01-19 10:23:06 +01:00
Improved the algorithm for GetHighestPriorityReadyThread.
This commit is contained in:
parent
bdad00c73f
commit
1f286b72a1
1 changed files with 13 additions and 14 deletions
|
@ -40,24 +40,23 @@ SharedPtr<Thread> WaitObject::GetHighestPriorityReadyThread() {
|
||||||
if (waiting_threads.empty())
|
if (waiting_threads.empty())
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
|
||||||
auto candidate_threads = waiting_threads;
|
SharedPtr<Thread> candidate = nullptr;
|
||||||
|
s32 candidate_priority = THREADPRIO_LOWEST + 1;
|
||||||
|
|
||||||
// Eliminate all threads that are waiting on more than one object, and not all of said objects are ready
|
for (const auto& thread : waiting_threads) {
|
||||||
candidate_threads.erase(std::remove_if(candidate_threads.begin(), candidate_threads.end(), [](const SharedPtr<Thread>& thread) -> bool {
|
if (thread->current_priority >= candidate_priority)
|
||||||
return std::any_of(thread->wait_objects.begin(), thread->wait_objects.end(), [](const SharedPtr<WaitObject>& object) -> bool {
|
continue;
|
||||||
|
|
||||||
|
bool ready_to_run = std::none_of(thread->wait_objects.begin(), thread->wait_objects.end(), [](const SharedPtr<WaitObject>& object) {
|
||||||
return object->ShouldWait();
|
return object->ShouldWait();
|
||||||
});
|
});
|
||||||
}), candidate_threads.end());
|
if (ready_to_run) {
|
||||||
|
candidate = thread;
|
||||||
|
candidate_priority = thread->current_priority;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Return the thread with the lowest priority value (The one with the highest priority)
|
return candidate;
|
||||||
auto thread_itr = std::min_element(candidate_threads.begin(), candidate_threads.end(), [](const SharedPtr<Thread>& lhs, const SharedPtr<Thread>& rhs) {
|
|
||||||
return lhs->current_priority < rhs->current_priority;
|
|
||||||
});
|
|
||||||
|
|
||||||
if (thread_itr == candidate_threads.end())
|
|
||||||
return nullptr;
|
|
||||||
|
|
||||||
return *thread_itr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaitObject::WakeupAllWaitingThreads() {
|
void WaitObject::WakeupAllWaitingThreads() {
|
||||||
|
|
Loading…
Reference in a new issue