2001-05-22 06:00:38 +00:00
|
|
|
/*
|
|
|
|
r_graph.c
|
|
|
|
|
|
|
|
rednerer diagnostic graphs
|
|
|
|
|
|
|
|
Copyright (C) 1996-1997 Id Software, Inc.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU General Public License
|
|
|
|
as published by the Free Software Foundation; either version 2
|
|
|
|
of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
|
|
|
|
See the GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to:
|
|
|
|
|
|
|
|
Free Software Foundation, Inc.
|
|
|
|
59 Temple Place - Suite 330
|
|
|
|
Boston, MA 02111-1307, USA
|
|
|
|
|
|
|
|
*/
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include "config.h"
|
|
|
|
#endif
|
2021-07-11 01:59:27 +00:00
|
|
|
#include <string.h>
|
2001-05-22 06:00:38 +00:00
|
|
|
|
2021-07-11 01:59:27 +00:00
|
|
|
#include "QF/cvar.h"
|
2001-05-22 06:00:38 +00:00
|
|
|
#include "QF/draw.h"
|
|
|
|
#include "QF/render.h"
|
2012-02-14 08:28:09 +00:00
|
|
|
#include "QF/plugin.h"
|
2001-05-22 06:00:38 +00:00
|
|
|
#include "QF/sys.h"
|
|
|
|
|
2012-02-14 08:28:09 +00:00
|
|
|
#include "r_internal.h"
|
2001-05-22 06:00:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
#define MAX_TIMINGS 100
|
|
|
|
int graphval;
|
|
|
|
|
2001-08-26 16:54:33 +00:00
|
|
|
|
2001-05-22 06:00:38 +00:00
|
|
|
/*
|
|
|
|
R_TimeGraph
|
|
|
|
|
|
|
|
Performance monitoring tool
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
R_TimeGraph (void)
|
|
|
|
{
|
|
|
|
static int timex;
|
|
|
|
int a;
|
|
|
|
int l;
|
2011-06-19 01:48:02 +00:00
|
|
|
//XXX float r_time2;
|
2021-07-11 01:59:27 +00:00
|
|
|
static int r_timings[MAX_TIMINGS];
|
|
|
|
int timings[MAX_TIMINGS];
|
|
|
|
int x, o;
|
2001-05-22 06:00:38 +00:00
|
|
|
|
2011-06-19 01:48:02 +00:00
|
|
|
//XXX r_time2 = Sys_DoubleTime ();
|
2001-05-22 06:00:38 +00:00
|
|
|
|
|
|
|
a = graphval;
|
|
|
|
|
|
|
|
r_timings[timex] = a;
|
|
|
|
|
|
|
|
l = MAX_TIMINGS;
|
|
|
|
if (l > r_refdef.vrect.width)
|
|
|
|
l = r_refdef.vrect.width;
|
|
|
|
x = r_refdef.vrect.width - l;
|
2021-07-11 01:59:27 +00:00
|
|
|
o = 0;
|
2001-05-22 06:00:38 +00:00
|
|
|
a = timex - l;
|
|
|
|
if (a < 0) {
|
2021-07-11 01:59:27 +00:00
|
|
|
memcpy (timings + o, r_timings + a + MAX_TIMINGS,
|
|
|
|
-a * sizeof (timings[0]));
|
|
|
|
o -= a;
|
2001-05-22 06:00:38 +00:00
|
|
|
l += a;
|
|
|
|
a = 0;
|
|
|
|
}
|
2021-07-11 01:59:27 +00:00
|
|
|
memcpy (timings + o, r_timings + a, l * sizeof (timings[0]));
|
|
|
|
vr_funcs->R_LineGraph (x, r_refdef.vrect.height - 2, r_timings,
|
|
|
|
MAX_TIMINGS, vr_data.graphheight->int_val);
|
2001-05-22 06:00:38 +00:00
|
|
|
|
|
|
|
timex = (timex + 1) % MAX_TIMINGS;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
R_ZGraph (void)
|
|
|
|
{
|
2011-06-19 01:48:02 +00:00
|
|
|
int x, w;
|
2001-05-22 06:00:38 +00:00
|
|
|
static int height[256];
|
|
|
|
|
|
|
|
if (r_refdef.vrect.width <= 256)
|
|
|
|
w = r_refdef.vrect.width;
|
|
|
|
else
|
|
|
|
w = 256;
|
|
|
|
|
|
|
|
height[r_framecount & 255] = ((int) r_origin[2]) & 31;
|
|
|
|
|
|
|
|
x = 0;
|
2021-07-11 01:59:27 +00:00
|
|
|
vr_funcs->R_LineGraph (x, r_refdef.vrect.height - 2, height,
|
|
|
|
w, vr_data.graphheight->int_val);
|
2001-05-22 06:00:38 +00:00
|
|
|
}
|