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