mirror of
https://github.com/wiiu-env/wut.git
synced 2025-01-10 03:29:24 +01:00
139 lines
2.6 KiB
C
139 lines
2.6 KiB
C
#pragma once
|
|
#include <wut.h>
|
|
|
|
/**
|
|
* \defgroup coreinit_memory Memory
|
|
* \ingroup coreinit
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
typedef enum OSMemoryType
|
|
{
|
|
OS_MEM1 = 1,
|
|
OS_MEM2 = 2,
|
|
} OSMemoryType;
|
|
|
|
/**
|
|
* Moves chunks of memory around, similarly to memmove. Overlapping source and
|
|
* destination regions are supported.
|
|
*
|
|
* \param dst
|
|
* The destination address for the move.
|
|
*
|
|
* \param src
|
|
* The source address for the move.
|
|
*
|
|
* \param size
|
|
* The size of the data to be moved, in bytes.
|
|
*
|
|
* \param flush
|
|
* Whether to flush the data caches for the source and destination.
|
|
*
|
|
* \return
|
|
* dst is returned.
|
|
*
|
|
* \note
|
|
* This function makes use of the cache to speed up the copy, so a flush is
|
|
* recommended.
|
|
*/
|
|
void *
|
|
OSBlockMove(void *dst,
|
|
const void *src,
|
|
uint32_t size,
|
|
BOOL flush);
|
|
|
|
/**
|
|
* Fills a chunk of memory with the given value, like memset.
|
|
*
|
|
* \param dst
|
|
* Pointer to the memory to fill.
|
|
*
|
|
* \param val
|
|
* Byte value to be set.
|
|
*
|
|
* \param size
|
|
* Number of bytes to be set to val.
|
|
*
|
|
* \return
|
|
* dst is returned.
|
|
*/
|
|
void *
|
|
OSBlockSet(void *dst,
|
|
uint8_t val,
|
|
uint32_t size);
|
|
|
|
void *
|
|
OSAllocFromSystem(uint32_t size,
|
|
int align);
|
|
|
|
void
|
|
OSFreeToSystem(void *ptr);
|
|
|
|
/**
|
|
* Gets the location and size of the foreground bucket memory area.
|
|
*
|
|
* \note
|
|
* This function may not account for the system reserved portion of the
|
|
* foreground bucket. Consider using OSGetForegroundBucketFreeArea() instead.
|
|
*
|
|
* \param outAddr
|
|
* Pointer to write the foreground bucket's address to.
|
|
*
|
|
* \param outSize
|
|
* Pointer to write the foreground bucket's size to.
|
|
*
|
|
* \return
|
|
* \c true on success.
|
|
*/
|
|
BOOL
|
|
OSGetForegroundBucket(uint32_t *outAddr,
|
|
uint32_t *outSize);
|
|
|
|
/**
|
|
* Gets the location and size of the application-usable portion of the
|
|
* foreground bucket area.
|
|
*
|
|
* \param outAddr
|
|
* Pointer to write the bucket area's address to.
|
|
*
|
|
* \param outSize
|
|
* Pointer to write the bucket area's size to.
|
|
*
|
|
* \return
|
|
* \c true on success.
|
|
*/
|
|
BOOL
|
|
OSGetForegroundBucketFreeArea(uint32_t *outAddr,
|
|
uint32_t *outSize);
|
|
|
|
/**
|
|
* Gets the location and size of available memory areas.
|
|
*
|
|
* \param type
|
|
* Type of memory to get information about. See #OSMemoryType.
|
|
*
|
|
* \param outAddr
|
|
* Pointer to write the area's address to.
|
|
*
|
|
* \param outSize
|
|
* Pointer to write the area's size to.
|
|
*
|
|
* \return
|
|
* 0 on success, -1 otherwise.
|
|
*/
|
|
int
|
|
OSGetMemBound(OSMemoryType type,
|
|
uint32_t *outAddr,
|
|
uint32_t *outSize);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
/** @} */
|