11363f04cSPaul Traina /*- 21363f04cSPaul Traina * Copyright (c) 1985, 1988, 1993 31363f04cSPaul Traina * The Regents of the University of California. All rights reserved. 41363f04cSPaul Traina * 51363f04cSPaul Traina * Redistribution and use in source and binary forms, with or without 61363f04cSPaul Traina * modification, are permitted provided that the following conditions 71363f04cSPaul Traina * are met: 81363f04cSPaul Traina * 1. Redistributions of source code must retain the above copyright 91363f04cSPaul Traina * notice, this list of conditions and the following disclaimer. 101363f04cSPaul Traina * 2. Redistributions in binary form must reproduce the above copyright 111363f04cSPaul Traina * notice, this list of conditions and the following disclaimer in the 121363f04cSPaul Traina * documentation and/or other materials provided with the distribution. 131363f04cSPaul Traina * 3. All advertising materials mentioning features or use of this software 141363f04cSPaul Traina * must display the following acknowledgement: 151363f04cSPaul Traina * This product includes software developed by the University of 161363f04cSPaul Traina * California, Berkeley and its contributors. 171363f04cSPaul Traina * 4. Neither the name of the University nor the names of its contributors 181363f04cSPaul Traina * may be used to endorse or promote products derived from this software 191363f04cSPaul Traina * without specific prior written permission. 201363f04cSPaul Traina * 211363f04cSPaul Traina * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 221363f04cSPaul Traina * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 231363f04cSPaul Traina * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 241363f04cSPaul Traina * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 251363f04cSPaul Traina * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 261363f04cSPaul Traina * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 271363f04cSPaul Traina * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 281363f04cSPaul Traina * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 291363f04cSPaul Traina * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 301363f04cSPaul Traina * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 311363f04cSPaul Traina * SUCH DAMAGE. 321363f04cSPaul Traina * - 331363f04cSPaul Traina * Portions Copyright (c) 1993 by Digital Equipment Corporation. 341363f04cSPaul Traina * 351363f04cSPaul Traina * Permission to use, copy, modify, and distribute this software for any 361363f04cSPaul Traina * purpose with or without fee is hereby granted, provided that the above 371363f04cSPaul Traina * copyright notice and this permission notice appear in all copies, and that 381363f04cSPaul Traina * the name of Digital Equipment Corporation not be used in advertising or 391363f04cSPaul Traina * publicity pertaining to distribution of the document or software without 401363f04cSPaul Traina * specific, written prior permission. 411363f04cSPaul Traina * 421363f04cSPaul Traina * THE SOFTWARE IS PROVIDED "AS IS" AND DIGITAL EQUIPMENT CORP. DISCLAIMS ALL 431363f04cSPaul Traina * WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES 441363f04cSPaul Traina * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL DIGITAL EQUIPMENT 451363f04cSPaul Traina * CORPORATION BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL 461363f04cSPaul Traina * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR 471363f04cSPaul Traina * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS 481363f04cSPaul Traina * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS 491363f04cSPaul Traina * SOFTWARE. 501363f04cSPaul Traina * - 511363f04cSPaul Traina * --Copyright-- 521363f04cSPaul Traina */ 534faad310SPeter Wemm /* Portions Copyright (c) 1993 Carlos Leandro and Rui Salgueiro 544faad310SPeter Wemm * Dep. Matematica Universidade de Coimbra, Portugal, Europe 554faad310SPeter Wemm * 564faad310SPeter Wemm * Permission to use, copy, modify, and distribute this software for any 574faad310SPeter Wemm * purpose with or without fee is hereby granted, provided that the above 584faad310SPeter Wemm * copyright notice and this permission notice appear in all copies. 594faad310SPeter Wemm */ 601363f04cSPaul Traina 611363f04cSPaul Traina #if defined(LIBC_SCCS) && !defined(lint) 621363f04cSPaul Traina static char sccsid[] = "@(#)gethostnamadr.c 8.1 (Berkeley) 6/4/93"; 631363f04cSPaul Traina #endif /* LIBC_SCCS and not lint */ 64333fc21eSDavid E. O'Brien #include <sys/cdefs.h> 65333fc21eSDavid E. O'Brien __FBSDID("$FreeBSD$"); 661363f04cSPaul Traina 671363f04cSPaul Traina #include <sys/param.h> 681363f04cSPaul Traina #include <sys/socket.h> 691363f04cSPaul Traina #include <netinet/in.h> 701363f04cSPaul Traina #include <arpa/inet.h> 711363f04cSPaul Traina #include <arpa/nameser.h> 724faad310SPeter Wemm 73a54c3906SDiomidis Spinellis #include <errno.h> 744faad310SPeter Wemm #include <stdio.h> 75a52b6b83SHajimu UMEMOTO #include <stdlib.h> 761363f04cSPaul Traina #include <netdb.h> 771363f04cSPaul Traina #include <resolv.h> 781363f04cSPaul Traina #include <ctype.h> 791363f04cSPaul Traina #include <string.h> 804faad310SPeter Wemm #include <unistd.h> 811363f04cSPaul Traina #include <syslog.h> 82248aee62SJacques Vidrine #include <stdarg.h> 83248aee62SJacques Vidrine #include <nsswitch.h> 841363f04cSPaul Traina 85a2a77501SHajimu UMEMOTO #include "netdb_private.h" 864faad310SPeter Wemm #include "res_config.h" 871363f04cSPaul Traina 884faad310SPeter Wemm extern int h_errno; 894faad310SPeter Wemm 904faad310SPeter Wemm #define BYADDR 0 914faad310SPeter Wemm #define BYNAME 1 921363f04cSPaul Traina 93a52b6b83SHajimu UMEMOTO #define MAXPACKET (64*1024) 941363f04cSPaul Traina 951363f04cSPaul Traina typedef union { 961363f04cSPaul Traina HEADER hdr; 971363f04cSPaul Traina u_char buf[MAXPACKET]; 981363f04cSPaul Traina } querybuf; 991363f04cSPaul Traina 1001363f04cSPaul Traina typedef union { 1014faad310SPeter Wemm long al; 1021363f04cSPaul Traina char ac; 1031363f04cSPaul Traina } align; 1041363f04cSPaul Traina 105a54c3906SDiomidis Spinellis /* 106a54c3906SDiomidis Spinellis * Reverse the order of first four dotted entries of in. 107a54c3906SDiomidis Spinellis * Out must contain space for at least strlen(in) characters. 108a54c3906SDiomidis Spinellis * The result does not include any leading 0s of in. 109a54c3906SDiomidis Spinellis */ 11050a51e39SRuslan Ermilov static void 111a54c3906SDiomidis Spinellis ipreverse(char *in, char *out) 112a54c3906SDiomidis Spinellis { 113a54c3906SDiomidis Spinellis char *pos[4]; 114a54c3906SDiomidis Spinellis int len[4]; 115a54c3906SDiomidis Spinellis char *p, *start; 116a54c3906SDiomidis Spinellis int i = 0; 117a54c3906SDiomidis Spinellis int leading = 1; 118a54c3906SDiomidis Spinellis 119a54c3906SDiomidis Spinellis /* Fill-in element positions and lengths: pos[], len[]. */ 120a54c3906SDiomidis Spinellis start = p = in; 121a54c3906SDiomidis Spinellis for (;;) { 122a54c3906SDiomidis Spinellis if (*p == '.' || *p == '\0') { 123a54c3906SDiomidis Spinellis /* Leading 0? */ 124a54c3906SDiomidis Spinellis if (leading && p - start == 1 && *start == '0') 125a54c3906SDiomidis Spinellis len[i] = 0; 126a54c3906SDiomidis Spinellis else { 127a54c3906SDiomidis Spinellis len[i] = p - start; 128a54c3906SDiomidis Spinellis leading = 0; 129a54c3906SDiomidis Spinellis } 130a54c3906SDiomidis Spinellis pos[i] = start; 131a54c3906SDiomidis Spinellis start = p + 1; 132a54c3906SDiomidis Spinellis i++; 133a54c3906SDiomidis Spinellis } 134a54c3906SDiomidis Spinellis if (i == 4) 135a54c3906SDiomidis Spinellis break; 136a54c3906SDiomidis Spinellis if (*p == 0) { 137a54c3906SDiomidis Spinellis for (; i < 4; i++) { 138a54c3906SDiomidis Spinellis pos[i] = p; 139a54c3906SDiomidis Spinellis len[i] = 0; 140a54c3906SDiomidis Spinellis } 141a54c3906SDiomidis Spinellis break; 142a54c3906SDiomidis Spinellis } 143a54c3906SDiomidis Spinellis p++; 144a54c3906SDiomidis Spinellis } 145a54c3906SDiomidis Spinellis 146a54c3906SDiomidis Spinellis /* Copy the entries in reverse order */ 147a54c3906SDiomidis Spinellis p = out; 148a54c3906SDiomidis Spinellis leading = 1; 149a54c3906SDiomidis Spinellis for (i = 3; i >= 0; i--) { 150a54c3906SDiomidis Spinellis memcpy(p, pos[i], len[i]); 151a54c3906SDiomidis Spinellis if (len[i]) 152a54c3906SDiomidis Spinellis leading = 0; 153a54c3906SDiomidis Spinellis p += len[i]; 154a54c3906SDiomidis Spinellis /* Need a . separator? */ 155a54c3906SDiomidis Spinellis if (!leading && i > 0 && len[i - 1]) 156a54c3906SDiomidis Spinellis *p++ = '.'; 157a54c3906SDiomidis Spinellis } 158a54c3906SDiomidis Spinellis *p = '\0'; 159a54c3906SDiomidis Spinellis } 160a54c3906SDiomidis Spinellis 161a2a77501SHajimu UMEMOTO static int 162a2a77501SHajimu UMEMOTO getnetanswer(querybuf *answer, int anslen, int net_i, struct netent *ne, 163a2a77501SHajimu UMEMOTO struct netent_data *ned) 1641363f04cSPaul Traina { 1651363f04cSPaul Traina 1668fb3f3f6SDavid E. O'Brien HEADER *hp; 1678fb3f3f6SDavid E. O'Brien u_char *cp; 1688fb3f3f6SDavid E. O'Brien int n; 1691363f04cSPaul Traina u_char *eom; 17050a51e39SRuslan Ermilov int type, class, ancount, qdcount, haveanswer; 171a54c3906SDiomidis Spinellis char aux[MAXHOSTNAMELEN]; 172a2a77501SHajimu UMEMOTO char ans[MAXHOSTNAMELEN]; 173a54c3906SDiomidis Spinellis char *in, *bp, *ep, **ap; 1741363f04cSPaul Traina 1751363f04cSPaul Traina /* 1761363f04cSPaul Traina * find first satisfactory answer 1771363f04cSPaul Traina * 1781363f04cSPaul Traina * answer --> +------------+ ( MESSAGE ) 1791363f04cSPaul Traina * | Header | 1801363f04cSPaul Traina * +------------+ 1811363f04cSPaul Traina * | Question | the question for the name server 1821363f04cSPaul Traina * +------------+ 1831363f04cSPaul Traina * | Answer | RRs answering the question 1841363f04cSPaul Traina * +------------+ 1851363f04cSPaul Traina * | Authority | RRs pointing toward an authority 1861363f04cSPaul Traina * | Additional | RRs holding additional information 1871363f04cSPaul Traina * +------------+ 1881363f04cSPaul Traina */ 1891363f04cSPaul Traina eom = answer->buf + anslen; 1901363f04cSPaul Traina hp = &answer->hdr; 1911363f04cSPaul Traina ancount = ntohs(hp->ancount); /* #/records in the answer section */ 1921363f04cSPaul Traina qdcount = ntohs(hp->qdcount); /* #/entries in the question section */ 193a2a77501SHajimu UMEMOTO bp = ned->netbuf; 194a2a77501SHajimu UMEMOTO ep = ned->netbuf + sizeof(ned->netbuf); 1951363f04cSPaul Traina cp = answer->buf + HFIXEDSZ; 1961363f04cSPaul Traina if (!qdcount) { 1971363f04cSPaul Traina if (hp->aa) 1981363f04cSPaul Traina h_errno = HOST_NOT_FOUND; 1991363f04cSPaul Traina else 2001363f04cSPaul Traina h_errno = TRY_AGAIN; 201a2a77501SHajimu UMEMOTO return -1; 2021363f04cSPaul Traina } 2034faad310SPeter Wemm while (qdcount-- > 0) 2041363f04cSPaul Traina cp += __dn_skipname(cp, eom) + QFIXEDSZ; 205a2a77501SHajimu UMEMOTO ap = ned->net_aliases; 2061363f04cSPaul Traina *ap = NULL; 207a2a77501SHajimu UMEMOTO ne->n_aliases = ned->net_aliases; 2081363f04cSPaul Traina haveanswer = 0; 2091363f04cSPaul Traina while (--ancount >= 0 && cp < eom) { 210d6af58f5SWarner Losh n = dn_expand(answer->buf, eom, cp, bp, ep - bp); 2115ce1c533SPeter Wemm if ((n < 0) || !res_dnok(bp)) 2121363f04cSPaul Traina break; 2131363f04cSPaul Traina cp += n; 2141363f04cSPaul Traina ans[0] = '\0'; 2153c8e19e1SWarner Losh (void)strncpy(&ans[0], bp, sizeof(ans) - 1); 2163c8e19e1SWarner Losh ans[sizeof(ans) - 1] = '\0'; 2171363f04cSPaul Traina GETSHORT(type, cp); 2181363f04cSPaul Traina GETSHORT(class, cp); 2191363f04cSPaul Traina cp += INT32SZ; /* TTL */ 2201363f04cSPaul Traina GETSHORT(n, cp); 2211363f04cSPaul Traina if (class == C_IN && type == T_PTR) { 222d6af58f5SWarner Losh n = dn_expand(answer->buf, eom, cp, bp, ep - bp); 2235ce1c533SPeter Wemm if ((n < 0) || !res_hnok(bp)) { 2241363f04cSPaul Traina cp += n; 225a2a77501SHajimu UMEMOTO return -1; 2261363f04cSPaul Traina } 2271363f04cSPaul Traina cp += n; 2281363f04cSPaul Traina *ap++ = bp; 2294cbd2472SWarner Losh n = strlen(bp) + 1; 2304cbd2472SWarner Losh bp += n; 231a2a77501SHajimu UMEMOTO ne->n_addrtype = (class == C_IN) ? AF_INET : AF_UNSPEC; 2321363f04cSPaul Traina haveanswer++; 2331363f04cSPaul Traina } 2341363f04cSPaul Traina } 2351363f04cSPaul Traina if (haveanswer) { 2361363f04cSPaul Traina *ap = NULL; 2371363f04cSPaul Traina switch (net_i) { 2381363f04cSPaul Traina case BYADDR: 239a2a77501SHajimu UMEMOTO ne->n_name = *ne->n_aliases; 240a2a77501SHajimu UMEMOTO ne->n_net = 0L; 2411363f04cSPaul Traina break; 2421363f04cSPaul Traina case BYNAME: 243a2a77501SHajimu UMEMOTO in = *ne->n_aliases; 244a2a77501SHajimu UMEMOTO n = strlen(ans) + 1; 245a2a77501SHajimu UMEMOTO if (ep - bp < n) { 246a2a77501SHajimu UMEMOTO h_errno = NETDB_INTERNAL; 247a2a77501SHajimu UMEMOTO errno = ENOBUFS; 248a2a77501SHajimu UMEMOTO return -1; 249a2a77501SHajimu UMEMOTO } 250a2a77501SHajimu UMEMOTO strlcpy(bp, ans, ep - bp); 251a2a77501SHajimu UMEMOTO ne->n_name = bp; 252a54c3906SDiomidis Spinellis if (strlen(in) + 1 > sizeof(aux)) { 253a54c3906SDiomidis Spinellis h_errno = NETDB_INTERNAL; 254a54c3906SDiomidis Spinellis errno = ENOBUFS; 255a2a77501SHajimu UMEMOTO return -1; 2561363f04cSPaul Traina } 257a54c3906SDiomidis Spinellis ipreverse(in, aux); 258a2a77501SHajimu UMEMOTO ne->n_net = inet_network(aux); 2594faad310SPeter Wemm break; 2601363f04cSPaul Traina } 261a2a77501SHajimu UMEMOTO ne->n_aliases++; 262036ae3ddSHajimu UMEMOTO #if __LONG_BIT == 64 263036ae3ddSHajimu UMEMOTO ne->__n_pad0 = 0; /* ABI compatibility */ 264036ae3ddSHajimu UMEMOTO #endif 265a2a77501SHajimu UMEMOTO return 0; 2661363f04cSPaul Traina } 2674faad310SPeter Wemm h_errno = TRY_AGAIN; 268a2a77501SHajimu UMEMOTO return -1; 2691363f04cSPaul Traina } 2701363f04cSPaul Traina 271248aee62SJacques Vidrine int 272248aee62SJacques Vidrine _dns_getnetbyaddr(void *rval, void *cb_data, va_list ap) 2731363f04cSPaul Traina { 274036ae3ddSHajimu UMEMOTO uint32_t net; 275248aee62SJacques Vidrine int net_type; 276a2a77501SHajimu UMEMOTO struct netent *ne; 277a2a77501SHajimu UMEMOTO struct netent_data *ned; 2781363f04cSPaul Traina unsigned int netbr[4]; 279a2a77501SHajimu UMEMOTO int nn, anslen, error; 280a52b6b83SHajimu UMEMOTO querybuf *buf; 2811363f04cSPaul Traina char qbuf[MAXDNAME]; 282036ae3ddSHajimu UMEMOTO uint32_t net2; 2831363f04cSPaul Traina 284036ae3ddSHajimu UMEMOTO net = va_arg(ap, uint32_t); 285248aee62SJacques Vidrine net_type = va_arg(ap, int); 286a2a77501SHajimu UMEMOTO ne = va_arg(ap, struct netent *); 287a2a77501SHajimu UMEMOTO ned = va_arg(ap, struct netent_data *); 288248aee62SJacques Vidrine 2891363f04cSPaul Traina if (net_type != AF_INET) 290248aee62SJacques Vidrine return NS_UNAVAIL; 2911363f04cSPaul Traina 2924faad310SPeter Wemm for (nn = 4, net2 = net; net2; net2 >>= 8) 2931363f04cSPaul Traina netbr[--nn] = net2 & 0xff; 2941363f04cSPaul Traina switch (nn) { 2951363f04cSPaul Traina case 3: /* Class A */ 2964faad310SPeter Wemm sprintf(qbuf, "0.0.0.%u.in-addr.arpa", netbr[3]); 2971363f04cSPaul Traina break; 2981363f04cSPaul Traina case 2: /* Class B */ 2994faad310SPeter Wemm sprintf(qbuf, "0.0.%u.%u.in-addr.arpa", netbr[3], netbr[2]); 3001363f04cSPaul Traina break; 3011363f04cSPaul Traina case 1: /* Class C */ 3024faad310SPeter Wemm sprintf(qbuf, "0.%u.%u.%u.in-addr.arpa", netbr[3], netbr[2], 3034faad310SPeter Wemm netbr[1]); 3041363f04cSPaul Traina break; 3051363f04cSPaul Traina case 0: /* Class D - E */ 3064faad310SPeter Wemm sprintf(qbuf, "%u.%u.%u.%u.in-addr.arpa", netbr[3], netbr[2], 3074faad310SPeter Wemm netbr[1], netbr[0]); 3081363f04cSPaul Traina break; 3091363f04cSPaul Traina } 310a52b6b83SHajimu UMEMOTO if ((buf = malloc(sizeof(*buf))) == NULL) { 311a52b6b83SHajimu UMEMOTO h_errno = NETDB_INTERNAL; 312a52b6b83SHajimu UMEMOTO return NS_NOTFOUND; 313a52b6b83SHajimu UMEMOTO } 314a52b6b83SHajimu UMEMOTO anslen = res_query(qbuf, C_IN, T_PTR, (u_char *)buf, sizeof(*buf)); 3151363f04cSPaul Traina if (anslen < 0) { 316a52b6b83SHajimu UMEMOTO free(buf); 3174faad310SPeter Wemm #ifdef DEBUG 3181363f04cSPaul Traina if (_res.options & RES_DEBUG) 31954384cf3SJacques Vidrine printf("res_search failed\n"); 32054384cf3SJacques Vidrine #endif 32154384cf3SJacques Vidrine return NS_UNAVAIL; 322a52b6b83SHajimu UMEMOTO } else if (anslen > sizeof(*buf)) { 323a52b6b83SHajimu UMEMOTO free(buf); 32454384cf3SJacques Vidrine #ifdef DEBUG 32554384cf3SJacques Vidrine if (_res.options & RES_DEBUG) 3267922d4cfSJacques Vidrine printf("res_search static buffer too small\n"); 3274faad310SPeter Wemm #endif 328248aee62SJacques Vidrine return NS_UNAVAIL; 3291363f04cSPaul Traina } 330a2a77501SHajimu UMEMOTO error = getnetanswer(buf, anslen, BYADDR, ne, ned); 331a52b6b83SHajimu UMEMOTO free(buf); 332a2a77501SHajimu UMEMOTO if (error == 0) { 3331363f04cSPaul Traina /* Strip trailing zeros */ 334036ae3ddSHajimu UMEMOTO while ((net & 0xff) == 0 && net != 0) 335036ae3ddSHajimu UMEMOTO net >>= 8; 336036ae3ddSHajimu UMEMOTO ne->n_net = net; 337036ae3ddSHajimu UMEMOTO #if __LONG_BIT == 64 338036ae3ddSHajimu UMEMOTO ne->__n_pad0 = 0; /* ABI compatibility */ 339036ae3ddSHajimu UMEMOTO #endif 340248aee62SJacques Vidrine return NS_SUCCESS; 3411363f04cSPaul Traina } 342248aee62SJacques Vidrine return NS_NOTFOUND; 3434faad310SPeter Wemm } 3441363f04cSPaul Traina 345248aee62SJacques Vidrine int 346248aee62SJacques Vidrine _dns_getnetbyname(void *rval, void *cb_data, va_list ap) 3471363f04cSPaul Traina { 348248aee62SJacques Vidrine const char *net; 349a2a77501SHajimu UMEMOTO struct netent *ne; 350a2a77501SHajimu UMEMOTO struct netent_data *ned; 351a2a77501SHajimu UMEMOTO int anslen, error; 352a52b6b83SHajimu UMEMOTO querybuf *buf; 3531363f04cSPaul Traina char qbuf[MAXDNAME]; 3541363f04cSPaul Traina 355248aee62SJacques Vidrine net = va_arg(ap, const char *); 356a2a77501SHajimu UMEMOTO ne = va_arg(ap, struct netent *); 357a2a77501SHajimu UMEMOTO ned = va_arg(ap, struct netent_data *); 358248aee62SJacques Vidrine 3594faad310SPeter Wemm if ((_res.options & RES_INIT) == 0 && res_init() == -1) { 3604faad310SPeter Wemm h_errno = NETDB_INTERNAL; 361248aee62SJacques Vidrine return NS_UNAVAIL; 3624faad310SPeter Wemm } 363a52b6b83SHajimu UMEMOTO if ((buf = malloc(sizeof(*buf))) == NULL) { 364a52b6b83SHajimu UMEMOTO h_errno = NETDB_INTERNAL; 365a52b6b83SHajimu UMEMOTO return NS_NOTFOUND; 366a52b6b83SHajimu UMEMOTO } 3673c8e19e1SWarner Losh strncpy(qbuf, net, sizeof(qbuf) - 1); 3683c8e19e1SWarner Losh qbuf[sizeof(qbuf) - 1] = '\0'; 369a52b6b83SHajimu UMEMOTO anslen = res_search(qbuf, C_IN, T_PTR, (u_char *)buf, sizeof(*buf)); 3701363f04cSPaul Traina if (anslen < 0) { 371a52b6b83SHajimu UMEMOTO free(buf); 3724faad310SPeter Wemm #ifdef DEBUG 3731363f04cSPaul Traina if (_res.options & RES_DEBUG) 37454384cf3SJacques Vidrine printf("res_search failed\n"); 37554384cf3SJacques Vidrine #endif 37654384cf3SJacques Vidrine return NS_UNAVAIL; 377a52b6b83SHajimu UMEMOTO } else if (anslen > sizeof(*buf)) { 378a52b6b83SHajimu UMEMOTO free(buf); 37954384cf3SJacques Vidrine #ifdef DEBUG 38054384cf3SJacques Vidrine if (_res.options & RES_DEBUG) 3817922d4cfSJacques Vidrine printf("res_search static buffer too small\n"); 3824faad310SPeter Wemm #endif 383248aee62SJacques Vidrine return NS_UNAVAIL; 3841363f04cSPaul Traina } 385a2a77501SHajimu UMEMOTO error = getnetanswer(buf, anslen, BYNAME, ne, ned); 386a52b6b83SHajimu UMEMOTO free(buf); 387a2a77501SHajimu UMEMOTO return (error == 0) ? NS_SUCCESS : NS_NOTFOUND; 3881363f04cSPaul Traina } 3891363f04cSPaul Traina 3901363f04cSPaul Traina void 3911363f04cSPaul Traina _setnetdnsent(stayopen) 3921363f04cSPaul Traina int stayopen; 3931363f04cSPaul Traina { 3941363f04cSPaul Traina if (stayopen) 3951363f04cSPaul Traina _res.options |= RES_STAYOPEN | RES_USEVC; 3961363f04cSPaul Traina } 3971363f04cSPaul Traina 3981363f04cSPaul Traina void 3991363f04cSPaul Traina _endnetdnsent() 4001363f04cSPaul Traina { 4011363f04cSPaul Traina _res.options &= ~(RES_STAYOPEN | RES_USEVC); 402ca785773SPeter Wemm res_close(); 4031363f04cSPaul Traina } 404