mirror of
https://github.com/moparisthebest/minetest
synced 2025-01-11 05:38:01 -05:00
connection: Make assertions non-fatal for received data
This commit is contained in:
parent
3295f3c401
commit
3183d5a403
@ -312,13 +312,29 @@ BufferedPacket ReliablePacketBuffer::popSeqnum(u16 seqnum)
|
|||||||
void ReliablePacketBuffer::insert(BufferedPacket &p,u16 next_expected)
|
void ReliablePacketBuffer::insert(BufferedPacket &p,u16 next_expected)
|
||||||
{
|
{
|
||||||
JMutexAutoLock listlock(m_list_mutex);
|
JMutexAutoLock listlock(m_list_mutex);
|
||||||
FATAL_ERROR_IF(p.data.getSize() < BASE_HEADER_SIZE+3, "Invalid data size");
|
if (p.data.getSize() < BASE_HEADER_SIZE + 3) {
|
||||||
u8 type = readU8(&p.data[BASE_HEADER_SIZE+0]);
|
errorstream << "ReliablePacketBuffer::insert(): Invalid data size for "
|
||||||
sanity_check(type == TYPE_RELIABLE);
|
"reliable packet" << std::endl;
|
||||||
u16 seqnum = readU16(&p.data[BASE_HEADER_SIZE+1]);
|
return;
|
||||||
|
}
|
||||||
|
u8 type = readU8(&p.data[BASE_HEADER_SIZE + 0]);
|
||||||
|
if (type != TYPE_RELIABLE) {
|
||||||
|
errorstream << "ReliablePacketBuffer::insert(): type is not reliable"
|
||||||
|
<< std::endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
u16 seqnum = readU16(&p.data[BASE_HEADER_SIZE + 1]);
|
||||||
|
|
||||||
sanity_check(seqnum_in_window(seqnum, next_expected, MAX_RELIABLE_WINDOW_SIZE));
|
if (!seqnum_in_window(seqnum, next_expected, MAX_RELIABLE_WINDOW_SIZE)) {
|
||||||
sanity_check(seqnum != next_expected);
|
errorstream << "ReliablePacketBuffer::insert(): seqnum is outside of "
|
||||||
|
"expected window " << std::endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (seqnum == next_expected) {
|
||||||
|
errorstream << "ReliablePacketBuffer::insert(): seqnum is next expected"
|
||||||
|
<< std::endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
++m_list_size;
|
++m_list_size;
|
||||||
sanity_check(m_list_size <= SEQNUM_MAX+1); // FIXME: Handle the error?
|
sanity_check(m_list_size <= SEQNUM_MAX+1); // FIXME: Handle the error?
|
||||||
@ -377,10 +393,6 @@ void ReliablePacketBuffer::insert(BufferedPacket &p,u16 next_expected)
|
|||||||
throw IncomingDataCorruption("duplicated packet isn't same as original one");
|
throw IncomingDataCorruption("duplicated packet isn't same as original one");
|
||||||
}
|
}
|
||||||
|
|
||||||
sanity_check(readU16(&(i->data[BASE_HEADER_SIZE+1])) == seqnum);
|
|
||||||
sanity_check(i->data.getSize() == p.data.getSize());
|
|
||||||
sanity_check(i->address == p.address);
|
|
||||||
|
|
||||||
/* nothing to do this seems to be a resent packet */
|
/* nothing to do this seems to be a resent packet */
|
||||||
/* for paranoia reason data should be compared */
|
/* for paranoia reason data should be compared */
|
||||||
--m_list_size;
|
--m_list_size;
|
||||||
@ -449,13 +461,21 @@ SharedBuffer<u8> IncomingSplitBuffer::insert(BufferedPacket &p, bool reliable)
|
|||||||
{
|
{
|
||||||
JMutexAutoLock listlock(m_map_mutex);
|
JMutexAutoLock listlock(m_map_mutex);
|
||||||
u32 headersize = BASE_HEADER_SIZE + 7;
|
u32 headersize = BASE_HEADER_SIZE + 7;
|
||||||
FATAL_ERROR_IF(p.data.getSize() < headersize, "Invalid data size");
|
if (p.data.getSize() < headersize) {
|
||||||
|
errorstream << "Invalid data size for split packet" << std::endl;
|
||||||
|
return SharedBuffer<u8>();
|
||||||
|
}
|
||||||
u8 type = readU8(&p.data[BASE_HEADER_SIZE+0]);
|
u8 type = readU8(&p.data[BASE_HEADER_SIZE+0]);
|
||||||
sanity_check(type == TYPE_SPLIT);
|
|
||||||
u16 seqnum = readU16(&p.data[BASE_HEADER_SIZE+1]);
|
u16 seqnum = readU16(&p.data[BASE_HEADER_SIZE+1]);
|
||||||
u16 chunk_count = readU16(&p.data[BASE_HEADER_SIZE+3]);
|
u16 chunk_count = readU16(&p.data[BASE_HEADER_SIZE+3]);
|
||||||
u16 chunk_num = readU16(&p.data[BASE_HEADER_SIZE+5]);
|
u16 chunk_num = readU16(&p.data[BASE_HEADER_SIZE+5]);
|
||||||
|
|
||||||
|
if (type != TYPE_SPLIT) {
|
||||||
|
errorstream << "IncomingSplitBuffer::insert(): type is not split"
|
||||||
|
<< std::endl;
|
||||||
|
return SharedBuffer<u8>();
|
||||||
|
}
|
||||||
|
|
||||||
// Add if doesn't exist
|
// Add if doesn't exist
|
||||||
if (m_buf.find(seqnum) == m_buf.end())
|
if (m_buf.find(seqnum) == m_buf.end())
|
||||||
{
|
{
|
||||||
@ -2327,8 +2347,9 @@ SharedBuffer<u8> ConnectionReceiveThread::processPacket(Channel *channel,
|
|||||||
u8 type = readU8(&(packetdata[0]));
|
u8 type = readU8(&(packetdata[0]));
|
||||||
|
|
||||||
if (MAX_UDP_PEERS <= 65535 && peer_id >= MAX_UDP_PEERS) {
|
if (MAX_UDP_PEERS <= 65535 && peer_id >= MAX_UDP_PEERS) {
|
||||||
errorstream << "Something is wrong with peer_id" << std::endl;
|
std::string errmsg = "Invalid peer_id=" + itos(peer_id);
|
||||||
FATAL_ERROR("");
|
errorstream << errmsg << std::endl;
|
||||||
|
throw InvalidIncomingDataException(errmsg.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (type == TYPE_CONTROL)
|
if (type == TYPE_CONTROL)
|
||||||
@ -2340,10 +2361,12 @@ SharedBuffer<u8> ConnectionReceiveThread::processPacket(Channel *channel,
|
|||||||
|
|
||||||
if (controltype == CONTROLTYPE_ACK)
|
if (controltype == CONTROLTYPE_ACK)
|
||||||
{
|
{
|
||||||
FATAL_ERROR_IF(channel == 0, "Invalid channel (0)");
|
assert(channel != NULL);
|
||||||
if (packetdata.getSize() < 4)
|
|
||||||
throw InvalidIncomingDataException
|
if (packetdata.getSize() < 4) {
|
||||||
("packetdata.getSize() < 4 (ACK header size)");
|
throw InvalidIncomingDataException(
|
||||||
|
"packetdata.getSize() < 4 (ACK header size)");
|
||||||
|
}
|
||||||
|
|
||||||
u16 seqnum = readU16(&packetdata[2]);
|
u16 seqnum = readU16(&packetdata[2]);
|
||||||
LOG(dout_con<<m_connection->getDesc()
|
LOG(dout_con<<m_connection->getDesc()
|
||||||
@ -2508,7 +2531,8 @@ SharedBuffer<u8> ConnectionReceiveThread::processPacket(Channel *channel,
|
|||||||
}
|
}
|
||||||
else if (type == TYPE_RELIABLE)
|
else if (type == TYPE_RELIABLE)
|
||||||
{
|
{
|
||||||
FATAL_ERROR_IF(channel == 0, "Invalid channel (0)");
|
assert(channel != NULL);
|
||||||
|
|
||||||
// Recursive reliable packets not allowed
|
// Recursive reliable packets not allowed
|
||||||
if (reliable)
|
if (reliable)
|
||||||
throw InvalidIncomingDataException("Found nested reliable packets");
|
throw InvalidIncomingDataException("Found nested reliable packets");
|
||||||
|
Loading…
Reference in New Issue
Block a user