diff options
author | Ulrich Drepper <drepper@redhat.com> | 2004-09-18 23:57:46 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2004-09-18 23:57:46 +0000 |
commit | d72433621f75bce7281adb7060459f6918287926 (patch) | |
tree | 4f261bb2474ac0af7fdc45b167ab8a4a3be165c7 | |
parent | 1ab1fa6fb741caf552f2f1d79467d2455655d02b (diff) | |
download | glibc-d72433621f75bce7281adb7060459f6918287926.zip glibc-d72433621f75bce7281adb7060459f6918287926.tar.gz glibc-d72433621f75bce7281adb7060459f6918287926.tar.bz2 |
Update.
* sysdeps/posix/getaddrinfo.c (gaih_inet): Do not use
gethostbyname3_r if we are not looking for the canonical name.
-rw-r--r-- | ChangeLog | 3 | ||||
-rw-r--r-- | sysdeps/posix/getaddrinfo.c | 9 |
2 files changed, 10 insertions, 2 deletions
@@ -1,5 +1,8 @@ 2004-09-18 Ulrich Drepper <drepper@redhat.com> + * sysdeps/posix/getaddrinfo.c (gaih_inet): Do not use + gethostbyname3_r if we are not looking for the canonical name. + * resolv/res_mkquery.c (res_nmkquery): Randomize request ID every time. diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c index f9d0bf4..b3f9f4f 100644 --- a/sysdeps/posix/getaddrinfo.c +++ b/sysdeps/posix/getaddrinfo.c @@ -775,8 +775,13 @@ gaih_inet (const char *name, const struct gaih_service *service, while (!no_more) { - nss_gethostbyname3_r fct - = __nss_lookup_function (nip, "gethostbyname3_r"); + nss_gethostbyname3_r fct = NULL; + if (req->ai_flags & AI_CANONNAME) + /* No need to use this function if we do not look for + the canonical name. The function does not exist in + all NSS modules and therefore the lookup would + often fail. */ + fct = __nss_lookup_function (nip, "gethostbyname3_r"); if (fct == NULL) /* We are cheating here. The gethostbyname2_r function does not have the same interface as gethostbyname3_r but the |