rtsp-session: Don't unref medias twice if it is removed inside gst_rtsp_session_filter() while the mutex is shortly released

Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/757

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/1004>
This commit is contained in:
Sebastian Dröge 2021-10-01 13:51:37 +03:00 committed by GStreamer Marge Bot
parent a774dfb18f
commit 7aa88364ac

View file

@ -454,19 +454,38 @@ restart:
res = func (sess, media, user_data); res = func (sess, media, user_data);
g_mutex_lock (&priv->lock); g_mutex_lock (&priv->lock);
} else } else {
res = GST_RTSP_FILTER_REF; res = GST_RTSP_FILTER_REF;
}
changed = (cookie != priv->medias_cookie); changed = (cookie != priv->medias_cookie);
switch (res) { switch (res) {
case GST_RTSP_FILTER_REMOVE: case GST_RTSP_FILTER_REMOVE:
if (changed) if (changed) {
priv->medias = g_list_remove (priv->medias, media); GList *l;
else
walk = NULL;
for (l = priv->medias; l; l = l->next) {
if (l->data == media) {
walk = l;
break;
}
}
}
/* The media might have been removed from the list while the mutex was
* unlocked above. In that case there's nothing else to do here as the
* only reference to the media owned by this function is in the
* visited hash table and that is released in the end
*/
if (walk) {
priv->medias = g_list_delete_link (priv->medias, walk); priv->medias = g_list_delete_link (priv->medias, walk);
cookie = ++priv->medias_cookie;
g_object_unref (media); g_object_unref (media);
}
cookie = ++priv->medias_cookie;
break; break;
case GST_RTSP_FILTER_REF: case GST_RTSP_FILTER_REF:
result = g_list_prepend (result, g_object_ref (media)); result = g_list_prepend (result, g_object_ref (media));