dtls: Add ability to set custom GstFlowReturn on callback error

Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/2229>
This commit is contained in:
Doug Nazar 2021-05-18 16:31:47 -04:00 committed by GStreamer Marge Bot
parent 3bdf1e691e
commit 8b8428aec2
2 changed files with 25 additions and 3 deletions

View file

@ -101,6 +101,7 @@ struct _GstDtlsConnectionPrivate
GstDtlsConnectionSendCallback send_callback; GstDtlsConnectionSendCallback send_callback;
gpointer send_callback_user_data; gpointer send_callback_user_data;
GDestroyNotify send_callback_destroy_notify; GDestroyNotify send_callback_destroy_notify;
GstFlowReturn syscall_flow_return;
gboolean timeout_pending; gboolean timeout_pending;
GThreadPool *thread_pool; GThreadPool *thread_pool;
@ -600,6 +601,14 @@ gst_dtls_connection_set_send_callback (GstDtlsConnection * self,
g_mutex_unlock (&priv->mutex); g_mutex_unlock (&priv->mutex);
} }
void
gst_dtls_connection_set_flow_return (GstDtlsConnection * self,
GstFlowReturn flow_ret)
{
g_return_if_fail (GST_IS_DTLS_CONNECTION (self));
self->priv->syscall_flow_return = flow_ret;
}
GstFlowReturn GstFlowReturn
gst_dtls_connection_process (GstDtlsConnection * self, gpointer data, gsize len, gst_dtls_connection_process (GstDtlsConnection * self, gpointer data, gsize len,
gsize * written, GError ** err) gsize * written, GError ** err)
@ -1002,13 +1011,19 @@ handle_error (GstDtlsConnection * self, int ret, GstResourceError error_type,
case SSL_ERROR_WANT_WRITE: case SSL_ERROR_WANT_WRITE:
GST_LOG_OBJECT (self, "SSL wants write"); GST_LOG_OBJECT (self, "SSL wants write");
return GST_FLOW_OK; return GST_FLOW_OK;
case SSL_ERROR_SYSCALL: case SSL_ERROR_SYSCALL:{
GstFlowReturn rc = GST_FLOW_OK;
/* OpenSSL shouldn't be making real system calls, so we can safely /* OpenSSL shouldn't be making real system calls, so we can safely
* ignore syscall errors. System interactions should happen through * ignore syscall errors. System interactions should happen through
* our BIO. * our BIO.
*/ */
GST_DEBUG_OBJECT (self, "OpenSSL reported a syscall error, ignoring."); if (error_type == GST_RESOURCE_ERROR_WRITE) {
return GST_FLOW_OK; rc = self->priv->syscall_flow_return;
}
GST_DEBUG_OBJECT (self,
"OpenSSL reported a syscall error. flow_return=%i", rc);
return rc;
}
default: default:
if (self->priv->connection_state != GST_DTLS_CONNECTION_STATE_FAILED) { if (self->priv->connection_state != GST_DTLS_CONNECTION_STATE_FAILED) {
self->priv->connection_state = GST_DTLS_CONNECTION_STATE_FAILED; self->priv->connection_state = GST_DTLS_CONNECTION_STATE_FAILED;
@ -1182,6 +1197,7 @@ bio_method_write (BIO * bio, const char *data, int size)
gboolean ret = TRUE; gboolean ret = TRUE;
GST_LOG_OBJECT (self, "BIO: writing %d", size); GST_LOG_OBJECT (self, "BIO: writing %d", size);
self->priv->syscall_flow_return = GST_FLOW_OK;
if (self->priv->send_callback) if (self->priv->send_callback)
ret = self->priv->send_callback (self, data, size, ret = self->priv->send_callback (self, data, size,

View file

@ -118,6 +118,11 @@ typedef gboolean (*GstDtlsConnectionSendCallback) (GstDtlsConnection * connectio
*/ */
void gst_dtls_connection_set_send_callback(GstDtlsConnection *, GstDtlsConnectionSendCallback, gpointer, GDestroyNotify); void gst_dtls_connection_set_send_callback(GstDtlsConnection *, GstDtlsConnectionSendCallback, gpointer, GDestroyNotify);
/*
* Sets the GstFlowReturn that be returned from gst_dtls_connection_send() if callback returns FALSE
*/
void gst_dtls_connection_set_flow_return(GstDtlsConnection *, GstFlowReturn);
/* /*
* Processes data that has been received, the transformation is done in-place. * Processes data that has been received, the transformation is done in-place.
* *
@ -142,6 +147,7 @@ GstFlowReturn gst_dtls_connection_process(GstDtlsConnection *, gpointer ptr, gsi
* we received an EOS before. * we received an EOS before.
* - GST_FLOW_ERROR + err if an error happened * - GST_FLOW_ERROR + err if an error happened
* - GST_FLOW_OK + written >= 0 if processing was successful * - GST_FLOW_OK + written >= 0 if processing was successful
* - Any GstFlowReturn set with gst_dtls_connection_set_flow_return()
*/ */
GstFlowReturn gst_dtls_connection_send(GstDtlsConnection *, gconstpointer ptr, gsize len, gsize *written, GError **err); GstFlowReturn gst_dtls_connection_send(GstDtlsConnection *, gconstpointer ptr, gsize len, gsize *written, GError **err);