[FFmpeg-cvslog] avformat/xmv: Discard remainder of packet on error

Michael Niedermayer git at videolan.org
Thu Nov 12 04:07:46 CET 2015


ffmpeg | branch: release/2.7 | Michael Niedermayer <michael at niedermayer.cc> | Fri Nov  6 02:13:36 2015 +0100| [bcedc2b0f0e47edc2670200c91a49b36e4c07257] | committer: Michael Niedermayer

avformat/xmv: Discard remainder of packet on error

Fixes infinite loop
Fixes: 9c48ae2680c5f23bca3d20ff0f325fd8/asan_generic_4c254d_1374_993f1e5967dd6f844b8d72f978ce2a6c.pss

Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind
Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>
(cherry picked from commit 79c4a338e4b2bf0bc6f81c9f455994f673a92f78)

Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=bcedc2b0f0e47edc2670200c91a49b36e4c07257
---

 libavformat/xmv.c |    5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/libavformat/xmv.c b/libavformat/xmv.c
index 06c070c..14d007a 100644
--- a/libavformat/xmv.c
+++ b/libavformat/xmv.c
@@ -554,8 +554,11 @@ static int xmv_read_packet(AVFormatContext *s,
 
         result = xmv_fetch_audio_packet(s, pkt, xmv->current_stream - 1);
     }
-    if (result)
+    if (result) {
+        xmv->current_stream = 0;
+        xmv->video.current_frame = xmv->video.frame_count;
         return result;
+    }
 
 
     /* Increase our counters */



More information about the ffmpeg-cvslog mailing list