summaryrefslogtreecommitdiffhomepage
path: root/Kernel/Sources/Pmm.cxx
diff options
context:
space:
mode:
authorAmlal El Mahrouss <amlal@el-mahrouss-logic.com>2024-05-21 09:10:57 +0200
committerAmlal El Mahrouss <amlal@el-mahrouss-logic.com>2024-05-21 09:10:57 +0200
commit0c211cca4d7a4d836f4cb685345e44f3f2814fd1 (patch)
treef08901e67cdabe025d8ad40c18c62b27b32c5517 /Kernel/Sources/Pmm.cxx
parentf022a2afeb7af04ce3ef256ef617d19f07d84d9a (diff)
MHR-23: New CoreSystem calls and refactors.
Signed-off-by: Amlal El Mahrouss <amlal@el-mahrouss-logic.com>
Diffstat (limited to 'Kernel/Sources/Pmm.cxx')
-rw-r--r--Kernel/Sources/Pmm.cxx88
1 files changed, 88 insertions, 0 deletions
diff --git a/Kernel/Sources/Pmm.cxx b/Kernel/Sources/Pmm.cxx
new file mode 100644
index 00000000..0641f457
--- /dev/null
+++ b/Kernel/Sources/Pmm.cxx
@@ -0,0 +1,88 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+#include <KernelKit/DebugOutput.hpp>
+#include <NewKit/Pmm.hpp>
+
+namespace NewOS
+{
+ /// @brief Pmm constructor.
+ Pmm::Pmm()
+ : fPageManager()
+ {
+ kcout << "[PMM] Allocate PageMemoryManager";
+ }
+
+ Pmm::~Pmm() = default;
+
+ /* If this returns Null pointer, enter emergency mode */
+ /// @param user is this a user page?
+ /// @param readWrite is it r/w?
+ Ref<PTEWrapper> Pmm::RequestPage(Boolean user, Boolean readWrite)
+ {
+ PTEWrapper pt = fPageManager.Leak().Request(user, readWrite, false, kPTESize);
+
+ if (pt.fPresent)
+ {
+ kcout << "[PMM]: Allocation was successful.\r";
+ return Ref<PTEWrapper>(pt);
+ }
+
+ kcout << "[PMM]: Allocation failed.\r";
+
+ return {};
+ }
+
+ Boolean Pmm::FreePage(Ref<PTEWrapper> PageRef)
+ {
+ if (!PageRef)
+ return false;
+
+ PageRef.Leak().fPresent = false;
+
+ return true;
+ }
+
+ Boolean Pmm::TogglePresent(Ref<PTEWrapper> PageRef, Boolean Enable)
+ {
+ if (!PageRef)
+ return false;
+
+ PageRef.Leak().fPresent = Enable;
+
+ return true;
+ }
+
+ Boolean Pmm::ToggleUser(Ref<PTEWrapper> PageRef, Boolean Enable)
+ {
+ if (!PageRef)
+ return false;
+
+ PageRef.Leak().fRw = Enable;
+
+ return true;
+ }
+
+ Boolean Pmm::ToggleRw(Ref<PTEWrapper> PageRef, Boolean Enable)
+ {
+ if (!PageRef)
+ return false;
+
+ PageRef.Leak().fRw = Enable;
+
+ return true;
+ }
+
+ Boolean Pmm::ToggleShare(Ref<PTEWrapper> PageRef, Boolean Enable)
+ {
+ if (!PageRef)
+ return false;
+
+ PageRef.Leak().fShareable = Enable;
+
+ return true;
+ }
+} // namespace NewOS