[FFmpeg-cvslog] avcodec_encode_{audio, video}: only reallocate output packet when it has non-zero size.
Anton Khirnov
git at videolan.org
Thu Mar 29 04:32:33 CEST 2012
ffmpeg | branch: master | Anton Khirnov <anton at khirnov.net> | Tue Mar 27 08:21:02 2012 +0200| [3c6607eb6f946ed3e108db3f0694cab7e5a5df7e] | committer: Anton Khirnov
avcodec_encode_{audio,video}: only reallocate output packet when it has non-zero size.
Otherwise realloc would free it, which would result in double free
later.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=3c6607eb6f946ed3e108db3f0694cab7e5a5df7e
---
libavcodec/utils.c | 4 ++--
1 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/libavcodec/utils.c b/libavcodec/utils.c
index 7d50bd5..aa0f5b6 100644
--- a/libavcodec/utils.c
+++ b/libavcodec/utils.c
@@ -960,7 +960,7 @@ int attribute_align_arg avcodec_encode_audio2(AVCodecContext *avctx,
avctx->frame_size = fs_tmp;
}
if (!ret) {
- if (!user_packet && avpkt->data) {
+ if (!user_packet && avpkt->size) {
uint8_t *new_data = av_realloc(avpkt->data, avpkt->size);
if (new_data)
avpkt->data = new_data;
@@ -1123,7 +1123,7 @@ int attribute_align_arg avcodec_encode_video2(AVCodecContext *avctx,
else if (!(avctx->codec->capabilities & CODEC_CAP_DELAY))
avpkt->pts = avpkt->dts = frame->pts;
- if (!user_packet && avpkt->data) {
+ if (!user_packet && avpkt->size) {
uint8_t *new_data = av_realloc(avpkt->data, avpkt->size);
if (new_data)
avpkt->data = new_data;
More information about the ffmpeg-cvslog
mailing list