[FFmpeg-cvslog] Detect NI-avi at playtime like mplayer.
Michael Niedermayer
git at videolan.org
Wed Aug 3 19:22:24 CEST 2011
ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Wed Aug 3 17:44:50 2011 +0200| [46eaaad8dd12eb6c962bc0f1d528afff933dc872] | committer: Michael Niedermayer
Detect NI-avi at playtime like mplayer.
Fixes Ticket333
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=46eaaad8dd12eb6c962bc0f1d528afff933dc872
---
libavformat/avidec.c | 12 ++++++++++++
1 files changed, 12 insertions(+), 0 deletions(-)
diff --git a/libavformat/avidec.c b/libavformat/avidec.c
index 2814b89..5dac749 100644
--- a/libavformat/avidec.c
+++ b/libavformat/avidec.c
@@ -73,6 +73,7 @@ typedef struct {
int odml_depth;
int use_odml;
#define MAX_ODML_DEPTH 1000
+ int64_t dts_max;
} AVIContext;
@@ -1168,6 +1169,16 @@ resync:
}
ast->seek_pos= 0;
+ if(!avi->non_interleaved && st->nb_index_entries>1){
+ int64_t dts= av_rescale_q(pkt->dts, st->time_base, AV_TIME_BASE_Q);
+
+ if(avi->dts_max - dts > 2*AV_TIME_BASE){
+ avi->non_interleaved= 1;
+ av_log(s, AV_LOG_INFO, "Switching to NI mode, due to poor interleaving\n");
+ }else if(avi->dts_max < dts)
+ avi->dts_max = dts;
+ }
+
return size;
}
@@ -1407,6 +1418,7 @@ static int avi_read_seek(AVFormatContext *s, int stream_index, int64_t timestamp
/* do the seek */
avio_seek(s->pb, pos_min, SEEK_SET);
avi->stream_index= -1;
+ avi->dts_max= INT_MIN;
return 0;
}
More information about the ffmpeg-cvslog
mailing list