From 04a5eaa1a5b36c025a609f56eb33437772f5f765 Mon Sep 17 00:00:00 2001
From: "Paul B. Mahol" <onemda@gmail.com>
Date: Tue, 6 Dec 2011 04:14:55 +0000
Subject: [PATCH] cljr: release picture at end of decoding

Otherwise after transcoding from cljr we get: Found 1 unreleased buffers!

Signed-off-by: Janne Grunau <janne-libav@jannau.net>
---
 libavcodec/cljr.c | 8 ++++++++
 1 file changed, 8 insertions(+)

diff --git a/libavcodec/cljr.c b/libavcodec/cljr.c
index e8d818aa784..6c7d7b0feee 100644
--- a/libavcodec/cljr.c
+++ b/libavcodec/cljr.c
@@ -129,6 +129,13 @@ static av_cold int decode_init(AVCodecContext *avctx){
     return 0;
 }
 
+static av_cold int decode_end(AVCodecContext *avctx) {
+    CLJRContext *a = avctx->priv_data;
+
+    if (a->picture.data[0]);
+        avctx->release_buffer(avctx, &a->picture);
+}
+
 #if CONFIG_CLJR_ENCODER
 static av_cold int encode_init(AVCodecContext *avctx){
 
@@ -144,6 +151,7 @@ AVCodec ff_cljr_decoder = {
     .id             = CODEC_ID_CLJR,
     .priv_data_size = sizeof(CLJRContext),
     .init           = decode_init,
+    .close          = decode_end,
     .decode         = decode_frame,
     .capabilities   = CODEC_CAP_DR1,
     .long_name = NULL_IF_CONFIG_SMALL("Cirrus Logic AccuPak"),
-- 
GitLab