/contrib/ntp/libisc/inet_aton.c

https://bitbucket.org/freebsd/freebsd-head/ · C · 195 lines · 82 code · 12 blank · 101 comment · 39 complexity · 28a9a7b077737d536f5dbb6131deeac2 MD5 · raw file

  1. /*
  2. * Portions Copyright (C) 2004 Internet Systems Consortium, Inc. ("ISC")
  3. * Portions Copyright (C) 1996-2001 Internet Software Consortium.
  4. *
  5. * Permission to use, copy, modify, and distribute this software for any
  6. * purpose with or without fee is hereby granted, provided that the above
  7. * copyright notice and this permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
  10. * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
  11. * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
  12. * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  13. * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
  14. * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  15. * PERFORMANCE OF THIS SOFTWARE.
  16. */
  17. /*
  18. * Copyright (c) 1983, 1990, 1993
  19. * The Regents of the University of California. All rights reserved.
  20. *
  21. * Redistribution and use in source and binary forms, with or without
  22. * modification, are permitted provided that the following conditions
  23. * are met:
  24. * 1. Redistributions of source code must retain the above copyright
  25. * notice, this list of conditions and the following disclaimer.
  26. * 2. Redistributions in binary form must reproduce the above copyright
  27. * notice, this list of conditions and the following disclaimer in the
  28. * documentation and/or other materials provided with the distribution.
  29. * 3. All advertising materials mentioning features or use of this software
  30. * must display the following acknowledgement:
  31. * This product includes software developed by the University of
  32. * California, Berkeley and its contributors.
  33. * 4. Neither the name of the University nor the names of its contributors
  34. * may be used to endorse or promote products derived from this software
  35. * without specific prior written permission.
  36. *
  37. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  38. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  39. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  40. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  41. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  42. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  43. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  44. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  45. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  46. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  47. * SUCH DAMAGE.
  48. */
  49. /*
  50. * Portions Copyright (c) 1993 by Digital Equipment Corporation.
  51. *
  52. * Permission to use, copy, modify, and distribute this software for any
  53. * purpose with or without fee is hereby granted, provided that the above
  54. * copyright notice and this permission notice appear in all copies, and that
  55. * the name of Digital Equipment Corporation not be used in advertising or
  56. * publicity pertaining to distribution of the document or software without
  57. * specific, written prior permission.
  58. *
  59. * THE SOFTWARE IS PROVIDED "AS IS" AND DIGITAL EQUIPMENT CORP. DISCLAIMS ALL
  60. * WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES
  61. * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL DIGITAL EQUIPMENT
  62. * CORPORATION BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  63. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  64. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
  65. * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
  66. * SOFTWARE.
  67. */
  68. #if defined(LIBC_SCCS) && !defined(lint)
  69. static char sccsid[] = "@(#)inet_addr.c 8.1 (Berkeley) 6/17/93";
  70. static char rcsid[] = "$Id: inet_aton.c,v 1.15.12.3 2004/03/08 09:04:49 marka Exp $";
  71. #endif /* LIBC_SCCS and not lint */
  72. #include <config.h>
  73. #include <ctype.h>
  74. #include <stddef.h> /* Required for NULL. */
  75. #include <isc/types.h>
  76. #include <isc/net.h>
  77. /*
  78. * Check whether "cp" is a valid ascii representation
  79. * of an Internet address and convert to a binary address.
  80. * Returns 1 if the address is valid, 0 if not.
  81. * This replaces inet_addr, the return value from which
  82. * cannot distinguish between failure and a local broadcast address.
  83. */
  84. int
  85. isc_net_aton(const char *cp, struct in_addr *addr) {
  86. unsigned long val;
  87. int base, n;
  88. unsigned char c;
  89. isc_uint8_t parts[4];
  90. isc_uint8_t *pp = parts;
  91. int digit;
  92. c = *cp;
  93. for (;;) {
  94. /*
  95. * Collect number up to ``.''.
  96. * Values are specified as for C:
  97. * 0x=hex, 0=octal, isdigit=decimal.
  98. */
  99. if (!isdigit(c & 0xff))
  100. return (0);
  101. val = 0; base = 10; digit = 0;
  102. if (c == '0') {
  103. c = *++cp;
  104. if (c == 'x' || c == 'X')
  105. base = 16, c = *++cp;
  106. else {
  107. base = 8;
  108. digit = 1;
  109. }
  110. }
  111. for (;;) {
  112. /*
  113. * isascii() is valid for all integer values, and
  114. * when it is true, c is known to be in scope
  115. * for isdigit(). No cast necessary. Similar
  116. * comment applies for later ctype uses.
  117. */
  118. if (isascii(c) && isdigit(c)) {
  119. if (base == 8 && (c == '8' || c == '9'))
  120. return (0);
  121. val = (val * base) + (c - '0');
  122. c = *++cp;
  123. digit = 1;
  124. } else if (base == 16 && isascii(c) && isxdigit(c)) {
  125. val = (val << 4) |
  126. (c + 10 - (islower(c) ? 'a' : 'A'));
  127. c = *++cp;
  128. digit = 1;
  129. } else
  130. break;
  131. }
  132. if (c == '.') {
  133. /*
  134. * Internet format:
  135. * a.b.c.d
  136. * a.b.c (with c treated as 16 bits)
  137. * a.b (with b treated as 24 bits)
  138. */
  139. if (pp >= parts + 3 || val > 0xff)
  140. return (0);
  141. *pp++ = (isc_uint8_t)val;
  142. c = *++cp;
  143. } else
  144. break;
  145. }
  146. /*
  147. * Check for trailing characters.
  148. */
  149. if (c != '\0' && (!isascii(c) || !isspace(c)))
  150. return (0);
  151. /*
  152. * Did we get a valid digit?
  153. */
  154. if (!digit)
  155. return (0);
  156. /*
  157. * Concoct the address according to
  158. * the number of parts specified.
  159. */
  160. n = pp - parts + 1;
  161. switch (n) {
  162. case 1: /* a -- 32 bits */
  163. break;
  164. case 2: /* a.b -- 8.24 bits */
  165. if (val > 0xffffff)
  166. return (0);
  167. val |= parts[0] << 24;
  168. break;
  169. case 3: /* a.b.c -- 8.8.16 bits */
  170. if (val > 0xffff)
  171. return (0);
  172. val |= (parts[0] << 24) | (parts[1] << 16);
  173. break;
  174. case 4: /* a.b.c.d -- 8.8.8.8 bits */
  175. if (val > 0xff)
  176. return (0);
  177. val |= (parts[0] << 24) | (parts[1] << 16) | (parts[2] << 8);
  178. break;
  179. }
  180. if (addr != NULL)
  181. addr->s_addr = htonl(val);
  182. return (1);
  183. }