gloadtex() cleanup, make some vars in kplib.c static, add source/valgrind_errors.log.

BUILD_LUNATIC.

git-svn-id: https://svn.eduke32.com/eduke32@4295 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2014-02-02 15:56:13 +00:00
parent 41cee5ed69
commit 2b583e9c9e
4 changed files with 159 additions and 28 deletions

View file

@ -161,8 +161,8 @@ static kzfilestate kzfs;
// pow2mask 128* // pow2mask 128*
// dcflagor 64 // dcflagor 64
int32_t palcol[256] ASMNAME("palcol"), paleng, bakcol, numhufblocks, zlibcompflags; static int32_t palcol[256] ASMNAME("palcol"), paleng, bakcol, numhufblocks, zlibcompflags;
int8_t coltype, filtype, bitdepth; static int8_t coltype, filtype, bitdepth;
//============================ KPNGILIB begins =============================== //============================ KPNGILIB begins ===============================

View file

@ -2546,13 +2546,17 @@ static voxmodel_t *gvox;
uint32_t gloadtex(int32_t *picbuf, int32_t xsiz, int32_t ysiz, int32_t is8bit, int32_t dapal) uint32_t gloadtex(int32_t *picbuf, int32_t xsiz, int32_t ysiz, int32_t is8bit, int32_t dapal)
{ {
uint32_t rtexid; uint32_t rtexid;
coltype *pic, *pic2;
char *cptr;
int32_t i; int32_t i;
pic = (coltype *)picbuf; //Correct for GL's RGB order; also apply gamma here.. const char *const cptr = &britable[gammabrightness ? 0 : curbrightness][0];
pic2 = (coltype *)Bmalloc(xsiz*ysiz*sizeof(int32_t)); if (!pic2) return((unsigned)-1);
cptr = (char *)&britable[gammabrightness ? 0 : curbrightness][0]; // Correct for GL's RGB order; also apply gamma here:
const coltype *const pic = (const coltype *)picbuf;
coltype *pic2 = (coltype *)Bmalloc(xsiz*ysiz*sizeof(coltype));
if (!pic2)
return (unsigned)-1;
if (!is8bit) if (!is8bit)
{ {
for (i=xsiz*ysiz-1; i>=0; i--) for (i=xsiz*ysiz-1; i>=0; i--)
@ -2565,12 +2569,16 @@ uint32_t gloadtex(int32_t *picbuf, int32_t xsiz, int32_t ysiz, int32_t is8bit, i
} }
else else
{ {
if (palookup[dapal] == NULL) dapal = 0; if (palookup[dapal] == NULL)
dapal = 0;
for (i=xsiz*ysiz-1; i>=0; i--) for (i=xsiz*ysiz-1; i>=0; i--)
{ {
pic2[i].b = cptr[palette[(int32_t)palookup[dapal][pic[i].a]*3+2]*4]; const int32_t ii = palookup[dapal][pic[i].a] * 3;
pic2[i].g = cptr[palette[(int32_t)palookup[dapal][pic[i].a]*3+1]*4];
pic2[i].r = cptr[palette[(int32_t)palookup[dapal][pic[i].a]*3+0]*4]; pic2[i].b = cptr[palette[ii+2]*4];
pic2[i].g = cptr[palette[ii+1]*4];
pic2[i].r = cptr[palette[ii+0]*4];
pic2[i].a = 255; pic2[i].a = 255;
} }
} }
@ -2580,8 +2588,10 @@ uint32_t gloadtex(int32_t *picbuf, int32_t xsiz, int32_t ysiz, int32_t is8bit, i
bglTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_NEAREST); bglTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_NEAREST);
bglTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_NEAREST); bglTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_NEAREST);
bglTexImage2D(GL_TEXTURE_2D,0,4,xsiz,ysiz,0,GL_RGBA,GL_UNSIGNED_BYTE,(char *)pic2); bglTexImage2D(GL_TEXTURE_2D,0,4,xsiz,ysiz,0,GL_RGBA,GL_UNSIGNED_BYTE,(char *)pic2);
Bfree(pic2); Bfree(pic2);
return(rtexid);
return rtexid;
} }
static int32_t getvox(int32_t x, int32_t y, int32_t z) static int32_t getvox(int32_t x, int32_t y, int32_t z)

View file

@ -1597,22 +1597,7 @@ int32_t MV_Init
MV_SetErrorCode(MV_Ok); MV_SetErrorCode(MV_Ok);
// MV_TotalMemory + 2: FIXME // MV_TotalMemory + 2: FIXME, see valgrind_errors.log
// Thread 3:
// Invalid read of size 2
// at 0x8730513: MV_Mix16BitStereo16Stereo (mixst.c:272)
// by 0x872A5A2: MV_Mix (multivoc.c:285)
// by 0x872B0EA: MV_ServiceVoc (multivoc.c:449)
// by 0x87342C1: fillData (driver_sdl.c:80)
// by 0x428F2AD: ??? (in /usr/lib/libSDL_mixer-1.2.so.0.2.6)
// . . .
// Address 0x11e9fa10 is 0 bytes after a block of size 9,728 alloc'd
// at 0x402732C: calloc (vg_replace_malloc.c:467)
// by 0x87288C8: MV_Init (multivoc.c:2528)
// by 0x871BD20: FX_Init (fx_man.c:160)
// by 0x84597CA: S_SoundStartup (sounds.c:62)
// by 0x80D7869: app_main (game.c:10378)
// by 0x870C9C0: main (sdlayer.c:222)
totalmem = Voices * sizeof(VoiceNode) + sizeof(HARSH_CLIP_TABLE_8) + MV_TOTALBUFFERSIZE + 2; totalmem = Voices * sizeof(VoiceNode) + sizeof(HARSH_CLIP_TABLE_8) + MV_TOTALBUFFERSIZE + 2;
ptr = (char *) calloc(1, totalmem); ptr = (char *) calloc(1, totalmem);

View file

@ -0,0 +1,136 @@
build: LTO=0 WITHOUT_GTK=1 RELEASE=0 LUNATIC=0 make
platform: Linux/x86_64
----------
Thread 3:
Invalid read of size 2
at 0x8730513: MV_Mix16BitStereo16Stereo (mixst.c:272)
by 0x872A5A2: MV_Mix (multivoc.c:285)
by 0x872B0EA: MV_ServiceVoc (multivoc.c:449)
by 0x87342C1: fillData (driver_sdl.c:80)
by 0x428F2AD: ??? (in /usr/lib/libSDL_mixer-1.2.so.0.2.6)
. . .
Address 0x11e9fa10 is 0 bytes after a block of size 9,728 alloc'd
at 0x402732C: calloc (vg_replace_malloc.c:467)
by 0x87288C8: MV_Init (multivoc.c:2528)
by 0x871BD20: FX_Init (fx_man.c:160)
by 0x84597CA: S_SoundStartup (sounds.c:62)
by 0x80D7869: app_main (game.c:10378)
by 0x870C9C0: main (sdlayer.c:222)
----------
AMC TC: drawing character selection screen? (The program was gdb-stopped for a
while before.)
Invalid read of size 1
at 0x11C8A709: bcmp (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
by 0x513A08: S_PlayMusic (sounds.c:265)
by 0x4F94E0: G_EnterLevel (premap.c:1917)
by 0x42CCF7: G_NewGame_EnterLevel (game.h:553)
by 0x453BB3: app_main (game.c:11859)
by 0x5BAB3C: main (sdlayer.c:278)
Address 0x19206e30 is 0 bytes after a block of size 0 alloc'd
at 0x11C852DB: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
by 0x51396F: S_PlayMusic (sounds.c:253)
by 0x4F94E0: G_EnterLevel (premap.c:1917)
by 0x42CCF7: G_NewGame_EnterLevel (game.h:553)
by 0x453BB3: app_main (game.c:11859)
by 0x5BAB3C: main (sdlayer.c:278)
----------
AMC TC: drawing Shadow Warrior Riot Gun.
Invalid read of size 1
at 0x5BEE8C: mspritevline (a-c.c:554)
by 0x541AFB: dorotatesprite (engine.c:7742)
by 0x556DAD: rotatesprite_ (engine.c:14581)
by 0x4A7D8F: VM_Execute (gameexec.c:2735)
by 0x4A68F4: VM_Execute (gameexec.c:2346)
by 0x4A4404: VM_Execute (gameexec.c:1779)
by 0x4B1469: VM_Execute (gameexec.c:4974)
by 0x4B1469: VM_Execute (gameexec.c:4974)
by 0x4A43D5: VM_Execute (gameexec.c:1772)
by 0x4B1170: VM_Execute (gameexec.c:4928)
by 0x4A4404: VM_Execute (gameexec.c:1779)
by 0x4B1170: VM_Execute (gameexec.c:4928)
Address 0x1f3524d6 is 22 bytes after a block of size 131,072 free'd
at 0x11C8660C: free (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
by 0x4B5BB9: Gv_Free (gamevars.c:49)
by 0x4B6EEF: Gv_ResetVars (gamevars.c:369)
by 0x4F7290: G_NewGame (premap.c:1423)
by 0x42CCED: G_NewGame_EnterLevel (game.h:551)
by 0x453BB3: app_main (game.c:11859)
by 0x5BAB4A: main (sdlayer.c:278)
----------
AMC TC: select James. Switching between his first weapon (a pistol) and the
next one, but still drawing the first one. Appears to happen only once.
Invalid read of size 1
at 0x5BEE8C: mspritevline (a-c.c:554)
by 0x541AFB: dorotatesprite (engine.c:7742)
by 0x556DAD: rotatesprite_ (engine.c:14581)
by 0x4A7D8F: VM_Execute (gameexec.c:2735)
by 0x4A68F4: VM_Execute (gameexec.c:2346)
by 0x4A43D5: VM_Execute (gameexec.c:1772)
by 0x4B1170: VM_Execute (gameexec.c:4928)
by 0x4A4404: VM_Execute (gameexec.c:1779)
by 0x4B1170: VM_Execute (gameexec.c:4928)
by 0x4A4404: VM_Execute (gameexec.c:1779)
by 0x4B1170: VM_Execute (gameexec.c:4928)
by 0x4B1170: VM_Execute (gameexec.c:4928)
Address 0x278048b5 is 5 bytes after a block of size 1,024 free'd
at 0x11C8660C: free (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
by 0x12B3DAE0: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.0.0)
by 0x12B3DB2C: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.0.0)
by 0x12B40009: SDL_LowerBlit (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.0.0)
by 0x12B4023C: SDL_UpperBlit (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.0.0)
by 0x5BD15A: showframe (sdlayer.c:1922)
by 0x54C44B: nextpage (engine.c:11208)
by 0x454291: app_main (game.c:12000)
by 0x5BAB4A: main (sdlayer.c:278)
----------
AMC TC: Polymost, voxels, r4292 line numbers
Use of uninitialised value of size 8
at 0x59BFF1: gloadtex (mdsprite.c:2571)
by 0x5A06E3: voxdraw (mdsprite.c:3301)
by 0x572F25: polymost_drawsprite (polymost.c:3730)
by 0x53912B: drawsprite_opengl (engine.c:5571)
by 0x53DC18: drawsprite (engine.c:6579)
by 0x545DD2: drawmasks (engine.c:9478)
by 0x43B655: G_HandleMirror (game.c:4296)
by 0x43C6A9: G_DrawRooms (game.c:4638)
by 0x4543AD: app_main (game.c:12018)
by 0x5BAB4A: main (sdlayer.c:278)
----------
Non-pow2 ysize tiles.
Invalid read of size 1
at 0x505D26: vlineasm4 (a-c.c:138)
by 0x47A5C1: wallscan (engine.c:3905)
by 0x47E549: drawalls (engine.c:4978)
by 0x48C342: drawrooms (engine.c:9052)
by 0x47192D: yax_drawrooms (engine.c:1174)
by 0x50756B: M32_DrawRoomsAndMasks (build.c:476)
by 0x507F69: app_main (build.c:742)
by 0x502328: main (sdlayer.c:278)
Address 0x1ea6f89d is 0 bytes after a block of size 10,509 alloc'd
at 0x112D62DB: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
by 0x46A0D3: allocache (cache1d.c:164)
by 0x494A35: loadtile (engine.c:11521)
by 0x475BAE: maskwallscan (engine.c:2832)
by 0x482DC3: drawsprite_classic (engine.c:6094)
by 0x485467: drawsprite (engine.c:6581)
by 0x48D759: drawmasks (engine.c:9495)
by 0x507589: M32_DrawRoomsAndMasks (build.c:479)
by 0x507F69: app_main (build.c:742)
by 0x502328: main (sdlayer.c:278)