[SCM] libav/experimental: Check size of "strf" header against size of enclosing "LIST" if there is one.

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sun Jun 30 16:48:31 UTC 2013


The following commit has been merged in the experimental branch:
commit 5a4a4d78396d4195e14fbc4ba6bb3f996edecdf6
Author: Reimar Döffinger <Reimar.Doeffinger at gmx.de>
Date:   Fri Jul 3 11:26:14 2009 +0000

    Check size of "strf" header against size of enclosing "LIST" if there is one.
    
    Originally committed as revision 19332 to svn://svn.ffmpeg.org/ffmpeg/trunk

diff --git a/libavformat/avidec.c b/libavformat/avidec.c
index b3c4177..5b7c8bb 100644
--- a/libavformat/avidec.c
+++ b/libavformat/avidec.c
@@ -252,6 +252,7 @@ static int avi_read_header(AVFormatContext *s, AVFormatParameters *ap)
     AVIStream *ast = NULL;
     int avih_width=0, avih_height=0;
     int amv_file_format=0;
+    uint64_t list_end = 0;
 
     avi->stream_index= -1;
 
@@ -277,6 +278,7 @@ static int avi_read_header(AVFormatContext *s, AVFormatParameters *ap)
 
         switch(tag) {
         case MKTAG('L', 'I', 'S', 'T'):
+            list_end = url_ftell(pb) + size;
             /* Ignored, except at start of video packets. */
             tag1 = get_le32(pb);
 #ifdef DEBUG
@@ -445,6 +447,9 @@ static int avi_read_header(AVFormatContext *s, AVFormatParameters *ap)
             if (stream_index >= (unsigned)s->nb_streams || avi->dv_demux) {
                 url_fskip(pb, size);
             } else {
+                uint64_t cur_pos = url_ftell(pb);
+                if (cur_pos < list_end)
+                    size = FFMIN(size, list_end - cur_pos);
                 st = s->streams[stream_index];
                 switch(codec_type) {
                 case CODEC_TYPE_VIDEO:

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list