|
XenevaOS
|
#include <Mm/pmmngr.h>#include <Hal/AA64/aa64lowlevel.h>#include <Mm/vmmngr.h>#include <Drivers/uart.h>#include <efi.h>
Classes | |
| struct | _lb_mem_rgn_ |
Macros | |
| #define | PAGE_SHIFT 12 |
Typedefs | |
| typedef struct _lb_mem_rgn_ | LBMemoryRegion |
Functions | |
| void | AuPmmngrInitBitmap (size_t BSize, void *Buffer) |
| AuPmmngrInitBitmap – Initialize the Ram bitmap with all zeros. | |
| bool | AuPmmngrBitmapCheck (uint64_t index) |
| bool | AuPmmngrBitmapSet (uint64_t index, bool value) |
| void | AuPmmngrLockPage (uint64_t Address) |
| AuPmmngrLockPage – Lock a given page. | |
| void | AuPmmngrLockPages (void *Address, size_t Size) |
| AuPmmngrLockPage – locks a set of pages. | |
| void | AuPmmngrUnreservePage (void *Address) |
| AuPmmngrUnreservePage – Marks a page as free. | |
| void | AuPmmngrInitialize (KERNEL_BOOT_INFO *info) |
| AuPmmngrInitialise – initialise the physical memory manager. | |
| bool | AuPmmngrAllocCheck (uint64_t address) |
| void * | AuPmmngrAlloc () |
| AuPmmngrAlloc – Allocate a single physical page frame and return it to the caller. | |
| void * | AuPmmngrAllocBlocks (int num) |
| AuPmmngrAllocBlocks – Allocate multiple physical page frames and return the first page pointer to the caller. | |
| void | AuPmmngrFree (void *Address) |
| AuPmmngrFree – Free a physical page frame. | |
| void | AuPmmngrFreeBlocks (void *Addr, int Count) |
| AuPmmngrFreeBlocks – Free multiple page frames. | |
| uint64_t | P2V (uint64_t addr) |
| P2V – Physical to Virtual conversion. | |
| uint64_t | V2P (uint64_t vaddr) |
| V2P – Virtual to Physical conversion. | |
| void | AuPmmngrMoveHigher () |
| AuPmmngrMoveHigher – moves the kernel to higher half of memory. | |
| uint64_t | AuPmmngrGetFreeMem () |
| AuPmmngrGetFreeMem – returns the total free amount of RAM. | |
| uint64_t | AuPmmngrGetTotalMem () |
| AuPmmngrGetTotalMem – returns the total amount of RAM. | |
BSD 2-Clause License
Copyright (c) 2022-2025, Manas Kamal Choudhury All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
| #define PAGE_SHIFT 12 |
| typedef struct _lb_mem_rgn_ LBMemoryRegion |
| void * AuPmmngrAlloc | ( | ) |
AuPmmngrAlloc – Allocate a single physical page frame and return it to the caller.
| void * AuPmmngrAllocBlocks | ( | int | num | ) |
AuPmmngrAllocBlocks – Allocate multiple physical page frames and return the first page pointer to the caller.
| size | – Number of blocks to allocate |
| void AuPmmngrFree | ( | void * | Address | ) |
AuPmmngrFree – Free a physical page frame.
| Address | – Pointer to physical page |
| void AuPmmngrFreeBlocks | ( | void * | Addr, |
| int | Count | ||
| ) |
AuPmmngrFreeBlocks – Free multiple page frames.
| Addr | – Address of the first page frame |
| Count | – Number of blocks to be freed |
| uint64_t AuPmmngrGetFreeMem | ( | ) |
AuPmmngrGetFreeMem – returns the total free amount of RAM.
| uint64_t AuPmmngrGetTotalMem | ( | ) |
AuPmmngrGetTotalMem – returns the total amount of RAM.
| void AuPmmngrInitBitmap | ( | size_t | BSize, |
| void * | Buffer | ||
| ) |
AuPmmngrInitBitmap – Initialize the Ram bitmap with all zeros.
| BitmapSize | – total bitmap size |
| Buffer | – Pointer to bitmap buffer |
| void AuPmmngrInitialize | ( | KERNEL_BOOT_INFO * | info | ) |
AuPmmngrInitialise – initialise the physical memory manager.
| info | – Pointer to kernel boot info structure |
| void AuPmmngrLockPage | ( | uint64_t | Address | ) |
AuPmmngrLockPage – Lock a given page.
| Address | – Pointer to page |
| void AuPmmngrLockPages | ( | void * | Address, |
| size_t | Size | ||
| ) |
AuPmmngrLockPage – locks a set of pages.
| Address | – Starting address of the first page |
| Size | – Size of the set |
| void AuPmmngrMoveHigher | ( | ) |
AuPmmngrMoveHigher – moves the kernel to higher half of memory.
| void AuPmmngrUnreservePage | ( | void * | Address | ) |
AuPmmngrUnreservePage – Marks a page as free.
| Address | – Pointer to the page |
P2V – Physical to Virtual conversion.
| addr | – Address to convert |
V2P – Virtual to Physical conversion.
| vaddr | – Address to convert |
| uint64_t _BitmapSize |
| uint64_t _FreeMemory |
| bool _HigherHalf |
| uint64_t _RamBitmapIndex |
| uint64_t _ReservedMemory |
| uint64_t _TotalRam |
| uint64_t _UsedMemory |
| uint8_t* BitmapBuffer |
| bool debugon |
| uint64_t UsablePhysicalMemory |