adaptivedemux: answer duration queries for live streams

For duration queries on live streams, adaptivedemux ignores the query.
The problem then is that the query is answered by the downstream
qtdemux element, with the duration of the currently passing fragment.

This commit changes the behaviour of adaptivedemux to answer the duration
queries for live streams, returning GST_CLOCK_TIME_NONE.

    https://bugzilla.gnome.org/show_bug.cgi?id=753879
This commit is contained in:
Alex Ashley 2016-02-05 12:44:23 +00:00 committed by Sebastian Dröge
parent b2e9891f8a
commit e1b68d9a65
6 changed files with 24 additions and 29 deletions

View file

@ -5483,18 +5483,12 @@ gst_mpd_client_get_next_fragment_duration (GstMpdClient * client,
GstClockTime GstClockTime
gst_mpd_client_get_media_presentation_duration (GstMpdClient * client) gst_mpd_client_get_media_presentation_duration (GstMpdClient * client)
{ {
GstClockTime duration;
g_return_val_if_fail (client != NULL, GST_CLOCK_TIME_NONE); g_return_val_if_fail (client != NULL, GST_CLOCK_TIME_NONE);
if (client->mpd_node->mediaPresentationDuration != -1) { /* Note: adaptivedemux makes sure we only get duration queries for on-demand streams */
duration = client->mpd_node->mediaPresentationDuration * GST_MSECOND; g_return_val_if_fail (client->mpd_node->mediaPresentationDuration != -1,
} else { GST_CLOCK_TIME_NONE);
/* We can only get the duration for on-demand streams */ return client->mpd_node->mediaPresentationDuration * GST_MSECOND;
duration = GST_CLOCK_TIME_NONE;
}
return duration;
} }
gboolean gboolean

View file

@ -1015,9 +1015,7 @@ gst_m3u8_get_duration (GstM3U8 * m3u8)
GST_M3U8_LOCK (m3u8); GST_M3U8_LOCK (m3u8);
/* We can only get the duration for on-demand streams */ /* Note: adaptivedemux makes sure we only get duration queries for on-demand streams */
if (!m3u8->endlist)
goto out;
if (!GST_CLOCK_TIME_IS_VALID (m3u8->duration) && m3u8->files != NULL) { if (!GST_CLOCK_TIME_IS_VALID (m3u8->duration) && m3u8->files != NULL) {
GList *f; GList *f;
@ -1028,8 +1026,6 @@ gst_m3u8_get_duration (GstM3U8 * m3u8)
} }
duration = m3u8->duration; duration = m3u8->duration;
out:
GST_M3U8_UNLOCK (m3u8); GST_M3U8_UNLOCK (m3u8);
return duration; return duration;

View file

@ -934,7 +934,7 @@ guint64
gst_mss_manifest_get_duration (GstMssManifest * manifest) gst_mss_manifest_get_duration (GstMssManifest * manifest)
{ {
gchar *duration; gchar *duration;
guint64 dur = -1; guint64 dur = GST_CLOCK_TIME_NONE;
/* try the property */ /* try the property */
duration = duration =

View file

@ -1748,13 +1748,13 @@ gst_adaptive_demux_src_query (GstPad * pad, GstObject * parent,
GST_MANIFEST_LOCK (demux); GST_MANIFEST_LOCK (demux);
if (fmt == GST_FORMAT_TIME && demux->priv->have_manifest) { if (fmt == GST_FORMAT_TIME && demux->priv->have_manifest) {
if (gst_adaptive_demux_is_live (demux))
duration = GST_CLOCK_TIME_NONE;
else
duration = demux_class->get_duration (demux); duration = demux_class->get_duration (demux);
if (GST_CLOCK_TIME_IS_VALID (duration) && duration > 0) {
gst_query_set_duration (query, GST_FORMAT_TIME, duration); gst_query_set_duration (query, GST_FORMAT_TIME, duration);
ret = TRUE; ret = TRUE;
} }
}
GST_MANIFEST_UNLOCK (demux); GST_MANIFEST_UNLOCK (demux);

View file

@ -293,6 +293,18 @@ struct _GstAdaptiveDemuxClass
GstFlowReturn (*update_manifest_data) (GstAdaptiveDemux * demux, GstBuffer * buf); GstFlowReturn (*update_manifest_data) (GstAdaptiveDemux * demux, GstBuffer * buf);
gboolean (*is_live) (GstAdaptiveDemux * demux); gboolean (*is_live) (GstAdaptiveDemux * demux);
/**
* get_duration:
* @demux: #GstAdaptiveDemux
*
* For non-live streams, this will be called to query the duration of the
* stream.
*
* Returns: The duration of the stream, or #GST_CLOCK_TIME_NONE if the
* duration is unknown
* Since: 1.6
*/
GstClockTime (*get_duration) (GstAdaptiveDemux * demux); GstClockTime (*get_duration) (GstAdaptiveDemux * demux);
/** /**

View file

@ -838,13 +838,6 @@ GST_START_TEST (test_get_duration)
assert_equals_uint64 (gst_m3u8_get_duration (pl), 40 * GST_SECOND); assert_equals_uint64 (gst_m3u8_get_duration (pl), 40 * GST_SECOND);
gst_hls_master_playlist_unref (master); gst_hls_master_playlist_unref (master);
/* Test duration for live playlists */
master = load_playlist (LIVE_PLAYLIST);
pl = master->default_variant->m3u8;
assert_equals_uint64 (gst_m3u8_get_duration (pl), GST_CLOCK_TIME_NONE);
gst_hls_master_playlist_unref (master);
} }
GST_END_TEST; GST_END_TEST;