2
0
mirror of https://github.com/rehlds/rehlds.git synced 2025-01-03 18:45:46 +03:00

SV_WriteEntitiesToClient: don't use intermediate 'fullpack' storage for entities being transmitted

SV_SetupMove: Don't look examine frame->entities after last player
This commit is contained in:
dreamstalker 2015-05-21 03:15:03 +04:00
parent ed6e5b4a94
commit f2fe5a6c74
2 changed files with 42 additions and 37 deletions

View File

@ -4385,7 +4385,7 @@ void SV_EmitPings(client_t *client, sizebuf_t *msg)
/* <a947b> ../engine/sv_main.c:5878 */ /* <a947b> ../engine/sv_main.c:5878 */
void SV_WriteEntitiesToClient(client_t *client, sizebuf_t *msg) void SV_WriteEntitiesToClient(client_t *client, sizebuf_t *msg)
{ {
full_packet_entities_t fullpack;
client_frame_t *frame = &client->frames[SV_UPDATE_MASK & client->netchan.outgoing_sequence]; client_frame_t *frame = &client->frames[SV_UPDATE_MASK & client->netchan.outgoing_sequence];
unsigned char *pvs = NULL; unsigned char *pvs = NULL;
@ -4393,72 +4393,68 @@ void SV_WriteEntitiesToClient(client_t *client, sizebuf_t *msg)
gEntityInterface.pfnSetupVisibility((edict_t*)client->pViewEntity, client->edict, &pvs, &pas); gEntityInterface.pfnSetupVisibility((edict_t*)client->pViewEntity, client->edict, &pvs, &pas);
unsigned char *pSet = pvs; unsigned char *pSet = pvs;
#ifndef REHLDS_FIXES
// don't reallocate entity states
SV_ClearPacketEntities(frame);
#endif // REHLDS_FIXES
packet_entities_t *pack = &frame->entities; packet_entities_t *pack = &frame->entities;
// for REHLDS_FIXES: Allocate the MAX_PACKET_ENTITIES ents in the frame's storage
// This allows us to avoid intermediate 'fullpack' storage
#ifdef REHLDS_FIXES
SV_AllocPacketEntities(frame, MAX_PACKET_ENTITIES);
packet_entities_t *curPack = &frame->entities;
curPack->num_entities = 0;
#else
SV_ClearPacketEntities(frame);
full_packet_entities_t fullpack;
fullpack.num_entities = 0; fullpack.num_entities = 0;
full_packet_entities_t* curPack = &fullpack;
#endif // REHLDS_FIXES
qboolean sendping = SV_ShouldUpdatePing(client); qboolean sendping = SV_ShouldUpdatePing(client);
int flags = client->lw != 0; int flags = client->lw != 0;
#ifdef REHLDS_FIXES
int e; int e;
for (e = 1; e <= g_psvs.maxclients; e++) for (e = 1; e <= g_psvs.maxclients; e++)
{ {
client_t *cl = &g_psvs.clients[e - 1]; client_t *cl = &g_psvs.clients[e - 1];
if( ( !cl->active && !cl->spawned ) || cl->proxy ) if( ( !cl->active && !cl->spawned ) || cl->proxy )
continue; continue;
qboolean add = gEntityInterface.pfnAddToFullPack(&fullpack.entities[fullpack.num_entities], e, &g_psv.edicts[e], host_client->edict, flags, TRUE, pSet); qboolean add = gEntityInterface.pfnAddToFullPack(&curPack->entities[curPack->num_entities], e, &g_psv.edicts[e], host_client->edict, flags, TRUE, pSet);
if (add) if (add)
++fullpack.num_entities; ++curPack->num_entities;
} }
for (; e < g_psv.num_edicts; e++) for (; e < g_psv.num_edicts; e++)
{ {
if (fullpack.num_entities >= MAX_PACKET_ENTITIES) if (curPack->num_entities >= MAX_PACKET_ENTITIES)
{ {
Con_DPrintf("Too many entities in visible packet list.\n"); Con_DPrintf("Too many entities in visible packet list.\n");
break; break;
} }
edict_t* ent = &g_psv.edicts[e];
#ifdef REHLDS_FIXES
//Part of gamedll's code is moved here to decrease amount of calls to AddToFullPack()
//We don't even try to transmit entities without model as well as invisible entities
if (ent->v.modelindex && !(ent->v.effects & EF_NODRAW)) {
qboolean add = gEntityInterface.pfnAddToFullPack(&curPack->entities[curPack->num_entities], e, &g_psv.edicts[e], host_client->edict, flags, FALSE, pSet);
if (add)
++curPack->num_entities;
}
#else
qboolean add = gEntityInterface.pfnAddToFullPack(&fullpack.entities[fullpack.num_entities], e, &g_psv.edicts[e], host_client->edict, flags, FALSE, pSet); qboolean add = gEntityInterface.pfnAddToFullPack(&fullpack.entities[fullpack.num_entities], e, &g_psv.edicts[e], host_client->edict, flags, FALSE, pSet);
if (add) if (add)
++fullpack.num_entities; ++fullpack.num_entities;
} #endif
#else // REHLDS_FIXES
for (int e = 1; e < g_psv.num_edicts; e++)
{
edict_t *ent = &g_psv.edicts[e];
int player = 0;
if (e >= 1 && e <= g_psvs.maxclients)
{
client_t *cl = &g_psvs.clients[e - 1];
if ((!cl->active && !cl->spawned) || cl->proxy)
continue;
player = 1;
} }
if (fullpack.num_entities >= MAX_PACKET_ENTITIES) //for REHLDS_FIXES: Entities are already in the frame's storage, no need to copy them
{ #ifndef REHLDS_FIXES
Con_DPrintf("Too many entities in visible packet list.\n");
break;
}
qboolean add = gEntityInterface.pfnAddToFullPack(&fullpack.entities[fullpack.num_entities], e, ent, host_client->edict, flags, player, pSet);
if (add)
++fullpack.num_entities;
}
#endif // REHLDS_FIXES
SV_AllocPacketEntities(frame, fullpack.num_entities); SV_AllocPacketEntities(frame, fullpack.num_entities);
if (pack->num_entities) if (pack->num_entities)
Q_memcpy(pack->entities, fullpack.entities, sizeof(entity_state_t) * pack->num_entities); Q_memcpy(pack->entities, fullpack.entities, sizeof(entity_state_t) * pack->num_entities);
#endif
SV_EmitPacketEntities(client, pack, msg); SV_EmitPacketEntities(client, pack, msg);
SV_EmitEvents(client, pack, msg); SV_EmitEvents(client, pack, msg);

View File

@ -1226,8 +1226,17 @@ void SV_SetupMove(client_t *_host_client)
for (int j = 0; j < nextFrame->entities.num_entities; j++) for (int j = 0; j < nextFrame->entities.num_entities; j++)
{ {
state = &nextFrame->entities.entities[j]; state = &nextFrame->entities.entities[j];
#ifdef REHLDS_OPT_PEDANTIC
if (state->number <= 0)
continue;
if (state->number > g_psvs.maxclients)
break; // players are always in the beginning of the list, no need to look more
#else
if (state->number <= 0 || state->number > g_psvs.maxclients) if (state->number <= 0 || state->number > g_psvs.maxclients)
continue; continue;
#endif
pos = &truepositions[state->number - 1]; pos = &truepositions[state->number - 1];
if (pos->deadflag) if (pos->deadflag)