* nss/bug-erange.c: New file.

* nss/Makefile (tests): Add it.
This commit is contained in:
Roland McGrath 2002-09-12 01:44:33 +00:00
parent f8494ee354
commit 049e7c97d6
3 changed files with 48 additions and 1 deletions

View File

@ -1,5 +1,8 @@
2002-09-11 Roland McGrath <roland@redhat.com> 2002-09-11 Roland McGrath <roland@redhat.com>
* nss/bug-erange.c: New file.
* nss/Makefile (tests): Add it.
* nss/getXXbyYY_r.c (INTERNAL (REENTRANT_NAME)): Return errno * nss/getXXbyYY_r.c (INTERNAL (REENTRANT_NAME)): Return errno
instead of always EAGAIN when status is NSS_STATUS_TRYAGAIN. instead of always EAGAIN when status is NSS_STATUS_TRYAGAIN.

View File

@ -39,7 +39,7 @@ databases = proto service hosts network grp pwd rpc ethers \
others := getent others := getent
install-bin := getent install-bin := getent
tests = test-netdb tests = test-netdb bug-erange
include ../Makeconfig include ../Makeconfig

44
nss/bug-erange.c Normal file
View File

@ -0,0 +1,44 @@
/* Test case for gethostbyname_r bug when buffer expansion required. */
#include <netdb.h>
#include <arpa/inet.h>
#include <errno.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
int
main (void)
{
const char *host = "www.gnu.org";
/* This code approximates the example code in the library manual. */
struct hostent hostbuf, *hp;
size_t hstbuflen;
char *tmphstbuf;
int res;
int herr;
hstbuflen = 16; /* Make it way small to ensure ERANGE. */
/* Allocate buffer, remember to free it to avoid memory leakage. */
tmphstbuf = malloc (hstbuflen);
while ((res = gethostbyname_r (host, &hostbuf, tmphstbuf, hstbuflen,
&hp, &herr)) == ERANGE)
{
/* Enlarge the buffer. */
hstbuflen *= 2;
tmphstbuf = realloc (tmphstbuf, hstbuflen);
}
if (res != 0 || hp == NULL)
{
printf ("gethostbyname_r failed: %s (errno: %m)\n", strerror (res));
return 1;
}
printf ("Got: %s %s\n", hp->h_name,
inet_ntoa (*(struct in_addr *) hp->h_addr));
return 0;
}