2020-10-03 15:22:44 +00:00
|
|
|
#include "global.h"
|
2020-03-17 04:31:30 +00:00
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
#define LOG_SEVERITY_NOLOG 0
|
|
|
|
#define LOG_SEVERITY_ERROR 2
|
|
|
|
#define LOG_SEVERITY_VERBOSE 3
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
|
|
Arena sZeldaArena;
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
#if OOT_DEBUG
|
|
|
|
s32 gZeldaArenaLogSeverity = LOG_SEVERITY_ERROR;
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
void ZeldaArena_CheckPointer(void* ptr, u32 size, const char* name, const char* action) {
|
2021-02-14 00:49:40 +00:00
|
|
|
if (ptr == NULL) {
|
2020-03-22 21:19:43 +00:00
|
|
|
if (gZeldaArenaLogSeverity >= LOG_SEVERITY_ERROR) {
|
2020-04-16 21:36:12 +00:00
|
|
|
// "%s: %u bytes %s failed\n"
|
2024-01-12 15:38:13 +00:00
|
|
|
PRINTF("%s: %u バイトの%sに失敗しました\n", name, size, action);
|
2020-03-22 21:19:43 +00:00
|
|
|
__osDisplayArena(&sZeldaArena);
|
2020-03-17 04:31:30 +00:00
|
|
|
}
|
2020-03-22 21:19:43 +00:00
|
|
|
} else if (gZeldaArenaLogSeverity >= LOG_SEVERITY_VERBOSE) {
|
2020-04-16 21:36:12 +00:00
|
|
|
// "%s: %u bytes %s succeeded\n"
|
2024-01-12 15:38:13 +00:00
|
|
|
PRINTF("%s: %u バイトの%sに成功しました\n", name, size, action);
|
2020-03-17 04:31:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
#define ZELDA_ARENA_CHECK_POINTER(ptr, size, name, action) ZeldaArena_CheckPointer(ptr, size, name, action)
|
|
|
|
#else
|
|
|
|
#define ZELDA_ARENA_CHECK_POINTER(ptr, size, name, action) (void)0
|
|
|
|
#endif
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
void* ZeldaArena_Malloc(u32 size) {
|
2021-02-14 00:49:40 +00:00
|
|
|
void* ptr = __osMalloc(&sZeldaArena, size);
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
ZELDA_ARENA_CHECK_POINTER(ptr, size, "zelda_malloc", "確保"); // "Secure"
|
2020-03-17 04:31:30 +00:00
|
|
|
return ptr;
|
|
|
|
}
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
#if OOT_DEBUG
|
2020-03-22 21:19:43 +00:00
|
|
|
void* ZeldaArena_MallocDebug(u32 size, const char* file, s32 line) {
|
2021-02-14 00:49:40 +00:00
|
|
|
void* ptr = __osMallocDebug(&sZeldaArena, size, file, line);
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
ZELDA_ARENA_CHECK_POINTER(ptr, size, "zelda_malloc_DEBUG", "確保"); // "Secure"
|
2020-03-17 04:31:30 +00:00
|
|
|
return ptr;
|
|
|
|
}
|
2024-02-02 20:01:49 +00:00
|
|
|
#endif
|
2020-03-17 04:31:30 +00:00
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
void* ZeldaArena_MallocR(u32 size) {
|
2021-02-14 00:49:40 +00:00
|
|
|
void* ptr = __osMallocR(&sZeldaArena, size);
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
ZELDA_ARENA_CHECK_POINTER(ptr, size, "zelda_malloc_r", "確保"); // "Secure"
|
2020-03-17 04:31:30 +00:00
|
|
|
return ptr;
|
|
|
|
}
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
#if OOT_DEBUG
|
2020-03-22 21:19:43 +00:00
|
|
|
void* ZeldaArena_MallocRDebug(u32 size, const char* file, s32 line) {
|
2021-02-14 00:49:40 +00:00
|
|
|
void* ptr = __osMallocRDebug(&sZeldaArena, size, file, line);
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
ZELDA_ARENA_CHECK_POINTER(ptr, size, "zelda_malloc_r_DEBUG", "確保"); // "Secure"
|
2020-03-17 04:31:30 +00:00
|
|
|
return ptr;
|
|
|
|
}
|
2024-02-02 20:01:49 +00:00
|
|
|
#endif
|
2020-03-17 04:31:30 +00:00
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
void* ZeldaArena_Realloc(void* ptr, u32 newSize) {
|
2020-03-17 04:31:30 +00:00
|
|
|
ptr = __osRealloc(&sZeldaArena, ptr, newSize);
|
2024-02-02 20:01:49 +00:00
|
|
|
ZELDA_ARENA_CHECK_POINTER(ptr, newSize, "zelda_realloc", "再確保"); // "Re-securing"
|
2020-03-17 04:31:30 +00:00
|
|
|
return ptr;
|
|
|
|
}
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
#if OOT_DEBUG
|
2020-03-22 21:19:43 +00:00
|
|
|
void* ZeldaArena_ReallocDebug(void* ptr, u32 newSize, const char* file, s32 line) {
|
2020-03-17 04:31:30 +00:00
|
|
|
ptr = __osReallocDebug(&sZeldaArena, ptr, newSize, file, line);
|
2024-02-02 20:01:49 +00:00
|
|
|
ZELDA_ARENA_CHECK_POINTER(ptr, newSize, "zelda_realloc_DEBUG", "再確保"); // "Re-securing"
|
2020-03-17 04:31:30 +00:00
|
|
|
return ptr;
|
|
|
|
}
|
2024-02-02 20:01:49 +00:00
|
|
|
#endif
|
2020-03-17 04:31:30 +00:00
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
void ZeldaArena_Free(void* ptr) {
|
2020-03-17 04:31:30 +00:00
|
|
|
__osFree(&sZeldaArena, ptr);
|
|
|
|
}
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
#if OOT_DEBUG
|
2020-03-22 21:19:43 +00:00
|
|
|
void ZeldaArena_FreeDebug(void* ptr, const char* file, s32 line) {
|
2020-03-17 04:31:30 +00:00
|
|
|
__osFreeDebug(&sZeldaArena, ptr, file, line);
|
|
|
|
}
|
2024-02-02 20:01:49 +00:00
|
|
|
#endif
|
2020-03-17 04:31:30 +00:00
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
void* ZeldaArena_Calloc(u32 num, u32 size) {
|
2020-03-17 04:31:30 +00:00
|
|
|
void* ret;
|
2021-02-14 00:49:40 +00:00
|
|
|
u32 n = num * size;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
2020-03-17 04:31:30 +00:00
|
|
|
ret = __osMalloc(&sZeldaArena, n);
|
2021-02-14 00:49:40 +00:00
|
|
|
if (ret != NULL) {
|
2020-03-17 04:31:30 +00:00
|
|
|
bzero(ret, n);
|
2020-03-22 21:19:43 +00:00
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
ZELDA_ARENA_CHECK_POINTER(ret, n, "zelda_calloc", "確保"); // "Secure"
|
2020-03-17 04:31:30 +00:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2024-02-02 20:01:49 +00:00
|
|
|
#if OOT_DEBUG
|
2022-03-21 19:49:11 +00:00
|
|
|
void ZeldaArena_Display(void) {
|
2024-01-12 15:38:13 +00:00
|
|
|
PRINTF("ゼルダヒープ表示\n"); // "Zelda heap display"
|
2020-03-17 04:31:30 +00:00
|
|
|
__osDisplayArena(&sZeldaArena);
|
|
|
|
}
|
2024-02-02 20:01:49 +00:00
|
|
|
#endif
|
2020-03-17 04:31:30 +00:00
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
void ZeldaArena_GetSizes(u32* outMaxFree, u32* outFree, u32* outAlloc) {
|
2020-03-17 04:31:30 +00:00
|
|
|
ArenaImpl_GetSizes(&sZeldaArena, outMaxFree, outFree, outAlloc);
|
|
|
|
}
|
|
|
|
|
2022-03-21 19:49:11 +00:00
|
|
|
void ZeldaArena_Check(void) {
|
2020-03-17 04:31:30 +00:00
|
|
|
__osCheckArena(&sZeldaArena);
|
|
|
|
}
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
void ZeldaArena_Init(void* start, u32 size) {
|
2024-02-02 20:01:49 +00:00
|
|
|
#if OOT_DEBUG
|
2020-03-17 04:31:30 +00:00
|
|
|
gZeldaArenaLogSeverity = LOG_SEVERITY_NOLOG;
|
2024-02-02 20:01:49 +00:00
|
|
|
#endif
|
2020-03-17 04:31:30 +00:00
|
|
|
__osMallocInit(&sZeldaArena, start, size);
|
|
|
|
}
|
|
|
|
|
2022-03-21 19:49:11 +00:00
|
|
|
void ZeldaArena_Cleanup(void) {
|
2024-02-02 20:01:49 +00:00
|
|
|
#if OOT_DEBUG
|
2020-03-17 04:31:30 +00:00
|
|
|
gZeldaArenaLogSeverity = LOG_SEVERITY_NOLOG;
|
2024-02-02 20:01:49 +00:00
|
|
|
#endif
|
2020-03-17 04:31:30 +00:00
|
|
|
__osMallocCleanup(&sZeldaArena);
|
|
|
|
}
|
|
|
|
|
2022-08-30 21:35:00 +00:00
|
|
|
u8 ZeldaArena_IsInitialized(void) {
|
|
|
|
return __osMallocIsInitialized(&sZeldaArena);
|
2020-03-17 04:31:30 +00:00
|
|
|
}
|