|
|
|
@ -188,6 +188,43 @@ void ChangeThreadState(Thread* t, ThreadStatus new_status) {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Arbitrate the highest priority thread that is waiting
|
|
|
|
|
Handle ArbitrateHighestPriorityThread(u32 arbiter, u32 address) {
|
|
|
|
|
Handle highest_priority_thread = 0;
|
|
|
|
|
s32 priority = THREADPRIO_LOWEST;
|
|
|
|
|
|
|
|
|
|
// Iterate through threads, find highest priority thread that is waiting to be arbitrated...
|
|
|
|
|
for (const auto& handle : g_thread_queue) {
|
|
|
|
|
|
|
|
|
|
// TODO(bunnei): Verify arbiter address...
|
|
|
|
|
if (!VerifyWait(handle, WAITTYPE_ARB, arbiter))
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
Thread* thread = g_object_pool.GetFast<Thread>(handle);
|
|
|
|
|
if(thread->current_priority <= priority) {
|
|
|
|
|
highest_priority_thread = handle;
|
|
|
|
|
priority = thread->current_priority;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// If a thread was arbitrated, resume it
|
|
|
|
|
if (0 != highest_priority_thread)
|
|
|
|
|
ResumeThreadFromWait(highest_priority_thread);
|
|
|
|
|
|
|
|
|
|
return highest_priority_thread;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Arbitrate all threads currently waiting
|
|
|
|
|
void ArbitrateAllThreads(u32 arbiter, u32 address) {
|
|
|
|
|
|
|
|
|
|
// Iterate through threads, find highest priority thread that is waiting to be arbitrated...
|
|
|
|
|
for (const auto& handle : g_thread_queue) {
|
|
|
|
|
|
|
|
|
|
// TODO(bunnei): Verify arbiter address...
|
|
|
|
|
if (VerifyWait(handle, WAITTYPE_ARB, arbiter))
|
|
|
|
|
ResumeThreadFromWait(handle);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Calls a thread by marking it as "ready" (note: will not actually execute until current thread yields)
|
|
|
|
|
void CallThread(Thread* t) {
|
|
|
|
|
// Stop waiting
|
|
|
|
|