mirror of
https://github.com/rehlds/rehlds.git
synced 2025-01-16 00:28:20 +03:00
Fix build
This commit is contained in:
parent
64c684af4a
commit
e83b324301
@ -276,15 +276,6 @@ typedef struct flow_s
|
|||||||
float avgkbytespersec;
|
float avgkbytespersec;
|
||||||
} flow_t;
|
} flow_t;
|
||||||
|
|
||||||
const int NET_DECOMPRESS_MAX_TIMES = 10;
|
|
||||||
|
|
||||||
typedef struct frag_decomp_failure_s
|
|
||||||
{
|
|
||||||
float failure_times[NET_DECOMPRESS_MAX_TIMES];
|
|
||||||
// Count of abnormal fragment decompressions in a time window
|
|
||||||
int num_failures;
|
|
||||||
} frag_decomp_failure_t;
|
|
||||||
|
|
||||||
const int FRAGMENT_C2S_MIN_SIZE = 16;
|
const int FRAGMENT_C2S_MIN_SIZE = 16;
|
||||||
const int FRAGMENT_S2C_MIN_SIZE = 256;
|
const int FRAGMENT_S2C_MIN_SIZE = 256;
|
||||||
const int FRAGMENT_S2C_MAX_SIZE = 1024;
|
const int FRAGMENT_S2C_MAX_SIZE = 1024;
|
||||||
@ -432,9 +423,6 @@ typedef struct netchan_s
|
|||||||
// Incoming and outgoing flow metrics
|
// Incoming and outgoing flow metrics
|
||||||
flow_t flow[MAX_FLOWS];
|
flow_t flow[MAX_FLOWS];
|
||||||
|
|
||||||
// Stats for decompression of incoming fragments
|
|
||||||
frag_decomp_failure_t frag_decompress[MAX_STREAMS];
|
|
||||||
|
|
||||||
} netchan_t;
|
} netchan_t;
|
||||||
|
|
||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
|
@ -174,10 +174,6 @@ void Netchan_Clear(netchan_t *chan)
|
|||||||
chan->frag_startpos[i] = 0;
|
chan->frag_startpos[i] = 0;
|
||||||
chan->frag_length[i] = 0;
|
chan->frag_length[i] = 0;
|
||||||
chan->incomingready[i] = FALSE;
|
chan->incomingready[i] = FALSE;
|
||||||
|
|
||||||
for (int j = 0; j < NET_DECOMPRESS_MAX_TIMES; j++)
|
|
||||||
chan->frag_decompress[i].failure_times[j] = 0;
|
|
||||||
chan->frag_decompress[i].num_failures = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (chan->tempbuffer)
|
if (chan->tempbuffer)
|
||||||
@ -191,6 +187,7 @@ void Netchan_Clear(netchan_t *chan)
|
|||||||
void Netchan_Setup(netsrc_t socketnumber, netchan_t *chan, netadr_t adr, int player_slot, void *connection_status, qboolean(*pfnNetchan_Blocksize)(void *))
|
void Netchan_Setup(netsrc_t socketnumber, netchan_t *chan, netadr_t adr, int player_slot, void *connection_status, qboolean(*pfnNetchan_Blocksize)(void *))
|
||||||
{
|
{
|
||||||
Netchan_Clear(chan);
|
Netchan_Clear(chan);
|
||||||
|
g_GameClients[player_slot]->NetchanClear();
|
||||||
|
|
||||||
Q_memset(chan, 0, sizeof(netchan_t));
|
Q_memset(chan, 0, sizeof(netchan_t));
|
||||||
|
|
||||||
@ -1460,7 +1457,6 @@ qboolean Netchan_ValidateDecompress(netchan_t *chan, int stream, unsigned int co
|
|||||||
{
|
{
|
||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
int i;
|
int i;
|
||||||
frag_decomp_failure_t *decomp;
|
|
||||||
|
|
||||||
if (sv_net_incoming_decompression_max_ratio.value <= 0)
|
if (sv_net_incoming_decompression_max_ratio.value <= 0)
|
||||||
return TRUE; // validation is disabled
|
return TRUE; // validation is disabled
|
||||||
@ -1477,24 +1473,24 @@ qboolean Netchan_ValidateDecompress(netchan_t *chan, int stream, unsigned int co
|
|||||||
|
|
||||||
Netchan_DecompressionCvarsBounds();
|
Netchan_DecompressionCvarsBounds();
|
||||||
|
|
||||||
decomp = &chan->frag_decompress[stream];
|
FragStats_t &stats = g_GameClients[chan->player_slot - 1]->GetFragStats(stream);
|
||||||
|
|
||||||
// check if the client should be rejected based on total failed decompress
|
// check if the client should be rejected based on total failed decompress
|
||||||
if (decomp->num_failures >= sv_net_incoming_decompression_max_failures.value)
|
if (stats.num_decompress_failures >= sv_net_incoming_decompression_max_failures.value)
|
||||||
{
|
{
|
||||||
for (i = 0; i < sv_net_incoming_decompression_max_failures.value - 1; i++)
|
for (i = 0; i < sv_net_incoming_decompression_max_failures.value - 1; i++)
|
||||||
decomp->failure_times[i] = decomp->failure_times[i + 1];
|
stats.decompress_failure_times[i] = stats.decompress_failure_times[i + 1];
|
||||||
|
|
||||||
decomp->num_failures = sv_net_incoming_decompression_max_failures.value - 1;
|
stats.num_decompress_failures = sv_net_incoming_decompression_max_failures.value - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
decomp->failure_times[decomp->num_failures++] = realtime;
|
stats.decompress_failure_times[stats.num_decompress_failures++] = realtime;
|
||||||
|
|
||||||
// check if the client should be rejected based on recent failed decompress
|
// check if the client should be rejected based on recent failed decompress
|
||||||
int recent_failures = 0;
|
int recent_failures = 0;
|
||||||
for (i = 0; i < decomp->num_failures; i++)
|
for (i = 0; i < stats.num_decompress_failures; i++)
|
||||||
{
|
{
|
||||||
if ((realtime - decomp->failure_times[i]) <= sv_net_incoming_decompression_min_failuretime.value)
|
if ((realtime - stats.decompress_failure_times[i]) <= sv_net_incoming_decompression_min_failuretime.value)
|
||||||
recent_failures++;
|
recent_failures++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -530,6 +530,15 @@ netchan_t* EXT_FUNC CNetChan::GetChan()
|
|||||||
return m_pNetChan;
|
return m_pNetChan;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CNetChan::Clear()
|
||||||
|
{
|
||||||
|
for (int i = 0; i < MAX_STREAMS; i++)
|
||||||
|
{
|
||||||
|
for (int j = 0; j < NET_DECOMPRESS_MAX_TIMES; j++)
|
||||||
|
m_FragStats[i].decompress_failure_times[j] = 0;
|
||||||
|
m_FragStats[i].num_decompress_failures = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int EXT_FUNC CRehldsServerStatic::GetMaxClients()
|
int EXT_FUNC CRehldsServerStatic::GetMaxClients()
|
||||||
|
@ -30,6 +30,16 @@
|
|||||||
#include "rehlds_interfaces.h"
|
#include "rehlds_interfaces.h"
|
||||||
#include "server.h"
|
#include "server.h"
|
||||||
|
|
||||||
|
const int NET_DECOMPRESS_MAX_TIMES = 10;
|
||||||
|
|
||||||
|
struct FragStats_t
|
||||||
|
{
|
||||||
|
float decompress_failure_times[NET_DECOMPRESS_MAX_TIMES];
|
||||||
|
|
||||||
|
// Count of abnormal fragment decompressions in a time window
|
||||||
|
int num_decompress_failures;
|
||||||
|
};
|
||||||
|
|
||||||
class CNetChan : public INetChan
|
class CNetChan : public INetChan
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
@ -38,6 +48,10 @@ private:
|
|||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
uint8_t m_messageBuffer[NET_MAX_PAYLOAD];
|
uint8_t m_messageBuffer[NET_MAX_PAYLOAD];
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Stats for decompression of incoming fragments
|
||||||
|
FragStats_t m_FragStats[MAX_STREAMS];
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CNetChan(netchan_t* chan);
|
CNetChan(netchan_t* chan);
|
||||||
|
|
||||||
@ -46,10 +60,13 @@ public:
|
|||||||
|
|
||||||
virtual netchan_t* GetChan();
|
virtual netchan_t* GetChan();
|
||||||
|
|
||||||
|
void Clear();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
uint8_t* GetExtendedMessageBuffer() { return m_messageBuffer; };
|
uint8_t* GetExtendedMessageBuffer() { return m_messageBuffer; };
|
||||||
#endif
|
#endif
|
||||||
|
FragStats_t &GetFragStats(int stream) { return m_FragStats[stream]; };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -247,6 +264,9 @@ public:
|
|||||||
uint8_t* GetExtendedMessageBuffer() { return m_NetChan.GetExtendedMessageBuffer(); };
|
uint8_t* GetExtendedMessageBuffer() { return m_NetChan.GetExtendedMessageBuffer(); };
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
void NetchanClear() { m_NetChan.Clear(); }
|
||||||
|
FragStats_t &GetFragStats(int stream) { return m_NetChan.GetFragStats(stream); };
|
||||||
|
|
||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
void SetupLocalGameTime() { m_localGameTimeBase = g_psv.time; }
|
void SetupLocalGameTime() { m_localGameTimeBase = g_psv.time; }
|
||||||
double GetLocalGameTime() const { return g_psv.time - m_localGameTimeBase; }
|
double GetLocalGameTime() const { return g_psv.time - m_localGameTimeBase; }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user