diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2014-03-11 19:04:45 +0100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-03-11 19:20:47 +0100 |
commit | 01000064c9518f76bc97b72e81aa34788d88534f (patch) | |
tree | 6f09eb895fb8648cb36599810ab9814f3b739a1c /libavformat/avidec.c | |
parent | 52b6db848d41ee811b9368a3df8918f7310bed31 (diff) | |
download | ffmpeg-01000064c9518f76bc97b72e81aa34788d88534f.tar.gz |
avidec: calculate missing bitrates from index
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavformat/avidec.c')
-rw-r--r-- | libavformat/avidec.c | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/libavformat/avidec.c b/libavformat/avidec.c index f79b0dfb6d..d44f59f2b6 100644 --- a/libavformat/avidec.c +++ b/libavformat/avidec.c @@ -379,6 +379,46 @@ static void avi_read_nikon(AVFormatContext *s, uint64_t end) } } +static int calculate_bitrate(AVFormatContext *s) +{ + AVIContext *avi = s->priv_data; + int i, j; + int64_t lensum = 0; + int64_t maxpos = 0; + + for (i = 0; i<s->nb_streams; i++) { + int64_t len = 0; + AVStream *st = s->streams[i]; + + if (!st->nb_index_entries) + continue; + + for (j = 0; j < st->nb_index_entries; j++) + len += st->index_entries[j].size; + maxpos = FFMAX(maxpos, st->index_entries[j-1].pos); + lensum += len; + } + if (maxpos < avi->io_fsize*9/10) // index doesnt cover the whole file + return 0; + if (lensum*9/10 > maxpos || lensum < maxpos*9/10) // frame sum and filesize mismatch + return 0; + + for (i = 0; i<s->nb_streams; i++) { + int64_t len = 0; + AVStream *st = s->streams[i]; + int64_t duration; + + for (j = 0; j < st->nb_index_entries; j++) + len += st->index_entries[j].size; + + if (st->nb_index_entries < 2 || st->codec->bit_rate > 0) + continue; + duration = st->index_entries[j-1].timestamp - st->index_entries[0].timestamp; + st->codec->bit_rate = av_rescale(8*len, st->time_base.den, duration * st->time_base.num); + } + return 1; +} + static int avi_read_header(AVFormatContext *s) { AVIContext *avi = s->priv_data; @@ -863,6 +903,7 @@ fail: if (!avi->index_loaded && pb->seekable) avi_load_index(s); + calculate_bitrate(s); avi->index_loaded |= 1; avi->non_interleaved |= guess_ni_flag(s) | (s->flags & AVFMT_FLAG_SORT_DTS); |