Merge pull request #7 from gamemasterplc/main

Decompile subchrdll.rel
This commit is contained in:
gamemasterplc 2023-11-23 12:22:44 -06:00 committed by GitHub
commit 072bbc5309
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 240 additions and 91 deletions

View file

@ -5,3 +5,12 @@ Sections:
.rodata type:rodata align:8
.data type:data align:8
.bss type:bss align:8
REL/executor.c:
.text start:0x00000000 end:0x000000A0
REL/subchrselDll/subchrselDll.c:
.text start:0x000000A0 end:0x000007B8
.rodata start:0x00000000 end:0x00000018
.data start:0x00000000 end:0x000000E1
.bss start:0x00000000 end:0x00000004

View file

@ -1,33 +1,33 @@
_prolog = .text:0x00000000; // type:function size:0x54 scope:global
_epilog = .text:0x00000054; // type:function size:0x4C scope:global
fn_1_A0 = .text:0x000000A0; // type:function size:0x6C
fn_1_10C = .text:0x0000010C; // type:function size:0x58
fn_1_164 = .text:0x00000164; // type:function size:0x654
ModuleProlog = .text:0x000000A0; // type:function size:0x6C
GetBtns = .text:0x0000010C; // type:function size:0x58 scope:local
SubchrMain = .text:0x00000164; // type:function size:0x654 scope:local
_ctors = .ctors:0x00000000; // type:label scope:global data:4byte
_dtors = .dtors:0x00000000; // type:label scope:global data:4byte
lbl_1_rodata_10 = .rodata:0x00000010; // type:object size:0x4 data:float
lbl_1_rodata_14 = .rodata:0x00000014; // type:object size:0x4 data:float
lbl_1_data_0 = .data:0x00000000; // type:object size:0x8 data:string
lbl_1_data_8 = .data:0x00000008; // type:object size:0x8 data:string
lbl_1_data_10 = .data:0x00000010; // type:object size:0x8 data:string
lbl_1_data_18 = .data:0x00000018; // type:object size:0x8 data:string
lbl_1_data_20 = .data:0x00000020; // type:object size:0x10
lbl_1_data_30 = .data:0x00000030; // type:object size:0x6 data:string
lbl_1_data_36 = .data:0x00000036; // type:object size:0x6 data:string
lbl_1_data_3C = .data:0x0000003C; // type:object size:0x6 data:string
lbl_1_data_42 = .data:0x00000042; // type:object size:0x6 data:string
lbl_1_data_48 = .data:0x00000048; // type:object size:0x6 data:string
lbl_1_data_4E = .data:0x0000004E; // type:object size:0x7 data:string
lbl_1_data_55 = .data:0x00000055; // type:object size:0x6 data:string
lbl_1_data_5B = .data:0x0000005B; // type:object size:0x9
lbl_1_data_64 = .data:0x00000064; // type:object size:0x20
lbl_1_data_84 = .data:0x00000084; // type:object size:0x1
lbl_1_data_85 = .data:0x00000085; // type:object size:0x6 data:string
lbl_1_data_8B = .data:0x0000008B; // type:object size:0x8 data:string
lbl_1_data_93 = .data:0x00000093; // type:object size:0x7 data:string
lbl_1_data_9A = .data:0x0000009A; // type:object size:0x7 data:string
lbl_1_data_A1 = .data:0x000000A1; // type:object size:0x6 data:string
lbl_1_data_A7 = .data:0x000000A7; // type:object size:0x9
lbl_1_data_B0 = .data:0x000000B0; // type:object size:0x1C
lbl_1_data_CC = .data:0x000000CC; // type:object size:0x15 data:string
lbl_1_bss_0 = .bss:0x00000000; // type:object size:0x4 data:byte
lbl_1_rodata_10 = .rodata:0x00000010; // type:object size:0x4 scope:local data:float
lbl_1_rodata_14 = .rodata:0x00000014; // type:object size:0x4 scope:local data:float
lbl_1_data_0 = .data:0x00000000; // type:object size:0x8 scope:local data:string
lbl_1_data_8 = .data:0x00000008; // type:object size:0x8 scope:local data:string
lbl_1_data_10 = .data:0x00000010; // type:object size:0x8 scope:local data:string
lbl_1_data_18 = .data:0x00000018; // type:object size:0x8 scope:local data:string
player_numstr = .data:0x00000020; // type:object size:0x10 scope:local
lbl_1_data_30 = .data:0x00000030; // type:object size:0x6 scope:local data:string
lbl_1_data_36 = .data:0x00000036; // type:object size:0x6 scope:local data:string
lbl_1_data_3C = .data:0x0000003C; // type:object size:0x6 scope:local data:string
lbl_1_data_42 = .data:0x00000042; // type:object size:0x6 scope:local data:string
lbl_1_data_48 = .data:0x00000048; // type:object size:0x6 scope:local data:string
lbl_1_data_4E = .data:0x0000004E; // type:object size:0x7 scope:local data:string
lbl_1_data_55 = .data:0x00000055; // type:object size:0x6 scope:local data:string
lbl_1_data_5B = .data:0x0000005B; // type:object size:0x9 scope:local
character_str = .data:0x00000064; // type:object size:0x20 scope:local
lbl_1_data_84 = .data:0x00000084; // type:object size:0x1 scope:local
lbl_1_data_85 = .data:0x00000085; // type:object size:0x6 scope:local data:string
lbl_1_data_8B = .data:0x0000008B; // type:object size:0x8 scope:local data:string
lbl_1_data_93 = .data:0x00000093; // type:object size:0x7 scope:local data:string
lbl_1_data_9A = .data:0x0000009A; // type:object size:0x7 scope:local data:string
lbl_1_data_A1 = .data:0x000000A1; // type:object size:0x6 scope:local data:string
lbl_1_data_A7 = .data:0x000000A7; // type:object size:0x9 scope:local
ext_character_str = .data:0x000000B0; // type:object size:0x1C scope:local
lbl_1_data_CC = .data:0x000000CC; // type:object size:0x15 scope:local data:string
lbl_1_bss_0 = .bss:0x00000000; // type:object size:0x4 scope:local data:byte

View file

@ -511,8 +511,8 @@ fn_8002EA6C = .text:0x8002EA6C; // type:function size:0x16C
fn_8002EBD8 = .text:0x8002EBD8; // type:function size:0x90
fn_8002EC68 = .text:0x8002EC68; // type:function size:0x170
fn_8002EDD8 = .text:0x8002EDD8; // type:function size:0xE8
fn_8002EEC0 = .text:0x8002EEC0; // type:function size:0x60
fn_8002EF20 = .text:0x8002EF20; // type:function size:0xF4
omOvlGotoEx = .text:0x8002EEC0; // type:function size:0x60
omOvlReturnEx = .text:0x8002EF20; // type:function size:0xF4
fn_8002F014 = .text:0x8002F014; // type:function size:0xB8
omOvlHisChg = .text:0x8002F0CC; // type:function size:0xA0
omOvlHisGet = .text:0x8002F16C; // type:function size:0x78
@ -728,7 +728,7 @@ fn_80040D60 = .text:0x80040D60; // type:function size:0x36C
fn_800410CC = .text:0x800410CC; // type:function size:0xA4
fn_80041170 = .text:0x80041170; // type:function size:0xB4
fn_80041224 = .text:0x80041224; // type:function size:0x288
fn_800414AC = .text:0x800414AC; // type:function size:0x12C
WipeCreate = .text:0x800414AC; // type:function size:0x12C
fn_800415D8 = .text:0x800415D8; // type:function size:0x28
fn_80041600 = .text:0x80041600; // type:function size:0x10
fn_80041610 = .text:0x80041610; // type:function size:0x8
@ -5400,7 +5400,7 @@ lbl_8018F790 = .bss:0x8018F790; // type:object size:0x370
lbl_8018FB00 = .bss:0x8018FB00; // type:object size:0x38
lbl_8018FB38 = .bss:0x8018FB38; // type:object size:0xC0
lbl_8018FBF8 = .bss:0x8018FBF8; // type:object size:0x18
lbl_8018FC10 = .bss:0x8018FC10; // type:object size:0x28
gPlayerConfig = .bss:0x8018FC10; // type:object size:0x28
gPlayerData = .bss:0x8018FC38; // type:object size:0xC0 data:byte
lbl_8018FCF8 = .bss:0x8018FCF8; // type:object size:0xE0 data:byte
lbl_8018FDD8 = .bss:0x8018FDD8; // type:object size:0x230
@ -5419,8 +5419,8 @@ lbl_80190E60 = .bss:0x80190E60; // type:object size:0x1200 data:4byte
lbl_80192060 = .bss:0x80192060; // type:object size:0x100
lbl_80192160 = .bss:0x80192160; // type:object size:0x100
lbl_80192260 = .bss:0x80192260; // type:object size:0x100
lbl_80192360 = .bss:0x80192360; // type:object size:0x60 data:4byte
winData = .bss:0x801923C0; // type:object size:0x3000 data:byte
wipeData = .bss:0x80192360; // type:object size:0x60 data:4byte
winData = .bss:0x801923C0; // type:object size:0x3000 align:32 data:byte
lbl_801953C0 = .bss:0x801953C0; // type:object size:0x10
lbl_801953D0 = .bss:0x801953D0; // type:object size:0x1410
lbl_801967E0 = .bss:0x801967E0; // type:object size:0x400 data:byte

View file

@ -176,6 +176,7 @@ cflags_rel = [
"-char unsigned",
"-sdata 0",
"-sdata2 0",
"-pool off",
]
# Game flags
@ -230,6 +231,7 @@ config.libs = [
Object(NonMatching, "game/data.c"),
Object(Matching, "game/decode.c"),
Object(NonMatching, "game/font.c"),
Object(NonMatching, "game/jmp.c"),
Object(Matching, "game/malloc.c"),
Object(Matching, "game/memory.c"),
Object(NonMatching, "game/printfunc.c"),
@ -268,6 +270,16 @@ config.libs = [
Object(Matching, "REL/_minigameDLL/_minigameDLL.c"),
],
},
{
"lib": "subchrselDll",
"mw_version": config.linker_version,
"cflags": cflags_rel,
"host": False,
"objects": [
Object(Matching, "REL/executor.c"),
Object(Matching, "REL/subchrselDll/subchrselDll.c"),
],
},
]
if args.mode == "configure":

View file

@ -43,10 +43,18 @@ typedef struct process {
void *user_data;
} Process;
typedef struct unkStruct1D3B44 {
struct unkStruct1D3B44 *prev;
char unk_04[0x1A];
u16 unk_1E;
} unkStruct1D3B44; // sizeof ???
typedef struct player_config {
s16 character;
s16 pad_idx;
s16 diff;
s16 group;
s16 iscom;
} PlayerConfig;
typedef struct wipe_state {
u8 unk[52];
float duration;
u8 unk2[20];
} WipeState;
#endif

View file

@ -14,7 +14,8 @@ void* omInitObjMan(s32, s32);
void fn_80044920(s16);
void fn_80045F74(s16, s32);
s32 fn_800578E4(void);
void fn_1_26C(void);
void fn_80032A58(int arg0);
void fn_80035A0C(void);
void HuDecodeData(void *src, void *dst, u32 size, int decode_type);
void HuMemInitAll(void);
@ -62,4 +63,10 @@ void HuPrcResetStat(Process *process, u16 value);
void HuPrcAllPause(int flag);
void HuPrcAllUPause(int flag);
void omOvlGotoEx(int id, s16 end_mode, int stat, int event);
void omOvlReturnEx(int level, s16 end_mode);
void WipeCreate(char dir, char type, short duration);
u16 print8(s16 x, s16 y, float scale, char *str, ...);
#endif

View file

@ -1,20 +1,171 @@
#include "subchrselDll.h"
#include "common.h"
void fn_1_A0(void) {
//HACK: Force 0.5 and 3.0 double constants to appear in REL
const double _half = 0.5;
const double _three = 3.0;
extern WipeState wipeData;
extern PlayerConfig gPlayerConfig[4];
extern u16 HuPadBtnDown[4];
extern u8 HuPadDStk[4];
extern int fontcolor;
static void SubchrMain(void);
static u8 cur_direction[4];
static char *player_numstr[4] = {
"PLAYER1",
"PLAYER2",
"PLAYER3",
"PLAYER4"
};
static char *character_str[8] = {
"MARIO",
"LUIGI",
"PEACH",
"YOSHI",
"WARIO",
"DONKEY",
"DAISY",
"WALUIGI"
};
static char *ext_character_str[7] = {
"",
"KOOPA",
"KINOPIO",
"HEIHOH",
"TERESA",
"NOKO2",
"MKOOPA"
};
void ModuleProlog(void)
{
void* sp8 = omInitObjMan(0x32, 0x2000);
Hu3DBGColorSet(0U, 0U, 0U);
fn_8000C760(&fn_1_164, 0x1000, 0x3000, 0, fn_8000CA3C());
fn_800414AC(1, 0, -1);
Hu3DBGColorSet(0, 0, 0);
HuPrcChildCreate(SubchrMain, 4096, 12288, 0, HuPrcCurrentGet());
WipeCreate(1, 0, -1);
}
u16 fn_1_10C(void) {
u16 var_r31;
static u16 GetBtns(void)
{
u16 btns;
var_r31 = lbl_801D3AD0;
if (lbl_1_bss_0 != lbl_801D3AAC) {
var_r31 |= lbl_801D3AAC;
btns = HuPadBtnDown[0];
if (cur_direction[0] != HuPadDStk[0]) {
btns |= HuPadDStk[0];
}
return var_r31;
return btns;
}
// void fn_1_164(void)
static void SubchrMain()
{
int prev_character[4];
int character[4];
int i, cursor_pos;
for(i=0; i<4; i++) {
prev_character[i] = gPlayerConfig[i].character;
character[i] = 0;
cur_direction[i] = 0;
}
cursor_pos = 0;
while(1) {
int y, x;
u16 btns;
fontcolor = 14;
print8(150, 64, 2.0f, "Sub Character Select");
x = 170;
y = 120;
for(i=0; i<4; i++, y += 16) {
fontcolor = 12;
print8(x, y, 2.0f, player_numstr[i]);
if(i == cursor_pos) {
fontcolor = 13;
} else {
fontcolor = 12;
}
if(character[i] != 0) {
print8(x+200, y, 2.0f, ext_character_str[character[i]]);
} else {
print8(x+200, y, 2.0f, character_str[prev_character[i]]);
}
}
if(GetBtns() & 0x1000) {
for(i=0; i<4; i++) {
if(character[i] != 0) {
gPlayerConfig[i]. character = character[i]+7;
}
}
fn_80032A58(30);
WipeCreate(2, 0, -1);
HuPrcSleep(wipeData.duration+1.0f);
fn_80035A0C();
omOvlGotoEx(41, 1, 0, 0);
do {
HuPrcVSleep();
} while(1);
} else {
if(GetBtns() & 0x1) {
do {
character[cursor_pos]--;
if(character[cursor_pos] < 0) {
character[cursor_pos] = 6;
}
for(i=0; i<4; i++) {
if(cursor_pos != i) {
if(character[cursor_pos] == character[i] && character[cursor_pos] != 0) {
break;
}
}
}
} while(i < 4);
}
if(GetBtns() & 0x2) {
do {
character[cursor_pos]++;
if(character[cursor_pos] > 6) {
character[cursor_pos] = 0;
}
for(i=0; i<4; i++) {
if(cursor_pos != i) {
if(character[cursor_pos] == character[i] && character[cursor_pos] != 0) {
break;
}
}
}
} while(i < 4);
}
if(GetBtns() & 0x4) {
cursor_pos++;
}
if(GetBtns() & 0x8) {
cursor_pos--;
}
if(cursor_pos < 0) {
cursor_pos = 3;
}
if(cursor_pos > 3) {
cursor_pos = 0;
}
if(GetBtns() & 0x200) {
fn_80032A58(30);
WipeCreate(2, 0, -1);
HuPrcSleep(wipeData.duration+1.0f);
fn_80035A0C();
omOvlReturnEx(1, 1);
do {
HuPrcVSleep();
} while(1);
} else {
if(cur_direction[0] != HuPadDStk[0]) {
cur_direction[0] = HuPadDStk[0];
}
}
}
HuPrcVSleep();
}
}

View file

@ -1,38 +0,0 @@
#include "common.h"
#include "REL/executor.h"
void fn_8000C760(void*, s32, s32, s32, s32);
s32 fn_8000CA3C();
void fn_800414AC(s16, s16, s16);
extern u8 lbl_1_bss_0;
extern u8 lbl_801D3AAC;
extern u16 lbl_801D3AD0;
typedef struct unkStruct192360 {
char unk_00[0x34];
f32 unk_34;
} unkStruct192360;
s16 fn_8000AFF4(s16, s16, f32, char*, ...); /* extern */
void fn_8000CF0C(s32, f32); /* extern */
void fn_8000CF8C(); /* extern */
void fn_8002EEC0(s32, s16, s32, s32); /* extern */
void fn_8002EF20(s16, s16); /* extern */
void fn_80032A58(s32); /* extern */
void fn_80035A0C(void); /* extern */
void fn_800414AC(s16, s16, s16); /* extern */
extern s32 debugFontColor;
extern u8 lbl_1_bss_0;
extern char *lbl_1_data_20[4];
extern char *lbl_1_data_64[8];
extern char *lbl_1_data_B0[7];
extern char lbl_1_data_CC[20];
extern s16 lbl_8018FC10[];
extern unkStruct192360 lbl_80192360;
extern u8 lbl_801D3AAC;
extern u16 lbl_801D3AD0;
void fn_1_A0(void);
u16 fn_1_10C(void);
void fn_1_164(void);