]> git.saurik.com Git - apple/network_cmds.git/blob - routed.tproj/af.c
network_cmds-306.tar.gz
[apple/network_cmds.git] / routed.tproj / af.c
1 /*
2 * Copyright (c) 1999 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * "Portions Copyright (c) 1999 Apple Computer, Inc. All Rights
7 * Reserved. This file contains Original Code and/or Modifications of
8 * Original Code as defined in and that are subject to the Apple Public
9 * Source License Version 1.0 (the 'License'). You may not use this file
10 * except in compliance with the License. Please obtain a copy of the
11 * License at http://www.apple.com/publicsource and read it before using
12 * this file.
13 *
14 * The Original Code and all software distributed under the License are
15 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
16 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
17 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
19 * License for the specific language governing rights and limitations
20 * under the License."
21 *
22 * @APPLE_LICENSE_HEADER_END@
23 */
24 /*
25 * Copyright (c) 1983, 1993
26 * The Regents of the University of California. All rights reserved.
27 *
28 * Redistribution and use in source and binary forms, with or without
29 * modification, are permitted provided that the following conditions
30 * are met:
31 * 1. Redistributions of source code must retain the above copyright
32 * notice, this list of conditions and the following disclaimer.
33 * 2. Redistributions in binary form must reproduce the above copyright
34 * notice, this list of conditions and the following disclaimer in the
35 * documentation and/or other materials provided with the distribution.
36 * 3. All advertising materials mentioning features or use of this software
37 * must display the following acknowledgment:
38 * This product includes software developed by the University of
39 * California, Berkeley and its contributors.
40 * 4. Neither the name of the University nor the names of its contributors
41 * may be used to endorse or promote products derived from this software
42 * without specific prior written permission.
43 *
44 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
45 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
46 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
47 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
48 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
49 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
50 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
51 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
52 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
53 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
54 * SUCH DAMAGE.
55 *
56 * @(#)defs.h 8.1 (Berkeley) 6/5/93
57 */
58
59
60 #include "defs.h"
61
62 /*
63 * Address family support routines
64 */
65 int inet_hash(), inet_netmatch(), inet_output(),
66 inet_portmatch(), inet_portcheck(),
67 inet_checkhost(), inet_rtflags(), inet_sendroute(), inet_canon();
68 char *inet_format();
69
70 #define NIL { 0 }
71 #define INET \
72 { inet_hash, inet_netmatch, inet_output, \
73 inet_portmatch, inet_portcheck, inet_checkhost, \
74 inet_rtflags, inet_sendroute, inet_canon, \
75 inet_format \
76 }
77
78 struct afswitch afswitch[AF_MAX] = {
79 NIL, /* 0- unused */
80 NIL, /* 1- Unix domain, unused */
81 INET, /* Internet */
82 };
83
84 int af_max = sizeof(afswitch) / sizeof(afswitch[0]);
85
86 struct sockaddr_in inet_default = {
87 #ifdef RTM_ADD
88 sizeof (inet_default),
89 #endif
90 AF_INET, INADDR_ANY };
91
92 int
93 inet_hash(sin, hp)
94 register struct sockaddr_in *sin;
95 struct afhash *hp;
96 {
97 register u_long n;
98
99 n = inet_netof(sin->sin_addr);
100 if (n)
101 while ((n & 0xff) == 0)
102 n >>= 8;
103 hp->afh_nethash = n;
104 hp->afh_hosthash = ntohl(sin->sin_addr.s_addr);
105 hp->afh_hosthash &= 0x7fffffff;
106 return 0;
107 }
108
109 int
110 inet_netmatch(sin1, sin2)
111 struct sockaddr_in *sin1, *sin2;
112 {
113
114 return (inet_netof(sin1->sin_addr) == inet_netof(sin2->sin_addr));
115 }
116
117 /*
118 * Verify the message is from the right port.
119 */
120 int
121 inet_portmatch(sin)
122 register struct sockaddr_in *sin;
123 {
124
125 return (sin->sin_port == sp->s_port);
126 }
127
128 /*
129 * Verify the message is from a "trusted" port.
130 */
131 int
132 inet_portcheck(sin)
133 struct sockaddr_in *sin;
134 {
135
136 return (ntohs(sin->sin_port) <= IPPORT_RESERVED);
137 }
138
139 /*
140 * Internet output routine.
141 */
142 int
143 inet_output(s, flags, sin, size)
144 int s, flags;
145 struct sockaddr_in *sin;
146 int size;
147 {
148 struct sockaddr_in dst;
149
150 dst = *sin;
151 sin = &dst;
152 if (sin->sin_port == 0)
153 sin->sin_port = sp->s_port;
154 if (sin->sin_len == 0)
155 sin->sin_len = sizeof (*sin);
156 if (sendto(s, packet, size, flags,
157 (struct sockaddr *)sin, sizeof (*sin)) < 0)
158 perror("sendto");
159 return 0;
160 }
161
162 /*
163 * Return 1 if the address is believed
164 * for an Internet host -- THIS IS A KLUDGE.
165 */
166 int
167 inet_checkhost(sin)
168 struct sockaddr_in *sin;
169 {
170 u_long i = ntohl(sin->sin_addr.s_addr);
171
172 #ifndef IN_EXPERIMENTAL
173 #define IN_EXPERIMENTAL(i) (((long) (i) & 0xe0000000) == 0xe0000000)
174 #endif
175
176 if (IN_EXPERIMENTAL(i) || sin->sin_port != 0)
177 return (0);
178 if (i != 0 && (i & 0xff000000) == 0)
179 return (0);
180 for (i = 0; i < sizeof(sin->sin_zero)/sizeof(sin->sin_zero[0]); i++)
181 if (sin->sin_zero[i])
182 return (0);
183 return (1);
184 }
185
186 int
187 inet_canon(sin)
188 struct sockaddr_in *sin;
189 {
190
191 sin->sin_port = 0;
192 sin->sin_len = sizeof(*sin);
193 return 0;
194 }
195
196 char *
197 inet_format(sin)
198 struct sockaddr_in *sin;
199 {
200 char *inet_ntoa();
201
202 return (inet_ntoa(sin->sin_addr));
203 }