From 0fbb0185b999169a265e5fac2145483dacd73e74 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Reimar=20D=C3=B6ffinger?= Date: Tue, 13 Oct 2009 18:31:22 +0000 Subject: [PATCH] Call release_buffer on close for v210dec and v210x Originally committed as revision 20228 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavcodec/v210dec.c | 3 +++ libavcodec/v210x.c | 12 +++++++++++- 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/libavcodec/v210dec.c b/libavcodec/v210dec.c index 0d71b5004f..08c954d88e 100644 --- a/libavcodec/v210dec.c +++ b/libavcodec/v210dec.c @@ -114,6 +114,9 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, static av_cold int decode_close(AVCodecContext *avctx) { + AVFrame *pic = avctx->coded_frame; + if (pic->data[0]) + avctx->release_buffer(avctx, pic); av_freep(&avctx->coded_frame); return 0; diff --git a/libavcodec/v210x.c b/libavcodec/v210x.c index 754b70a1f0..fe1b6de30a 100644 --- a/libavcodec/v210x.c +++ b/libavcodec/v210x.c @@ -124,6 +124,16 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, AVPac return avpkt->size; } +static av_cold int decode_close(AVCodecContext *avctx) +{ + AVFrame *pic = avctx->coded_frame; + if (pic->data[0]) + avctx->release_buffer(avctx, pic); + av_freep(&avctx->coded_frame); + + return 0; +} + AVCodec v210x_decoder = { "v210x", CODEC_TYPE_VIDEO, @@ -131,7 +141,7 @@ AVCodec v210x_decoder = { 0, decode_init, NULL, - NULL, + decode_close, decode_frame, CODEC_CAP_DR1, };