diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2015-03-19 12:18:02 +0100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2015-03-19 12:18:05 +0100 |
commit | 09585e377c71bb1a153717350011e062ae089385 (patch) | |
tree | aa5ff2bcc61736507944b0ff8545a33fb4a737d4 /libavformat/dashenc.c | |
parent | 76fef5cd27861ec3b574a06e8be6ea03bcdde7a5 (diff) | |
parent | 3041183677bda0a431b36e96a2c76617abaa8183 (diff) | |
download | ffmpeg-09585e377c71bb1a153717350011e062ae089385.tar.gz |
Merge commit '3041183677bda0a431b36e96a2c76617abaa8183'
* commit '3041183677bda0a431b36e96a2c76617abaa8183':
dashenc: Heuristically fill in the duration of packets that need it
Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavformat/dashenc.c')
-rw-r--r-- | libavformat/dashenc.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/libavformat/dashenc.c b/libavformat/dashenc.c index 92b7d6c773..cc88676170 100644 --- a/libavformat/dashenc.c +++ b/libavformat/dashenc.c @@ -69,6 +69,7 @@ typedef struct OutputStream { int nb_segments, segments_size, segment_index; Segment **segments; int64_t first_pts, start_pts, max_pts; + int64_t last_dts; int bit_rate; char bandwidth_str[64]; @@ -654,6 +655,7 @@ static int dash_write_header(AVFormatContext *s) set_codec_str(s, st->codec, os->codec_str, sizeof(os->codec_str)); os->first_pts = AV_NOPTS_VALUE; os->max_pts = AV_NOPTS_VALUE; + os->last_dts = AV_NOPTS_VALUE; os->segment_index = 1; } @@ -866,6 +868,16 @@ static int dash_write_packet(AVFormatContext *s, AVPacket *pkt) if (ret < 0) return ret; + // Fill in a heuristic guess of the packet duration, if none is available. + // The mp4 muxer will do something similar (for the last packet in a fragment) + // if nothing is set (setting it for the other packets doesn't hurt). + // By setting a nonzero duration here, we can be sure that the mp4 muxer won't + // invoke its heuristic (this doesn't have to be identical to that algorithm), + // so that we know the exact timestamps of fragments. + if (!pkt->duration && os->last_dts != AV_NOPTS_VALUE) + pkt->duration = pkt->dts - os->last_dts; + os->last_dts = pkt->dts; + // If forcing the stream to start at 0, the mp4 muxer will set the start // timestamps to 0. Do the same here, to avoid mismatches in duration/timestamps. if (os->first_pts == AV_NOPTS_VALUE && |