aboutsummaryrefslogtreecommitdiffstats
path: root/tools/libxc/xc_dom_core.c
diff options
context:
space:
mode:
authorKeir Fraser <keir.fraser@citrix.com>2008-12-10 13:14:13 +0000
committerKeir Fraser <keir.fraser@citrix.com>2008-12-10 13:14:13 +0000
commitac677794d61dc7a6f92b16946863043da890c828 (patch)
tree6fe0e679dd838060932619bef20b40a7e5cf53c4 /tools/libxc/xc_dom_core.c
parent8d4638d15e10d2d52547195dd6b57402b5382cce (diff)
downloadxen-ac677794d61dc7a6f92b16946863043da890c828.tar.gz
xen-ac677794d61dc7a6f92b16946863043da890c828.tar.bz2
xen-ac677794d61dc7a6f92b16946863043da890c828.zip
libxc: Fix memory leak in zlib usage
Any call to inflate() must be followed by inflateEnd(), otherwise the internal zlib state is leaked. Signed-off-by: Kevin Wolf <kwolf@suse.de>
Diffstat (limited to 'tools/libxc/xc_dom_core.c')
-rw-r--r--tools/libxc/xc_dom_core.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/tools/libxc/xc_dom_core.c b/tools/libxc/xc_dom_core.c
index 2b6f6b6868..b1e90d8d6e 100644
--- a/tools/libxc/xc_dom_core.c
+++ b/tools/libxc/xc_dom_core.c
@@ -244,6 +244,7 @@ int xc_dom_do_gunzip(void *src, size_t srclen, void *dst, size_t dstlen)
return -1;
}
rc = inflate(&zStream, Z_FINISH);
+ inflateEnd(&zStream);
if ( rc != Z_STREAM_END )
{
xc_dom_panic(XC_INTERNAL_ERROR,