Files
dusklight/libs/JSystem/JKernel/JKRAram.cpp
T
2021-03-31 23:22:38 +02:00

997 lines
28 KiB
C++

//
// Generated By: dol2asm
// Translation Unit: JKRAram
//
#include "dol2asm.h"
#include "dolphin/types.h"
#include "JSystem/JKernel/JKRAram.h"
//
// Types:
//
struct JUTException {
/* 802E21FC */ // False False
// char const* False
// char const False
// char False
// int False
// char const* False
// char const False
// char False
// ... False
void panic_f(char const*, int, char const*, ...);
};
struct JSUPtrList {
/* 802DBEAC */ // False False
~JSUPtrList();
/* 802DBF14 */ // False False
void initiate();
};
template <typename A0>
struct JSUList { };
/* JSUList<JKRAMCommand> */
struct JSUList__template5 {
/* 802D2DF0 */ // False True
~JSUList__template5();
};
struct JKRThread {
/* 802D1568 */ // False False
// u32 False
// int False
// int False
JKRThread(u32, int, int);
/* 802D1758 */ // False False
~JKRThread();
};
struct JKRHeap {
/* 802CE4D4 */ // False False
// u32 False
// int False
void alloc(u32, int);
/* 802CE474 */ // False False
// u32 False
// int False
// JKRHeap* False
// JKRHeap False
void alloc(u32, int, JKRHeap*);
/* 802CE500 */ // False False
// void* False
// void False
// JKRHeap* False
// JKRHeap False
void free(void*, JKRHeap*);
};
struct JKRExpandSwitch {
};
struct JKRDecomp {
/* 802DB680 */ // False False
// s32 False
void create(s32);
/* 802DB988 */ // False False
// u8* False
// u8 False
// u8* False
// u8 False
// u32 False
// u32 False
void orderSync(u8*, u8*, u32, u32);
/* 802DBCF8 */ // False False
// u8* False
// u8 False
void checkCompressed(u8*);
};
struct JKRAramStream {
/* 802D3B48 */ // False False
// s32 False
void create(s32);
};
struct JKRAramBlock {
};
struct JKRAMCommand {
};
struct JKRAramPiece {
/* 802D3838 */ // False False
// int False
// u32 False
// u32 False
// u32 False
// JKRAramBlock* False
// JKRAramBlock False
void orderSync(int, u32, u32, u32, JKRAramBlock*);
/* 802D38CC */ // False False
// JKRAMCommand* False
// JKRAMCommand False
void startDMA(JKRAMCommand*);
};
struct JKRAramHeap {
struct EAllocMode {
};
/* 802D2E44 */ // False False
// u32 False
// u32 False
JKRAramHeap(u32, u32);
/* 802D2FBC */ // False False
// u32 False
// JKRAramHeap::EAllocMode False
void alloc(u32, JKRAramHeap::EAllocMode);
};
struct JKRAram {
/* 802D1FA4 */ // False False
// u32 False
// u32 False
// s32 False
// s32 False
// s32 False
void create(u32, u32, s32, s32, s32);
/* 802D2040 */ // True False
// u32 False
// u32 False
// s32 False
JKRAram(u32, u32, s32);
/* 802D214C */ // True False
~JKRAram();
/* 802D21DC */ // True False
void run();
/* 802D2248 */ // True False
// u8* False
// u8 False
// u32 False
// JKRAramBlock* False
// JKRAramBlock False
// u32 False
void checkOkAddress(u8*, u32, JKRAramBlock*, u32);
/* 802D22DC */ // True False
// u8* False
// u8 False
// int False
void changeGroupIdIfNeed(u8*, int);
/* 802D233C */ // False False
// u8* False
// u8 False
// u32 False
// u32 False
// JKRExpandSwitch False
// u32 False
// JKRHeap* False
// JKRHeap False
// int False
// u32* False
// u32 False
void mainRamToAram(u8*, u32, u32, JKRExpandSwitch, u32, JKRHeap*, int, u32*);
/* 802D25B4 */ // False False
// u32 False
// u8* False
// u8 False
// u32 False
// JKRExpandSwitch False
// u32 False
// JKRHeap* False
// JKRHeap False
// int False
// u32* False
// u32 False
void aramToMainRam(u32, u8*, u32, JKRExpandSwitch, u32, JKRHeap*, int, u32*);
};
//
// Forward References:
//
// True False
// u32 False
// void* False
// void False
// u32 False
// u32 False
// u32 False
// u32* False
// u32 False
static void JKRDecompressFromAramToMainRam(u32, void*, u32, u32, u32, u32*);
// True False
// u8* False
// u8 False
// u8* False
// u8 False
static void decompSZS_subroutine(u8*, u8*);
// True False
static void firstSrcData();
// True False
// u8* False
// u8 False
static void nextSrcData(u8*);
// False False
// u32 False
// u32 False
// s32 False
// s32 False
// s32 False
extern "C" void create__7JKRAramFUlUllll();
// True False
// u32 False
// u32 False
// s32 False
extern "C" void __ct__7JKRAramFUlUll();
// True False
extern "C" void __dt__7JKRAramFv();
// True False
extern "C" void run__7JKRAramFv();
// True False
// u8* False
// u8 False
// u32 False
// JKRAramBlock* False
// JKRAramBlock False
// u32 False
extern "C" void checkOkAddress__7JKRAramFPUcUlP12JKRAramBlockUl();
// True False
// u8* False
// u8 False
// int False
extern "C" void changeGroupIdIfNeed__7JKRAramFPUci();
// False False
// u8* False
// u8 False
// u32 False
// u32 False
// JKRExpandSwitch False
// u32 False
// JKRHeap* False
// JKRHeap False
// int False
// u32* False
// u32 False
extern "C" void mainRamToAram__7JKRAramFPUcUlUl15JKRExpandSwitchUlP7JKRHeapiPUl();
// False False
// u32 False
// u8* False
// u8 False
// u32 False
// JKRExpandSwitch False
// u32 False
// JKRHeap* False
// JKRHeap False
// int False
// u32* False
// u32 False
extern "C" void aramToMainRam__7JKRAramFUlPUcUl15JKRExpandSwitchUlP7JKRHeapiPUl();
// True False
// u32 False
// void* False
// void False
// u32 False
// u32 False
// u32 False
// u32* False
// u32 False
extern "C" static void JKRDecompressFromAramToMainRam__FUlPvUlUlUlPUl();
// True False
// u8* False
// u8 False
// u8* False
// u8 False
extern "C" static void decompSZS_subroutine__FPUcPUc();
// True False
extern "C" static void firstSrcData__Fv();
// True False
// u8* False
// u8 False
extern "C" static void nextSrcData__FPUc();
// False False
extern "C" void __sinit_JKRAram_cpp();
// False True
extern "C" void func_802D2DF0();
extern "C" extern char const* const JKRAram__stringBase0;
extern "C" extern u8 sMessageQueue__7JKRAram[32];
extern "C" extern void* __vt__7JKRAram[4];
extern "C" extern u32 sSZSBufferSize__7JKRAram[1 + 1 /* padding */];
extern "C" extern u8 sAramObject__7JKRAram[4];
//
// External References:
//
// False False
// void* False
// void False
// u32 False
// JKRHeap* False
// JKRHeap False
// int False
void* operator new(u32, JKRHeap*, int);
// False False
// void False
// void* False
// void False
void operator delete(void*);
// False False
SECTION_INIT void memcpy();
// False False
// u32 False
// int False
// JKRHeap* False
// JKRHeap False
extern "C" void alloc__7JKRHeapFUliP7JKRHeap();
// False False
// u32 False
// int False
extern "C" void alloc__7JKRHeapFUli();
// False False
// void* False
// void False
// JKRHeap* False
// JKRHeap False
extern "C" void free__7JKRHeapFPvP7JKRHeap();
// False False
// void* False
// void False
// u32 False
// JKRHeap* False
// JKRHeap False
// int False
extern "C" void* __nw__FUlP7JKRHeapi();
// False False
// void False
// void* False
// void False
extern "C" void __dl__FPv();
// False False
// u32 False
// int False
// int False
extern "C" void __ct__9JKRThreadFUlii();
// False False
extern "C" void __dt__9JKRThreadFv();
// False False
// u32 False
// u32 False
extern "C" void __ct__11JKRAramHeapFUlUl();
// False False
// u32 False
// JKRAramHeap::EAllocMode False
extern "C" void alloc__11JKRAramHeapFUlQ211JKRAramHeap10EAllocMode();
// False False
// int False
// u32 False
// u32 False
// u32 False
// JKRAramBlock* False
// JKRAramBlock False
extern "C" void orderSync__12JKRAramPieceFiUlUlUlP12JKRAramBlock();
// False False
// JKRAMCommand* False
// JKRAMCommand False
extern "C" void startDMA__12JKRAramPieceFP12JKRAMCommand();
// False False
// s32 False
extern "C" void create__13JKRAramStreamFl();
// False False
// s32 False
extern "C" void create__9JKRDecompFl();
// False False
// u8* False
// u8 False
// u8* False
// u8 False
// u32 False
// u32 False
extern "C" void orderSync__9JKRDecompFPUcPUcUlUl();
// False False
// u8* False
// u8 False
extern "C" void checkCompressed__9JKRDecompFPUc();
// False False
extern "C" void __dt__10JSUPtrListFv();
// False False
extern "C" void initiate__10JSUPtrListFv();
// False False
// char const* False
// char const False
// char False
// int False
// char const* False
// char const False
// char False
// ... False
extern "C" void panic_f__12JUTExceptionFPCciPCce();
// False False
extern "C" void DCStoreRangeNoSync();
// False False
extern "C" void OSDisableInterrupts();
// False False
extern "C" void OSRestoreInterrupts();
// False False
extern "C" void OSInitMessageQueue();
// False False
extern "C" void OSReceiveMessage();
// False False
extern "C" void OSInitMutex();
// False False
extern "C" void OSLockMutex();
// False False
extern "C" void OSUnlockMutex();
// False False
extern "C" void OSResumeThread();
// False False
extern "C" void ARAlloc();
// False False
extern "C" void ARInit();
// False False
extern "C" void ARGetSize();
// False False
extern "C" void ARQInit();
// False False
extern "C" void __register_global_object();
// False False
extern "C" void _savegpr_22();
// False False
extern "C" void _savegpr_23();
// False False
extern "C" void _savegpr_25();
// False False
extern "C" void _savegpr_27();
// False False
extern "C" void _savegpr_28();
// False False
extern "C" void _savegpr_29();
// False False
extern "C" void _restgpr_22();
// False False
extern "C" void _restgpr_23();
// False False
extern "C" void _restgpr_25();
// False False
extern "C" void _restgpr_27();
// False False
extern "C" void _restgpr_28();
// False False
extern "C" void _restgpr_29();
extern "C" extern u8 sSystemHeap__7JKRHeap[4];
extern "C" extern u8 sCurrentHeap__7JKRHeap[4];
//
// Declarations:
//
/* ############################################################################################## */
/* 804513C8-804513CC 0004+00 s=3 e=9 z=0 None .sbss sAramObject__7JKRAram */
u8 sAramObject__7JKRAram[4];
/* 802D1FA4-802D2040 009C+00 s=0 e=1 z=0 None .text create__7JKRAramFUlUllll */
// 802D1FB4: 803621D4 (_savegpr_27)
// 802D1FCC: 804513C8 (sAramObject__7JKRAram)
// 802D1FDC: 80451370 (sSystemHeap__7JKRHeap)
// 802D1FE4: 802CEC98 (__nw__FUlP7JKRHeapi)
// 802D1FFC: 802D2040 (__ct__7JKRAramFUlUll)
// 802D2004: 804513C8 (sAramObject__7JKRAram)
// 802D200C: 802D3B48 (create__13JKRAramStreamFl)
// 802D2014: 802DB680 (create__9JKRDecompFl)
// 802D2018: 804513C8 (sAramObject__7JKRAram)
// 802D2020: 803417B4 (OSResumeThread)
// 802D2024: 804513C8 (sAramObject__7JKRAram)
// 802D202C: 80362220 (_restgpr_27)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// False False
// u32 False
// u32 False
// s32 False
// s32 False
// s32 False
asm void JKRAram::create(u32 param_0, u32 param_1, s32 param_2, s32 param_3, s32 param_4) {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/create__7JKRAramFUlUllll.s"
}
#pragma pop
/* ############################################################################################## */
/* 803CC128-803CC138 0010+00 s=1 e=0 z=0 None .data sMessageBuffer__7JKRAram */
SECTION_DATA static u8 sMessageBuffer__7JKRAram[16] = {
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
};
/* 803CC138-803CC158 0020+00 s=1 e=1 z=0 None .data sMessageQueue__7JKRAram */
SECTION_DATA u8 sMessageQueue__7JKRAram[32] = {
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
};
/* 803CC158-803CC168 0010+00 s=2 e=0 z=0 None .data __vt__7JKRAram */
SECTION_DATA void* __vt__7JKRAram[4] = {
(void*)NULL /* RTTI */,
(void*)NULL,
(void*)__dt__7JKRAramFv,
(void*)run__7JKRAramFv,
};
/* 802D2040-802D214C 010C+00 s=1 e=0 z=0 None .text __ct__7JKRAramFUlUll */
// 802D2050: 803621D8 (_savegpr_28)
// 802D2068: 802D1568 (__ct__9JKRThreadFUlii)
// 802D206C: 803CC158 (__vt__7JKRAram)
// 802D2070: 803CC158 (__vt__7JKRAram)
// 802D2080: 8035072C (ARInit)
// 802D2088: 80352264 (ARQInit)
// 802D208C: 803507F0 (ARGetSize)
// 802D20D0: 803506C4 (ARAlloc)
// 802D20DC: 803506C4 (ARAlloc)
// 802D20F0: 803506C4 (ARAlloc)
// 802D2108: 80451370 (sSystemHeap__7JKRHeap)
// 802D2110: 802CEC98 (__nw__FUlP7JKRHeapi)
// 802D2124: 802D2E44 (__ct__11JKRAramHeapFUlUl)
// 802D2138: 80362224 (_restgpr_28)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// True False
// u32 False
// u32 False
// s32 False
asm JKRAram::JKRAram(u32 param_0, u32 param_1, s32 param_2) {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/__ct__7JKRAramFUlUll.s"
}
#pragma pop
/* 802D214C-802D21DC 0090+00 s=1 e=0 z=0 None .text __dt__7JKRAramFv */
// 802D216C: 803CC158 (__vt__7JKRAram)
// 802D2170: 803CC158 (__vt__7JKRAram)
// 802D217C: 804513C8 (sAramObject__7JKRAram)
// 802D21AC: 802D1758 (__dt__9JKRThreadFv)
// 802D21BC: 802CED3C (__dl__FPv)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// True False
asm JKRAram::~JKRAram() {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/__dt__7JKRAramFv.s"
}
#pragma pop
/* 802D21DC-802D2248 006C+00 s=1 e=0 z=0 None .text run__7JKRAramFv */
// 802D21EC: 803621DC (_savegpr_29)
// 802D21F0: 803CC138 (sMessageQueue__7JKRAram)
// 802D21F4: 803CC138 (sMessageQueue__7JKRAram)
// 802D21F8: 803CC128 (sMessageBuffer__7JKRAram)
// 802D21FC: 803CC128 (sMessageBuffer__7JKRAram)
// 802D2204: 8033E994 (OSInitMessageQueue)
// 802D2208: 803CC138 (sMessageQueue__7JKRAram)
// 802D220C: 803CC138 (sMessageQueue__7JKRAram)
// 802D221C: 8033EABC (OSReceiveMessage)
// 802D222C: 802CED3C (__dl__FPv)
// 802D2240: 802D38CC (startDMA__12JKRAramPieceFP12JKRAMCommand)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// True False
asm void JKRAram::run() {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/run__7JKRAramFv.s"
}
#pragma pop
/* ############################################################################################## */
/* 8039D078-8039D0B8 003C+04 s=1 e=0 z=0 None .rodata @stringBase0 */
#pragma push
#pragma force_active on
#pragma section ".dead"
SECTION_DEAD char const* const stringBase_8039D078 = "JKRAram.cpp";
SECTION_DEAD char const* const stringBase_8039D084 = "%s";
SECTION_DEAD char const* const stringBase_8039D087 = ":::address not 32Byte aligned.";
SECTION_DEAD char const* const stringBase_8039D0A6 = "bad aramSync\n";
/* @stringBase0 padding */
SECTION_DEAD static char const* const pad_8039D0B4 = "\0\0\0";
#pragma pop
/* 802D2248-802D22DC 0094+00 s=2 e=0 z=0 None .text checkOkAddress__7JKRAramFPUcUlP12JKRAramBlockUl */
// 802D2274: 8039D078 (JKRAram__stringBase0)
// 802D2278: 8039D078 (JKRAram__stringBase0)
// 802D228C: 802E21FC (panic_f__12JUTExceptionFPCciPCce)
// 802D22A8: 8039D078 (JKRAram__stringBase0)
// 802D22AC: 8039D078 (JKRAram__stringBase0)
// 802D22C0: 802E21FC (panic_f__12JUTExceptionFPCciPCce)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// True False
// u8* False
// u8 False
// u32 False
// JKRAramBlock* False
// JKRAramBlock False
// u32 False
asm void JKRAram::checkOkAddress(u8* param_0, u32 param_1, JKRAramBlock* param_2, u32 param_3) {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/checkOkAddress__7JKRAramFPUcUlP12JKRAramBlockUl.s"
}
#pragma pop
/* 802D22DC-802D233C 0060+00 s=1 e=0 z=0 None .text changeGroupIdIfNeed__7JKRAramFPUci */
// 802D22F8: 80451374 (sCurrentHeap__7JKRHeap)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// True False
// u8* False
// u8 False
// int False
asm void JKRAram::changeGroupIdIfNeed(u8* param_0, int param_1) {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/changeGroupIdIfNeed__7JKRAramFPUci.s"
}
#pragma pop
/* 802D233C-802D25B4 0278+00 s=0 e=3 z=0 None .text mainRamToAram__7JKRAramFPUcUlUl15JKRExpandSwitchUlP7JKRHeapiPUl */
// 802D234C: 803621C4 (_savegpr_23)
// 802D237C: 802D2248 (checkOkAddress__7JKRAramFPUcUlP12JKRAramBlockUl)
// 802D238C: 802DBCF8 (checkCompressed__9JKRDecompFPUc)
// 802D23EC: 804513C8 (sAramObject__7JKRAram)
// 802D23FC: 802D2FBC (alloc__11JKRAramHeapFUlQ211JKRAramHeap10EAllocMode)
// 802D241C: 804513C8 (sAramObject__7JKRAram)
// 802D2468: 802CE474 (alloc__7JKRHeapFUliP7JKRHeap)
// 802D24B0: 802DB988 (orderSync__9JKRDecompFPUcPUcUlUl)
// 802D24C8: 802D3838 (orderSync__12JKRAramPieceFiUlUlUlP12JKRAramBlock)
// 802D24D4: 802CE500 (free__7JKRHeapFPvP7JKRHeap)
// 802D2518: 804513C8 (sAramObject__7JKRAram)
// 802D2528: 802D2FBC (alloc__11JKRAramHeapFUlQ211JKRAramHeap10EAllocMode)
// 802D2538: 804513C8 (sAramObject__7JKRAram)
// 802D2578: 802D3838 (orderSync__12JKRAramPieceFiUlUlUlP12JKRAramBlock)
// 802D25A0: 80362210 (_restgpr_23)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// False False
// u8* False
// u8 False
// u32 False
// u32 False
// JKRExpandSwitch False
// u32 False
// JKRHeap* False
// JKRHeap False
// int False
// u32* False
// u32 False
asm void JKRAram::mainRamToAram(u8* param_0, u32 param_1, u32 param_2, JKRExpandSwitch param_3, u32 param_4, JKRHeap* param_5, int param_6, u32* param_7) {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/mainRamToAram__7JKRAramFPUcUlUl15JKRExpandSwitchUlP7JKRHeapiPUl.s"
}
#pragma pop
/* 802D25B4-802D2830 027C+00 s=0 e=6 z=0 None .text aramToMainRam__7JKRAramFUlPUcUl15JKRExpandSwitchUlP7JKRHeapiPUl */
// 802D25C4: 803621C0 (_savegpr_22)
// 802D2608: 802D2248 (checkOkAddress__7JKRAramFPUcUlP12JKRAramBlockUl)
// 802D2630: 802D3838 (orderSync__12JKRAramPieceFiUlUlUlP12JKRAramBlock)
// 802D2638: 802DBCF8 (checkCompressed__9JKRDecompFPUc)
// 802D269C: 802CE474 (alloc__7JKRHeapFUliP7JKRHeap)
// 802D26BC: 802D22DC (changeGroupIdIfNeed__7JKRAramFPUci)
// 802D26D8: 802D2830 (JKRDecompressFromAramToMainRam__FUlPvUlUlUlPUl)
// 802D26F8: 802CE474 (alloc__7JKRHeapFUliP7JKRHeap)
// 802D2720: 802D3838 (orderSync__12JKRAramPieceFiUlUlUlP12JKRAramBlock)
// 802D274C: 802CE474 (alloc__7JKRHeapFUliP7JKRHeap)
// 802D276C: 802CE500 (free__7JKRHeapFPvP7JKRHeap)
// 802D2780: 802D22DC (changeGroupIdIfNeed__7JKRAramFPUci)
// 802D2794: 802DB988 (orderSync__9JKRDecompFPUcPUcUlUl)
// 802D27A0: 802CE500 (free__7JKRHeapFPvP7JKRHeap)
// 802D27CC: 802CE474 (alloc__7JKRHeapFUliP7JKRHeap)
// 802D27EC: 802D22DC (changeGroupIdIfNeed__7JKRAramFPUci)
// 802D2804: 802D3838 (orderSync__12JKRAramPieceFiUlUlUlP12JKRAramBlock)
// 802D281C: 8036220C (_restgpr_22)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// False False
// u32 False
// u8* False
// u8 False
// u32 False
// JKRExpandSwitch False
// u32 False
// JKRHeap* False
// JKRHeap False
// int False
// u32* False
// u32 False
asm void JKRAram::aramToMainRam(u32 param_0, u8* param_1, u32 param_2, JKRExpandSwitch param_3, u32 param_4, JKRHeap* param_5, int param_6, u32* param_7) {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/aramToMainRam__7JKRAramFUlPUcUl15JKRExpandSwitchUlP7JKRHeapiPUl.s"
}
#pragma pop
/* ############################################################################################## */
/* 804342D0-804342DC 000C+00 s=1 e=0 z=0 None .bss @492 */
static u8 lit_492[12];
/* 804342DC-804342E8 000C+00 s=1 e=0 z=0 None .bss sAramCommandList__7JKRAram */
static u8 sAramCommandList__7JKRAram[12];
/* 804342E8-80434300 0018+00 s=1 e=0 z=0 None .bss decompMutex */
static u8 decompMutex[24];
/* 804508B8-804508C0 0004+04 s=1 e=1 z=0 None .sdata sSZSBufferSize__7JKRAram */
SECTION_SDATA u32 sSZSBufferSize__7JKRAram[1 + 1 /* padding */] = {
0x00000400,
/* padding */
0x00000000,
};
/* 804513CC-804513D0 0004+00 s=3 e=0 z=0 None .sbss szpBuf */
static u8 szpBuf[4];
/* 804513D0-804513D4 0004+00 s=3 e=0 z=0 None .sbss szpEnd */
static u8 szpEnd[4];
/* 804513D4-804513D8 0004+00 s=2 e=0 z=0 None .sbss refBuf */
static u8 refBuf[4];
/* 804513D8-804513DC 0004+00 s=2 e=0 z=0 None .sbss refEnd */
static u8 refEnd[4];
/* 804513DC-804513E0 0004+00 s=2 e=0 z=0 None .sbss refCurrent */
static u8 refCurrent[4];
/* 804513E0-804513E4 0004+00 s=3 e=0 z=0 None .sbss srcOffset */
static u8 srcOffset[4];
/* 804513E4-804513E8 0004+00 s=4 e=0 z=0 None .sbss transLeft */
static u8 transLeft[4];
/* 804513E8-804513EC 0004+00 s=3 e=0 z=0 None .sbss srcLimit */
static u8 srcLimit[4];
/* 804513EC-804513F0 0004+00 s=3 e=0 z=0 None .sbss srcAddress */
static u8 srcAddress[4];
/* 804513F0-804513F4 0004+00 s=2 e=0 z=0 None .sbss fileOffset */
static u8 fileOffset[4];
/* 804513F4-804513F8 0004+00 s=2 e=0 z=0 None .sbss readCount */
static u8 readCount[4];
/* 804513F8-804513FC 0004+00 s=2 e=0 z=0 None .sbss maxDest */
static u8 maxDest[4];
/* 804513FC-80451400 0004+00 s=1 e=0 z=0 None .sbss None */
static u8 data_804513FC[4];
/* 80451400-80451404 0004+00 s=2 e=0 z=0 None .sbss tsPtr */
static u8 tsPtr[4];
/* 80451404-80451408 0004+00 s=1 e=0 z=0 None .sbss tsArea */
static u8 tsArea[4];
/* 802D2830-802D29A0 0170+00 s=1 e=0 z=0 None .text JKRDecompressFromAramToMainRam__FUlPvUlUlUlPUl */
// 802D2840: 803621CC (_savegpr_25)
// 802D285C: 8033D6F4 (OSDisableInterrupts)
// 802D2864: 804513FC (data_804513FC)
// 802D2870: 804342E8 (decompMutex)
// 802D2874: 804342E8 (decompMutex)
// 802D2878: 8033F008 (OSInitMutex)
// 802D2880: 804513FC (data_804513FC)
// 802D2888: 8033D71C (OSRestoreInterrupts)
// 802D288C: 804342E8 (decompMutex)
// 802D2890: 804342E8 (decompMutex)
// 802D2894: 8033F040 (OSLockMutex)
// 802D2898: 804508B8 (sSZSBufferSize__7JKRAram)
// 802D289C: 80451370 (sSystemHeap__7JKRHeap)
// 802D28A8: 802CE4D4 (alloc__7JKRHeapFUli)
// 802D28AC: 804513CC (szpBuf)
// 802D28B4: 804513D0 (szpEnd)
// 802D28C0: 80451370 (sSystemHeap__7JKRHeap)
// 802D28CC: 802CE4D4 (alloc__7JKRHeapFUli)
// 802D28D0: 804513D4 (refBuf)
// 802D28D8: 804513D8 (refEnd)
// 802D28DC: 804513DC (refCurrent)
// 802D28E8: 804513D4 (refBuf)
// 802D28EC: 804513EC (srcAddress)
// 802D28F4: 804513E0 (srcOffset)
// 802D2908: 804513E4 (transLeft)
// 802D290C: 804513F0 (fileOffset)
// 802D2914: 804513F4 (readCount)
// 802D2918: 804513F8 (maxDest)
// 802D292C: 80451404 (tsArea)
// 802D2930: 80451400 (tsPtr)
// 802D293C: 802D2C40 (firstSrcData__Fv)
// 802D2944: 802D29A0 (decompSZS_subroutine__FPUcPUc)
// 802D2948: 804513CC (szpBuf)
// 802D2950: 802CE500 (free__7JKRHeapFPvP7JKRHeap)
// 802D2954: 804513D4 (refBuf)
// 802D2964: 802CE500 (free__7JKRHeapFPvP7JKRHeap)
// 802D296C: 80451400 (tsPtr)
// 802D2974: 8033B638 (DCStoreRangeNoSync)
// 802D2978: 804342E8 (decompMutex)
// 802D297C: 804342E8 (decompMutex)
// 802D2980: 8033F11C (OSUnlockMutex)
// 802D298C: 80362218 (_restgpr_25)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// True False
// u32 False
// void* False
// void False
// u32 False
// u32 False
// u32 False
// u32* False
// u32 False
asm static void JKRDecompressFromAramToMainRam(u32 param_0, void* param_1, u32 param_2, u32 param_3, u32 param_4, u32* param_5) {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/JKRDecompressFromAramToMainRam__FUlPvUlUlUlPUl.s"
}
#pragma pop
/* 802D29A0-802D2C40 02A0+00 s=1 e=0 z=0 None .text decompSZS_subroutine__FPUcPUc */
// 802D29B0: 803621DC (_savegpr_29)
// 802D29FC: 804513F0 (fileOffset)
// 802D2A0C: 804513F8 (maxDest)
// 802D2A2C: 804513E8 (srcLimit)
// 802D2A38: 804513E4 (transLeft)
// 802D2A44: 802D2CE4 (nextSrcData__FPUc)
// 802D2A5C: 804513F0 (fileOffset)
// 802D2A68: 804513F4 (readCount)
// 802D2A90: 804513DC (refCurrent)
// 802D2A98: 804513DC (refCurrent)
// 802D2AA0: 804513DC (refCurrent)
// 802D2AA4: 804513D8 (refEnd)
// 802D2AB0: 804513D4 (refBuf)
// 802D2AB4: 804513DC (refCurrent)
// 802D2ADC: 804513F4 (readCount)
// 802D2AE4: 804513F4 (readCount)
// 802D2AFC: 804513F0 (fileOffset)
// 802D2B0C: 804513DC (refCurrent)
// 802D2B18: 804513D4 (refBuf)
// 802D2B24: 804513D8 (refEnd)
// 802D2B60: 804513F4 (readCount)
// 802D2B64: 804513F0 (fileOffset)
// 802D2B8C: 804513DC (refCurrent)
// 802D2B94: 804513DC (refCurrent)
// 802D2B9C: 804513DC (refCurrent)
// 802D2BA0: 804513D8 (refEnd)
// 802D2BAC: 804513D4 (refBuf)
// 802D2BB0: 804513DC (refCurrent)
// 802D2BC0: 804513D4 (refBuf)
// 802D2BC4: 804513F4 (readCount)
// 802D2BCC: 804513F4 (readCount)
// 802D2BF4: 804513F4 (readCount)
// 802D2BFC: 804513F4 (readCount)
// 802D2C1C: 80451400 (tsPtr)
// 802D2C2C: 80362228 (_restgpr_29)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// True False
// u8* False
// u8 False
// u8* False
// u8 False
asm static void decompSZS_subroutine(u8* param_0, u8* param_1) {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/decompSZS_subroutine__FPUcPUc.s"
}
#pragma pop
/* 802D2C40-802D2CE4 00A4+00 s=1 e=0 z=0 None .text firstSrcData__Fv */
// 802D2C54: 804513D0 (szpEnd)
// 802D2C5C: 804513E8 (srcLimit)
// 802D2C60: 804513CC (szpBuf)
// 802D2C6C: 804513E4 (transLeft)
// 802D2C84: 804513EC (srcAddress)
// 802D2C88: 804513E0 (srcOffset)
// 802D2CA0: 802D3838 (orderSync__12JKRAramPieceFiUlUlUlP12JKRAramBlock)
// 802D2CA4: 804513E0 (srcOffset)
// 802D2CAC: 804513E0 (srcOffset)
// 802D2CB0: 804513E4 (transLeft)
// 802D2CB8: 804513E4 (transLeft)
// 802D2CC4: 804513E8 (srcLimit)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// True False
asm static void firstSrcData() {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/firstSrcData__Fv.s"
}
#pragma pop
/* 802D2CE4-802D2DAC 00C8+00 s=1 e=0 z=0 None .text nextSrcData__FPUc */
// 802D2CF4: 803621D8 (_savegpr_28)
// 802D2CFC: 804513D0 (szpEnd)
// 802D2D0C: 804513CC (szpBuf)
// 802D2D1C: 804513CC (szpBuf)
// 802D2D28: 80003540 (memcpy)
// 802D2D30: 804513D0 (szpEnd)
// 802D2D38: 804513E4 (transLeft)
// 802D2D4C: 804513EC (srcAddress)
// 802D2D50: 804513E0 (srcOffset)
// 802D2D68: 802D3838 (orderSync__12JKRAramPieceFiUlUlUlP12JKRAramBlock)
// 802D2D6C: 804513E0 (srcOffset)
// 802D2D74: 804513E0 (srcOffset)
// 802D2D78: 804513E4 (transLeft)
// 802D2D80: 804513E4 (transLeft)
// 802D2D8C: 804513E8 (srcLimit)
// 802D2D98: 80362224 (_restgpr_28)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// True False
// u8* False
// u8 False
asm static void nextSrcData(u8* param_0) {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/nextSrcData__FPUc.s"
}
#pragma pop
/* 802D2DAC-802D2DF0 0044+00 s=0 e=0 z=0 None .text __sinit_JKRAram_cpp */
// 802D2DB8: 804342DC (sAramCommandList__7JKRAram)
// 802D2DBC: 804342DC (sAramCommandList__7JKRAram)
// 802D2DC0: 802DBF14 (initiate__10JSUPtrListFv)
// 802D2DC4: 804342DC (sAramCommandList__7JKRAram)
// 802D2DC8: 804342DC (sAramCommandList__7JKRAram)
// 802D2DCC: 802D2DF0 (func_802D2DF0)
// 802D2DD0: 802D2DF0 (func_802D2DF0)
// 802D2DD4: 804342D0 (lit_492)
// 802D2DD8: 804342D0 (lit_492)
// 802D2DDC: 80361C24 (__register_global_object)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// False False
extern "C" asm void __sinit_JKRAram_cpp() {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/__sinit_JKRAram_cpp.s"
}
#pragma pop
#pragma push
#pragma force_active on
#pragma section ".ctors$15"
__declspec(section ".ctors$15") void* const _ctors_802D2DAC = (void*)__sinit_JKRAram_cpp;
#pragma pop
/* 802D2DF0-802D2E44 0054+00 s=1 e=1 z=0 None .text __dt__23JSUList<12JKRAMCommand>Fv */
// 802D2E14: 802DBEAC (__dt__10JSUPtrListFv)
// 802D2E24: 802CED3C (__dl__FPv)
#pragma push
#pragma optimization_level 0
#pragma optimizewithasm off
// False True
asm JSUList__template5::~JSUList__template5() {
nofralloc
#include "asm/JSystem/JKernel/JKRAram/func_802D2DF0.s"
}
#pragma pop