git: b5d570e711da - main - libfetch: Gracefully skip unsupported protocols
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Sat, 21 Feb 2026 01:18:53 UTC
The branch main has been updated by des:
URL: https://cgit.FreeBSD.org/src/commit/?id=b5d570e711da1dad303312bebaf1bd2fb720f0dc
commit b5d570e711da1dad303312bebaf1bd2fb720f0dc
Author: Dag-Erling Smørgrav <des@FreeBSD.org>
AuthorDate: 2026-02-21 01:18:18 +0000
Commit: Dag-Erling Smørgrav <des@FreeBSD.org>
CommitDate: 2026-02-21 01:18:18 +0000
libfetch: Gracefully skip unsupported protocols
If socket() fails because the address family or protocol is unsupported,
just continue with the next address.
MFC after: 1 week
Reviewed by: imp
Differential Revision: https://reviews.freebsd.org/D55407
---
lib/libfetch/common.c | 6 +++++-
1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/lib/libfetch/common.c b/lib/libfetch/common.c
index b3250940becc..88b5e5a2f096 100644
--- a/lib/libfetch/common.c
+++ b/lib/libfetch/common.c
@@ -637,8 +637,12 @@ fetch_connect(const char *host, int port, int af, int verbose)
/* try each server address in turn */
for (err = 0, sai = sais; sai != NULL; sai = sai->ai_next) {
/* open socket */
- if ((sd = socket(sai->ai_family, SOCK_STREAM, 0)) < 0)
+ if ((sd = socket(sai->ai_family, SOCK_STREAM, 0)) < 0) {
+ err = -1;
+ if (errno == EAFNOSUPPORT || errno == EPROTONOSUPPORT)
+ continue;
goto syserr;
+ }
/* attempt to bind to client address */
for (err = 0, cai = cais; cai != NULL; cai = cai->ai_next) {
if (cai->ai_family != sai->ai_family)