aboutsummaryrefslogtreecommitdiff
path: root/arch/x86_64/include
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86_64/include')
-rw-r--r--arch/x86_64/include/arch/memory/paging/active_page_table.hpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/arch/x86_64/include/arch/memory/paging/active_page_table.hpp b/arch/x86_64/include/arch/memory/paging/active_page_table.hpp
index c7d835a..c5b972b 100644
--- a/arch/x86_64/include/arch/memory/paging/active_page_table.hpp
+++ b/arch/x86_64/include/arch/memory/paging/active_page_table.hpp
@@ -166,8 +166,11 @@ namespace teachos::arch::memory::paging
}
// TODO: Flushing only specifc page does not work and cause temporary_page.map_table_frame to return an invalid
// page table (Memory inside buffer shows nothing)
- cpu::tlb_flush(page.start_address());
- // cpu::tlb_flush_all();
+ // cpu::tlb_flush(page.start_address());
+ // This is the case, because we have unmapped the active page and it is completly invalid, if we only flush one
+ // page, the other pages which are huge still exist in the cache and can therefore still be accessed. But because
+ // they are huge pages the temporary page is not mapped correctly.
+ cpu::tlb_flush_all();
}
private: