mirror of
https://github.com/wiiu-env/wut.git
synced 2025-01-23 19:51:12 +01:00
193 lines
4.1 KiB
C
193 lines
4.1 KiB
C
#pragma once
|
|
#include <wut.h>
|
|
|
|
/**
|
|
* \defgroup coreinit_memorymap Memory Map
|
|
* \ingroup coreinit
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
typedef enum OSMemoryMapMode
|
|
{
|
|
OS_MAP_MEMORY_INVALID = 0,
|
|
OS_MAP_MEMORY_READ_ONLY = 1,
|
|
OS_MAP_MEMORY_READ_WRITE = 2,
|
|
OS_MAP_MEMORY_FREE = 3,
|
|
OS_MAP_MEMORY_ALLOCATED = 4,
|
|
} OSMemoryMapMode;
|
|
|
|
#define OS_PAGE_SIZE (128 * 1024)
|
|
|
|
uint32_t
|
|
OSEffectiveToPhysical(uint32_t virtualAddress);
|
|
|
|
BOOL
|
|
OSIsAddressValid(uint32_t virtualAddress);
|
|
|
|
BOOL
|
|
__OSValidateAddressSpaceRange(int /* unused */,
|
|
uint32_t virtualAddress,
|
|
uint32_t size);
|
|
|
|
/**
|
|
* Allocates virtual address range for later mapping.
|
|
*
|
|
* \param virtualAddress
|
|
* Requested start address for the range. If there is no preference, NULL can be
|
|
* used.
|
|
*
|
|
* \param size
|
|
* Size of address range to allocate.
|
|
*
|
|
* \param align
|
|
* Alignment of address range to allocate.
|
|
*
|
|
* \return
|
|
* The starting address of the newly allocated range, or NULL on failure.
|
|
*
|
|
* \sa
|
|
* - OSFreeVirtAddr()
|
|
* - OSMapMemory()
|
|
*/
|
|
uint32_t
|
|
OSAllocVirtAddr(uint32_t virtualAddress,
|
|
uint32_t size,
|
|
uint32_t align);
|
|
|
|
/**
|
|
* Frees a previously allocated virtual address range back to the system.
|
|
*
|
|
* \param virtualAddress
|
|
* The start of the virtual address range to free.
|
|
*
|
|
* \param size
|
|
* The size of the virtual address range to free.
|
|
*
|
|
* \return
|
|
* \c true on success.
|
|
*/
|
|
BOOL
|
|
OSFreeVirtAddr(uint32_t virtualAddress,
|
|
uint32_t size);
|
|
|
|
/**
|
|
* Determines the status of the given virtual memory address - mapped read-write
|
|
* or read-only, free, allocated or invalid.
|
|
*
|
|
* \param virtualAddress
|
|
* The virtual address to query.
|
|
*
|
|
* \return
|
|
* The status of the memory address - see #OSMemoryMapMode.
|
|
*/
|
|
OSMemoryMapMode
|
|
OSQueryVirtAddr(uint32_t virtualAddress);
|
|
|
|
/**
|
|
* Maps a physical address to a virtual address, with a given size and set of
|
|
* permissions.
|
|
*
|
|
* \param virtualAddress
|
|
* The target virtual address for the mapping.
|
|
*
|
|
* \param physicalAddress
|
|
* Physical address of the memory to back the mapping.
|
|
*
|
|
* \param size
|
|
* Size, in bytes, of the desired mapping. Likely has an alignment requirement.
|
|
*
|
|
* \param mode
|
|
* Permissions to map the memory with - see #OSMemoryMapMode.
|
|
*
|
|
* \return
|
|
* \c true on success.
|
|
*
|
|
* \sa
|
|
* - OSAllocVirtAddr()
|
|
* - OSUnmapMemory()
|
|
*/
|
|
BOOL
|
|
OSMapMemory(uint32_t virtualAddress,
|
|
uint32_t physicalAddress,
|
|
uint32_t size,
|
|
OSMemoryMapMode mode);
|
|
|
|
/**
|
|
* Unmaps previously mapped memory.
|
|
*
|
|
* \param virtualAddress
|
|
* Starting address of the area to unmap.
|
|
*
|
|
* \param size
|
|
* Size of the memory area to unmap.
|
|
*
|
|
* \return
|
|
* \c true on success.
|
|
*/
|
|
BOOL
|
|
OSUnmapMemory(uint32_t virtualAddress,
|
|
uint32_t size);
|
|
|
|
/**
|
|
* Gets the range of virtual addresses available for mapping.
|
|
*
|
|
* \param outVirtualAddress
|
|
* Pointer to write the starting address of the memory area to.
|
|
*
|
|
* \param outSize
|
|
* Pointer to write the size of the memory area to.
|
|
*
|
|
* \sa
|
|
* - OSMapMemory()
|
|
*/
|
|
void
|
|
OSGetMapVirtAddrRange(uint32_t *outVirtualAddress,
|
|
uint32_t *outSize);
|
|
|
|
/**
|
|
* Gets the range of available physical memory (not reserved for app code or
|
|
* data).
|
|
*
|
|
* \param outPhysicalAddress
|
|
* Pointer to write the starting physical address of the memory area to.
|
|
*
|
|
* \param outSize
|
|
* Pointer to write the size of the memory area to.
|
|
*
|
|
* \if false
|
|
* Is memory returned by this function actually safe to map and use? couldn't
|
|
* get a straight answer from decaf-emu's kernel_memory.cpp...
|
|
* \endif
|
|
*/
|
|
void
|
|
OSGetAvailPhysAddrRange(uint32_t *outPhysicalAddress,
|
|
uint32_t *outSize);
|
|
|
|
/**
|
|
* Gets the range of physical memory used for the application's data.
|
|
*
|
|
* \param outPhysicalAddress
|
|
* Pointer to write the starting physical address of the memory area to.
|
|
*
|
|
* \param outSize
|
|
* Pointer to write the size of the memory area to.
|
|
*
|
|
* \if false
|
|
* does this include the main heap?
|
|
* \endif
|
|
*/
|
|
void
|
|
OSGetDataPhysAddrRange(uint32_t *outPhysicalAddress,
|
|
uint32_t *outSize);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
/** @} */
|