From: Florian Weimer Date: Fri, 1 Sep 2017 06:57:52 +0000 (+0200) Subject: getaddrinfo: In gaih_inet, use h_errno for certain status values only X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=e552550b409fda1369dc8f23c659c554632619e5;p=thirdparty%2Fglibc.git getaddrinfo: In gaih_inet, use h_errno for certain status values only h_errno is not set for NSS_STATUS_SUCCESS, so its value might not be accurate at this point. (cherry picked from commit a2881ef01450295782b065f2f850f340d5c12c14) --- diff --git a/ChangeLog b/ChangeLog index 0d09261cac2..410d132f284 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2017-09-01 Florian Weimer + + * sysdeps/posix/getaddrinfo.c (gaih_inet): Only use h_errno if + status indicates it is set. + 2017-09-01 Florian Weimer * sysdeps/posix/getaddrinfo.c (gaih_inet): Make reporting of NSS diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c index 65394a37d6d..668f7b75079 100644 --- a/sysdeps/posix/getaddrinfo.c +++ b/sysdeps/posix/getaddrinfo.c @@ -944,7 +944,10 @@ gaih_inet (const char *name, const struct gaih_service *service, _res.options |= old_res_options & DEPRECATED_RES_USE_INET6; - if (h_errno == NETDB_INTERNAL) + /* If we have a failure which sets errno, report it using + EAI_SYSTEM. */ + if ((status == NSS_STATUS_TRYAGAIN || status == NSS_STATUS_UNAVAIL) + && h_errno == NETDB_INTERNAL) { result = -EAI_SYSTEM; goto free_and_return;