/* * Copyright 2014, Henry Harrington, henry.harrington@gmail.com. * Copyright 2019-2022, Haiku, Inc. All rights reserved. * Distributed under the terms of the MIT License. */ #ifndef MMU_H #define MMU_H #ifndef _ASSEMBLER #include "efi_platform.h" #include #ifdef __cplusplus extern "C" { #endif static const uint32 kDefaultPageFlags = 0x3; // present, R/W static const uint64 kTableMappingFlags = 0x7; // present, R/W, user static const uint64 kLargePageMappingFlags = 0x183; // present, R/W, user, global, large static const uint64 kPageMappingFlags = 0x103; // present, R/W, user, global extern addr_t get_next_virtual_address(size_t size); extern addr_t get_current_virtual_address(); extern void mmu_init(); extern phys_addr_t mmu_allocate_page(); bool mmu_next_region(void** cookie, addr_t* vaddr, phys_addr_t* paddr, size_t* size); extern addr_t mmu_map_physical_memory(addr_t physicalAddress, size_t size, uint32 flags); extern status_t platform_kernel_address_to_bootloader_address(addr_t address, void **_result); extern status_t platform_bootloader_address_to_kernel_address(void *address, addr_t *_result); extern status_t platform_allocate_lomem(void **_address, size_t size); #ifdef __cplusplus } #endif /*! Convert a 32-bit address to a 64-bit address. */ inline addr_t fix_address(addr_t address) { addr_t result; if (platform_bootloader_address_to_kernel_address((void *)address, &result) != B_OK) { return address; } else return result; } template inline void fix_address(FixedWidthPointer& p) { if (p != NULL) p.SetTo(fix_address(p.Get())); } #endif // !_ASSEMBLER #endif /* MMU_H */