fix potentially fatal sv_minping memory leak.

git-svn-id: https://svn.code.sf.net/p/fteqw/code/trunk@4702 fc73d0e0-1445-4013-8a0c-d673dee63da5
This commit is contained in:
Spoike 2014-06-30 20:32:34 +00:00
parent a842a623e4
commit 75e22d98fe
1 changed files with 12 additions and 3 deletions

View File

@ -266,6 +266,12 @@ void SV_Shutdown (void)
BZ_Free(sv_staticentities);
sv_staticentities = NULL;
}
while (svs.free_lagged_packet)
{
laggedpacket_t *lp = svs.free_lagged_packet;
svs.free_lagged_packet = lp->next;
Z_Free(lp);
}
T_FreeStrings();
@ -4474,7 +4480,7 @@ qboolean SV_ReadPackets (float *delay)
}
#ifdef SERVER_DEMO_PLAYBACK
while (giveup-- > 0 && SV_GetPacket())
while (giveup-- > 0 && SV_GetPacket()>=0)
#else
while (giveup-- > 0 && (cookie=NET_GetPacket (NS_SERVER, cookie)) >= 0)
#endif
@ -4573,9 +4579,12 @@ dominping:
if (!cl->laggedpacket)
cl->laggedpacket_last = cl->laggedpacket = svs.free_lagged_packet;
else
cl->laggedpacket_last = cl->laggedpacket_last->next = svs.free_lagged_packet;
cl->laggedpacket_last->next = NULL;
{
cl->laggedpacket_last->next = svs.free_lagged_packet;
cl->laggedpacket_last = cl->laggedpacket_last->next;
}
svs.free_lagged_packet = svs.free_lagged_packet->next;
cl->laggedpacket_last->next = NULL;
cl->laggedpacket_last->time = realtime + cl->delay;
memcpy(cl->laggedpacket_last->data, net_message.data, net_message.cursize);