[FFmpeg-cvslog] wmv1: check that the input buffer is large enough

Michael Niedermayer git at videolan.org
Sat Jun 9 22:02:20 CEST 2012


ffmpeg | branch: release/0.5 | Michael Niedermayer <michaelni at gmx.at> | Fri Jun  1 21:42:29 2012 +0200| [48ef11663164b5e7221089a813e733dc7a0776b3] | committer: Michael Niedermayer

wmv1: check that the input buffer is large enough

Fixes null ptr deref
Fixes Ticket1367

Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
(cherry picked from commit f23a2418fb0ccc56fdae4dbf83a5994cc917c475)

Signed-off-by: Michael Niedermayer <michaelni at gmx.at>

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

 libavcodec/wnv1.c |    5 +++++
 1 file changed, 5 insertions(+)

diff --git a/libavcodec/wnv1.c b/libavcodec/wnv1.c
index 7c0105f..aa284da 100644
--- a/libavcodec/wnv1.c
+++ b/libavcodec/wnv1.c
@@ -67,6 +67,11 @@ static int decode_frame(AVCodecContext *avctx,
     int prev_y = 0, prev_u = 0, prev_v = 0;
     uint8_t *rbuf;
 
+    if(buf_size<=8) {
+        av_log(avctx, AV_LOG_ERROR, "buf_size %d is too small\n", buf_size);
+        return AVERROR_INVALIDDATA;
+    }
+
     rbuf = av_malloc(buf_size + FF_INPUT_BUFFER_PADDING_SIZE);
     if(!rbuf){
         av_log(avctx, AV_LOG_ERROR, "Cannot allocate temporary buffer\n");



More information about the ffmpeg-cvslog mailing list