aboutsummaryrefslogtreecommitdiff
path: root/arch/x86_64/src/memory/cpu/tlb.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86_64/src/memory/cpu/tlb.cpp')
-rw-r--r--arch/x86_64/src/memory/cpu/tlb.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/arch/x86_64/src/memory/cpu/tlb.cpp b/arch/x86_64/src/memory/cpu/tlb.cpp
index 1663e80..591d9fc 100644
--- a/arch/x86_64/src/memory/cpu/tlb.cpp
+++ b/arch/x86_64/src/memory/cpu/tlb.cpp
@@ -1,6 +1,6 @@
#include "arch/memory/cpu/tlb.hpp"
-#include "arch/memory/cpu/cr3.hpp"
+#include "arch/memory/cpu/control_register.hpp"
namespace teachos::arch::memory::cpu
{
@@ -9,5 +9,8 @@ namespace teachos::arch::memory::cpu
asm volatile("invlpg (%[input])" : /* no output from call */ : [input] "r"(address) : "memory");
}
- auto tlb_flush_all() -> void { write_cr3_register(read_cr3_register()); }
+ auto tlb_flush_all() -> void
+ {
+ write_control_register(cpu::control_register::CR3, read_control_register(cpu::control_register::CR3));
+ }
} // namespace teachos::arch::memory::cpu