]> git.sesse.net Git - ffmpeg/commitdiff
asfdec: fix reading files larger than 2GB
authorJohn Stebbins <stebbins@jetheaddev.com>
Thu, 23 Feb 2017 23:47:58 +0000 (16:47 -0700)
committerJohn Stebbins <stebbins@jetheaddev.com>
Fri, 24 Feb 2017 18:41:33 +0000 (11:41 -0700)
avio_skip returns file position and overflows int

libavformat/asfdec.c

index 34730b20aa882b38a1b9f58db3d1c7314c141836..9e1f8f6b62aecd7d112dfff06d2ab12782911c7b 100644 (file)
@@ -976,7 +976,8 @@ static int asf_read_simple_index(AVFormatContext *s, const GUIDParseTable *g)
     uint64_t interval; // index entry time interval in 100 ns units, usually it's 1s
     uint32_t pkt_num, nb_entries;
     int32_t prev_pkt_num = -1;
-    int i, ret;
+    int i;
+    int64_t offset;
     uint64_t size = avio_rl64(pb);
 
     // simple index objects should be ordered by stream number, this loop tries to find
@@ -998,10 +999,10 @@ static int asf_read_simple_index(AVFormatContext *s, const GUIDParseTable *g)
     nb_entries = avio_rl32(pb);
     for (i = 0; i < nb_entries; i++) {
         pkt_num = avio_rl32(pb);
-        ret = avio_skip(pb, 2);
-        if (ret < 0) {
+        offset = avio_skip(pb, 2);
+        if (offset < 0) {
             av_log(s, AV_LOG_ERROR, "Skipping failed in asf_read_simple_index.\n");
-            return ret;
+            return offset;
         }
         if (prev_pkt_num != pkt_num) {
             av_add_index_entry(st, asf->first_packet_offset + asf->packet_size *