From fa31c594590c7a2ab760e6d67f00a2ecf61bdfe9 Mon Sep 17 00:00:00 2001 From: millert <> Date: Wed, 27 Jul 2005 14:16:43 +0000 Subject: Restore recent changes except for the actual one that causes the problem. --- src/lib/libc/net/gethostnamadr.c | 28 ++++++++-------------------- 1 file changed, 8 insertions(+), 20 deletions(-) (limited to 'src/lib') diff --git a/src/lib/libc/net/gethostnamadr.c b/src/lib/libc/net/gethostnamadr.c index 4450652167..c984fac7b1 100644 --- a/src/lib/libc/net/gethostnamadr.c +++ b/src/lib/libc/net/gethostnamadr.c @@ -48,7 +48,7 @@ */ #if defined(LIBC_SCCS) && !defined(lint) -static const char rcsid[] = "$OpenBSD: gethostnamadr.c,v 1.66 2005/07/27 13:40:28 jaredy Exp $"; +static const char rcsid[] = "$OpenBSD: gethostnamadr.c,v 1.67 2005/07/27 14:16:43 millert Exp $"; #endif /* LIBC_SCCS and not lint */ #include @@ -786,7 +786,7 @@ _endhtent(void) } } -struct hostent * +static struct hostent * _gethtent(void) { struct __res_state *_resp = _THREAD_PRIVATE(_res, _res, &_res); @@ -832,9 +832,9 @@ _gethtent(void) goto again; } /* if this is not something we're looking for, skip it. */ - if (host.h_addrtype != af) + if (host.h_addrtype != AF_UNSPEC && host.h_addrtype != af) goto again; - if (host.h_length != len) + if (host.h_length != 0 && host.h_length != len) goto again; h_addr_ptrs[0] = (char *)host_addr; h_addr_ptrs[1] = NULL; @@ -868,21 +868,6 @@ _gethtent(void) return (&host); } -struct hostent * -_gethtbyname(const char *name) -{ - struct __res_state *_resp = _THREAD_PRIVATE(_res, _res, &_res); - struct hostent *hp; - extern struct hostent *_gethtbyname2(const char *, int); - - if (_resp->options & RES_USE_INET6) { - hp = _gethtbyname2(name, AF_INET6); - if (hp) - return (hp); - } - return (_gethtbyname2(name, AF_INET)); -} - struct hostent * _gethtbyname2(const char *name, int af) { @@ -914,7 +899,8 @@ _gethtbyaddr(const void *addr, socklen_t len, int af) _sethtent(0); while ((p = _gethtent())) - if (p->h_addrtype == af && !bcmp(p->h_addr, addr, len)) + if (p->h_addrtype == af && p->h_length == len && + !bcmp(p->h_addr, addr, len)) break; _endhtent(); return (p); @@ -1093,6 +1079,8 @@ map_v4v6_hostent(struct hostent *hp, char **bpp, char *ep) struct hostent * gethostent(void) { + host.h_addrtype = AF_UNSPEC; + host.h_length = 0; return (_gethtent()); } -- cgit v1.2.3-55-g6feb