From 610efb67739f850d7d08779f55661e15bc6f6722 Mon Sep 17 00:00:00 2001 From: Michael Niedermayer Date: Sun, 30 Sep 2012 21:52:59 +0200 Subject: [PATCH] qt-faststart: dont allocate a bigger buffer than needed Signed-off-by: Michael Niedermayer --- tools/qt-faststart.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/tools/qt-faststart.c b/tools/qt-faststart.c index bfa6f1a489..b1917f18ef 100644 --- a/tools/qt-faststart.c +++ b/tools/qt-faststart.c @@ -37,6 +37,8 @@ #define ftello(x) _ftelli64(x) #endif +#define FFMIN(a,b) ((a) > (b) ? (b) : (a)) + #define BE_16(x) ((((uint8_t*)(x))[0] << 8) | ((uint8_t*)(x))[1]) #define BE_32(x) ((((uint8_t*)(x))[0] << 24) | \ @@ -293,9 +295,10 @@ int main(int argc, char *argv[]) } /* copy the remainder of the infile, from offset 0 -> last_offset - 1 */ - copy_buffer = malloc(COPY_BUFFER_SIZE); + bytes_to_copy = FFMIN(COPY_BUFFER_SIZE, last_offset); + copy_buffer = malloc(bytes_to_copy); if (!copy_buffer) { - printf("could not allocate %"PRIu64" bytes for copy_buffer\n", COPY_BUFFER_SIZE); + printf("could not allocate %"PRIu64" bytes for copy_buffer\n", bytes_to_copy); goto error_out; } printf(" copying rest of file...\n");