[FFmpeg-cvslog] encode_video2: shrink packet after encoding.

Nicolas George git at videolan.org
Wed Feb 29 18:06:54 CET 2012


ffmpeg | branch: master | Nicolas George <nicolas.george at normalesup.org> | Wed Feb 29 14:39:50 2012 +0100| [33b9fe562a307629d8db61edcf729c4cb8f78413] | committer: Nicolas George

encode_video2: shrink packet after encoding.

With the encode2 API, encoders allocate huge packets to be
sure they have enough room (a typical case is mpeg4, which
allocs ~10M for 1280x768 yuv420p) but only actually use a
very small part of the buffer.

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

 libavcodec/utils.c |    7 +++++++
 1 files changed, 7 insertions(+), 0 deletions(-)

diff --git a/libavcodec/utils.c b/libavcodec/utils.c
index 63f7fae..99e36f8 100644
--- a/libavcodec/utils.c
+++ b/libavcodec/utils.c
@@ -1198,6 +1198,7 @@ int attribute_align_arg avcodec_encode_video2(AVCodecContext *avctx,
 {
     int ret;
     int user_packet = !!avpkt->data;
+    void *new_data;
 
     *got_packet_ptr = 0;
 
@@ -1218,6 +1219,12 @@ int attribute_align_arg avcodec_encode_video2(AVCodecContext *avctx,
             avpkt->size = 0;
         else if (!(avctx->codec->capabilities & CODEC_CAP_DELAY))
             avpkt->pts = avpkt->dts = frame->pts;
+        if (avpkt->data) {
+            new_data = av_realloc(avpkt->data,
+                                  avpkt->size + FF_INPUT_BUFFER_PADDING_SIZE);
+            if (new_data)
+                avpkt->data = new_data;
+        }
 
         avctx->frame_number++;
     }



More information about the ffmpeg-cvslog mailing list