Date: Sun, 25 Jan 2026 04:13:28 +0000 From: Eugene Grosbein <eugen@FreeBSD.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org Subject: git: fae1c84e95f7 - stable/14 - MFC: libfetch: apply timeout to SSL_read() Message-ID: <69759868.37d03.60f06fa7@gitrepo.freebsd.org>
index | next in thread | raw e-mail
The branch stable/14 has been updated by eugen: URL: https://cgit.FreeBSD.org/src/commit/?id=fae1c84e95f7be4deacdab8a97f140714d8d2ae8 commit fae1c84e95f7be4deacdab8a97f140714d8d2ae8 Author: Eugene Grosbein <eugen@FreeBSD.org> AuthorDate: 2026-01-22 08:40:35 +0000 Commit: Eugene Grosbein <eugen@FreeBSD.org> CommitDate: 2026-01-25 04:13:02 +0000 MFC: libfetch: apply timeout to SSL_read() Currently, fetchTimeout works for non-SSL connections only, so does fetch -T. Fix it applying specified timeout to SSL_read(). (cherry picked from commit 8f8a7f6fffd7dca09013f7c4bfa075bc3825fb8e) --- lib/libfetch/common.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/lib/libfetch/common.c b/lib/libfetch/common.c index 22779876ded4..9721cc557b53 100644 --- a/lib/libfetch/common.c +++ b/lib/libfetch/common.c @@ -1266,6 +1266,14 @@ fetch_ssl_read(SSL *ssl, char *buf, size_t len) { ssize_t rlen; int ssl_err; + struct timeval tv; + + if (fetchTimeout > 0) { + tv.tv_sec = fetchTimeout; + tv.tv_usec = 0; + setsockopt(SSL_get_fd(ssl), SOL_SOCKET, SO_RCVTIMEO, + &tv, sizeof(tv)); + } rlen = SSL_read(ssl, buf, len); if (rlen < 0) {home | help
Want to link to this message? Use this
URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?69759868.37d03.60f06fa7>
