]> git.karo-electronics.de Git - karo-tx-redboot.git/blob - packages/net/bsd_tcpip/v2_0/include/netinet/if_ether.h
Initial revision
[karo-tx-redboot.git] / packages / net / bsd_tcpip / v2_0 / include / netinet / if_ether.h
1 //==========================================================================
2 //
3 //      include/netinet/if_ether.h
4 //
5 //==========================================================================
6 //####BSDCOPYRIGHTBEGIN####
7 //
8 // -------------------------------------------
9 //
10 // Portions of this software may have been derived from OpenBSD, 
11 // FreeBSD or other sources, and are covered by the appropriate
12 // copyright disclaimers included herein.
13 //
14 // Portions created by Red Hat are
15 // Copyright (C) 2002 Red Hat, Inc. All Rights Reserved.
16 //
17 // -------------------------------------------
18 //
19 //####BSDCOPYRIGHTEND####
20 //==========================================================================
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  * $FreeBSD: src/sys/netinet/if_ether.h,v 1.24 1999/12/29 04:40:58 peter Exp $
56  */
57
58 #ifndef _NETINET_IF_ETHER_H_
59 #define _NETINET_IF_ETHER_H_
60
61 #include <net/ethernet.h>
62 #include <net/if_arp.h>
63
64 /*
65  * Macro to map an IP multicast address to an Ethernet multicast address.
66  * The high-order 25 bits of the Ethernet address are statically assigned,
67  * and the low-order 23 bits are taken from the low end of the IP address.
68  */
69 #define ETHER_MAP_IP_MULTICAST(ipaddr, enaddr) \
70         /* struct in_addr *ipaddr; */ \
71         /* u_char enaddr[ETHER_ADDR_LEN];          */ \
72 { \
73         (enaddr)[0] = 0x01; \
74         (enaddr)[1] = 0x00; \
75         (enaddr)[2] = 0x5e; \
76         (enaddr)[3] = ((u_char *)ipaddr)[1] & 0x7f; \
77         (enaddr)[4] = ((u_char *)ipaddr)[2]; \
78         (enaddr)[5] = ((u_char *)ipaddr)[3]; \
79 }
80 /*
81  * Macro to map an IP6 multicast address to an Ethernet multicast address.
82  * The high-order 16 bits of the Ethernet address are statically assigned,
83  * and the low-order 32 bits are taken from the low end of the IP6 address.
84  */
85 #define ETHER_MAP_IPV6_MULTICAST(ip6addr, enaddr)                       \
86 /* struct       in6_addr *ip6addr; */                                   \
87 /* u_char       enaddr[ETHER_ADDR_LEN]; */                              \
88 {                                                                       \
89         (enaddr)[0] = 0x33;                                             \
90         (enaddr)[1] = 0x33;                                             \
91         (enaddr)[2] = ((u_char *)ip6addr)[12];                          \
92         (enaddr)[3] = ((u_char *)ip6addr)[13];                          \
93         (enaddr)[4] = ((u_char *)ip6addr)[14];                          \
94         (enaddr)[5] = ((u_char *)ip6addr)[15];                          \
95 }
96
97 /*
98  * Ethernet Address Resolution Protocol.
99  *
100  * See RFC 826 for protocol description.  Structure below is adapted
101  * to resolving internet addresses.  Field names used correspond to
102  * RFC 826.
103  */
104 struct  ether_arp {
105         struct  arphdr ea_hdr;  /* fixed-size header */
106         u_char  arp_sha[ETHER_ADDR_LEN];        /* sender hardware address */
107         u_char  arp_spa[4];     /* sender protocol address */
108         u_char  arp_tha[ETHER_ADDR_LEN];        /* target hardware address */
109         u_char  arp_tpa[4];     /* target protocol address */
110 };
111 #define arp_hrd ea_hdr.ar_hrd
112 #define arp_pro ea_hdr.ar_pro
113 #define arp_hln ea_hdr.ar_hln
114 #define arp_pln ea_hdr.ar_pln
115 #define arp_op  ea_hdr.ar_op
116
117 struct sockaddr_inarp {
118         u_char  sin_len;
119         u_char  sin_family;
120         u_short sin_port;
121         struct  in_addr sin_addr;
122         struct  in_addr sin_srcaddr;
123         u_short sin_tos;
124         u_short sin_other;
125         u_char  _padding[16];    // So this matches in size with struct sockaddr
126 #define SIN_PROXY 1
127 };
128 /*
129  * IP and ethernet specific routing flags
130  */
131 #define RTF_USETRAILERS RTF_PROTO1      /* use trailers */
132 #define RTF_ANNOUNCE    RTF_PROTO2      /* announce new arp entry */
133
134 #ifdef  _KERNEL
135 extern u_char   ether_ipmulticast_min[ETHER_ADDR_LEN];
136 extern u_char   ether_ipmulticast_max[ETHER_ADDR_LEN];
137 extern struct   ifqueue arpintrq;
138
139 int     arpresolve __P((struct arpcom *, struct rtentry *, struct mbuf *,
140                         struct sockaddr *, u_char *, struct rtentry *));
141 void    arp_ifinit __P((struct arpcom *, struct ifaddr *));
142 #endif
143
144 #endif