diff options
author | Ulrich Drepper <drepper@redhat.com> | 1998-04-29 17:14:29 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 1998-04-29 17:14:29 +0000 |
commit | b062f051ec5678a1f056656601715c9d047e6fc2 (patch) | |
tree | 71c7f38a076d8fe0249b4df681c3dbf493d499e9 /resolv/inet_addr.c | |
parent | d079f32126a4d1005a646dd907b4c791df7b0934 (diff) | |
download | glibc-b062f051ec5678a1f056656601715c9d047e6fc2.tar glibc-b062f051ec5678a1f056656601715c9d047e6fc2.tar.gz glibc-b062f051ec5678a1f056656601715c9d047e6fc2.tar.bz2 glibc-b062f051ec5678a1f056656601715c9d047e6fc2.zip |
Update.
1998-04-23 07:31 H.J. Lu <hjl@gnu.org>
* resolv/inet_addr.c (inet_aton): Use __strtoul_internal to
check overflow.
* resolv/Makefile (tests): New, add tst-aton.
* resolv/tst-aton.c: New file.
1998-04-29 Ulrich Drepper <drepper@cygnus.com>
* sysdeps/sparc/sparc32/dl-machine.h (WEAKADDR): Add missing
semicolon.
* sysdeps/unix/sysv/linux/alpha/bits/signum.h: Add SIGCLD definition.
Diffstat (limited to 'resolv/inet_addr.c')
-rw-r--r-- | resolv/inet_addr.c | 24 |
1 files changed, 22 insertions, 2 deletions
diff --git a/resolv/inet_addr.c b/resolv/inet_addr.c index 7e38af223f..635dd4596d 100644 --- a/resolv/inet_addr.c +++ b/resolv/inet_addr.c @@ -63,6 +63,11 @@ static char rcsid[] = "$Id$"; #include <netinet/in.h> #include <arpa/inet.h> #include <ctype.h> +#ifdef _LIBC +# include <stdlib.h> +# include <limits.h> +# include <errno.h> +#endif #include "../conf/portability.h" /* these are compatibility routines, not needed on recent BSD releases */ @@ -91,7 +96,7 @@ inet_addr(cp) */ int inet_aton(cp, addr) - register const char *cp; + const char *cp; struct in_addr *addr; { register u_int32_t val; /* changed from u_long --david */ @@ -99,7 +104,11 @@ inet_aton(cp, addr) register char c; u_int parts[4]; register u_int *pp = parts; +#ifdef _LIBC + int saved_errno = errno; + __set_errno (0); +#endif c = *cp; for (;;) { /* @@ -109,7 +118,7 @@ inet_aton(cp, addr) */ if (!isdigit(c)) return (0); - val = 0; base = 10; + base = 10; if (c == '0') { c = *++cp; if (c == 'x' || c == 'X') @@ -117,6 +126,16 @@ inet_aton(cp, addr) else base = 8; } +#ifdef _LIBC + val = strtoul (cp, (char **) &cp, base); + if (val == ULONG_MAX && errno == ERANGE) + { + __set_errno (saved_errno); + return 0; + } + c = *cp; +#else + val = 0; for (;;) { if (isascii(c) && isdigit(c)) { val = (val * base) + (c - '0'); @@ -128,6 +147,7 @@ inet_aton(cp, addr) } else break; } +#endif if (c == '.') { /* * Internet format: |