mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
Add zlib_freetable() to prevent memory leaks. Thanks to Kevin Eric Saunders
[originally from svn r917]
This commit is contained in:
parent
13b9a2da31
commit
48699e8431
34
sshzlib.c
34
sshzlib.c
@ -747,6 +747,31 @@ static struct zlib_table *zlib_mktable(unsigned char *lengths, int nlengths) {
|
|||||||
maxlen < 9 ? maxlen : 9);
|
maxlen < 9 ? maxlen : 9);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int zlib_freetable(struct zlib_table ** ztab) {
|
||||||
|
struct zlib_table *tab;
|
||||||
|
int code;
|
||||||
|
|
||||||
|
if (ztab == NULL)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
if (*ztab == NULL)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
tab = *ztab;
|
||||||
|
|
||||||
|
for (code = 0; code <= tab->mask; code++)
|
||||||
|
if (tab->table[code].nexttable != NULL)
|
||||||
|
zlib_freetable(&tab->table[code].nexttable);
|
||||||
|
|
||||||
|
sfree(tab->table);
|
||||||
|
tab->table = NULL;
|
||||||
|
|
||||||
|
sfree(tab);
|
||||||
|
*ztab = NULL;
|
||||||
|
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
|
|
||||||
static struct zlib_decompress_ctx {
|
static struct zlib_decompress_ctx {
|
||||||
struct zlib_table *staticlentable, *staticdisttable;
|
struct zlib_table *staticlentable, *staticdisttable;
|
||||||
struct zlib_table *currlentable, *currdisttable, *lenlentable;
|
struct zlib_table *currlentable, *currdisttable, *lenlentable;
|
||||||
@ -893,8 +918,8 @@ int zlib_decompress_block(unsigned char *block, int len,
|
|||||||
dctx.currlentable = zlib_mktable(dctx.lengths, dctx.hlit);
|
dctx.currlentable = zlib_mktable(dctx.lengths, dctx.hlit);
|
||||||
dctx.currdisttable = zlib_mktable(dctx.lengths + dctx.hlit,
|
dctx.currdisttable = zlib_mktable(dctx.lengths + dctx.hlit,
|
||||||
dctx.hdist);
|
dctx.hdist);
|
||||||
/* FIXME: zlib_freetable(dctx.lenlentable); */
|
zlib_freetable(&dctx.lenlentable);
|
||||||
dctx.state = INBLK;
|
dctx.state = INBLK;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
code = zlib_huflookup(&dctx.bits, &dctx.nbits, dctx.lenlentable);
|
code = zlib_huflookup(&dctx.bits, &dctx.nbits, dctx.lenlentable);
|
||||||
@ -930,7 +955,10 @@ int zlib_decompress_block(unsigned char *block, int len,
|
|||||||
zlib_emit_char(code);
|
zlib_emit_char(code);
|
||||||
else if (code == 256) {
|
else if (code == 256) {
|
||||||
dctx.state = OUTSIDEBLK;
|
dctx.state = OUTSIDEBLK;
|
||||||
/* FIXME: zlib_freetable(both) if not static */
|
if (dctx.currlentable != dctx.staticlentable)
|
||||||
|
zlib_freetable(&dctx.currlentable);
|
||||||
|
if (dctx.currdisttable != dctx.staticdisttable)
|
||||||
|
zlib_freetable(&dctx.currdisttable);
|
||||||
} else if (code < 286) { /* static tree can give >285; ignore */
|
} else if (code < 286) { /* static tree can give >285; ignore */
|
||||||
dctx.state = GOTLENSYM;
|
dctx.state = GOTLENSYM;
|
||||||
dctx.sym = code;
|
dctx.sym = code;
|
||||||
|
Loading…
Reference in New Issue
Block a user