mirror of
https://github.com/minetest/minetest.git
synced 2024-11-27 10:03:45 +01:00
Sanity-check reliable packet size at earlier point
This commit is contained in:
parent
5df60d85f7
commit
97066bf795
@ -103,12 +103,10 @@ void makeSplitPacket(const SharedBuffer<u8> &data, u32 chunksize_max, u16 seqnum
|
|||||||
std::list<SharedBuffer<u8>> *chunks)
|
std::list<SharedBuffer<u8>> *chunks)
|
||||||
{
|
{
|
||||||
// Chunk packets, containing the TYPE_SPLIT header
|
// Chunk packets, containing the TYPE_SPLIT header
|
||||||
u32 chunk_header_size = 7;
|
const u32 chunk_header_size = 7;
|
||||||
u32 maximum_data_size = chunksize_max - chunk_header_size;
|
const u32 maximum_data_size = chunksize_max - chunk_header_size;
|
||||||
u32 start = 0;
|
u32 start = 0, end = 0;
|
||||||
u32 end = 0;
|
u16 chunk_num = 0;
|
||||||
u32 chunk_num = 0;
|
|
||||||
u16 chunk_count = 0;
|
|
||||||
do {
|
do {
|
||||||
end = start + maximum_data_size - 1;
|
end = start + maximum_data_size - 1;
|
||||||
if (end > data.getSize() - 1)
|
if (end > data.getSize() - 1)
|
||||||
@ -126,16 +124,16 @@ void makeSplitPacket(const SharedBuffer<u8> &data, u32 chunksize_max, u16 seqnum
|
|||||||
memcpy(&chunk[chunk_header_size], &data[start], payload_size);
|
memcpy(&chunk[chunk_header_size], &data[start], payload_size);
|
||||||
|
|
||||||
chunks->push_back(chunk);
|
chunks->push_back(chunk);
|
||||||
chunk_count++;
|
|
||||||
|
|
||||||
start = end + 1;
|
start = end + 1;
|
||||||
|
sanity_check(chunk_num < 0xFFFF); // overflow
|
||||||
chunk_num++;
|
chunk_num++;
|
||||||
}
|
}
|
||||||
while (end != data.getSize() - 1);
|
while (end != data.getSize() - 1);
|
||||||
|
|
||||||
for (SharedBuffer<u8> &chunk : *chunks) {
|
for (auto &chunk : *chunks) {
|
||||||
// Write chunk_count
|
// Write chunk_count
|
||||||
writeU16(&(chunk[3]), chunk_count);
|
writeU16(&chunk[3], chunk_num);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1061,22 +1059,22 @@ bool UDPPeer::processReliableSendCommand(
|
|||||||
const auto &c = *c_ptr;
|
const auto &c = *c_ptr;
|
||||||
Channel &chan = channels[c.channelnum];
|
Channel &chan = channels[c.channelnum];
|
||||||
|
|
||||||
u32 chunksize_max = max_packet_size
|
const u32 chunksize_max = max_packet_size
|
||||||
- BASE_HEADER_SIZE
|
- BASE_HEADER_SIZE
|
||||||
- RELIABLE_HEADER_SIZE;
|
- RELIABLE_HEADER_SIZE;
|
||||||
|
|
||||||
sanity_check(c.data.getSize() < MAX_RELIABLE_WINDOW_SIZE*512);
|
|
||||||
|
|
||||||
std::list<SharedBuffer<u8>> originals;
|
std::list<SharedBuffer<u8>> originals;
|
||||||
u16 split_sequence_number = chan.readNextSplitSeqNum();
|
|
||||||
|
|
||||||
if (c.raw) {
|
if (c.raw) {
|
||||||
originals.emplace_back(c.data);
|
originals.emplace_back(c.data);
|
||||||
} else {
|
} else {
|
||||||
makeAutoSplitPacket(c.data, chunksize_max,split_sequence_number, &originals);
|
u16 split_seqnum = chan.readNextSplitSeqNum();
|
||||||
chan.setNextSplitSeqNum(split_sequence_number);
|
makeAutoSplitPacket(c.data, chunksize_max, split_seqnum, &originals);
|
||||||
|
chan.setNextSplitSeqNum(split_seqnum);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sanity_check(originals.size() < MAX_RELIABLE_WINDOW_SIZE);
|
||||||
|
|
||||||
bool have_sequence_number = false;
|
bool have_sequence_number = false;
|
||||||
bool have_initial_sequence_number = false;
|
bool have_initial_sequence_number = false;
|
||||||
std::queue<BufferedPacketPtr> toadd;
|
std::queue<BufferedPacketPtr> toadd;
|
||||||
@ -1271,7 +1269,7 @@ Connection::Connection(u32 protocol_id, u32 max_packet_size, float timeout,
|
|||||||
m_udpSocket(ipv6),
|
m_udpSocket(ipv6),
|
||||||
m_protocol_id(protocol_id),
|
m_protocol_id(protocol_id),
|
||||||
m_sendThread(new ConnectionSendThread(max_packet_size, timeout)),
|
m_sendThread(new ConnectionSendThread(max_packet_size, timeout)),
|
||||||
m_receiveThread(new ConnectionReceiveThread(max_packet_size)),
|
m_receiveThread(new ConnectionReceiveThread()),
|
||||||
m_bc_peerhandler(peerhandler)
|
m_bc_peerhandler(peerhandler)
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -1505,6 +1503,15 @@ void Connection::Send(session_t peer_id, u8 channelnum,
|
|||||||
{
|
{
|
||||||
assert(channelnum < CHANNEL_COUNT); // Pre-condition
|
assert(channelnum < CHANNEL_COUNT); // Pre-condition
|
||||||
|
|
||||||
|
// approximate check similar to UDPPeer::processReliableSendCommand()
|
||||||
|
// to get nicer errors / backtraces if this happens.
|
||||||
|
if (reliable && pkt->getSize() > MAX_RELIABLE_WINDOW_SIZE*512) {
|
||||||
|
std::ostringstream oss;
|
||||||
|
oss << "Packet too big for window, peer_id=" << peer_id
|
||||||
|
<< " command=" << pkt->getCommand() << " size=" << pkt->getSize();
|
||||||
|
FATAL_ERROR(oss.str().c_str());
|
||||||
|
}
|
||||||
|
|
||||||
putCommand(ConnectionCommand::send(peer_id, channelnum, pkt, reliable));
|
putCommand(ConnectionCommand::send(peer_id, channelnum, pkt, reliable));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -796,7 +796,7 @@ void ConnectionSendThread::sendAsPacket(session_t peer_id, u8 channelnum,
|
|||||||
m_outgoing_queue.push(packet);
|
m_outgoing_queue.push(packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
ConnectionReceiveThread::ConnectionReceiveThread(unsigned int max_packet_size) :
|
ConnectionReceiveThread::ConnectionReceiveThread() :
|
||||||
Thread("ConnectionReceive")
|
Thread("ConnectionReceive")
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -113,7 +113,7 @@ private:
|
|||||||
class ConnectionReceiveThread : public Thread
|
class ConnectionReceiveThread : public Thread
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ConnectionReceiveThread(unsigned int max_packet_size);
|
ConnectionReceiveThread();
|
||||||
|
|
||||||
void *run();
|
void *run();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user