From 178e95ae50fb1b21dffc38e3dedc7b6e3b83ed5f Mon Sep 17 00:00:00 2001 From: cadmic Date: Sat, 3 Feb 2024 07:59:25 -0800 Subject: [PATCH] Give debug_malloc.c the same treatment as system_malloc.c and z_malloc.c (#1700) --- include/functions.h | 14 ++++++++------ include/macros.h | 6 ++++++ src/code/db_camera.c | 14 +++++++------- src/code/debug_malloc.c | 37 +++++++++++++++++++++++++++++-------- 4 files changed, 50 insertions(+), 21 deletions(-) diff --git a/include/functions.h b/include/functions.h index d2baeb8ae7..d8d09222c9 100644 --- a/include/functions.h +++ b/include/functions.h @@ -1464,22 +1464,24 @@ u64* SysUcode_GetUCodeData(void); NORETURN void func_800D31A0(void); void func_800D31F0(void); void func_800D3210(void); -void DebugArena_CheckPointer(void* ptr, u32 size, const char* name, const char* action); void* DebugArena_Malloc(u32 size); -void* DebugArena_MallocDebug(u32 size, const char* file, s32 line); void* DebugArena_MallocR(u32 size); -void* DebugArena_MallocRDebug(u32 size, const char* file, s32 line); void* DebugArena_Realloc(void* ptr, u32 newSize); -void* DebugArena_ReallocDebug(void* ptr, u32 newSize, const char* file, s32 line); void DebugArena_Free(void* ptr); -void DebugArena_FreeDebug(void* ptr, const char* file, s32 line); void* DebugArena_Calloc(u32 num, u32 size); -void DebugArena_Display(void); void DebugArena_GetSizes(u32* outMaxFree, u32* outFree, u32* outAlloc); void DebugArena_Check(void); void DebugArena_Init(void* start, u32 size); void DebugArena_Cleanup(void); u8 DebugArena_IsInitialized(void); +#if OOT_DEBUG +void DebugArena_CheckPointer(void* ptr, u32 size, const char* name, const char* action); +void* DebugArena_MallocDebug(u32 size, const char* file, s32 line); +void* DebugArena_MallocRDebug(u32 size, const char* file, s32 line); +void* DebugArena_ReallocDebug(void* ptr, u32 newSize, const char* file, s32 line); +void DebugArena_FreeDebug(void* ptr, const char* file, s32 line); +void DebugArena_Display(void); +#endif void UCodeDisas_Init(UCodeDisas*); void UCodeDisas_Destroy(UCodeDisas*); void UCodeDisas_Disassemble(UCodeDisas*, Gfx*); diff --git a/include/macros.h b/include/macros.h index 10ac65f6ff..b0a35844f4 100644 --- a/include/macros.h +++ b/include/macros.h @@ -194,6 +194,9 @@ extern struct GraphicsContext* __gfxCtx; #define DMA_REQUEST_SYNC(ram, vrom, size, file, line) DmaMgr_RequestSyncDebug(ram, vrom, size, file, line) #define DMA_REQUEST_ASYNC(req, ram, vrom, size, unk5, queue, msg, file, line) DmaMgr_RequestAsyncDebug(req, ram, vrom, size, unk5, queue, msg, file, line) #define GAME_STATE_ALLOC(gameState, size, file, line) GameState_Alloc(gameState, size, file, line) +#define DEBUG_ARENA_MALLOC(size, file, line) DebugArena_MallocDebug(size, file, line) +#define DEBUG_ARENA_MALLOC_R(size, file, line) DebugArena_MallocRDebug(size, file, line) +#define DEBUG_ARENA_FREE(size, file, line) DebugArena_FreeDebug(size, file, line) #define SYSTEM_ARENA_MALLOC(size, file, line) SystemArena_MallocDebug(size, file, line) #define SYSTEM_ARENA_MALLOC_R(size, file, line) SystemArena_MallocRDebug(size, file, line) #define SYSTEM_ARENA_FREE(size, file, line) SystemArena_FreeDebug(size, file, line) @@ -224,6 +227,9 @@ extern struct GraphicsContext* __gfxCtx; #define DMA_REQUEST_SYNC(ram, vrom, size, file, line) DmaMgr_RequestSync(ram, vrom, size) #define DMA_REQUEST_ASYNC(req, ram, vrom, size, unk5, queue, msg, file, line) DmaMgr_RequestAsync(req, ram, vrom, size, unk5, queue, msg) #define GAME_STATE_ALLOC(gameState, size, file, line) THA_AllocTailAlign16(&(gameState)->tha, size) +#define DEBUG_ARENA_MALLOC(size, file, line) DebugArena_Malloc(size) +#define DEBUG_ARENA_MALLOC_R(size, file, line) DebugArena_MallocR(size) +#define DEBUG_ARENA_FREE(size, file, line) DebugArena_Free(size) #define SYSTEM_ARENA_MALLOC(size, file, line) SystemArena_Malloc(size) #define SYSTEM_ARENA_MALLOC_R(size, file, line) SystemArena_MallocR(size) #define SYSTEM_ARENA_FREE(size, file, line) SystemArena_Free(size) diff --git a/src/code/db_camera.c b/src/code/db_camera.c index 795b6f5efc..242609295d 100644 --- a/src/code/db_camera.c +++ b/src/code/db_camera.c @@ -1538,18 +1538,18 @@ char DebugCamera_InitCut(s32 idx, DebugCamSub* sub) { D_80161250[0x3F + sDebugCamCuts[idx].letter] = 'O'; i = sub->nPoints * sizeof(CutsceneCameraPoint); - sDebugCamCuts[idx].lookAt = DebugArena_MallocDebug(i, "../db_camera.c", 2748); + sDebugCamCuts[idx].lookAt = DEBUG_ARENA_MALLOC(i, "../db_camera.c", 2748); if (sDebugCamCuts[idx].lookAt == NULL) { // "Debug camera memory allocation failure" PRINTF("%s: %d: デバッグカメラ メモリ確保失敗!!\n", "../db_camera.c", 2751); return '?'; } - sDebugCamCuts[idx].position = DebugArena_MallocDebug(i, "../db_camera.c", 2754); + sDebugCamCuts[idx].position = DEBUG_ARENA_MALLOC(i, "../db_camera.c", 2754); if (sDebugCamCuts[idx].position == NULL) { // "Debug camera memory allocation failure" PRINTF("%s: %d: デバッグカメラ メモリ確保失敗!!\n", "../db_camera.c", 2757); - DebugArena_FreeDebug(sDebugCamCuts[idx].lookAt, "../db_camera.c", 2758); + DEBUG_ARENA_FREE(sDebugCamCuts[idx].lookAt, "../db_camera.c", 2758); sDebugCamCuts[idx].lookAt = NULL; return '?'; } @@ -1572,8 +1572,8 @@ void DebugCamera_ResetCut(s32 idx, s32 shouldFree) { } if (shouldFree) { - DebugArena_FreeDebug(sDebugCamCuts[idx].lookAt, "../db_camera.c", 2784); - DebugArena_FreeDebug(sDebugCamCuts[idx].position, "../db_camera.c", 2785); + DEBUG_ARENA_FREE(sDebugCamCuts[idx].lookAt, "../db_camera.c", 2784); + DEBUG_ARENA_FREE(sDebugCamCuts[idx].position, "../db_camera.c", 2785); } sDebugCamCuts[idx].letter = '?'; @@ -1623,7 +1623,7 @@ s32 DebugCamera_LoadCallback(char* c) { if (sDebugCamCuts[i].letter != '?') { size = sDebugCamCuts[i].nPoints * sizeof(CutsceneCameraPoint); - sDebugCamCuts[i].lookAt = DebugArena_MallocDebug(ALIGN32(size), "../db_camera.c", 2844); + sDebugCamCuts[i].lookAt = DEBUG_ARENA_MALLOC(ALIGN32(size), "../db_camera.c", 2844); if (sDebugCamCuts[i].lookAt == NULL) { // "Debug camera memory allocation failure" PRINTF("%s: %d: デバッグカメラ メモリ確保失敗!!\n", "../db_camera.c", 2847); @@ -1634,7 +1634,7 @@ s32 DebugCamera_LoadCallback(char* c) { } off += ALIGN32(size); - sDebugCamCuts[i].position = DebugArena_MallocDebug(ALIGN32(size), "../db_camera.c", 2855); + sDebugCamCuts[i].position = DEBUG_ARENA_MALLOC(ALIGN32(size), "../db_camera.c", 2855); if (sDebugCamCuts[i].position == NULL) { // "Debug camera memory allocation failure" PRINTF("%s: %d: デバッグカメラ メモリ確保失敗!!\n", "../db_camera.c", 2858); diff --git a/src/code/debug_malloc.c b/src/code/debug_malloc.c index b833b6dfd7..1f00167bd2 100644 --- a/src/code/debug_malloc.c +++ b/src/code/debug_malloc.c @@ -4,9 +4,11 @@ #define LOG_SEVERITY_ERROR 2 #define LOG_SEVERITY_VERBOSE 3 -s32 gDebugArenaLogSeverity = LOG_SEVERITY_ERROR; Arena sDebugArena; +#if OOT_DEBUG +s32 gDebugArenaLogSeverity = LOG_SEVERITY_ERROR; + void DebugArena_CheckPointer(void* ptr, u32 size, const char* name, const char* action) { if (ptr == NULL) { if (gDebugArenaLogSeverity >= LOG_SEVERITY_ERROR) { @@ -21,53 +23,66 @@ void DebugArena_CheckPointer(void* ptr, u32 size, const char* name, const char* } } +#define DEBUG_ARENA_CHECK_POINTER(ptr, size, name, action) DebugArena_CheckPointer(ptr, size, name, action) +#else +#define DEBUG_ARENA_CHECK_POINTER(ptr, size, name, action) (void)0 +#endif + void* DebugArena_Malloc(u32 size) { void* ptr = __osMalloc(&sDebugArena, size); - DebugArena_CheckPointer(ptr, size, "debug_malloc", "確保"); // "Secure" + DEBUG_ARENA_CHECK_POINTER(ptr, size, "debug_malloc", "確保"); // "Secure" return ptr; } +#if OOT_DEBUG void* DebugArena_MallocDebug(u32 size, const char* file, s32 line) { void* ptr = __osMallocDebug(&sDebugArena, size, file, line); - DebugArena_CheckPointer(ptr, size, "debug_malloc_DEBUG", "確保"); // "Secure" + DEBUG_ARENA_CHECK_POINTER(ptr, size, "debug_malloc_DEBUG", "確保"); // "Secure" return ptr; } +#endif void* DebugArena_MallocR(u32 size) { void* ptr = __osMallocR(&sDebugArena, size); - DebugArena_CheckPointer(ptr, size, "debug_malloc_r", "確保"); // "Secure" + DEBUG_ARENA_CHECK_POINTER(ptr, size, "debug_malloc_r", "確保"); // "Secure" return ptr; } +#if OOT_DEBUG void* DebugArena_MallocRDebug(u32 size, const char* file, s32 line) { void* ptr = __osMallocRDebug(&sDebugArena, size, file, line); - DebugArena_CheckPointer(ptr, size, "debug_malloc_r_DEBUG", "確保"); // "Secure" + DEBUG_ARENA_CHECK_POINTER(ptr, size, "debug_malloc_r_DEBUG", "確保"); // "Secure" return ptr; } +#endif void* DebugArena_Realloc(void* ptr, u32 newSize) { ptr = __osRealloc(&sDebugArena, ptr, newSize); - DebugArena_CheckPointer(ptr, newSize, "debug_realloc", "再確保"); // "Re-securing" + DEBUG_ARENA_CHECK_POINTER(ptr, newSize, "debug_realloc", "再確保"); // "Re-securing" return ptr; } +#if OOT_DEBUG void* DebugArena_ReallocDebug(void* ptr, u32 newSize, const char* file, s32 line) { ptr = __osReallocDebug(&sDebugArena, ptr, newSize, file, line); - DebugArena_CheckPointer(ptr, newSize, "debug_realloc_DEBUG", "再確保"); // "Re-securing" + DEBUG_ARENA_CHECK_POINTER(ptr, newSize, "debug_realloc_DEBUG", "再確保"); // "Re-securing" return ptr; } +#endif void DebugArena_Free(void* ptr) { __osFree(&sDebugArena, ptr); } +#if OOT_DEBUG void DebugArena_FreeDebug(void* ptr, const char* file, s32 line) { __osFreeDebug(&sDebugArena, ptr, file, line); } +#endif void* DebugArena_Calloc(u32 num, u32 size) { void* ret; @@ -78,15 +93,17 @@ void* DebugArena_Calloc(u32 num, u32 size) { bzero(ret, n); } - DebugArena_CheckPointer(ret, n, "debug_calloc", "確保"); + DEBUG_ARENA_CHECK_POINTER(ret, n, "debug_calloc", "確保"); return ret; } +#if OOT_DEBUG void DebugArena_Display(void) { // "Zelda heap display" ("Zelda" should probably have been changed to "Debug") PRINTF("ゼルダヒープ表示\n"); __osDisplayArena(&sDebugArena); } +#endif void DebugArena_GetSizes(u32* outMaxFree, u32* outFree, u32* outAlloc) { ArenaImpl_GetSizes(&sDebugArena, outMaxFree, outFree, outAlloc); @@ -97,12 +114,16 @@ void DebugArena_Check(void) { } void DebugArena_Init(void* start, u32 size) { +#if OOT_DEBUG gDebugArenaLogSeverity = LOG_SEVERITY_NOLOG; +#endif __osMallocInit(&sDebugArena, start, size); } void DebugArena_Cleanup(void) { +#if OOT_DEBUG gDebugArenaLogSeverity = LOG_SEVERITY_NOLOG; +#endif __osMallocCleanup(&sDebugArena); }