]> git.sesse.net Git - ffmpeg/blobdiff - libavformat/asfdec.c
Merge commit '593d2326ef985cdffe413df629419938f7b07c4c'
[ffmpeg] / libavformat / asfdec.c
index 03f4b20164be7581942a9e81f49cbe4c1dcfa22b..7b4a0a5c473586527b9788639f6b473f542f2b10 100644 (file)
@@ -372,7 +372,8 @@ static int asf_read_stream_properties(AVFormatContext *s, int64_t size)
 
     if (!(asf->hdr.flags & 0x01)) { // if we aren't streaming...
         int64_t fsize = avio_size(pb);
-        if (fsize <= 0 || (int64_t)asf->hdr.file_size <= 0 || FFABS(fsize - (int64_t)asf->hdr.file_size) < 10000)
+        if (fsize <= 0 || (int64_t)asf->hdr.file_size <= 0 ||
+            FFABS(fsize - (int64_t)asf->hdr.file_size) / (float)FFMIN(fsize, asf->hdr.file_size) < 0.05)
             st->duration = asf->hdr.play_time /
                        (10000000 / 1000) - start_time;
     }