]> git.saurik.com Git - apple/xnu.git/blob - bsd/netinet/if_ether.h
xnu-201.19.3.tar.gz
[apple/xnu.git] / bsd / netinet / if_ether.h
1 /*
2 * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * The contents of this file constitute Original Code as defined in and
7 * are subject to the Apple Public Source License Version 1.1 (the
8 * "License"). You may not use this file except in compliance with the
9 * License. Please obtain a copy of the License at
10 * http://www.apple.com/publicsource and read it before using this file.
11 *
12 * This Original Code and all software distributed under the License are
13 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17 * License for the specific language governing rights and limitations
18 * under the License.
19 *
20 * @APPLE_LICENSE_HEADER_END@
21 */
22 /*
23 * Copyright (c) 1982, 1986, 1993
24 * The Regents of the University of California. All rights reserved.
25 *
26 * Redistribution and use in source and binary forms, with or without
27 * modification, are permitted provided that the following conditions
28 * are met:
29 * 1. Redistributions of source code must retain the above copyright
30 * notice, this list of conditions and the following disclaimer.
31 * 2. Redistributions in binary form must reproduce the above copyright
32 * notice, this list of conditions and the following disclaimer in the
33 * documentation and/or other materials provided with the distribution.
34 * 3. All advertising materials mentioning features or use of this software
35 * must display the following acknowledgement:
36 * This product includes software developed by the University of
37 * California, Berkeley and its contributors.
38 * 4. Neither the name of the University nor the names of its contributors
39 * may be used to endorse or promote products derived from this software
40 * without specific prior written permission.
41 *
42 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
43 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
44 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
45 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
46 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
47 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
48 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
49 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
50 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
51 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
52 * SUCH DAMAGE.
53 *
54 * @(#)if_ether.h 8.3 (Berkeley) 5/2/95
55 */
56
57 #ifndef _NETINET_IF_ETHER_H_
58 #define _NETINET_IF_ETHER_H_
59
60
61 #include <net/ethernet.h>
62
63 #include <netinet/in.h>
64 #include <net/if_arp.h>
65 #include <net/etherdefs.h>
66 #define ea_byte ether_addr_octet
67
68
69 /*
70 * Macro for looking up the ether_multi record for a given range of Ethernet
71 * multicast addresses connected to a given arpcom structure. If no matching
72 * record is found, "enm" returns NULL.
73 */
74 #define ETHER_LOOKUP_MULTI(addrlo, addrhi, ac, enm) \
75 /* u_char addrlo[6]; */ \
76 /* u_char addrhi[6]; */ \
77 /* struct arpcom *ac; */ \
78 /* struct ether_multi *enm; */ \
79 { \
80 for ((enm) = (ac)->ac_multiaddrs; \
81 (enm) != NULL && \
82 (bcmp((enm)->enm_addrlo, (addrlo), 6) != 0 || \
83 bcmp((enm)->enm_addrhi, (addrhi), 6) != 0); \
84 (enm) = (enm)->enm_next); \
85 }
86
87 /*
88 * Macro to step through all of the ether_multi records, one at a time.
89 * The current position is remembered in "step", which the caller must
90 * provide. ETHER_FIRST_MULTI(), below, must be called to initialize "step"
91 * and get the first record. Both macros return a NULL "enm" when there
92 * are no remaining records.
93 */
94 #define ETHER_NEXT_MULTI(step, enm) \
95 /* struct ether_multistep step; */ \
96 /* struct ether_multi *enm; */ \
97 { \
98 if (((enm) = (step).e_enm) != NULL) \
99 (step).e_enm = (enm)->enm_next; \
100 }
101
102 #define ETHER_FIRST_MULTI(step, ac, enm) \
103 /* struct ether_multistep step; */ \
104 /* struct arpcom *ac; */ \
105 /* struct ether_multi *enm; */ \
106 { \
107 (step).e_enm = (ac)->ac_multiaddrs; \
108 ETHER_NEXT_MULTI((step), (enm)); \
109 }
110
111 #define ETHERTYPE_IPV6 0x86dd
112
113 /*
114 * Macro to map an IP multicast address to an Ethernet multicast address.
115 * The high-order 25 bits of the Ethernet address are statically assigned,
116 * and the low-order 23 bits are taken from the low end of the IP address.
117 */
118 #define ETHER_MAP_IP_MULTICAST(ipaddr, enaddr) \
119 /* struct in_addr *ipaddr; */ \
120 /* u_char enaddr[ETHER_ADDR_LEN]; */ \
121 { \
122 (enaddr)[0] = 0x01; \
123 (enaddr)[1] = 0x00; \
124 (enaddr)[2] = 0x5e; \
125 (enaddr)[3] = ((u_char *)ipaddr)[1] & 0x7f; \
126 (enaddr)[4] = ((u_char *)ipaddr)[2]; \
127 (enaddr)[5] = ((u_char *)ipaddr)[3]; \
128 }
129 /*
130 * Macro to map an IP6 multicast address to an Ethernet multicast address.
131 * The high-order 16 bits of the Ethernet address are statically assigned,
132 * and the low-order 32 bits are taken from the low end of the IP6 address.
133 */
134 #define ETHER_MAP_IPV6_MULTICAST(ip6addr, enaddr) \
135 /* struct in6_addr *ip6addr; */ \
136 /* u_char enaddr[ETHER_ADDR_LEN]; */ \
137 { \
138 (enaddr)[0] = 0x33; \
139 (enaddr)[1] = 0x33; \
140 (enaddr)[2] = ((u_char *)ip6addr)[12]; \
141 (enaddr)[3] = ((u_char *)ip6addr)[13]; \
142 (enaddr)[4] = ((u_char *)ip6addr)[14]; \
143 (enaddr)[5] = ((u_char *)ip6addr)[15]; \
144 }
145
146 /*
147 * Ethernet Address Resolution Protocol.
148 *
149 * See RFC 826 for protocol description. Structure below is adapted
150 * to resolving internet addresses. Field names used correspond to
151 * RFC 826.
152 */
153 struct ether_arp {
154 struct arphdr ea_hdr; /* fixed-size header */
155 u_char arp_sha[ETHER_ADDR_LEN]; /* sender hardware address */
156 u_char arp_spa[4]; /* sender protocol address */
157 u_char arp_tha[ETHER_ADDR_LEN]; /* target hardware address */
158 u_char arp_tpa[4]; /* target protocol address */
159 };
160 #define arp_hrd ea_hdr.ar_hrd
161 #define arp_pro ea_hdr.ar_pro
162 #define arp_hln ea_hdr.ar_hln
163 #define arp_pln ea_hdr.ar_pln
164 #define arp_op ea_hdr.ar_op
165
166 struct sockaddr_inarp {
167 u_char sin_len;
168 u_char sin_family;
169 u_short sin_port;
170 struct in_addr sin_addr;
171 struct in_addr sin_srcaddr;
172 u_short sin_tos;
173 u_short sin_other;
174 #define SIN_PROXY 1
175 };
176 /*
177 * IP and ethernet specific routing flags
178 */
179 #define RTF_USETRAILERS RTF_PROTO1 /* use trailers */
180 #define RTF_ANNOUNCE RTF_PROTO2 /* announce new arp entry */
181
182 #ifdef KERNEL
183 extern u_char ether_ipmulticast_min[ETHER_ADDR_LEN];
184 extern u_char ether_ipmulticast_max[ETHER_ADDR_LEN];
185 extern struct ifqueue arpintrq;
186
187 int arpresolve __P((struct arpcom *, struct rtentry *, struct mbuf *,
188 struct sockaddr *, u_char *, struct rtentry *));
189 void arp_ifinit __P((struct arpcom *, struct ifaddr *));
190 #endif
191
192 #endif