Report the errno set by getifaddrs(3) if the setup for AI_ADDRCONFIG fails,
rather than a non-informative EAI_FAIL. Compare to -1 for error detection
while here.
Eric.
Index: asr/getaddrinfo_async.c
===================================================================
RCS file: /cvs/src/lib/libc/asr/getaddrinfo_async.c,v
retrieving revision 1.50
diff -u -p -r1.50 getaddrinfo_async.c
--- asr/getaddrinfo_async.c 16 Dec 2015 16:32:30 -0000 1.50
+++ asr/getaddrinfo_async.c 20 Feb 2017 20:09:25 -0000
@@ -191,8 +191,9 @@ getaddrinfo_async_run(struct asr_query *
/* Restrict result set to configured address families */
if (ai->ai_flags & AI_ADDRCONFIG) {
- if (addrconfig_setup(as) != 0) {
- ar->ar_gai_errno = EAI_FAIL;
+ if (addrconfig_setup(as) == -1) {
+ ar->ar_errno = errno;
+ ar->ar_gai_errno = EAI_SYSTEM;
async_set_state(as, ASR_STATE_HALT);
break;
}
@@ -679,7 +680,7 @@ addrconfig_setup(struct asr_query *as)
struct sockaddr_in *sinp;
struct sockaddr_in6 *sin6p;
- if (getifaddrs(&ifa0) != 0)
+ if (getifaddrs(&ifa0) == -1)
return (-1);
as->as.ai.flags |= ASYNC_NO_INET | ASYNC_NO_INET6;