Get rid of OFP_MAXLEN.
[sliver-openvswitch.git] / include / packets.h
1 /* Copyright (c) 2008 The Board of Trustees of The Leland Stanford
2  * Junior University
3  * 
4  * We are making the OpenFlow specification and associated documentation
5  * (Software) available for public use and benefit with the expectation
6  * that others will use, modify and enhance the Software and contribute
7  * those enhancements back to the community. However, since we would
8  * like to make the Software available for broadest use, with as few
9  * restrictions as possible permission is hereby granted, free of
10  * charge, to any person obtaining a copy of this Software to deal in
11  * the Software under the copyrights without restriction, including
12  * without limitation the rights to use, copy, modify, merge, publish,
13  * distribute, sublicense, and/or sell copies of the Software, and to
14  * permit persons to whom the Software is furnished to do so, subject to
15  * the following conditions:
16  * 
17  * The above copyright notice and this permission notice shall be
18  * included in all copies or substantial portions of the Software.
19  * 
20  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
21  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
23  * NONINFRINGEMENT.  IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
24  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
25  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
26  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
27  * SOFTWARE.
28  * 
29  * The name and trademarks of copyright holder(s) may NOT be used in
30  * advertising or publicity pertaining to the Software or any
31  * derivatives without specific, written prior permission.
32  */
33 #ifndef PACKETS_H
34 #define PACKETS_H 1
35
36 #include <stdint.h>
37 #include <string.h>
38 #include "compiler.h"
39 #include "random.h"
40 #include "util.h"
41
42 #define ETH_ADDR_LEN           6
43
44 static const uint8_t eth_addr_broadcast[ETH_ADDR_LEN] UNUSED
45     = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
46
47 static inline bool eth_addr_is_broadcast(const uint8_t ea[6])
48 {
49     return (ea[0] & ea[1] & ea[2] & ea[3] & ea[4] & ea[5]) == 0xff;
50 }
51 static inline bool eth_addr_is_multicast(const uint8_t ea[6])
52 {
53     return ea[0] & 1;
54 }
55 static inline bool eth_addr_is_local(const uint8_t ea[6]) 
56 {
57     return ea[0] & 2;
58 }
59 static inline bool eth_addr_is_zero(const uint8_t ea[6]) 
60 {
61     return !(ea[0] | ea[1] | ea[2] | ea[3] | ea[4] | ea[5]);
62 }
63 static inline bool eth_addr_equals(const uint8_t a[ETH_ADDR_LEN],
64                                    const uint8_t b[ETH_ADDR_LEN]) 
65 {
66     return !memcmp(a, b, ETH_ADDR_LEN);
67 }
68 static inline uint64_t eth_addr_to_uint64(const uint8_t ea[ETH_ADDR_LEN])
69 {
70     return (((uint64_t) ea[0] << 40)
71             | ((uint64_t) ea[1] << 32)
72             | ((uint64_t) ea[2] << 24)
73             | ((uint64_t) ea[3] << 16)
74             | ((uint64_t) ea[4] << 8)
75             | ea[5]);
76 }
77 static inline void eth_addr_from_uint64(uint64_t x, uint8_t ea[ETH_ADDR_LEN])
78 {
79     ea[0] = x >> 40;
80     ea[1] = x >> 32;
81     ea[2] = x >> 24;
82     ea[3] = x >> 16;
83     ea[4] = x >> 8;
84     ea[5] = x;
85 }
86 static inline void eth_addr_random(uint8_t ea[ETH_ADDR_LEN])
87 {
88     random_bytes(ea, ETH_ADDR_LEN);
89 }
90
91 #define ETH_ADDR_FMT                                                    \
92     "%02"PRIx8":%02"PRIx8":%02"PRIx8":%02"PRIx8":%02"PRIx8":%02"PRIx8
93 #define ETH_ADDR_ARGS(ea)                                   \
94     (ea)[0], (ea)[1], (ea)[2], (ea)[3], (ea)[4], (ea)[5]
95
96 #define ETH_TYPE_IP            0x0800
97 #define ETH_TYPE_ARP           0x0806
98 #define ETH_TYPE_VLAN          0x8100
99
100 #define ETH_HEADER_LEN 14
101 #define ETH_PAYLOAD_MIN 46
102 #define ETH_PAYLOAD_MAX 1500
103 #define ETH_TOTAL_MIN (ETH_HEADER_LEN + ETH_PAYLOAD_MIN)
104 #define ETH_TOTAL_MAX (ETH_HEADER_LEN + ETH_PAYLOAD_MAX)
105 #define ETH_VLAN_TOTAL_MAX (ETH_HEADER_LEN + VLAN_HEADER_LEN + ETH_PAYLOAD_MAX)
106 struct eth_header {
107     uint8_t eth_dst[ETH_ADDR_LEN];
108     uint8_t eth_src[ETH_ADDR_LEN];
109     uint16_t eth_type;
110 } __attribute__((packed));
111 BUILD_ASSERT_DECL(ETH_HEADER_LEN == sizeof(struct eth_header));
112
113 #define LLC_DSAP_SNAP 0xaa
114 #define LLC_SSAP_SNAP 0xaa
115 #define LLC_CNTL_SNAP 3
116
117 #define LLC_HEADER_LEN 3
118 struct llc_header {
119     uint8_t llc_dsap;
120     uint8_t llc_ssap;
121     uint8_t llc_cntl;
122 } __attribute__((packed));
123 BUILD_ASSERT_DECL(LLC_HEADER_LEN == sizeof(struct llc_header));
124
125 #define SNAP_ORG_ETHERNET "\0\0" /* The compiler adds a null byte, so
126                                     sizeof(SNAP_ORG_ETHERNET) == 3. */
127 #define SNAP_HEADER_LEN 5
128 struct snap_header {
129     uint8_t snap_org[3];
130     uint16_t snap_type;
131 } __attribute__((packed));
132 BUILD_ASSERT_DECL(SNAP_HEADER_LEN == sizeof(struct snap_header));
133
134 #define LLC_SNAP_HEADER_LEN (LLC_HEADER_LEN + SNAP_HEADER_LEN)
135 struct llc_snap_header {
136     struct llc_header llc;
137     struct snap_header snap;
138 } __attribute__((packed));
139 BUILD_ASSERT_DECL(LLC_SNAP_HEADER_LEN == sizeof(struct llc_snap_header));
140
141 #define VLAN_VID 0x0fff
142
143 #define VLAN_HEADER_LEN 4
144 struct vlan_header {
145     uint16_t vlan_tci;          /* Lowest 12 bits are VLAN ID. */
146     uint16_t vlan_next_type;
147 };
148 BUILD_ASSERT_DECL(VLAN_HEADER_LEN == sizeof(struct vlan_header));
149
150 #define VLAN_ETH_HEADER_LEN (ETH_HEADER_LEN + VLAN_HEADER_LEN)
151 struct vlan_eth_header {
152     uint8_t veth_dst[ETH_ADDR_LEN];
153     uint8_t veth_src[ETH_ADDR_LEN];
154     uint16_t veth_type;         /* Always htons(ETH_TYPE_VLAN). */
155     uint16_t veth_tci;          /* Lowest 12 bits are VLAN ID. */
156     uint16_t veth_next_type;
157 } __attribute__((packed));
158 BUILD_ASSERT_DECL(VLAN_ETH_HEADER_LEN == sizeof(struct vlan_eth_header));
159
160 #define IP_FMT "%"PRIu8".%"PRIu8".%"PRIu8".%"PRIu8
161 #define IP_ARGS(ip)                             \
162         ((uint8_t *) ip)[0],                    \
163         ((uint8_t *) ip)[1],                    \
164         ((uint8_t *) ip)[2],                    \
165         ((uint8_t *) ip)[3]
166
167 #define IP_VER(ip_ihl_ver) ((ip_ihl_ver) >> 4)
168 #define IP_IHL(ip_ihl_ver) ((ip_ihl_ver) & 15)
169 #define IP_IHL_VER(ihl, ver) (((ver) << 4) | (ihl))
170
171 #define IP_TYPE_ICMP 1
172 #define IP_TYPE_TCP 6
173 #define IP_TYPE_UDP 17
174
175 #define IP_VERSION 4
176
177 #define IP_DONT_FRAGMENT  0x4000 /* Don't fragment. */
178 #define IP_MORE_FRAGMENTS 0x2000 /* More fragments. */
179 #define IP_FRAG_OFF_MASK  0x1fff /* Fragment offset. */
180 #define IP_IS_FRAGMENT(ip_frag_off) \
181         ((ip_frag_off) & htons(IP_MORE_FRAGMENTS | IP_FRAG_OFF_MASK))
182
183 #define IP_HEADER_LEN 20
184 struct ip_header {
185     uint8_t ip_ihl_ver;
186     uint8_t ip_tos;
187     uint16_t ip_tot_len;
188     uint16_t ip_id;
189     uint16_t ip_frag_off;
190     uint8_t ip_ttl;
191     uint8_t ip_proto;
192     uint16_t ip_csum;
193     uint32_t ip_src;
194     uint32_t ip_dst;
195 };
196 BUILD_ASSERT_DECL(IP_HEADER_LEN == sizeof(struct ip_header));
197
198 #define UDP_HEADER_LEN 8
199 struct udp_header {
200     uint16_t udp_src;
201     uint16_t udp_dst;
202     uint16_t udp_len;
203     uint16_t udp_csum;
204 };
205 BUILD_ASSERT_DECL(UDP_HEADER_LEN == sizeof(struct udp_header));
206
207 #define TCP_FIN 0x01
208 #define TCP_SYN 0x02
209 #define TCP_RST 0x04
210 #define TCP_PSH 0x08
211 #define TCP_ACK 0x10
212 #define TCP_URG 0x20
213
214 #define TCP_FLAGS(tcp_ctl) (htons(tcp_ctl) & 0x003f)
215 #define TCP_OFFSET(tcp_ctl) (htons(tcp_ctl) >> 12)
216
217 #define TCP_HEADER_LEN 20
218 struct tcp_header {
219     uint16_t tcp_src;
220     uint16_t tcp_dst;
221     uint32_t tcp_seq;
222     uint32_t tcp_ack;
223     uint16_t tcp_ctl;
224     uint16_t tcp_winsz;
225     uint16_t tcp_csum;
226     uint16_t tcp_urg;
227 };
228 BUILD_ASSERT_DECL(TCP_HEADER_LEN == sizeof(struct tcp_header));
229
230 #define ARP_HRD_ETHERNET 1
231 #define ARP_PRO_IP 0x0800
232 #define ARP_OP_REQUEST 1
233 #define ARP_OP_REPLY 2
234
235 #define ARP_ETH_HEADER_LEN 28
236 struct arp_eth_header {
237     /* Generic members. */
238     uint16_t ar_hrd;           /* Hardware type. */
239     uint16_t ar_pro;           /* Protocol type. */
240     uint8_t ar_hln;            /* Hardware address length. */
241     uint8_t ar_pln;            /* Protocol address length. */
242     uint16_t ar_op;            /* Opcode. */
243
244     /* Ethernet+IPv4 specific members. */
245     uint8_t ar_sha[ETH_ADDR_LEN]; /* Sender hardware address. */
246     uint32_t ar_spa;           /* Sender protocol address. */
247     uint8_t ar_tha[ETH_ADDR_LEN]; /* Target hardware address. */
248     uint32_t ar_tpa;           /* Target protocol address. */
249 } __attribute__((packed));
250 BUILD_ASSERT_DECL(ARP_ETH_HEADER_LEN == sizeof(struct arp_eth_header));
251
252 #endif /* packets.h */