|
|
00db10 |
commit 5e30b8ef0758763effa115634e0ed7d8938e4bc0
|
|
|
00db10 |
Author: Florian Weimer <fweimer@redhat.com>
|
|
|
00db10 |
Date: Mon Jan 21 08:59:42 2019 +0100
|
|
|
00db10 |
|
|
|
00db10 |
resolv: Reformat inet_addr, inet_aton to GNU style
|
|
|
00db10 |
|
|
|
00db10 |
diff --git a/resolv/inet_addr.c b/resolv/inet_addr.c
|
|
|
00db10 |
index 022f7ea0841b6bae..32f58b0e13598b32 100644
|
|
|
00db10 |
--- a/resolv/inet_addr.c
|
|
|
00db10 |
+++ b/resolv/inet_addr.c
|
|
|
00db10 |
@@ -1,3 +1,21 @@
|
|
|
00db10 |
+/* Legacy IPv4 text-to-address functions.
|
|
|
00db10 |
+ Copyright (C) 2019 Free Software Foundation, Inc.
|
|
|
00db10 |
+ This file is part of the GNU C Library.
|
|
|
00db10 |
+
|
|
|
00db10 |
+ The GNU C Library is free software; you can redistribute it and/or
|
|
|
00db10 |
+ modify it under the terms of the GNU Lesser General Public
|
|
|
00db10 |
+ License as published by the Free Software Foundation; either
|
|
|
00db10 |
+ version 2.1 of the License, or (at your option) any later version.
|
|
|
00db10 |
+
|
|
|
00db10 |
+ The GNU C Library is distributed in the hope that it will be useful,
|
|
|
00db10 |
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
00db10 |
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
00db10 |
+ Lesser General Public License for more details.
|
|
|
00db10 |
+
|
|
|
00db10 |
+ You should have received a copy of the GNU Lesser General Public
|
|
|
00db10 |
+ License along with the GNU C Library; if not, see
|
|
|
00db10 |
+ <http://www.gnu.org/licenses/>. */
|
|
|
00db10 |
+
|
|
|
00db10 |
/*
|
|
|
00db10 |
* Copyright (c) 1983, 1990, 1993
|
|
|
00db10 |
* The Regents of the University of California. All rights reserved.
|
|
|
00db10 |
@@ -78,105 +96,97 @@
|
|
|
00db10 |
#include <limits.h>
|
|
|
00db10 |
#include <errno.h>
|
|
|
00db10 |
|
|
|
00db10 |
-/*
|
|
|
00db10 |
- * Ascii internet address interpretation routine.
|
|
|
00db10 |
- * The value returned is in network order.
|
|
|
00db10 |
- */
|
|
|
00db10 |
+/* ASCII IPv4 Internet address interpretation routine. The value
|
|
|
00db10 |
+ returned is in network order. */
|
|
|
00db10 |
in_addr_t
|
|
|
00db10 |
-__inet_addr(const char *cp) {
|
|
|
00db10 |
- struct in_addr val;
|
|
|
00db10 |
+__inet_addr (const char *cp)
|
|
|
00db10 |
+{
|
|
|
00db10 |
+ struct in_addr val;
|
|
|
00db10 |
|
|
|
00db10 |
- if (__inet_aton(cp, &val))
|
|
|
00db10 |
- return (val.s_addr);
|
|
|
00db10 |
- return (INADDR_NONE);
|
|
|
00db10 |
+ if (__inet_aton (cp, &val))
|
|
|
00db10 |
+ return val.s_addr;
|
|
|
00db10 |
+ return INADDR_NONE;
|
|
|
00db10 |
}
|
|
|
00db10 |
weak_alias (__inet_addr, inet_addr)
|
|
|
00db10 |
|
|
|
00db10 |
-/*
|
|
|
00db10 |
- * Check whether "cp" is a valid ascii representation
|
|
|
00db10 |
- * of an Internet address and convert to a binary address.
|
|
|
00db10 |
- * Returns 1 if the address is valid, 0 if not.
|
|
|
00db10 |
- * This replaces inet_addr, the return value from which
|
|
|
00db10 |
- * cannot distinguish between failure and a local broadcast address.
|
|
|
00db10 |
- */
|
|
|
00db10 |
+/* Check whether "cp" is a valid ASCII representation of an IPv4
|
|
|
00db10 |
+ Internet address and convert it to a binary address. Returns 1 if
|
|
|
00db10 |
+ the address is valid, 0 if not. This replaces inet_addr, the
|
|
|
00db10 |
+ return value from which cannot distinguish between failure and a
|
|
|
00db10 |
+ local broadcast address. */
|
|
|
00db10 |
int
|
|
|
00db10 |
-__inet_aton(const char *cp, struct in_addr *addr)
|
|
|
00db10 |
+__inet_aton (const char *cp, struct in_addr *addr)
|
|
|
00db10 |
{
|
|
|
00db10 |
- static const in_addr_t max[4] = { 0xffffffff, 0xffffff, 0xffff, 0xff };
|
|
|
00db10 |
- in_addr_t val;
|
|
|
00db10 |
- char c;
|
|
|
00db10 |
- union iaddr {
|
|
|
00db10 |
- uint8_t bytes[4];
|
|
|
00db10 |
- uint32_t word;
|
|
|
00db10 |
- } res;
|
|
|
00db10 |
- uint8_t *pp = res.bytes;
|
|
|
00db10 |
- int digit;
|
|
|
00db10 |
-
|
|
|
00db10 |
- int saved_errno = errno;
|
|
|
00db10 |
- __set_errno (0);
|
|
|
00db10 |
-
|
|
|
00db10 |
- res.word = 0;
|
|
|
00db10 |
-
|
|
|
00db10 |
- c = *cp;
|
|
|
00db10 |
- for (;;) {
|
|
|
00db10 |
- /*
|
|
|
00db10 |
- * Collect number up to ``.''.
|
|
|
00db10 |
- * Values are specified as for C:
|
|
|
00db10 |
- * 0x=hex, 0=octal, isdigit=decimal.
|
|
|
00db10 |
- */
|
|
|
00db10 |
- if (!isdigit(c))
|
|
|
00db10 |
- goto ret_0;
|
|
|
00db10 |
- {
|
|
|
00db10 |
- char *endp;
|
|
|
00db10 |
- unsigned long ul = strtoul (cp, (char **) &endp, 0);
|
|
|
00db10 |
- if (ul == ULONG_MAX && errno == ERANGE)
|
|
|
00db10 |
- goto ret_0;
|
|
|
00db10 |
- if (ul > 0xfffffffful)
|
|
|
00db10 |
- goto ret_0;
|
|
|
00db10 |
- val = ul;
|
|
|
00db10 |
- digit = cp != endp;
|
|
|
00db10 |
- cp = endp;
|
|
|
00db10 |
- }
|
|
|
00db10 |
- c = *cp;
|
|
|
00db10 |
- if (c == '.') {
|
|
|
00db10 |
- /*
|
|
|
00db10 |
- * Internet format:
|
|
|
00db10 |
- * a.b.c.d
|
|
|
00db10 |
- * a.b.c (with c treated as 16 bits)
|
|
|
00db10 |
- * a.b (with b treated as 24 bits)
|
|
|
00db10 |
- */
|
|
|
00db10 |
- if (pp > res.bytes + 2 || val > 0xff)
|
|
|
00db10 |
- goto ret_0;
|
|
|
00db10 |
- *pp++ = val;
|
|
|
00db10 |
- c = *++cp;
|
|
|
00db10 |
- } else
|
|
|
00db10 |
- break;
|
|
|
00db10 |
- }
|
|
|
00db10 |
- /*
|
|
|
00db10 |
- * Check for trailing characters.
|
|
|
00db10 |
- */
|
|
|
00db10 |
- if (c != '\0' && (!isascii(c) || !isspace(c)))
|
|
|
00db10 |
- goto ret_0;
|
|
|
00db10 |
- /*
|
|
|
00db10 |
- * Did we get a valid digit?
|
|
|
00db10 |
- */
|
|
|
00db10 |
- if (!digit)
|
|
|
00db10 |
- goto ret_0;
|
|
|
00db10 |
-
|
|
|
00db10 |
- /* Check whether the last part is in its limits depending on
|
|
|
00db10 |
- the number of parts in total. */
|
|
|
00db10 |
- if (val > max[pp - res.bytes])
|
|
|
00db10 |
+ static const in_addr_t max[4] = { 0xffffffff, 0xffffff, 0xffff, 0xff };
|
|
|
00db10 |
+ in_addr_t val;
|
|
|
00db10 |
+ char c;
|
|
|
00db10 |
+ union iaddr
|
|
|
00db10 |
+ {
|
|
|
00db10 |
+ uint8_t bytes[4];
|
|
|
00db10 |
+ uint32_t word;
|
|
|
00db10 |
+ } res;
|
|
|
00db10 |
+ uint8_t *pp = res.bytes;
|
|
|
00db10 |
+ int digit;
|
|
|
00db10 |
+
|
|
|
00db10 |
+ int saved_errno = errno;
|
|
|
00db10 |
+ __set_errno (0);
|
|
|
00db10 |
+
|
|
|
00db10 |
+ res.word = 0;
|
|
|
00db10 |
+
|
|
|
00db10 |
+ c = *cp;
|
|
|
00db10 |
+ for (;;)
|
|
|
00db10 |
+ {
|
|
|
00db10 |
+ /* Collect number up to ``.''. Values are specified as for C:
|
|
|
00db10 |
+ 0x=hex, 0=octal, isdigit=decimal. */
|
|
|
00db10 |
+ if (!isdigit (c))
|
|
|
00db10 |
+ goto ret_0;
|
|
|
00db10 |
+ {
|
|
|
00db10 |
+ char *endp;
|
|
|
00db10 |
+ unsigned long ul = strtoul (cp, &endp, 0);
|
|
|
00db10 |
+ if (ul == ULONG_MAX && errno == ERANGE)
|
|
|
00db10 |
goto ret_0;
|
|
|
00db10 |
-
|
|
|
00db10 |
- if (addr != NULL)
|
|
|
00db10 |
- addr->s_addr = res.word | htonl (val);
|
|
|
00db10 |
-
|
|
|
00db10 |
- __set_errno (saved_errno);
|
|
|
00db10 |
- return (1);
|
|
|
00db10 |
-
|
|
|
00db10 |
-ret_0:
|
|
|
00db10 |
- __set_errno (saved_errno);
|
|
|
00db10 |
- return (0);
|
|
|
00db10 |
+ if (ul > 0xfffffffful)
|
|
|
00db10 |
+ goto ret_0;
|
|
|
00db10 |
+ val = ul;
|
|
|
00db10 |
+ digit = cp != endp;
|
|
|
00db10 |
+ cp = endp;
|
|
|
00db10 |
+ }
|
|
|
00db10 |
+ c = *cp;
|
|
|
00db10 |
+ if (c == '.')
|
|
|
00db10 |
+ {
|
|
|
00db10 |
+ /* Internet format:
|
|
|
00db10 |
+ a.b.c.d
|
|
|
00db10 |
+ a.b.c (with c treated as 16 bits)
|
|
|
00db10 |
+ a.b (with b treated as 24 bits). */
|
|
|
00db10 |
+ if (pp > res.bytes + 2 || val > 0xff)
|
|
|
00db10 |
+ goto ret_0;
|
|
|
00db10 |
+ *pp++ = val;
|
|
|
00db10 |
+ c = *++cp;
|
|
|
00db10 |
+ }
|
|
|
00db10 |
+ else
|
|
|
00db10 |
+ break;
|
|
|
00db10 |
+ }
|
|
|
00db10 |
+ /* Check for trailing characters. */
|
|
|
00db10 |
+ if (c != '\0' && (!isascii (c) || !isspace (c)))
|
|
|
00db10 |
+ goto ret_0;
|
|
|
00db10 |
+ /* Did we get a valid digit? */
|
|
|
00db10 |
+ if (!digit)
|
|
|
00db10 |
+ goto ret_0;
|
|
|
00db10 |
+
|
|
|
00db10 |
+ /* Check whether the last part is in its limits depending on the
|
|
|
00db10 |
+ number of parts in total. */
|
|
|
00db10 |
+ if (val > max[pp - res.bytes])
|
|
|
00db10 |
+ goto ret_0;
|
|
|
00db10 |
+
|
|
|
00db10 |
+ if (addr != NULL)
|
|
|
00db10 |
+ addr->s_addr = res.word | htonl (val);
|
|
|
00db10 |
+
|
|
|
00db10 |
+ __set_errno (saved_errno);
|
|
|
00db10 |
+ return 1;
|
|
|
00db10 |
+
|
|
|
00db10 |
+ ret_0:
|
|
|
00db10 |
+ __set_errno (saved_errno);
|
|
|
00db10 |
+ return 0;
|
|
|
00db10 |
}
|
|
|
00db10 |
weak_alias (__inet_aton, inet_aton)
|
|
|
00db10 |
libc_hidden_def (__inet_aton)
|