mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 11:10:39 +00:00
Two tweaks to make the precaching more efficient/less redundant in the game.
First, if we're in Polymer, don't precache tinted tiles that have a highpal for that certain pal. Second, don't precache tiles for palnum 251 (the last non-reserved one, which is used as a crosshair pal). Assuming that there are no other tints, this cuts the initial precache time and cache size on disk in half. git-svn-id: https://svn.eduke32.com/eduke32@2045 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
c6f58c8dde
commit
bb72f803c4
6 changed files with 35 additions and 12 deletions
|
@ -310,6 +310,7 @@ void polymer_deletelight(int16_t lighti);
|
||||||
void polymer_invalidatelights(void);
|
void polymer_invalidatelights(void);
|
||||||
void polymer_texinvalidate(void);
|
void polymer_texinvalidate(void);
|
||||||
void polymer_definehighpalookup(char basepalnum, char palnum, char *fn);
|
void polymer_definehighpalookup(char basepalnum, char palnum, char *fn);
|
||||||
|
int32_t polymer_havehighpalookup(int32_t basepalnum, int32_t palnum);
|
||||||
|
|
||||||
# ifdef POLYMER_C
|
# ifdef POLYMER_C
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@ int32_t curextra=MAXTILES;
|
||||||
// #define MODEL_POOL_SIZE 20971520
|
// #define MODEL_POOL_SIZE 20971520
|
||||||
#define model_data_pool (nedpool *) 0 // take it out of the system pool
|
#define model_data_pool (nedpool *) 0 // take it out of the system pool
|
||||||
|
|
||||||
#define MIN_CACHETIME_PRINT 5
|
#define MIN_CACHETIME_PRINT 10
|
||||||
|
|
||||||
static void QuitOnFatalError(const char *msg)
|
static void QuitOnFatalError(const char *msg)
|
||||||
{
|
{
|
||||||
|
|
|
@ -634,7 +634,7 @@ int32_t culledface;
|
||||||
// EXTERNAL FUNCTIONS
|
// EXTERNAL FUNCTIONS
|
||||||
int32_t polymer_init(void)
|
int32_t polymer_init(void)
|
||||||
{
|
{
|
||||||
int32_t i, j;
|
int32_t i, j, t = getticks();
|
||||||
|
|
||||||
if (pr_verbosity >= 1) OSD_Printf("Initializing Polymer subsystem...\n");
|
if (pr_verbosity >= 1) OSD_Printf("Initializing Polymer subsystem...\n");
|
||||||
|
|
||||||
|
@ -730,7 +730,7 @@ int32_t polymer_init(void)
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pr_verbosity >= 1) OSD_Printf("PR : Initialization complete.\n");
|
if (pr_verbosity >= 1) OSD_Printf("PR : Initialization complete in %d ms.\n", getticks()-t);
|
||||||
|
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
@ -761,7 +761,7 @@ void polymer_uninit(void)
|
||||||
// }
|
// }
|
||||||
if (prhighpalookups[i][j].map) {
|
if (prhighpalookups[i][j].map) {
|
||||||
bglDeleteTextures(1, &prhighpalookups[i][j].map);
|
bglDeleteTextures(1, &prhighpalookups[i][j].map);
|
||||||
// prhighpalookups[i][j].map = 0;
|
prhighpalookups[i][j].map = 0;
|
||||||
}
|
}
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
|
@ -1504,6 +1504,15 @@ void polymer_definehighpalookup(char basepalnum, char palnum, cha
|
||||||
Bmemcpy(prhighpalookups[basepalnum][palnum].data, data, PR_HIGHPALOOKUP_DATA_SIZE);
|
Bmemcpy(prhighpalookups[basepalnum][palnum].data, data, PR_HIGHPALOOKUP_DATA_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t polymer_havehighpalookup(int32_t basepalnum, int32_t palnum)
|
||||||
|
{
|
||||||
|
if ((uint32_t)basepalnum >= MAXBASEPALS || (uint32_t)palnum >= MAXPALOOKUPS)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
return (prhighpalookups[basepalnum][palnum].data != NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// CORE
|
// CORE
|
||||||
static void polymer_displayrooms(int16_t dacursectnum)
|
static void polymer_displayrooms(int16_t dacursectnum)
|
||||||
{
|
{
|
||||||
|
|
|
@ -212,7 +212,7 @@ int32_t r_parallaxskypanning = 0;
|
||||||
|
|
||||||
extern int16_t editstatus;
|
extern int16_t editstatus;
|
||||||
|
|
||||||
#define MIN_CACHETIME_PRINT 5
|
#define MIN_CACHETIME_PRINT 10
|
||||||
|
|
||||||
|
|
||||||
static inline int32_t imod(int32_t a, int32_t b)
|
static inline int32_t imod(int32_t a, int32_t b)
|
||||||
|
@ -314,8 +314,8 @@ pthtyp *gltexcachead[GLTEXCACHEADSIZ];
|
||||||
|
|
||||||
int32_t drawingskybox = 0;
|
int32_t drawingskybox = 0;
|
||||||
|
|
||||||
int32_t gloadtile_art(int32_t,int32_t,int32_t,pthtyp *,int32_t);
|
static int32_t gloadtile_art(int32_t,int32_t,int32_t,pthtyp *,int32_t);
|
||||||
int32_t gloadtile_hi(int32_t,int32_t,int32_t,hicreplctyp *,int32_t,pthtyp *,int32_t,char);
|
static int32_t gloadtile_hi(int32_t,int32_t,int32_t,hicreplctyp *,int32_t,pthtyp *,int32_t,char);
|
||||||
static int32_t hicprecaching = 0;
|
static int32_t hicprecaching = 0;
|
||||||
pthtyp *gltexcache(int32_t dapicnum, int32_t dapalnum, int32_t dameth)
|
pthtyp *gltexcache(int32_t dapicnum, int32_t dapalnum, int32_t dameth)
|
||||||
{
|
{
|
||||||
|
@ -806,6 +806,8 @@ void polymost_glinit()
|
||||||
glusetexcache = 0;
|
glusetexcache = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
initprintf("Opened '%s' as cache file\n", TEXCACHEFILE);
|
||||||
|
|
||||||
if (glusememcache && !dont_alloc_memcache)
|
if (glusememcache && !dont_alloc_memcache)
|
||||||
{
|
{
|
||||||
|
@ -930,6 +932,8 @@ void invalidatecache(void)
|
||||||
glusetexcache = 0;
|
glusetexcache = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
initprintf("Deleted and reopened '%s' as cache file\n", TEXCACHEFILE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void resizeglcheck()
|
void resizeglcheck()
|
||||||
|
@ -1158,7 +1162,7 @@ void uploadtexture(int32_t doalloc, int32_t xsiz, int32_t ysiz, int32_t intexfmt
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t gloadtile_art(int32_t dapic, int32_t dapal, int32_t dameth, pthtyp *pth, int32_t doalloc)
|
static int32_t gloadtile_art(int32_t dapic, int32_t dapal, int32_t dameth, pthtyp *pth, int32_t doalloc)
|
||||||
{
|
{
|
||||||
coltype *pic, *wpptr;
|
coltype *pic, *wpptr;
|
||||||
int32_t x, y, x2, y2, xsiz, ysiz, dacol, tsizx, tsizy;
|
int32_t x, y, x2, y2, xsiz, ysiz, dacol, tsizx, tsizy;
|
||||||
|
@ -1685,8 +1689,7 @@ failure:
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
// --------------------------------------------------- JONOF'S COMPRESSED TEXTURE CACHE STUFF
|
// --------------------------------------------------- JONOF'S COMPRESSED TEXTURE CACHE STUFF
|
||||||
//static
|
static int32_t gloadtile_hi(int32_t dapic,int32_t dapalnum, int32_t facen, hicreplctyp *hicr, int32_t dameth, pthtyp *pth, int32_t doalloc, char effect)
|
||||||
int32_t gloadtile_hi(int32_t dapic,int32_t dapalnum, int32_t facen, hicreplctyp *hicr, int32_t dameth, pthtyp *pth, int32_t doalloc, char effect)
|
|
||||||
{
|
{
|
||||||
coltype *pic = NULL, *rpptr;
|
coltype *pic = NULL, *rpptr;
|
||||||
int32_t j, x, y, xsiz=0, ysiz=0, tsizx, tsizy;
|
int32_t j, x, y, xsiz=0, ysiz=0, tsizx, tsizy;
|
||||||
|
@ -6774,7 +6777,7 @@ int32_t dedxtfilter(int32_t fil, texcachepicture *pict, char *pic, void *midbuf,
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#else /* POLYMOST */
|
#else /* if !defined USE_OPENGL */
|
||||||
|
|
||||||
#include "inttypes.h"
|
#include "inttypes.h"
|
||||||
int32_t polymost_drawtilescreen(int32_t tilex, int32_t tiley, int32_t wallnum, int32_t dimen,
|
int32_t polymost_drawtilescreen(int32_t tilex, int32_t tiley, int32_t wallnum, int32_t dimen,
|
||||||
|
|
|
@ -2546,6 +2546,7 @@ void G_SetCrosshairColor(int32_t r, int32_t g, int32_t b)
|
||||||
makepalookup(CROSSHAIR_PAL,tempbuf,CrosshairColors.r>>2, CrosshairColors.g>>2, CrosshairColors.b>>2,1);
|
makepalookup(CROSSHAIR_PAL,tempbuf,CrosshairColors.r>>2, CrosshairColors.g>>2, CrosshairColors.b>>2,1);
|
||||||
|
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
|
// XXX: this makes us also load all hightile textures tinted with the crosshair color!
|
||||||
Bmemcpy(&hictinting[CROSSHAIR_PAL], &CrosshairColors, sizeof(palette_t));
|
Bmemcpy(&hictinting[CROSSHAIR_PAL], &CrosshairColors, sizeof(palette_t));
|
||||||
hictinting[CROSSHAIR_PAL].f = 9;
|
hictinting[CROSSHAIR_PAL].f = 9;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -514,8 +514,17 @@ void G_CacheMapData(void)
|
||||||
for (type=0; type<=1; type++)
|
for (type=0; type<=1; type++)
|
||||||
if (precachehightile[type][i>>3] & pow2char[i&7])
|
if (precachehightile[type][i>>3] & pow2char[i&7])
|
||||||
{
|
{
|
||||||
|
k = 0;
|
||||||
for (k=0; k<MAXPALOOKUPS-RESERVEDPALS && !KB_KeyPressed(sc_Space); k++)
|
for (k=0; k<MAXPALOOKUPS-RESERVEDPALS && !KB_KeyPressed(sc_Space); k++)
|
||||||
|
{
|
||||||
|
// this is the CROSSHAIR_COLOR, see comment in game.c
|
||||||
|
if (k == MAXPALOOKUPS-RESERVEDPALS-1)
|
||||||
|
break;
|
||||||
|
|
||||||
|
if (rendmode!=4 || !polymer_havehighpalookup(0, k))
|
||||||
polymost_precache(i,k,type);
|
polymost_precache(i,k,type);
|
||||||
|
}
|
||||||
|
|
||||||
if (r_detailmapping && !KB_KeyPressed(sc_Space))
|
if (r_detailmapping && !KB_KeyPressed(sc_Space))
|
||||||
polymost_precache(i,DETAILPAL,type);
|
polymost_precache(i,DETAILPAL,type);
|
||||||
if (r_glowmapping && !KB_KeyPressed(sc_Space))
|
if (r_glowmapping && !KB_KeyPressed(sc_Space))
|
||||||
|
|
Loading…
Reference in a new issue