xref: /nrf52832-nimble/rt-thread/components/net/lwip-2.0.2/src/include/lwip/prot/ethernet.h (revision 104654410c56c573564690304ae786df310c91fc)
1*10465441SEvalZero /**
2*10465441SEvalZero  * @file
3*10465441SEvalZero  * Ethernet protocol definitions
4*10465441SEvalZero  */
5*10465441SEvalZero 
6*10465441SEvalZero /*
7*10465441SEvalZero  * Copyright (c) 2001-2004 Swedish Institute of Computer Science.
8*10465441SEvalZero  * All rights reserved.
9*10465441SEvalZero  *
10*10465441SEvalZero  * Redistribution and use in source and binary forms, with or without modification,
11*10465441SEvalZero  * are permitted provided that the following conditions are met:
12*10465441SEvalZero  *
13*10465441SEvalZero  * 1. Redistributions of source code must retain the above copyright notice,
14*10465441SEvalZero  *    this list of conditions and the following disclaimer.
15*10465441SEvalZero  * 2. Redistributions in binary form must reproduce the above copyright notice,
16*10465441SEvalZero  *    this list of conditions and the following disclaimer in the documentation
17*10465441SEvalZero  *    and/or other materials provided with the distribution.
18*10465441SEvalZero  * 3. The name of the author may not be used to endorse or promote products
19*10465441SEvalZero  *    derived from this software without specific prior written permission.
20*10465441SEvalZero  *
21*10465441SEvalZero  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
22*10465441SEvalZero  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
23*10465441SEvalZero  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
24*10465441SEvalZero  * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25*10465441SEvalZero  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
26*10465441SEvalZero  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27*10465441SEvalZero  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28*10465441SEvalZero  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
29*10465441SEvalZero  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
30*10465441SEvalZero  * OF SUCH DAMAGE.
31*10465441SEvalZero  *
32*10465441SEvalZero  * This file is part of the lwIP TCP/IP stack.
33*10465441SEvalZero  *
34*10465441SEvalZero  * Author: Adam Dunkels <[email protected]>
35*10465441SEvalZero  *
36*10465441SEvalZero  */
37*10465441SEvalZero #ifndef LWIP_HDR_PROT_ETHERNET_H
38*10465441SEvalZero #define LWIP_HDR_PROT_ETHERNET_H
39*10465441SEvalZero 
40*10465441SEvalZero #include "lwip/arch.h"
41*10465441SEvalZero 
42*10465441SEvalZero #ifdef __cplusplus
43*10465441SEvalZero extern "C" {
44*10465441SEvalZero #endif
45*10465441SEvalZero 
46*10465441SEvalZero #ifndef ETH_HWADDR_LEN
47*10465441SEvalZero #ifdef ETHARP_HWADDR_LEN
48*10465441SEvalZero #define ETH_HWADDR_LEN    ETHARP_HWADDR_LEN /* compatibility mode */
49*10465441SEvalZero #else
50*10465441SEvalZero #define ETH_HWADDR_LEN    6
51*10465441SEvalZero #endif
52*10465441SEvalZero #endif
53*10465441SEvalZero 
54*10465441SEvalZero #ifdef PACK_STRUCT_USE_INCLUDES
55*10465441SEvalZero #  include "arch/bpstruct.h"
56*10465441SEvalZero #endif
57*10465441SEvalZero PACK_STRUCT_BEGIN
58*10465441SEvalZero struct eth_addr {
59*10465441SEvalZero   PACK_STRUCT_FLD_8(u8_t addr[ETH_HWADDR_LEN]);
60*10465441SEvalZero } PACK_STRUCT_STRUCT;
61*10465441SEvalZero PACK_STRUCT_END
62*10465441SEvalZero #ifdef PACK_STRUCT_USE_INCLUDES
63*10465441SEvalZero #  include "arch/epstruct.h"
64*10465441SEvalZero #endif
65*10465441SEvalZero 
66*10465441SEvalZero #ifdef PACK_STRUCT_USE_INCLUDES
67*10465441SEvalZero #  include "arch/bpstruct.h"
68*10465441SEvalZero #endif
69*10465441SEvalZero PACK_STRUCT_BEGIN
70*10465441SEvalZero /** Ethernet header */
71*10465441SEvalZero struct eth_hdr {
72*10465441SEvalZero #if ETH_PAD_SIZE
73*10465441SEvalZero   PACK_STRUCT_FLD_8(u8_t padding[ETH_PAD_SIZE]);
74*10465441SEvalZero #endif
75*10465441SEvalZero   PACK_STRUCT_FLD_S(struct eth_addr dest);
76*10465441SEvalZero   PACK_STRUCT_FLD_S(struct eth_addr src);
77*10465441SEvalZero   PACK_STRUCT_FIELD(u16_t type);
78*10465441SEvalZero } PACK_STRUCT_STRUCT;
79*10465441SEvalZero PACK_STRUCT_END
80*10465441SEvalZero #ifdef PACK_STRUCT_USE_INCLUDES
81*10465441SEvalZero #  include "arch/epstruct.h"
82*10465441SEvalZero #endif
83*10465441SEvalZero 
84*10465441SEvalZero #define SIZEOF_ETH_HDR (14 + ETH_PAD_SIZE)
85*10465441SEvalZero 
86*10465441SEvalZero #ifdef PACK_STRUCT_USE_INCLUDES
87*10465441SEvalZero #  include "arch/bpstruct.h"
88*10465441SEvalZero #endif
89*10465441SEvalZero PACK_STRUCT_BEGIN
90*10465441SEvalZero /** VLAN header inserted between ethernet header and payload
91*10465441SEvalZero  * if 'type' in ethernet header is ETHTYPE_VLAN.
92*10465441SEvalZero  * See IEEE802.Q */
93*10465441SEvalZero struct eth_vlan_hdr {
94*10465441SEvalZero   PACK_STRUCT_FIELD(u16_t prio_vid);
95*10465441SEvalZero   PACK_STRUCT_FIELD(u16_t tpid);
96*10465441SEvalZero } PACK_STRUCT_STRUCT;
97*10465441SEvalZero PACK_STRUCT_END
98*10465441SEvalZero #ifdef PACK_STRUCT_USE_INCLUDES
99*10465441SEvalZero #  include "arch/epstruct.h"
100*10465441SEvalZero #endif
101*10465441SEvalZero 
102*10465441SEvalZero #define SIZEOF_VLAN_HDR 4
103*10465441SEvalZero #define VLAN_ID(vlan_hdr) (lwip_htons((vlan_hdr)->prio_vid) & 0xFFF)
104*10465441SEvalZero 
105*10465441SEvalZero /**
106*10465441SEvalZero  * @ingroup ethernet
107*10465441SEvalZero  * A list of often ethtypes (although lwIP does not use all of them): */
108*10465441SEvalZero enum eth_type {
109*10465441SEvalZero   /** Internet protocol v4 */
110*10465441SEvalZero   ETHTYPE_IP        = 0x0800U,
111*10465441SEvalZero   /** Address resolution protocol */
112*10465441SEvalZero   ETHTYPE_ARP       = 0x0806U,
113*10465441SEvalZero   /** Wake on lan */
114*10465441SEvalZero   ETHTYPE_WOL       = 0x0842U,
115*10465441SEvalZero   /** RARP */
116*10465441SEvalZero   ETHTYPE_RARP      = 0x8035U,
117*10465441SEvalZero   /** Virtual local area network */
118*10465441SEvalZero   ETHTYPE_VLAN      = 0x8100U,
119*10465441SEvalZero   /** Internet protocol v6 */
120*10465441SEvalZero   ETHTYPE_IPV6      = 0x86DDU,
121*10465441SEvalZero   /** PPP Over Ethernet Discovery Stage */
122*10465441SEvalZero   ETHTYPE_PPPOEDISC = 0x8863U,
123*10465441SEvalZero   /** PPP Over Ethernet Session Stage */
124*10465441SEvalZero   ETHTYPE_PPPOE     = 0x8864U,
125*10465441SEvalZero   /** Jumbo Frames */
126*10465441SEvalZero   ETHTYPE_JUMBO     = 0x8870U,
127*10465441SEvalZero   /** EAPOL, EAP over LAN */
128*10465441SEvalZero   ETHTYPE_EAPOL     = 0x888EU,
129*10465441SEvalZero   /** Process field network */
130*10465441SEvalZero   ETHTYPE_PROFINET  = 0x8892U,
131*10465441SEvalZero   /** Ethernet for control automation technology */
132*10465441SEvalZero   ETHTYPE_ETHERCAT  = 0x88A4U,
133*10465441SEvalZero   /** Link layer discovery protocol */
134*10465441SEvalZero   ETHTYPE_LLDP      = 0x88CCU,
135*10465441SEvalZero   /** Serial real-time communication system */
136*10465441SEvalZero   ETHTYPE_SERCOS    = 0x88CDU,
137*10465441SEvalZero   /** Media redundancy protocol */
138*10465441SEvalZero   ETHTYPE_MRP       = 0x88E3U,
139*10465441SEvalZero   /** Precision time protocol */
140*10465441SEvalZero   ETHTYPE_PTP       = 0x88F7U,
141*10465441SEvalZero   /** Q-in-Q, 802.1ad */
142*10465441SEvalZero   ETHTYPE_QINQ      = 0x9100U,
143*10465441SEvalZero };
144*10465441SEvalZero 
145*10465441SEvalZero /** The 24-bit IANA IPv4-multicast OUI is 01-00-5e: */
146*10465441SEvalZero #define LL_IP4_MULTICAST_ADDR_0 0x01
147*10465441SEvalZero #define LL_IP4_MULTICAST_ADDR_1 0x00
148*10465441SEvalZero #define LL_IP4_MULTICAST_ADDR_2 0x5e
149*10465441SEvalZero 
150*10465441SEvalZero /** IPv6 multicast uses this prefix */
151*10465441SEvalZero #define LL_IP6_MULTICAST_ADDR_0 0x33
152*10465441SEvalZero #define LL_IP6_MULTICAST_ADDR_1 0x33
153*10465441SEvalZero 
154*10465441SEvalZero /** MEMCPY-like macro to copy to/from struct eth_addr's that are local variables
155*10465441SEvalZero  * or known to be 32-bit aligned within the protocol header. */
156*10465441SEvalZero #ifndef ETHADDR32_COPY
157*10465441SEvalZero #define ETHADDR32_COPY(dst, src)  SMEMCPY(dst, src, ETH_HWADDR_LEN)
158*10465441SEvalZero #endif
159*10465441SEvalZero 
160*10465441SEvalZero /** MEMCPY-like macro to copy to/from struct eth_addr's that are no local
161*10465441SEvalZero  * variables and known to be 16-bit aligned within the protocol header. */
162*10465441SEvalZero #ifndef ETHADDR16_COPY
163*10465441SEvalZero #define ETHADDR16_COPY(dst, src)  SMEMCPY(dst, src, ETH_HWADDR_LEN)
164*10465441SEvalZero #endif
165*10465441SEvalZero 
166*10465441SEvalZero #define eth_addr_cmp(addr1, addr2) (memcmp((addr1)->addr, (addr2)->addr, ETH_HWADDR_LEN) == 0)
167*10465441SEvalZero 
168*10465441SEvalZero #ifdef __cplusplus
169*10465441SEvalZero }
170*10465441SEvalZero #endif
171*10465441SEvalZero 
172*10465441SEvalZero #endif /* LWIP_HDR_PROT_ETHERNET_H */
173