[FFmpeg-cvslog] parser: fix large overreads

Michael Niedermayer git at videolan.org
Sat Dec 8 15:07:09 CET 2012


ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Wed Oct  3 16:06:23 2012 +0200| [096abfa15052977eed93f0b5e01afd2d47c53c1f] | committer: Justin Ruggles

parser: fix large overreads

Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
Signed-off-by: Justin Ruggles <justin.ruggles at gmail.com>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=096abfa15052977eed93f0b5e01afd2d47c53c1f
---

 libavcodec/parser.c |    4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/libavcodec/parser.c b/libavcodec/parser.c
index 7ace766..0767a34 100644
--- a/libavcodec/parser.c
+++ b/libavcodec/parser.c
@@ -254,7 +254,9 @@ int ff_combine_frame(ParseContext *pc, int next, const uint8_t **buf, int *buf_s
         if(!new_buffer)
             return AVERROR(ENOMEM);
         pc->buffer = new_buffer;
-        memcpy(&pc->buffer[pc->index], *buf, next + FF_INPUT_BUFFER_PADDING_SIZE );
+        if (next > -FF_INPUT_BUFFER_PADDING_SIZE)
+            memcpy(&pc->buffer[pc->index], *buf,
+                   next + FF_INPUT_BUFFER_PADDING_SIZE);
         pc->index = 0;
         *buf= pc->buffer;
     }



More information about the ffmpeg-cvslog mailing list