Files
exectos/xtoskrnl/includes/mm/i686/pagemap.hh
Aiken Harris ffa480d69a
Some checks failed
Builds / ExectOS (amd64, debug) (push) Failing after 26s
Builds / ExectOS (amd64, release) (push) Failing after 24s
Builds / ExectOS (i686, debug) (push) Failing after 27s
Builds / ExectOS (i686, release) (push) Failing after 25s
Implement unified PTE accessors and management helpers
2025-10-30 20:14:02 +01:00

103 lines
4.3 KiB
C++

/**
* PROJECT: ExectOS
* COPYRIGHT: See COPYING.md in the top level directory
* FILE: xtoskrnl/includes/mm/pagemap.hh
* DESCRIPTION: Low-level support for page map manipulation
* DEVELOPERS: Aiken Harris <harraiken91@gmail.com>
*/
#ifndef __XTOSKRNL_MM_PAGEMAP_HH
#define __XTOSKRNL_MM_PAGEMAP_HH
#include <xtos.hh>
/* Memory Manager */
namespace MM
{
typedef class PageMap
{
protected:
MMPAGEMAP_INFO PageMapInfo;
public:
VIRTUAL XTAPI PMMPTE AdvancePte(PMMPTE Pte,
ULONG Count) = 0;
XTAPI VOID ClearPte(PHARDWARE_PTE PtePointer);
XTAPI ULONG GetEmptyPteList(VOID);
VIRTUAL XTAPI ULONG_PTR GetNextEntry(PMMPTE Pte) = 0;
VIRTUAL XTAPI PMMPTE GetNextPte(PMMPTE Pte) = 0;
VIRTUAL XTAPI BOOLEAN GetOneEntry(PMMPTE Pte) = 0;
XTAPI PMMPDE GetPdeAddress(PVOID Address);
XTAPI ULONG GetPdeIndex(PVOID Address);
XTAPI PVOID GetPdeVirtualAddress(PMMPDE PdePointer);
XTAPI PMMPPE GetPpeAddress(PVOID Address);
XTAPI ULONG GetPpeIndex(PVOID Address);
XTAPI PVOID GetPpeVirtualAddress(PMMPPE PpePointer);
XTAPI PMMPTE GetPteAddress(PVOID Address);
XTAPI ULONG GetPteIndex(PVOID Address);
VIRTUAL XTAPI ULONG GetPteSize(VOID) = 0;
XTAPI PVOID GetPteVirtualAddress(PMMPTE PtePointer);
VIRTUAL XTAPI VOID InitializePageMapInfo(VOID) = 0;
VIRTUAL XTAPI BOOLEAN PteValid(PHARDWARE_PTE PtePointer) = 0;
VIRTUAL XTAPI VOID SetNextEntry(PMMPTE Pte,
ULONG_PTR Value) = 0;
VIRTUAL XTAPI VOID SetOneEntry(PMMPTE Pte,
BOOLEAN Value) = 0;
VIRTUAL XTAPI VOID SetPte(PHARDWARE_PTE PtePointer,
PFN_NUMBER PageFrameNumber,
BOOLEAN Writable) = 0;
VIRTUAL XTAPI VOID SetPteCaching(PHARDWARE_PTE PtePointer,
BOOLEAN CacheDisable,
BOOLEAN WriteThrough) = 0;
} PAGEMAP, *PPAGEMAP;
class PageMapBasic final : public PageMap
{
public:
XTAPI PMMPTE AdvancePte(PMMPTE Pte,
ULONG Count);
XTAPI ULONG_PTR GetNextEntry(PMMPTE Pte);
XTAPI PMMPTE GetNextPte(PMMPTE Pte);
XTAPI BOOLEAN GetOneEntry(PMMPTE Pte);
XTAPI ULONG GetPteSize(VOID);
XTAPI VOID InitializePageMapInfo(VOID);
XTAPI BOOLEAN PteValid(PHARDWARE_PTE PtePointer);
XTAPI VOID SetNextEntry(PMMPTE Pte,
ULONG_PTR Value);
XTAPI VOID SetOneEntry(PMMPTE Pte,
BOOLEAN Value);
XTAPI VOID SetPte(PHARDWARE_PTE PtePointer,
PFN_NUMBER PageFrameNumber,
BOOLEAN Writable);
XTAPI VOID SetPteCaching(PHARDWARE_PTE PtePointer,
BOOLEAN CacheDisable,
BOOLEAN WriteThrough);
};
class PageMapXpa final : public PageMap
{
public:
XTAPI PMMPTE AdvancePte(PMMPTE Pte,
ULONG Count);
XTAPI ULONG_PTR GetNextEntry(PMMPTE Pte);
XTAPI PMMPTE GetNextPte(PMMPTE Pte);
XTAPI BOOLEAN GetOneEntry(PMMPTE Pte);
XTAPI ULONG GetPteSize(VOID);
XTAPI VOID InitializePageMapInfo(VOID);
XTAPI BOOLEAN PteValid(PHARDWARE_PTE PtePointer);
XTAPI VOID SetNextEntry(PMMPTE Pte,
ULONG_PTR Value);
XTAPI VOID SetOneEntry(PMMPTE Pte,
BOOLEAN Value);
XTAPI VOID SetPte(PHARDWARE_PTE PtePointer,
PFN_NUMBER PageFrameNumber,
BOOLEAN Writable);
XTAPI VOID SetPteCaching(PHARDWARE_PTE PtePointer,
BOOLEAN CacheDisable,
BOOLEAN WriteThrough);
};
}
#endif /* __XTOSKRNL_MM_PAGEMAP_HH */