cancel CMD transfer if there isn't enough time left

This commit is contained in:
Arisotura 2023-07-25 23:45:10 +02:00
parent a87dc83279
commit b04c250e2f
1 changed files with 35 additions and 8 deletions

View File

@ -564,8 +564,6 @@ void StartTX_Cmd()
{ {
TXSlot* slot = &TXSlots[1]; TXSlot* slot = &TXSlots[1];
// TODO: cancel the transfer if there isn't enough time left (check CMDCOUNT)
if (IOPORT(W_TXSlotCmd) & 0x3000) if (IOPORT(W_TXSlotCmd) & 0x3000)
Log(LogLevel::Warn,"wifi: !! unusual TXSLOT_CMD bits set %04X\n", IOPORT(W_TXSlotCmd)); Log(LogLevel::Warn,"wifi: !! unusual TXSLOT_CMD bits set %04X\n", IOPORT(W_TXSlotCmd));
@ -576,9 +574,22 @@ void StartTX_Cmd()
if (rate == 0x14) slot->Rate = 2; if (rate == 0x14) slot->Rate = 2;
else slot->Rate = 1; else slot->Rate = 1;
u32 duration = PreambleLen(slot->Rate) + (slot->Length * (slot->Rate==2 ? 4:8));
u16 clientmask = *(u16*)&RAM[slot->Addr + 12 + 24 + 2] & 0xFFFE;
duration += 112 + ((10 + IOPORT(W_CmdReplyTime)) * NumClients(clientmask));
duration += (32 * (slot->Rate==2 ? 4:8));
if (CmdCounter > (duration + 100))
{
slot->CurPhase = 0; slot->CurPhase = 0;
slot->CurPhaseTime = PreambleLen(slot->Rate); slot->CurPhaseTime = PreambleLen(slot->Rate);
} }
else
{
slot->CurPhase = 13;
slot->CurPhaseTime = CmdCounter - 100;
}
}
void StartTX_Beacon() void StartTX_Beacon()
{ {
@ -950,7 +961,7 @@ bool ProcessTX(TXSlot* slot, int num)
//slot->Addr = 0; //slot->Addr = 0;
//slot->Length = 28; //slot->Length = 28;
slot->CurPhase = 4; slot->CurPhase = 11;
slot->CurPhaseTime = 28*4; slot->CurPhaseTime = 28*4;
slot->HalfwordTimeMask = 0xFFFFFFFF; slot->HalfwordTimeMask = 0xFFFFFFFF;
} }
@ -1031,6 +1042,16 @@ bool ProcessTX(TXSlot* slot, int num)
} }
return true; return true;
case 11: // MP default reply transfer finished
{
IOPORT(W_TXSeqNo) = (IOPORT(W_TXSeqNo) + 1) & 0x0FFF;
IOPORT(W_TXBusy) &= ~0x80;
SetStatus(1);
FireTX();
}
return true;
case 2: // MP host transfer done case 2: // MP host transfer done
{ {
SetIRQ(7); SetIRQ(7);
@ -1045,7 +1066,7 @@ bool ProcessTX(TXSlot* slot, int num)
// send // send
u16 cmdcount = (CmdCounter + 9) / 10; u16 cmdcount = (CmdCounter + 9) / 10;
SendMPAck(cmdcount-3, MPClientFail); SendMPAck(cmdcount, MPClientFail);
slot->CurPhase = 3; slot->CurPhase = 3;
} }
@ -1084,12 +1105,18 @@ bool ProcessTX(TXSlot* slot, int num)
} }
return true; return true;
case 4: // MP default reply transfer finished case 13: // MP transfer failed (timeout)
{ {
IOPORT(W_TXBusy) &= ~(1<<1);
IOPORT(W_TXSlotCmd) &= 0x7FFF;
*(u16*)&RAM[slot->Addr] = 0x0005;
IOPORT(W_TXSeqNo) = (IOPORT(W_TXSeqNo) + 1) & 0x0FFF; IOPORT(W_TXSeqNo) = (IOPORT(W_TXSeqNo) + 1) & 0x0FFF;
IOPORT(W_TXBusy) &= ~0x80;
SetStatus(1); SetStatus(1);
SetIRQ(12);
FireTX(); FireTX();
} }
return true; return true;