blob: e753c2cf6a3706b0e5b01a521f9c2078243e1c2f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#include "arch/kernel/cpu/tlb.hpp"
#include "arch/kernel/cpu/control_register.hpp"
namespace teachos::arch::memory::cpu
{
auto tlb_flush(paging::virtual_address address) -> void
{
asm volatile("invlpg (%[input])" : /* no output from call */ : [input] "r"(address) : "memory");
}
auto tlb_flush_all() -> void
{
write_control_register(cpu::control_register::CR3, read_control_register(cpu::control_register::CR3));
}
} // namespace teachos::arch::memory::cpu
|