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 854faad310SPeter Wemm #include "res_config.h" 861363f04cSPaul Traina 874faad310SPeter Wemm extern int h_errno; 884faad310SPeter Wemm 894faad310SPeter Wemm #define BYADDR 0 904faad310SPeter Wemm #define BYNAME 1 911363f04cSPaul Traina #define MAXALIASES 35 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 */ 110a54c3906SDiomidis Spinellis static int 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 1611363f04cSPaul Traina static struct netent * 1621363f04cSPaul Traina getnetanswer(answer, anslen, net_i) 1631363f04cSPaul Traina querybuf *answer; 1641363f04cSPaul Traina int anslen; 1651363f04cSPaul Traina int net_i; 1661363f04cSPaul Traina { 1671363f04cSPaul Traina 1688fb3f3f6SDavid E. O'Brien HEADER *hp; 1698fb3f3f6SDavid E. O'Brien u_char *cp; 1708fb3f3f6SDavid E. O'Brien int n; 1711363f04cSPaul Traina u_char *eom; 172d6af58f5SWarner Losh int type, class, ancount, qdcount, haveanswer, i, nchar; 173a54c3906SDiomidis Spinellis char aux[MAXHOSTNAMELEN]; 174a54c3906SDiomidis Spinellis char *in, *bp, *ep, **ap; 1751363f04cSPaul Traina static struct netent net_entry; 1766c5aff80SPeter Wemm static char *net_aliases[MAXALIASES], netbuf[PACKETSZ]; 177a54c3906SDiomidis Spinellis static char ans[MAXHOSTNAMELEN]; 1781363f04cSPaul Traina 1791363f04cSPaul Traina /* 1801363f04cSPaul Traina * find first satisfactory answer 1811363f04cSPaul Traina * 1821363f04cSPaul Traina * answer --> +------------+ ( MESSAGE ) 1831363f04cSPaul Traina * | Header | 1841363f04cSPaul Traina * +------------+ 1851363f04cSPaul Traina * | Question | the question for the name server 1861363f04cSPaul Traina * +------------+ 1871363f04cSPaul Traina * | Answer | RRs answering the question 1881363f04cSPaul Traina * +------------+ 1891363f04cSPaul Traina * | Authority | RRs pointing toward an authority 1901363f04cSPaul Traina * | Additional | RRs holding additional information 1911363f04cSPaul Traina * +------------+ 1921363f04cSPaul Traina */ 1931363f04cSPaul Traina eom = answer->buf + anslen; 1941363f04cSPaul Traina hp = &answer->hdr; 1951363f04cSPaul Traina ancount = ntohs(hp->ancount); /* #/records in the answer section */ 1961363f04cSPaul Traina qdcount = ntohs(hp->qdcount); /* #/entries in the question section */ 1971363f04cSPaul Traina bp = netbuf; 1989a370b24SJacques Vidrine ep = netbuf + sizeof(netbuf); 1991363f04cSPaul Traina cp = answer->buf + HFIXEDSZ; 2001363f04cSPaul Traina if (!qdcount) { 2011363f04cSPaul Traina if (hp->aa) 2021363f04cSPaul Traina h_errno = HOST_NOT_FOUND; 2031363f04cSPaul Traina else 2041363f04cSPaul Traina h_errno = TRY_AGAIN; 2054faad310SPeter Wemm return (NULL); 2061363f04cSPaul Traina } 2074faad310SPeter Wemm while (qdcount-- > 0) 2081363f04cSPaul Traina cp += __dn_skipname(cp, eom) + QFIXEDSZ; 2091363f04cSPaul Traina ap = net_aliases; 2101363f04cSPaul Traina *ap = NULL; 2111363f04cSPaul Traina net_entry.n_aliases = net_aliases; 2121363f04cSPaul Traina haveanswer = 0; 2131363f04cSPaul Traina while (--ancount >= 0 && cp < eom) { 214d6af58f5SWarner Losh n = dn_expand(answer->buf, eom, cp, bp, ep - bp); 2155ce1c533SPeter Wemm if ((n < 0) || !res_dnok(bp)) 2161363f04cSPaul Traina break; 2171363f04cSPaul Traina cp += n; 2181363f04cSPaul Traina ans[0] = '\0'; 2193c8e19e1SWarner Losh (void)strncpy(&ans[0], bp, sizeof(ans) - 1); 2203c8e19e1SWarner Losh ans[sizeof(ans) - 1] = '\0'; 2211363f04cSPaul Traina GETSHORT(type, cp); 2221363f04cSPaul Traina GETSHORT(class, cp); 2231363f04cSPaul Traina cp += INT32SZ; /* TTL */ 2241363f04cSPaul Traina GETSHORT(n, cp); 2251363f04cSPaul Traina if (class == C_IN && type == T_PTR) { 226d6af58f5SWarner Losh n = dn_expand(answer->buf, eom, cp, bp, ep - bp); 2275ce1c533SPeter Wemm if ((n < 0) || !res_hnok(bp)) { 2281363f04cSPaul Traina cp += n; 2291363f04cSPaul Traina return (NULL); 2301363f04cSPaul Traina } 2311363f04cSPaul Traina cp += n; 2321363f04cSPaul Traina *ap++ = bp; 2334cbd2472SWarner Losh n = strlen(bp) + 1; 2344cbd2472SWarner Losh bp += n; 2354faad310SPeter Wemm net_entry.n_addrtype = 2364faad310SPeter Wemm (class == C_IN) ? AF_INET : AF_UNSPEC; 2371363f04cSPaul Traina haveanswer++; 2381363f04cSPaul Traina } 2391363f04cSPaul Traina } 2401363f04cSPaul Traina if (haveanswer) { 2411363f04cSPaul Traina *ap = NULL; 2421363f04cSPaul Traina switch (net_i) { 2431363f04cSPaul Traina case BYADDR: 2441363f04cSPaul Traina net_entry.n_name = *net_entry.n_aliases; 2451363f04cSPaul Traina net_entry.n_net = 0L; 2461363f04cSPaul Traina break; 2471363f04cSPaul Traina case BYNAME: 2481363f04cSPaul Traina in = *net_entry.n_aliases; 2491363f04cSPaul Traina net_entry.n_name = &ans[0]; 250a54c3906SDiomidis Spinellis if (strlen(in) + 1 > sizeof(aux)) { 251a54c3906SDiomidis Spinellis h_errno = NETDB_INTERNAL; 252a54c3906SDiomidis Spinellis errno = ENOBUFS; 253a54c3906SDiomidis Spinellis return (NULL); 2541363f04cSPaul Traina } 255a54c3906SDiomidis Spinellis ipreverse(in, aux); 256a54c3906SDiomidis Spinellis net_entry.n_net = inet_network(aux); 2574faad310SPeter Wemm break; 2581363f04cSPaul Traina } 2591363f04cSPaul Traina net_entry.n_aliases++; 2601363f04cSPaul Traina return (&net_entry); 2611363f04cSPaul Traina } 2624faad310SPeter Wemm h_errno = TRY_AGAIN; 2634faad310SPeter Wemm return (NULL); 2641363f04cSPaul Traina } 2651363f04cSPaul Traina 266248aee62SJacques Vidrine int 267248aee62SJacques Vidrine _dns_getnetbyaddr(void *rval, void *cb_data, va_list ap) 2681363f04cSPaul Traina { 269248aee62SJacques Vidrine unsigned long net; 270248aee62SJacques Vidrine int net_type; 2711363f04cSPaul Traina unsigned int netbr[4]; 2721363f04cSPaul Traina int nn, anslen; 273a52b6b83SHajimu UMEMOTO querybuf *buf; 2741363f04cSPaul Traina char qbuf[MAXDNAME]; 2751363f04cSPaul Traina unsigned long net2; 2761363f04cSPaul Traina struct netent *net_entry; 2771363f04cSPaul Traina 278248aee62SJacques Vidrine net = va_arg(ap, unsigned long); 279248aee62SJacques Vidrine net_type = va_arg(ap, int); 280248aee62SJacques Vidrine 281248aee62SJacques Vidrine *(struct netent **)rval = NULL; 282248aee62SJacques Vidrine 2831363f04cSPaul Traina if (net_type != AF_INET) 284248aee62SJacques Vidrine return NS_UNAVAIL; 2851363f04cSPaul Traina 2864faad310SPeter Wemm for (nn = 4, net2 = net; net2; net2 >>= 8) 2871363f04cSPaul Traina netbr[--nn] = net2 & 0xff; 2881363f04cSPaul Traina switch (nn) { 2891363f04cSPaul Traina case 3: /* Class A */ 2904faad310SPeter Wemm sprintf(qbuf, "0.0.0.%u.in-addr.arpa", netbr[3]); 2911363f04cSPaul Traina break; 2921363f04cSPaul Traina case 2: /* Class B */ 2934faad310SPeter Wemm sprintf(qbuf, "0.0.%u.%u.in-addr.arpa", netbr[3], netbr[2]); 2941363f04cSPaul Traina break; 2951363f04cSPaul Traina case 1: /* Class C */ 2964faad310SPeter Wemm sprintf(qbuf, "0.%u.%u.%u.in-addr.arpa", netbr[3], netbr[2], 2974faad310SPeter Wemm netbr[1]); 2981363f04cSPaul Traina break; 2991363f04cSPaul Traina case 0: /* Class D - E */ 3004faad310SPeter Wemm sprintf(qbuf, "%u.%u.%u.%u.in-addr.arpa", netbr[3], netbr[2], 3014faad310SPeter Wemm netbr[1], netbr[0]); 3021363f04cSPaul Traina break; 3031363f04cSPaul Traina } 304a52b6b83SHajimu UMEMOTO if ((buf = malloc(sizeof(*buf))) == NULL) { 305a52b6b83SHajimu UMEMOTO h_errno = NETDB_INTERNAL; 306a52b6b83SHajimu UMEMOTO return NS_NOTFOUND; 307a52b6b83SHajimu UMEMOTO } 308a52b6b83SHajimu UMEMOTO anslen = res_query(qbuf, C_IN, T_PTR, (u_char *)buf, sizeof(*buf)); 3091363f04cSPaul Traina if (anslen < 0) { 310a52b6b83SHajimu UMEMOTO free(buf); 3114faad310SPeter Wemm #ifdef DEBUG 3121363f04cSPaul Traina if (_res.options & RES_DEBUG) 31354384cf3SJacques Vidrine printf("res_search failed\n"); 31454384cf3SJacques Vidrine #endif 31554384cf3SJacques Vidrine return NS_UNAVAIL; 316a52b6b83SHajimu UMEMOTO } else if (anslen > sizeof(*buf)) { 317a52b6b83SHajimu UMEMOTO free(buf); 31854384cf3SJacques Vidrine #ifdef DEBUG 31954384cf3SJacques Vidrine if (_res.options & RES_DEBUG) 3207922d4cfSJacques Vidrine printf("res_search static buffer too small\n"); 3214faad310SPeter Wemm #endif 322248aee62SJacques Vidrine return NS_UNAVAIL; 3231363f04cSPaul Traina } 324a52b6b83SHajimu UMEMOTO net_entry = getnetanswer(buf, anslen, BYADDR); 325a52b6b83SHajimu UMEMOTO free(buf); 3261363f04cSPaul Traina if (net_entry) { 3271363f04cSPaul Traina unsigned u_net = net; /* maybe net should be unsigned ? */ 3281363f04cSPaul Traina 3291363f04cSPaul Traina /* Strip trailing zeros */ 3304faad310SPeter Wemm while ((u_net & 0xff) == 0 && u_net != 0) 3311363f04cSPaul Traina u_net >>= 8; 3321363f04cSPaul Traina net_entry->n_net = u_net; 333248aee62SJacques Vidrine *(struct netent **)rval = net_entry; 334248aee62SJacques Vidrine return NS_SUCCESS; 3351363f04cSPaul Traina } 336248aee62SJacques Vidrine return NS_NOTFOUND; 3374faad310SPeter Wemm } 3381363f04cSPaul Traina 339248aee62SJacques Vidrine int 340248aee62SJacques Vidrine _dns_getnetbyname(void *rval, void *cb_data, va_list ap) 3411363f04cSPaul Traina { 342248aee62SJacques Vidrine const char *net; 3431363f04cSPaul Traina int anslen; 344a52b6b83SHajimu UMEMOTO querybuf *buf; 3451363f04cSPaul Traina char qbuf[MAXDNAME]; 3461363f04cSPaul Traina 347248aee62SJacques Vidrine net = va_arg(ap, const char *); 348248aee62SJacques Vidrine 349248aee62SJacques Vidrine *(struct netent**)rval = NULL; 350248aee62SJacques Vidrine 3514faad310SPeter Wemm if ((_res.options & RES_INIT) == 0 && res_init() == -1) { 3524faad310SPeter Wemm h_errno = NETDB_INTERNAL; 353248aee62SJacques Vidrine return NS_UNAVAIL; 3544faad310SPeter Wemm } 355a52b6b83SHajimu UMEMOTO if ((buf = malloc(sizeof(*buf))) == NULL) { 356a52b6b83SHajimu UMEMOTO h_errno = NETDB_INTERNAL; 357a52b6b83SHajimu UMEMOTO return NS_NOTFOUND; 358a52b6b83SHajimu UMEMOTO } 3593c8e19e1SWarner Losh strncpy(qbuf, net, sizeof(qbuf) - 1); 3603c8e19e1SWarner Losh qbuf[sizeof(qbuf) - 1] = '\0'; 361a52b6b83SHajimu UMEMOTO anslen = res_search(qbuf, C_IN, T_PTR, (u_char *)buf, sizeof(*buf)); 3621363f04cSPaul Traina if (anslen < 0) { 363a52b6b83SHajimu UMEMOTO free(buf); 3644faad310SPeter Wemm #ifdef DEBUG 3651363f04cSPaul Traina if (_res.options & RES_DEBUG) 36654384cf3SJacques Vidrine printf("res_search failed\n"); 36754384cf3SJacques Vidrine #endif 36854384cf3SJacques Vidrine return NS_UNAVAIL; 369a52b6b83SHajimu UMEMOTO } else if (anslen > sizeof(*buf)) { 370a52b6b83SHajimu UMEMOTO free(buf); 37154384cf3SJacques Vidrine #ifdef DEBUG 37254384cf3SJacques Vidrine if (_res.options & RES_DEBUG) 3737922d4cfSJacques Vidrine printf("res_search static buffer too small\n"); 3744faad310SPeter Wemm #endif 375248aee62SJacques Vidrine return NS_UNAVAIL; 3761363f04cSPaul Traina } 377a52b6b83SHajimu UMEMOTO *(struct netent**)rval = getnetanswer(buf, anslen, BYNAME); 378a52b6b83SHajimu UMEMOTO free(buf); 379248aee62SJacques Vidrine return (*(struct netent**)rval != NULL) ? NS_SUCCESS : NS_NOTFOUND; 3801363f04cSPaul Traina } 3811363f04cSPaul Traina 3821363f04cSPaul Traina void 3831363f04cSPaul Traina _setnetdnsent(stayopen) 3841363f04cSPaul Traina int stayopen; 3851363f04cSPaul Traina { 3861363f04cSPaul Traina if (stayopen) 3871363f04cSPaul Traina _res.options |= RES_STAYOPEN | RES_USEVC; 3881363f04cSPaul Traina } 3891363f04cSPaul Traina 3901363f04cSPaul Traina void 3911363f04cSPaul Traina _endnetdnsent() 3921363f04cSPaul Traina { 3931363f04cSPaul Traina _res.options &= ~(RES_STAYOPEN | RES_USEVC); 394ca785773SPeter Wemm res_close(); 3951363f04cSPaul Traina } 396