aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-03-11 19:04:45 +0100
committerMichael Niedermayer <michaelni@gmx.at>2014-03-11 19:20:47 +0100
commit01000064c9518f76bc97b72e81aa34788d88534f (patch)
tree6f09eb895fb8648cb36599810ab9814f3b739a1c
parent52b6db848d41ee811b9368a3df8918f7310bed31 (diff)
downloadffmpeg-01000064c9518f76bc97b72e81aa34788d88534f.tar.gz
avidec: calculate missing bitrates from index
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--libavformat/avidec.c41
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);