[FFmpeg-cvslog] mux/chunked interleaver: better align duration chunks.
Michael Niedermayer
git at videolan.org
Thu Jan 17 15:17:12 CET 2013
ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Wed Jan 16 00:03:36 2013 +0100| [46730e7a0c1a934be05def268b992239b94269c3] | committer: Michael Niedermayer
mux/chunked interleaver: better align duration chunks.
This code causes the chunking to tend toward more optimal
alignment between streams.
The first chunks can still be less optimal aligned
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=46730e7a0c1a934be05def268b992239b94269c3
---
libavformat/mux.c | 10 ++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/libavformat/mux.c b/libavformat/mux.c
index ccb1530..98ec7a4 100644
--- a/libavformat/mux.c
+++ b/libavformat/mux.c
@@ -555,9 +555,15 @@ int ff_interleave_add_packet(AVFormatContext *s, AVPacket *pkt,
st->interleaver_chunk_duration += pkt->duration;
if ( (s->max_chunk_size && st->interleaver_chunk_size > s->max_chunk_size)
|| (max && st->interleaver_chunk_duration > max)) {
- st->interleaver_chunk_size =
- st->interleaver_chunk_duration = 0;
+ st->interleaver_chunk_size = 0;
this_pktl->pkt.flags |= CHUNK_START;
+ if (max && st->interleaver_chunk_duration > max) {
+ int64_t syncoffset = (st->codec->codec_type == AVMEDIA_TYPE_VIDEO)*max/2;
+ int64_t syncto = av_rescale(pkt->dts + syncoffset, 1, max)*max - syncoffset;
+
+ st->interleaver_chunk_duration += (pkt->dts - syncto)/8 - max;
+ } else
+ st->interleaver_chunk_duration = 0;
}
}
if (*next_point) {
More information about the ffmpeg-cvslog
mailing list