mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-02-06 14:32:31 +00:00
rtsp-client: Session filter in unwatch session
Call session filter with filter_session_media as paramer in client_unwatch_session if using drop_backlog = FALSE. In client_unwatch_session its allowed to grow the watchs backlog. If using drop_backlog = FALSE and the backlog is full it will cause a deadlock when setting session media state to NULL if the backlog is not allowed to grow. https://bugzilla.gnome.org/show_bug.cgi?id=771983
This commit is contained in:
parent
34ed1d0bea
commit
dbf91ab231
1 changed files with 11 additions and 3 deletions
|
@ -416,6 +416,11 @@ client_unwatch_session (GstRTSPClient * client, GstRTSPSession * session,
|
|||
priv->session_removed_id = 0;
|
||||
}
|
||||
|
||||
if (!priv->drop_backlog) {
|
||||
/* unlink all media managed in this session */
|
||||
gst_rtsp_session_filter (session, filter_session_media, client);
|
||||
}
|
||||
|
||||
/* remove the session */
|
||||
g_object_unref (session);
|
||||
}
|
||||
|
@ -425,10 +430,13 @@ cleanup_session (GstRTSPClient * client, GstRTSPSession * sess,
|
|||
gpointer user_data)
|
||||
{
|
||||
gboolean *closed = user_data;
|
||||
GstRTSPClientPrivate *priv = client->priv;
|
||||
|
||||
/* unlink all media managed in this session. This needs to happen
|
||||
* without the client lock, so we really want to do it here. */
|
||||
gst_rtsp_session_filter (sess, filter_session_media, user_data);
|
||||
if (priv->drop_backlog) {
|
||||
/* unlink all media managed in this session. This needs to happen
|
||||
* without the client lock, so we really want to do it here. */
|
||||
gst_rtsp_session_filter (sess, filter_session_media, user_data);
|
||||
}
|
||||
|
||||
if (*closed)
|
||||
return GST_RTSP_FILTER_REMOVE;
|
||||
|
|
Loading…
Reference in a new issue