From e283ac5c3cf941372fca5369fe1c8ff91700a0ba Mon Sep 17 00:00:00 2001 From: arpi Date: Sun, 4 Aug 2002 01:48:35 +0000 Subject: [PATCH] detection of badly interleaved avi files and auto-switch to -ni git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@6885 b3059339-0415-0410-9bf9-f77b7e298cf2 --- libmpdemux/demux_avi.c | 44 ++++++++++++++++++++++++++++++++---------- 1 file changed, 34 insertions(+), 10 deletions(-) diff --git a/libmpdemux/demux_avi.c b/libmpdemux/demux_avi.c index 1796f5b493..c375011b92 100644 --- a/libmpdemux/demux_avi.c +++ b/libmpdemux/demux_avi.c @@ -76,11 +76,11 @@ static int choose_chunk_len(unsigned int len1,unsigned int len2){ return (len1priv; int skip; float pts=0; - demux_stream_t *ds=demux_avi_select_stream(demux,id); +// demux_stream_t *ds=demux_avi_select_stream(demux,id); mp_dbg(MSGT_DEMUX,MSGL_DBG3,"demux_avi.read_packet: %X\n",id); @@ -161,8 +161,9 @@ int demux_avi_fill_buffer(demuxer_t *demux){ avi_priv_t *priv=demux->priv; unsigned int id=0; unsigned int len; -int max_packs=128; +//int max_packs=128; int ret=0; +demux_stream_t *ds; do{ int flags=0; @@ -242,7 +243,27 @@ do{ continue; } } - ret=demux_avi_read_packet(demux,id,len,priv->idx_pos-1,flags); + + ds=demux_avi_select_stream(demux,id); + if(ds) + if(ds->packs+1>=MAX_PACKS || ds->bytes+len>=MAX_PACK_BYTES){ + // this packet will cause a buffer overflow, switch to -ni mode!!! + mp_msg(MSGT_DEMUX,MSGL_WARN,MSGTR_SwitchToNi); + if(priv->idx_size>0){ + // has index + demux->type=DEMUXER_TYPE_AVI_NI; + --priv->idx_pos; // hack + } else { + // no index + demux->type=DEMUXER_TYPE_AVI_NINI; + priv->idx_pos=demux->filepos; // hack + } + priv->idx_pos_v=priv->idx_pos_a=priv->idx_pos; + // quit now, we can't even (no enough buffer memory) read this packet :( + return -1; + } + + ret=demux_avi_read_packet(demux,ds,id,len,priv->idx_pos-1,flags); // if(!ret && priv->skip_video_frames<=0) // if(--max_packs==0){ // demux->stream->eof=1; @@ -261,7 +282,7 @@ int demux_avi_fill_buffer_ni(demuxer_t *demux,demux_stream_t* ds){ avi_priv_t *priv=demux->priv; unsigned int id=0; unsigned int len; -int max_packs=128; +//int max_packs=128; int ret=0; do{ @@ -321,7 +342,7 @@ do{ } if(idx->dwFlags&AVIIF_KEYFRAME) flags=1; } else return 0; - ret=demux_avi_read_packet(demux,id,len,idx_pos,flags); + ret=demux_avi_read_packet(demux,demux_avi_select_stream(demux,id),id,len,idx_pos,flags); // if(!ret && priv->skip_video_frames<=0) // if(--max_packs==0){ // demux->stream->eof=1; @@ -353,27 +374,30 @@ do{ demux->filepos=stream_tell(demux->stream); if(demux->filepos>=demux->movi_end && (demux->movi_end>demux->movi_start)){ - demux->stream->eof=1; + //demux->stream->eof=1; + ds->eof=1; return 0; } - if(stream_eof(demux->stream)) return 0; id=stream_read_dword_le(demux->stream); len=stream_read_dword_le(demux->stream); + + if(stream_eof(demux->stream)) return 0; + if(id==mmioFOURCC('L','I','S','T')){ id=stream_read_dword_le(demux->stream); // list type continue; } if(id==mmioFOURCC('R','I','F','F')){ - printf("additional RIFF header...\n"); + mp_msg(MSGT_DEMUX,MSGL_V,"additional RIFF header...\n"); id=stream_read_dword_le(demux->stream); // "AVIX" continue; } if(ds==demux_avi_select_stream(demux,id)){ // read it! - ret=demux_avi_read_packet(demux,id,len,priv->idx_pos-1,0); + ret=demux_avi_read_packet(demux,ds,id,len,priv->idx_pos-1,0); } else { // skip it! int skip=(len+1)&(~1); // total bytes in this chunk