From 80dc7c0160fb27e46fc0caae8af10b3d63730c7c Mon Sep 17 00:00:00 2001 From: Anton Khirnov Date: Sun, 25 Dec 2011 19:35:19 +0100 Subject: avs: call release_buffer() at the end. Fixes a memleak. --- libavcodec/avs.c | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'libavcodec/avs.c') diff --git a/libavcodec/avs.c b/libavcodec/avs.c index 3ccded3f8c..b3cd5b1478 100644 --- a/libavcodec/avs.c +++ b/libavcodec/avs.c @@ -161,6 +161,15 @@ static av_cold int avs_decode_init(AVCodecContext * avctx) return 0; } +static av_cold int avs_decode_end(AVCodecContext *avctx) +{ + AvsContext *s = avctx->priv_data; + if (s->picture.data[0]) + avctx->release_buffer(avctx, &s->picture); + return 0; +} + + AVCodec ff_avs_decoder = { .name = "avs", .type = AVMEDIA_TYPE_VIDEO, @@ -168,6 +177,7 @@ AVCodec ff_avs_decoder = { .priv_data_size = sizeof(AvsContext), .init = avs_decode_init, .decode = avs_decode_frame, + .close = avs_decode_end, .capabilities = CODEC_CAP_DR1, .long_name = NULL_IF_CONFIG_SMALL("AVS (Audio Video Standard) video"), }; -- cgit v1.2.3