Mercurial > mplayer.hg
changeset 13953:3dbebe82fc37
3 memory leaks fixed
Xlib funtions allocate memory that should be freed appropriately
author | iive |
---|---|
date | Mon, 15 Nov 2004 14:56:18 +0000 |
parents | bcdf8a05ad45 |
children | 7dfda76015c8 |
files | libvo/vo_xv.c libvo/x11_common.c |
diffstat | 2 files changed, 8 insertions(+), 2 deletions(-) [+] |
line wrap: on
line diff
--- a/libvo/vo_xv.c Mon Nov 15 13:14:02 2004 +0000 +++ b/libvo/vo_xv.c Mon Nov 15 14:56:18 2004 +0000 @@ -68,7 +68,7 @@ static unsigned int ver, rel, req, ev, err; static unsigned int formats, adaptors, xv_port, xv_format; static XvAdaptorInfo *ai = NULL; -static XvImageFormatValues *fo; +static XvImageFormatValues *fo=NULL; static int current_buf = 0; static int current_ip_buf = 0; @@ -761,6 +761,10 @@ return; XvFreeAdaptorInfo(ai); ai = NULL; + if(fo){ + XFree(fo); + fo=NULL; + } for (i = 0; i < num_buffers; i++) deallocate_xvimage(i); #ifdef HAVE_XF86VM @@ -878,7 +882,7 @@ { int howmany, i; - const XvAttribute *const attributes = + XvAttribute * const attributes = XvQueryPortAttributes(mDisplay, xv_port, &howmany); for (i = 0; i < howmany && attributes; i++) @@ -889,6 +893,7 @@ XvSetPortAttribute(mDisplay, xv_port, autopaint, 1); break; } + XFree(attributes); } fo = XvListImageFormats(mDisplay, xv_port, (int *) &formats);