]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
getaddrinfo: Return EAI_NODATA if gethostbyname2_r reports NO_DATA [BZ #21922]
authorFlorian Weimer <fweimer@redhat.com>
Mon, 4 Sep 2017 09:25:34 +0000 (11:25 +0200)
committerFlorian Weimer <fweimer@redhat.com>
Mon, 4 Sep 2017 09:44:22 +0000 (11:44 +0200)
(cherry picked from commit 5f8340f583fe3d4f5734bd2371c5a45ecff2db0d)

ChangeLog
NEWS
sysdeps/posix/getaddrinfo.c

index c58cd5ccd0a50e5d82304fb4a7b2dbcad775cb90..f46bbb7c0d1be4d7aae80d3d575c28942a5820ac 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2017-09-01  Florian Weimer  <fweimer@redhat.com>
+
+       [BZ #21922]
+       * sysdeps/posix/getaddrinfo.c (gaih_inet): Report EAI_NODATA error
+       coming from gethostbyname2_r.
+
 2017-09-01  Florian Weimer  <fweimer@redhat.com>
 
        * sysdeps/posix/getaddrinfo.c (gaih_inet): Only use h_errno if
diff --git a/NEWS b/NEWS
index 756e849643c5ed618e1539ec95c5cda6a83e759f..97eb21e868798a8be41b00d133bf94856f817239 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -22,6 +22,7 @@ The following bugs are resolved with this release:
   [21780] posix: Set p{read,write}v2 to return ENOTSUP
   [21871] x86-64: Use _dl_runtime_resolve_opt only with AVX512F
   [21885] getaddrinfo: Release resolver context on error in gethosts
+  [21922] getaddrinfo with AF_INET(6) returns EAI_NONAME, not EAI_NODATA
   [21930] Do not use __builtin_types_compatible_p in C++ mode
   [21932] Unpaired __resolv_context_get in generic get*_r implementation
   [21941] powerpc: Restrict xssqrtqp operands to Vector Registers
index 9d9e7e2bf2a78cbb980defd619eca7baf616ef50..0cf87c224dff5c660f945bac79e375ff63c13360 100644 (file)
@@ -619,6 +619,14 @@ gaih_inet (const char *name, const struct gaih_service *service,
                        }
                      *pat = addrmem;
                    }
+                 else
+                   {
+                     if (h_errno == NO_DATA)
+                       result = -EAI_NODATA;
+                     else
+                       result = -EAI_NONAME;
+                     goto free_and_return;
+                   }
                }
              else
                {