mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
Polymost: fix mirror-related oob access analogous to r1872's fix for classic.
When drawing from inside the mirror, there may be no 'bunches' (BUILD lingo, not TROR ones) collected, but following code used the first one unconditionally. git-svn-id: https://svn.eduke32.com/eduke32@2427 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
9f78a773f1
commit
07426ccc2a
2 changed files with 11 additions and 5 deletions
|
@ -7943,7 +7943,7 @@ int32_t initengine(void)
|
||||||
|
|
||||||
// for (i=0; i<MAXPALOOKUPS; i++) palookup[i] = NULL;
|
// for (i=0; i<MAXPALOOKUPS; i++) palookup[i] = NULL;
|
||||||
/*
|
/*
|
||||||
clearbuf(&waloff[0],(int32_t)MAXTILES,0L);
|
Bmemset(waloff, 0, sizeof(waloff));
|
||||||
|
|
||||||
clearbuf(&show2dsector[0],(int32_t)((MAXSECTORS+3)>>5),0L);
|
clearbuf(&show2dsector[0],(int32_t)((MAXSECTORS+3)>>5),0L);
|
||||||
clearbuf(&show2dsprite[0],(int32_t)((MAXSPRITES+3)>>5),0L);
|
clearbuf(&show2dsprite[0],(int32_t)((MAXSPRITES+3)>>5),0L);
|
||||||
|
@ -8228,6 +8228,7 @@ void drawrooms(int32_t daposx, int32_t daposy, int32_t daposz,
|
||||||
|
|
||||||
if (inpreparemirror)
|
if (inpreparemirror)
|
||||||
{
|
{
|
||||||
|
// INPREPAREMIRROR_NO_BUNCHES
|
||||||
// numbunches==0 can happen if the mirror is far away... the game code decides
|
// numbunches==0 can happen if the mirror is far away... the game code decides
|
||||||
// to draw it, but scansector gets zero bunches. Result: big screwup!
|
// to draw it, but scansector gets zero bunches. Result: big screwup!
|
||||||
// Leave inpreparemirror as is, it's restored by completemirror.
|
// Leave inpreparemirror as is, it's restored by completemirror.
|
||||||
|
|
|
@ -4604,11 +4604,16 @@ void polymost_drawrooms()
|
||||||
{
|
{
|
||||||
grhalfxdown10x = -grhalfxdown10;
|
grhalfxdown10x = -grhalfxdown10;
|
||||||
inpreparemirror = 0;
|
inpreparemirror = 0;
|
||||||
|
|
||||||
|
// see engine.c: INPREPAREMIRROR_NO_BUNCHES
|
||||||
|
if (numbunches > 0)
|
||||||
|
{
|
||||||
polymost_drawalls(0);
|
polymost_drawalls(0);
|
||||||
numbunches--;
|
numbunches--;
|
||||||
bunchfirst[0] = bunchfirst[numbunches];
|
bunchfirst[0] = bunchfirst[numbunches];
|
||||||
bunchlast[0] = bunchlast[numbunches];
|
bunchlast[0] = bunchlast[numbunches];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
grhalfxdown10x = grhalfxdown10;
|
grhalfxdown10x = grhalfxdown10;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue