mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 08:50:55 +00:00
Stylistic/formatting tweaks in cache1d code.
git-svn-id: https://svn.eduke32.com/eduke32@4255 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
d452fd7891
commit
3b1515e51b
4 changed files with 75 additions and 28 deletions
|
@ -84,21 +84,21 @@ static intptr_t kzipopen(const char *filnam)
|
||||||
// without first calling initcache.
|
// without first calling initcache.
|
||||||
|
|
||||||
// Uncomment for easier allocache-allocated bound checking (e.g. with Valgrind)
|
// Uncomment for easier allocache-allocated bound checking (e.g. with Valgrind)
|
||||||
|
// KEEPINSYNC game.c
|
||||||
//#define DEBUG_ALLOCACHE_AS_MALLOC
|
//#define DEBUG_ALLOCACHE_AS_MALLOC
|
||||||
|
|
||||||
#define MAXCACHEOBJECTS 9216
|
#define MAXCACHEOBJECTS 9216
|
||||||
|
|
||||||
#ifndef DEBUG_ALLOCACHE_AS_MALLOC
|
#if !defined DEBUG_ALLOCACHE_AS_MALLOC
|
||||||
static int32_t cachesize = 0;
|
static int32_t cachesize = 0;
|
||||||
//static int32_t cachecount = 0;
|
|
||||||
static char zerochar = 0;
|
static char zerochar = 0;
|
||||||
static intptr_t cachestart = 0;
|
static intptr_t cachestart = 0;
|
||||||
static int32_t agecount = 0;
|
static int32_t agecount = 0;
|
||||||
static int32_t lockrecip[200];
|
static int32_t lockrecip[200];
|
||||||
#endif
|
|
||||||
|
|
||||||
int32_t cacnum = 0;
|
int32_t cacnum = 0;
|
||||||
cactype cac[MAXCACHEOBJECTS];
|
cactype cac[MAXCACHEOBJECTS];
|
||||||
|
#endif
|
||||||
|
|
||||||
static char toupperlookup[256] =
|
static char toupperlookup[256] =
|
||||||
{
|
{
|
||||||
|
@ -128,7 +128,8 @@ void initcache(intptr_t dacachestart, int32_t dacachesize)
|
||||||
#ifndef DEBUG_ALLOCACHE_AS_MALLOC
|
#ifndef DEBUG_ALLOCACHE_AS_MALLOC
|
||||||
int32_t i;
|
int32_t i;
|
||||||
|
|
||||||
for (i=1; i<200; i++) lockrecip[i] = (1<<28)/(200-i);
|
for (i=1; i<200; i++)
|
||||||
|
lockrecip[i] = (1<<28)/(200-i);
|
||||||
|
|
||||||
// The following code was relocated here from engine.c, since this
|
// The following code was relocated here from engine.c, since this
|
||||||
// function is only ever called once (from there), and it seems to
|
// function is only ever called once (from there), and it seems to
|
||||||
|
@ -165,9 +166,17 @@ void allocache(intptr_t *newhandle, int32_t newbytes, char *newlockptr)
|
||||||
reportandexit("OUT OF MEMORY in allocache as malloc wrapper!");
|
reportandexit("OUT OF MEMORY in allocache as malloc wrapper!");
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
static void inc_and_check_cacnum(void)
|
||||||
|
{
|
||||||
|
cacnum++;
|
||||||
|
|
||||||
|
if (cacnum > MAXCACHEOBJECTS)
|
||||||
|
reportandexit("Too many objects in cache! (cacnum > MAXCACHEOBJECTS)");
|
||||||
|
}
|
||||||
|
|
||||||
void allocache(intptr_t *newhandle, int32_t newbytes, char *newlockptr)
|
void allocache(intptr_t *newhandle, int32_t newbytes, char *newlockptr)
|
||||||
{
|
{
|
||||||
int32_t i, /*j,*/ z, zz, bestz=0, daval, bestval, besto=0, o1, o2, sucklen, suckz;
|
int32_t i, z, bestz=0, bestval, besto=0, o1, sucklen, suckz;
|
||||||
|
|
||||||
//printf(" ==> asking for %d bytes, ", newbytes);
|
//printf(" ==> asking for %d bytes, ", newbytes);
|
||||||
// Make all requests a multiple of 16 bytes
|
// Make all requests a multiple of 16 bytes
|
||||||
|
@ -190,17 +199,34 @@ void allocache(intptr_t *newhandle, int32_t newbytes, char *newlockptr)
|
||||||
bestval = 0x7fffffff; o1 = cachesize;
|
bestval = 0x7fffffff; o1 = cachesize;
|
||||||
for (z=cacnum-1; z>=0; z--)
|
for (z=cacnum-1; z>=0; z--)
|
||||||
{
|
{
|
||||||
|
int32_t zz, o2, daval;
|
||||||
|
|
||||||
o1 -= cac[z].leng;
|
o1 -= cac[z].leng;
|
||||||
o2 = o1+newbytes; if (o2 > cachesize) continue;
|
o2 = o1+newbytes;
|
||||||
|
|
||||||
|
if (o2 > cachesize)
|
||||||
|
continue;
|
||||||
|
|
||||||
daval = 0;
|
daval = 0;
|
||||||
for (i=o1,zz=z; i<o2; i+=cac[zz++].leng)
|
for (i=o1,zz=z; i<o2; i+=cac[zz++].leng)
|
||||||
{
|
{
|
||||||
if (*cac[zz].lock == 0) continue;
|
if (*cac[zz].lock == 0)
|
||||||
if (*cac[zz].lock >= 200) { daval = 0x7fffffff; break; }
|
continue;
|
||||||
daval += mulscale32(cac[zz].leng+65536,lockrecip[*cac[zz].lock]);
|
|
||||||
if (daval >= bestval) break;
|
if (*cac[zz].lock >= 200)
|
||||||
|
{
|
||||||
|
daval = 0x7fffffff;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Potential for eviction increases with
|
||||||
|
// - smaller item size
|
||||||
|
// - smaller lock byte value (but in [1 .. 199])
|
||||||
|
daval += mulscale32(cac[zz].leng+65536, lockrecip[*cac[zz].lock]);
|
||||||
|
if (daval >= bestval)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if (daval < bestval)
|
if (daval < bestval)
|
||||||
{
|
{
|
||||||
bestval = daval; besto = o1; bestz = z;
|
bestval = daval; besto = o1; bestz = z;
|
||||||
|
@ -215,33 +241,43 @@ void allocache(intptr_t *newhandle, int32_t newbytes, char *newlockptr)
|
||||||
|
|
||||||
//Suck things out
|
//Suck things out
|
||||||
for (sucklen=-newbytes,suckz=bestz; sucklen<0; sucklen+=cac[suckz++].leng)
|
for (sucklen=-newbytes,suckz=bestz; sucklen<0; sucklen+=cac[suckz++].leng)
|
||||||
if (*cac[suckz].lock) *cac[suckz].hand = 0;
|
if (*cac[suckz].lock)
|
||||||
|
*cac[suckz].hand = 0;
|
||||||
|
|
||||||
//Remove all blocks except 1
|
//Remove all blocks except 1
|
||||||
suckz -= (bestz+1); cacnum -= suckz;
|
suckz -= bestz+1;
|
||||||
// copybufbyte(&cac[bestz+suckz],&cac[bestz],(cacnum-bestz)*sizeof(cactype));
|
cacnum -= suckz;
|
||||||
|
|
||||||
Bmemmove(&cac[bestz], &cac[bestz+suckz], (cacnum-bestz)*sizeof(cactype));
|
Bmemmove(&cac[bestz], &cac[bestz+suckz], (cacnum-bestz)*sizeof(cactype));
|
||||||
cac[bestz].hand = newhandle; *newhandle = cachestart+(intptr_t)besto;
|
cac[bestz].hand = newhandle;
|
||||||
|
*newhandle = cachestart + besto;
|
||||||
cac[bestz].leng = newbytes;
|
cac[bestz].leng = newbytes;
|
||||||
cac[bestz].lock = newlockptr;
|
cac[bestz].lock = newlockptr;
|
||||||
// cachecount++;
|
|
||||||
|
|
||||||
//Add new empty block if necessary
|
//Add new empty block if necessary
|
||||||
if (sucklen <= 0) return;
|
if (sucklen <= 0)
|
||||||
|
return;
|
||||||
|
|
||||||
bestz++;
|
bestz++;
|
||||||
if (bestz == cacnum)
|
if (bestz == cacnum)
|
||||||
{
|
{
|
||||||
cacnum++; if (cacnum > MAXCACHEOBJECTS) reportandexit("Too many objects in cache! (cacnum > MAXCACHEOBJECTS)");
|
inc_and_check_cacnum();
|
||||||
|
|
||||||
cac[bestz].leng = sucklen;
|
cac[bestz].leng = sucklen;
|
||||||
cac[bestz].lock = &zerochar;
|
cac[bestz].lock = &zerochar;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (*cac[bestz].lock == 0) { cac[bestz].leng += sucklen; return; }
|
if (*cac[bestz].lock == 0)
|
||||||
|
{
|
||||||
|
cac[bestz].leng += sucklen;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
cacnum++; if (cacnum > MAXCACHEOBJECTS) reportandexit("Too many objects in cache! (cacnum > MAXCACHEOBJECTS)");
|
inc_and_check_cacnum();
|
||||||
for (z=cacnum-1; z>bestz; z--) cac[z] = cac[z-1];
|
|
||||||
|
for (z=cacnum-1; z>bestz; z--)
|
||||||
|
cac[z] = cac[z-1];
|
||||||
cac[bestz].leng = sucklen;
|
cac[bestz].leng = sucklen;
|
||||||
cac[bestz].lock = &zerochar;
|
cac[bestz].lock = &zerochar;
|
||||||
}
|
}
|
||||||
|
@ -252,16 +288,21 @@ void agecache(void)
|
||||||
#ifndef DEBUG_ALLOCACHE_AS_MALLOC
|
#ifndef DEBUG_ALLOCACHE_AS_MALLOC
|
||||||
int32_t cnt = (cacnum>>4);
|
int32_t cnt = (cacnum>>4);
|
||||||
|
|
||||||
if (agecount >= cacnum) agecount = cacnum-1;
|
if (agecount >= cacnum)
|
||||||
if (agecount < 0 || !cnt) return;
|
agecount = cacnum-1;
|
||||||
|
|
||||||
|
if (agecount < 0 || !cnt)
|
||||||
|
return;
|
||||||
|
|
||||||
for (; cnt>=0; cnt--)
|
for (; cnt>=0; cnt--)
|
||||||
{
|
{
|
||||||
|
// If we have pointer to lock char and it's in [2 .. 199], decrease.
|
||||||
if (cac[agecount].lock && (((*cac[agecount].lock)-2)&255) < 198)
|
if (cac[agecount].lock && (((*cac[agecount].lock)-2)&255) < 198)
|
||||||
(*cac[agecount].lock)--;
|
(*cac[agecount].lock)--;
|
||||||
|
|
||||||
agecount--;
|
agecount--;
|
||||||
if (agecount < 0) agecount = cacnum-1;
|
if (agecount < 0)
|
||||||
|
agecount = cacnum-1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
|
@ -11054,11 +11054,12 @@ int32_t loadpics(const char *filename, int32_t askedsize)
|
||||||
|
|
||||||
for (i=localtilestart; i<=localtileend; i++)
|
for (i=localtilestart; i<=localtileend; i++)
|
||||||
{
|
{
|
||||||
|
EDUKE32_STATIC_ASSERT(sizeof(picanm_t) == 4);
|
||||||
|
EDUKE32_STATIC_ASSERT(PICANM_ANIMTYPE_MASK == 192);
|
||||||
|
|
||||||
tilesizx[i] = B_LITTLE16(tilesizx[i]);
|
tilesizx[i] = B_LITTLE16(tilesizx[i]);
|
||||||
tilesizy[i] = B_LITTLE16(tilesizy[i]);
|
tilesizy[i] = B_LITTLE16(tilesizy[i]);
|
||||||
|
|
||||||
Bassert(sizeof(picanm_t)==4);
|
|
||||||
Bassert(PICANM_ANIMTYPE_MASK == 192);
|
|
||||||
// Old on-disk format: anim type is in the 2 highest bits of the lowest byte.
|
// Old on-disk format: anim type is in the 2 highest bits of the lowest byte.
|
||||||
picanm[i].sf &= ~192;
|
picanm[i].sf &= ~192;
|
||||||
picanm[i].sf |= picanm[i].num&192;
|
picanm[i].sf |= picanm[i].num&192;
|
||||||
|
|
|
@ -1371,8 +1371,14 @@ void G_GameQuit(void)
|
||||||
G_GameExit("Timed out.");
|
G_GameExit("Timed out.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Uncomment for easier allocache-allocated bound checking (e.g. with Valgrind)
|
||||||
|
// KEEPINSYNC cache1d.c
|
||||||
|
//#define DEBUG_ALLOCACHE_AS_MALLOC
|
||||||
|
|
||||||
|
#if !defined DEBUG_ALLOCACHE_AS_MALLOC
|
||||||
extern int32_t cacnum;
|
extern int32_t cacnum;
|
||||||
extern cactype cac[];
|
extern cactype cac[];
|
||||||
|
#endif
|
||||||
|
|
||||||
static void G_ShowCacheLocks(void)
|
static void G_ShowCacheLocks(void)
|
||||||
{
|
{
|
||||||
|
@ -1382,6 +1388,7 @@ static void G_ShowCacheLocks(void)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
k = 0;
|
k = 0;
|
||||||
|
#if !defined DEBUG_ALLOCACHE_AS_MALLOC
|
||||||
for (i=cacnum-1; i>=0; i--)
|
for (i=cacnum-1; i>=0; i--)
|
||||||
if ((*cac[i].lock) >= 200)
|
if ((*cac[i].lock) >= 200)
|
||||||
{
|
{
|
||||||
|
@ -1392,7 +1399,7 @@ static void G_ShowCacheLocks(void)
|
||||||
printext256(0L,k,31,-1,tempbuf,1);
|
printext256(0L,k,31,-1,tempbuf,1);
|
||||||
k += 6;
|
k += 6;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
if (k < ydim-12)
|
if (k < ydim-12)
|
||||||
k += 6;
|
k += 6;
|
||||||
|
|
||||||
|
|
|
@ -241,8 +241,6 @@ typedef struct {
|
||||||
} user_defs;
|
} user_defs;
|
||||||
|
|
||||||
|
|
||||||
extern cactype cac[];
|
|
||||||
|
|
||||||
// this is checked against http://eduke32.com/VERSION
|
// this is checked against http://eduke32.com/VERSION
|
||||||
extern const char *s_buildDate;
|
extern const char *s_buildDate;
|
||||||
extern const char *g_gameNamePtr;
|
extern const char *g_gameNamePtr;
|
||||||
|
|
Loading…
Reference in a new issue