diff options
author | Denis Vlasenko <vda.linux@googlemail.com> | 2008-11-14 00:35:40 +0000 |
---|---|---|
committer | Denis Vlasenko <vda.linux@googlemail.com> | 2008-11-14 00:35:40 +0000 |
commit | 97a8f9f4dc1f94060b74943d9887cffed268b21b (patch) | |
tree | ccadfe75a8f4332e1ff7e38fb7bb4d7400acb59b /libc/inet/resolv.c | |
parent | 676ddd7a30ee8cef3796c51bc922fd76166cbfc9 (diff) |
fixing resolver part 2: make _res structure members
configurable. we don't use most of it anyway.
Diffstat (limited to 'libc/inet/resolv.c')
-rw-r--r-- | libc/inet/resolv.c | 28 |
1 files changed, 17 insertions, 11 deletions
diff --git a/libc/inet/resolv.c b/libc/inet/resolv.c index 7ef2fba45..b7ab27690 100644 --- a/libc/inet/resolv.c +++ b/libc/inet/resolv.c @@ -1255,20 +1255,26 @@ int res_init(void) __UCLIBC_MUTEX_LOCK(__resolv_lock); /* must be a recursive lock! */ __close_nameservers(); __open_nameservers(); + memset(rp, 0, sizeof(*rp)); + rp->options = RES_INIT; +#ifdef __UCLIBC_HAS_COMPAT_RES_STATE__ rp->retrans = RES_TIMEOUT; rp->retry = 4; - rp->options = RES_INIT; - rp->id = (u_int) random(); - rp->nsaddr.sin_addr.s_addr = INADDR_ANY; - rp->nsaddr.sin_family = AF_INET; - rp->nsaddr.sin_port = htons(NAMESERVER_PORT); + rp->id = random(); +#endif + /* man resolv.conf says: + * "On a normally configured system this file should not be necessary. + * The only name server to be queried will be on the local machine; + * the domain name is determined from the host name + * and the domain search path is constructed from the domain name" */ + rp->nscount = 1; + rp->nsaddr_list[0].sin_addr.s_addr = INADDR_ANY; + rp->nsaddr_list[0].sin_family = AF_INET; + rp->nsaddr_list[0].sin_port = htons(NAMESERVER_PORT); rp->ndots = 1; - /** rp->pfcode = 0; **/ +#ifdef __UCLIBC_HAS_EXTRA_COMPAT_RES_STATE__ rp->_vcsock = -1; - /** rp->_flags = 0; **/ - /** rp->qhook = NULL; **/ - /** rp->rhook = NULL; **/ - /** rp->_u._ext.nsinit = 0; **/ +#endif if (__searchdomains) { int i; @@ -1286,8 +1292,8 @@ int res_init(void) rp->nsaddr_list[i].sin_port = htons(NAMESERVER_PORT); } } + rp->nscount = __nameservers; } - rp->nscount = __nameservers; __UCLIBC_MUTEX_UNLOCK(__resolv_lock); return 0; |