aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-11-24 14:07:01 +0100
committerMichael Niedermayer <michaelni@gmx.at>2014-11-24 14:07:35 +0100
commit9a57309665225537fd86f53fa65ee826c215ad66 (patch)
tree4ff36436eb431c67ee7331df1fd5201b5d27f260 /libavformat
parent7a19a8fb696f700bee96c983b825f80f3b3a82f6 (diff)
parentfe42f94ce1023f9c2f7e86404c60afcee5b078a9 (diff)
downloadffmpeg-9a57309665225537fd86f53fa65ee826c215ad66.tar.gz
Merge commit 'fe42f94ce1023f9c2f7e86404c60afcee5b078a9'
* commit 'fe42f94ce1023f9c2f7e86404c60afcee5b078a9': dashenc: Don't segment all video streams when one stream gets a keyframe Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavformat')
-rw-r--r--libavformat/dashenc.c25
1 files changed, 19 insertions, 6 deletions
diff --git a/libavformat/dashenc.c b/libavformat/dashenc.c
index 8bf507728f..b840db909e 100644
--- a/libavformat/dashenc.c
+++ b/libavformat/dashenc.c
@@ -75,7 +75,6 @@ typedef struct DASHContext {
int single_file;
OutputStream *streams;
int has_video, has_audio;
- int nb_segments;
int last_duration;
int total_duration;
char availability_start_time[100];
@@ -598,10 +597,13 @@ static void find_index_range(AVFormatContext *s, const char *dirname,
*index_length = AV_RB32(&buf[0]);
}
-static int dash_flush(AVFormatContext *s, int final)
+static int dash_flush(AVFormatContext *s, int final, int stream)
{
DASHContext *c = s->priv_data;
int i, ret = 0;
+ int cur_flush_segment_index = 0;
+ if (stream >= 0)
+ cur_flush_segment_index = c->streams[stream].segment_index;
for (i = 0; i < s->nb_streams; i++) {
OutputStream *os = &c->streams[i];
@@ -612,6 +614,18 @@ static int dash_flush(AVFormatContext *s, int final)
if (!os->packets_written)
continue;
+ // Flush the single stream that got a keyframe right now.
+ // Flush all audio streams as well, in sync with video keyframes,
+ // but not the other video streams.
+ if (stream >= 0 && i != stream) {
+ if (s->streams[i]->codec->codec_type != AVMEDIA_TYPE_AUDIO)
+ continue;
+ // Make sure we don't flush audio streams multiple times, when
+ // all video streams are flushed one at a time.
+ if (c->has_video && os->segment_index > cur_flush_segment_index)
+ continue;
+ }
+
if (!c->single_file) {
snprintf(filename, sizeof(filename), "chunk-stream%d-%05d.m4s", i, os->segment_index);
snprintf(full_path, sizeof(full_path), "%s%s", c->dirname, filename);
@@ -668,7 +682,7 @@ static int dash_write_packet(AVFormatContext *s, AVPacket *pkt)
DASHContext *c = s->priv_data;
AVStream *st = s->streams[pkt->stream_index];
OutputStream *os = &c->streams[pkt->stream_index];
- int64_t seg_end_duration = (c->nb_segments + 1) * (int64_t) c->min_seg_duration;
+ int64_t seg_end_duration = (os->segment_index) * (int64_t) c->min_seg_duration;
int ret;
// If forcing the stream to start at 0, the mp4 muxer will set the start
@@ -704,9 +718,8 @@ static int dash_write_packet(AVFormatContext *s, AVPacket *pkt)
}
}
- if ((ret = dash_flush(s, 0)) < 0)
+ if ((ret = dash_flush(s, 0, pkt->stream_index)) < 0)
return ret;
- c->nb_segments++;
}
if (!os->packets_written)
@@ -732,7 +745,7 @@ static int dash_write_trailer(AVFormatContext *s)
s->streams[0]->time_base,
AV_TIME_BASE_Q);
}
- dash_flush(s, 1);
+ dash_flush(s, 1, -1);
if (c->remove_at_exit) {
char filename[1024];