From: Ulrich Drepper Date: Sat, 25 Jul 2009 19:29:04 +0000 (-0700) Subject: Handle missing NSS modules and those without callbacks. X-Git-Tag: upstream/2.30~13416 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=657317537c09b82a2feb1194fda045f63e3a1222;p=external%2Fglibc.git Handle missing NSS modules and those without callbacks. getaddrinfo didn't update the status variable in that round of the loop if no callback was used. --- diff --git a/ChangeLog b/ChangeLog index 8246614..f47b089 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,9 @@ 2009-07-25 Ulrich Drepper + [BZ #10448] + * sysdeps/posix/getaddrinfo.c (gaih_inet): If NSS module contains no + callback we must touch the status to avoid using stale value. + * sysdeps/x86_64/multiarch/strcmp.S: Exclude unused code from being compiled in. diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c index d346c62..a788d18 100644 --- a/sysdeps/posix/getaddrinfo.c +++ b/sysdeps/posix/getaddrinfo.c @@ -833,6 +833,8 @@ gaih_inet (const char *name, const struct gaih_service *service, && inet6_status != NSS_STATUS_UNAVAIL) status = inet6_status; } + else + status = NSS_STATUS_UNAVAIL; } if (nss_next_action (nip, status) == NSS_ACTION_RETURN)