mirror of
https://github.com/yquake2/yquake2remaster.git
synced 2025-01-19 07:51:03 +00:00
Replace hard coded array with malloc() to prevent stack overflow.
This was an issue an Windows with it's small stack. It didn't trigger on Linux. While at it make the code a little bit more robust by allocating exactly the amount of data we need and not some arbitrary guess.
This commit is contained in:
parent
3873c76e12
commit
8dde5b8539
2 changed files with 14 additions and 26 deletions
|
@ -785,16 +785,8 @@ R_Upload32(unsigned *data, int width, int height, qboolean mipmap)
|
|||
qboolean
|
||||
R_Upload8(byte *data, int width, int height, qboolean mipmap, qboolean is_sky)
|
||||
{
|
||||
unsigned trans[1024 * 1024];
|
||||
int i, s;
|
||||
int p;
|
||||
|
||||
s = width * height;
|
||||
|
||||
if (s > sizeof(trans) / 4)
|
||||
{
|
||||
ri.Sys_Error(ERR_DROP, "%s: too large", __func__);
|
||||
}
|
||||
int s = width * height;
|
||||
unsigned *trans = malloc(s * sizeof(unsigned));
|
||||
|
||||
if (gl_config.palettedtexture && is_sky)
|
||||
{
|
||||
|
@ -809,9 +801,9 @@ R_Upload8(byte *data, int width, int height, qboolean mipmap, qboolean is_sky)
|
|||
}
|
||||
else
|
||||
{
|
||||
for (i = 0; i < s; i++)
|
||||
for (int i = 0; i < s; i++)
|
||||
{
|
||||
p = data[i];
|
||||
int p = data[i];
|
||||
trans[i] = d_8to24table[p];
|
||||
|
||||
/* transparent, so scan around for
|
||||
|
@ -846,7 +838,9 @@ R_Upload8(byte *data, int width, int height, qboolean mipmap, qboolean is_sky)
|
|||
}
|
||||
}
|
||||
|
||||
return R_Upload32(trans, width, height, mipmap);
|
||||
qboolean ret = R_Upload32(trans, width, height, mipmap);
|
||||
free(trans);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -238,20 +238,12 @@ GL3_Upload32(unsigned *data, int width, int height, qboolean mipmap)
|
|||
qboolean
|
||||
GL3_Upload8(byte *data, int width, int height, qboolean mipmap, qboolean is_sky)
|
||||
{
|
||||
unsigned trans[1024 * 1024];
|
||||
int i, s;
|
||||
int p;
|
||||
int s = width * height;
|
||||
unsigned *trans = malloc(s * sizeof(unsigned));
|
||||
|
||||
s = width * height;
|
||||
|
||||
if (s > sizeof(trans) / 4)
|
||||
for (int i = 0; i < s; i++)
|
||||
{
|
||||
ri.Sys_Error(ERR_DROP, "%s: too large", __func__);
|
||||
}
|
||||
|
||||
for (i = 0; i < s; i++)
|
||||
{
|
||||
p = data[i];
|
||||
int p = data[i];
|
||||
trans[i] = d_8to24table[p];
|
||||
|
||||
/* transparent, so scan around for
|
||||
|
@ -286,7 +278,9 @@ GL3_Upload8(byte *data, int width, int height, qboolean mipmap, qboolean is_sky)
|
|||
}
|
||||
}
|
||||
|
||||
return GL3_Upload32(trans, width, height, mipmap);
|
||||
qboolean ret = GL3_Upload32(trans, width, height, mipmap);
|
||||
free(trans);
|
||||
return ret;
|
||||
}
|
||||
|
||||
typedef struct
|
||||
|
|
Loading…
Reference in a new issue