From 7db1a8253b2574c45b2d6f12743dea4a7a17c5f4 Mon Sep 17 00:00:00 2001 From: apio Date: Wed, 7 Dec 2022 12:26:09 +0100 Subject: [PATCH] CPU: Add an idle_loop method --- kernel/src/arch/CPU.h | 2 ++ kernel/src/arch/x86_64/CPU.cpp | 14 +++++++++++--- 2 files changed, 13 insertions(+), 3 deletions(-) diff --git a/kernel/src/arch/CPU.h b/kernel/src/arch/CPU.h index abf826e3..9d973a3d 100644 --- a/kernel/src/arch/CPU.h +++ b/kernel/src/arch/CPU.h @@ -13,6 +13,8 @@ namespace CPU [[noreturn]] void efficient_halt(); + void idle_loop(); + void switch_kernel_stack(u64 top); void enable_interrupts(); diff --git a/kernel/src/arch/x86_64/CPU.cpp b/kernel/src/arch/x86_64/CPU.cpp index e3ef18a2..8a9346fb 100644 --- a/kernel/src/arch/x86_64/CPU.cpp +++ b/kernel/src/arch/x86_64/CPU.cpp @@ -1,14 +1,14 @@ #include "arch/CPU.h" -#include "arch/x86_64/CPU.h" #include "Log.h" #include "arch/Timer.h" +#include "arch/x86_64/CPU.h" #include "arch/x86_64/IO.h" #include +#include +#include #include #include #include -#include -#include extern "C" void enable_sse(); extern "C" void enable_write_protect(); @@ -430,6 +430,14 @@ namespace CPU goto loop; // Safeguard: if we ever wake up, start our low-power rest again } + void idle_loop() + { + asm volatile("sti"); + loop: + asm volatile("hlt"); + goto loop; + } + void switch_kernel_stack(u64 top) { task_state_segment.rsp[0] = top;