diff --git a/kernel/arch/x86_64/IDT.cpp b/kernel/arch/x86_64/IDT.cpp index dce1d4e341..239d800704 100644 --- a/kernel/arch/x86_64/IDT.cpp +++ b/kernel/arch/x86_64/IDT.cpp @@ -310,10 +310,12 @@ done: else { InterruptController::get().eoi(irq); - if (s_interruptables[irq]) - s_interruptables[irq]->handle_irq(); + if (irq == IRQ_IPI) + Scheduler::get().reschedule(); + else if (auto* handler = s_interruptables[irq]) + handler->handle_irq(); else - dprintln("no handler for irq 0x{2H}\n", irq); + dprintln("no handler for irq 0x{2H}", irq); } Scheduler::get().reschedule_if_idling(); diff --git a/kernel/kernel/Scheduler.cpp b/kernel/kernel/Scheduler.cpp index c68428bb6a..73f9d86f59 100644 --- a/kernel/kernel/Scheduler.cpp +++ b/kernel/kernel/Scheduler.cpp @@ -67,6 +67,10 @@ namespace Kernel void Scheduler::timer_reschedule() { + // Broadcast IPI to all other processors for them + // to perform reschedule + InterruptController::get().broadcast_ipi(); + auto state = m_lock.lock(); m_blocking_threads.remove_with_wake_time(m_active_threads, SystemTimer::get().ms_since_boot()); if (save_current_thread())