blob: cf9fcb70bcca5475daacedc19ad215b64e54bf4c [file] [log] [blame]
Ed Warnickecb9cada2015-12-08 15:45:58 -07001#ifndef included_vnet_sr_packet_h
2#define included_vnet_sr_packet_h
3
4#include <vnet/ip/ip.h>
5
6/*
7 * ipv6 segment-routing header format
8 *
9 * Copyright (c) 2013 Cisco and/or its affiliates.
10 * Licensed under the Apache License, Version 2.0 (the "License");
11 * you may not use this file except in compliance with the License.
12 * You may obtain a copy of the License at:
13 *
14 * http://www.apache.org/licenses/LICENSE-2.0
15 *
16 * Unless required by applicable law or agreed to in writing, software
17 * distributed under the License is distributed on an "AS IS" BASIS,
18 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19 * See the License for the specific language governing permissions and
20 * limitations under the License.
21 */
22
Pablo Camarillofb380952016-12-07 18:34:18 +010023/*
24 * The Segment Routing Header (SRH) is defined as follows:
Keith Burns (alagalah)7214cf12016-08-08 15:56:50 -070025 *
Pablo Camarillofb380952016-12-07 18:34:18 +010026 * 0 1 2 3
27 * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
28 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
29 * | Next Header | Hdr Ext Len | Routing Type | Segments Left |
30 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Ahmed Abdelsalambe837042019-06-20 11:18:57 +000031 * | Last Entry | Flags | Tag |
Pablo Camarillofb380952016-12-07 18:34:18 +010032 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
33 * | |
34 * | Segment List[0] (128 bits IPv6 address) |
35 * | |
36 * | |
37 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
38 * | |
39 * | |
40 * ...
41 * | |
42 * | |
43 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
44 * | |
45 * | Segment List[n] (128 bits IPv6 address) |
46 * | |
47 * | |
48 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
49 * // //
50 * // Optional Type Length Value objects (variable) //
51 * // //
52 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Ed Warnickecb9cada2015-12-08 15:45:58 -070053 *
54 * where:
55 *
56 * o Next Header: 8-bit selector. Identifies the type of header
57 * immediately following the SRH.
58 *
59 * o Hdr Ext Len: 8-bit unsigned integer, is the length of the SRH
60 * header in 8-octet units, not including the first 8 octets.
61 *
62 * o Routing Type: TBD, to be assigned by IANA (suggested value: 4).
63 *
Ahmed Abdelsalambe837042019-06-20 11:18:57 +000064 * o Segments Left. Defined in [RFC8200], it contains the index, in
Ed Warnickecb9cada2015-12-08 15:45:58 -070065 * the Segment List, of the next segment to inspect. Segments Left
Pablo Camarillofb380952016-12-07 18:34:18 +010066 * is decremented at each segment.
Ed Warnickecb9cada2015-12-08 15:45:58 -070067 *
Ahmed Abdelsalambe837042019-06-20 11:18:57 +000068 * o Last Entry: contains the index (zero based), in the Segment List,
69 * of the the last element of the Segment List
Ed Warnickecb9cada2015-12-08 15:45:58 -070070 *
Pablo Camarillofb380952016-12-07 18:34:18 +010071 * o Flags: 8 bits of flags. Following flags are defined:
Ed Warnickecb9cada2015-12-08 15:45:58 -070072 *
Pablo Camarillofb380952016-12-07 18:34:18 +010073 * 0 1 2 3 4 5 6 7
74 * +-+-+-+-+-+-+-+-+
75 * |U|P|O|A|H| U |
76 * +-+-+-+-+-+-+-+-+
Ed Warnickecb9cada2015-12-08 15:45:58 -070077 *
Pablo Camarillofb380952016-12-07 18:34:18 +010078 * U: Unused and for future use. SHOULD be unset on transmission
79 * and MUST be ignored on receipt.
Ed Warnickecb9cada2015-12-08 15:45:58 -070080 *
Pablo Camarillofb380952016-12-07 18:34:18 +010081 * P-flag: Protected flag. Set when the packet has been rerouted
82 * through FRR mechanism by an SR endpoint node.
Ed Warnickecb9cada2015-12-08 15:45:58 -070083 *
Pablo Camarillofb380952016-12-07 18:34:18 +010084 * O-flag: OAM flag. When set, it indicates that this packet is
85 * an operations and management (OAM) packet.
Ed Warnickecb9cada2015-12-08 15:45:58 -070086 *
Pablo Camarillofb380952016-12-07 18:34:18 +010087 * A-flag: Alert flag. If present, it means important Type Length
88 * Value (TLV) objects are present. See Section 3.1 for details
89 * on TLVs objects.
Ed Warnickecb9cada2015-12-08 15:45:58 -070090 *
Pablo Camarillofb380952016-12-07 18:34:18 +010091 * H-flag: HMAC flag. If set, the HMAC TLV is present and is
92 * encoded as the last TLV of the SRH. In other words, the last
93 * 36 octets of the SRH represent the HMAC information. See
94 * Section 3.1.5 for details on the HMAC TLV.
Ed Warnickecb9cada2015-12-08 15:45:58 -070095 *
Ahmed Abdelsalambe837042019-06-20 11:18:57 +000096 * o Tag: tag a packet as part of a class or group of packets, e.g.,
97 * packets sharing the same set of properties. When tag is not used
98 * at source it MUST be set to zero on transmission. When tag is not
99 * used during SRH Processing it SHOULD be ignored.
Ed Warnickecb9cada2015-12-08 15:45:58 -0700100 *
101 * o Segment List[n]: 128 bit IPv6 addresses representing the nth
102 * segment in the Segment List. The Segment List is encoded starting
103 * from the last segment of the path. I.e., the first element of the
104 * segment list (Segment List [0]) contains the last segment of the
105 * path while the last segment of the Segment List (Segment List[n])
106 * contains the first segment of the path. The index contained in
107 * "Segments Left" identifies the current active segment.
108 *
Pablo Camarillofb380952016-12-07 18:34:18 +0100109 * o Type Length Value (TLV) are described in Section 3.1.
Ed Warnickecb9cada2015-12-08 15:45:58 -0700110 *
Ed Warnickecb9cada2015-12-08 15:45:58 -0700111 */
112
Chris Luke4b8b7182016-05-25 14:39:47 -0400113#ifndef IPPROTO_IPV6_ROUTE
114#define IPPROTO_IPV6_ROUTE 43
115#endif
116
117#define ROUTING_HEADER_TYPE_SR 4
Pablo Camarillofb380952016-12-07 18:34:18 +0100118
Ahmed Abdelsalam9cca6942022-06-06 15:54:02 +0000119#define IP6_SRH_PT_TLV_TYPE 128
120#define IP6_SRH_PT_TLV_LEN 14
121
Keith Burns (alagalah)06c5ffd2016-08-06 08:32:45 -0700122typedef struct
123{
Pablo Camarillofb380952016-12-07 18:34:18 +0100124 /* Protocol for next header. */
Ed Warnickecb9cada2015-12-08 15:45:58 -0700125 u8 protocol;
Pablo Camarillofb380952016-12-07 18:34:18 +0100126 /*
Damjan Marion607de1a2016-08-16 22:53:54 +0200127 * Length of routing header in 8 octet units,
Ed Warnickecb9cada2015-12-08 15:45:58 -0700128 * not including the first 8 octets
129 */
130 u8 length;
131
Pablo Camarillofb380952016-12-07 18:34:18 +0100132 /* Type of routing header; type 4 = segement routing */
Ed Warnickecb9cada2015-12-08 15:45:58 -0700133 u8 type;
134
Pablo Camarillofb380952016-12-07 18:34:18 +0100135 /* Next segment in the segment list */
Ed Warnickecb9cada2015-12-08 15:45:58 -0700136 u8 segments_left;
137
Pablo Camarillofb380952016-12-07 18:34:18 +0100138 /* Pointer to the first segment in the header */
Ahmed Abdelsalambe837042019-06-20 11:18:57 +0000139 u8 last_entry;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700140
Pablo Camarillofb380952016-12-07 18:34:18 +0100141 /* Flag bits */
142#define IP6_SR_HEADER_FLAG_PROTECTED (0x40)
143#define IP6_SR_HEADER_FLAG_OAM (0x20)
144#define IP6_SR_HEADER_FLAG_ALERT (0x10)
145#define IP6_SR_HEADER_FLAG_HMAC (0x80)
Keith Burns (alagalah)06c5ffd2016-08-06 08:32:45 -0700146
Pablo Camarillofb380952016-12-07 18:34:18 +0100147 /* values 0x0, 0x4 - 0x7 are reserved */
148 u8 flags;
Ahmed Abdelsalambe837042019-06-20 11:18:57 +0000149 u16 tag;
Pablo Camarillofb380952016-12-07 18:34:18 +0100150
151 /* The segment elts */
Ed Warnickecb9cada2015-12-08 15:45:58 -0700152 ip6_address_t segments[0];
Keith Burns (alagalah)06c5ffd2016-08-06 08:32:45 -0700153} __attribute__ ((packed)) ip6_sr_header_t;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700154
Tetsuya Murakami9e722bd2020-03-04 16:27:14 -0800155typedef struct
156{
157 u8 type;
158 u8 length;
159 u8 value[0];
160} __attribute__ ((packed)) ip6_sr_tlv_t;
161
Ahmed Abdelsalam9cca6942022-06-06 15:54:02 +0000162typedef struct
163{
164 u32 sec;
165 u32 nsec;
166} __attribute__ ((packed)) timestamp_64_t;
167
168typedef struct
169{
170 u8 type;
171 u8 length;
172 u16 id_ld;
173 timestamp_64_t t64;
174 u16 session_id;
175 u16 seq_num;
176} __attribute__ ((packed)) ip6_sr_pt_tlv_t;
Pablo Camarillofb380952016-12-07 18:34:18 +0100177/*
178* fd.io coding-style-patch-verification: ON
179*
180* Local Variables:
181* eval: (c-set-style "gnu")
182* End:
183*/
Ed Warnickecb9cada2015-12-08 15:45:58 -0700184
185#endif /* included_vnet_sr_packet_h */