SRB2/src/m_perfstats.h

65 lines
1.7 KiB
C
Raw Normal View History

2020-10-10 18:08:24 +00:00
// SONIC ROBO BLAST 2
//-----------------------------------------------------------------------------
2023-03-31 12:53:31 +00:00
// Copyright (C) 2020-2023 by Sonic Team Junior.
2020-10-10 18:08:24 +00:00
//
// This program is free software distributed under the
// terms of the GNU General Public License, version 2.
// See the 'LICENSE' file for more details.
//-----------------------------------------------------------------------------
/// \file m_perfstats.h
/// \brief Performance measurement tools.
#ifndef __M_PERFSTATS_H__
#define __M_PERFSTATS_H__
#include "doomdef.h"
#include "lua_script.h"
#include "p_local.h"
2021-10-25 17:49:15 +00:00
typedef struct
{
union {
precise_t p;
INT32 i;
} value;
void *history;
} ps_metric_t;
2020-10-10 18:08:24 +00:00
typedef struct
{
2021-10-25 17:49:15 +00:00
ps_metric_t time_taken;
2020-10-10 18:08:24 +00:00
char short_src[LUA_IDSIZE];
} ps_hookinfo_t;
2021-10-25 17:49:15 +00:00
#define PS_START_TIMING(metric) metric.value.p = I_GetPreciseTime()
#define PS_STOP_TIMING(metric) metric.value.p = I_GetPreciseTime() - metric.value.p
extern ps_metric_t ps_tictime;
extern ps_metric_t ps_playerthink_time;
extern ps_metric_t ps_thinkertime;
extern ps_metric_t ps_thlist_times[];
extern ps_metric_t ps_checkposition_calls;
extern ps_metric_t ps_lua_prethinkframe_time;
2021-10-25 17:49:15 +00:00
extern ps_metric_t ps_lua_thinkframe_time;
extern ps_metric_t ps_lua_postthinkframe_time;
2021-10-25 17:49:15 +00:00
extern ps_metric_t ps_lua_mobjhooks;
extern ps_metric_t ps_otherlogictime;
void PS_SetPreThinkFrameHookInfo(int index, precise_t time_taken, char* short_src);
void PS_SetThinkFrameHookInfo(int index, precise_t time_taken, char* short_src);
void PS_SetPostThinkFrameHookInfo(int index, precise_t time_taken, char* short_src);
2020-10-10 18:08:24 +00:00
2021-10-25 17:49:15 +00:00
void PS_UpdateTickStats(void);
2020-10-10 18:08:24 +00:00
void M_DrawPerfStats(void);
2021-10-25 17:49:15 +00:00
void PS_PerfStats_OnChange(void);
void PS_SampleSize_OnChange(void);
2020-10-10 19:23:33 +00:00
#endif