mirror of
https://github.com/PurpleI2P/i2pd
synced 2024-11-10 00:00:29 +03:00
cleanup out-of-sequnce list more aggressivly
This commit is contained in:
parent
bf8eecf407
commit
4960587f46
@ -2851,7 +2851,8 @@ namespace transport
|
|||||||
}
|
}
|
||||||
if (!m_OutOfSequencePackets.empty ())
|
if (!m_OutOfSequencePackets.empty ())
|
||||||
{
|
{
|
||||||
if (m_OutOfSequencePackets.size () > 2*SSU2_MAX_NUM_ACK_RANGES ||
|
int ranges = 0;
|
||||||
|
while (m_OutOfSequencePackets.size () > 2*SSU2_MAX_NUM_ACK_RANGES ||
|
||||||
*m_OutOfSequencePackets.rbegin () > m_ReceivePacketNum + 255*8)
|
*m_OutOfSequencePackets.rbegin () > m_ReceivePacketNum + 255*8)
|
||||||
{
|
{
|
||||||
uint32_t packet = *m_OutOfSequencePackets.begin ();
|
uint32_t packet = *m_OutOfSequencePackets.begin ();
|
||||||
@ -2861,9 +2862,14 @@ namespace transport
|
|||||||
packet--;
|
packet--;
|
||||||
m_ReceivePacketNum = packet - 1;
|
m_ReceivePacketNum = packet - 1;
|
||||||
UpdateReceivePacketNum (packet);
|
UpdateReceivePacketNum (packet);
|
||||||
|
ranges++;
|
||||||
|
if (ranges > SSU2_MAX_NUM_ACK_RANGES) break;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
LogPrint (eLogError, "SSU2: Out of sequence packet ", packet, " is less than last received ", m_ReceivePacketNum);
|
LogPrint (eLogError, "SSU2: Out of sequence packet ", packet, " is less than last received ", m_ReceivePacketNum);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (m_OutOfSequencePackets.size () > 255*4)
|
if (m_OutOfSequencePackets.size () > 255*4)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user