This is an automated email from the git hooks/post-receive script.
Git pushed a commit to branch master
in repository ffmpeg.
The following commit(s) were added to refs/heads/master by this push:
new b0fe52ba4e avformat/tls_gnutls: add gnutls_pull_timeout() for dtls
b0fe52ba4e is described below
commit b0fe52ba4ee6a826bafaf4c6a14b33ecb1d77b7a
Author: Jack Lau <[email protected]>
AuthorDate: Sat Jan 10 20:37:08 2026 +0800
Commit: Gyan Doshi <[email protected]>
CommitDate: Sun Jan 11 04:24:26 2026 +0000
avformat/tls_gnutls: add gnutls_pull_timeout() for dtls
See
https://gnutls.org/manual/gnutls.html#index-gnutls_005ftransport_005fset_005fpull_005ftimeout_005ffunction
This callback is necessary for enforcing the DTLS mode timeouts when in
blocking mode.
Otherwise the dtls pull function won't work.
The gnutls_pull_timeout() implementation refers to gnutls example:
https://gnutls.org/manual/gnutls.html#DTLS-echo-server-with-X_002e509-authentication-1
Signed-off-by: Jack Lau <[email protected]>
---
libavformat/tls_gnutls.c | 27 ++++++++++++++++++++++++++-
1 file changed, 26 insertions(+), 1 deletion(-)
diff --git a/libavformat/tls_gnutls.c b/libavformat/tls_gnutls.c
index c991a712df..6f58ec03d2 100644
--- a/libavformat/tls_gnutls.c
+++ b/libavformat/tls_gnutls.c
@@ -167,6 +167,29 @@ static ssize_t gnutls_url_push(gnutls_transport_ptr_t
transport,
return -1;
}
+static int gnutls_pull_timeout(gnutls_transport_ptr_t ptr, unsigned int ms)
+{
+ TLSContext *c = (TLSContext*) ptr;
+ TLSShared *s = &c->tls_shared;
+ int ret;
+ fd_set rfds;
+ struct timeval tv;
+ int sockfd = ffurl_get_file_handle(s->udp);
+ if (sockfd < 0)
+ return 0;
+
+ FD_ZERO(&rfds);
+ FD_SET(sockfd, &rfds);
+
+ tv.tv_sec = ms / 1000;
+ tv.tv_usec = (ms % 1000) * 1000;
+
+ ret = select(sockfd + 1, &rfds, NULL, NULL, &tv);
+ if (ret <= 0)
+ return ret;
+ return 1;
+}
+
static int tls_handshake(URLContext *h)
{
TLSContext *c = h->priv_data;
@@ -244,9 +267,11 @@ static int tls_open(URLContext *h, const char *uri, int
flags, AVDictionary **op
gnutls_transport_set_pull_function(c->session, gnutls_url_pull);
gnutls_transport_set_push_function(c->session, gnutls_url_push);
gnutls_transport_set_ptr(c->session, c);
- if (s->is_dtls)
+ if (s->is_dtls) {
+ gnutls_transport_set_pull_timeout_function(c->session,
gnutls_pull_timeout);
if (s->mtu)
gnutls_dtls_set_mtu(c->session, s->mtu);
+ }
gnutls_set_default_priority(c->session);
ret = tls_handshake(h);
if (ret < 0)
_______________________________________________
ffmpeg-cvslog mailing list -- [email protected]
To unsubscribe send an email to [email protected]