mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 18:35:35 +00:00
mssdemux: make sure streams stop properly on cancelled
specially when the gst_task_join is waiting for the task to go stop and the task itself sets its back to paused, causing a deadlock on exit.
This commit is contained in:
parent
99c8fb7330
commit
26acbbcca9
1 changed files with 7 additions and 16 deletions
|
@ -140,6 +140,8 @@ static GstFlowReturn gst_mss_demux_stream_push_event (GstMssDemuxStream *
|
||||||
static GstFlowReturn gst_mss_demux_combine_flows (GstMssDemux * mssdemux);
|
static GstFlowReturn gst_mss_demux_combine_flows (GstMssDemux * mssdemux);
|
||||||
|
|
||||||
static gboolean gst_mss_demux_process_manifest (GstMssDemux * mssdemux);
|
static gboolean gst_mss_demux_process_manifest (GstMssDemux * mssdemux);
|
||||||
|
static void
|
||||||
|
gst_mss_demux_stop_tasks (GstMssDemux * mssdemux, gboolean immediate);
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_mss_demux_class_init (GstMssDemuxClass * klass)
|
gst_mss_demux_class_init (GstMssDemuxClass * klass)
|
||||||
|
@ -278,13 +280,7 @@ gst_mss_demux_reset (GstMssDemux * mssdemux)
|
||||||
{
|
{
|
||||||
GSList *iter;
|
GSList *iter;
|
||||||
|
|
||||||
for (iter = mssdemux->streams; iter; iter = g_slist_next (iter)) {
|
gst_mss_demux_stop_tasks (mssdemux, TRUE);
|
||||||
GstMssDemuxStream *stream = iter->data;
|
|
||||||
|
|
||||||
if (stream->downloader)
|
|
||||||
gst_uri_downloader_cancel (stream->downloader);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mssdemux->manifest_buffer) {
|
if (mssdemux->manifest_buffer) {
|
||||||
gst_buffer_unref (mssdemux->manifest_buffer);
|
gst_buffer_unref (mssdemux->manifest_buffer);
|
||||||
|
@ -481,16 +477,16 @@ gst_mss_demux_stop_tasks (GstMssDemux * mssdemux, gboolean immediate)
|
||||||
for (iter = mssdemux->streams; iter; iter = g_slist_next (iter)) {
|
for (iter = mssdemux->streams; iter; iter = g_slist_next (iter)) {
|
||||||
GstMssDemuxStream *stream = iter->data;
|
GstMssDemuxStream *stream = iter->data;
|
||||||
|
|
||||||
|
gst_task_stop (stream->download_task);
|
||||||
stream->cancelled = TRUE;
|
stream->cancelled = TRUE;
|
||||||
if (immediate)
|
if (immediate)
|
||||||
gst_uri_downloader_cancel (stream->downloader);
|
gst_uri_downloader_cancel (stream->downloader);
|
||||||
gst_task_pause (stream->download_task);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (iter = mssdemux->streams; iter; iter = g_slist_next (iter)) {
|
for (iter = mssdemux->streams; iter; iter = g_slist_next (iter)) {
|
||||||
GstMssDemuxStream *stream = iter->data;
|
GstMssDemuxStream *stream = iter->data;
|
||||||
g_rec_mutex_lock (&stream->download_lock);
|
|
||||||
stream->cancelled = FALSE;
|
gst_task_join (stream->download_task);
|
||||||
stream->download_error_count = 0;
|
stream->download_error_count = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -502,11 +498,7 @@ gst_mss_demux_restart_tasks (GstMssDemux * mssdemux)
|
||||||
for (iter = mssdemux->streams; iter; iter = g_slist_next (iter)) {
|
for (iter = mssdemux->streams; iter; iter = g_slist_next (iter)) {
|
||||||
GstMssDemuxStream *stream = iter->data;
|
GstMssDemuxStream *stream = iter->data;
|
||||||
gst_uri_downloader_reset (stream->downloader);
|
gst_uri_downloader_reset (stream->downloader);
|
||||||
g_rec_mutex_unlock (&stream->download_lock);
|
stream->cancelled = FALSE;
|
||||||
}
|
|
||||||
for (iter = mssdemux->streams; iter; iter = g_slist_next (iter)) {
|
|
||||||
GstMssDemuxStream *stream = iter->data;
|
|
||||||
|
|
||||||
gst_task_start (stream->download_task);
|
gst_task_start (stream->download_task);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1232,7 +1224,6 @@ gst_mss_demux_download_loop (GstMssDemuxStream * stream)
|
||||||
cancelled:
|
cancelled:
|
||||||
{
|
{
|
||||||
GST_DEBUG_OBJECT (mssdemux, "Stream %p has been cancelled", stream);
|
GST_DEBUG_OBJECT (mssdemux, "Stream %p has been cancelled", stream);
|
||||||
gst_task_pause (stream->download_task);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue