diff options
author | Todd C. Miller <millert@cvs.openbsd.org> | 2002-01-18 21:48:36 +0000 |
---|---|---|
committer | Todd C. Miller <millert@cvs.openbsd.org> | 2002-01-18 21:48:36 +0000 |
commit | 80c89a0bd4283e8268bd9ad6e434a1079a2e2f71 (patch) | |
tree | 6ef80674e224abccd376d56c2256b2f3576330a8 /sys/lib | |
parent | 065be7af7bf8303ae6746863aed2c5399ea42327 (diff) |
Fix some zlib memory leaks, originally from Mark Adler
Diffstat (limited to 'sys/lib')
-rw-r--r-- | sys/lib/libz/infblock.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/sys/lib/libz/infblock.c b/sys/lib/libz/infblock.c index d3d3bb8e347..df9eb431f51 100644 --- a/sys/lib/libz/infblock.c +++ b/sys/lib/libz/infblock.c @@ -246,10 +246,12 @@ int r; &s->sub.trees.tb, s->hufts, z); if (t != Z_OK) { - ZFREE(z, s->sub.trees.blens); r = t; if (r == Z_DATA_ERROR) + { + ZFREE(z, s->sub.trees.blens); s->mode = BAD; + } LEAVE } s->sub.trees.index = 0; @@ -310,11 +312,13 @@ int r; t = inflate_trees_dynamic(257 + (t & 0x1f), 1 + ((t >> 5) & 0x1f), s->sub.trees.blens, &bl, &bd, &tl, &td, s->hufts, z); - ZFREE(z, s->sub.trees.blens); if (t != Z_OK) { if (t == (uInt)Z_DATA_ERROR) + { + ZFREE(z, s->sub.trees.blens); s->mode = BAD; + } r = t; LEAVE } @@ -326,6 +330,7 @@ int r; } s->sub.decode.codes = c; } + ZFREE(z, s->sub.trees.blens); s->mode = CODES; case CODES: UPDATE |