]> git.sesse.net Git - ffmpeg/commitdiff
xxan: fix invalid memory access in xan_decode_frame_type0()
authorAnton Khirnov <anton@khirnov.net>
Wed, 6 Mar 2013 08:06:16 +0000 (09:06 +0100)
committerAnton Khirnov <anton@khirnov.net>
Fri, 8 Mar 2013 07:11:22 +0000 (08:11 +0100)
The loop a few lines below the xan_unpack() call accesses up to
dec_size * 2 bytes into y_buffer, so dec_size must be limited to
buffer_size / 2.

CC:libav-stable@libav.org

libavcodec/xxan.c

index 47ab54a7f90ed56cb6e2ac410913dd094f339e62..2bc9ff697b6905da57cb22a91349d4f27460e043 100644 (file)
@@ -308,7 +308,7 @@ static int xan_decode_frame_type0(AVCodecContext *avctx)
         int dec_size;
 
         bytestream2_seek(&s->gb, 8 + corr_off, SEEK_SET);
-        dec_size = xan_unpack(s, s->scratch_buffer, s->buffer_size);
+        dec_size = xan_unpack(s, s->scratch_buffer, s->buffer_size / 2);
         if (dec_size < 0)
             dec_size = 0;
         for (i = 0; i < dec_size; i++)