rtsp-media: Unblock all streams

When unsuspending and going to PLAYING, unblock all streams instead of
only those that are linked (the linked streams are the ones for which
SETUP has been called). GST_FLOW_NOT_LINKED will be returned when
pushing buffers on unlinked streams.

This change is because playback using single-threaded demuxers like
matroska-demux could be blocked if SETUP was not called for all media.
Demuxers that use GstFlowCombiner (including gstoggdemux, gstavidemux,
gstflvdemux, qtdemux, and matroska-demux) will handle
GST_FLOW_NOT_LINKED automatically.

Fixes #39
This commit is contained in:
David Svensson Fors 2018-10-29 17:02:41 +01:00 committed by Sebastian Dröge
parent 18f4f4e509
commit e16867b161
2 changed files with 12 additions and 8 deletions

View file

@ -2635,15 +2635,15 @@ media_streams_set_blocked (GstRTSPMedia * media, gboolean blocked)
static void static void
stream_unblock (GstRTSPStream * stream, GstRTSPMedia * media) stream_unblock (GstRTSPStream * stream, GstRTSPMedia * media)
{ {
gst_rtsp_stream_unblock_linked (stream); gst_rtsp_stream_set_blocked (stream, FALSE);
} }
static void static void
media_unblock_linked (GstRTSPMedia * media) media_unblock (GstRTSPMedia * media)
{ {
GstRTSPMediaPrivate *priv = media->priv; GstRTSPMediaPrivate *priv = media->priv;
GST_DEBUG ("media %p unblocking linked streams", media); GST_DEBUG ("media %p unblocking streams", media);
/* media is not blocked any longer, as it contains active streams, /* media is not blocked any longer, as it contains active streams,
* streams that are complete */ * streams that are complete */
priv->blocked = FALSE; priv->blocked = FALSE;
@ -4393,8 +4393,8 @@ default_unsuspend (GstRTSPMedia * media)
gst_rtsp_media_set_status (media, GST_RTSP_MEDIA_STATUS_PREPARING); gst_rtsp_media_set_status (media, GST_RTSP_MEDIA_STATUS_PREPARING);
/* at this point the media pipeline has been updated and contain all /* at this point the media pipeline has been updated and contain all
* specific transport parts: all active streams contain at least one sink * specific transport parts: all active streams contain at least one sink
* element and it's safe to unblock any blocked streams that are active */ * element and it's safe to unblock all blocked streams */
media_unblock_linked (media); media_unblock (media);
} else { } else {
/* streams are not blocked and media is suspended from PAUSED */ /* streams are not blocked and media is suspended from PAUSED */
gst_rtsp_media_set_status (media, GST_RTSP_MEDIA_STATUS_PREPARED); gst_rtsp_media_set_status (media, GST_RTSP_MEDIA_STATUS_PREPARED);
@ -4414,8 +4414,8 @@ default_unsuspend (GstRTSPMedia * media)
gst_rtsp_media_set_status (media, GST_RTSP_MEDIA_STATUS_PREPARING); gst_rtsp_media_set_status (media, GST_RTSP_MEDIA_STATUS_PREPARING);
/* at this point the media pipeline has been updated and contain all /* at this point the media pipeline has been updated and contain all
* specific transport parts: all active streams contain at least one sink * specific transport parts: all active streams contain at least one sink
* element and it's safe to unblock any blocked streams that are active */ * element and it's safe to unblock all blocked streams */
media_unblock_linked (media); media_unblock (media);
if (!start_preroll (media)) if (!start_preroll (media))
goto start_failed; goto start_failed;
@ -4507,7 +4507,7 @@ media_set_pipeline_state_locked (GstRTSPMedia * media, GstState state)
} else { } else {
if (state == GST_STATE_PLAYING) if (state == GST_STATE_PLAYING)
/* make sure pads are not blocking anymore when going to PLAYING */ /* make sure pads are not blocking anymore when going to PLAYING */
media_unblock_linked (media); media_unblock (media);
if (state == GST_STATE_PAUSED) { if (state == GST_STATE_PAUSED) {
set_state_ret = set_state (media, state); set_state_ret = set_state (media, state);

View file

@ -30,10 +30,14 @@
#include "rtsp-server.h" #include "rtsp-server.h"
#define ERRORIGNORE "errorignore ignore-error=false ignore-notlinked=true " \
"ignore-notnegotiated=false convert-to=ok"
#define VIDEO_PIPELINE "videotestsrc ! " \ #define VIDEO_PIPELINE "videotestsrc ! " \
ERRORIGNORE " ! " \
"video/x-raw,width=352,height=288 ! " \ "video/x-raw,width=352,height=288 ! " \
"rtpgstpay name=pay0 pt=96" "rtpgstpay name=pay0 pt=96"
#define AUDIO_PIPELINE "audiotestsrc ! " \ #define AUDIO_PIPELINE "audiotestsrc ! " \
ERRORIGNORE " ! " \
"audio/x-raw,rate=8000 ! " \ "audio/x-raw,rate=8000 ! " \
"rtpgstpay name=pay1 pt=97" "rtpgstpay name=pay1 pt=97"