[FFmpeg-cvslog] r22172 - in trunk/libavcodec: vp56.c vp6.c
vitor
subversion
Wed Mar 3 18:24:32 CET 2010
Author: vitor
Date: Wed Mar 3 18:24:32 2010
New Revision: 22172
Log:
Plug some memory leaks in the VP6 decoder
Modified:
trunk/libavcodec/vp56.c
trunk/libavcodec/vp6.c
Modified: trunk/libavcodec/vp56.c
==============================================================================
--- trunk/libavcodec/vp56.c Wed Mar 3 17:47:40 2010 (r22171)
+++ trunk/libavcodec/vp56.c Wed Mar 3 18:24:32 2010 (r22172)
@@ -26,6 +26,7 @@
#include "vp56.h"
#include "vp56data.h"
+#include "get_bits.h"
void vp56_init_dequant(VP56Context *s, int quantizer)
@@ -695,6 +696,7 @@ av_cold void vp56_init(AVCodecContext *a
av_cold int vp56_free(AVCodecContext *avctx)
{
VP56Context *s = avctx->priv_data;
+ int pt;
av_freep(&s->qscale_table);
av_freep(&s->above_blocks);
@@ -706,5 +708,15 @@ av_cold int vp56_free(AVCodecContext *av
avctx->release_buffer(avctx, s->framep[VP56_FRAME_GOLDEN2]);
if (s->framep[VP56_FRAME_PREVIOUS]->data[0])
avctx->release_buffer(avctx, s->framep[VP56_FRAME_PREVIOUS]);
+
+ for (pt=0; pt < 2; pt++) {
+ int ct, cg;
+ free_vlc(&s->dccv_vlc[pt]);
+ free_vlc(&s->runv_vlc[pt]);
+ for (ct=0; ct<3; ct++)
+ for (cg = 0; cg < 6; cg++)
+ free_vlc(&s->ract_vlc[pt][ct][cg]);
+ }
+
return 0;
}
Modified: trunk/libavcodec/vp6.c
==============================================================================
--- trunk/libavcodec/vp6.c Wed Mar 3 17:47:40 2010 (r22171)
+++ trunk/libavcodec/vp6.c Wed Mar 3 18:24:32 2010 (r22172)
@@ -227,6 +227,7 @@ static void vp6_build_huff_tree(VP56Cont
nodes[map[2*i+1]].count = b + !b;
}
+ free_vlc(vlc);
/* then build the huffman tree accodring to probabilities */
ff_huff_build_tree(s->avctx, vlc, size, nodes, vp6_huff_cmp,
FF_HUFFMAN_FLAG_HNODE_FIRST);
More information about the ffmpeg-cvslog
mailing list