[FFmpeg-cvslog] Do not leak extradata when encoding avui.

Carl Eugen Hoyos git at videolan.org
Wed May 23 16:49:11 CEST 2012


ffmpeg | branch: master | Carl Eugen Hoyos <cehoyos at ag.or.at> | Wed May 23 16:48:40 2012 +0200| [5e268633d17ccfe99955af95f5b60fc4f983a7b2] | committer: Carl Eugen Hoyos

Do not leak extradata when encoding avui.

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=5e268633d17ccfe99955af95f5b60fc4f983a7b2
---

 libavcodec/avuienc.c |   19 +++++++++++--------
 1 file changed, 11 insertions(+), 8 deletions(-)

diff --git a/libavcodec/avuienc.c b/libavcodec/avuienc.c
index 53688a9..5165073 100644
--- a/libavcodec/avuienc.c
+++ b/libavcodec/avuienc.c
@@ -35,6 +35,16 @@ static av_cold int avui_encode_init(AVCodecContext *avctx)
         av_log(avctx, AV_LOG_ERROR, "Could not allocate frame.\n");
         return AVERROR(ENOMEM);
     }
+    if (!(avctx->extradata = av_mallocz(24 + FF_INPUT_BUFFER_PADDING_SIZE)))
+        return AVERROR(ENOMEM);
+    avctx->extradata_size = 24;
+    memcpy(avctx->extradata, "\0\0\0\x18""APRGAPRG0001", 16);
+    if (avctx->field_order > AV_FIELD_PROGRESSIVE) {
+        avctx->extradata[19] = 2;
+    } else {
+        avctx->extradata[19] = 1;
+    }
+
 
     return 0;
 }
@@ -56,14 +66,7 @@ static int avui_encode_frame(AVCodecContext *avctx, AVPacket *pkt,
     if ((ret = ff_alloc_packet2(avctx, pkt, size)) < 0)
         return ret;
     dst = pkt->data;
-    if (!(avctx->extradata = av_mallocz(24 + FF_INPUT_BUFFER_PADDING_SIZE)))
-        return AVERROR(ENOMEM);
-    avctx->extradata_size = 24;
-    memcpy(avctx->extradata, "\0\0\0\x18""APRGAPRG0001", 16);
-    if (interlaced) {
-        avctx->extradata[19] = 2;
-    } else {
-        avctx->extradata[19] = 1;
+    if (!interlaced) {
         dst += avctx->width * skip;
     }
 



More information about the ffmpeg-cvslog mailing list