through SendRecvDone
This commit is contained in:
-277
@@ -5,283 +5,6 @@
|
|||||||
|
|
||||||
.text
|
.text
|
||||||
|
|
||||||
thumb_func_start DoRecv
|
|
||||||
DoRecv: @ 800BBCC
|
|
||||||
push {r4-r7,lr}
|
|
||||||
mov r7, r8
|
|
||||||
push {r7}
|
|
||||||
sub sp, 0x8
|
|
||||||
ldr r0, =0x04000120
|
|
||||||
ldr r1, [r0, 0x4]
|
|
||||||
ldr r0, [r0]
|
|
||||||
str r0, [sp]
|
|
||||||
str r1, [sp, 0x4]
|
|
||||||
ldr r0, =gLink
|
|
||||||
ldrb r1, [r0, 0x16]
|
|
||||||
adds r6, r0, 0
|
|
||||||
cmp r1, 0
|
|
||||||
bne _0800BC30
|
|
||||||
movs r4, 0
|
|
||||||
ldr r7, =gUnknown_03000D72
|
|
||||||
ldrb r0, [r6, 0x3]
|
|
||||||
cmp r4, r0
|
|
||||||
bcs _0800BC1A
|
|
||||||
adds r5, r6, 0
|
|
||||||
ldrh r1, [r6, 0x14]
|
|
||||||
adds r3, r7, 0
|
|
||||||
adds r2, r6, 0
|
|
||||||
_0800BBFA:
|
|
||||||
lsls r0, r4, 1
|
|
||||||
add r0, sp
|
|
||||||
ldrh r0, [r0]
|
|
||||||
cmp r1, r0
|
|
||||||
beq _0800BC0E
|
|
||||||
ldrb r0, [r3]
|
|
||||||
cmp r0, 0
|
|
||||||
beq _0800BC0E
|
|
||||||
movs r0, 0x1
|
|
||||||
strb r0, [r5, 0x11]
|
|
||||||
_0800BC0E:
|
|
||||||
adds r0, r4, 0x1
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r4, r0, 24
|
|
||||||
ldrb r0, [r2, 0x3]
|
|
||||||
cmp r4, r0
|
|
||||||
bcc _0800BBFA
|
|
||||||
_0800BC1A:
|
|
||||||
movs r0, 0
|
|
||||||
strh r0, [r6, 0x14]
|
|
||||||
movs r0, 0x1
|
|
||||||
strb r0, [r7]
|
|
||||||
b _0800BCD0
|
|
||||||
.pool
|
|
||||||
_0800BC30:
|
|
||||||
ldr r2, =0x00000fbc
|
|
||||||
adds r1, r6, r2
|
|
||||||
adds r2, 0x1
|
|
||||||
adds r0, r6, r2
|
|
||||||
ldrb r2, [r0]
|
|
||||||
ldrb r1, [r1]
|
|
||||||
adds r0, r2, r1
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
cmp r0, 0x31
|
|
||||||
bls _0800BC4C
|
|
||||||
subs r0, 0x32
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
_0800BC4C:
|
|
||||||
cmp r2, 0x31
|
|
||||||
bhi _0800BCA8
|
|
||||||
movs r4, 0
|
|
||||||
ldrb r1, [r6, 0x3]
|
|
||||||
cmp r4, r1
|
|
||||||
bcs _0800BCAC
|
|
||||||
adds r5, r6, 0
|
|
||||||
ldr r7, =gUnknown_03000D70
|
|
||||||
lsls r0, 1
|
|
||||||
mov r12, r0
|
|
||||||
movs r2, 0xCF
|
|
||||||
lsls r2, 2
|
|
||||||
adds r2, r6
|
|
||||||
mov r8, r2
|
|
||||||
_0800BC68:
|
|
||||||
lsls r1, r4, 1
|
|
||||||
mov r2, sp
|
|
||||||
adds r0, r2, r1
|
|
||||||
ldrh r3, [r0]
|
|
||||||
ldrh r2, [r5, 0x14]
|
|
||||||
adds r0, r3, r2
|
|
||||||
strh r0, [r5, 0x14]
|
|
||||||
ldrh r0, [r7]
|
|
||||||
orrs r0, r3
|
|
||||||
strh r0, [r7]
|
|
||||||
ldrb r2, [r5, 0x17]
|
|
||||||
movs r0, 0x64
|
|
||||||
muls r0, r2
|
|
||||||
add r0, r12
|
|
||||||
adds r1, r4
|
|
||||||
lsls r1, 3
|
|
||||||
adds r1, r4
|
|
||||||
lsls r1, 5
|
|
||||||
adds r0, r1
|
|
||||||
add r0, r8
|
|
||||||
strh r3, [r0]
|
|
||||||
adds r0, r4, 0x1
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r4, r0, 24
|
|
||||||
ldrb r0, [r5, 0x3]
|
|
||||||
cmp r4, r0
|
|
||||||
bcc _0800BC68
|
|
||||||
b _0800BCAC
|
|
||||||
.pool
|
|
||||||
_0800BCA8:
|
|
||||||
movs r0, 0x2
|
|
||||||
strb r0, [r6, 0x12]
|
|
||||||
_0800BCAC:
|
|
||||||
ldrb r0, [r6, 0x17]
|
|
||||||
adds r0, 0x1
|
|
||||||
strb r0, [r6, 0x17]
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
cmp r0, 0x8
|
|
||||||
bne _0800BCD0
|
|
||||||
ldr r2, =gUnknown_03000D70
|
|
||||||
ldrh r0, [r2]
|
|
||||||
cmp r0, 0
|
|
||||||
beq _0800BCD0
|
|
||||||
ldr r1, =0x00000fbd
|
|
||||||
adds r0, r6, r1
|
|
||||||
ldrb r1, [r0]
|
|
||||||
adds r1, 0x1
|
|
||||||
strb r1, [r0]
|
|
||||||
movs r0, 0
|
|
||||||
strh r0, [r2]
|
|
||||||
_0800BCD0:
|
|
||||||
add sp, 0x8
|
|
||||||
pop {r3}
|
|
||||||
mov r8, r3
|
|
||||||
pop {r4-r7}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end DoRecv
|
|
||||||
|
|
||||||
thumb_func_start DoSend
|
|
||||||
DoSend: @ 800BCE4
|
|
||||||
push {r4,lr}
|
|
||||||
ldr r0, =gLink
|
|
||||||
ldrb r1, [r0, 0x16]
|
|
||||||
adds r4, r0, 0
|
|
||||||
cmp r1, 0x8
|
|
||||||
bne _0800BD36
|
|
||||||
ldr r1, =0x0400012a
|
|
||||||
ldrh r0, [r4, 0x14]
|
|
||||||
strh r0, [r1]
|
|
||||||
ldr r1, =gUnknown_03000D6D
|
|
||||||
ldrb r2, [r1]
|
|
||||||
cmp r2, 0
|
|
||||||
bne _0800BD30
|
|
||||||
ldr r0, =0x00000339
|
|
||||||
adds r1, r4, r0
|
|
||||||
ldrb r0, [r1]
|
|
||||||
subs r0, 0x1
|
|
||||||
strb r0, [r1]
|
|
||||||
movs r0, 0xCE
|
|
||||||
lsls r0, 2
|
|
||||||
adds r1, r4, r0
|
|
||||||
ldrb r0, [r1]
|
|
||||||
adds r0, 0x1
|
|
||||||
strb r0, [r1]
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
cmp r0, 0x31
|
|
||||||
bls _0800BD8C
|
|
||||||
strb r2, [r1]
|
|
||||||
b _0800BD8C
|
|
||||||
.pool
|
|
||||||
_0800BD30:
|
|
||||||
movs r0, 0
|
|
||||||
strb r0, [r1]
|
|
||||||
b _0800BD8C
|
|
||||||
_0800BD36:
|
|
||||||
ldr r1, =gUnknown_03000D6D
|
|
||||||
ldrb r0, [r1]
|
|
||||||
cmp r0, 0
|
|
||||||
bne _0800BD52
|
|
||||||
ldr r2, =0x00000339
|
|
||||||
adds r0, r4, r2
|
|
||||||
ldrb r0, [r0]
|
|
||||||
cmp r0, 0
|
|
||||||
bne _0800BD4C
|
|
||||||
movs r0, 0x1
|
|
||||||
strb r0, [r1]
|
|
||||||
_0800BD4C:
|
|
||||||
ldrb r0, [r1]
|
|
||||||
cmp r0, 0
|
|
||||||
beq _0800BD68
|
|
||||||
_0800BD52:
|
|
||||||
ldr r1, =0x0400012a
|
|
||||||
movs r0, 0
|
|
||||||
strh r0, [r1]
|
|
||||||
b _0800BD86
|
|
||||||
.pool
|
|
||||||
_0800BD68:
|
|
||||||
ldr r3, =0x0400012a
|
|
||||||
movs r1, 0xCE
|
|
||||||
lsls r1, 2
|
|
||||||
adds r0, r4, r1
|
|
||||||
ldrb r0, [r0]
|
|
||||||
lsls r0, 1
|
|
||||||
ldrb r2, [r4, 0x16]
|
|
||||||
movs r1, 0x64
|
|
||||||
muls r1, r2
|
|
||||||
adds r0, r1
|
|
||||||
adds r1, r4, 0
|
|
||||||
adds r1, 0x18
|
|
||||||
adds r0, r1
|
|
||||||
ldrh r0, [r0]
|
|
||||||
strh r0, [r3]
|
|
||||||
_0800BD86:
|
|
||||||
ldrb r0, [r4, 0x16]
|
|
||||||
adds r0, 0x1
|
|
||||||
strb r0, [r4, 0x16]
|
|
||||||
_0800BD8C:
|
|
||||||
pop {r4}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end DoSend
|
|
||||||
|
|
||||||
thumb_func_start StopTimer
|
|
||||||
StopTimer: @ 800BD98
|
|
||||||
push {lr}
|
|
||||||
ldr r0, =gLink
|
|
||||||
ldrb r0, [r0]
|
|
||||||
cmp r0, 0
|
|
||||||
beq _0800BDB4
|
|
||||||
ldr r2, =0x0400010e
|
|
||||||
ldrh r1, [r2]
|
|
||||||
ldr r0, =0x0000ff7f
|
|
||||||
ands r0, r1
|
|
||||||
strh r0, [r2]
|
|
||||||
ldr r1, =0x0400010c
|
|
||||||
ldr r2, =0x0000ff3b
|
|
||||||
adds r0, r2, 0
|
|
||||||
strh r0, [r1]
|
|
||||||
_0800BDB4:
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end StopTimer
|
|
||||||
|
|
||||||
thumb_func_start SendRecvDone
|
|
||||||
SendRecvDone: @ 800BDCC
|
|
||||||
push {lr}
|
|
||||||
ldr r1, =gLink
|
|
||||||
ldrb r0, [r1, 0x17]
|
|
||||||
cmp r0, 0x8
|
|
||||||
bne _0800BDE4
|
|
||||||
movs r0, 0
|
|
||||||
strb r0, [r1, 0x16]
|
|
||||||
strb r0, [r1, 0x17]
|
|
||||||
b _0800BDF4
|
|
||||||
.pool
|
|
||||||
_0800BDE4:
|
|
||||||
ldrb r0, [r1]
|
|
||||||
cmp r0, 0
|
|
||||||
beq _0800BDF4
|
|
||||||
ldr r0, =0x0400010e
|
|
||||||
ldrh r1, [r0]
|
|
||||||
movs r2, 0x80
|
|
||||||
orrs r1, r2
|
|
||||||
strh r1, [r0]
|
|
||||||
_0800BDF4:
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end SendRecvDone
|
|
||||||
|
|
||||||
thumb_func_start sub_800BDFC
|
thumb_func_start sub_800BDFC
|
||||||
sub_800BDFC: @ 800BDFC
|
sub_800BDFC: @ 800BDFC
|
||||||
push {r4-r6,lr}
|
push {r4-r6,lr}
|
||||||
|
|||||||
+183
-74
@@ -61,10 +61,10 @@ IWRAM_DATA u32 gUnknown_03000D60;
|
|||||||
IWRAM_DATA u8 sLinkTestLastBlockSendPos;
|
IWRAM_DATA u8 sLinkTestLastBlockSendPos;
|
||||||
ALIGNED() IWRAM_DATA u8 sLinkTestLastBlockRecvPos[MAX_LINK_PLAYERS];
|
ALIGNED() IWRAM_DATA u8 sLinkTestLastBlockRecvPos[MAX_LINK_PLAYERS];
|
||||||
IWRAM_DATA u8 sNumVBlanksWithoutSerialIntr;
|
IWRAM_DATA u8 sNumVBlanksWithoutSerialIntr;
|
||||||
IWRAM_DATA bool8 gUnknown_03000D6D;
|
IWRAM_DATA bool8 sSendBufferEmpty;
|
||||||
IWRAM_DATA u16 sSendNonzeroCheck;
|
IWRAM_DATA u16 sSendNonzeroCheck;
|
||||||
IWRAM_DATA u16 gUnknown_03000D70;
|
IWRAM_DATA u16 sRecvNonzeroCheck;
|
||||||
IWRAM_DATA u8 gUnknown_03000D72;
|
IWRAM_DATA u8 sChecksumAvailable;
|
||||||
IWRAM_DATA u8 sHandshakePlayerCount;
|
IWRAM_DATA u8 sHandshakePlayerCount;
|
||||||
IWRAM_DATA u8 gUnknown_03000D74;
|
IWRAM_DATA u8 gUnknown_03000D74;
|
||||||
|
|
||||||
@@ -161,10 +161,10 @@ static void EnqueueSendCmd(u16 *sendCmd);
|
|||||||
static void DequeueRecvCmds(u16 (*recvCmds)[CMD_LENGTH]);
|
static void DequeueRecvCmds(u16 (*recvCmds)[CMD_LENGTH]);
|
||||||
static void StartTransfer(void);
|
static void StartTransfer(void);
|
||||||
static bool8 DoHandshake(void);
|
static bool8 DoHandshake(void);
|
||||||
void DoRecv(void);
|
static void DoRecv(void);
|
||||||
void DoSend(void);
|
static void DoSend(void);
|
||||||
void StopTimer(void);
|
static void StopTimer(void);
|
||||||
void SendRecvDone(void);
|
static void SendRecvDone(void);
|
||||||
|
|
||||||
// .rodata
|
// .rodata
|
||||||
|
|
||||||
@@ -282,7 +282,7 @@ void LinkTestScreen(void)
|
|||||||
gLinkType = 0x1111;
|
gLinkType = 0x1111;
|
||||||
OpenLink();
|
OpenLink();
|
||||||
SeedRng(gMain.vblankCounter2);
|
SeedRng(gMain.vblankCounter2);
|
||||||
for (i = 0; i < MAX_LINK_PLAYERS; i ++)
|
for (i = 0; i < MAX_LINK_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
gSaveBlock2Ptr->playerTrainerId[i] = Random() % 256;
|
gSaveBlock2Ptr->playerTrainerId[i] = Random() % 256;
|
||||||
}
|
}
|
||||||
@@ -331,7 +331,7 @@ static void InitLink(void)
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < 8; i ++)
|
for (i = 0; i < 8; i++)
|
||||||
{
|
{
|
||||||
gSendCmd[i] = 0xefff;
|
gSendCmd[i] = 0xefff;
|
||||||
}
|
}
|
||||||
@@ -341,7 +341,7 @@ static void InitLink(void)
|
|||||||
|
|
||||||
static void Task_TriggerHandshake(u8 taskId)
|
static void Task_TriggerHandshake(u8 taskId)
|
||||||
{
|
{
|
||||||
if (++ gTasks[taskId].data[0] == 5)
|
if (++gTasks[taskId].data[0] == 5)
|
||||||
{
|
{
|
||||||
gShouldAdvanceLinkState = 1;
|
gShouldAdvanceLinkState = 1;
|
||||||
DestroyTask(taskId);
|
DestroyTask(taskId);
|
||||||
@@ -373,7 +373,7 @@ void OpenLink(void)
|
|||||||
sub_800E700();
|
sub_800E700();
|
||||||
}
|
}
|
||||||
gReceivedRemoteLinkPlayers = 0;
|
gReceivedRemoteLinkPlayers = 0;
|
||||||
for (i = 0; i < MAX_LINK_PLAYERS; i ++)
|
for (i = 0; i < MAX_LINK_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
gRemoteLinkPlayersNotReceived[i] = TRUE;
|
gRemoteLinkPlayersNotReceived[i] = TRUE;
|
||||||
gUnknown_030030F0[i] = FALSE;
|
gUnknown_030030F0[i] = FALSE;
|
||||||
@@ -402,7 +402,7 @@ static void TestBlockTransfer(u8 nothing, u8 is, u8 used)
|
|||||||
LinkTest_prnthex(sBlockSend.pos, 2, 3, 2);
|
LinkTest_prnthex(sBlockSend.pos, 2, 3, 2);
|
||||||
sLinkTestLastBlockSendPos = sBlockSend.pos;
|
sLinkTestLastBlockSendPos = sBlockSend.pos;
|
||||||
}
|
}
|
||||||
for (i = 0; i < MAX_LINK_PLAYERS; i ++)
|
for (i = 0; i < MAX_LINK_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
if (sLinkTestLastBlockRecvPos[i] != sBlockRecv[i].pos)
|
if (sLinkTestLastBlockRecvPos[i] != sBlockRecv[i].pos)
|
||||||
{
|
{
|
||||||
@@ -413,7 +413,7 @@ static void TestBlockTransfer(u8 nothing, u8 is, u8 used)
|
|||||||
status = GetBlockReceivedStatus();
|
status = GetBlockReceivedStatus();
|
||||||
if (status == 0xF) // 0b1111
|
if (status == 0xF) // 0b1111
|
||||||
{
|
{
|
||||||
for (i = 0; i < MAX_LINK_PLAYERS; i ++)
|
for (i = 0; i < MAX_LINK_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
if ((status >> i) & 1)
|
if ((status >> i) & 1)
|
||||||
{
|
{
|
||||||
@@ -479,7 +479,7 @@ u16 LinkMain2(const u16 *heldKeys)
|
|||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
for (i = 0; i < 8; i ++)
|
for (i = 0; i < 8; i++)
|
||||||
{
|
{
|
||||||
gSendCmd[i] = 0;
|
gSendCmd[i] = 0;
|
||||||
}
|
}
|
||||||
@@ -503,7 +503,7 @@ static void HandleReceiveRemoteLinkPlayer(u8 who)
|
|||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
gRemoteLinkPlayersNotReceived[who] = FALSE;
|
gRemoteLinkPlayersNotReceived[who] = FALSE;
|
||||||
for (i = 0; i < GetLinkPlayerCount_2(); i ++)
|
for (i = 0; i < GetLinkPlayerCount_2(); i++)
|
||||||
{
|
{
|
||||||
count += gRemoteLinkPlayersNotReceived[i];
|
count += gRemoteLinkPlayersNotReceived[i];
|
||||||
}
|
}
|
||||||
@@ -517,7 +517,7 @@ static void ProcessRecvCmds(u8 unused)
|
|||||||
{
|
{
|
||||||
u16 i;
|
u16 i;
|
||||||
|
|
||||||
for (i = 0; i < MAX_LINK_PLAYERS; i ++)
|
for (i = 0; i < MAX_LINK_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
gLinkPartnersHeldKeys[i] = 0;
|
gLinkPartnersHeldKeys[i] = 0;
|
||||||
if (gRecvCmds[i][0] == 0)
|
if (gRecvCmds[i][0] == 0)
|
||||||
@@ -565,7 +565,7 @@ static void ProcessRecvCmds(u8 unused)
|
|||||||
u16 j;
|
u16 j;
|
||||||
|
|
||||||
buffer = (u16 *)gDecompressionBuffer;
|
buffer = (u16 *)gDecompressionBuffer;
|
||||||
for (j = 0; j < CMD_LENGTH - 1; j ++)
|
for (j = 0; j < CMD_LENGTH - 1; j++)
|
||||||
{
|
{
|
||||||
buffer[(sBlockRecv[i].pos / 2) + j] = gRecvCmds[i][j + 1];
|
buffer[(sBlockRecv[i].pos / 2) + j] = gRecvCmds[i][j + 1];
|
||||||
}
|
}
|
||||||
@@ -574,7 +574,7 @@ static void ProcessRecvCmds(u8 unused)
|
|||||||
{
|
{
|
||||||
u16 j;
|
u16 j;
|
||||||
|
|
||||||
for (j = 0; j < CMD_LENGTH - 1; j ++)
|
for (j = 0; j < CMD_LENGTH - 1; j++)
|
||||||
{
|
{
|
||||||
gBlockRecvBuffer[i][(sBlockRecv[i].pos / 2) + j] = gRecvCmds[i][j + 1];
|
gBlockRecvBuffer[i][(sBlockRecv[i].pos / 2) + j] = gRecvCmds[i][j + 1];
|
||||||
}
|
}
|
||||||
@@ -662,7 +662,7 @@ static void BuildSendCmd(u16 command)
|
|||||||
u8 i;
|
u8 i;
|
||||||
|
|
||||||
gSendCmd[0] = LINKCMD_0x7777;
|
gSendCmd[0] = LINKCMD_0x7777;
|
||||||
for (i = 0; i < 5; i ++)
|
for (i = 0; i < 5; i++)
|
||||||
{
|
{
|
||||||
gSendCmd[i + 1] = 0xEE;
|
gSendCmd[i + 1] = 0xEE;
|
||||||
}
|
}
|
||||||
@@ -771,7 +771,7 @@ static int sub_8009FF8(u32 version1, u32 version2)
|
|||||||
u8 nPlayers;
|
u8 nPlayers;
|
||||||
|
|
||||||
nPlayers = GetLinkPlayerCount();
|
nPlayers = GetLinkPlayerCount();
|
||||||
for (i = 0; i < nPlayers; i ++)
|
for (i = 0; i < nPlayers; i++)
|
||||||
{
|
{
|
||||||
if ((gLinkPlayers[i].version & 0xFF) == version1 || (gLinkPlayers[i].version & 0xFF) == version2)
|
if ((gLinkPlayers[i].version & 0xFF) == version1 || (gLinkPlayers[i].version & 0xFF) == version2)
|
||||||
{
|
{
|
||||||
@@ -848,11 +848,11 @@ u8 GetLinkPlayerDataExchangeStatusTimed(int lower, int upper)
|
|||||||
gLinkErrorOccurred = TRUE;
|
gLinkErrorOccurred = TRUE;
|
||||||
CloseLink();
|
CloseLink();
|
||||||
}
|
}
|
||||||
for (i = 0, index = 0; i < GetLinkPlayerCount(); index ++, i ++)
|
for (i = 0, index = 0; i < GetLinkPlayerCount(); index++, i++)
|
||||||
{
|
{
|
||||||
if (gLinkPlayers[index].linkType == gLinkPlayers[0].linkType)
|
if (gLinkPlayers[index].linkType == gLinkPlayers[0].linkType)
|
||||||
{
|
{
|
||||||
count ++;
|
count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (count == GetLinkPlayerCount())
|
if (count == GetLinkPlayerCount())
|
||||||
@@ -889,7 +889,7 @@ u8 GetLinkPlayerDataExchangeStatusTimed(int lower, int upper)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (++ gLinkTimeOutCounter > 600)
|
else if (++gLinkTimeOutCounter > 600)
|
||||||
{
|
{
|
||||||
sPlayerDataExchangeStatus = EXCHANGE_TIMED_OUT;
|
sPlayerDataExchangeStatus = EXCHANGE_TIMED_OUT;
|
||||||
}
|
}
|
||||||
@@ -903,11 +903,11 @@ bool8 IsLinkPlayerDataExchangeComplete(void)
|
|||||||
bool8 retval;
|
bool8 retval;
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
for (i = 0; i < GetLinkPlayerCount(); i ++)
|
for (i = 0; i < GetLinkPlayerCount(); i++)
|
||||||
{
|
{
|
||||||
if (gLinkPlayers[i].linkType == gLinkPlayers[0].linkType)
|
if (gLinkPlayers[i].linkType == gLinkPlayers[0].linkType)
|
||||||
{
|
{
|
||||||
count ++;
|
count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (count == GetLinkPlayerCount())
|
if (count == GetLinkPlayerCount())
|
||||||
@@ -932,7 +932,7 @@ void ResetLinkPlayers(void)
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i <= MAX_LINK_PLAYERS; i ++)
|
for (i = 0; i <= MAX_LINK_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
gLinkPlayers[i] = (struct LinkPlayer){};
|
gLinkPlayers[i] = (struct LinkPlayer){};
|
||||||
}
|
}
|
||||||
@@ -976,7 +976,7 @@ static bool32 InitBlockSend(const void *src, size_t size)
|
|||||||
|
|
||||||
static void LinkCB_BlockSendBegin(void)
|
static void LinkCB_BlockSendBegin(void)
|
||||||
{
|
{
|
||||||
if (++ sBlockSendDelayCounter > 2)
|
if (++sBlockSendDelayCounter > 2)
|
||||||
{
|
{
|
||||||
gLinkCallback = LinkCB_BlockSend;
|
gLinkCallback = LinkCB_BlockSend;
|
||||||
}
|
}
|
||||||
@@ -989,7 +989,7 @@ static void LinkCB_BlockSend(void)
|
|||||||
|
|
||||||
src = sBlockSend.src;
|
src = sBlockSend.src;
|
||||||
gSendCmd[0] = LINKCMD_CONT_BLOCK;
|
gSendCmd[0] = LINKCMD_CONT_BLOCK;
|
||||||
for (i = 0; i < 7; i ++)
|
for (i = 0; i < 7; i++)
|
||||||
{
|
{
|
||||||
gSendCmd[i + 1] = (src[sBlockSend.pos + i * 2 + 1] << 8) | src[sBlockSend.pos + i * 2];
|
gSendCmd[i + 1] = (src[sBlockSend.pos + i * 2 + 1] << 8) | src[sBlockSend.pos + i * 2];
|
||||||
}
|
}
|
||||||
@@ -1010,7 +1010,7 @@ static void sub_800A3F8(void)
|
|||||||
{
|
{
|
||||||
GetMultiplayerId();
|
GetMultiplayerId();
|
||||||
BuildSendCmd(LINKCMD_SEND_HELD_KEYS);
|
BuildSendCmd(LINKCMD_SEND_HELD_KEYS);
|
||||||
gUnknown_020223C0 ++;
|
gUnknown_020223C0++;
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_800A418(void)
|
void sub_800A418(void)
|
||||||
@@ -1113,14 +1113,14 @@ void ResetBlockReceivedFlags(void)
|
|||||||
|
|
||||||
if (gWirelessCommType == TRUE)
|
if (gWirelessCommType == TRUE)
|
||||||
{
|
{
|
||||||
for (i = 0; i < MAX_RFU_PLAYERS; i ++)
|
for (i = 0; i < MAX_RFU_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
sub_800F728(i);
|
sub_800F728(i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for (i = 0; i < MAX_LINK_PLAYERS; i ++)
|
for (i = 0; i < MAX_LINK_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
gBlockReceivedStatus[i] = FALSE;
|
gBlockReceivedStatus[i] = FALSE;
|
||||||
}
|
}
|
||||||
@@ -1153,7 +1153,7 @@ static u16 LinkTestCalcBlockChecksum(const u16 *src, u16 size)
|
|||||||
u16 i;
|
u16 i;
|
||||||
|
|
||||||
chksum = 0;
|
chksum = 0;
|
||||||
for (i = 0; i < size / 2; i ++)
|
for (i = 0; i < size / 2; i++)
|
||||||
{
|
{
|
||||||
chksum += src[i];
|
chksum += src[i];
|
||||||
}
|
}
|
||||||
@@ -1181,15 +1181,15 @@ static void LinkTest_prnthex(u32 pos, u8 a0, u8 a1, u8 a2)
|
|||||||
char sp[32 / 2];
|
char sp[32 / 2];
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < a2; i ++)
|
for (i = 0; i < a2; i++)
|
||||||
{
|
{
|
||||||
sp[i] = pos & 0xf;
|
sp[i] = pos & 0xf;
|
||||||
pos >>= 4;
|
pos >>= 4;
|
||||||
}
|
}
|
||||||
for (i = a2 - 1; i >= 0; i --)
|
for (i = a2 - 1; i >= 0; i--)
|
||||||
{
|
{
|
||||||
LinkTest_prnthexchar(sp[i], a0, a1);
|
LinkTest_prnthexchar(sp[i], a0, a1);
|
||||||
a0 ++;
|
a0++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1205,15 +1205,15 @@ static void LinkTest_prntint(int a0, u8 a1, u8 a2, u8 a3)
|
|||||||
sp10 = a1;
|
sp10 = a1;
|
||||||
a0 = -a0;
|
a0 = -a0;
|
||||||
}
|
}
|
||||||
for (i = 0; i < a3; i ++)
|
for (i = 0; i < a3; i++)
|
||||||
{
|
{
|
||||||
sp[i] = a0 % 10;
|
sp[i] = a0 % 10;
|
||||||
a0 /= 10;
|
a0 /= 10;
|
||||||
}
|
}
|
||||||
for (i = a3 - 1; i >= 0; i --)
|
for (i = a3 - 1; i >= 0; i--)
|
||||||
{
|
{
|
||||||
LinkTest_prnthexchar(sp[i], a1, a2);
|
LinkTest_prnthexchar(sp[i], a1, a2);
|
||||||
a1 ++;
|
a1++;
|
||||||
}
|
}
|
||||||
if (sp10 != -1)
|
if (sp10 != -1)
|
||||||
{
|
{
|
||||||
@@ -1229,17 +1229,17 @@ static void LinkTest_prntstr(const char *a0, u8 a1, u8 a2)
|
|||||||
|
|
||||||
r5 = 0;
|
r5 = 0;
|
||||||
r6 = 0;
|
r6 = 0;
|
||||||
for (i = 0; a0[i] != 0; a0 ++)
|
for (i = 0; a0[i] != 0; a0++)
|
||||||
{
|
{
|
||||||
if (a0[i] == *"\n")
|
if (a0[i] == *"\n")
|
||||||
{
|
{
|
||||||
r5 ++;
|
r5++;
|
||||||
r6 = 0;
|
r6 = 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
LinkTest_prntchar(a0[i], a1 + r6, a2 + r5);
|
LinkTest_prntchar(a0[i], a1 + r6, a2 + r5);
|
||||||
r6 ++;
|
r6++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1292,7 +1292,7 @@ u8 sub_800A9A8(void)
|
|||||||
u8 flags;
|
u8 flags;
|
||||||
|
|
||||||
flags = 0;
|
flags = 0;
|
||||||
for (i = 0; i < gSavedLinkPlayerCount; i ++)
|
for (i = 0; i < gSavedLinkPlayerCount; i++)
|
||||||
{
|
{
|
||||||
flags |= (1 << i);
|
flags |= (1 << i);
|
||||||
}
|
}
|
||||||
@@ -1305,7 +1305,7 @@ u8 sub_800A9D8(void)
|
|||||||
u8 flags;
|
u8 flags;
|
||||||
|
|
||||||
flags = 0;
|
flags = 0;
|
||||||
for (i = 0; i < GetLinkPlayerCount(); i ++)
|
for (i = 0; i < GetLinkPlayerCount(); i++)
|
||||||
{
|
{
|
||||||
flags |= (1 << i);
|
flags |= (1 << i);
|
||||||
}
|
}
|
||||||
@@ -1318,7 +1318,7 @@ void sub_800AA04(u8 a0)
|
|||||||
|
|
||||||
gSavedLinkPlayerCount = a0;
|
gSavedLinkPlayerCount = a0;
|
||||||
gSavedMultiplayerId = GetMultiplayerId();
|
gSavedMultiplayerId = GetMultiplayerId();
|
||||||
for (i = 0; i < MAX_RFU_PLAYERS; i ++)
|
for (i = 0; i < MAX_RFU_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
gSavedLinkPlayers[i] = gLinkPlayers[i];
|
gSavedLinkPlayers[i] = gLinkPlayers[i];
|
||||||
}
|
}
|
||||||
@@ -1340,7 +1340,7 @@ bool8 sub_800AA60(void)
|
|||||||
unsigned count;
|
unsigned count;
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
for (i = 0; i < gSavedLinkPlayerCount; i ++)
|
for (i = 0; i < gSavedLinkPlayerCount; i++)
|
||||||
{
|
{
|
||||||
if (gLinkPlayers[i].trainerId == gSavedLinkPlayers[i].trainerId)
|
if (gLinkPlayers[i].trainerId == gSavedLinkPlayers[i].trainerId)
|
||||||
{
|
{
|
||||||
@@ -1348,12 +1348,12 @@ bool8 sub_800AA60(void)
|
|||||||
{
|
{
|
||||||
if (gLinkType == gLinkPlayers[i].linkType)
|
if (gLinkType == gLinkPlayers[i].linkType)
|
||||||
{
|
{
|
||||||
count ++;
|
count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
count ++;
|
count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1372,7 +1372,7 @@ void sub_800AAF4(void)
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
// Clearly not what was meant to be written, but here it is anyway.
|
// Clearly not what was meant to be written, but here it is anyway.
|
||||||
for (i = 0; i < 4; i ++)
|
for (i = 0; i < 4; i++)
|
||||||
{
|
{
|
||||||
CpuSet(&gSavedLinkPlayers[i], NULL, sizeof(struct LinkPlayer));
|
CpuSet(&gSavedLinkPlayers[i], NULL, sizeof(struct LinkPlayer));
|
||||||
}
|
}
|
||||||
@@ -1382,7 +1382,7 @@ void sub_800AB18(void)
|
|||||||
{
|
{
|
||||||
u8 i;
|
u8 i;
|
||||||
|
|
||||||
for (i = 0; i < gSavedLinkPlayerCount; i ++)
|
for (i = 0; i < gSavedLinkPlayerCount; i++)
|
||||||
{
|
{
|
||||||
if (gSavedLinkPlayers[i].trainerId != gLinkPlayers[i].trainerId || StringCompare(gSavedLinkPlayers[i].name, gLinkPlayers[i].name) != 0)
|
if (gSavedLinkPlayers[i].trainerId != gLinkPlayers[i].trainerId || StringCompare(gSavedLinkPlayers[i].name, gLinkPlayers[i].name) != 0)
|
||||||
{
|
{
|
||||||
@@ -1445,7 +1445,7 @@ void sub_800AC34(void)
|
|||||||
{
|
{
|
||||||
if (gLinkCallback != NULL)
|
if (gLinkCallback != NULL)
|
||||||
{
|
{
|
||||||
gUnknown_02022B08 ++;
|
gUnknown_02022B08++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -1473,11 +1473,11 @@ static void sub_800ACAC(void)
|
|||||||
|
|
||||||
linkPlayerCount = GetLinkPlayerCount();
|
linkPlayerCount = GetLinkPlayerCount();
|
||||||
count = 0;
|
count = 0;
|
||||||
for (i = 0; i < linkPlayerCount; i ++)
|
for (i = 0; i < linkPlayerCount; i++)
|
||||||
{
|
{
|
||||||
if (gUnknown_030030F0[i])
|
if (gUnknown_030030F0[i])
|
||||||
{
|
{
|
||||||
count ++;
|
count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (count == linkPlayerCount)
|
if (count == linkPlayerCount)
|
||||||
@@ -1500,7 +1500,7 @@ void sub_800AD10(void)
|
|||||||
{
|
{
|
||||||
if (gLinkCallback != NULL)
|
if (gLinkCallback != NULL)
|
||||||
{
|
{
|
||||||
gUnknown_02022B08 ++;
|
gUnknown_02022B08++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -1528,15 +1528,15 @@ static void sub_800AD88(void)
|
|||||||
|
|
||||||
linkPlayerCount = GetLinkPlayerCount();
|
linkPlayerCount = GetLinkPlayerCount();
|
||||||
count = 0;
|
count = 0;
|
||||||
for (i = 0; i < linkPlayerCount; i ++)
|
for (i = 0; i < linkPlayerCount; i++)
|
||||||
{
|
{
|
||||||
if (gLinkPlayers[i].language == LANGUAGE_JAPANESE)
|
if (gLinkPlayers[i].language == LANGUAGE_JAPANESE)
|
||||||
{
|
{
|
||||||
count ++;
|
count++;
|
||||||
}
|
}
|
||||||
else if (gUnknown_030030F0[i])
|
else if (gUnknown_030030F0[i])
|
||||||
{
|
{
|
||||||
count ++;
|
count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (count == linkPlayerCount)
|
if (count == linkPlayerCount)
|
||||||
@@ -1580,7 +1580,7 @@ static void sub_800AE5C(void)
|
|||||||
u8 linkPlayerCount;
|
u8 linkPlayerCount;
|
||||||
|
|
||||||
linkPlayerCount = GetLinkPlayerCount();
|
linkPlayerCount = GetLinkPlayerCount();
|
||||||
for (i = 0; i < linkPlayerCount; i ++)
|
for (i = 0; i < linkPlayerCount; i++)
|
||||||
{
|
{
|
||||||
if (!gUnknown_030030EC[i])
|
if (!gUnknown_030030EC[i])
|
||||||
{
|
{
|
||||||
@@ -1589,7 +1589,7 @@ static void sub_800AE5C(void)
|
|||||||
}
|
}
|
||||||
if (i == linkPlayerCount)
|
if (i == linkPlayerCount)
|
||||||
{
|
{
|
||||||
for (i = 0; i < MAX_LINK_PLAYERS; i ++)
|
for (i = 0; i < MAX_LINK_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
gUnknown_030030EC[i] = FALSE;
|
gUnknown_030030EC[i] = FALSE;
|
||||||
}
|
}
|
||||||
@@ -1767,7 +1767,7 @@ static void CB2_PrintErrorMessage(void)
|
|||||||
}
|
}
|
||||||
if (gMain.state != 160)
|
if (gMain.state != 160)
|
||||||
{
|
{
|
||||||
gMain.state ++;
|
gMain.state++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1927,8 +1927,8 @@ static void EnableSerial(void)
|
|||||||
CpuFill32(0, &gLink, sizeof(gLink));
|
CpuFill32(0, &gLink, sizeof(gLink));
|
||||||
sNumVBlanksWithoutSerialIntr = 0;
|
sNumVBlanksWithoutSerialIntr = 0;
|
||||||
sSendNonzeroCheck = 0;
|
sSendNonzeroCheck = 0;
|
||||||
gUnknown_03000D70 = 0;
|
sRecvNonzeroCheck = 0;
|
||||||
gUnknown_03000D72 = 0;
|
sChecksumAvailable = 0;
|
||||||
sHandshakePlayerCount = 0;
|
sHandshakePlayerCount = 0;
|
||||||
gLastSendQueueCount = 0;
|
gLastSendQueueCount = 0;
|
||||||
gLastRecvQueueCount = 0;
|
gLastRecvQueueCount = 0;
|
||||||
@@ -2061,7 +2061,7 @@ static void InitTimer(void)
|
|||||||
{
|
{
|
||||||
if (gLink.isMaster)
|
if (gLink.isMaster)
|
||||||
{
|
{
|
||||||
REG_TM3CNT_L = 0xFF3B;
|
REG_TM3CNT_L = -197;
|
||||||
REG_TM3CNT_H = TIMER_64CLK | TIMER_INTR_ENABLE;
|
REG_TM3CNT_H = TIMER_64CLK | TIMER_INTR_ENABLE;
|
||||||
EnableInterrupts(INTR_FLAG_TIMER3);
|
EnableInterrupts(INTR_FLAG_TIMER3);
|
||||||
}
|
}
|
||||||
@@ -2081,7 +2081,7 @@ static void EnqueueSendCmd(u16 *sendCmd)
|
|||||||
{
|
{
|
||||||
offset -= QUEUE_CAPACITY;
|
offset -= QUEUE_CAPACITY;
|
||||||
}
|
}
|
||||||
for (i = 0; i < CMD_LENGTH; i ++)
|
for (i = 0; i < CMD_LENGTH; i++)
|
||||||
{
|
{
|
||||||
sSendNonzeroCheck |= *sendCmd;
|
sSendNonzeroCheck |= *sendCmd;
|
||||||
gLink.sendQueue.data[i][offset] = *sendCmd;
|
gLink.sendQueue.data[i][offset] = *sendCmd;
|
||||||
@@ -2095,7 +2095,7 @@ static void EnqueueSendCmd(u16 *sendCmd)
|
|||||||
}
|
}
|
||||||
if (sSendNonzeroCheck)
|
if (sSendNonzeroCheck)
|
||||||
{
|
{
|
||||||
gLink.sendQueue.count ++;
|
gLink.sendQueue.count++;
|
||||||
sSendNonzeroCheck = 0;
|
sSendNonzeroCheck = 0;
|
||||||
}
|
}
|
||||||
REG_IME = gLinkSavedIme;
|
REG_IME = gLinkSavedIme;
|
||||||
@@ -2112,9 +2112,9 @@ static void DequeueRecvCmds(u16 (*recvCmds)[CMD_LENGTH])
|
|||||||
REG_IME = 0;
|
REG_IME = 0;
|
||||||
if (gLink.recvQueue.count == 0)
|
if (gLink.recvQueue.count == 0)
|
||||||
{
|
{
|
||||||
for (i = 0; i < gLink.playerCount; i ++)
|
for (i = 0; i < gLink.playerCount; i++)
|
||||||
{
|
{
|
||||||
for (j = 0; j < CMD_LENGTH; j ++)
|
for (j = 0; j < CMD_LENGTH; j++)
|
||||||
{
|
{
|
||||||
recvCmds[i][j] = 0;
|
recvCmds[i][j] = 0;
|
||||||
}
|
}
|
||||||
@@ -2124,15 +2124,15 @@ static void DequeueRecvCmds(u16 (*recvCmds)[CMD_LENGTH])
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for (i = 0; i < gLink.playerCount; i ++)
|
for (i = 0; i < gLink.playerCount; i++)
|
||||||
{
|
{
|
||||||
for (j = 0; j < CMD_LENGTH; j ++)
|
for (j = 0; j < CMD_LENGTH; j++)
|
||||||
{
|
{
|
||||||
recvCmds[i][j] = gLink.recvQueue.data[i][j][gLink.recvQueue.pos];
|
recvCmds[i][j] = gLink.recvQueue.data[i][j][gLink.recvQueue.pos];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
gLink.recvQueue.count --;
|
gLink.recvQueue.count--;
|
||||||
gLink.recvQueue.pos ++;
|
gLink.recvQueue.pos++;
|
||||||
if (gLink.recvQueue.pos >= QUEUE_CAPACITY)
|
if (gLink.recvQueue.pos >= QUEUE_CAPACITY)
|
||||||
{
|
{
|
||||||
gLink.recvQueue.pos = 0;
|
gLink.recvQueue.pos = 0;
|
||||||
@@ -2142,6 +2142,8 @@ static void DequeueRecvCmds(u16 (*recvCmds)[CMD_LENGTH])
|
|||||||
REG_IME = gLinkSavedIme;
|
REG_IME = gLinkSavedIme;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// link_intr.c
|
||||||
|
|
||||||
void LinkVSync(void)
|
void LinkVSync(void)
|
||||||
{
|
{
|
||||||
if (gLink.isMaster)
|
if (gLink.isMaster)
|
||||||
@@ -2173,7 +2175,7 @@ void LinkVSync(void)
|
|||||||
}
|
}
|
||||||
else if (gLink.state == LINK_STATE_CONN_ESTABLISHED || gLink.state == LINK_STATE_HANDSHAKE)
|
else if (gLink.state == LINK_STATE_CONN_ESTABLISHED || gLink.state == LINK_STATE_HANDSHAKE)
|
||||||
{
|
{
|
||||||
if (++ sNumVBlanksWithoutSerialIntr > 10)
|
if (++sNumVBlanksWithoutSerialIntr > 10)
|
||||||
{
|
{
|
||||||
if (gLink.state == LINK_STATE_CONN_ESTABLISHED)
|
if (gLink.state == LINK_STATE_CONN_ESTABLISHED)
|
||||||
{
|
{
|
||||||
@@ -2220,7 +2222,7 @@ void SerialCB(void)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
gLink.serialIntrCounter ++;
|
gLink.serialIntrCounter++;
|
||||||
sNumVBlanksWithoutSerialIntr = 0;
|
sNumVBlanksWithoutSerialIntr = 0;
|
||||||
if (gLink.serialIntrCounter == 8)
|
if (gLink.serialIntrCounter == 8)
|
||||||
{
|
{
|
||||||
@@ -2252,11 +2254,11 @@ static bool8 DoHandshake(void)
|
|||||||
*(u64 *)gLink.tempRecvBuffer = REG_SIOMLT_RECV;
|
*(u64 *)gLink.tempRecvBuffer = REG_SIOMLT_RECV;
|
||||||
REG_SIOMLT_RECV = 0;
|
REG_SIOMLT_RECV = 0;
|
||||||
gLink.handshakeAsMaster = FALSE;
|
gLink.handshakeAsMaster = FALSE;
|
||||||
for (i = 0; i < 4; i ++)
|
for (i = 0; i < 4; i++)
|
||||||
{
|
{
|
||||||
if ((gLink.tempRecvBuffer[i] & ~0x3) == SLAVE_HANDSHAKE || gLink.tempRecvBuffer[i] == MASTER_HANDSHAKE)
|
if ((gLink.tempRecvBuffer[i] & ~0x3) == SLAVE_HANDSHAKE || gLink.tempRecvBuffer[i] == MASTER_HANDSHAKE)
|
||||||
{
|
{
|
||||||
playerCount ++;
|
playerCount++;
|
||||||
if (minRecv > gLink.tempRecvBuffer[i] && gLink.tempRecvBuffer[i] != 0)
|
if (minRecv > gLink.tempRecvBuffer[i] && gLink.tempRecvBuffer[i] != 0)
|
||||||
{
|
{
|
||||||
minRecv = gLink.tempRecvBuffer[i];
|
minRecv = gLink.tempRecvBuffer[i];
|
||||||
@@ -2287,3 +2289,110 @@ static bool8 DoHandshake(void)
|
|||||||
sHandshakePlayerCount = gLink.playerCount;
|
sHandshakePlayerCount = gLink.playerCount;
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void DoRecv(void)
|
||||||
|
{
|
||||||
|
u16 recv[4];
|
||||||
|
u8 i;
|
||||||
|
u8 index;
|
||||||
|
|
||||||
|
*(u64 *)recv = REG_SIOMLT_RECV;
|
||||||
|
if (gLink.sendCmdIndex == 0)
|
||||||
|
{
|
||||||
|
for (i = 0; i < gLink.playerCount; i++)
|
||||||
|
{
|
||||||
|
if (gLink.checksum != recv[i] && sChecksumAvailable)
|
||||||
|
{
|
||||||
|
gLink.badChecksum = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
gLink.checksum = 0;
|
||||||
|
sChecksumAvailable = TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
index = gLink.recvQueue.pos + gLink.recvQueue.count;
|
||||||
|
if (index >= QUEUE_CAPACITY)
|
||||||
|
{
|
||||||
|
index -= QUEUE_CAPACITY;
|
||||||
|
}
|
||||||
|
if (gLink.recvQueue.count < QUEUE_CAPACITY)
|
||||||
|
{
|
||||||
|
for (i = 0; i < gLink.playerCount; i++)
|
||||||
|
{
|
||||||
|
gLink.checksum += recv[i];
|
||||||
|
sRecvNonzeroCheck |= recv[i];
|
||||||
|
gLink.recvQueue.data[i][gLink.recvCmdIndex][index] = recv[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gLink.queueFull = QUEUE_FULL_RECV;
|
||||||
|
}
|
||||||
|
gLink.recvCmdIndex++;
|
||||||
|
if (gLink.recvCmdIndex == CMD_LENGTH && sRecvNonzeroCheck)
|
||||||
|
{
|
||||||
|
gLink.recvQueue.count++;
|
||||||
|
sRecvNonzeroCheck = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void DoSend(void)
|
||||||
|
{
|
||||||
|
if (gLink.sendCmdIndex == CMD_LENGTH)
|
||||||
|
{
|
||||||
|
REG_SIOMLT_SEND = gLink.checksum;
|
||||||
|
if (!sSendBufferEmpty)
|
||||||
|
{
|
||||||
|
gLink.sendQueue.count--;
|
||||||
|
gLink.sendQueue.pos++;
|
||||||
|
if (gLink.sendQueue.pos >= QUEUE_CAPACITY)
|
||||||
|
{
|
||||||
|
gLink.sendQueue.pos = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sSendBufferEmpty = FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (!sSendBufferEmpty && gLink.sendQueue.count == 0)
|
||||||
|
{
|
||||||
|
sSendBufferEmpty = TRUE;
|
||||||
|
}
|
||||||
|
if (sSendBufferEmpty)
|
||||||
|
{
|
||||||
|
REG_SIOMLT_SEND = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
REG_SIOMLT_SEND = gLink.sendQueue.data[gLink.sendCmdIndex][gLink.sendQueue.pos];
|
||||||
|
}
|
||||||
|
gLink.sendCmdIndex++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void StopTimer(void)
|
||||||
|
{
|
||||||
|
if (gLink.isMaster)
|
||||||
|
{
|
||||||
|
REG_TM3CNT_H &= ~TIMER_ENABLE;
|
||||||
|
REG_TM3CNT_L = -197;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void SendRecvDone(void)
|
||||||
|
{
|
||||||
|
if (gLink.recvCmdIndex == CMD_LENGTH)
|
||||||
|
{
|
||||||
|
gLink.sendCmdIndex = 0;
|
||||||
|
gLink.recvCmdIndex = 0;
|
||||||
|
}
|
||||||
|
else if (gLink.isMaster)
|
||||||
|
{
|
||||||
|
REG_TM3CNT_H |= TIMER_ENABLE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user