The branch stable/14 has been updated by des:

URL: 
https://cgit.FreeBSD.org/src/commit/?id=31f3640c4aa859f2e3a78a51f3c43e0e6e7239f9

commit 31f3640c4aa859f2e3a78a51f3c43e0e6e7239f9
Author:     Dag-Erling Smørgrav <[email protected]>
AuthorDate: 2026-02-21 01:18:18 +0000
Commit:     Dag-Erling Smørgrav <[email protected]>
CommitDate: 2026-02-26 04:03:43 +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
    
    (cherry picked from commit b5d570e711da1dad303312bebaf1bd2fb720f0dc)
---
 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 784da2d9e6a2..5115933b8e41 100644
--- a/lib/libfetch/common.c
+++ b/lib/libfetch/common.c
@@ -638,8 +638,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)

Reply via email to