summaryrefslogtreecommitdiff
path: root/src/link_rfu.c
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2020-02-16 13:49:36 -0500
committerPikalaxALT <pikalaxalt@gmail.com>2020-02-16 13:49:36 -0500
commit91dd7f5cc3ed4c641e02d42397e08877560a7a58 (patch)
tree2d10575a006b8ff1c5527f20065528870f6f3096 /src/link_rfu.c
parentac1738e11dcfc0a574f90b4f4905c2533630eb50 (diff)
Port librfu from firered
Diffstat (limited to 'src/link_rfu.c')
-rw-r--r--src/link_rfu.c5146
1 files changed, 0 insertions, 5146 deletions
diff --git a/src/link_rfu.c b/src/link_rfu.c
deleted file mode 100644
index 9291f574e..000000000
--- a/src/link_rfu.c
+++ /dev/null
@@ -1,5146 +0,0 @@
-#include "global.h"
-#include "malloc.h"
-#include "battle.h"
-#include "berry_blender.h"
-#include "decompress.h"
-#include "event_data.h"
-#include "gpu_regs.h"
-#include "librfu.h"
-#include "link.h"
-#include "link_rfu.h"
-#include "overworld.h"
-#include "random.h"
-#include "palette.h"
-#include "union_room.h"
-#include "string_util.h"
-#include "task.h"
-#include "text.h"
-#include "constants/species.h"
-#include "save.h"
-#include "mystery_gift.h"
-
-extern u16 gHeldKeyCodeToSend;
-
-struct UnkRfuStruct_1 gUnknown_03004140;
-struct UnkRfuStruct_2 gUnknown_03005000;
-
-BSS_DATA u8 gUnknown_03000D74;
-ALIGNED(4) BSS_DATA u8 gUnknown_03000D78[8];
-BSS_DATA u8 gUnknown_03000D80[16];
-BSS_DATA u16 gUnknown_03000D90[8];
-
-EWRAM_DATA u8 gWirelessStatusIndicatorSpriteId = 0;
-EWRAM_DATA ALIGNED(4) struct UnkLinkRfuStruct_02022B14 gUnknown_02022B14 = {};
-EWRAM_DATA ALIGNED(2) u8 gUnknown_02022B22[PLAYER_NAME_LENGTH + 1] = {};
-EWRAM_DATA struct UnkLinkRfuStruct_02022B2C gUnknown_02022B2C = {};
-EWRAM_DATA struct UnkLinkRfuStruct_02022B44 gUnknown_02022B44 = {};
-
-// Static ROM declarations
-static void sub_800C000(void);
-static void sub_800C7B4(u16 r8, u16 r6);
-static void sub_800C744(u32 a0);
-static void sub_800CEB0(u16 r6);
-static void sub_800CF34(void);
-static void sub_800D158(void);
-static void sub_800D20C(void);
-static void sub_800D268(void);
-static u8 sub_800D294(void);
-static void sub_800D30C(u8 a0, u8 a1);
-static void sub_800D334(u8 a0);
-static void sub_800D358(u8 a0);
-static void sub_800D434(void);
-static void sub_800D610(void);
-void sub_800D630(void);
-static bool8 sub_800DAC8(struct UnkRfuStruct_2_Sub_c1c *q1, u8 *q2);
-static void sub_800EAB4(void);
-static void sub_800EAFC(void);
-void sub_800ED34(u16 unused);
-static void sub_800EDBC(u16 unused);
-static void sub_800F048(void);
-static void sub_800F86C(u8 unused);
-static void sub_800FCC4(struct UnkRfuStruct_2_Sub_6c *data);
-void sub_800FD14(u16 command);
-static void rfufunc_80F9F44(void);
-static void sub_800FFB0(void);
-static void rfufunc_80FA020(void);
-bool32 sub_8010454(u32 a0);
-static void sub_8010528(void);
-void sub_8010750(void);
-s32 sub_80107A0(void);
-void sub_801084C(u8 taskId);
-void sub_80109E8(u16 a0);
-void sub_8010A70(void *a0);
-void sub_8010AAC(u8 taskId);
-void sub_8010D0C(u8 taskId);
-void sub_80115EC(s32 a0);
-u8 sub_8011CE4(const u8 *a0, u16 a1);
-void sub_8011D6C(u32 a0);
-void sub_8011E94(u32 a0, u32 a1);
-bool8 sub_8012224(void);
-void sub_801227C(void);
-void sub_801209C(u8 taskId);
-void sub_8011BF8(void);
-void sub_8011BA4(void);
-
-// .rodata
-
-const u16 gWirelessLinkIconPalette[] = INCBIN_U16("graphics/interface/wireless_link_icon.gbapal");
-const u32 gWirelessLinkIconPic[] = INCBIN_U32("graphics/interface/wireless_link_icon.4bpp.lz");
-const u8 sWireless_ASCIItoRSETable[] = {
- 0xff, 0x95, 0x96, 0x97, 0x98, 0x99, 0x9a, 0x37,
- 0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f,
- 0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47,
- 0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e, 0x4f,
- 0x00, 0xab, 0xb5, 0xb6, 0xb1, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0xb2, 0xf1, 0x00, 0xae, 0xad, 0xba,
- 0xa1, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7, 0xa8,
- 0xa9, 0xaa, 0x00, 0x9b, 0x9c, 0x9d, 0x9e, 0x9f,
- 0x00, 0xbb, 0xbc, 0xbd, 0xbe, 0xbf, 0xc0, 0xc1,
- 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7, 0xc8, 0xc9,
- 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf, 0xd0, 0xd1,
- 0xd2, 0xd3, 0xd4, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6,
- 0x00, 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda, 0xdb,
- 0xdc, 0xdd, 0xde, 0xdf, 0xe0, 0xe1, 0xe2, 0xe3,
- 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea, 0xeb,
- 0xec, 0xed, 0xee, 0x2d, 0x2f, 0x30, 0x31, 0x32,
- 0x33, 0x34, 0x35, 0x36, 0x50, 0x00, 0x01, 0x02,
- 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a,
- 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12,
- 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1a,
- 0x1b, 0xad, 0xb3, 0xb4, 0x00, 0xaf, 0x7d, 0x7f,
- 0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0xa0,
- 0xae, 0x51, 0x52, 0x53, 0x54, 0x55, 0x56, 0x57,
- 0x58, 0x59, 0x5a, 0x5b, 0x5c, 0x5d, 0x5e, 0x5f,
- 0x60, 0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67,
- 0x68, 0x69, 0x6a, 0x6b, 0x6c, 0x6d, 0x6e, 0x6f,
- 0x70, 0x71, 0x72, 0x73, 0x74, 0x75, 0x76, 0x77,
- 0x78, 0x79, 0x7a, 0x7b, 0x7c, 0x7e, 0xb0, 0xac,
- 0x1c, 0x1d, 0x1e, 0x1f, 0x20, 0x21, 0x22, 0x23,
- 0x24, 0x25, 0x26, 0x27, 0x28, 0x29, 0x2a, 0x2b,
- 0x2c, 0x2e, 0x87, 0x88, 0x89, 0x8a, 0x8b, 0x8c,
- 0x8d, 0x8e, 0x8f, 0x90, 0x91, 0x92, 0x93, 0x94
-};
-const u8 sWireless_RSEtoASCIITable[] = {
- 0x20, 0x86, 0x87, 0x88, 0x89, 0x8a, 0x8b, 0x8c,
- 0x8d, 0x8e, 0x8f, 0x90, 0x91, 0x92, 0x93, 0x94,
- 0x95, 0x96, 0x97, 0x98, 0x99, 0x9a, 0x9b, 0x9c,
- 0x9d, 0x9e, 0x9f, 0xa0, 0xe0, 0xe1, 0xe2, 0xe3,
- 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea, 0xeb,
- 0xec, 0xed, 0xee, 0xef, 0xf0, 0x7b, 0xf1, 0x7c,
- 0x7d, 0x7e, 0x7f, 0x80, 0x81, 0x82, 0x83, 0x07,
- 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
- 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
- 0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f,
- 0x84, 0xb1, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6, 0xb7,
- 0xb8, 0xb9, 0xba, 0xbb, 0xbc, 0xbd, 0xbe, 0xbf,
- 0xc0, 0xc1, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7,
- 0xc8, 0xc9, 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf,
- 0xd0, 0xd1, 0xd2, 0xd3, 0xd4, 0xd5, 0xd6, 0xd7,
- 0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0xa6, 0xdd, 0xa7,
- 0xa8, 0xa9, 0xaa, 0xab, 0xac, 0xad, 0xae, 0xf2,
- 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8, 0xf9, 0xfa,
- 0xfb, 0xfc, 0xfd, 0xfe, 0xff, 0x01, 0x02, 0x03,
- 0x04, 0x05, 0x06, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f,
- 0xaf, 0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36,
- 0x37, 0x38, 0x39, 0x21, 0xdf, 0xa1, 0xb0, 0xa5,
- 0xde, 0x24, 0x2a, 0xa2, 0xa3, 0x22, 0x23, 0x20,
- 0xa4, 0x20, 0x2f, 0x41, 0x42, 0x43, 0x44, 0x45,
- 0x46, 0x47, 0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d,
- 0x4e, 0x4f, 0x50, 0x51, 0x52, 0x53, 0x54, 0x55,
- 0x56, 0x57, 0x58, 0x59, 0x5a, 0x61, 0x62, 0x63,
- 0x64, 0x65, 0x66, 0x67, 0x68, 0x69, 0x6a, 0x6b,
- 0x6c, 0x6d, 0x6e, 0x6f, 0x70, 0x71, 0x72, 0x73,
- 0x74, 0x75, 0x76, 0x77, 0x78, 0x79, 0x7a, 0x20,
- 0x20, 0x2b, 0x5b, 0x5c, 0x5d, 0x5e, 0x5f, 0x20,
- 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x00
-};
-const struct OamData sWirelessStatusIndicatorOamData =
-{
- .y = 0,
- .affineMode = ST_OAM_AFFINE_OFF,
- .objMode = ST_OAM_OBJ_NORMAL,
- .bpp = ST_OAM_4BPP,
- .shape = SPRITE_SHAPE(16x16),
- .x = 0,
- .size = SPRITE_SIZE(16x16),
- .tileNum = 0,
- .priority = 0,
- .paletteNum = 0,
-};
-static const union AnimCmd sWirelessStatusIndicatorAnim0[] = {
- // 3 bars
- ANIMCMD_FRAME( 4, 5),
- ANIMCMD_FRAME( 8, 5),
- ANIMCMD_FRAME(12, 5),
- ANIMCMD_FRAME(16, 10),
- ANIMCMD_FRAME(12, 5),
- ANIMCMD_FRAME( 8, 5),
- ANIMCMD_JUMP(0)
-};
-static const union AnimCmd sWirelessStatusIndicatorAnim1[] = {
- // 2 bars
- ANIMCMD_FRAME( 4, 5),
- ANIMCMD_FRAME( 8, 5),
- ANIMCMD_FRAME(12, 10),
- ANIMCMD_FRAME( 8, 5),
- ANIMCMD_JUMP(0)
-};
-static const union AnimCmd sWirelessStatusIndicatorAnim2[] = {
- // 1 bar
- ANIMCMD_FRAME(4, 5),
- ANIMCMD_FRAME(8, 5),
- ANIMCMD_JUMP(0)
-};
-static const union AnimCmd sWirelessStatusIndicatorAnim3[] = {
- // searching
- ANIMCMD_FRAME( 4, 10),
- ANIMCMD_FRAME(20, 10),
- ANIMCMD_JUMP(0)
-};
-static const union AnimCmd sWirelessStatusIndicatorAnim4[] = {
- // error
- ANIMCMD_FRAME(24, 10),
- ANIMCMD_FRAME( 4, 10),
- ANIMCMD_JUMP(0)
-};
-static const union AnimCmd *const sWirelessStatusIndicatorAnims[] = {
- sWirelessStatusIndicatorAnim0,
- sWirelessStatusIndicatorAnim1,
- sWirelessStatusIndicatorAnim2,
- sWirelessStatusIndicatorAnim3,
- sWirelessStatusIndicatorAnim4
-};
-const struct CompressedSpriteSheet sWirelessStatusIndicatorSpriteSheet = {
- gWirelessLinkIconPic, 0x0380, 0xD431
-};
-const struct SpritePalette sWirelessStatusIndicatorSpritePalette = {
- gWirelessLinkIconPalette, 0xD432
-};
-static const struct SpriteTemplate sWirelessStatusIndicatorSpriteTemplate = {
- 0xD431,
- 0xD432,
- &sWirelessStatusIndicatorOamData,
- sWirelessStatusIndicatorAnims,
- NULL,
- gDummySpriteAffineAnimTable,
- SpriteCallbackDummy
-};
-
-const struct UnkLinkRfuStruct_02022B2C gUnknown_082ED608 = {
- 0x04, 0x20, 0x00, 0x00, 0x02,
- &gUnknown_02022B14,
- gUnknown_02022B22,
- 0x01, 0x00, 0x258, 0x12c
-};
-const u8 gUnknown_082ED620[] = {
- 0, 3, 2, 1, 0
-};
-const u32 gUnknown_082ED628[] = {
- 0x000000,
- 0x000001,
- 0x000003,
- 0x000007,
- 0x00000f,
- 0x00001f,
- 0x00003f,
- 0x00007f,
- 0x0000ff,
- 0x0001ff,
- 0x0003ff,
- 0x0007ff,
- 0x000fff,
- 0x001fff,
- 0x003fff,
- 0x007fff,
- 0x00ffff,
- 0x01ffff,
- 0x03ffff,
- 0x07ffff,
- 0x0fffff,
- 0x1fffff,
- 0x3fffff,
- 0x7fffff,
- 0xffffff
-};
-const u8 gUnknown_082ED68C[] = {
- 0, 0, 1,
- 1, 2, 2,
- 2, 2, 3
-};
-const u8 gUnknown_082ED695[] = {
- 0, 1, 1, 2,
- 1, 2, 2, 3,
- 1, 2, 2, 3,
- 2, 3, 3, 4
-};
-const u8 gUnknown_082ED6A5[] = {
- 0, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0
-};
-const struct {
- u8 *buffer;
- u32 size;
-} gUnknown_082ED6B8[] = {
- { gBlockSendBuffer, 200 },
- { gBlockSendBuffer, 200 },
- { gBlockSendBuffer, 100 },
- { gBlockSendBuffer, 220 },
- { gBlockSendBuffer, 40 }
-};
-const u16 gUnknown_082ED6E0[] = {
- 0x0002, 0x7f7d, 0x0000, 0xFFFF
-};
-
-const char sUnref_082ED6E8[][15] = {
- "RFU WAIT",
- "RFU BOOT",
- "RFU ERROR",
- "RFU RESET",
- "RFU CONFIG",
- "RFU START",
- "RFU SC POLL",
- "RFU SP POLL",
- "RFU START",
- "RFU SEND ERR",
- "RFU CP POLL"
-};
-const char sUnref_082ED6E9[][16] = {
- " ",
- "RECOVER START ",
- "DISSCONECT ",
- "RECOVER SUUSES",
- "RECOVER FAILED"
-};
-const TaskFunc gUnknown_082ED7E0[] = {
- sub_801084C,
- sub_8010AAC,
- sub_8010D0C
-};
-const char gUnknown_082ED7EC[] = "PokemonSioInfo";
-const char gUnknown_082ED7FC[] = "LINK LOSS DISCONNECT!";
-const char gUnknown_082ED814[] = "LINK LOSS RECOVERY NOW";
-
-ALIGNED(4) const char gUnknown_082ED82C[31] = {' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',0x00};
-const char gUnknown_082ED84B[16] = {' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',0x00};
-const char gUnknown_082ED85B[9] = {' ',' ',' ',' ',' ',' ',' ',' ',0x00};
-ALIGNED(4) const char gUnknown_082ED864[2] = {' ',0x00};
-const char gUnknown_082ED866[2] = {'*',0x00};
-const char gUnknown_082ED868[8] = "NOWSLOT";
-const char gUnknown_082ED870[12] = " ";
-const char gUnknown_082ED87C[12] = "CLOCK DRIFT";
-const char gUnknown_082ED888[12] = "BUSY SEND ";
-const char gUnknown_082ED894[12] = "CMD REJECT ";
-const char gUnknown_082ED8A0[12] = "CLOCK SLAVE";
-const char gUnknown_082ED8A8[3][8] = {
- "CHILD ",
- "PARENT",
- "SEARCH"
-};
-
-// .text
-
-u32 sub_800BEC0(void)
-{
- u32 r4;
-
- r4 = rfu_REQBN_softReset_and_checkID();
- if (r4 == 0x8001)
- {
- gUnknown_03004140.unk_08 = 1;
- }
- if (gUnknown_03004140.unk_04 != 0x17 && gUnknown_03004140.unk_04 != 0x01)
- {
- gUnknown_03004140.unk_05 = 0;
- gUnknown_03004140.unk_04 = 0;
- }
- gUnknown_03004140.unk_07 = 0;
- gUnknown_03004140.unk_0d = 0;
- gUnknown_03004140.unk_01 = 0;
- gUnknown_03004140.unk_00 = 0;
- gUnknown_03004140.unk_06 = -1;
- sub_800D610();
- return r4;
-}
-
-void rfu_REQ_sendData_wrapper(u8 r2)
-{
- u8 val;
- if (!gRfuLinkStatus->parentChild)
- {
- val = gUnknown_03004140.unk_02;
- r2 = 0;
- if (val == 1)
- {
- r2 = 1;
- }
- }
- else
- {
- gUnknown_03004140.unk_03 = 0;
- }
- rfu_REQ_sendData(r2);
-}
-
-s32 sub_800BF4C(void (*func1)(u8, u8), void (*func2)(u16))
-{
- if (func1 == NULL)
- {
- return 4;
- }
- CpuFill16(0, &gUnknown_03004140, offsetof(struct UnkRfuStruct_1, filler_48));
- gUnknown_03004140.unk_06 = -1;
- gUnknown_03004140.unk_40 = func1;
- gUnknown_03004140.unk_44 = func2;
- rfu_setMSCCallback(sub_800CEB0);
- rfu_setREQCallback(sub_800C7B4);
- return 0;
-}
-
-void sub_800BFA0(void)
-{
- CpuFill16(0, &gUnknown_03004140, offsetof(struct UnkRfuStruct_1, unk_40));
- gUnknown_03004140.unk_06 = -1;
-}
-
-void sub_800BFCC(const struct UnkLinkRfuStruct_02022B2C *unk0)
-{
- sub_800C000();
- gUnknown_03004140.unk_04 = 1;
- gUnknown_03004140.unk_05 = 2;
- gUnknown_03004140.unk_3c = unk0;
- gUnknown_03004140.unk_09 = unk0->unk_11;
- gUnknown_03004140.unk_32 = unk0->unk_12;
- gUnknown_03004140.unk_18 = unk0->unk_14;
- if (unk0->unk_10)
- {
- gUnknown_03004140.unk_0b = 1;
- }
-}
-
-static void sub_800C000(void)
-{
- u8 i;
-
- gUnknown_03004140.unk_05 = 0;
- gUnknown_03004140.unk_04 = 0;
- gUnknown_03004140.unk_06 = -1;
- gUnknown_03004140.unk_07 = 0;
- gUnknown_03004140.unk_10 = 0;
- gUnknown_03004140.unk_0c = 0;
- gUnknown_03004140.unk_24 = 0;
- gUnknown_03004140.unk_30 = 0;
- for (i = 0; i < 4; i++)
- {
- gUnknown_03004140.unk_28[i] = 0;
- gUnknown_03004140.unk_34[i] = 0;
- }
-}
-
-void sub_800C048(void)
-{
- gUnknown_03004140.unk_04 = 0x15;
-}
-
-u8 sub_800C054(u8 r5, u16 r7, u16 r8, const u16 *r6)
-{
- u8 i;
- const u16 *buffer;
-
- if (gUnknown_03004140.unk_04 != 0 && (gUnknown_03004140.unk_04 != 0x08 || r5 != 1))
- {
- 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, buffer = r6; i < 16; i++)
- {
- if (*buffer++ == 0xFFFF)
- {
- break;
- }
- }
- if (i == 16)
- {
- gUnknown_03004140.unk_14 = 4;
- sub_800D30C(0xf3, 0x01);
- return 4;
- }
- if (r5 > 1)
- {
- gUnknown_03004140.unk_07 = 1;
- r5 = 1;
- r7 = 0;
- }
- else
- {
- gUnknown_03004140.unk_07 = 0;
- }
- if (r5 != 0)
- {
- gUnknown_03004140.unk_04 = 5;
- }
- else
- {
- gUnknown_03004140.unk_04 = 9;
- if (gUnknown_03004140.unk_0b)
- {
- gUnknown_03004140.unk_0b = 2;
- }
- }
- gUnknown_03004140.unk_06 = r5;
- gUnknown_03004140.unk_1a = r7;
- gUnknown_03004140.unk_26 = r8;
- gUnknown_03004140.unk_20 = r6;
- return 0;
-}
-
-u8 sub_800C12C(u16 r6, u16 r8)
-{
- u8 i;
-
- 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 < gRfuLinkStatus->findParentCount; i++)
- {
- if (gRfuLinkStatus->partner[i].id == r6)
- {
- break;
- }
- }
- if (gRfuLinkStatus->findParentCount == 0 || i == gRfuLinkStatus->findParentCount)
- {
- 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;
-}
-
-void sub_800C210(u8 a0)
-{
- u8 i;
-
- if (a0 & gUnknown_03004140.unk_30)
- {
- gUnknown_03004140.unk_30 &= ~a0;
- for (i = 0; i < 4; i++)
- {
- if ((a0 >> i) & 1)
- {
- gUnknown_03004140.unk_34[i] = 0;
- }
- }
- i = gRfuLinkStatus->linkLossSlotFlag & a0;
- if (i)
- {
- sub_800D334(i);
- }
- gUnknown_03004140.unk_14 = i;
- sub_800D30C(0x33, i);
- }
-}
-
-void sub_800C27C(bool8 a0)
-{
- u8 r2;
-
- r2 = 0;
- gUnknown_03004140.unk_07 = 0;
- if (a0)
- {
- sub_800C000();
- gUnknown_03004140.unk_04 = 23;
- }
- else
- {
- switch (gUnknown_03004140.unk_04)
- {
- case 5:
- gUnknown_03004140.unk_04 = 8;
- gUnknown_03004140.unk_05 = 0;
- r2 = 0x13;
- break;
- case 6:
- gUnknown_03004140.unk_04 = 7;
- gUnknown_03004140.unk_05 = 8;
- break;
- case 7:
- gUnknown_03004140.unk_04 = 7;
- gUnknown_03004140.unk_05 = 8;
- break;
- case 8:
- break;
- case 9:
- gUnknown_03004140.unk_05 = 0;
- gUnknown_03004140.unk_04 = 0;
- r2 = 0x21;
- break;
- case 10:
- gUnknown_03004140.unk_04 = 11;
- gUnknown_03004140.unk_05 = 0;
- break;
- case 11:
- gUnknown_03004140.unk_04 = 11;
- gUnknown_03004140.unk_05 = 0;
- break;
- case 12:
- gUnknown_03004140.unk_05 = 0;
- gUnknown_03004140.unk_04 = 0;
- r2 = 0x23;
- break;
- case 13:
- gUnknown_03004140.unk_04 = 14;
- break;
- case 14:
- gUnknown_03004140.unk_04 = 14;
- break;
- case 15:
- break;
- case 16:
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_11;
- gUnknown_03004140.unk_05 = gUnknown_03004140.unk_12;
- sub_800D334(gRfuLinkStatus->linkLossSlotFlag);
- gUnknown_03004140.unk_14 = gRfuLinkStatus->linkLossSlotFlag;
- sub_800D30C(0x33, 0x01);
- return;
- case 17:
- gUnknown_03004140.unk_04 = 18;
- break;
- case 18:
- gUnknown_03004140.unk_04 = 18;
- break;
- default:
- gUnknown_03004140.unk_05 = 0;
- gUnknown_03004140.unk_04 = 0;
- r2 = 0x43;
- break;
- }
- if (gUnknown_03004140.unk_04 == 0)
- {
- sub_800D30C(r2, 0);
- }
- }
-}
-
-bool8 sub_800C36C(u16 a0)
-{
- bool8 retVal;
- u8 i;
- u8 sp0;
- u8 sp1;
- u8 sp2;
- u8 flags;
-
- retVal = FALSE;
- rfu_REQBN_watchLink(a0, &sp0, &sp1, &sp2);
- if (sp0)
- {
- gUnknown_03004140.unk_14 = sp0;
- gUnknown_03004140.unk_16 = sp1;
- if (gUnknown_03004140.unk_09)
- {
- gUnknown_03004140.unk_0a = 1;
- if (gUnknown_03004140.unk_06 == 0 && sp1 == 0)
- {
- gUnknown_03004140.unk_0a = 4;
- }
- if (gUnknown_03004140.unk_0a == 1)
- {
- for (i = 0; i < 4; i++)
- {
- if ((sp0 >> i) & 1)
- {
- gUnknown_03004140.unk_30 |= (1 << i);
- gUnknown_03004140.unk_34[i] = gUnknown_03004140.unk_32;
- }
- }
- sub_800D30C(0x31, 0x01);
- }
- else
- {
- gUnknown_03004140.unk_0a = 0;
- sub_800D334(sp0);
- retVal = TRUE;
- sub_800D30C(0x33, 0x01);
- }
- }
- else
- {
- sub_800D334(sp0);
- retVal = TRUE;
- sub_800D30C(0x30, 0x02);
- }
- sub_800D610();
- }
- if (gRfuLinkStatus->parentChild == 1)
- {
- if (sp2)
- {
- for (i = 0; i < 4; i++)
- {
- if ((gUnknown_03004140.unk_30 >> i) & 1 && (sp2 >> i) & 1)
- {
- gUnknown_03004140.unk_34[i] = 0;
- }
- }
- gUnknown_03004140.unk_30 &= ~sp2;
- gUnknown_03004140.unk_14 = sp2;
- sub_800D30C(0x32, 0x01);
- }
- if (gUnknown_03004140.unk_30)
- {
- flags = 0;
- for (i = 0; i < 4; i++)
- {
- if ((gUnknown_03004140.unk_30 >> i) & 1 && gUnknown_03004140.unk_34[i] && --gUnknown_03004140.unk_34[i] == 0)
- {
- gUnknown_03004140.unk_30 &= ~(1 << i);
- flags |= (1 << i);
- }
- }
- if (flags)
- {
- sub_800D334(flags);
- retVal = TRUE;
- gUnknown_03004140.unk_14 = flags;
- sub_800D30C(0x33, 0x01);
- }
- }
- if (!gUnknown_03004140.unk_30)
- {
- gUnknown_03004140.unk_0a = 0;
- }
- }
- return retVal;
-}
-
-void rfu_syncVBlank_(void)
-{
- if (rfu_syncVBlank())
- {
- sub_800D30C(0xF1, 0x00);
- sub_800D610();
- }
-}
-
-void sub_800C54C(u32 a0)
-{
- u8 r2;
-
- if (gUnknown_03004140.unk_40 == NULL && gUnknown_03004140.unk_04 != 0)
- {
- gUnknown_03004140.unk_04 = 0;
- }
- else
- {
- if (gUnknown_03004140.unk_07 != 0)
- {
- sub_800C744(a0);
- }
- do
- {
- if (gUnknown_03004140.unk_04 != 0)
- {
- rfu_waitREQComplete();
- gUnknown_03004140.unk_0e = 1;
- switch (gUnknown_03004140.unk_04)
- {
- case 23:
- r2 = sub_800BEC0() == 0x8001 ? 0x44 : 0xFF;
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- sub_800D30C(r2, 0);
- break;
- case 1:
- if (sub_800BEC0() == 0x8001)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05;
- gUnknown_03004140.unk_05 = 3;
- }
- else
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- sub_800D30C(0xFF, 0);
- }
- break;
- case 2:
- rfu_REQ_reset();
- break;
- case 3:
- rfu_REQ_configSystem(gUnknown_03004140.unk_3c->unk_02, gUnknown_03004140.unk_3c->unk_00, gUnknown_03004140.unk_3c->unk_01);
- break;
- case 4:
- rfu_REQ_configGameData(gUnknown_03004140.unk_3c->unk_04, gUnknown_03004140.unk_3c->unk_06, (const u8 *)gUnknown_03004140.unk_3c->unk_08, gUnknown_03004140.unk_3c->unk_0c);
- break;
- case 5:
- rfu_REQ_startSearchChild();
- break;
- case 6:
- rfu_REQ_pollSearchChild();
- break;
- case 7:
- rfu_REQ_endSearchChild();
- break;
- case 8:
- break;
- case 9:
- rfu_REQ_startSearchParent();
- break;
- case 10:
- rfu_REQ_pollSearchParent();
- break;
- case 11:
- rfu_REQ_endSearchParent();
- break;
- case 12:
- rfu_REQ_startConnectParent(gUnknown_03004140.unk_1e);
- break;
- case 13:
- rfu_REQ_pollConnectParent();
- break;
- case 14:
- rfu_REQ_endConnectParent();
- break;
- case 15:
- break;
- case 16:
- rfu_REQ_CHILD_startConnectRecovery(gRfuLinkStatus->linkLossSlotFlag);
- break;
- case 17:
- rfu_REQ_CHILD_pollConnectRecovery();
- break;
- case 18:
- rfu_REQ_CHILD_endConnectRecovery();
- break;
- case 19:
- rfu_REQ_changeMasterSlave();
- break;
- case 20:
- break;
- case 21:
- rfu_REQ_stopMode();
- break;
- case 22:
- break;
- }
- rfu_waitREQComplete();
- gUnknown_03004140.unk_0e = 0;
- }
- } while (gUnknown_03004140.unk_04 == 18 || gUnknown_03004140.unk_04 == 19);
- if (gRfuLinkStatus->parentChild != 1 || !sub_800C36C(0))
- {
- sub_800CF34();
- sub_800D158();
- sub_800D268();
- sub_800D434();
- }
- }
-}
-
-static void sub_800C744(u32 a0)
-{
- if (gUnknown_03004140.unk_07 == 5)
- {
- gUnknown_03004140.unk_06 = 1;
- gUnknown_03004140.unk_04 = 5;
- gUnknown_03004140.unk_1a = gUnknown_03004140.unk_1c;
- if (gUnknown_03004140.unk_1a)
- {
- gUnknown_03004140.unk_07 = 6;
- }
- else
- {
- gUnknown_03004140.unk_07 = 1;
- }
- }
- if (gUnknown_03004140.unk_07 == 1)
- {
- gUnknown_03004140.unk_06 = 1;
- gUnknown_03004140.unk_04 = 5;
- gUnknown_03004140.unk_1a = a0 % 140;
- gUnknown_03004140.unk_1c = 140 - gUnknown_03004140.unk_1a;
- if (gUnknown_03004140.unk_1a)
- {
- gUnknown_03004140.unk_07 = 2;
- }
- else
- {
- gUnknown_03004140.unk_07 = 3;
- }
- }
- if (gUnknown_03004140.unk_07 == 3)
- {
- gUnknown_03004140.unk_06 = 0;
- gUnknown_03004140.unk_1a = 40;
- gUnknown_03004140.unk_07 = 4;
- gUnknown_03004140.unk_04 = 9;
- }
-}
-
-static void sub_800C7B4(u16 r8, u16 r6)
-{
- u8 sp0;
- register struct RfuIntrStruct *stwiRecvBuffer asm("r0");
- u8 *tmp;
- u8 i;
-
- if (gUnknown_03004140.unk_0e != 0)
- {
- gUnknown_03004140.unk_0e = 0;
- switch (r8)
- {
- case 16:
- if (r6 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05;
- gUnknown_03004140.unk_05 = 4;
- }
- break;
- case 23:
- if (r6 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05;
- gUnknown_03004140.unk_05 = 0;
- }
- break;
- case 22:
- if (r6 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- sub_800D30C(0x00, 0x00);
- }
- break;
- case 25:
- if (r6 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 6;
- }
- break;
- case 26:
- if (gUnknown_03004140.unk_1a && --gUnknown_03004140.unk_1a == 0)
- {
- gUnknown_03004140.unk_04 = 7;
- gUnknown_03004140.unk_05 = 8;
- }
- break;
- case 27:
- if (r6 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05;
- gUnknown_03004140.unk_05 = 0;
- if (gUnknown_03004140.unk_07 == 0)
- {
- sub_800D30C(0x13, 0x00);
- }
- }
- break;
- case 28:
- if (r6 == 0)
- {
- if (gUnknown_03004140.unk_0b == 1 && gUnknown_03004140.unk_1a > 1)
- {
- gUnknown_03004140.unk_1a--;
- }
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 10;
- }
- break;
- case 29:
- if (r6 == 0)
- {
- sp0 = sub_800D294();
- gUnknown_03004140.unk_14 = sp0;
- if (sp0)
- {
- sub_800D30C(0x20, 0x01);
- }
- if (gUnknown_03004140.unk_0b && gUnknown_03004140.unk_1a != 1 && gRfuLinkStatus->findParentCount == 4)
- {
- rfu_REQ_endSearchParent();
- rfu_waitREQComplete();
- gUnknown_03004140.unk_04 = 9;
- gUnknown_03004140.unk_0b = 1;
- }
- }
- if (gUnknown_03004140.unk_1a && --gUnknown_03004140.unk_1a == 0)
- {
- gUnknown_03004140.unk_04 = 11;
- gUnknown_03004140.unk_05 = 0;
- }
- break;
- case 30:
- if (r6 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05;
- if (gUnknown_03004140.unk_07 == 0)
- {
- if (gUnknown_03004140.unk_04 == 0)
- {
- sub_800D30C(0x21, 0x00);
- }
- }
- else if (gUnknown_03004140.unk_07 != 7)
- {
- gUnknown_03004140.unk_04 = 5;
- gUnknown_03004140.unk_07 = 5;
- }
- }
- break;
- case 31:
- if (r6 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 13;
- }
- break;
- case 32:
- if (r6 == 0 && !rfu_getConnectParentStatus(&sp0, &gUnknown_03004140.unk_10) && !sp0)
- {
- gUnknown_03004140.unk_04 = 14;
- }
- if (gUnknown_03004140.unk_1a && --gUnknown_03004140.unk_1a == 0)
- {
- gUnknown_03004140.unk_04 = 14;
- }
- break;
- case 33:
- if (r6 == 0 && !rfu_getConnectParentStatus(&sp0, &gUnknown_03004140.unk_10))
- {
- if (!sp0)
- {
- gUnknown_03004140.unk_04 = 19;
- gUnknown_03004140.unk_05 = 15;
- gUnknown_03004140.unk_1e = 0x22;
- gUnknown_03004140.unk_14 = gUnknown_03004140.unk_10;
- }
- else
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- gUnknown_03004140.unk_1e = 0x23;
- gUnknown_03004140.unk_14 = sp0;
- if (gUnknown_03004140.unk_07)
- {
- gUnknown_03004140.unk_07 = 3;
- gUnknown_03004140.unk_04 = 9;
- }
- }
- sub_800D30C(gUnknown_03004140.unk_1e, 0x01);
- gUnknown_03004140.unk_1e = 0;
- }
- break;
- case 50:
- if (r6 == 0)
- {
- gUnknown_03004140.unk_14 = gRfuLinkStatus->linkLossSlotFlag;
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 17;
- for (gUnknown_03004140.unk_10 = 0; gUnknown_03004140.unk_10 < 4; gUnknown_03004140.unk_10 ++)
- {
- if ((gRfuLinkStatus->linkLossSlotFlag >> gUnknown_03004140.unk_10) & 1)
- {
- break;
- }
- }
- }
- break;
- case 51:
- if (r6 == 0 && !rfu_CHILD_getConnectRecoveryStatus(&sp0) && sp0 < 2)
- {
- gUnknown_03004140.unk_04 = 18;
- }
- if (gUnknown_03004140.unk_34[gUnknown_03004140.unk_10] && --gUnknown_03004140.unk_34[gUnknown_03004140.unk_10] == 0)
- {
- gUnknown_03004140.unk_04 = 18;
- }
- break;
- case 52:
- if (r6 == 0 && !rfu_CHILD_getConnectRecoveryStatus(&sp0))
- {
- if (!sp0)
- {
- gUnknown_03004140.unk_04 = 19;
- gUnknown_03004140.unk_05 = 22;
- gUnknown_03004140.unk_1e = 0x32;
- }
- else
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- sub_800D334(gRfuLinkStatus->linkLossSlotFlag);
- gUnknown_03004140.unk_1e = 0x33;
- }
- gUnknown_03004140.unk_34[gUnknown_03004140.unk_10] = 0;
- gUnknown_03004140.unk_30 = 0;
- gUnknown_03004140.unk_0a = 0;
- sub_800D30C(gUnknown_03004140.unk_1e, 0x01);
- gUnknown_03004140.unk_1e = 0;
- }
- break;
- case 39:
- if (r6 == 0)
- {
- if (gUnknown_03004140.unk_05 == 22)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_11;
- gUnknown_03004140.unk_05 = gUnknown_03004140.unk_12;
- gUnknown_03004140.unk_02 = 1;
- sub_800D30C(0x41, 0x00);
- }
- else if (gUnknown_03004140.unk_05 == 15)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05;
- gUnknown_03004140.unk_02 = 1;
- sub_800D30C(0x41, 0x00);
- gUnknown_03004140.unk_24 |= 1 << gUnknown_03004140.unk_10;
- gUnknown_03004140.unk_28[gUnknown_03004140.unk_10] = gUnknown_03004140.unk_26;
- rfu_clearSlot(4, gUnknown_03004140.unk_10);
- tmp = &sp0;
- *tmp = rfu_NI_CHILD_setSendGameName(gUnknown_03004140.unk_10, 0x0e);
- if (*tmp)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- sub_800D610();
- sub_800D334(gRfuLinkStatus->connSlotFlag | gRfuLinkStatus->linkLossSlotFlag);
- gUnknown_03004140.unk_14 = sp0;
- sub_800D30C(0x25, 0x01);
- }
- }
- }
- break;
- case 61:
- if (r6 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- sub_800D30C(0x42, 0x00);
- }
- break;
- }
- gUnknown_03004140.unk_0e = 1;
- }
- else if (r6 == 3 && gUnknown_03004140.unk_0f && (r8 == 0x24 || r8 == 0x26 || r8 == 0x27))
- {
- rfu_REQ_RFUStatus();
- rfu_waitREQComplete();
- rfu_getRFUStatus(&sp0);
- if (sp0 == 0 && gRfuLinkStatus->parentChild == 0)
- {
- stwiRecvBuffer = rfu_getSTWIRecvBuffer();
- stwiRecvBuffer->rxPacketAlloc.rfuPacket8.data[4] = gRfuLinkStatus->connSlotFlag;
- stwiRecvBuffer->rxPacketAlloc.rfuPacket8.data[5] = 1;
- sub_800C36C(0x29);
- r6 = 0;
- }
- }
- switch (r8)
- {
- case 48:
- if (r6 == 0)
- {
- stwiRecvBuffer = rfu_getSTWIRecvBuffer();
- gUnknown_03004140.unk_14 = stwiRecvBuffer->rxPacketAlloc.rfuPacket8.data[8];
- sub_800D358(gUnknown_03004140.unk_14);
- if (gUnknown_03004140.unk_30)
- {
- gUnknown_03004140.unk_30 &= ~gUnknown_03004140.unk_14;
- for (i = 0; i < 4; i++)
- {
- if ((gUnknown_03004140.unk_14 >> i) & 1)
- {
- gUnknown_03004140.unk_34[i] = 0;
- }
- }
- if (gUnknown_03004140.unk_06 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- }
- }
- sp0 = gUnknown_03004140.unk_00 & gUnknown_03004140.unk_14;
- for (i = 0; i < 4; i++)
- {
- if ((sp0 >> i) & 1 && gUnknown_03004140.unk_01)
- {
- gUnknown_03004140.unk_01--;
- }
- }
- gUnknown_03004140.unk_00 &= ~gUnknown_03004140.unk_14;
- if (gUnknown_03004140.unk_07)
- {
- if (gRfuLinkStatus->parentChild == 0xFF)
- {
- if (gUnknown_03004140.unk_07 == 8)
- {
- gUnknown_03004140.unk_1a = gUnknown_03004140.unk_1c;
- gUnknown_03004140.unk_07 = 6;
- gUnknown_03004140.unk_04 = 6;
- }
- else if (gUnknown_03004140.unk_04 != 6 && gUnknown_03004140.unk_04 != 7)
- {
- gUnknown_03004140.unk_07 = 1;
- gUnknown_03004140.unk_04 = 5;
- }
- }
- }
- if (gRfuLinkStatus->parentChild == 0xFF)
- {
- if (gUnknown_03004140.unk_04 == 0)
- {
- gUnknown_03004140.unk_06 = -1;
- }
- }
- if (gUnknown_03004140.unk_0e == 0)
- {
- sub_800D30C(0x40, 0x01);
- }
- }
- break;
- case 38:
- sub_800D20C();
- if (gRfuLinkStatus->parentChild != 0xFF)
- {
- sub_800D30C(0x50, 0x00);
- }
- break;
- case 16:
- case 61:
- if (r6 == 0)
- {
- gUnknown_03004140.unk_0d = 0;
- gUnknown_03004140.unk_01 = 0;
- gUnknown_03004140.unk_00 = 0;;
- gUnknown_03004140.unk_06 = -1;
- sub_800D610();
- if (r8 == 61)
- {
- sub_800BFA0();
- }
- }
- break;
- }
- if (r6 != 0)
- {
- if (r8 == 28 && r6 != 0 && gUnknown_03004140.unk_07 == 4)
- {
- gRfuLinkStatus->parentChild = 1;
- gRfuLinkStatus->connSlotFlag = 15;
- sub_800D334(15);
- rfu_waitREQComplete();
- return;
- }
- else
- {
- gUnknown_03004140.unk_14 = r8;
- gUnknown_03004140.unk_16 = r6;
- if (gUnknown_03004140.unk_0e)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- }
- sub_800D30C(0xf0, 0x02);
- sub_800D610();
- }
- }
- if (r8 == 0xFF)
- {
- sub_800D30C(0xf2, 0x00);
- sub_800D610();
- }
-}
-
-static void sub_800CEB0(u16 r6)
-{
- u8 r7;
- u8 sp0;
-
- r7 = gUnknown_03004140.unk_0e;
- gUnknown_03004140.unk_0e = 0;
- gUnknown_03004140.unk_0f = 1;
- if (gRfuLinkStatus->parentChild == 0)
- {
- sub_800C36C(r6);
- if (gUnknown_03004140.unk_02 != 1)
- {
- sub_800D610();
- gUnknown_03004140.unk_0f = 0;
- gUnknown_03004140.unk_0e = r7;
- return;
- }
- }
- else
- {
- if (!rfu_UNI_PARENT_getDRAC_ACK(&sp0))
- {
- gUnknown_03004140.unk_03 |= sp0;
- }
- }
- if (gUnknown_03004140.unk_44 != NULL)
- {
- gUnknown_03004140.unk_44(r6);
- rfu_waitREQComplete();
- if (gUnknown_03004140.unk_02 == 2)
- {
- sub_800D610();
- }
- }
- gUnknown_03004140.unk_0f = 0;
- gUnknown_03004140.unk_0e = r7;
-}
-
-static void sub_800CF34(void)
-{
- u8 flags;
- u8 sp0;
- u8 i;
- u8 r5;
- u8 r4;
- const u16 *ptr;
-
- if (gUnknown_03004140.unk_04 == 5 || gUnknown_03004140.unk_04 == 6 || gUnknown_03004140.unk_04 == 7 || gUnknown_03004140.unk_04 == 8)
- {
- flags = ((gRfuLinkStatus->connSlotFlag ^ gUnknown_03004140.unk_0c) & gRfuLinkStatus->connSlotFlag) & ~gRfuLinkStatus->getNameFlag;
- gUnknown_03004140.unk_0c = gRfuLinkStatus->connSlotFlag;
- if (flags)
- {
- gUnknown_03004140.unk_14 = flags;
- sub_800D30C(0x10, 0x01);
- }
- sp0 = 0x00;
- for (i = 0; i < 4; i++)
- {
- r4 = 1 << i;
- r5 = 0x00;
- if (flags & r4)
- {
- gUnknown_03004140.unk_28[i] = gUnknown_03004140.unk_26;
- gUnknown_03004140.unk_24 |= r4;
- }
- else if (gUnknown_03004140.unk_24 & r4)
- {
- if (gRfuSlotStatusNI[i]->recv.state == 0x46)
- {
- if (gRfuSlotStatusNI[i]->recv.dataType == 1)
- {
- r5 = 0x02;
- for (ptr = gUnknown_03004140.unk_20; *ptr != 0xFFFF; ptr++)
- {
- if (gRfuLinkStatus->partner[i].serialNo == *ptr)
- {
- gUnknown_03004140.unk_00 |= r4;
- gUnknown_03004140.unk_01++;
- sp0 |= r4;
- r5 |= 0x01;
- break;
- }
- }
- if (!(r5 & 0x01))
- {
- r5 |= 0x04;
- }
- }
- }
- else if (--gUnknown_03004140.unk_28[i] == 0)
- {
- r5 = 0x06;
- }
- if (r5 & 0x02)
- {
- gUnknown_03004140.unk_24 &= ~r4;
- gUnknown_03004140.unk_28[i] = 0;
- rfu_clearSlot(0x08, i);
- }
- if (r5 & 0x04)
- {
- gUnknown_03004140.unk_0d |= r4;
- }
- }
- }
- if (sp0)
- {
- gUnknown_03004140.unk_14 = sp0;
- sub_800D30C(0x11, 0x01);
- }
- if (gUnknown_03004140.unk_0d)
- {
- r5 = 0x01;
- if (gRfuLinkStatus->sendSlotUNIFlag && ((gUnknown_03004140.unk_03 & gUnknown_03004140.unk_00) != gUnknown_03004140.unk_00))
- {
- r5 = 0x00;
- }
- if (r5)
- {
- sub_800D334(gUnknown_03004140.unk_0d);
- gUnknown_03004140.unk_14 = gUnknown_03004140.unk_0d;
- gUnknown_03004140.unk_0d = 0;
- sub_800D30C(0x12, 0x01);
- }
- }
- if (gUnknown_03004140.unk_24 == 0 && gUnknown_03004140.unk_04 == 8)
- {
- if (gUnknown_03004140.unk_07 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- sub_800D30C(0x14, 0x00);
- }
- else
- {
- if (gUnknown_03004140.unk_07 == 2)
- {
- gUnknown_03004140.unk_07 = 3;
- gUnknown_03004140.unk_04 = 9;
- }
- else
- {
- gUnknown_03004140.unk_07 = 1;
- gUnknown_03004140.unk_04 = 5;
- }
- if (gUnknown_03004140.unk_00)
- {
- gUnknown_03004140.unk_1a = 0;
- gUnknown_03004140.unk_07 = 8;
- gUnknown_03004140.unk_04 = 5;
- }
- }
- }
- }
-}
-
-static void sub_800D158(void)
-{
- u16 imeBak = REG_IME;
- REG_IME = 0;
- if (gUnknown_03004140.unk_04 == 15)
- {
- if (--gUnknown_03004140.unk_28[gUnknown_03004140.unk_10] == 0 || gRfuSlotStatusNI[gUnknown_03004140.unk_10]->send.state == 0x27)
- {
- sub_800D630();
- gUnknown_03004140.unk_04 = 24;
- rfu_clearSlot(4, gUnknown_03004140.unk_10);
- gUnknown_03004140.unk_24 &= ~(1 << gUnknown_03004140.unk_10);
- gUnknown_03004140.unk_28[gUnknown_03004140.unk_10] = 0;
- }
- }
- REG_IME = imeBak;
- if (gUnknown_03004140.unk_04 == 24)
- {
- if (gUnknown_03004140.unk_02 == 1)
- {
- sub_800D630();
- }
- if (gUnknown_03004140.unk_02 == 0)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- sub_800D334(gRfuLinkStatus->connSlotFlag | gRfuLinkStatus->linkLossSlotFlag);
- gUnknown_03004140.unk_14 = 0;
- sub_800D30C(0x25, 0x01);
- }
- }
-}
-
-static void sub_800D20C(void)
-{
- if (gUnknown_03004140.unk_04 == 15 && gRfuSlotStatusNI[gUnknown_03004140.unk_10]->send.state == 0x26)
- {
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- rfu_clearSlot(4, gUnknown_03004140.unk_10);
- gUnknown_03004140.unk_24 &= ~(1 << gUnknown_03004140.unk_10);
- gUnknown_03004140.unk_28[gUnknown_03004140.unk_10] = 0;
- sub_800D30C(0x24, 0x00);
- }
-}
-
-static void sub_800D268(void)
-{
- if (gUnknown_03004140.unk_06 == 0 && gUnknown_03004140.unk_0a == 1)
- {
- gUnknown_03004140.unk_11 = gUnknown_03004140.unk_04;
- gUnknown_03004140.unk_12 = gUnknown_03004140.unk_05;
- gUnknown_03004140.unk_04 = 16;
- gUnknown_03004140.unk_05 = 17;
- gUnknown_03004140.unk_0a = 2;
- }
-}
-
-static u8 sub_800D294(void)
-{
- u8 i;
- const u16 *ptr;
- u8 flags = 0x00;
-
- for (i = 0; i < gRfuLinkStatus->findParentCount; i++)
- {
- for (ptr = gUnknown_03004140.unk_20; *ptr != 0xFFFF; ptr++)
- {
- if (gRfuLinkStatus->partner[i].serialNo == *ptr)
- {
- flags |= (1 << i);
- }
- }
- }
- return flags;
-}
-
-static void sub_800D30C(u8 a0, u8 a1)
-{
- if (gUnknown_03004140.unk_40 != NULL)
- {
- gUnknown_03004140.unk_40(a0, a1);
- }
- gUnknown_03004140.unk_14 = gUnknown_03004140.unk_16 = 0;
-}
-
-static void sub_800D334(u8 a0)
-{
- u8 unk_0e_bak = gUnknown_03004140.unk_0e;
- gUnknown_03004140.unk_0e = 1;
- rfu_REQ_disconnect(a0);
- rfu_waitREQComplete();
- gUnknown_03004140.unk_0e = unk_0e_bak;
-}
-
-static void sub_800D358(u8 a0)
-{
- u8 i;
-
- if (gRfuLinkStatus->sendSlotNIFlag)
- {
- for (i = 0; i < 4; i++)
- {
- if (gRfuSlotStatusNI[i]->send.state & 0x8000 && gRfuSlotStatusNI[i]->send.bmSlot & a0)
- {
- rfu_changeSendTarget(0x20, i, gRfuSlotStatusNI[i]->send.bmSlot & ~a0);
- }
- }
- }
- if (gRfuLinkStatus->recvSlotNIFlag)
- {
- for (i = 0; i < 4; i++)
- {
- if (gRfuSlotStatusNI[i]->recv.state & 0x8000 && gRfuSlotStatusNI[i]->recv.bmSlot & a0)
- {
- rfu_NI_stopReceivingData(i);
- }
- }
- }
- if (gRfuLinkStatus->sendSlotUNIFlag)
- {
- gRfuLinkStatus->sendSlotUNIFlag &= ~a0;
- for (i = 0; i < 4; i++)
- {
- if (gRfuSlotStatusUNI[i]->send.state == 0x8024 && a0 & gRfuSlotStatusUNI[i]->send.bmSlot)
- {
- gRfuSlotStatusUNI[i]->send.bmSlot &= ~a0;
- }
- }
- }
-}
-
-static void sub_800D434(void)
-{
- u8 i;
- u8 j;
- u8 flags;
-
- if (gUnknown_03004140.unk_18)
- {
- if (gRfuLinkStatus->sendSlotNIFlag)
- {
- for (i = 0; i < 4; i ++)
- {
- if (gRfuSlotStatusNI[i]->send.state & 0x8000)
- {
- flags = 0;
- for (j = 0; j < 4; j++)
- {
- if ((gRfuSlotStatusNI[i]->send.bmSlot >> j) & 1 && gRfuSlotStatusNI[j]->send.failCounter > gUnknown_03004140.unk_18)
- {
- flags |= (1 << j);
- }
- if (flags)
- {
- rfu_changeSendTarget(0x20, i, flags ^ gRfuSlotStatusNI[i]->send.bmSlot);
- }
- }
- }
- }
- }
- if (gRfuLinkStatus->recvSlotNIFlag)
- {
- for (i = 0; i < 4; i++)
- {
- if (gRfuSlotStatusNI[i]->recv.state & 0x8000 && gRfuSlotStatusNI[i]->recv.failCounter > gUnknown_03004140.unk_18)
- {
- rfu_NI_stopReceivingData(i);
- }
- }
- }
- }
-}
-
-void sub_800D52C(void (*func)(u16))
-{
- gUnknown_03004140.unk_44 = func;
- rfu_setMSCCallback(sub_800CEB0);
-}
-
-void sub_800D544(void (*func)(u8, u8))
-{
- gUnknown_03004140.unk_40 = func;
-}
-
-u8 sub_800D550(u8 a0, u16 a1)
-{
- u16 imeBak;
- if (gUnknown_03004140.unk_09 && a0 == 0 && gUnknown_03004140.unk_30)
- {
- return 5;
- }
- imeBak = REG_IME;
- REG_IME = 0;
- gUnknown_03004140.unk_09 = a0;
- gUnknown_03004140.unk_32 = a1;
- REG_IME = imeBak;
- return 0;
-}
-
-u8 sub_800D594(u16 a0)
-{
- if (gRfuLinkStatus->sendSlotNIFlag | gRfuLinkStatus->recvSlotNIFlag)
- {
- gUnknown_03004140.unk_14 = 6;
- sub_800D30C(0xf3, 0x01);
- return 6;
- }
- gUnknown_03004140.unk_18 = a0;
- return 0;
-}
-
-u8 sub_800D5D0(u8 a0)
-{
- if (gUnknown_03004140.unk_04 == 9 || gUnknown_03004140.unk_04 == 10 || gUnknown_03004140.unk_04 == 11)
- {
- gUnknown_03004140.unk_14 = 7;
- sub_800D30C(0xf3, 0x01);
- return 7;
- }
- if (a0)
- {
- gUnknown_03004140.unk_0b = 1;
- }
- else
- {
- gUnknown_03004140.unk_0b = 0;
- }
- return 0;
-}
-
-static void sub_800D610(void)
-{
- if (gUnknown_03004140.unk_02)
- {
- gUnknown_03004140.unk_02 = 0;
- sub_800D30C(0x45, 0x00);
- }
-}
-
-void sub_800D630(void)
-{
- if (gUnknown_03004140.unk_02 == 0)
- {
- sub_800D30C(0x45, 0x00);
- }
- else if (gUnknown_03004140.unk_02 == 1)
- {
- gUnknown_03004140.unk_02 = 2;
- }
-}
-
-void sub_800D658(void)
-{
- if (gUnknown_03004140.unk_07)
- {
- switch (gUnknown_03004140.unk_04)
- {
- case 5:
- gUnknown_03004140.unk_07 = 3;
- gUnknown_03004140.unk_04 = 9;
- break;
- case 6:
- gUnknown_03004140.unk_07 = 2;
- gUnknown_03004140.unk_1a = 1;
- break;
- case 7:
- case 8:
- gUnknown_03004140.unk_07 = 2;
- break;
- case 9:
- case 10:
- gUnknown_03004140.unk_1a = 40;
- break;
- case 11:
- gUnknown_03004140.unk_1a = 40;
- gUnknown_03004140.unk_04 = 10;
- break;
- }
- }
-}
-
-// TODO: Is there a file boundary here?
-
-void sub_800D6C8(struct UnkRfuStruct_2_Sub_124 *ptr)
-{
- s32 i;
- s32 j;
-
- for (i = 0; i < 32; i++)
- {
- for (j = 0; j < 70; j++)
- {
- ptr->unk_00[i][j] = 0;
- }
- }
- ptr->unk_8c1 = 0;
- ptr->unk_8c0 = 0;
- ptr->unk_8c2 = 0;
- ptr->unk_8c3 = 0;
-}
-
-void sub_800D724(struct UnkRfuStruct_2_Sub_9e8 *ptr)
-{
- s32 i;
- s32 j;
-
- for (i = 0; i < 40; i++)
- {
- for (j = 0; j < 14; j++)
- {
- ptr->unk_00[i][j] = 0;
- }
- }
- ptr->unk_231 = 0;
- ptr->unk_230 = 0;
- ptr->unk_232 = 0;
- ptr->unk_233 = 0;
-}
-
-void sub_800D780(struct UnkRfuStruct_Sub_Unused *ptr)
-{
- s32 i;
- s32 j;
-
- for (i = 0; i < 2; i++)
- {
- for (j = 0; j < 256; j++)
- {
- ptr->unk_00[i][j] = 0;
- }
- }
- ptr->unk_201 = 0;
- ptr->unk_200 = 0;
- ptr->unk_202 = 0;
- ptr->unk_203 = 0;
-}
-
-void sub_800D7D8(struct UnkRfuStruct_2_Sub_124 *q1, u8 *q2)
-{
- s32 i;
- u16 imeBak;
- u8 count;
-
- if (q1->unk_8c2 < 32)
- {
- imeBak = REG_IME;
- REG_IME = 0;
- count = 0;
- for (i = 0; i < 70; i += 14)
- {
- if (q2[i] == 0 && q2[i + 1] == 0)
- {
- count++;
- }
- }
- if (count != 5)
- {
- for (i = 0; i < 70; i++)
- {
- q1->unk_00[q1->unk_8c0][i] = q2[i];
- }
- q1->unk_8c0++;
- q1->unk_8c0 %= 32;
- q1->unk_8c2++;
- for (i = 0; i < 70; i++)
- {
- q2[i] = 0;
- }
- }
- REG_IME = imeBak;
- }
- else
- {
- q1->unk_8c3 = 1;
- }
-}
-
-void sub_800D888(struct UnkRfuStruct_2_Sub_9e8 *q1, u8 *q2)
-{
- s32 i;
- u16 imeBak;
-
- if (q1->unk_232 < 40)
- {
- imeBak = REG_IME;
- REG_IME = 0;
- for (i = 0; i < 14; i++)
- {
- if (q2[i] != 0)
- {
- break;
- }
- }
- if (i != 14)
- {
- for (i = 0; i < 14; i++)
- {
- q1->unk_00[q1->unk_230][i] = q2[i];
- }
- q1->unk_230++;
- q1->unk_230 %= 40;
- q1->unk_232++;
- for (i = 0; i < 14; i++)
- {
- q2[i] = 0;
- }
- }
- REG_IME = imeBak;
- }
- else
- {
- q1->unk_233 = 1;
- }
-}
-
-bool8 sub_800D934(struct UnkRfuStruct_2_Sub_124 *q1, u8 *q2)
-{
- u16 imeBak;
- s32 i;
-
- imeBak = REG_IME;
- REG_IME = 0;
- if (q1->unk_8c0 == q1->unk_8c1 || q1->unk_8c3 != 0)
- {
- for (i = 0; i < 70; i++)
- {
- q2[i] = 0;
- }
- REG_IME = imeBak;
- return FALSE;
- }
- for (i = 0; i < 70; i++)
- {
- q2[i] = q1->unk_00[q1->unk_8c1][i];
- }
- q1->unk_8c1++;
- q1->unk_8c1 %= 32;
- q1->unk_8c2--;
- REG_IME = imeBak;
- return TRUE;
-}
-
-bool8 sub_800D9DC(struct UnkRfuStruct_2_Sub_9e8 *q1, u8 *q2)
-{
- s32 i;
- u16 imeBak;
-
- if (q1->unk_230 == q1->unk_231 || q1->unk_233 != 0)
- {
- return FALSE;
- }
- imeBak = REG_IME;
- REG_IME = 0;
- for (i = 0; i < 14; i++)
- {
- q2[i] = q1->unk_00[q1->unk_231][i];
- }
- q1->unk_231++;
- q1->unk_231 %= 40;
- q1->unk_232--;
- REG_IME = imeBak;
- return TRUE;
-}
-
-void sub_800DA68(struct UnkRfuStruct_2_Sub_c1c *q1, const u8 *q2)
-{
- s32 i;
-
- if (q2[1] == 0)
- {
- sub_800DAC8(q1, NULL);
- }
- else
- {
- for (i = 0; i < 14; i++)
- {
- q1->unk_00[q1->unk_1c][i] = q2[i];
- }
- q1->unk_1c++;
- q1->unk_1c %= 2;
- if (q1->unk_1e < 2)
- {
- q1->unk_1e++;
- }
- else
- {
- q1->unk_1d = q1->unk_1c;
- }
- }
-}
-
-static bool8 sub_800DAC8(struct UnkRfuStruct_2_Sub_c1c *q1, u8 *q2)
-{
- s32 i;
-
- if (q1->unk_1e == 0)
- {
- return FALSE;
- }
- if (q2 != NULL)
- {
- for (i = 0; i < 14; i++)
- {
- q2[i] = q1->unk_00[q1->unk_1d][i];
- }
- }
- q1->unk_1d++;
- q1->unk_1d %= 2;
- q1->unk_1e--;
- return TRUE;
-}
-
-void sub_800DB18(struct UnkRfuStruct_Sub_Unused *q1, u8 *q2)
-{
- s32 i;
-
- if (q1->unk_202 < 2)
- {
- for (i = 0; i < 256; i++)
- {
- q1->unk_00[q1->unk_200][i] = q2[i];
- }
- q1->unk_200++;
- q1->unk_200 %= 2;
- q1->unk_202++;
- }
- else
- {
- q1->unk_203 = 1;
- }
-}
-
-bool8 sub_800DB84(struct UnkRfuStruct_Sub_Unused *q1, u8 *q2)
-{
- s32 i;
-
- if (q1->unk_200 == q1->unk_201 || q1->unk_203)
- {
- return FALSE;
- }
- for (i = 0; i < 256; i++)
- {
- q2[i] = q1->unk_00[q1->unk_201][i];
- }
- q1->unk_201++;
- q1->unk_201 %= 2;
- q1->unk_202--;
- return TRUE;
-}
-
-void sub_800DBF8(u8 *q1, u8 mode)
-{
- s32 i;
- u8 rval;
- u16 r5 = 0;
- switch (mode)
- {
- case 0:
- for (i = 0; i < 200; i++)
- {
- q1[i] = i + 1;
- r5 += i + 1;
- }
- *((u16 *)(q1 + i)) = r5;
- break;
- case 1:
- for (i = 0; i < 100; i++)
- {
- q1[i] = i + 1;
- r5 += i + 1;
- }
- *((u16 *)(q1 + 200)) = r5;
- break;
- case 2:
- for (i = 0; i < 200; i++)
- {
- rval = Random();
- q1[i] = rval;
- r5 += rval;
- }
- *((u16 *)(q1 + i)) = r5;
- break;
- case 3:
- for (i = 0; i < 200; i++)
- {
- q1[i] = i + 1 + gUnknown_03000D74;
- r5 += (i + 1 + gUnknown_03000D74) & 0xFF;
- }
- *((u16 *)(q1 + i)) = r5;
- gUnknown_03000D74++;
- break;
- }
-}
-
-// File boundary here maybe?
-
-void PkmnStrToASCII(u8 *q1, const u8 *q2)
-{
- s32 i;
-
- for (i = 0; q2[i] != EOS; i++)
- {
- q1[i] = sWireless_RSEtoASCIITable[q2[i]];
- }
- q1[i] = 0;
-}
-
-void ASCIIToPkmnStr(u8 *q1, const u8 *q2)
-{
- s32 i;
-
- for (i = 0; q2[i] != 0; i++)
- {
- q1[i] = sWireless_ASCIItoRSETable[q2[i]];
- }
- q1[i] = EOS;
-}
-
-#ifdef NONMATCHING
-u8 sub_800DD1C(u8 maxFlags)
-{
- u8 flagCount = 0;
- u32 flags = gRfuLinkStatus->connSlotFlag;
- u8 i;
-
- if (gRfuLinkStatus->parentChild == 1)
- {
- for (i = 0; i < 4; flags >>= 1, i++)
- {
- if (flags & 1)
- {
- if (maxFlags == flagCount + 1)
- return gRfuLinkStatus->strength[i];
- flagCount++;
- }
- }
- }
- else
- {
- for (i = 0; i < 4; flags >>= 1, i++)
- {
- if (flags & 1)
- return gRfuLinkStatus->strength[i];
- }
- }
- return 0;
-}
-#else
-NAKED u8 sub_800DD1C(u8 maxFlags)
-{
- asm_unified("\tpush {r4-r7,lr}\n"
- "\tlsls r0, 24\n"
- "\tlsrs r5, r0, 24\n"
- "\tmovs r6, 0\n"
- "\tldr r0, =gRfuLinkStatus\n"
- "\tldr r4, [r0]\n"
- "\tldrb r2, [r4, 0x2]\n"
- "\tldrb r1, [r4]\n"
- "\tadds r7, r0, 0\n"
- "\tcmp r1, 0x1\n"
- "\tbne _0800DD72\n"
- "\tmovs r3, 0\n"
- "\tands r1, r2\n"
- "\tcmp r1, 0\n"
- "\tbeq _0800DD4E\n"
- "\tcmp r5, 0x1\n"
- "\tbne _0800DD48\n"
- "\tldrb r0, [r4, 0xA]\n"
- "\tb _0800DD8C\n"
- "\t.pool\n"
- "_0800DD48:\n"
- "\tadds r0, r6, 0x1\n"
- "\tlsls r0, 24\n"
- "\tlsrs r6, r0, 24\n"
- "_0800DD4E:\n"
- "\tlsrs r2, 1\n"
- "\tadds r0, r3, 0x1\n"
- "\tlsls r0, 24\n"
- "\tlsrs r3, r0, 24\n"
- "\tcmp r3, 0x3\n"
- "\tbhi _0800DD8A\n"
- "\tmovs r0, 0x1\n"
- "\tands r0, r2\n"
- "\tcmp r0, 0\n"
- "\tbeq _0800DD4E\n"
- "\tadds r0, r6, 0x1\n"
- "\tcmp r5, r0\n"
- "\tbne _0800DD48\n"
- "_0800DD68:\n"
- "\tldr r0, [r7]\n"
- "\tadds r0, 0xA\n"
- "\tadds r0, r3\n"
- "\tldrb r0, [r0]\n"
- "\tb _0800DD8C\n"
- "_0800DD72:\n"
- "\tmovs r3, 0\n"
- "\tmovs r1, 0x1\n"
- "_0800DD76:\n"
- "\tadds r0, r2, 0\n"
- "\tands r0, r1\n"
- "\tcmp r0, 0\n"
- "\tbne _0800DD68\n"
- "\tlsrs r2, 1\n"
- "\tadds r0, r3, 0x1\n"
- "\tlsls r0, 24\n"
- "\tlsrs r3, r0, 24\n"
- "\tcmp r3, 0x3\n"
- "\tbls _0800DD76\n"
- "_0800DD8A:\n"
- "\tmovs r0, 0\n"
- "_0800DD8C:\n"
- "\tpop {r4-r7}\n"
- "\tpop {r1}\n"
- "\tbx r1");
-}
-#endif
-
-void sub_800DD94(struct UnkLinkRfuStruct_02022B14 *data, u8 r9, bool32 r2, s32 r3)
-{
- s32 i;
-
- for (i = 0; i < 2; i++)
- {
- data->unk_00.playerTrainerId[i] = gSaveBlock2Ptr->playerTrainerId[i];
- }
- for (i = 0; i < 4; i++)
- {
- data->unk_04[i] = r3;
- r3 >>= 8;
- }
- data->playerGender = gSaveBlock2Ptr->playerGender;
- data->unk_0a_0 = r9;
- data->unk_0a_7 = r2;
- data->unk_00.unk_00_0 = 2;
- data->unk_00.unk_01_2 = 3;
- data->unk_00.unk_00_4 = 0;
- data->unk_00.unk_00_5 = 0;
- data->unk_00.unk_00_6 = 0;
- data->unk_00.isChampion = FlagGet(FLAG_IS_CHAMPION);
- data->unk_00.hasNationalDex = IsNationalPokedexEnabled();
- data->unk_00.gameClear = FlagGet(FLAG_SYS_GAME_CLEAR);
-}
-
-bool8 sub_800DE7C(struct UnkLinkRfuStruct_02022B14 *buff1, u8 *buff2, u8 idx)
-{
- bool8 retVal;
-
- if (gUnknown_03004140.unk_06 == 1)
- {
- retVal = TRUE;
- if (sub_8010454(gRfuLinkStatus->partner[idx].serialNo) && ((gRfuLinkStatus->getNameFlag >> idx) & 1))
- {
- memcpy(buff1, gRfuLinkStatus->partner[idx].gname, 0xD);
- memcpy(buff2, gRfuLinkStatus->partner[idx].uname, PLAYER_NAME_LENGTH + 1);
- }
- else
- {
- memset(buff1, 0, 0xD);
- memset(buff2, 0, PLAYER_NAME_LENGTH + 1);
- }
- }
- else
- {
- retVal = FALSE;
- if (sub_8010454(gRfuLinkStatus->partner[idx].serialNo))
- {
- memcpy(buff1, gRfuLinkStatus->partner[idx].gname, 0xD);
- memcpy(buff2, gRfuLinkStatus->partner[idx].uname, PLAYER_NAME_LENGTH + 1);
- }
- else
- {
- memset(buff1, 0, 0xD);
- memset(buff2, 0, PLAYER_NAME_LENGTH + 1);
- }
- }
- return retVal;
-}
-
-bool8 sub_800DF34(struct UnkLinkRfuStruct_02022B14 *buff1, u8 *buff2, u8 idx)
-{
- bool8 retVal = FALSE;
- if (gRfuLinkStatus->partner[idx].serialNo == 0x7F7D)
- {
- memcpy(buff1, gRfuLinkStatus->partner[idx].gname, 0xD);
- memcpy(buff2, gRfuLinkStatus->partner[idx].uname, 8);
- retVal = TRUE;
- }
- else
- {
- memset(buff1, 0, 0xD);
- memset(buff2, 0, 8);
- }
- return retVal;
-}
-
-void sub_800DF90(struct UnkLinkRfuStruct_02022B14 *buff1, u8 *buff2)
-{
- memcpy(buff1, &gUnknown_02022B14, 0xD);
- memcpy(buff2, gUnknown_02022B22, 8);
-}
-
-void CreateWirelessStatusIndicatorSprite(u8 x, u8 y)
-{
- u8 sprId;
-
- if (x == 0 && y == 0)
- {
- x = 0xE7;
- y = 0x08;
- }
- if (gRfuLinkStatus->parentChild == 1)
- {
- sprId = CreateSprite(&sWirelessStatusIndicatorSpriteTemplate, x, y, 0);
- gSprites[sprId].data[7] = 0x1234;
- gSprites[sprId].data[6] = GetSpriteTileStartByTag(sWirelessStatusIndicatorSpriteSheet.tag);
- gSprites[sprId].invisible = TRUE;
- gWirelessStatusIndicatorSpriteId = sprId;
- }
- else
- {
- gWirelessStatusIndicatorSpriteId = CreateSprite(&sWirelessStatusIndicatorSpriteTemplate, x, y, 0);
- gSprites[gWirelessStatusIndicatorSpriteId].data[7] = 0x1234;
- gSprites[gWirelessStatusIndicatorSpriteId].data[6] = GetSpriteTileStartByTag(sWirelessStatusIndicatorSpriteSheet.tag);
- gSprites[gWirelessStatusIndicatorSpriteId].invisible = TRUE;
- }
-}
-
-void DestroyWirelessStatusIndicatorSprite(void)
-{
- if (gSprites[gWirelessStatusIndicatorSpriteId].data[7] == 0x1234)
- {
- gSprites[gWirelessStatusIndicatorSpriteId].data[7] = 0;
- DestroySprite(&gSprites[gWirelessStatusIndicatorSpriteId]);
- gMain.oamBuffer[125] = gDummyOamData;
- CpuCopy16(&gDummyOamData, (struct OamData *)OAM + 125, sizeof(struct OamData));
- }
-}
-
-void LoadWirelessStatusIndicatorSpriteGfx(void)
-{
- if (GetSpriteTileStartByTag(sWirelessStatusIndicatorSpriteSheet.tag) == 0xFFFF)
- {
- LoadCompressedSpriteSheet(&sWirelessStatusIndicatorSpriteSheet);
- }
- LoadSpritePalette(&sWirelessStatusIndicatorSpritePalette);
- gWirelessStatusIndicatorSpriteId = 0xFF;
-}
-
-u8 sub_800E124(void)
-{
- u8 i;
- u8 flags = gRfuLinkStatus->connSlotFlag;
- for (i = 0; i < 4; i++)
- {
- if (flags & 1)
- {
- return gRfuLinkStatus->strength[i];
- }
- flags >>= 1;
- }
- return 0;
-}
-
-void sub_800E15C(struct Sprite *sprite, s32 signalStrengthAnimNum)
-{
- if (sprite->data[2] != signalStrengthAnimNum)
- {
- sprite->data[2] = signalStrengthAnimNum;
- sprite->data[3] = 0;
- sprite->data[4] = 0;
- }
-}
-
-void sub_800E174(void)
-{
- if (gWirelessStatusIndicatorSpriteId != 0xFF && gSprites[gWirelessStatusIndicatorSpriteId].data[7] == 0x1234)
- {
- struct Sprite *sprite = &gSprites[gWirelessStatusIndicatorSpriteId];
- u8 signalStrength = 255;
- u8 i = 0;
- if (gRfuLinkStatus->parentChild == 1)
- {
- for (i = 0; i < GetLinkPlayerCount() - 1; i++)
- {
- if (signalStrength >= sub_800DD1C(i + 1))
- {
- signalStrength = sub_800DD1C(i + 1);
- }
- }
- }
- else
- {
- signalStrength = sub_800E124();
- }
- if (sub_8012224() == TRUE)
- {
- sprite->data[0] = 4;
- }
- else if (signalStrength < 25)
- {
- sprite->data[0] = 3;
- }
- else if (signalStrength >= 25 && signalStrength < 127)
- {
- sprite->data[0] = 2;
- }
- else if (signalStrength >= 127 && signalStrength < 229)
- {
- sprite->data[0] = 1;
- }
- else if (signalStrength >= 229)
- {
- sprite->data[0] = 0;
- }
- if (sprite->data[0] != sprite->data[1])
- {
- sub_800E15C(sprite, sprite->data[0]);
- sprite->data[1] = sprite->data[0];
- }
- if (sprite->anims[sprite->data[2]][sprite->data[4]].frame.duration < sprite->data[3])
- {
- sprite->data[4]++;
- sprite->data[3] = 0;
- if (sprite->anims[sprite->data[2]][sprite->data[4]].type == -2)
- {
- sprite->data[4] = 0;
- }
- }
- else
- {
- sprite->data[3]++;
- }
- gMain.oamBuffer[125] = sWirelessStatusIndicatorOamData;
- gMain.oamBuffer[125].x = sprite->pos1.x + sprite->centerToCornerVecX;
- gMain.oamBuffer[125].y = sprite->pos1.y + sprite->centerToCornerVecY;
- gMain.oamBuffer[125].paletteNum = sprite->oam.paletteNum;
- gMain.oamBuffer[125].tileNum = sprite->data[6] + sprite->anims[sprite->data[2]][sprite->data[4]].frame.imageValue;
- CpuCopy16(gMain.oamBuffer + 125, (struct OamData *)OAM + 125, sizeof(struct OamData));
- if (sub_8011A74() == 1)
- {
- DestroyWirelessStatusIndicatorSprite();
- }
- }
-}
-
-void CopyTrainerRecord(struct TrainerNameRecord *dest, u32 trainerId, const u8 *name)
-{
- dest->trainerId = trainerId;
- StringCopy(dest->trainerName, name);
-}
-
-bool32 NameIsNotEmpty(const u8 *name)
-{
- s32 i;
-
- for (i = 0; i < PLAYER_NAME_LENGTH + 1; i++)
- {
- if (name[i] != 0)
- {
- return TRUE;
- }
- }
- return FALSE;
-}
-
-// Save the currently connected players into the trainer records, shifting all previous records down.
-void RecordMixTrainerNames(void)
-{
- if (gWirelessCommType != 0)
- {
- s32 i;
- s32 j;
- s32 nextSpace;
- s32 connectedTrainerRecordIndices[5];
- struct TrainerNameRecord *newRecords = calloc(20, sizeof(struct TrainerNameRecord));
-
- // Check if we already have a record saved for connected trainers.
- for (i = 0; i < GetLinkPlayerCount(); i++)
- {
- connectedTrainerRecordIndices[i] = -1;
- for (j = 0; j < 20; j++)
- {
- if ((u16)gLinkPlayers[i].trainerId == gSaveBlock1Ptr->trainerNameRecords[j].trainerId && StringCompare(gLinkPlayers[i].name, gSaveBlock1Ptr->trainerNameRecords[j].trainerName) == 0)
- {
- connectedTrainerRecordIndices[i] = j;
- }
- }
- }
-
- // Save the connected trainers first, at the top of the list.
- nextSpace = 0;
- for (i = 0; i < GetLinkPlayerCount(); i++)
- {
- if (i != GetMultiplayerId() && gLinkPlayers[i].language != LANGUAGE_JAPANESE)
- {
- CopyTrainerRecord(&newRecords[nextSpace], (u16)gLinkPlayers[i].trainerId, gLinkPlayers[i].name);
-
- // If we already had a record for this trainer, wipe it so that the next step doesn't duplicate it.
- if (connectedTrainerRecordIndices[i] >= 0)
- {
- memset(gSaveBlock1Ptr->trainerNameRecords[connectedTrainerRecordIndices[i]].trainerName, 0, 8);
- }
- nextSpace++;
- }
- }
-
- // Copy all non-empty records to the new list, in the order they appear on the old list. If the list is full,
- // the last (oldest) records will be dropped.
- for (i = 0; i < 20; i++)
- {
- if (NameIsNotEmpty(gSaveBlock1Ptr->trainerNameRecords[i].trainerName))
- {
- CopyTrainerRecord(&newRecords[nextSpace], gSaveBlock1Ptr->trainerNameRecords[i].trainerId, gSaveBlock1Ptr->trainerNameRecords[i].trainerName);
- if (++nextSpace >= 20)
- {
- break;
- }
- }
- }
-
- // Finalize the new list, and clean up.
- memcpy(gSaveBlock1Ptr->trainerNameRecords, newRecords, 20 * sizeof(struct TrainerNameRecord));
- free(newRecords);
- }
-}
-
-bool32 sub_800E540(u16 id, u8 *name)
-{
- s32 i;
-
- for (i = 0; i < 20; i++)
- {
- if (StringCompare(gSaveBlock1Ptr->trainerNameRecords[i].trainerName, name) == 0 && gSaveBlock1Ptr->trainerNameRecords[i].trainerId == id)
- {
- return TRUE;
- }
- if (!NameIsNotEmpty(gSaveBlock1Ptr->trainerNameRecords[i].trainerName))
- {
- return FALSE;
- }
- }
- return FALSE;
-}
-
-void WipeTrainerNameRecords(void)
-{
- s32 i;
-
- for (i = 0; i < 20; i++)
- {
- gSaveBlock1Ptr->trainerNameRecords[i].trainerId = 0;
- CpuFill16(0, gSaveBlock1Ptr->trainerNameRecords[i].trainerName, 8);
- }
-}
-
-void nullsub_5(const void *unused_0, u8 unused_1, u8 unused_2)
-{
- // debug?
-}
-
-void nullsub_13(u16 unused_0, u8 unused_1, u8 unused_2, u8 unused_3)
-{
-
-}
-
-void sub_800E604(void)
-{
- s32 i;
- u8 unk_ee_bak = gUnknown_03005000.unk_ee;
- CpuFill16(0, &gUnknown_03005000, sizeof gUnknown_03005000);
- gUnknown_03005000.unk_ee = unk_ee_bak;
- gUnknown_03005000.unk_0c = 0xFF;
- if (gUnknown_03005000.unk_ee != 4)
- {
- gUnknown_03005000.unk_ee = 0;
- }
- for (i = 0; i < 5; i++)
- {
- sub_800FCC4(gUnknown_03005000.unk_80 + i);
- }
- sub_800FCC4(&gUnknown_03005000.unk_6c);
- sub_800D6C8(&gUnknown_03005000.unk_124);
- sub_800D724(&gUnknown_03005000.unk_9e8);
- CpuFill16(0, gSendCmd, sizeof gSendCmd);
- CpuFill16(0, gRecvCmds, sizeof gRecvCmds);
- CpuFill16(0, gLinkPlayers, sizeof gLinkPlayers);
-}
-
-void sub_800E6D0(void)
-{
- IntrFunc serialIntr = gIntrTable[1];
- IntrFunc timerIntr = gIntrTable[2];
- sub_800E700();
- rfu_REQ_stopMode();
- rfu_waitREQComplete();
- REG_IME = 0;
- gIntrTable[1] = serialIntr;
- gIntrTable[2] = timerIntr;
- REG_IME = INTR_FLAG_VBLANK;
-}
-
-void sub_800E700(void)
-{
- if (!rfu_initializeAPI((void *)gUnknown_03004140.unk_50, sizeof gUnknown_03004140.unk_50, gIntrTable + 1, TRUE))
- {
- gLinkType = 0;
- sub_800AAF4();
- sub_80111B0(0);
- sub_800E604();
- rfu_setTimerInterrupt(3, gIntrTable + 2);
- }
-}
-
-void sub_800E748(u8 taskId)
-{
- sub_8010750();
- switch (gUnknown_03005000.unk_04)
- {
- case 0:
- sub_800BFCC(&gUnknown_02022B2C);
- gUnknown_03005000.unk_04 = 1;
- gTasks[taskId].data[1] = 1;
- break;
- case 1:
- break;
- case 2:
- sub_800C054(gUnknown_03005000.unk_0c, 0, 240, gUnknown_082ED6E0);
- gUnknown_03005000.unk_04 = 3;
- gTasks[taskId].data[1] = 6;
- break;
- case 3:
- break;
- case 4:
- sub_800C27C(FALSE);
- gUnknown_03005000.unk_04 = 5;
- break;
- case 5:
- break;
- case 18:
- gUnknown_03005000.unk_cdb = 0;
- sub_800D52C(sub_800EDBC);
- sub_800EAB4();
- sub_800EAFC();
- gUnknown_03005000.unk_04 = 20;
- gTasks[taskId].data[1] = 8;
- CreateTask(sub_801084C, 5);
- DestroyTask(taskId);
- break;
- }
-}
-
-s32 sub_800E87C(u8 idx)
-{
- return gUnknown_082ED6A5[idx];
-}
-
-void sub_800E88C(s32 r2, s32 r5)
-{
- u8 i;
- u8 r4 = 1;
- s32 r1 = r2;
- s32 r6 = 0;
- if (r5 == -1)
- {
- for (i = 0; i < 4; r2 >>= 1, i++)
- {
- if (r2 & 1)
- {
- gUnknown_03005000.unk_cde[i] = r4;
- r4++;
- }
- }
- }
- else
- {
- for (i = 0; i < 4; r1 >>= 1, i++)
- {
- if (!(r1 & 1))
- {
- gUnknown_03005000.unk_cde[i] = 0;
- }
- }
- for (r4 = 4; r4 != 0; r4--)
- {
- for (i = 0; i < 4 && gUnknown_03005000.unk_cde[i] != r4; i++);
- if (i == 4)
- {
- r6 = r4;
- }
- }
- for (r5 &= ~r2, i = 0; i < 4; r5 >>= 1, i++)
- {
- if (r5 & 1)
- {
- gUnknown_03005000.unk_cde[i] = r6++;
- }
- }
- }
-}
-
-void sub_800E94C(u8 taskId)
-{
- switch (gUnknown_03005000.unk_04)
- {
- case 0:
- sub_800BFCC(&gUnknown_082ED608);
- gUnknown_03005000.unk_04 = 1;
- gTasks[taskId].data[1] = 1;
- break;
- case 1:
- break;
- case 6:
- sub_800C054(gUnknown_03005000.unk_0c, 0, 0xf0, gUnknown_082ED6E0);
- gUnknown_03005000.unk_04 = 7;
- gTasks[taskId].data[1] = 7;
- break;
- case 7:
- break;
- case 9:
- gTasks[taskId].data[1] = 10;
- break;
- case 11:
- switch (sub_80107A0())
- {
- case 5:
- gUnknown_03005000.unk_04 = 12;
- break;
- case 6:
- case 9:
- sub_800D630();
- gUnknown_03005000.unk_ce4 = 2;
- DestroyTask(taskId);
- break;
- }
- break;
- case 12:
- {
- u8 r5 = 1 << gUnknown_03005000.unk_c3e;
- rfu_clearSlot(12, gUnknown_03005000.unk_c3e);
- rfu_setRecvBuffer(16, gUnknown_03005000.unk_c3e, gUnknown_03005000.unk_c3f, 70);
- rfu_UNI_setSendData(r5, gUnknown_03005000.unk_4c, 14);
- gTasks[taskId].data[1] = 8;
- DestroyTask(taskId);
- if (gUnknown_02022B44.unk_0f == 0)
- {
- sub_801227C();
- gUnknown_02022B44.unk_0f++;
- }
- CreateTask(sub_801084C, 5);
- break;
- }
- }
-}
-
-static void sub_800EAB4(void)
-{
- u8 i;
- u8 r5 = gUnknown_03004140.unk_00;
- for (i = 0; i < 4; i++)
- {
- if (r5 & 1)
- {
- rfu_setRecvBuffer(16, i, gUnknown_03005000.unk_14[i], 14);
- rfu_clearSlot(3, i);
- }
- r5 >>= 1;
- }
-}
-
-static void sub_800EAFC(void)
-{
- u8 r5 = gUnknown_03004140.unk_00;
- rfu_UNI_setSendData(r5, gUnknown_03005000.unk_c87, 70);
- gUnknown_03005000.unk_cda = sub_800E87C(r5);
- gUnknown_03005000.unk_ce2 = r5;
- sub_800E88C(r5, -1);
- gUnknown_03005000.unk_0c = 1;
-}
-
-void sub_800EB44(u8 taskId)
-{
- if (sub_800F7DC()->unk_0a_0 == 0x54 && sub_8011A74() == 4)
- {
- rfu_REQ_disconnect(gUnknown_03004140.unk_00);
- rfu_waitREQComplete();
- sub_8011A64(0, 0);
- }
- switch (gUnknown_03005000.unk_04)
- {
- case 0:
- sub_800BFCC(&gUnknown_02022B2C);
- gUnknown_03005000.unk_04 = 1;
- gTasks[taskId].data[1] = 1;
- break;
- case 1:
- break;
- case 17:
- sub_800C054(2, 0, 240, gUnknown_082ED6E0);
- sub_800D52C(sub_800ED34);
- gUnknown_03005000.unk_04 = 18;
- break;
- case 18:
- break;
- case 13:
- if (rfu_UNI_setSendData(1 << gUnknown_03005000.unk_c3e, gUnknown_03005000.unk_4c, 14) == 0)
- {
- gUnknown_03005000.unk_0c = 0;
- DestroyTask(taskId);
- if (gTasks[taskId].data[7])
- {
- CreateTask(sub_8010D0C, 1);
- }
- else
- {
- CreateTask(sub_801084C, 5);
- }
- }
- break;
- case 14:
- sub_800C27C(0);
- gUnknown_03005000.unk_04 = 15;
- break;
- case 15:
- break;
- case 16:
- gUnknown_03005000.unk_cdb = 0;
- sub_800D52C(sub_800EDBC);
- sub_8011068(1);
- sub_800EAB4();
- sub_800EAFC();
- gUnknown_03005000.unk_04 = 20;
- gTasks[taskId].data[1] = 8;
- gUnknown_03005000.unk_0c = 1;
- CreateTask(sub_801084C, 5);
- gUnknown_03005000.unk_ce8 = 1;
- DestroyTask(taskId);
- break;
- }
-}
-
-void sub_800ED10(void)
-{
- sub_800C054(1, 0, 240, gUnknown_082ED6E0);
-}
-
-void sub_800ED28(void)
-{
- sub_800C27C(FALSE);
-}
-
-void sub_800ED34(u16 unused)
-{
- s32 i;
-
- for (i = 0; i < 14; i++)
- {
- gUnknown_03005000.unk_4c[i] = 0;
- }
- rfu_REQ_recvData();
- rfu_waitREQComplete();
- if (gRfuSlotStatusUNI[gUnknown_03005000.unk_c3e]->recv.newDataFlag)
- {
- gUnknown_03005000.unk_cd0++;
- sub_800D7D8(&gUnknown_03005000.unk_124, gUnknown_03005000.unk_c3f);
- gUnknown_02022B44.unk_06++;
- sub_800F048();
- rfu_UNI_readySendData(gUnknown_03005000.unk_c3e);
- rfu_UNI_clearRecvNewDataFlag(gUnknown_03005000.unk_c3e);
- }
- rfu_REQ_sendData_wrapper(1);
-}
-
-static void sub_800EDBC(u16 unused)
-{
- gUnknown_03005000.unk_cdb = 1;
-}
-
-void sub_800EDD4(void)
-{
- u8 i;
-
- sub_800C048();
- if (gUnknown_03005000.unk_0c == 1)
- {
- if (FuncIsActiveTask(sub_800E748) == TRUE)
- {
- DestroyTask(gUnknown_03005000.unk_67);
- sub_800E604();
- }
- }
- else if (gUnknown_03005000.unk_0c == 0)
- {
- if (FuncIsActiveTask(sub_800E94C) == TRUE)
- {
- DestroyTask(gUnknown_03005000.unk_67);
- sub_800E604();
- }
- }
- else if (gUnknown_03005000.unk_0c == 2)
- {
- if (FuncIsActiveTask(sub_800EB44) == TRUE)
- {
- DestroyTask(gUnknown_03005000.unk_67);
- sub_800E604();
- }
- }
- for (i = 0; i < 3; i++)
- {
- if (FuncIsActiveTask(gUnknown_082ED7E0[i]) == TRUE)
- {
- DestroyTask(FindTaskIdByFunc(gUnknown_082ED7E0[i]));
- }
- }
-}
-
-void sub_800EE78(void)
-{
- gUnknown_03005000.unk_67 = CreateTask(sub_800E748, 1);
-}
-
-bool8 sub_800EE94(void)
-{
- if (gUnknown_03005000.unk_04 == 7 && gUnknown_03005000.unk_ccd)
- {
- return TRUE;
- }
- return FALSE;
-}
-
-bool32 sub_800EEBC(void)
-{
- if (gUnknown_03005000.unk_04 == 7 && !sub_800C12C(gRfuLinkStatus->partner[gUnknown_03005000.unk_c3d].id, 240))
- {
- gUnknown_03005000.unk_04 = 9;
- return TRUE;
- }
- return FALSE;
-}
-
-void sub_800EF00(void)
-{
- gUnknown_03005000.unk_67 = CreateTask(sub_800E94C, 1);
-}
-
-bool8 sub_800EF1C(void)
-{
- if (gUnknown_03004140.unk_00)
- {
- return TRUE;
- }
- return FALSE;
-}
-
-void sub_800EF38(void)
-{
- gUnknown_03005000.unk_04 = 4;
- gUnknown_03005000.unk_ce7 = gUnknown_03004140.unk_00;
-}
-
-bool32 sub_800EF58(bool32 a0)
-{
- if (gUnknown_03005000.unk_04 == 17 || a0)
- {
- gUnknown_03005000.unk_04 = 18;
- return TRUE;
- }
- return FALSE;
-}
-
-void sub_800EF7C(void)
-{
- gUnknown_03005000.unk_04 = 14;
-}
-
-void sub_800EF88(u8 a0)
-{
- u8 i;
-
- for (i = 0; i < 4; i++)
- {
- if (a0 & 1)
- {
- rfu_UNI_readySendData(i);
- break;
- }
- a0 >>= 1;
- }
-}
-
-void sub_800EFB0(void)
-{
- s32 i, j;
-
- for (i = 0; i < 5; i++)
- {
- struct UnkRfuStruct_2 *ptr = &gUnknown_03005000;
- for (j = 0; j < 7; j++)
- {
- ptr->unk_c87[i][j][1] = gRecvCmds[i][j] >> 8;
- ptr->unk_c87[i][j][0] = gRecvCmds[i][j];
- }
- }
- CpuFill16(0, gRecvCmds, sizeof gRecvCmds);
-}
-
-void sub_800F014(void)
-{
- s32 i;
- for (i = 0; i < 7; i++)
- {
- gRecvCmds[0][i] = gSendCmd[i];
- }
- for (i = 0; i < 7; i++)
- {
- gSendCmd[i] = 0;
- }
-}
-
-static void sub_800F048(void)
-{
- if (gUnknown_03005000.unk_c3c)
- {
- u8 r2 = sub_800DAC8(&gUnknown_03005000.unk_c1c, gUnknown_03005000.unk_4c);
- if (gUnknown_03005000.unk_c1c.unk_1e == 0)
- {
- gUnknown_03005000.unk_c3c = 0;
- }
- if (r2)
- {
- return;
- }
- }
- if (gUnknown_03005000.unk_c3c == 0)
- {
- sub_800D9DC(&gUnknown_03005000.unk_9e8, gUnknown_03005000.unk_4c);
- sub_800DA68(&gUnknown_03005000.unk_c1c, gUnknown_03005000.unk_4c);
- }
-}
-
-bool32 IsRfuRecvQueueEmpty(void)
-{
- s32 i;
- s32 j;
-
- if (gRfuLinkStatus->sendSlotUNIFlag == 0)
- {
- return FALSE;
- }
- for (i = 0; i < 5; i++)
- {
- for (j = 0; j < 7; j++)
- {
- if (gRecvCmds[i][j] != 0)
- {
- return FALSE;
- }
- }
- }
- return TRUE;
-}
-
-bool32 sub_800F0F8(void)
-{
- if (gUnknown_03005000.unk_04 < 20)
- {
- rfu_REQ_recvData();
- rfu_waitREQComplete();
- rfu_REQ_sendData_wrapper(0);
- }
- else
- {
- gUnknown_03005000.unk_cdb = 0;
- if ((gUnknown_03005000.unk_ce2 & gRfuLinkStatus->connSlotFlag) == gUnknown_03005000.unk_ce2 && (gUnknown_03005000.unk_ce2 & gRfuLinkStatus->connSlotFlag))
- {
- if (!gUnknown_03005000.unk_cdc)
- {
- if (gUnknown_03005000.unk_ce3)
- {
- sub_8011D6C(gUnknown_03005000.unk_ce3);
- gUnknown_03005000.unk_ce3 = 0;
- if (gUnknown_03005000.unk_ce4 == 1)
- {
- sub_8011A64(2, 0x8000);
- sub_8011170(0x8000);
- return FALSE;
- }
- if (!gUnknown_03004140.unk_00)
- {
- sub_800EDD4();
- gReceivedRemoteLinkPlayers = 0;
- return FALSE;
- }
- }
- sub_800EFB0();
- rfu_UNI_readySendData(gUnknown_03005000.unk_cda);
- rfu_REQ_sendData_wrapper(1);
- }
- else
- {
- rfu_REQ_PARENT_resumeRetransmitAndChange();
- }
- gUnknown_03005000.unk_0e = 1;
- }
- }
- return FALSE;
-}
-
-bool32 sub_800F1E0(void)
-{
- u16 i;
- u16 flags;
- u8 r0;
- u16 j;
- u8 retval;
-
- if (gUnknown_03005000.unk_04 >= 20 && gUnknown_03005000.unk_0e == 1)
- {
- rfu_waitREQComplete();
- while (gUnknown_03005000.unk_cdb == 0)
- {
- if (gUnknown_03005000.unk_ee != 0)
- {
- return FALSE;
- }
- }
- rfu_REQ_recvData();
- rfu_waitREQComplete();
- if ((gUnknown_03004140.unk_03 & gUnknown_03005000.unk_ce2) == gUnknown_03005000.unk_ce2)
- {
- gUnknown_03005000.unk_cdc = 0;
- gUnknown_02022B44.unk_06++;
- flags = gUnknown_03004140.unk_00;
- for (i = 0; i < 4; i++)
- {
- if (flags & 1)
- {
- if (gUnknown_03005000.unk_14[i][1])
- {
- if (gUnknown_03005000.unk_cee[i] != 0xFF && (gUnknown_03005000.unk_14[i][0] >> 5) != ((gUnknown_03005000.unk_cee[i] + 1) & 7))
- {
- if (++gUnknown_03005000.unk_cea[i] > 4)
- sub_8011170(0x8100);
- }
- else
- {
- gUnknown_03005000.unk_cee[i] = gUnknown_03005000.unk_14[i][0] / 32;
- gUnknown_03005000.unk_cea[i] = 0;
- gUnknown_03005000.unk_14[i][0] &= 0x1f;
- r0 = gUnknown_03005000.unk_cde[i];
- for (j = 0; j < 7; j++)
- {
- gRecvCmds[r0][j] = (gUnknown_03005000.unk_14[i][(j << 1) + 1] << 8) | gUnknown_03005000.unk_14[i][(j << 1) + 0];
- gUnknown_03005000.unk_14[i][(j << 1) + 1] = 0;
- gUnknown_03005000.unk_14[i][(j << 1) + 0] = 0;
- }
- }
- }
- rfu_UNI_clearRecvNewDataFlag(i);
- }
- flags >>= 1;
- }
- sub_800F014();
- sub_800F86C(0);
- sub_8010528();
- if (gUnknown_03005000.unk_ce5 && !gUnknown_03005000.unk_cd9)
- {
- gUnknown_02022B44.unk_0e = 0;
- rfu_clearSlot(3, gUnknown_03005000.unk_cda);
- for (i = 0; i < 4; i++)
- {
- if ((gUnknown_03005000.unk_ce5 >> i) & 1)
- {
- rfu_setRecvBuffer(0x10, i, gUnknown_03005000.unk_14[i], 14);
- }
- }
- sub_800E88C(gUnknown_03005000.unk_ce2, gUnknown_03005000.unk_ce2 | gUnknown_03005000.unk_ce5);
- gUnknown_03005000.unk_ce9 = gUnknown_03005000.unk_ce5;
- gUnknown_03005000.unk_ce2 |= gUnknown_03005000.unk_ce5;
- gUnknown_03005000.unk_ce5 = 0;
- rfu_UNI_setSendData(gUnknown_03005000.unk_ce2, gUnknown_03005000.unk_c87, 70);
- gUnknown_03005000.unk_cda = sub_800E87C(gUnknown_03005000.unk_ce2);
- CreateTask(sub_8010AAC, 0);
- }
- }
- else
- {
- gUnknown_03005000.unk_cdc = 1;
- gUnknown_03005000.unk_0e = 0;
- }
- gUnknown_03005000.unk_0e = 0;
- }
- retval = gUnknown_03005000.unk_cdc;
- return gRfuLinkStatus->sendSlotUNIFlag ? retval & 1 : FALSE;
-}
-
-void sub_800F498(u16 *a0, u8 *a1)
-{
- s32 i;
-
- if (a0[0])
- {
- a0[0] |= (gUnknown_03005000.unk_102 << 5);
- gUnknown_03005000.unk_102 = (gUnknown_03005000.unk_102 + 1) & 7;
- for (i = 0; i < 7; i++)
- {
- a1[2 * i + 1] = a0[i] >> 8;
- a1[2 * i + 0] = a0[i];
- }
- }
- else
- {
- for (i = 0; i < 14; i++)
- a1[i] = 0;
- }
-}
-
-bool32 sub_800F4F0(void)
-{
- u8 i;
- u8 j;
- u8 sp00[MAX_RFU_PLAYERS * (2 * (CMD_LENGTH - 1))];
- u8 sp48[2 * (CMD_LENGTH - 1)];
- u8 switchval;
-
- sub_800D934(&gUnknown_03005000.unk_124, sp00);
- for (i = 0; i < MAX_RFU_PLAYERS; i++)
- {
- for (j = 0; j < CMD_LENGTH - 1; j++)
- {
- gRecvCmds[i][j] = (sp00[i * 14 + (j << 1) + 1] << 8) | sp00[i * 14 + (j << 1) + 0];
- }
- }
- sub_800F86C(0);
- if (gUnknown_03004140.unk_02 == 0 && gUnknown_03005000.unk_ce4)
- {
- rfu_REQ_disconnect(gRfuLinkStatus->connSlotFlag | gRfuLinkStatus->linkLossSlotFlag);
- rfu_waitREQComplete();
- switchval = sub_8011A74();
- if (switchval != 1 && switchval != 6 && switchval != 9)
- sub_8011A64(2, 0x9000);
- rfu_clearAllSlot();
- gReceivedRemoteLinkPlayers = FALSE;
- gUnknown_03005000.linkRfuCallback = NULL;
- if (gUnknown_03005000.unk_ce4 == 1)
- {
- sub_8011A64(2, 0x9000);
- sub_8011170(0x9000);
- }
- gUnknown_03004140.unk_04 = gUnknown_03004140.unk_05 = 0;
- gUnknown_03005000.unk_ce4 = 0;
- }
- if (gUnknown_03005000.unk_cd0)
- {
- gUnknown_03005000.unk_cd0--;
- sub_8010528();
- sub_800F498(gSendCmd, sp48);
- sub_800D888(&gUnknown_03005000.unk_9e8, sp48);
- for (i = 0; i < CMD_LENGTH - 1; i++)
- gSendCmd[i] = 0;
- }
- return IsRfuRecvQueueEmpty();
-}
-
-void sub_800F638(u8 unused, u32 flags)
-{
- s32 i, j;
-
- const u8 *r10 = gUnknown_03005000.unk_6c.unk_04;
- for (i = 0; i < gUnknown_03005000.unk_6c.unk_02; i++)
- {
- if (!(flags & 1))
- {
- gUnknown_03000D90[0] = (~0x76ff) | i;
- for (j = 0; j < 7; j++)
- {
- gUnknown_03000D90[j + 1] = (r10[12 * i + (j << 1) + 1] << 8) | r10[12 * i + (j << 1) + 0];
- }
- for (j = 0; j < 7; j++)
- {
- gUnknown_03000D80[2 * j + 1] = gUnknown_03000D90[j] >> 8;
- gUnknown_03000D80[2 * j + 0] = gUnknown_03000D90[j];
-
- j++;j--; // Needed to match;
- }
- sub_800D888(&gUnknown_03005000.unk_9e8, gUnknown_03000D80);
- gUnknown_03005000.unk_6c.unk_0c |= (1 << i);
- }
- flags >>= 1;
- }
-}
-
-void sub_800F6FC(u8 a0)
-{
- if (gUnknown_03005000.unk_0c == 1 && a0)
- gUnknown_03005000.unk_61[a0] = 1;
- else
- gUnknown_03005000.unk_5c[a0] = 1;
-}
-
-void sub_800F728(u8 a0)
-{
- gUnknown_03005000.unk_5c[a0] = 0;
- gUnknown_03005000.unk_80[a0].unk_12 = 0;
-}
-
-u8 sub_800F74C(const u8 *a0)
-{
- u8 i;
-
- if (gUnknown_03005000.unk_0c == 1)
- return FALSE;
- for (i = 0; i < 4; i++)
- {
- gUnknown_03005000.unk_cde[i] = a0[i];
- }
- return a0[gUnknown_03005000.unk_c3e];
-}
-
-void rfu_func_080F97B8(void)
-{
- if (gReceivedRemoteLinkPlayers
- && gHeldKeyCodeToSend != LINK_KEY_CODE_NULL
- && gLinkTransferringData != TRUE)
- {
- gUnknown_03000D78[0]++;
- gHeldKeyCodeToSend |= (gUnknown_03000D78[0] << 8);
- sub_800FD14(0xbe00);
- }
-}
-
-struct UnkLinkRfuStruct_02022B14 *sub_800F7DC(void)
-{
- return &gUnknown_02022B14;
-}
-
-bool32 IsSendingKeysToRfu(void)
-{
- return gUnknown_03005000.linkRfuCallback == rfu_func_080F97B8;
-}
-
-void sub_800F804(void)
-{
- gUnknown_03005000.linkRfuCallback = rfu_func_080F97B8;
-}
-
-void ClearLinkRfuCallback(void)
-{
- gUnknown_03005000.linkRfuCallback = NULL;
-}
-
-void sub_800F820(void)
-{
- sub_800FD14(0x4400);
- if (GetMultiplayerId() == 0)
- gSendCmd[6] = GetBlenderArrowPosition();
- gUnknown_020223C0++;
-}
-
-void sub_800F850(void)
-{
- if (gUnknown_03005000.linkRfuCallback == NULL)
- gUnknown_03005000.linkRfuCallback = sub_800F820;
-}
-
-static void sub_800F86C(u8 unused)
-{
- u16 i;
- u16 j;
-
- for (i = 0; i < MAX_RFU_PLAYERS; i++)
- {
- switch (gRecvCmds[i][0] & 0xff00)
- {
- case 0x7800:
- if (gUnknown_03005000.unk_0c == 0 && gReceivedRemoteLinkPlayers != 0)
- return;
- // fallthrough
- case 0x7700:
- if (gRfuLinkStatus->parentChild == 0)
- {
- gUnknown_03005000.playerCount = gRecvCmds[i][1];
- gUnknown_03005000.unk_cce = sub_800F74C((u8 *)(gRecvCmds[i] + 2));
- }
- break;
- case 0x8800:
- if (gUnknown_03005000.unk_80[i].unk_12 == 0)
- {
- gUnknown_03005000.unk_80[i].unk_00 = 0;
- gUnknown_03005000.unk_80[i].unk_02 = gRecvCmds[i][1];
- gUnknown_03005000.unk_80[i].unk_11 = gRecvCmds[i][2];
- gUnknown_03005000.unk_80[i].unk_08 = 0;
- gUnknown_03005000.unk_80[i].unk_12 = 1;
- gUnknown_03005000.unk_5c[i] = 0;
- }
- break;
- case 0x8900:
- if (gUnknown_03005000.unk_80[i].unk_12 == 1)
- {
- gUnknown_03005000.unk_80[i].unk_00 = gRecvCmds[i][0] & 0xff;
- gUnknown_03005000.unk_80[i].unk_08 |= (1 << gUnknown_03005000.unk_80[i].unk_00);
- for (j = 0; j < 6; j++)
- gBlockRecvBuffer[i][gUnknown_03005000.unk_80[i].unk_00 * 6 + j] = gRecvCmds[i][j + 1];
- if (gUnknown_03005000.unk_80[i].unk_08 == gUnknown_082ED628[gUnknown_03005000.unk_80[i].unk_02])
- {
- gUnknown_03005000.unk_80[i].unk_12 = 2;
- sub_800F6FC(i);
- if (sub_800F7DC()->unk_0a_0 == 0x45 && gReceivedRemoteLinkPlayers != 0 && gUnknown_03005000.unk_0c == 0)
- sub_8010A70(gBlockRecvBuffer);
- }
- }
- break;
- case 0xa100:
- sub_800FE84(gUnknown_082ED6B8[gRecvCmds[i][1]].buffer, (u16)gUnknown_082ED6B8[gRecvCmds[i][1]].size);
- break;
- case 0x5f00:
- gUnknown_03005000.unk_e4[i] = 1;
- break;
- case 0x6600:
- if (gUnknown_03005000.unk_100 == gRecvCmds[i][1])
- gUnknown_03005000.unk_e9[i] = 1;
- break;
- case 0xed00:
- if (gUnknown_03005000.unk_0c == 0)
- {
- if (gReceivedRemoteLinkPlayers != 0)
- {
- if (gRecvCmds[i][1] & gRfuLinkStatus->connSlotFlag)
- {
- gReceivedRemoteLinkPlayers = 0;
- sub_800D630();
- gUnknown_03005000.unk_ce4 = gRecvCmds[i][2];
- }
- gUnknown_03005000.playerCount = gRecvCmds[i][3];
- sub_80109E8(gRecvCmds[i][1]);
- }
- }
- else
- {
- sub_800FD14(0xee00);
- gSendCmd[1] = gRecvCmds[i][1];
- gSendCmd[2] = gRecvCmds[i][2];
- gSendCmd[3] = gRecvCmds[i][3];
- }
- break;
- case 0xee00:
- if (gUnknown_03005000.unk_0c == 1)
- {
- gUnknown_03005000.unk_ce3 |= gRecvCmds[i][1];
- gUnknown_03005000.unk_ce4 = gRecvCmds[i][2];
- sub_80109E8(gRecvCmds[i][1]);
- }
- break;
- case 0x4400:
- case 0xbe00:
- gLinkPartnersHeldKeys[i] = gRecvCmds[i][1];
- break;
- }
- if (gUnknown_03005000.unk_0c == 1 && gUnknown_03005000.unk_61[i])
- {
- if (gUnknown_03005000.unk_61[i] == 4)
- {
- gUnknown_03005000.unk_5c[i] = 1;
- gUnknown_03005000.unk_61[i] = 0;
- }
- else
- gUnknown_03005000.unk_61[i]++;
- }
- }
-}
-
-bool8 sub_800FC60(void)
-{
- s32 i;
-
- for (i = 0; i < 5; i++)
- {
- if (gUnknown_03005000.unk_80[i].unk_12)
- return FALSE;
- }
- return TRUE;
-}
-
-bool8 sub_800FC88(void)
-{
- s32 i;
-
- for (i = 0; i < gUnknown_03005000.playerCount; i++)
- {
- if (gUnknown_03005000.unk_80[i].unk_12 != 2 || gUnknown_03005000.unk_5c[i] != 1)
- return FALSE;
- }
- return TRUE;
-}
-
-static void sub_800FCC4(struct UnkRfuStruct_2_Sub_6c *data)
-{
- data->unk_00 = 0;
- data->unk_02 = 0;
- data->unk_04 = NULL;
- data->unk_08 = 0;
- data->unk_10 = 0;
- data->unk_11 = 0;
- data->unk_12 = 0;
-}
-
-u8 sub_800FCD8(void)
-{
- u8 flags = 0;
- s32 i;
-
- for (i = 0; i < 5; i++)
- {
- if (gUnknown_03005000.unk_80[i].unk_12 == 2 && gUnknown_03005000.unk_5c[i] == 1)
- {
- flags |= (1 << i);
- }
- }
- return flags;
-}
-
-void sub_800FD14(u16 command)
-{
- u8 i;
- u8 *buff;
- u8 tmp;
-
- gSendCmd[0] = command;
- switch (command)
- {
- case 0x8800:
- gSendCmd[1] = gUnknown_03005000.unk_6c.unk_02;
- gSendCmd[2] = gUnknown_03005000.unk_6c.unk_11 + 0x80;
- break;
- case 0xa100:
- if (sub_800FC60())
- gSendCmd[1] = gUnknown_03005000.unk_5a;
- break;
- case 0x7700:
- case 0x7800:
- tmp = gUnknown_03005000.unk_ce2 ^ gUnknown_03005000.unk_ce3;
- gUnknown_03005000.playerCount = gUnknown_082ED695[tmp] + 1;
- gSendCmd[1] = gUnknown_03005000.playerCount;
- buff = (u8 *)(gSendCmd + 2);
- for (i = 0; i < 4; i++)
- buff[i] = gUnknown_03005000.unk_cde[i];
- break;
- case 0x6600:
- case 0x5f00:
- gSendCmd[1] = gUnknown_03005000.unk_100;
- break;
- case 0x4400:
- gSendCmd[0] = command;
- gSendCmd[1] = gMain.heldKeys;
- break;
- case 0x2f00:
- for (i = 0; i < 6; i++)
- gSendCmd[1 + i] = gUnknown_03005000.unk_f2[i];
- break;
- case 0xbe00:
- gSendCmd[1] = gHeldKeyCodeToSend;
- break;
- case 0xee00:
- break;
- case 0xed00:
- break;
- }
-}
-
-void sub_800FE50(void *a0)
-{
- if (gSendCmd[0] == 0 && !sub_8011A80())
- {
- memcpy(gUnknown_03005000.unk_f2, a0, sizeof(gUnknown_03005000.unk_f2));
- sub_800FD14(0x2f00);
- }
-}
-
-bool32 sub_800FE84(const u8 *src, size_t size)
-{
- bool8 r4;
- if (gUnknown_03005000.linkRfuCallback != NULL)
- return FALSE;
- if (gSendCmd[0] != 0)
- return FALSE;
- if (gUnknown_03005000.unk_6c.unk_10 != 0)
- {
- gUnknown_02022B44.unk_83++;
- return FALSE;
- }
- r4 = (size % 12) != 0;
- gUnknown_03005000.unk_6c.unk_11 = GetMultiplayerId();
- gUnknown_03005000.unk_6c.unk_10 = 1;
- gUnknown_03005000.unk_6c.unk_02 = (size / 12) + r4;
- gUnknown_03005000.unk_6c.unk_00 = 0;
- if (size > 0x100)
- gUnknown_03005000.unk_6c.unk_04 = src;
- else
- {
- if (src != gBlockSendBuffer)
- memcpy(gBlockSendBuffer, src, size);
- gUnknown_03005000.unk_6c.unk_04 = gBlockSendBuffer;
- }
- sub_800FD14(0x8800);
- gUnknown_03005000.linkRfuCallback = rfufunc_80F9F44;
- gUnknown_03005000.unk_5b = 0;
- return TRUE;
-}
-
-static void rfufunc_80F9F44(void)
-{
- if (gSendCmd[0] == 0)
- {
- sub_800FD14(0x8800);
- if (gUnknown_03005000.unk_0c == 1)
- {
- if (++gUnknown_03005000.unk_5b > 2)
- gUnknown_03005000.linkRfuCallback = sub_800FFB0;
- }
- else
- {
- if ((gRecvCmds[GetMultiplayerId()][0] & 0xff00) == 0x8800)
- gUnknown_03005000.linkRfuCallback = sub_800FFB0;
- }
- }
-}
-
-static void sub_800FFB0(void)
-{
- s32 i;
- const u8 *src = gUnknown_03005000.unk_6c.unk_04;
- gSendCmd[0] = 0x8900 | gUnknown_03005000.unk_6c.unk_00;
- for (i = 0; i < 7; i++)
- gSendCmd[i + 1] = (src[(i << 1) + gUnknown_03005000.unk_6c.unk_00 * 12 + 1] << 8) | src[(i << 1) + gUnknown_03005000.unk_6c.unk_00 * 12 + 0];
- gUnknown_03005000.unk_6c.unk_00++;
- if (gUnknown_03005000.unk_6c.unk_02 <= gUnknown_03005000.unk_6c.unk_00)
- {
- gUnknown_03005000.unk_6c.unk_10 = 0;
- gUnknown_03005000.linkRfuCallback = rfufunc_80FA020;
- }
-}
-
-static void rfufunc_80FA020(void)
-{
- const u8 *src = gUnknown_03005000.unk_6c.unk_04;
- u8 mpId = GetMultiplayerId();
- s32 i;
- if (gUnknown_03005000.unk_0c == 0)
- {
- gSendCmd[0] = (~0x76ff) | (gUnknown_03005000.unk_6c.unk_02 - 1);
- for (i = 0; i < 7; i++)
- gSendCmd[i + 1] = (src[(i << 1) + (gUnknown_03005000.unk_6c.unk_02 - 1) * 12 + 1] << 8) | src[(i << 1) + (gUnknown_03005000.unk_6c.unk_02 - 1) * 12 + 0];
- if ((u8)gRecvCmds[mpId][0] == gUnknown_03005000.unk_6c.unk_02 - 1)
- {
- if (gUnknown_03005000.unk_80[mpId].unk_08 != gUnknown_082ED628[gUnknown_03005000.unk_80[mpId].unk_02])
- {
- sub_800F638(mpId, gUnknown_03005000.unk_80[mpId].unk_08);
- gUnknown_02022B44.unk_64++;
- }
- else
- gUnknown_03005000.linkRfuCallback = NULL;
- }
- }
- else
- gUnknown_03005000.linkRfuCallback = NULL;
-}
-
-bool8 sub_8010100(u8 a0)
-{
- gUnknown_03005000.unk_5a = a0;
- sub_800FD14(0xa100);
- return TRUE;
-}
-
-void sub_801011C(void)
-{
- rfu_clearAllSlot();
- sub_800C048();
- gReceivedRemoteLinkPlayers = 0;
- gUnknown_03005000.unk_ef = 1;
- gUnknown_03005000.linkRfuCallback = NULL;
-}
-
-void sub_8010148(void)
-{
- rfu_REQ_disconnect(gRfuLinkStatus->connSlotFlag | gRfuLinkStatus->linkLossSlotFlag);
- rfu_waitREQComplete();
- sub_801011C();
-}
-
-void sub_8010168(void)
-{
- if (gUnknown_03005000.unk_0c == 0)
- {
- sub_800D630();
- gUnknown_03005000.unk_ce4 = 2;
- }
- else
- gUnknown_03005000.linkRfuCallback = sub_8010148;
-}
-
-void LinkRfu_FatalError(void)
-{
- sub_800D630();
- gUnknown_03005000.unk_ce4 = 1;
- gUnknown_03005000.unk_ce3 = gRfuLinkStatus->connSlotFlag | gRfuLinkStatus->linkLossSlotFlag;
-}
-
-void sub_80101CC(void)
-{
- s32 i;
- u8 playerCount = gUnknown_03005000.playerCount;
- s32 count = 0;
-
- for (i = 0; i < MAX_RFU_PLAYERS; i++)
- {
- if (gUnknown_03005000.unk_e4[i])
- count++;
- }
- if (count == playerCount)
- {
- gBattleTypeFlags &= ~BATTLE_TYPE_20;
- if (gUnknown_03005000.unk_0c == 0)
- {
- gUnknown_03005000.unk_ee = 3;
- sub_8010168();
- }
- else
- gUnknown_03005000.linkRfuCallback = sub_8010168;
- }
-}
-
-void sub_801022C(void)
-{
- if (gSendCmd[0] == 0 && gUnknown_03005000.unk_ce8 == 0)
- {
- sub_800FD14(0x5f00);
- gUnknown_03005000.linkRfuCallback = sub_80101CC;
- }
-}
-
-void sub_8010264(u8 taskId)
-{
- if (gUnknown_03005000.linkRfuCallback == NULL)
- {
- gUnknown_03005000.unk_cd9 = 1;
- gUnknown_03005000.linkRfuCallback = sub_801022C;
- DestroyTask(taskId);
- }
-}
-
-void task_add_05_task_del_08FA224_when_no_RfuFunc(void)
-{
- if (!FuncIsActiveTask(sub_8010264))
- CreateTask(sub_8010264, 5);
-}
-
-void sub_80102B8(void)
-{
- u8 playerCount;
- u8 i;
-
- if (GetMultiplayerId() != 0)
- {
- u8 r4 = gUnknown_03005000.unk_124.unk_8c2;
- if (r4 == 0 && gUnknown_03005000.unk_fe > 0x3c)
- {
- sub_800FD14(0x6600);
- gUnknown_03005000.unk_fe = r4;
- }
- }
- playerCount = GetLinkPlayerCount();
- for (i = 0; i < playerCount; i++)
- {
- if (gUnknown_03005000.unk_e9[i] == 0)
- break;
- }
- if (i == playerCount)
- {
- for (i = 0; i < MAX_RFU_PLAYERS; i++)
- gUnknown_03005000.unk_e9[i] = 0;
- gUnknown_03005000.unk_100++;
- gUnknown_03005000.linkRfuCallback = NULL;
- }
- gUnknown_03005000.unk_fe++;
-}
-
-void sub_8010358(void)
-{
- if (gUnknown_03005000.unk_124.unk_8c2 == 0 && gSendCmd[0] == 0)
- {
- sub_800FD14(0x6600);
- gUnknown_03005000.linkRfuCallback = sub_80102B8;
- }
-}
-
-void sub_8010390(void)
-{
- u8 i;
- u8 playerCount;
-
- if (GetMultiplayerId() != 0)
- {
- if (gUnknown_03005000.unk_124.unk_8c2 == 0 && gSendCmd[0] == 0)
- {
- sub_800FD14(0x6600);
- gUnknown_03005000.linkRfuCallback = sub_80102B8;
- }
- }
- else
- {
- playerCount = GetLinkPlayerCount();
- for (i = 1; i < playerCount; i++)
- {
- if (gUnknown_03005000.unk_e9[i] == 0)
- break;
- }
- if (i == playerCount)
- {
- if (gUnknown_03005000.unk_124.unk_8c2 == 0 && gSendCmd[0] == 0)
- {
- sub_800FD14(0x6600);
- gUnknown_03005000.linkRfuCallback = sub_8010358;
- }
- }
- }
-}
-
-void sub_8010434(void)
-{
- if (gUnknown_03005000.linkRfuCallback == NULL)
- {
- gUnknown_03005000.linkRfuCallback = sub_8010390;
- gUnknown_03005000.unk_fe = 0;
- }
-}
-
-bool32 sub_8010454(u32 a0)
-{
- s32 i;
- for (i = 0; gUnknown_082ED6E0[i] != a0; i++)
- {
- if (gUnknown_082ED6E0[i] == 0xFFFF)
- return FALSE;
- }
- return TRUE;
-}
-
-u8 sub_801048C(bool32 a0)
-{
- if (a0 == FALSE)
- return sub_800D550(0, 0);
- sub_800D550(1, 0x258);
- return 0;
-}
-
-void sub_80104B0(void)
-{
- gUnknown_03005000.unk_cd9 = 1;
- sub_800C27C(FALSE);
-}
-
-u8 rfu_get_multiplayer_id(void)
-{
- if (gUnknown_03005000.unk_0c == 1)
- return 0;
- return gUnknown_03005000.unk_cce;
-}
-
-u8 sub_80104F4(void)
-{
- return gUnknown_03005000.playerCount;
-}
-
-bool8 IsLinkRfuTaskFinished(void)
-{
- if (gUnknown_03005000.unk_f1 == 2)
- return FALSE;
- return gUnknown_03005000.linkRfuCallback ? FALSE : TRUE;
-}
-
-static void sub_8010528(void)
-{
- if (gUnknown_03005000.linkRfuCallback)
- gUnknown_03005000.linkRfuCallback();
-}
-
-bool8 sub_8010540(void)
-{
- s32 i;
- bool8 retval = FALSE;
- for (i = 0; i < 4; i++)
- {
- if (gUnknown_03005000.unk_cd1[i] < 5 || gUnknown_03005000.unk_cd1[i] > 6)
- {
- if (gRfuSlotStatusNI[i]->recv.state == 0x46 || gRfuSlotStatusNI[i]->recv.state == 0x48)
- {
- if (gUnknown_03005000.unk_cd5[i] == 8)
- {
- gUnknown_03005000.unk_cd1[i] = 9;
- gUnknown_03005000.unk_cd5[i] = 10;
- rfu_clearSlot(8, i);
- rfu_NI_setSendData(1 << i, 8, gUnknown_03005000.unk_cd1 + i, 1);
- retval = TRUE;
- }
-
- }
- else if (gRfuSlotStatusNI[gUnknown_03005000.unk_c3e]->recv.state == 0x47)
- rfu_clearSlot(8, i);
- {
-
- }
- }
- }
- return retval;
-}
-
-bool32 sub_80105EC(void)
-{
- u8 flags = 0;
- s32 i;
- for (i = 0; i < 4; i++)
- {
- if (gUnknown_03005000.unk_cd5[i] == 11)
- {
- flags |= (1 << i);
- gUnknown_03005000.unk_cd5[i] = 0;
- }
- }
- if (flags)
- {
- rfu_REQ_disconnect(flags);
- rfu_waitREQComplete();
- }
- for (i = 0; i < 4; i++)
- {
- if (gUnknown_03005000.unk_cd5[i] == 10 || gUnknown_03005000.unk_cd5[i] == 11)
- return TRUE;
- }
- return FALSE;
-}
-
-bool32 sub_801064C(u16 a0, const u8 *a1)
-{
- u8 r1 = sub_8011CE4(a1, a0);
- if (r1 == 0xFF)
- return TRUE;
- if (gUnknown_03005000.unk_cd1[r1] == 9)
- return TRUE;
- return FALSE;
-}
-
-void sub_8010688(u8 a0, u16 a1, const u8 *a2)
-{
- u8 r4 = sub_8011CE4(a2, a1);
- gUnknown_03005000.unk_cd1[r4] = a0;
- rfu_clearSlot(4, r4);
- rfu_NI_setSendData(1 << r4, 8, gUnknown_03005000.unk_cd1 + r4, 1);
-}
-
-void sub_80106D4(void)
-{
- gUnknown_03005000.unk_c85 = 8;
- rfu_clearSlot(4, gUnknown_03005000.unk_c3e);
- rfu_NI_setSendData(1 << gUnknown_03005000.unk_c3e, 8, &gUnknown_03005000.unk_c85, 1);
-}
-
-u32 sub_8010714(u16 a0, const u8 *a1)
-{
- u8 r0 = sub_8011CE4(a1, a0);
- if (r0 == 0xFF)
- return 2;
- if (gRfuSlotStatusNI[r0]->send.state == 0)
- return 1;
- return 0;
-}
-
-void sub_8010750(void)
-{
- s32 i;
-
- sub_8010540();
- for (i = 0; i < 4; i++)
- {
- if (gRfuSlotStatusNI[i]->send.state == 0x26 || gRfuSlotStatusNI[i]->send.state == 0x27)
- {
- if (gUnknown_03005000.unk_cd5[i] == 10)
- gUnknown_03005000.unk_cd5[i] = 11;
- rfu_clearSlot(4, i);
- }
- }
-}
-
-s32 sub_80107A0(void)
-{
- s32 retval = 0;
- if (gUnknown_03005000.unk_c85 == 8)
- {
- if (gRfuSlotStatusNI[gUnknown_03005000.unk_c3e]->send.state == 0x26 || gRfuSlotStatusNI[gUnknown_03005000.unk_c3e]->send.state == 0x27)
- rfu_clearSlot(4, gUnknown_03005000.unk_c3e);
- }
- if (gRfuSlotStatusNI[gUnknown_03005000.unk_c3e]->recv.state == 0x46 || gRfuSlotStatusNI[gUnknown_03005000.unk_c3e]->recv.state == 0x48)
- {
- rfu_clearSlot(8, gUnknown_03005000.unk_c3e);
- sub_8011A64(gUnknown_03005000.unk_c86, 0);
- retval = gUnknown_03005000.unk_c86;
- }
- else if (gRfuSlotStatusNI[gUnknown_03005000.unk_c3e]->recv.state == 0x47)
- {
- rfu_clearSlot(8, gUnknown_03005000.unk_c3e);
- retval = 6;
- }
- return retval;
-}
-
-void sub_801084C(u8 taskId)
-{
- s32 i;
-
- if (gUnknown_03005000.unk_f1 == 1 || gUnknown_03005000.unk_f1 == 2)
- {
- gUnknown_03005000.unk_ce8 = 0;
- DestroyTask(taskId);
- }
- switch (gTasks[taskId].data[0])
- {
- case 0:
- if (sub_800FC60())
- {
- ResetBlockReceivedFlags();
- sub_800B348();
- gTasks[taskId].data[0]++;
- }
- break;
- case 1:
- if (gUnknown_03005000.unk_0c == 1)
- {
- if (gReceivedRemoteLinkPlayers)
- sub_800FD14(0x7800);
- else
- sub_800FD14(0x7700);
- gTasks[taskId].data[0] = 101;
- }
- else
- gTasks[taskId].data[0] = 2;
- break;
- case 101:
- if (gSendCmd[0] == 0)
- gTasks[taskId].data[0] = 2;
- break;
- case 2:
- if (gUnknown_03005000.playerCount)
- gTasks[taskId].data[0]++;
- break;
- case 3:
- if (gUnknown_03005000.unk_0c == 1)
- {
- if (sub_800FC60())
- {
- gUnknown_03005000.unk_5a = 0;
- sub_800FD14(0xa100);
- gTasks[taskId].data[0]++;
- }
- }
- else
- gTasks[taskId].data[0]++;
- break;
- case 4:
- if (sub_800FC88())
- gTasks[taskId].data[0]++;
- break;
- case 5:
- for (i = 0; i < gUnknown_03005000.playerCount; i++)
- {
- sub_800B3A4(i);
- sub_800F728(i);
- }
- gTasks[taskId].data[0]++;
- break;
- case 6:
- DestroyTask(taskId);
- gReceivedRemoteLinkPlayers = 1;
- gUnknown_03005000.unk_ce8 = 0;
- sub_800D550(1, 0x258);
- if (gUnknown_03005000.unk_ce6)
- {
- for (i = 0; i < 4; i++)
- {
- if ((gUnknown_03005000.unk_ce6 >> i) & 1)
- {
- gUnknown_03005000.unk_ce5 = 1 << i;
- gUnknown_03005000.unk_ce6 ^= (1 << i);
- }
- }
- }
- break;
- }
-}
-
-void sub_80109E8(u16 a0)
-{
- s32 i;
-
- for (i = 0; i < 4; i++)
- {
- if ((a0 >> i) & 1)
- gUnknown_03005000.unk_cde[i] = 0;
- }
-}
-
-void sub_8010A14(const struct UnkRfuStruct_8010A14 *a0)
-{
- s32 i;
- gUnknown_03005000.playerCount = a0->unk_0f;
- for (i = 0; i < 4; i++)
- gUnknown_03005000.unk_cde[i] = a0->unk_10[i];
- for (i = 0; i < MAX_RFU_PLAYERS; i++)
- {
- gLinkPlayers[i] = a0->unk_14[i];
- sub_800B524(gLinkPlayers + i);
- }
-}
-
-void sub_8010A70(void *a0)
-{
- if (strcmp(gUnknown_082ED7EC, a0) == 0)
- {
- sub_8010A14(a0);
- CpuFill16(0, a0, sizeof(struct UnkRfuStruct_8010A14));
- ResetBlockReceivedFlag(0);
- }
-}
-
-void sub_8010AAC(u8 taskId)
-{
- s32 i;
- struct LinkPlayerBlock *r2;
- struct UnkRfuStruct_8010A14 *r5;
- u8 r4 = gUnknown_03005000.unk_cde[gUnknown_082ED68C[gUnknown_03005000.unk_ce9]];
- if (gUnknown_03005000.unk_f1 == 1 || gUnknown_03005000.unk_f1 == 2)
- {
- gUnknown_03005000.unk_ce8 = 0;
- DestroyTask(taskId);
- }
- switch (gTasks[taskId].data[0])
- {
- case 0:
- if (gSendCmd[0] == 0)
- {
- ResetBlockReceivedFlag(r4);
- sub_800FD14(0x7800);
- gTasks[taskId].data[0]++;
- }
- break;
- case 1:
- if (gSendCmd[0] == 0)
- gTasks[taskId].data[0]++;
- break;
- case 2:
- if ((GetBlockReceivedStatus() >> r4) & 1)
- {
- ResetBlockReceivedFlag(r4);
- r2 = (struct LinkPlayerBlock *)gBlockRecvBuffer[r4];
- gLinkPlayers[r4] = r2->linkPlayer;
- sub_800B524(gLinkPlayers + r4);
- gTasks[taskId].data[0]++;
- }
- break;
- case 3:
- r5 = (struct UnkRfuStruct_8010A14 *)gBlockSendBuffer;
- memcpy(r5->unk_00, gUnknown_082ED7EC, sizeof gUnknown_082ED7EC);
- r5->unk_0f = gUnknown_03005000.playerCount;
- for (i = 0; i < 4; i++)
- r5->unk_10[i] = gUnknown_03005000.unk_cde[i];
- memcpy(r5->unk_14, gLinkPlayers, sizeof gLinkPlayers);
- gTasks[taskId].data[0]++;
- // fallthrough
- case 4:
- r5 = (struct UnkRfuStruct_8010A14 *)gBlockSendBuffer;
- r5->unk_0f = gUnknown_03005000.playerCount;
- for (i = 0; i < 4; i++)
- r5->unk_10[i] = gUnknown_03005000.unk_cde[i];
- memcpy(r5->unk_14, gLinkPlayers, sizeof gLinkPlayers);
- if (SendBlock(0, gBlockSendBuffer, 0xa0))
- gTasks[taskId].data[0]++;
- break;
- case 5:
- if (IsLinkTaskFinished() && GetBlockReceivedStatus() & 1)
- {
- CpuFill16(0, gBlockRecvBuffer, sizeof(struct UnkRfuStruct_8010A14));
- ResetBlockReceivedFlag(0);
- gUnknown_03005000.unk_ce8 = 0;
- if (gUnknown_03005000.unk_ce6)
- {
- for (i = 0; i < 4; i++)
- {
- if ((gUnknown_03005000.unk_ce6 >> i) & 1)
- {
- gUnknown_03005000.unk_ce5 = 1 << i;
- gUnknown_03005000.unk_ce6 ^= (1 << i);
- gUnknown_03005000.unk_ce8 = 1;
- break;
- }
- }
- }
- DestroyTask(taskId);
- }
- break;
- }
-}
-
-void sub_8010D0C(u8 taskId)
-{
- if (gUnknown_03005000.unk_f1 == 1 || gUnknown_03005000.unk_f1 == 2)
- DestroyTask(taskId);
- switch (gTasks[taskId].data[0])
- {
- case 0:
- if (gUnknown_03005000.playerCount)
- {
- sub_800B348();
- SendBlock(0, gBlockSendBuffer, sizeof(struct LinkPlayerBlock));
- gTasks[taskId].data[0]++;
- }
- break;
- case 1:
- if (IsLinkTaskFinished())
- gTasks[taskId].data[0]++;
- break;
- case 2:
- if (GetBlockReceivedStatus() & 1)
- {
- sub_8010A14((const struct UnkRfuStruct_8010A14 *)gBlockRecvBuffer);
- ResetBlockReceivedFlag(0);
- gReceivedRemoteLinkPlayers = 1;
- DestroyTask(taskId);
- }
- break;
- }
-}
-
-void sub_8010DB4(void)
-{
- if (gUnknown_03005000.unk_ee == 1 && gUnknown_03004140.unk_02 == 0)
- {
- if (gMain.callback2 == c2_mystery_gift_e_reader_run || gUnknown_03004140.unk_3c->unk_04)
- gWirelessCommType = 2;
- SetMainCallback2(CB2_LinkError);
- gMain.savedCallback = CB2_LinkError;
- sub_800AF18((gUnknown_03005000.unk_0a << 16) | (gUnknown_03005000.unk_10 << 8) | gUnknown_03005000.unk_12, gUnknown_03005000.unk_124.unk_8c2, gUnknown_03005000.unk_9e8.unk_232, sub_8011A74() == 2);
- gUnknown_03005000.unk_ee = 2;
- CloseLink();
- }
- else if (gUnknown_03005000.unk_9e8.unk_233 == 1 || gUnknown_03005000.unk_124.unk_8c3 == 1)
- {
- if (gUnknown_03004140.unk_02)
- sub_800D630();
- sub_8011A64(1, 0x7000);
- sub_8011170(0x7000);
- }
-}
-
-void rfu_REQ_recvData_then_sendData(void)
-{
- if (gUnknown_03004140.unk_06 == 1)
- {
- rfu_REQ_recvData();
- rfu_waitREQComplete();
- rfu_REQ_sendData_wrapper(0);
- }
-}
-
-bool32 sub_8010EC0(void)
-{
- bool32 retval = FALSE;
- gUnknown_03005000.unk_ccd = 0;
- sub_800C54C(Random2());
- if (gUnknown_03005000.unk_ef == 0)
- {
- switch (gUnknown_03005000.unk_0c)
- {
- case 1:
- sub_800F0F8();
- break;
- case 0:
- retval = sub_800F4F0();
- break;
- case 2:
- rfu_REQ_recvData_then_sendData();
- break;
- }
- }
- return retval;
-}
-
-bool32 sub_8010F1C(void)
-{
- bool32 retval = FALSE;
- if (gUnknown_03005000.unk_ef == 0)
- {
- if (gUnknown_03005000.unk_0c == 1)
- retval = sub_800F1E0();
- sub_8010DB4();
- }
- return retval;
-}
-
-void sub_8010F48(void)
-{
- StringCopy(gUnknown_02022B22, gSaveBlock2Ptr->playerName);
-}
-
-void sub_8010F60(void)
-{
- memset(&gUnknown_02022B14, 0, 0xD);
- sub_800DD94(&gUnknown_02022B14, 0, 0, 0);
-}
-
-void sub_8010F84(u8 a0, u32 a1, u32 a2)
-{
- sub_800DD94(&gUnknown_02022B14, a0, a2, a1);
-}
-
-void sub_8010FA0(bool32 a0, bool32 a1)
-{
- gUnknown_02022B14.unk_00.unk_00_4 = a0;
- gUnknown_02022B14.unk_00.unk_00_5 = a1;
-}
-
-void sub_8010FCC(u32 type, u32 species, u32 level)
-{
- gUnknown_02022B14.type = type;
- gUnknown_02022B14.species = species;
- gUnknown_02022B14.level = level;
-}
-
-u8 sub_801100C(s32 a0)
-{
- u8 retval = 0x80;
- retval |= (gLinkPlayers[a0].gender << 3);
- retval |= (gLinkPlayers[a0].trainerId & 7);
- return retval;
-}
-
-void sub_801103C(void)
-{
- struct UnkLinkRfuStruct_02022B14 *r5 = &gUnknown_02022B14;
- s32 i;
-
- for (i = 1; i < GetLinkPlayerCount(); i++)
- r5->unk_04[i - 1] = sub_801100C(i);
-}
-
-void sub_8011068(u8 a0)
-{
- gUnknown_02022B14.unk_0a_7 = a0;
- rfu_REQ_configGameData(0, 2, (const u8 *)&gUnknown_02022B14, gUnknown_02022B22);
-}
-
-void sub_8011090(u8 a0, u32 a1, u32 a2)
-{
- if (a0)
- sub_8010F84(a0, a1, a2);
- rfu_REQ_configGameData(0, 2, (const u8 *)&gUnknown_02022B14, gUnknown_02022B22);
-}
-
-void sub_80110B8(u32 a0)
-{
- s32 i;
- u32 r5;
- u32 r7;
- s32 r8;
-
- if (sub_800F7DC()->unk_0a_0 == 0x45)
- {
- r5 = 0;
- r7 = 0;
- r8 = gUnknown_03005000.unk_ce2 ^ gUnknown_03005000.unk_ce3;
- for (i = 0; i < 4; i++)
- {
- if ((r8 >> i) & 1)
- {
- r7 |= ((0x80 | ((gLinkPlayers[gUnknown_03005000.unk_cde[i]].gender & 1) << 3) | (gLinkPlayers[gUnknown_03005000.unk_cde[i]].trainerId & 7)) << (r5 << 3));
- r5++;
- if (r5 == a0 - 1)
- break;
- }
- }
- sub_8011090(0x45, r7, 0);
- }
-}
-
-void sub_8011170(u32 a0)
-{
- if (gUnknown_03005000.unk_ee == 0)
- {
- gUnknown_03005000.unk_10 = gUnknown_03004140.unk_14;
- gUnknown_03005000.unk_12 = gUnknown_03004140.unk_16;
- gUnknown_03005000.unk_0a = a0;
- gUnknown_03005000.unk_ee = 1;
- }
-}
-
-void sub_80111A0(void)
-{
- gUnknown_03005000.unk_ee = 0;
-}
-
-void sub_80111B0(bool32 a0)
-{
- if (!a0)
- gUnknown_03005000.unk_ee = 0;
- else
- gUnknown_03005000.unk_ee = 4;
-}
-
-void sub_80111DC(void)
-{
- sub_8011E94(gUnknown_03004140.unk_00, 1);
- gUnknown_03005000.linkRfuCallback = NULL;
-}
-
-void sub_80111FC(void)
-{
- gUnknown_03005000.linkRfuCallback = sub_80111DC;
-}
-
-void sub_801120C(u8 a0, u8 unused1)
-{
- u8 i;
- u8 r6 = 0;
- switch (a0)
- {
- case 0x00:
- gUnknown_03005000.unk_04 = 2;
- break;
- case 0x10:
- break;
- case 0x11:
- sub_80115EC(gUnknown_03004140.unk_14);
- for (i = 0; i < 4; i++)
- {
- if ((gUnknown_03004140.unk_14 >> i) & 1)
- {
- struct UnkLinkRfuStruct_02022B14 *structPtr = (void *)gRfuLinkStatus->partner[i].gname;
- if (structPtr->unk_0a_0 == sub_800F7DC()->unk_0a_0)
- {
- gUnknown_03005000.unk_cd1[i] = 0;
- gUnknown_03005000.unk_cd5[i] = 0;
- rfu_setRecvBuffer(0x20, i, gUnknown_03005000.unk_cd5 + i, 1);
- }
- else
- {
- r6 |= (1 << i);
- }
- }
- }
- if (r6)
- {
- rfu_REQ_disconnect(r6);
- rfu_waitREQComplete();
- }
- break;
- case 0x12:
- break;
- case 0x13:
- break;
- case 0x14:
- if (gUnknown_03005000.unk_ce7 != gUnknown_03004140.unk_00)
- {
- rfu_REQ_disconnect(gUnknown_03005000.unk_ce7 ^ gUnknown_03004140.unk_00);
- rfu_waitREQComplete();
- }
- gUnknown_03005000.unk_04 = 0x11;
- break;
- case 0x31:
- gUnknown_03005000.unk_f0 = 1;
- break;
- case 0x32:
- gUnknown_03005000.unk_f0 = 3;
- break;
- case 0x30:
- case 0x33:
- gUnknown_03005000.unk_f0 = 4;
- gUnknown_03005000.unk_ce2 &= ~gUnknown_03004140.unk_14;
- if (gReceivedRemoteLinkPlayers == 1)
- {
- if (gUnknown_03005000.unk_ce2 == 0)
- sub_8011170(a0);
- else
- sub_80111FC();
- }
- sub_8011A64(2, a0);
- break;
- case 0x34:
- break;
- case 0x42 ... 0x44:
- break;
- case 0xf3:
- sub_8011A64(1, a0);
- sub_8011170(a0);
- gUnknown_03005000.unk_ef = 1;
- break;
- case 0xf0 ... 0xf2:
- case 0xff:
- sub_8011170(a0);
- sub_8011A64(1, a0);
- gUnknown_03005000.unk_cdb = 1;
- break;
- }
-}
-
-void sub_8011404(u8 a0, u8 unused1)
-{
- switch (a0)
- {
- case 0x00:
- gUnknown_03005000.unk_04 = 6;
- break;
- case 0x20:
- gUnknown_03005000.unk_ccd = gUnknown_03004140.unk_14;
- break;
- case 0x21:
- break;
- case 0x22:
- gUnknown_03005000.unk_c3e = gUnknown_03004140.unk_14;
- break;
- case 0x23:
- sub_8011A64(2, a0);
- break;
- case 0x24:
- gUnknown_03005000.unk_04 = 11;
- gUnknown_03005000.unk_c85 = 0;
- gUnknown_03005000.unk_c86 = 0;
- rfu_setRecvBuffer(0x20, gUnknown_03005000.unk_c3e, &gUnknown_03005000.unk_c86, 1);
- rfu_setRecvBuffer(0x10, gUnknown_03005000.unk_c3e, gUnknown_03005000.unk_c3f, 70);
- break;
- case 0x25:
- sub_8011A64(2, 0x25);
- break;
- case 0x30:
- gUnknown_03005000.unk_f0 = 2;
- if (gUnknown_03005000.unk_c86 == 6)
- break;
- case 0x33:
- if (gUnknown_03005000.unk_f0 != 2)
- gUnknown_03005000.unk_f0 = 4;
- if (gUnknown_03005000.unk_c86 != 9)
- sub_8011A64(2, a0);
- nullsub_5(gUnknown_082ED7FC, 5, 5);
- if (gReceivedRemoteLinkPlayers == 1)
- sub_8011170(a0);
- break;
- case 0x31:
- gUnknown_03005000.unk_f0 = 1;
- nullsub_5(gUnknown_082ED814, 5, 5);
- break;
- case 0x32:
- gUnknown_03005000.unk_f0 = 3;
- gUnknown_03005000.unk_c3c = 1;
- break;
- case 0x34:
- break;
- case 0x42 ... 0x44:
- break;
- case 0xF3:
- sub_8011A64(1, a0);
- sub_8011170(a0);
- gUnknown_03005000.unk_ef = 1;
- break;
- case 0xF0 ... 0xF2:
- case 0xFF:
- sub_8011A64(1, a0);
- sub_8011170(a0);
- gUnknown_03005000.unk_cdb = 1;
- break;
- }
-}
-
-void sub_80115EC(s32 a0)
-{
- s32 i;
-
- for (i = 0; i < 4; i++)
- {
- if ((a0 >> i) & 1)
- {
- gUnknown_03005000.unk_cea[i] = 0;
- gUnknown_03005000.unk_cee[i] = 0xFF;
- }
- }
-}
-
-u8 sub_8011628(s32 a0)
-{
- u8 ret = 0;
- u8 i;
-
- for (i = 0; i < 4; i++)
- {
- if ((a0 >> i) & 1)
- {
- struct UnkLinkRfuStruct_02022B14 *structPtr = (void *)gRfuLinkStatus->partner[i].gname;
- if (structPtr->unk_0a_0 == 0x45)
- ret |= (1 << i);
- }
- }
-
- return ret;
-}
-
-void sub_8011674(u8 a0, u8 unused1)
-{
- u8 r1;
-
- switch (a0)
- {
- case 0x00:
- gUnknown_03005000.unk_04 = 0x11;
- break;
- case 0x10:
- sub_8011A64(4, 0);
- break;
- case 0x11:
- if (sub_800F7DC()->unk_0a_0 == 0x45 && gUnknown_03005000.unk_cd9 == 0)
- {
- u8 idx = sub_8011628(gUnknown_03004140.unk_14);
- if (idx != 0)
- {
- r1 = 1 << sub_800E87C(idx);
- if (gUnknown_03005000.unk_ce6 == 0 && gUnknown_03005000.unk_ce8 == 0)
- {
- gUnknown_03005000.unk_ce5 = r1;
- gUnknown_03005000.unk_ce6 |= (r1 ^ idx);
- gUnknown_03005000.unk_ce8 = 1;
- }
- else
- {
- gUnknown_03005000.unk_ce6 |= idx;
- }
- }
- if (idx != gUnknown_03004140.unk_14)
- {
- gUnknown_03005000.unk_ce3 |= (idx ^ gUnknown_03004140.unk_14);
- gUnknown_03005000.unk_ce4 = 2;
- }
- }
- else if (sub_800F7DC()->unk_0a_0 == 0x54)
- {
- rfu_REQ_disconnect(gUnknown_03004140.unk_00);
- rfu_waitREQComplete();
- }
- sub_80115EC(gUnknown_03004140.unk_14);
- break;
- case 0x12:
- break;
- case 0x13:
- break;
- case 0x14:
- if (sub_800F7DC()->unk_0a_0 != 0x45 && gUnknown_03004140.unk_01 > 1)
- {
- r1 = 1 << sub_800E87C(gUnknown_03004140.unk_14);
- rfu_REQ_disconnect(gUnknown_03004140.unk_00 ^ r1);
- rfu_waitREQComplete();
- }
- if (gUnknown_03005000.unk_04 == 0xF)
- gUnknown_03005000.unk_04 = 0x10;
- break;
- break;
- case 0x20:
- gUnknown_03005000.unk_ccd = gUnknown_03004140.unk_14;
- break;
- case 0x21:
- break;
- case 0x22:
- gUnknown_03005000.unk_c3e = gUnknown_03004140.unk_14;
- break;
- case 0x23:
- gUnknown_03005000.unk_04 = 0x12;
- if (gUnknown_03005000.unk_ccf < 2)
- {
- gUnknown_03005000.unk_ccf++;
- CreateTask(sub_801209C, 2);
- }
- else
- {
- sub_8011A64(2, a0);
- }
- break;
- case 0x24:
- gUnknown_03005000.unk_04 = 0xD;
- sub_8011A64(3, 0);
- rfu_setRecvBuffer(0x10, gUnknown_03005000.unk_c3e, gUnknown_03005000.unk_c3f, 70);
- break;
- case 0x25:
- sub_8011A64(2, a0);
- break;
- case 0x31:
- if (gUnknown_03004140.unk_00 & gUnknown_03004140.unk_14)
- gUnknown_03005000.unk_f0 = 1;
- break;
- case 0x32:
- gUnknown_03005000.unk_f0 = 3;
- if (gRfuLinkStatus->parentChild == 0)
- gUnknown_03005000.unk_c3c = 1;
- break;
- case 0x30:
- gUnknown_03005000.unk_f0 = 2;
- case 0x33:
- if (gUnknown_03005000.unk_f0 != 2)
- gUnknown_03005000.unk_f0 = 4;
- if (gUnknown_03005000.unk_0c == 1)
- {
- if (gReceivedRemoteLinkPlayers == 1)
- {
- gUnknown_03005000.unk_ce2 &= ~(gUnknown_03004140.unk_14);
- if (gUnknown_03005000.unk_ce2 == 0)
- sub_8011170(a0);
- else
- sub_80111FC();
- }
- }
- else if (gUnknown_03005000.unk_ce4 != 2 && gReceivedRemoteLinkPlayers == 1)
- {
- sub_8011170(a0);
- sub_800C27C(0);
- }
-
- if (gRfuLinkStatus->parentChild == 0xFF && gUnknown_03004140.unk_07 == 0 && FuncIsActiveTask(sub_800EB44) == TRUE)
- gUnknown_03005000.unk_04 = 0x11;
-
- sub_8011A64(2, a0);
- break;
- case 0x40:
- gUnknown_03005000.unk_ce3 = 0;
- break;
- case 0x42 ... 0x44:
- break;
- case 0xF3:
- sub_8011A64(1, a0);
- sub_8011170(a0);
- gUnknown_03005000.unk_ef = 1;
- break;
- case 0xF0 ... 0xF2:
- case 0xFF:
- sub_8011170(a0);
- sub_8011A64(1, a0);
- gUnknown_03005000.unk_cdb = 0;
- break;
- }
-}
-
-void sub_8011A50(void)
-{
- gUnknown_03005000.unk_ce4 = 2;
-}
-
-void sub_8011A64(u8 a0, u16 a1)
-{
- gUnknown_03005000.unk_f1 = a0;
- gUnknown_03005000.unk_0a = a1;
-}
-
-u8 sub_8011A74(void)
-{
- return gUnknown_03005000.unk_f1;
-}
-
-bool32 sub_8011A80(void)
-{
- u32 var = sub_8011A74() - 1;
- if (var < 2)
- return TRUE;
- else
- return FALSE;
-}
-
-bool32 sub_8011A9C(void)
-{
- return gUnknown_03005000.unk_ce8;
-}
-
-bool8 Rfu_IsMaster(void)
-{
- return gUnknown_03005000.unk_0c;
-}
-
-void RfuVSync(void)
-{
- rfu_syncVBlank_();
-}
-
-void sub_8011AC8(void)
-{
- CpuFill32(0, gRecvCmds, sizeof(gRecvCmds));
-}
-
-void sub_8011AE8(void)
-{
- LoadOam();
- ProcessSpriteCopyRequests();
- TransferPlttBuffer();
-}
-
-void sub_8011AFC(void)
-{
- s32 i;
-
- ResetSpriteData();
- FreeAllSpritePalettes();
- ResetTasks();
- ResetPaletteFade();
- SetVBlankCallback(sub_8011AE8);
- if (IsWirelessAdapterConnected())
- {
- gLinkType = LINKTYPE_0x1111;
- sub_800B488();
- OpenLink();
- SeedRng(gMain.vblankCounter2);
- for (i = 0; i < 4; i++)
- gSaveBlock2Ptr->playerTrainerId[i] = Random() % 256;
-
- SetGpuReg(REG_OFFSET_DISPCNT, DISPCNT_OBJ_ON | DISPCNT_BG0_ON | DISPCNT_BG2_ON | DISPCNT_OBJ_1D_MAP);
- RunTasks();
- AnimateSprites();
- BuildOamBuffer();
- UpdatePaletteFade();
- sub_8011BA4();
- SetMainCallback2(sub_8011BF8);
- }
-}
-
-bool32 sub_8011B90(void)
-{
- return FuncIsActiveTask(sub_800EB44);
-}
-
-void sub_8011BA4(void)
-{
- if (!FuncIsActiveTask(nullsub_89))
- gUnknown_03005000.unk_66 = CreateTask(nullsub_89, 0);
-}
-
-void sub_8011BD0(void)
-{
- if (FuncIsActiveTask(nullsub_89) == TRUE)
- DestroyTask(gUnknown_03005000.unk_66);
-}
-
-void sub_8011BF8(void)
-{
- RunTasks();
- AnimateSprites();
- BuildOamBuffer();
- UpdatePaletteFade();
-}
-
-void sub_8011C10(u32 a0)
-{
- gUnknown_03005000.unk_0c = 1;
- sub_8010F48();
- sub_800BF4C(sub_801120C, NULL);
- gUnknown_02022B2C = gUnknown_082ED608;
- gUnknown_02022B2C.unk_02 = gUnknown_082ED620[a0 - 1];
- sub_800EE78();
-}
-
-void sub_8011C5C(void)
-{
- gUnknown_03005000.unk_0c = 0;
- sub_8010F48();
- sub_800BF4C(sub_8011404, sub_800ED34);
- sub_800EF00();
-}
-
-void sub_8011C84(void)
-{
- gUnknown_03005000.unk_0c = 2;
- sub_8010F48();
- sub_800BF4C(sub_8011674, NULL);
- gUnknown_02022B2C = gUnknown_082ED608;
- gUnknown_02022B2C.unk_11 = 0;
- gUnknown_02022B2C.unk_12 = 0x258;
- gUnknown_03005000.unk_67 = CreateTask(sub_800EB44, 1);
-}
-
-static u16 ReadU16(const void *ptr)
-{
- const u8 *ptr_ = ptr;
- return (ptr_[1] << 8) | (ptr_[0]);
-}
-
-u8 sub_8011CE4(const u8 *a0, u16 a1)
-{
- u8 i;
- u8 ret = 0xFF;
-
- for (i = 0; i < 4; i++)
- {
- u16 trainerId = ReadU16(gRfuLinkStatus->partner[i].gname + 2);
- if (sub_8010454(gRfuLinkStatus->partner[i].serialNo)
- && !StringCompare(a0, gRfuLinkStatus->partner[i].uname)
- && a1 == trainerId)
- {
- ret = i;
- if (gRfuLinkStatus->partner[i].slot != 0xFF)
- break;
- }
- }
-
- return ret;
-}
-
-void sub_8011D6C(u32 a0)
-{
- rfu_REQ_disconnect(a0);
- rfu_waitREQComplete();
- gUnknown_03005000.unk_ce2 &= ~(a0);
- rfu_clearSlot(1, gUnknown_03005000.unk_cda);
- rfu_UNI_setSendData(gUnknown_03005000.unk_ce2, gUnknown_03005000.unk_c87, 70);
- gUnknown_03005000.unk_cda = sub_800E87C(gUnknown_03005000.unk_ce2);
-}
-
-void sub_8011DC0(const u8 *ptr, u16 a1)
-{
- u8 var = sub_8011CE4(ptr, a1);
- if (var != 0xFF)
- sub_8011D6C(1 << var);
-}
-
-void sub_8011DE0(u32 a0)
-{
- if (a0 != 0)
- {
- s32 i;
- u8 var = 0;
-
- for (i = 0; i < 4; i++)
- {
- if (gUnknown_03005000.unk_cde[i] == a0 && (gUnknown_03005000.unk_ce2 >> i) & 1)
- var |= 1 << i;
- }
- if (var)
- sub_8011E94(var, 2);
- }
-}
-
-void sub_8011E2C(u8 taskId)
-{
- if (gSendCmd[0] == 0 && gUnknown_03005000.unk_ce8 == 0)
- {
- sub_800FD14(0xED00);
- gSendCmd[1] = gTasks[taskId].data[0];
- gSendCmd[2] = gTasks[taskId].data[1];
- gUnknown_03005000.playerCount -= gUnknown_082ED695[gTasks[taskId].data[0]];
- gSendCmd[3] = gUnknown_03005000.playerCount;
- DestroyTask(taskId);
- }
-}
-
-void sub_8011E94(u32 a0, u32 a1)
-{
- u8 taskId = FindTaskIdByFunc(sub_8011E2C);
- if (taskId == 0xFF)
- {
- taskId = CreateTask(sub_8011E2C, 5);
- gTasks[taskId].data[0] = a0;
- }
- else
- {
- gTasks[taskId].data[0] |= a0;
- }
-
- gTasks[taskId].data[1] = a1;
-}
-
-void sub_8011EF4(u8 taskId)
-{
- s16 *data = gTasks[taskId].data;
-
- if (sub_800EE94())
- {
- u8 id = sub_8011CE4((u8*)data, ReadU16(&data[8]));
- if (id != 0xFF)
- {
- if (gRfuLinkStatus->partner[id].slot != 0xFF)
- {
- gUnknown_03005000.unk_c3d = id;
- if (sub_800EEBC())
- DestroyTask(taskId);
- }
- else if (sub_800F7DC()->unk_0a_0 == 0x15 || sub_800F7DC()->unk_0a_0 == 0x16)
- {
- data[15]++;
- }
- else
- {
- sub_8011A64(2, 0x7000);
- DestroyTask(taskId);
- }
- }
- else
- {
- data[15]++;
- gUnknown_03005000.unk_c3d = id;
- }
- }
- else
- {
- data[15]++;
- }
-
- if (data[15] > 240)
- {
- sub_8011A64(2, 0x7000);
- DestroyTask(taskId);
- }
-}
-
-void sub_8011FC8(const u8 *src, u16 trainerId)
-{
- u8 taskId;
- s16 *data;
-
- gUnknown_03005000.unk_f1 = 0;
- taskId = CreateTask(sub_8011EF4, 3);
- data = gTasks[taskId].data;
- StringCopy((u8*)(data), src);
- data[8] = trainerId;
-}
-
-bool32 sub_801200C(s16 a1, struct UnkLinkRfuStruct_02022B14 *structPtr)
-{
- if (sub_800F7DC()->unk_0a_0 == 0x45)
- {
- if (structPtr->unk_0a_0 != 0x45)
- return TRUE;
- }
- else if (structPtr->unk_0a_0 != 0x40)
- {
- return TRUE;
- }
- else if (a1 == 0x44)
- {
- struct UnkLinkRfuStruct_02022B14 *structPtr2 = &gUnknown_03005000.unk_10A;
- if (structPtr2->species == SPECIES_EGG)
- {
- if (structPtr->species == structPtr2->species)
- return FALSE;
- else
- return TRUE;
- }
- else if (structPtr->species != structPtr2->species
- || structPtr->level != structPtr2->level
- || structPtr->type != structPtr2->type)
- {
- return TRUE;
- }
- }
-
- return FALSE;
-}
-
-void sub_801209C(u8 taskId)
-{
- if (gUnknown_03005000.unk_f1 == 4)
- DestroyTask(taskId);
-
- if (++gTasks[taskId].data[0] > 300)
- {
- sub_8011A64(2, 0x7000);
- DestroyTask(taskId);
- }
-
- if (gUnknown_03005000.unk_ccd != 0 && gUnknown_03004140.unk_06 == 0)
- {
- u16 trainerId = ReadU16(gUnknown_03005000.unk_10A.unk_00.playerTrainerId);
- u8 id = sub_8011CE4(gUnknown_03005000.playerName, trainerId);
- if (id != 0xFF)
- {
- if (!sub_801200C(gTasks[taskId].data[1], (void *)gRfuLinkStatus->partner[id].gname))
- {
- if (gRfuLinkStatus->partner[id].slot != 0xFF && !sub_800C12C(gRfuLinkStatus->partner[id].id, 0x5A))
- {
- gUnknown_03005000.unk_04 = 0xA;
- DestroyTask(taskId);
- }
- }
- else
- {
- sub_8011A64(2, 0x7000);
- DestroyTask(taskId);
- }
- }
- }
-}
-
-void sub_8012188(const u8 *name, struct UnkLinkRfuStruct_02022B14 *structPtr, u8 a2)
-{
- u8 taskId, taskId2;
-
- gUnknown_03005000.unk_ccf = 0;
- gUnknown_03005000.unk_f1 = 0;
- StringCopy(gUnknown_03005000.playerName, name);
- memcpy(&gUnknown_03005000.unk_10A, structPtr, 0xD);
- sub_800D658();
- taskId = CreateTask(sub_801209C, 2);
- gTasks[taskId].data[1] = a2;
- taskId2 = FindTaskIdByFunc(sub_800EB44);
- if (a2 == 0x45)
- {
- if (taskId2 != 0xFF)
- gTasks[taskId2].data[7] = 1;
- }
- else
- {
- if (taskId2 != 0xFF)
- gTasks[taskId2].data[7] = 0;
- }
-}
-
-bool8 sub_8012224(void)
-{
- if (gUnknown_03005000.unk_f0 == 1)
- return TRUE;
- else
- return FALSE;
-}
-
-bool32 sub_8012240(void)
-{
- s32 i;
-
- for (i = 0; i < 4; i++)
- {
- if ((gUnknown_03004140.unk_00 >> i) & 1 && gUnknown_03005000.unk_cd1[i] == 0)
- return FALSE;
- }
-
- return TRUE;
-}
-
-void sub_801227C(void)
-{
- s32 i;
-
- for (i = 0; i < 20; i++)
- nullsub_5(gUnknown_082ED82C, 0, i);
-}
-
-void sub_801229C(void)
-{
- s32 i, j;
-
- nullsub_13(GetBlockReceivedStatus(), 0x1C, 0x13, 2);
- nullsub_13(gRfuLinkStatus->connSlotFlag, 0x14, 1, 1);
- nullsub_13(gRfuLinkStatus->linkLossSlotFlag, 0x17, 1, 1);
- if (gUnknown_03005000.unk_0c == 1)
- {
- for (i = 0; i < 4; i++)
- {
- if ((gRfuLinkStatus->getNameFlag >> i) & 1)
- {
- nullsub_13(gRfuLinkStatus->partner[i].serialNo, 1, i + 3, 4);
- nullsub_5((void*)gRfuLinkStatus->partner[i].gname, 6, i + 3);
- nullsub_5(gRfuLinkStatus->partner[i].uname, 0x16, i + 3);
- }
- }
- for (i = 0; i < 4; i++)
- {
- for (j = 0; j < 14; j++)
- {
- nullsub_13(gUnknown_03005000.unk_14[i][j], j * 2, i + 11, 2);
- }
- }
- nullsub_5(gUnknown_082ED868, 1, 0xF);
- }
- else if (gRfuLinkStatus->connSlotFlag != 0 && gRfuLinkStatus->getNameFlag != 0)
- {
- for (i = 0; i < 4; i++)
- {
- nullsub_13(0, 1, i + 3, 4);
- nullsub_5(gUnknown_082ED84B, 6, i + 3);
- nullsub_5(gUnknown_082ED85B, 0x16, i + 3);
- }
- nullsub_13(gRfuLinkStatus->partner[gUnknown_03005000.unk_c3e].serialNo, 1, 3, 4);
- nullsub_5((void*)gRfuLinkStatus->partner[gUnknown_03005000.unk_c3e].gname, 6, 3);
- nullsub_5(gRfuLinkStatus->partner[gUnknown_03005000.unk_c3e].uname, 0x16, 3);
- }
- else
- {
- for (i = 0; i < gRfuLinkStatus->findParentCount; i++)
- {
- if (gRfuLinkStatus->partner[i].slot != 0xFF)
- {
- nullsub_13(gRfuLinkStatus->partner[i].serialNo, 1, i + 3, 4);
- nullsub_13(gRfuLinkStatus->partner[i].id, 6, i + 3, 4);
- nullsub_5(gRfuLinkStatus->partner[i].uname, 0x16, i + 3);
- }
- }
- for (; i < 4; i++)
- {
- nullsub_13(0, 1, i + 3, 4);
- nullsub_5(gUnknown_082ED84B, 6, i + 3);
- nullsub_5(gUnknown_082ED85B, 0x16, i + 3);
- }
- }
-}
-
-u32 sub_80124C0(void)
-{
- return gUnknown_03005000.unk_9e8.unk_232;
-}
-
-u32 GetRfuRecvQueueLength(void)
-{
- return gUnknown_03005000.unk_124.unk_8c2;
-}