[FFmpeg-devel] [PATCH] Only do 1 malloc instead of 3 and check for failure.
Reimar Döffinger
Reimar.Doeffinger at gmx.de
Sat Oct 29 13:40:55 CEST 2011
Signed-off-by: Reimar Döffinger <Reimar.Doeffinger at gmx.de>
---
libavcodec/proresenc.c | 12 ++++++------
1 files changed, 6 insertions(+), 6 deletions(-)
diff --git a/libavcodec/proresenc.c b/libavcodec/proresenc.c
index 7940343..e95287a 100644
--- a/libavcodec/proresenc.c
+++ b/libavcodec/proresenc.c
@@ -545,9 +545,11 @@ static av_cold int prores_encode_init(AVCodecContext *avctx)
}
if ((avctx->height & 0xf) || (avctx->width & 0xf)) {
- ctx->fill_y = av_malloc(DEFAULT_SLICE_MB_WIDTH << 9);
- ctx->fill_u = av_malloc(DEFAULT_SLICE_MB_WIDTH << 8);
- ctx->fill_v = av_malloc(DEFAULT_SLICE_MB_WIDTH << 8);
+ ctx->fill_y = av_malloc(4 * (DEFAULT_SLICE_MB_WIDTH << 8));
+ if (!ctx->fill_y)
+ return AVERROR(ENOMEM);
+ ctx->fill_u = ctx->fill_y + (DEFAULT_SLICE_MB_WIDTH << 9);
+ ctx->fill_v = ctx->fill_u + (DEFAULT_SLICE_MB_WIDTH << 8);
}
if (avctx->profile == FF_PROFILE_UNKNOWN) {
@@ -583,9 +585,7 @@ static av_cold int prores_encode_close(AVCodecContext *avctx)
{
ProresContext* ctx = avctx->priv_data;
av_freep(&avctx->coded_frame);
- av_free(ctx->fill_y);
- av_free(ctx->fill_u);
- av_free(ctx->fill_v);
+ av_freep(&ctx->fill_y);
return 0;
}
--
1.7.7.1
More information about the ffmpeg-devel
mailing list