Kernel: Scheduler::unblock_thread() wakes sleeping threads
This commit is contained in:
parent
976ae64f88
commit
534969df32
|
@ -23,6 +23,7 @@ namespace Kernel
|
||||||
|
|
||||||
void block_current_thread(Semaphore*);
|
void block_current_thread(Semaphore*);
|
||||||
void unblock_threads(Semaphore*);
|
void unblock_threads(Semaphore*);
|
||||||
|
// Makes sleeping or blocked thread with tid active.
|
||||||
void unblock_thread(pid_t tid);
|
void unblock_thread(pid_t tid);
|
||||||
|
|
||||||
Thread& current_thread();
|
Thread& current_thread();
|
||||||
|
|
|
@ -351,8 +351,23 @@ namespace Kernel
|
||||||
{
|
{
|
||||||
if (it->thread->tid() == tid)
|
if (it->thread->tid() == tid)
|
||||||
{
|
{
|
||||||
auto thread = it->thread;
|
Thread* thread = it->thread;
|
||||||
it = m_blocking_threads.remove(it);
|
m_blocking_threads.remove(it);
|
||||||
|
|
||||||
|
// This should work as we released enough memory from active thread
|
||||||
|
static_assert(sizeof(ActiveThread) == sizeof(BlockingThread));
|
||||||
|
MUST(m_active_threads.emplace_back(thread));
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (auto it = m_sleeping_threads.begin(); it != m_sleeping_threads.end(); it++)
|
||||||
|
{
|
||||||
|
if (it->thread->tid() == tid)
|
||||||
|
{
|
||||||
|
Thread* thread = it->thread;
|
||||||
|
m_sleeping_threads.remove(it);
|
||||||
|
|
||||||
// This should work as we released enough memory from active thread
|
// This should work as we released enough memory from active thread
|
||||||
static_assert(sizeof(ActiveThread) == sizeof(BlockingThread));
|
static_assert(sizeof(ActiveThread) == sizeof(BlockingThread));
|
||||||
|
|
Loading…
Reference in New Issue