2004-08-15 Ulrich Drepper <drepper@redhat.com>
+ * sysdeps/posix/getaddrinfo.c (gaih_inet): Optimize generation of
+ v4-mapped addresses a bit.
+ (gethosts): Move alloca out of macro, so that it is done only once.
+
* sysdeps/posix/getaddrinfo.c (gaih_addrtuple): Change type of
addr to avoid casts.
(gethosts): Removed.
#define gethosts(_family, _type) \
{ \
- int i, herrno; \
- size_t tmpbuflen; \
+ int i; \
+ int herrno; \
struct hostent th; \
- char *tmpbuf = NULL; \
- tmpbuflen = 512; \
no_data = 0; \
- do { \
- tmpbuf = extend_alloca (tmpbuf, tmpbuflen, 2 * tmpbuflen); \
+ while (1) { \
rc = 0; \
status = DL_CALL_FCT (fct, (name, _family, &th, tmpbuf, \
tmpbuflen, &rc, &herrno)); \
- } while (rc == ERANGE && herrno == NETDB_INTERNAL); \
+ if (rc != ERANGE || herrno != NETDB_INTERNAL) \
+ break; \
+ tmpbuf = extend_alloca (tmpbuf, tmpbuflen, 2 * tmpbuflen); \
+ } \
if (status == NSS_STATUS_SUCCESS && rc == 0) \
h = &th; \
else \
int no_more;
nss_gethostbyname2_r fct;
int old_res_options;
+ size_t tmpbuflen = 512;
+ char *tmpbuf = alloca (tmpbuflen);
if (__nss_hosts_database != NULL)
{
if (req->ai_family == AF_INET
|| req->ai_family == AF_UNSPEC
|| (req->ai_family == AF_INET6
- && (req->ai_flags & AI_V4MAPPED)))
+ && (req->ai_flags & AI_V4MAPPED)
+ /* Avoid generating the mapped addresses if we
+ know we are not going to need them. */
+ && ((req->ai_flags & AI_ALL) || !got_ipv6)))
{
gethosts (AF_INET, struct in_addr);