summaryrefslogtreecommitdiffstats
path: root/libmpdemux
diff options
context:
space:
mode:
authorreimar <reimar@b3059339-0415-0410-9bf9-f77b7e298cf2>2009-01-01 11:39:47 +0000
committerreimar <reimar@b3059339-0415-0410-9bf9-f77b7e298cf2>2009-01-01 11:39:47 +0000
commit12b1fea30f9629b7a05e5a85d7dc7aff8989f0d4 (patch)
tree57a9a68196ec6e66860decbb677f5256d5dd472b /libmpdemux
parent2641f962467dde8af5b972eadb078b0a353099fc (diff)
downloadmpv-12b1fea30f9629b7a05e5a85d7dc7aff8989f0d4.tar.bz2
mpv-12b1fea30f9629b7a05e5a85d7dc7aff8989f0d4.tar.xz
Make AVI demuxer more resilient against broken or incomplete files.
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@28224 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpdemux')
-rw-r--r--libmpdemux/demux_avi.c19
1 files changed, 17 insertions, 2 deletions
diff --git a/libmpdemux/demux_avi.c b/libmpdemux/demux_avi.c
index 87e4a4aa9d..fa1fc91e48 100644
--- a/libmpdemux/demux_avi.c
+++ b/libmpdemux/demux_avi.c
@@ -158,6 +158,9 @@ static int demux_avi_read_packet(demuxer_t *demux,demux_stream_t *ds,unsigned in
ds_read_packet(ds,demux->stream,len,pts,idxpos,flags);
skip-=len;
}
+ skip = FFMAX(skip, 0);
+ if (avi_stream_id(id) > 99 && id != mmioFOURCC('J','U','N','K'))
+ skip = FFMIN(skip, 65536);
if(skip){
mp_dbg(MSGT_DEMUX,MSGL_DBG2,"DEMUX_AVI: Skipping %d bytes from packet %04X\n",skip,id);
stream_skip(demux->stream,skip);
@@ -165,6 +168,18 @@ static int demux_avi_read_packet(demuxer_t *demux,demux_stream_t *ds,unsigned in
return ds?1:0;
}
+static uint32_t avi_find_id(stream_t *stream) {
+ uint32_t id = stream_read_dword_le(stream);
+ if (!id) {
+ mp_msg(MSGT_DEMUX, MSGL_WARN, "Incomplete stream? Trying resync.\n");
+ do {
+ id = stream_read_dword_le(stream);
+ if (stream_eof(stream)) return 0;
+ } while (avi_stream_id(id) > 99);
+ }
+ return id;
+}
+
// return value:
// 0 = EOF or no stream found
// 1 = successfully read a packet
@@ -222,7 +237,7 @@ do{
demux->stream->eof=1;
return 0;
}
- id=stream_read_dword_le(demux->stream);
+ id=avi_find_id(demux->stream);
len=stream_read_dword_le(demux->stream);
if(stream_eof(demux->stream)) return 0; // EOF!
@@ -347,7 +362,7 @@ do{
return 0;
}
- id=stream_read_dword_le(demux->stream);
+ id=avi_find_id(demux->stream);
len=stream_read_dword_le(demux->stream);
if(stream_eof(demux->stream)) return 0;