sub_800C12C

This commit is contained in:
PikalaxALT
2017-11-18 20:55:57 -05:00
parent 728532be77
commit bd30e5aa24
5 changed files with 59 additions and 126 deletions
-8
View File
@@ -3,14 +3,6 @@
#include "librfu.h"
extern struct RfuUnk5 *gUnknown_03007890;
extern u32 *gUnknown_03007894;
extern struct RfuUnk3* gUnknown_03007898;
extern struct RfuUnk2* gUnknown_03007880[4];
extern struct RfuUnk1* gUnknown_03007870[4];
extern void* sub_82E53F4;
extern void rfu_STC_clearAPIVariables(void);
// Nonmatching, only register differences
/*u16 rfu_initializeAPI(u32 *unk0, u16 unk1, IntrFunc *interrupt, bool8 copyInterruptToRam)
{
+50
View File
@@ -191,3 +191,53 @@ u8 sub_800C054(u8 r5, u16 r7, u16 r8, u16 *r6)
gUnknown_03004140.unk_20 = r6;
return 0;
}
u8 sub_800C12C(u16 r6, u16 r8)
{
u8 i;
struct RfuUnk5 *tmp;
if (gUnknown_03004140.unk_04 != 0 && (gUnknown_03004140.unk_04 < 9 || gUnknown_03004140.unk_04 > 11))
{
gUnknown_03004140.unk_14 = 1;
sub_800D30C(0xF3, 0x01);
return 1;
}
if (!rfu_getMasterSlave())
{
gUnknown_03004140.unk_14 = 2;
sub_800D30C(0xF3, 0x01);
return 2;
}
for (i = 0; i < gUnknown_03007890->unk_08; i ++)
{
tmp = &gUnknown_03007890[i];
if (tmp->unk_14 == r6)
{
break;
}
}
if (gUnknown_03007890->unk_08 == 0 || i == gUnknown_03007890->unk_08)
{
gUnknown_03004140.unk_14 = 3;
sub_800D30C(0xF3, 0x01);
return 3;
}
if (gUnknown_03004140.unk_04 == 0 || gUnknown_03004140.unk_04 == 9)
{
gUnknown_03004140.unk_04 = 12;
gUnknown_03004140.unk_05 = 13;
}
else
{
gUnknown_03004140.unk_04 = 11;
gUnknown_03004140.unk_05 = 12;
}
gUnknown_03004140.unk_1e = r6;
gUnknown_03004140.unk_1a = r8;
if (gUnknown_03004140.unk_07 != 0)
{
gUnknown_03004140.unk_07 = 7;
}
return 0;
}