]>
git.saurik.com Git - apple/xnu.git/blob - libkern/net/inet_aton.c
2 * Copyright (c) 2001 Charles Mott <cm@linktel.net>
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 #include <sys/param.h>
27 #include <sys/systm.h>
29 #include <netinet/in.h>
31 /* XXX ctype.h is missing, see libkern/stdio/scanf.c */
36 return c
== ' ' || c
== '\t' || c
== '\n' || c
== '\12';
41 inet_aton(const char *cp
, struct in_addr
*addr
)
53 * Run through the string, grabbing numbers until
54 * the end of the string, or some error
60 l
= strtoul(c
, &endptr
, 0);
62 if (l
== ULONG_MAX
|| (l
== 0 && endptr
== c
)) {
69 * If the whole string is invalid, endptr will equal
70 * c.. this way we can make sure someone hasn't
71 * gone '.12' or something which would get past
80 /* Check the next character past the previous number's end */
84 /* Make sure we only do 3 dots .. */
85 if (n
== 3) { /* Whoops. Quit. */
97 if (isspace((unsigned char)*c
)) {
101 /* Invalid character, then fail. */
107 /* Concoct the address according to the number of parts specified. */
109 case 0: /* a -- 32 bits */
112 * Nothing is necessary here. Overflow checking was
113 * already done in strtoul().
116 case 1: /* a.b -- 8.24 bits */
117 if (val
> 0xffffff || parts
[0] > 0xff) {
120 val
|= parts
[0] << 24;
123 case 2: /* a.b.c -- 8.8.16 bits */
124 if (val
> 0xffff || parts
[0] > 0xff || parts
[1] > 0xff) {
127 val
|= (parts
[0] << 24) | (parts
[1] << 16);
130 case 3: /* a.b.c.d -- 8.8.8.8 bits */
131 if (val
> 0xff || parts
[0] > 0xff || parts
[1] > 0xff ||
135 val
|= (parts
[0] << 24) | (parts
[1] << 16) | (parts
[2] << 8);
140 addr
->s_addr
= htonl(val
);