//----------------------------------------------------------------------------// // OS on Kaleid // // // // Desc: Mapping and checking memory related functions // // // // // // Copyright © 2018-2020 The OS/K Team // // // // This file is part of OS/K. // // // // OS/K is free software: you can redistribute it and/or modify // // it under the terms of the GNU General Public License as published by // // the Free Software Foundation, either version 3 of the License, or // // any later version. // // // // OS/K is distributed in the hope that it will be useful, // // but WITHOUT ANY WARRANTY//without even the implied warranty of // // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // // GNU General Public License for more details. // // // // You should have received a copy of the GNU General Public License // // along with OS/K. If not, see . // //----------------------------------------------------------------------------// #ifndef _KERNEL_H #include #endif #ifndef _MM_MAP_H #define _MM_MAP_H //----------------------------------------------------------------------------// #define MINIMUM_RAM_SIZE 16 // Mio, the minimum RAM size. #define AVAILABLE_ZONE 1 // Fully usable RAM zone #define RESERVED_ZONE 2 // Used by the firmware #define ACPI_ZONE 3 // Used by ACPI but can be freed #define NVS_ZONE 4 // Dunno #define BADRAM_ZONE 5 // Invalid zone because material problem... #define MAX_ENTRIES 2048 // Max number of memory map entries //----------------------------------------------------------------------------// // The entry structure of the map struct MapEntry_t { void *addr; size_t length; // in bytes uint type; // reserved or not } __attribute__((__packed__)); // the map structure struct MemoryMap_t { size_t length; size_t freeRamSize; size_t nonfreeRamSize; MapEntry_t entry[MAX_ENTRIES]; } __attribute__((__packed__)); //----------------------------------------------------------------------------// // // Initializes the memory map structure // void MmInitMemoryMap(void); // // Initializes the memory map structure // void MmPrintMemoryMap(void); // // Returns the size of the first available memory zone // from the start address pointer // size_t MmGetAvailZoneSize(void *start); // // Returns 1 if busy // bool MmIsBusyZone(void *start); // // Returns the first available memory zone from the start address pointer // void *MmGetFirstAvailZone(void *start); //----------------------------------------------------------------------------// #endif