diff --git a/config/eur/arm9/delinks.txt b/config/eur/arm9/delinks.txt index 12508e64..e4fb5113 100644 --- a/config/eur/arm9/delinks.txt +++ b/config/eur/arm9/delinks.txt @@ -15,8 +15,11 @@ libs/cpp/src/__register_global_object.cpp: .text start:0x0204f8d4 end:0x0204f8f4 .bss start:0x02076da8 end:0x02076dac -src/Main/BmgRelatedFunctions.cpp: +src/Main/Message/BmgRelatedFunctions.cpp: .text start:0x0202d3bc end:0x0202d56c -src/Main/BMG.cpp: - .text start:0x02036c50 end:0x0203744c +src/Main/Message/MessageManager.cpp: + .text start:0x02036c50 end:0x020371b0 + +src/Main/Message/BMG.cpp: + .text start:0x020371b0 end:0x0203744c diff --git a/config/eur/arm9/symbols.txt b/config/eur/arm9/symbols.txt index 96f4d244..74290a74 100644 --- a/config/eur/arm9/symbols.txt +++ b/config/eur/arm9/symbols.txt @@ -1305,7 +1305,7 @@ func_0202aaa8 kind:function(arm,size=0x40) addr:0x202aaa8 func_0202aae8 kind:function(thumb,size=0x10) addr:0x202aae8 func_0202aaf8 kind:function(thumb,size=0x40) addr:0x202aaf8 _Z13func_0202ab38Pj kind:function(thumb,size=0x10) addr:0x202ab38 -func_0202ab48 kind:function(thumb,size=0x4) addr:0x202ab48 +_Z13func_0202ab48v kind:function(thumb,size=0x4) addr:0x202ab48 func_0202ab4c kind:function(thumb,size=0x8) addr:0x202ab4c func_0202ab54 kind:function(thumb,size=0x10) addr:0x202ab54 func_0202ab64 kind:function(thumb,size=0x14) addr:0x202ab64 @@ -1802,24 +1802,24 @@ func_020367dc kind:function(arm,size=0x10) addr:0x20367dc func_020367ec kind:function(arm,size=0x1c) addr:0x20367ec func_02036808 kind:function(arm,size=0x1c) addr:0x2036808 _Z13func_02036824v kind:function(arm,size=0x2c) addr:0x2036824 -_Z13func_02036850P15Struct_027E0C68 kind:function(arm,size=0x38) addr:0x2036850 +_ZN18UnkStruct_027E0C6813func_02036850Ev kind:function(arm,size=0x38) addr:0x2036850 func_02036888 kind:function(arm,size=0x6c) addr:0x2036888 func_020368f4 kind:function(arm,size=0x18) addr:0x20368f4 func_0203690c kind:function(arm,size=0x2b0) addr:0x203690c func_02036bbc kind:function(arm,size=0x94) addr:0x2036bbc func_02036c50 kind:function(arm,size=0x54) addr:0x2036c50 func_02036ca4 kind:function(arm,size=0x40) addr:0x2036ca4 -_Z13func_02036ce4P15Struct_027E0C68P22Struct_027E0C68_unk_18i kind:function(arm,size=0x4c) addr:0x2036ce4 -func_02036d30 kind:function(arm,size=0x1c) addr:0x2036d30 -func_02036d4c kind:function(arm,size=0x20) addr:0x2036d4c -func_02036d6c kind:function(arm,size=0x3c) addr:0x2036d6c +_ZN18UnkStruct_027E0C6813func_02036ce4EP22Struct_027E0C68_unk_18i kind:function(arm,size=0x4c) addr:0x2036ce4 +_ZN18UnkStruct_027E0C6813func_02036d30Ei kind:function(arm,size=0x1c) addr:0x2036d30 +_ZN18UnkStruct_027E0C6813func_02036d4cEi kind:function(arm,size=0x20) addr:0x2036d4c +_ZN18UnkStruct_027E0C6813func_02036d6cEv kind:function(arm,size=0x3c) addr:0x2036d6c func_02036da8 kind:function(arm,size=0x134) addr:0x2036da8 -func_02036edc kind:function(arm,size=0x8c) addr:0x2036edc -func_02036f68 kind:function(arm,size=0x168) addr:0x2036f68 -_Z13func_020370d0P15Struct_027E0C68ii kind:function(arm,size=0x18) addr:0x20370d0 -_Z13func_020370e8P15Struct_027E0C68issi kind:function(arm,size=0x70) addr:0x20370e8 -_Z13func_02037158P15Struct_027E0C68j kind:function(arm,size=0x20) addr:0x2037158 -_Z13func_02037178P15Struct_027E0C68j kind:function(arm,size=0x38) addr:0x2037178 +_ZN18UnkStruct_027E0C6813func_02036edcEjh kind:function(arm,size=0x8c) addr:0x2036edc +_ZN18UnkStruct_027E0C6813func_02036f68EjPh kind:function(arm,size=0x168) addr:0x2036f68 +_ZN18UnkStruct_027E0C6813func_020370d0Eii kind:function(arm,size=0x18) addr:0x20370d0 +_ZN18UnkStruct_027E0C6813func_020370e8Eissi kind:function(arm,size=0x70) addr:0x20370e8 +_ZN18UnkStruct_027E0C6813func_02037158EP22Struct_027E0C68_unk_28 kind:function(arm,size=0x20) addr:0x2037158 +_ZN18UnkStruct_027E0C6813func_02037178EP22Struct_027E0C68_unk_28 kind:function(arm,size=0x38) addr:0x2037178 _Z13func_020371b0v kind:function(arm,size=0x4) addr:0x20371b0 _Z13func_020371b4P11BMGFileInfo kind:function(thumb,size=0x14) addr:0x20371b4 _Z13func_020371c8P11BMGFileInfoPjs kind:function(thumb,size=0x90) addr:0x20371c8 @@ -1878,7 +1878,7 @@ func_02038b08 kind:function(thumb,size=0x14) addr:0x2038b08 func_02038b1c kind:function(thumb,size=0xc) addr:0x2038b1c func_02038b28 kind:function(thumb,size=0xc) addr:0x2038b28 func_02038b34 kind:function(arm,size=0xc) addr:0x2038b34 -func_02038b40 kind:function(arm,size=0x34) addr:0x2038b40 +_Z13func_02038b40P22Struct_027E0C68_unk_28 kind:function(arm,size=0x34) addr:0x2038b40 func_02038b74 kind:function(arm,size=0x4) addr:0x2038b74 func_02038b78 kind:function(arm,size=0xbc) addr:0x2038b78 func_02038c34 kind:function(arm,size=0x84) addr:0x2038c34 diff --git a/config/usa/arm9/symbols.txt b/config/usa/arm9/symbols.txt index 30f06274..4535de5e 100644 --- a/config/usa/arm9/symbols.txt +++ b/config/usa/arm9/symbols.txt @@ -1305,7 +1305,7 @@ func_0202aaa8 kind:function(arm,size=0x40) addr:0x202aaa8 func_0202aae8 kind:function(thumb,size=0x10) addr:0x202aae8 func_0202aaf8 kind:function(thumb,size=0x28) addr:0x202aaf8 _Z13func_0202ab38Pj kind:function(thumb,size=0x10) addr:0x202ab20 -func_0202ab48 kind:function(thumb,size=0x4) addr:0x202ab30 +_Z13func_0202ab48v kind:function(thumb,size=0x4) addr:0x202ab30 func_0202ab4c kind:function(thumb,size=0x8) addr:0x202ab34 func_0202ab54 kind:function(thumb,size=0x10) addr:0x202ab3c func_0202ab64 kind:function(thumb,size=0x14) addr:0x202ab4c @@ -1802,24 +1802,24 @@ func_020367dc kind:function(arm,size=0x10) addr:0x2036798 func_020367ec kind:function(arm,size=0x1c) addr:0x20367a8 func_02036808 kind:function(arm,size=0x1c) addr:0x20367c4 _Z13func_02036824v kind:function(arm,size=0x2c) addr:0x20367e0 -_Z13func_02036850P15Struct_027E0C68 kind:function(arm,size=0x38) addr:0x203680c +_ZN18UnkStruct_027E0C6813func_02036850Ev kind:function(arm,size=0x38) addr:0x203680c func_02036888 kind:function(arm,size=0x6c) addr:0x2036844 func_020368f4 kind:function(arm,size=0x18) addr:0x20368b0 func_0203690c kind:function(arm,size=0x2b0) addr:0x20368c8 func_02036bbc kind:function(arm,size=0x94) addr:0x2036b78 func_02036c50 kind:function(arm,size=0x54) addr:0x2036c0c func_02036ca4 kind:function(arm,size=0x40) addr:0x2036c60 -_Z13func_02036ce4P15Struct_027E0C68P22Struct_027E0C68_unk_18i kind:function(arm,size=0x4c) addr:0x2036ca0 -func_02036d30 kind:function(arm,size=0x1c) addr:0x2036cec -func_02036d4c kind:function(arm,size=0x20) addr:0x2036d08 -func_02036d6c kind:function(arm,size=0x3c) addr:0x2036d28 +_ZN18UnkStruct_027E0C6813func_02036ce4EP22Struct_027E0C68_unk_18i kind:function(arm,size=0x4c) addr:0x2036ca0 +_ZN18UnkStruct_027E0C6813func_02036d30Ei kind:function(arm,size=0x1c) addr:0x2036cec +_ZN18UnkStruct_027E0C6813func_02036d4cEi kind:function(arm,size=0x20) addr:0x2036d08 +_ZN18UnkStruct_027E0C6813func_02036d6cEv kind:function(arm,size=0x3c) addr:0x2036d28 func_02036da8 kind:function(arm,size=0x134) addr:0x2036d64 -func_02036edc kind:function(arm,size=0x8c) addr:0x2036e98 -func_02036f68 kind:function(arm,size=0x168) addr:0x2036f24 -_Z13func_020370d0P15Struct_027E0C68ii kind:function(arm,size=0x18) addr:0x203708c -_Z13func_020370e8P15Struct_027E0C68issi kind:function(arm,size=0x70) addr:0x20370a4 -_Z13func_02037158P15Struct_027E0C68j kind:function(arm,size=0x20) addr:0x2037114 -_Z13func_02037178P15Struct_027E0C68j kind:function(arm,size=0x38) addr:0x2037134 +_ZN18UnkStruct_027E0C6813func_02036edcEjh kind:function(arm,size=0x8c) addr:0x2036e98 +_ZN18UnkStruct_027E0C6813func_02036f68EjPh kind:function(arm,size=0x168) addr:0x2036f24 +_ZN18UnkStruct_027E0C6813func_020370d0Eii kind:function(arm,size=0x18) addr:0x203708c +_ZN18UnkStruct_027E0C6813func_020370e8Eissi kind:function(arm,size=0x70) addr:0x20370a4 +_ZN18UnkStruct_027E0C6813func_02037158EP22Struct_027E0C68_unk_28 kind:function(arm,size=0x20) addr:0x2037114 +_ZN18UnkStruct_027E0C6813func_02037178EP22Struct_027E0C68_unk_28 kind:function(arm,size=0x38) addr:0x2037134 _Z13func_020371b0v kind:function(arm,size=0x4) addr:0x203716c _Z13func_020371b4P11BMGFileInfo kind:function(thumb,size=0x14) addr:0x2037170 _Z13func_020371c8P11BMGFileInfoPjs kind:function(thumb,size=0x90) addr:0x2037184 @@ -1878,7 +1878,7 @@ func_02038b08 kind:function(thumb,size=0x14) addr:0x2038ac4 func_02038b1c kind:function(thumb,size=0xc) addr:0x2038ad8 func_02038b28 kind:function(thumb,size=0xc) addr:0x2038ae4 func_02038b34 kind:function(arm,size=0xc) addr:0x2038af0 -func_02038b40 kind:function(arm,size=0x34) addr:0x2038afc +_Z13func_02038b40P22Struct_027E0C68_unk_28 kind:function(arm,size=0x34) addr:0x2038afc func_02038b74 kind:function(arm,size=0x4) addr:0x2038b30 func_02038b78 kind:function(arm,size=0xbc) addr:0x2038b34 func_02038c34 kind:function(arm,size=0x84) addr:0x2038bf0 diff --git a/include/Message/BMG.hpp b/include/Message/BMG.hpp index 08c7a7fa..4af7ccb7 100644 --- a/include/Message/BMG.hpp +++ b/include/Message/BMG.hpp @@ -173,7 +173,9 @@ typedef struct BMGGroups { /* 0x04 */ s32 numEntries; } BMGGroups; // size = 0x8 +typedef void (*Struct_027E0C68_unk_28_unk_50)(struct Struct_027E0C68_unk_28*, EntryINF1*, int, u8*); typedef void (*Struct_027E0C68_unk_28_unk_58)(struct Struct_027E0C68_unk_28*); +typedef void (*Struct_027E0C68_unk_18_unk_08)(struct Struct_027E0C68_unk_18*); typedef struct Struct_027E0C68_unk_28_unk_00 { /* 0x00 */ unk32 unk_00; @@ -196,22 +198,30 @@ typedef struct Struct_027E0C68_unk_28_unk_00 { /* 0x44 */ unk32 unk_44; /* 0x48 */ unk32 unk_48; /* 0x4C */ unk32 unk_4C; - /* 0x50 */ unk32 unk_50; + /* 0x50 */ Struct_027E0C68_unk_28_unk_50 unk_50; /* 0x54 */ unk32 unk_54; /* 0x58 */ Struct_027E0C68_unk_28_unk_58 unk_58; /* 0x5C */ unk32 unk_5C; } Struct_027E0C68_unk_28_unk_00; +//! TODO: this should be a class typedef struct Struct_027E0C68_unk_28 { /* 0x00 */ Struct_027E0C68_unk_28_unk_00* unk_00; - /* 0x04 */ unk32 unk_04; - /* 0x08 */ unk32 unk_08; + /* 0x04 */ struct Struct_027E0C68_unk_28* unk_04; + /* 0x08 */ struct Struct_027E0C68_unk_28* unk_08; /* 0x0C */ unk32 unk_0C; } Struct_027E0C68_unk_28; -typedef struct Struct_027E0C68_unk_18 { +typedef struct Struct_027E0C68_unk_18_unk_00 { /* 0x00 */ unk32 unk_00; /* 0x04 */ unk32 unk_04; + /* 0x08 */ Struct_027E0C68_unk_18_unk_08 unk_08; + /* 0x0C */ unk32 unk_0C; +} Struct_027E0C68_unk_18_unk_00; + +typedef struct Struct_027E0C68_unk_18 { + /* 0x00 */ Struct_027E0C68_unk_18_unk_00* unk_00; + /* 0x04 */ unk32 unk_04; /* 0x08 */ unk32 unk_08; /* 0x0C */ unk32 unk_0C; /* 0x10 */ unk32 unk_10; @@ -235,8 +245,10 @@ typedef struct Struct_027E0C68_unk_18 { typedef struct Struct_027E0C68 { /* 0x00 */ unk16 unk_00; /* 0x02 */ unk16 unk_02; - /* 0x04 */ unk32 unk_04; - /* 0x08 */ unk32 unk_08; + /* 0x04 */ u8 unk_04; + /* 0x05 */ u8 unk_05; + /* 0x06 */ unk16 unk_06; + /* 0x08 */ Struct_027E0C68_unk_28* unk_08; /* 0x0C */ unk32 unk_0C; /* 0x10 */ unk32 unk_10; /* 0x14 */ BMGGroups* pGroups; @@ -247,5 +259,8 @@ typedef struct Struct_027E0C68 { /* 0x28 */ Struct_027E0C68_unk_28* unk_28[6]; // 022172B0 } Struct_027E0C68; -Struct_027E0C68_unk_18* func_020370e8(Struct_027E0C68* param_1, unk32 param_2, unk16 param_3, unk16 param_4, unk32 param_5); -Struct_027E0C68_unk_28* func_02037178(Struct_027E0C68* param_1, u32 param_2); +extern Struct_027E0C68_unk_28* func_02036f68(Struct_027E0C68 *param_1, u32 param_2, u8* param_3); +extern Struct_027E0C68_unk_18* func_020370e8(Struct_027E0C68* param_1, unk32 param_2, unk16 param_3, unk16 param_4, unk32 param_5); +extern Struct_027E0C68_unk_28* func_02037178(Struct_027E0C68* param_1, u32 param_2); +extern EntryINF1* func_02037258(BMGFileInfo* pFileInfo, unk32 param_2); +extern u32 func_020373ec(BMGGroups* pGroups, unk32 param_2); diff --git a/include/Message/MessageManager.hpp b/include/Message/MessageManager.hpp new file mode 100644 index 00000000..4151991b --- /dev/null +++ b/include/Message/MessageManager.hpp @@ -0,0 +1,37 @@ +#pragma once + +#include "global.h" +#include "types.h" + +#include "Message/BMG.hpp" + +class UnkStruct_027E0C68 { +private: + /* 0x00 */ unk16 unk_00; + /* 0x02 */ unk16 unk_02; + /* 0x04 */ u8 unk_04; + /* 0x05 */ u8 unk_05; + /* 0x06 */ unk16 unk_06; + /* 0x08 */ Struct_027E0C68_unk_28* unk_08; + /* 0x0C */ unk32 unk_0C; + /* 0x10 */ unk32 unk_10; + /* 0x14 */ BMGGroups* pGroups; + /* 0x18 */ Struct_027E0C68_unk_18* unk_18; + /* 0x1C */ Struct_027E0C68_unk_18* unk_1C; + /* 0x20 */ unk32 unk_20; + /* 0x24 */ unk32 unk_24; + /* 0x28 */ Struct_027E0C68_unk_28* unk_28[6]; // 022172B0 + +public: + s32 func_02036850(void); + s32 func_02036ce4(Struct_027E0C68_unk_18* param_2, unk32 param_3); + unk32 func_02036d30(unk32 param_2); + unk32 func_02036d4c(unk32 param_2); + void func_02036d6c(void); + void func_02036edc(u32 param_2, u8 param_3); + Struct_027E0C68_unk_28* func_02036f68(u32 param_2, u8* param_3); + Struct_027E0C68_unk_18* func_020370d0(unk32 param_2, unk32 param_3); + Struct_027E0C68_unk_18* func_020370e8(unk32 param_2, unk16 param_3, unk16 param_4, unk32 param_5); + void func_02037158(Struct_027E0C68_unk_28* param_2); + Struct_027E0C68_unk_28* func_02037178(Struct_027E0C68_unk_28* param_2); +}; diff --git a/src/Main/BMG.cpp b/src/Main/Message/BMG.cpp similarity index 79% rename from src/Main/BMG.cpp rename to src/Main/Message/BMG.cpp index e6cf6808..830fccba 100644 --- a/src/Main/BMG.cpp +++ b/src/Main/Message/BMG.cpp @@ -48,66 +48,6 @@ static char* sBMGFileNames[BMG_FILE_INDEX_MAX] = { "kaitei_F", // BMG_FILE_INDEX_KAITEI_F }; -s32 func_02036824(void); -s32 func_02036850(Struct_027E0C68*); - -ARM s32 func_02036ce4(Struct_027E0C68*, Struct_027E0C68_unk_18*, unk32) { - // TODO -} - -ARM Struct_027E0C68_unk_18* func_020370d0(Struct_027E0C68* param_1, unk32 param_2, unk32 param_3) { - return func_020370e8(param_1, param_2, -1, -1, param_3); -} - -ARM Struct_027E0C68_unk_18* func_020370e8(Struct_027E0C68* param_1, unk32 param_2, unk16 param_3, unk16 param_4, unk32 param_5) { - Struct_027E0C68_unk_18* puVar2; - - if (func_02036824() != 0) { - puVar2 = param_1->unk_18; - } else { - if (func_02036850(param_1) != 0) { - puVar2 = param_1->unk_1C; - } else { - return NULL; - } - } - - puVar2->unk_30 = param_5; - puVar2->unk_34 = param_3; - puVar2->unk_36 = param_4; - - if (func_02036ce4(param_1, puVar2, param_2) != 0) { - return puVar2; - } - - return NULL; -} - -ARM void func_02037158(Struct_027E0C68* param_1, u32 param_2) { - Struct_027E0C68_unk_28* pSVar1; - - pSVar1 = func_02037178(param_1, param_2); - - if (pSVar1 != NULL) { - pSVar1->unk_00->unk_58(pSVar1); - } -} - -ARM Struct_027E0C68_unk_28* func_02037178(Struct_027E0C68* param_1, u32 param_2) { - Struct_027E0C68_unk_28* piVar1; - s32 iVar2; - - for (iVar2 = 0; iVar2 < ARRAY_LEN(param_1->unk_28); iVar2++) { - piVar1 = param_1->unk_28[iVar2]; - - if (piVar1 != NULL && piVar1->unk_08 == param_2) { - return piVar1; - } - } - - return NULL; -} - ARM void func_020371b0(void) { } diff --git a/src/Main/BmgRelatedFunctions.cpp b/src/Main/Message/BmgRelatedFunctions.cpp similarity index 100% rename from src/Main/BmgRelatedFunctions.cpp rename to src/Main/Message/BmgRelatedFunctions.cpp diff --git a/src/Main/Message/MessageManager.cpp b/src/Main/Message/MessageManager.cpp new file mode 100644 index 00000000..7413e15c --- /dev/null +++ b/src/Main/Message/MessageManager.cpp @@ -0,0 +1,174 @@ +#include "Message/MessageManager.hpp" + +s32 func_02036824(void); +unk32 func_ov000_020d7f18(u32*, unk32); +unk32 func_ov000_020d77e4(u32*, unk32); +unk32 func_02037628(u8*); +THUMB unk32 func_0202ab48(void); +ARM void func_02038b40(Struct_027E0C68_unk_28*); + +// see Actor.cpp +struct UnkStruct2 { + /* 0 */ u32 mUnk_0; + /* 4 */ u32 mUnk_4; + /* 8 */ +}; +extern UnkStruct2 data_027e077c; +extern u32 data_ov000_020eec9c[]; +extern u8 data_02056be4[]; + +ARM s32 UnkStruct_027E0C68::func_02036ce4(Struct_027E0C68_unk_18* param_2, unk32 param_3) { + if (param_3 == 0) { + return 0; + } + + if (func_020373ec(this->pGroups,param_3) != -1) { + param_2->unk_00->unk_08(param_2); + return 1; + } + + return 0; +} + +ARM unk32 UnkStruct_027E0C68::func_02036d30(unk32 param_2) { + if (this->unk_20 == 0 || this->unk_20 == param_2) { + this->unk_20 = param_2; + return 1; + } + + return 0; +} + +ARM unk32 UnkStruct_027E0C68::func_02036d4c(unk32 param_2) { + if (this->unk_20 == param_2) { + this->unk_20 = 0; + return 1; + } + + return 0; +} + +ARM void UnkStruct_027E0C68::func_02036d6c(void) { + s32 i; + + for (i = 0; i < ARRAY_LEN(this->unk_28); i++) { + if (func_0202ab48() == 0 || i != 5) { + func_02038b40(this->unk_28[i]); + } + } +} + +ARM void UnkStruct_027E0C68::func_02036edc(u32 param_2, u8 param_3) { + Struct_027E0C68_unk_28 *pSVar1; + u8 auStack_28[24]; + u8 local_13; + + func_02037628(auStack_28); + local_13 = 0; + + if ((data_02056be4[data_027e077c.mUnk_0] & 1) != 0 && (data_02056be4[data_027e077c.mUnk_0] & 2) == 0) { + local_13 = 1; + } + + auStack_28[21] = local_13; + auStack_28[20] = param_3; + pSVar1 = this->func_02036f68(param_2, auStack_28); + + if (pSVar1 != NULL) { + if (this->unk_04 == 0) { + this->unk_08 = pSVar1; + } + } +} + +ARM Struct_027E0C68_unk_28* UnkStruct_027E0C68::func_02036f68(u32 param_2, u8* param_3) { + EntryINF1 *pEVar1; + Struct_027E0C68_unk_28 *pSVar2; + EntryINF1 *pEVar3; + int iVar4; + Struct_027E0C68_unk_28 *pSVar5; + BMGGroups *pBVar6; + + pEVar1 = func_02037258(&this->pGroups->entries[param_2 >> 0x10], param_2 & 0xffff); + + if (pEVar1 == NULL) { + return NULL; + } + + if (param_3[21] != 0) { + pSVar5 = this->unk_28[2]; + pSVar2 = this->unk_28[3]; + } else { + pSVar5 = this->unk_28[0]; + pSVar2 = this->unk_28[1]; + } + + pSVar5[0x16].unk_04 = pSVar2; + pSVar5[0x41].unk_08 = this->unk_28[5]; + pBVar6 = this->pGroups; + pEVar3 = func_02037258(&pBVar6->entries[param_2 >> 0x10], param_2 & 0xffff); + + pSVar5->unk_00->unk_50(pSVar5, pEVar1, (int)&((pBVar6->entries[param_2 >> 0x10].pDAT1)->base).tag + (pEVar3->offset & 0xfffffffe), param_3); + + if (func_ov000_020d7f18(data_ov000_020eec9c, 0x19) == 0 && func_ov000_020d7f18(data_ov000_020eec9c, 0x18) == 0 && + func_ov000_020d7f18(data_ov000_020eec9c, 0x34) == 0 && func_ov000_020d7f18(data_ov000_020eec9c, 0x35) == 0 && + func_ov000_020d7f18(data_ov000_020eec9c, 0x1A) == 0 && func_ov000_020d7f18(data_ov000_020eec9c, 0x1B) == 0 && + (param_3[12]) != 7) { + func_ov000_020d77e4(data_ov000_020eec9c, 0x1C); + } + + return pSVar5; +} + +ARM Struct_027E0C68_unk_18* UnkStruct_027E0C68::func_020370d0(unk32 param_2, unk32 param_3) { + return this->func_020370e8(param_2, -1, -1, param_3); +} + +ARM Struct_027E0C68_unk_18* UnkStruct_027E0C68::func_020370e8(unk32 param_2, unk16 param_3, unk16 param_4, unk32 param_5) { + Struct_027E0C68_unk_18* puVar2; + + if (func_02036824() != 0) { + puVar2 = this->unk_18; + } else { + if (this->func_02036850() != 0) { + puVar2 = this->unk_1C; + } else { + return NULL; + } + } + + puVar2->unk_30 = param_5; + puVar2->unk_34 = param_3; + puVar2->unk_36 = param_4; + + if (this->func_02036ce4(puVar2, param_2) != 0) { + return puVar2; + } + + return NULL; +} + +ARM void UnkStruct_027E0C68::func_02037158(Struct_027E0C68_unk_28* param_2) { + Struct_027E0C68_unk_28* pSVar1; + + pSVar1 = this->func_02037178(param_2); + + if (pSVar1 != NULL) { + pSVar1->unk_00->unk_58(pSVar1); + } +} + +ARM Struct_027E0C68_unk_28* UnkStruct_027E0C68::func_02037178(Struct_027E0C68_unk_28* param_2) { + Struct_027E0C68_unk_28* piVar1; + s32 iVar2; + + for (iVar2 = 0; iVar2 < ARRAY_LEN(this->unk_28); iVar2++) { + piVar1 = this->unk_28[iVar2]; + + if (piVar1 != NULL && piVar1->unk_08 == param_2) { + return piVar1; + } + } + + return NULL; +}