From ddd4fe680f5379d4ddf6ee06166870626f9c5cec Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim-Philipp=20M=C3=BCller?= Date: Thu, 25 Jan 2018 00:46:57 +0000 Subject: [PATCH] splitmuxsrc: properly set total duration on outgoing segment We would accidentally pass through the duration value from the demuxer from a single fragment, which causes problems when feeding the stream from splitmuxsrc to rtsp-server. Streaming would stop after one fragment due to that. https://bugzilla.gnome.org/show_bug.cgi?id=792861 --- gst/multifile/gstsplitmuxsrc.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/gst/multifile/gstsplitmuxsrc.c b/gst/multifile/gstsplitmuxsrc.c index df8eba2bc3..7f1ed653f7 100644 --- a/gst/multifile/gstsplitmuxsrc.c +++ b/gst/multifile/gstsplitmuxsrc.c @@ -428,6 +428,7 @@ gst_splitmux_handle_event (GstSplitMuxSrc * splitmux, break; } case GST_EVENT_SEGMENT:{ + GstClockTime duration; GstSegment seg; gst_event_copy_segment (event, &seg); @@ -462,6 +463,15 @@ gst_splitmux_handle_event (GstSplitMuxSrc * splitmux, } } + GST_OBJECT_LOCK (splitmux); + duration = splitmux->total_duration; + GST_OBJECT_UNLOCK (splitmux); + + if (duration > 0) + seg.duration = duration; + else + seg.duration = GST_CLOCK_TIME_NONE; + GST_INFO_OBJECT (splitpad, "Forwarding segment %" GST_SEGMENT_FORMAT, &seg);