From c12d3db20e06b933ae9cee85460c15b6c54c1ca0 Mon Sep 17 00:00:00 2001 From: divverent Date: Mon, 6 Oct 2008 16:09:34 +0000 Subject: [PATCH] add entity size profiling (currently spams the console with sizes of entity updates if developer_networkentities is >= 2, may later change it to collect statistics based on classname) git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@8525 d7cf8633-e32d-0410-b094-e92efae38249 --- protocol.c | 37 ++++++++++++++++++++++++++++++++++--- 1 file changed, 34 insertions(+), 3 deletions(-) diff --git a/protocol.c b/protocol.c index 3ffdd43e..c705eeec 100644 --- a/protocol.c +++ b/protocol.c @@ -1,6 +1,23 @@ #include "quakedef.h" +#define ENTITYSIZEPROFILING_START(msg, num) \ + int entityprofiling_startsize = msg->cursize + +#define ENTITYSIZEPROFILING_END(msg, num) \ + if(developer_networkentities.integer >= 2) \ + { \ + prvm_edict_t *ed = prog->edicts + num; \ + const char *cname = "(no classname)"; \ + if(prog->fieldoffsets.classname >= 0) \ + { \ + string_t handle = PRVM_EDICTFIELDVALUE(ed, prog->fieldoffsets.classname)->string; \ + if (handle) \ + cname = PRVM_GetString(handle); \ + } \ + Con_Printf("sent entity update of size %d for a %s\n", (msg->cursize - entityprofiling_startsize), cname); \ + } + // this is 88 bytes (must match entity_state_t in protocol.h) entity_state_t defaultstate = { @@ -344,9 +361,13 @@ void EntityFrameCSQC_WriteFrame (sizebuf_t *msg, int maxsize, int numstates, con MSG_WriteByte(msg, svc_csqcentities); } // write the remove message - MSG_WriteShort(msg, (unsigned short)number | 0x8000); - client->csqcentityscope[number] = 0; - client->csqcentitysendflags[number] = 0xFFFFFF; // resend completely if it becomes active again + { + ENTITYSIZEPROFILING_START(msg, number); + MSG_WriteShort(msg, (unsigned short)number | 0x8000); + client->csqcentityscope[number] = 0; + client->csqcentitysendflags[number] = 0xFFFFFF; // resend completely if it becomes active again + ENTITYSIZEPROFILING_END(msg, number); + } if (msg->cursize + 17 >= maxsize) break; } @@ -359,6 +380,7 @@ void EntityFrameCSQC_WriteFrame (sizebuf_t *msg, int maxsize, int numstates, con val = PRVM_EDICTFIELDVALUE(ed, prog->fieldoffsets.SendEntity); if (val->function) { + ENTITYSIZEPROFILING_START(msg, number); if(!sectionstarted) MSG_WriteByte(msg, svc_csqcentities); MSG_WriteShort(msg, number); @@ -377,6 +399,7 @@ void EntityFrameCSQC_WriteFrame (sizebuf_t *msg, int maxsize, int numstates, con sectionstarted = 1; if (msg->cursize + 17 >= maxsize) break; + ENTITYSIZEPROFILING_END(msg, number); continue; } } @@ -497,6 +520,7 @@ void EntityFrameQuake_WriteFrame(sizebuf_t *msg, int maxsize, int numstates, con SZ_Clear(&buf); // send an update + ENTITYSIZEPROFILING_START(msg, s->number); bits = 0; if (s->number >= 256) bits |= U_LONGENTITY; @@ -632,6 +656,7 @@ void EntityFrameQuake_WriteFrame(sizebuf_t *msg, int maxsize, int numstates, con } // write the message to the packet SZ_Write(msg, buf.data, buf.cursize); + ENTITYSIZEPROFILING_END(msg, s->number); } } @@ -817,6 +842,7 @@ void EntityState_WriteFields(const entity_state_t *ent, sizebuf_t *msg, unsigned void EntityState_WriteUpdate(const entity_state_t *ent, sizebuf_t *msg, const entity_state_t *delta) { unsigned int bits; + ENTITYSIZEPROFILING_START(msg, ent->number); if (ent->active) { // entity is active, check for changes from the delta @@ -837,6 +863,7 @@ void EntityState_WriteUpdate(const entity_state_t *ent, sizebuf_t *msg, const en MSG_WriteShort(msg, ent->number | 0x8000); } } + ENTITYSIZEPROFILING_END(msg, ent->number); } int EntityState_ReadExtendBits(void) @@ -1800,6 +1827,8 @@ int EntityState5_Priority(entityframe5_database_t *d, int stateindex) void EntityState5_WriteUpdate(int number, const entity_state_t *s, int changedbits, sizebuf_t *msg) { unsigned int bits = 0; + int startsize; + ENTITYSIZEPROFILING_START(msg, s->number); prvm_eval_t *val; val = PRVM_EDICTFIELDVALUE((&prog->edicts[s->number]), prog->fieldoffsets.SendEntity); @@ -1938,6 +1967,8 @@ void EntityState5_WriteUpdate(int number, const entity_state_t *s, int changedbi MSG_WriteByte(msg, s->colormod[2]); } } + + ENTITYSIZEPROFILING_END(msg, s->number); } void EntityState5_ReadUpdate(entity_state_t *s, int number) -- 2.39.5