2017-11-28 21:32 GMT+01:00 Michael Niedermayer <mich...@niedermayer.cc>: > On Mon, Nov 27, 2017 at 05:24:14AM +0100, Carl Eugen Hoyos wrote: >> Hi! >> >> Attached patch avoids allocations >1GB for (short and) invalid mov >> files with only reasonable speed impact. >> >> Please review, Carl Eugen > >> mov.c | 16 +++++++++++++--- >> 1 file changed, 13 insertions(+), 3 deletions(-) >> 980861e4c47c80c850d4e849043df2510a3d1d32 >> 0001-lavf-mov-Do-not-blindly-allocate-huge-memory-blocks-.patch >> From 0d243bad5fdd9850ff41d49a32a06274a3cd9756 Mon Sep 17 00:00:00 2001 >> From: Carl Eugen Hoyos <ceffm...@gmail.com> >> Date: Mon, 27 Nov 2017 05:13:25 +0100 >> Subject: [PATCH] lavf/mov: Do not blindly allocate huge memory blocks for >> stts entries. >> >> Fixes large allocations for short files with invalid stts entry. >> Fixes bugzilla 1102. >> --- >> libavformat/mov.c | 16 +++++++++++++--- >> 1 file changed, 13 insertions(+), 3 deletions(-) >> >> diff --git a/libavformat/mov.c b/libavformat/mov.c >> index ddb1e59..9d353bf 100644 >> --- a/libavformat/mov.c >> +++ b/libavformat/mov.c >> @@ -2838,14 +2838,24 @@ static int mov_read_stts(MOVContext *c, AVIOContext >> *pb, MOVAtom atom) >> if (sc->stts_data) >> av_log(c->fc, AV_LOG_WARNING, "Duplicated STTS atom\n"); >> av_free(sc->stts_data); >> - sc->stts_count = 0; >> - sc->stts_data = av_malloc_array(entries, sizeof(*sc->stts_data)); >> + sc->stts_count = FFMIN(1024 * 1024, entries); >> + sc->stts_data = av_realloc_array(NULL, sc->stts_count, >> sizeof(*sc->stts_data)); >> if (!sc->stts_data) >> return AVERROR(ENOMEM); > > i dont know if leaving stts_count random on return is a good idea
Fixed. >> for (i = 0; i < entries && !pb->eof_reached; i++) { >> - int sample_duration; >> + int sample_duration, ret; >> unsigned int sample_count; >> + if (i > sc->stts_count) { >> + ret = av_reallocp_array(&sc->stts_data, >> + FFMIN(sc->stts_count * 2LL, entries), >> + sizeof(*sc->stts_data)); > > this should use a variant of av_fast_realloc New patch attached, only tested with fate. Thank you, Carl Eugen
From 85620d03b313f5a684a5e9c06e445180601592f5 Mon Sep 17 00:00:00 2001 From: Carl Eugen Hoyos <ceffm...@gmail.com> Date: Fri, 29 Dec 2017 02:08:48 +0100 Subject: [PATCH] lavf/mov: Do not blindly allocate huge memory blocks for stts entries. Fixes large allocations for short files with invalid stts entry. Fixes bugzilla 1102. --- libavformat/mov.c | 23 +++++++++++++++++++---- 1 file changed, 19 insertions(+), 4 deletions(-) diff --git a/libavformat/mov.c b/libavformat/mov.c index 2064473..df7a40f 100644 --- a/libavformat/mov.c +++ b/libavformat/mov.c @@ -2849,14 +2849,29 @@ static int mov_read_stts(MOVContext *c, AVIOContext *pb, MOVAtom atom) if (sc->stts_data) av_log(c->fc, AV_LOG_WARNING, "Duplicated STTS atom\n"); av_free(sc->stts_data); - sc->stts_count = 0; - sc->stts_data = av_malloc_array(entries, sizeof(*sc->stts_data)); - if (!sc->stts_data) + if (INT_MAX / sizeof(*sc->stts_data) <= entries) return AVERROR(ENOMEM); + sc->stts_count = FFMIN(1024 * 1024, entries); + sc->stts_data = av_realloc_array(NULL, sc->stts_count, sizeof(*sc->stts_data)); + if (!sc->stts_data) { + sc->stts_count = 0; + return AVERROR(ENOMEM); + } for (i = 0; i < entries && !pb->eof_reached; i++) { int sample_duration; - unsigned int sample_count; + unsigned int sample_count, alloc_size = sc->stts_count * sizeof(*sc->stts_data); + if (i > sc->stts_count) { + MOVStts *stts_data = av_fast_realloc(sc->stts_data, &alloc_size, + FFMIN(sc->stts_count * 2LL, entries) * sizeof(*sc->stts_data)); + if (!stts_data) { + av_freep(&sc->stts_data); + sc->stts_count = 0; + return AVERROR(ENOMEM); + } + sc->stts_count = FFMIN(sc->stts_count * 2, entries); + sc->stts_data = stts_data; + } sample_count=avio_rb32(pb); sample_duration = avio_rb32(pb); -- 1.7.10.4
_______________________________________________ ffmpeg-devel mailing list ffmpeg-devel@ffmpeg.org http://ffmpeg.org/mailman/listinfo/ffmpeg-devel