From 02fd687bbe15b6a3859532898c5d90bc7fa181d6 Mon Sep 17 00:00:00 2001 From: Carl Eugen Hoyos Date: Mon, 4 Apr 2011 16:43:15 +0200 Subject: [PATCH] Only make buffer smaller in fill_buffer() if read_packet() is set. Fixes a possible invalid free(). --- libavformat/aviobuf.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/libavformat/aviobuf.c b/libavformat/aviobuf.c index 5396eb1635..152869bacd 100644 --- a/libavformat/aviobuf.c +++ b/libavformat/aviobuf.c @@ -556,7 +556,7 @@ static void fill_buffer(AVIOContext *s) } /* make buffer smaller in case it ended up large after probing */ - if (s->buffer_size > max_buffer_size) { + if (s->read_packet && s->buffer_size > max_buffer_size) { ffio_set_buf_size(s, max_buffer_size); s->checksum_ptr = dst = s->buffer;