[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