Update frameheap to have correct structure.

This commit is contained in:
James Benton 2016-07-17 22:31:12 +01:00
parent 8e9425f7d4
commit 29b6d586e6
3 changed files with 132 additions and 2 deletions

View File

@ -1,5 +1,6 @@
#pragma once #pragma once
#include <wut.h> #include <wut.h>
#include "memheap.h"
/** /**
* \defgroup coreinit_frameheap Frame Heap * \defgroup coreinit_frameheap Frame Heap
@ -18,16 +19,38 @@ typedef enum MEMFrameHeapFreeMode
} MEMFrameHeapFreeMode; } MEMFrameHeapFreeMode;
typedef struct MEMFrameHeap MEMFrameHeap; typedef struct MEMFrameHeap MEMFrameHeap;
typedef struct MEMFrameHeapState MEMFrameHeapState;
struct MEMFrameHeapState
{
uint32_t tag;
void *head;
void *tail;
MEMFrameHeapState *previous;
};
CHECK_OFFSET(MEMFrameHeapState, 0x00, tag);
CHECK_OFFSET(MEMFrameHeapState, 0x04, head);
CHECK_OFFSET(MEMFrameHeapState, 0x08, tail);
CHECK_OFFSET(MEMFrameHeapState, 0x0C, previous);
CHECK_SIZE(MEMFrameHeapState, 0x10);
struct MEMFrameHeap struct MEMFrameHeap
{ {
MEMHeapHeader header;
void *head;
void *tail;
MEMFrameHeapState *previousState;
}; };
UNKNOWN_SIZE(MEMFrameHeap); CHECK_OFFSET(MEMFrameHeap, 0x00, header);
CHECK_OFFSET(MEMFrameHeap, 0x40, head);
CHECK_OFFSET(MEMFrameHeap, 0x44, tail);
CHECK_OFFSET(MEMFrameHeap, 0x48, previousState);
CHECK_SIZE(MEMFrameHeap, 0x4C);
MEMFrameHeap * MEMFrameHeap *
MEMCreateFrmHeapEx(MEMFrameHeap *heap, MEMCreateFrmHeapEx(MEMFrameHeap *heap,
uint32_t size, uint32_t size,
uint16_t flags); uint32_t flags);
void * void *
MEMDestroyFrmHeap(MEMFrameHeap *heap); MEMDestroyFrmHeap(MEMFrameHeap *heap);

101
include/coreinit/memheap.h Normal file
View File

@ -0,0 +1,101 @@
#pragma once
#include <wut.h>
#include "spinlock.h"
#include "memlist.h"
/**
* \defgroup coreinit_memheap Common Memory Heap
* \ingroup coreinit
*
* Common memory heap fucntions.
* @{
*/
#ifdef __cplusplus
extern "C" {
#endif
typedef struct MEMHeapHeader MEMHeapHeader;
typedef enum MEMHeapFillType
{
MEM_HEAP_FILL_TYPE_UNUSED = 0,
MEM_HEAP_FILL_TYPE_ALLOCATED = 1,
MEM_HEAP_FILL_TYPE_FREED = 2,
} MEMHeapFillType;
#define MEM_BLOCK_HEAP_TAG 0x424C4B48u
#define MEM_EXPANDED_HEAP_TAG 0x45585048u
#define MEM_FRAME_HEAP_TAG 0x46524D48u
#define MEM_UNIT_HEAP_TAG 0x554E5448u
#define MEM_USER_HEAP_TAG 0x55535248u
#define MEM_HEAP_FLAG_ZERO_ALLOCATED (1 << 0)
#define MEM_HEAP_FLAG_DEBUG_MODE (1 << 1)
#define MEM_HEAP_FLAG_USE_LOCK (1 << 2)
struct MEMHeapHeader
{
//! Tag indicating which type of heap this is
uint32_t tag;
//! Link for list this heap is in
MEMMemoryLink link;
//! List of all child heaps in this heap
MEMMemoryList list;
//! Pointer to start of allocatable memory
void *dataStart;
//! Pointer to end of allocatable memory
void *dataEnd;
//! Lock used when MEM_HEAP_FLAG_USE_LOCK is set.
OSSpinLock lock;
//! Flags set during heap creation.
uint32_t flags;
UNKNOWN(0x0C);
};
CHECK_OFFSET(MEMHeapHeader, 0x00, tag);
CHECK_OFFSET(MEMHeapHeader, 0x04, link);
CHECK_OFFSET(MEMHeapHeader, 0x0C, list);
CHECK_OFFSET(MEMHeapHeader, 0x18, dataStart);
CHECK_OFFSET(MEMHeapHeader, 0x1C, dataEnd);
CHECK_OFFSET(MEMHeapHeader, 0x20, lock);
CHECK_OFFSET(MEMHeapHeader, 0x30, flags);
CHECK_SIZE(MEMHeapHeader, 0x40);
/**
* Print details about heap to COSWarn
*/
void
MEMDumpHeap(MEMHeapHeader *heap);
/**
* Find heap which contains a memory block.
*/
MEMHeapHeader *
MEMFindContainHeap(void *block);
/**
* Get the data fill value used when MEM_HEAP_FLAG_DEBUG_MODE is set.
*/
uint32_t
MEMGetFillValForHeap(MEMHeapFillType type);
/**
* Set the data fill value used when MEM_HEAP_FLAG_DEBUG_MODE is set.
*/
void
MEMSetFillValForHeap(MEMHeapFillType type,
uint32_t value);
#ifdef __cplusplus
}
#endif
/** @} */

View File

@ -163,6 +163,12 @@ EXPORT(MEMAdjustFrmHeap);
EXPORT(MEMResizeForMBlockFrmHeap); EXPORT(MEMResizeForMBlockFrmHeap);
EXPORT(MEMGetAllocatableSizeForFrmHeapEx); EXPORT(MEMGetAllocatableSizeForFrmHeapEx);
// coreinit/memheap.h
EXPORT(MEMDumpHeap);
EXPORT(MEMFindContainHeap);
EXPORT(MEMGetFillValForHeap);
EXPORT(MEMSetFillValForHeap);
// coreinit/memlist.h // coreinit/memlist.h
EXPORT(MEMInitList); EXPORT(MEMInitList);
EXPORT(MEMAppendListObject); EXPORT(MEMAppendListObject);