mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-22 07:08:23 +00:00
rtsp-client: Use fixed backlog size
Change to using a fixed backlog size WATCH_BACKLOG_SIZE. Preparation for the next commit, which changes to a different way of avoiding both deadlocks and unlimited memory usage with the watch backlog.
This commit is contained in:
parent
12c2dd6e1c
commit
287345f6ac
1 changed files with 0 additions and 45 deletions
|
@ -3175,11 +3175,7 @@ client_session_removed (GstRTSPSessionPool * pool, GstRTSPSession * session,
|
||||||
GST_INFO ("client %p: session %p removed", client, session);
|
GST_INFO ("client %p: session %p removed", client, session);
|
||||||
|
|
||||||
g_mutex_lock (&priv->lock);
|
g_mutex_lock (&priv->lock);
|
||||||
if (priv->watch != NULL)
|
|
||||||
gst_rtsp_watch_set_send_backlog (priv->watch, 0, 0);
|
|
||||||
client_unwatch_session (client, session, NULL);
|
client_unwatch_session (client, session, NULL);
|
||||||
if (priv->watch != NULL)
|
|
||||||
gst_rtsp_watch_set_send_backlog (priv->watch, 0, WATCH_BACKLOG_SIZE);
|
|
||||||
g_mutex_unlock (&priv->lock);
|
g_mutex_unlock (&priv->lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3369,37 +3365,6 @@ handle_request (GstRTSPClient * client, GstRTSPMessage * request)
|
||||||
if (!check_request_requirements (ctx, &unsupported_reqs))
|
if (!check_request_requirements (ctx, &unsupported_reqs))
|
||||||
goto unsupported_requirement;
|
goto unsupported_requirement;
|
||||||
|
|
||||||
/* the backlog must be unlimited while processing requests.
|
|
||||||
* the causes of this are two cases of deadlocks while streaming over TCP:
|
|
||||||
*
|
|
||||||
* 1. consider the scenario where the media pipeline's streaming thread
|
|
||||||
* is blocking in the appsink (taking the appsink's preroll lock) because
|
|
||||||
* the backlog is full. when a PAUSE request is received by the RTSP
|
|
||||||
* client thread then the the state of the session media ought to change
|
|
||||||
* to PAUSED. while most elements in the pipeline can change state this
|
|
||||||
* can never happen for the appsink since its preroll lock is taken by
|
|
||||||
* another thread.
|
|
||||||
*
|
|
||||||
* 2. consider the scenario where the media pipeline's streaming thread
|
|
||||||
* is blocking in the appsink new_sample callback (taking the send lock
|
|
||||||
* in RTSP client) because the backlog is full. when e.g. a GET request
|
|
||||||
* is received by the RTSP client thread then a response ought to be sent
|
|
||||||
* but this can never happen since it requires taking the send lock
|
|
||||||
* already taken by another thread.
|
|
||||||
*
|
|
||||||
* the reason that the backlog is never emptied is that the source used
|
|
||||||
* for dequeing messages from the backlog is never dispatched because it
|
|
||||||
* is attached to the same mainloop as the source receving RTSP requests and
|
|
||||||
* therefore run by the RTSP client thread which is alreayd blocking.
|
|
||||||
*
|
|
||||||
* without significant changes the easiest way to cope with this is to
|
|
||||||
* not block indefinitely when the backlog is full, but rather let the
|
|
||||||
* backlog grow in size. this in effect means that there can not be any
|
|
||||||
* upper boundary on its size.
|
|
||||||
*/
|
|
||||||
if (priv->watch != NULL)
|
|
||||||
gst_rtsp_watch_set_send_backlog (priv->watch, 0, 0);
|
|
||||||
|
|
||||||
/* now see what is asked and dispatch to a dedicated handler */
|
/* now see what is asked and dispatch to a dedicated handler */
|
||||||
switch (method) {
|
switch (method) {
|
||||||
case GST_RTSP_OPTIONS:
|
case GST_RTSP_OPTIONS:
|
||||||
|
@ -3438,19 +3403,12 @@ handle_request (GstRTSPClient * client, GstRTSPMessage * request)
|
||||||
handle_record_request (client, ctx);
|
handle_record_request (client, ctx);
|
||||||
break;
|
break;
|
||||||
case GST_RTSP_REDIRECT:
|
case GST_RTSP_REDIRECT:
|
||||||
if (priv->watch != NULL)
|
|
||||||
gst_rtsp_watch_set_send_backlog (priv->watch, 0, WATCH_BACKLOG_SIZE);
|
|
||||||
goto not_implemented;
|
goto not_implemented;
|
||||||
case GST_RTSP_INVALID:
|
case GST_RTSP_INVALID:
|
||||||
default:
|
default:
|
||||||
if (priv->watch != NULL)
|
|
||||||
gst_rtsp_watch_set_send_backlog (priv->watch, 0, WATCH_BACKLOG_SIZE);
|
|
||||||
goto bad_request;
|
goto bad_request;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (priv->watch != NULL)
|
|
||||||
gst_rtsp_watch_set_send_backlog (priv->watch, 0, WATCH_BACKLOG_SIZE);
|
|
||||||
|
|
||||||
done:
|
done:
|
||||||
if (ctx == &sctx)
|
if (ctx == &sctx)
|
||||||
gst_rtsp_context_pop_current (ctx);
|
gst_rtsp_context_pop_current (ctx);
|
||||||
|
@ -3470,9 +3428,6 @@ not_supported:
|
||||||
}
|
}
|
||||||
invalid_command_for_version:
|
invalid_command_for_version:
|
||||||
{
|
{
|
||||||
if (priv->watch != NULL)
|
|
||||||
gst_rtsp_watch_set_send_backlog (priv->watch, 0, WATCH_BACKLOG_SIZE);
|
|
||||||
|
|
||||||
GST_ERROR ("client %p: invalid command for version", client);
|
GST_ERROR ("client %p: invalid command for version", client);
|
||||||
send_generic_response (client, GST_RTSP_STS_BAD_REQUEST, ctx);
|
send_generic_response (client, GST_RTSP_STS_BAD_REQUEST, ctx);
|
||||||
goto done;
|
goto done;
|
||||||
|
|
Loading…
Reference in a new issue