Add a basic scheduler with threads #18
@ -88,22 +88,29 @@ namespace Scheduler
|
|||||||
Thread* old = g_current;
|
Thread* old = g_current;
|
||||||
if (old->is_idle())
|
if (old->is_idle())
|
||||||
{
|
{
|
||||||
auto maybe_first = g_threads.last();
|
auto maybe_last = g_threads.last();
|
||||||
if (maybe_first.has_error()) // No threads!!
|
if (maybe_last.has_error()) // No threads!!
|
||||||
return &g_idle;
|
return &g_idle;
|
||||||
g_current = old = maybe_first.value();
|
g_current = old = maybe_last.value();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool has_found_thread = false;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
auto maybe_next = g_threads.next(g_current);
|
auto maybe_next = g_threads.next(g_current);
|
||||||
if (maybe_next.has_error()) g_current = g_threads.first().value();
|
if (maybe_next.has_error()) g_current = g_threads.first().value();
|
||||||
else
|
else
|
||||||
g_current = maybe_next.value();
|
g_current = maybe_next.value();
|
||||||
|
|
||||||
if (true) // FIXME: Check if the current task is runnable.
|
if (g_current->state == ThreadState::Runnable)
|
||||||
|
{
|
||||||
|
has_found_thread = true;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
} while (g_current != old);
|
} while (g_current != old);
|
||||||
|
|
||||||
|
if (!has_found_thread) g_current = &g_idle;
|
||||||
|
|
||||||
return g_current;
|
return g_current;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user