asfdec: fix parsing of packets that overrun into padding.
authorRonald S. Bultje <rbultje@google.com>
Wed, 27 Apr 2011 22:42:16 +0000 (15:42 -0700)
committerRonald S. Bultje <rsbultje@gmail.com>
Wed, 4 May 2011 02:14:04 +0000 (22:14 -0400)
Signed-off-by: Ronald S. Bultje <rsbultje@gmail.com>
libavformat/asfdec.c

index 8e10d68..637ceed 100644 (file)
@@ -853,8 +853,14 @@ static int asf_read_frame_header(AVFormatContext *s, AVIOContext *pb){
     if (asf->packet_flags & 0x01) {
         DO_2BITS(asf->packet_segsizetype >> 6, asf->packet_frag_size, 0); // 0 is illegal
         if(asf->packet_frag_size > asf->packet_size_left - rsize){
-            av_log(s, AV_LOG_ERROR, "packet_frag_size is invalid\n");
-            return -1;
+            if (asf->packet_frag_size > asf->packet_size_left - rsize + asf->packet_padsize) {
+                av_log(s, AV_LOG_ERROR, "packet_frag_size is invalid (%d-%d)\n", asf->packet_size_left, rsize);
+                return -1;
+            } else {
+                int diff = asf->packet_frag_size - (asf->packet_size_left - rsize);
+                asf->packet_size_left += diff;
+                asf->packet_padsize   -= diff;
+            }
         }
         //printf("Fragsize %d\n", asf->packet_frag_size);
     } else {