2 * This is an implementation of Segment Routing for IS-IS as per RFC 8667
4 * Copyright (C) 2019 Orange http://www.orange.com
6 * Author: Olivier Dugeon <olivier.dugeon@orange.com>
7 * Contributor: Renato Westphal <renato@opensourcerouting.org> for NetDEF
9 * This program is free software; you can redistribute it and/or modify it
10 * under the terms of the GNU General Public License as published by the Free
11 * Software Foundation; either version 2 of the License, or (at your option)
14 * This program is distributed in the hope that it will be useful, but WITHOUT
15 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
19 * You should have received a copy of the GNU General Public License along
20 * with this program; see the file COPYING; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
24 #ifndef _FRR_ISIS_SR_H
25 #define _FRR_ISIS_SR_H
27 #include "lib/linklist.h"
29 #include "lib/nexthop.h"
30 #include "lib/typesafe.h"
32 #include "isisd/isis_tlvs.h"
35 * Segment Routing information is transported through the following Sub-TLVs:
37 * Sub-TLV Name Value TLVs
38 * ---------------------------------------------------------------------
41 * Prefix Segment Identifier 3 135, 235, 236 and 237
43 * Adjacency Segment Identifier 31 22, 23, 141, 222 and 223
44 * LAN Adjacency Segment Identifier 32 22, 23, 141, 222 and 223
46 * Segment Routing Capability 2 242
47 * Segment Routing Algorithm 19 242
48 * Node Maximum Stack Depth (MSD) 23 242
50 * Sub-TLV definitions, serialization and de-serialization are defined
54 #define SRGB_LOWER_BOUND 16000
55 #define SRGB_UPPER_BOUND 23999
56 #define SRLB_LOWER_BOUND 15000
57 #define SRLB_UPPER_BOUND 15999
59 /* Segment Routing Data Base (SRDB) RB-Tree structure */
60 PREDECL_RBTREE_UNIQ(srdb_node
)
61 PREDECL_RBTREE_UNIQ(srdb_node_prefix
)
62 PREDECL_RBTREE_UNIQ(srdb_area_prefix
)
63 PREDECL_RBTREE_UNIQ(srdb_prefix_cfg
)
65 /* Segment Routing Local Block allocation */
66 struct sr_local_block
{
74 #define SRLB_BLOCK_SIZE 64
76 /* Segment Routing Adjacency-SID type. */
78 ISIS_SR_ADJ_NORMAL
= 0,
82 /* Segment Routing Adjacency. */
85 enum sr_adj_type type
;
87 /* Adjacency-SID input label. */
88 mpls_label_t input_label
;
90 /* Adjacency-SID nexthop information. */
96 /* Adjacency-SID TI-LFA backup nexthops. */
97 struct list
*backup_nexthops
;
99 /* (LAN-)Adjacency-SID Sub-TLV. */
101 struct isis_adj_sid
*adj_sid
;
102 struct isis_lan_adj_sid
*ladj_sid
;
105 /* Back pointer to IS-IS adjacency. */
106 struct isis_adjacency
*adj
;
109 /* Segment Routing Prefix-SID type. */
110 enum sr_prefix_type
{
111 ISIS_SR_PREFIX_LOCAL
= 0,
112 ISIS_SR_PREFIX_REMOTE
,
115 /* Segment Routing Nexthop Information. */
116 struct sr_nexthop_info
{
121 /* State of Object (SR-Node and SR-Prefix) stored in SRDB */
123 SRDB_STATE_VALIDATED
= 0,
129 /* Segment Routing Prefix-SID. */
131 /* SRDB RB-tree entries. */
132 struct srdb_node_prefix_item node_entry
;
133 struct srdb_area_prefix_item area_entry
;
136 struct prefix prefix
;
138 /* SID value, algorithm and flags subTLVs. */
139 struct isis_prefix_sid sid
;
141 /* Input label value. */
142 mpls_label_t input_label
;
144 /* Prefix-SID type. */
145 enum sr_prefix_type type
;
148 /* Information about this local Prefix-SID. */
149 struct sr_nexthop_info info
;
152 /* Route associated to this remote Prefix-SID. */
153 struct isis_route_info
*rinfo
;
157 /* Backpointer to Segment Routing node. */
160 /* SR-Prefix State used while the LSPDB is being parsed. */
161 enum srdb_state state
;
164 /* Segment Routing node. */
166 /* SRDB RB-tree entry. */
167 struct srdb_node_item entry
;
169 /* IS-IS level: ISIS_LEVEL1 or ISIS_LEVEL2. */
172 /* IS-IS node identifier. */
173 uint8_t sysid
[ISIS_SYS_ID_LEN
];
175 /* Segment Routing node capabilities (SRGB, SR Algorithms) subTLVs. */
176 struct isis_router_cap cap
;
178 /* List of Prefix-SIDs advertised by this node. */
179 struct srdb_node_prefix_head prefix_sids
;
181 /* Backpointer to IS-IS area. */
182 struct isis_area
*area
;
184 /* SR-Node State used while the LSPDB is being parsed. */
185 enum srdb_state state
;
188 /* SID type. NOTE: these values must be in sync with the YANG module. */
189 enum sr_sid_value_type
{
190 SR_SID_VALUE_TYPE_INDEX
= 0,
191 SR_SID_VALUE_TYPE_ABSOLUTE
= 1,
194 #define IS_SID_VALUE(flag) CHECK_FLAG(flag, ISIS_PREFIX_SID_VALUE)
196 /* Last Hop Behavior. NOTE: these values must be in sync with the YANG module */
197 enum sr_last_hop_behavior
{
198 SR_LAST_HOP_BEHAVIOR_EXP_NULL
= 0,
199 SR_LAST_HOP_BEHAVIOR_NO_PHP
= 1,
200 SR_LAST_HOP_BEHAVIOR_PHP
= 2,
203 /* Segment Routing Prefix-SID configuration. */
204 struct sr_prefix_cfg
{
205 /* SRDB RB-tree entry. */
206 struct srdb_prefix_cfg_item entry
;
209 struct prefix prefix
;
214 /* SID value type. */
215 enum sr_sid_value_type sid_type
;
217 /* SID last hop behavior. */
218 enum sr_last_hop_behavior last_hop_behavior
;
220 /* Does this Prefix-SID refer to a loopback address (Node-SID)? */
223 /* Backpointer to IS-IS area. */
224 struct isis_area
*area
;
227 /* Per-area IS-IS Segment Routing Data Base (SRDB). */
229 /* Global Operational status of Segment Routing. */
232 /* Thread timer to start Label Manager */
233 struct thread
*t_start_lm
;
235 /* List of local Adjacency-SIDs. */
236 struct list
*adj_sids
;
238 /* Segment Routing Node information per IS-IS level. */
239 struct srdb_node_head sr_nodes
[ISIS_LEVELS
];
241 /* Segment Routing Prefix-SIDs per IS-IS level. */
242 struct srdb_area_prefix_head prefix_sids
[ISIS_LEVELS
];
244 /* Management of SRLB & SRGB allocation */
245 struct sr_local_block srlb
;
248 /* Area Segment Routing configuration. */
250 /* Administrative status of Segment Routing. */
253 /* Segment Routing Global Block lower & upper bound. */
254 uint32_t srgb_lower_bound
;
255 uint32_t srgb_upper_bound
;
257 /* Segment Routing Local Block lower & upper bound. */
258 uint32_t srlb_lower_bound
;
259 uint32_t srlb_upper_bound
;
261 /* Maximum SID Depth supported by the node. */
264 /* Prefix-SID mappings. */
265 struct srdb_prefix_cfg_head prefix_sids
;
270 extern int isis_sr_cfg_srgb_update(struct isis_area
*area
, uint32_t lower_bound
,
271 uint32_t upper_bound
);
272 extern int isis_sr_cfg_srlb_update(struct isis_area
*area
, uint32_t lower_bound
,
273 uint32_t upper_bound
);
274 extern struct sr_prefix_cfg
*
275 isis_sr_cfg_prefix_add(struct isis_area
*area
, const struct prefix
*prefix
);
276 extern void isis_sr_cfg_prefix_del(struct sr_prefix_cfg
*pcfg
);
277 extern struct sr_prefix_cfg
*
278 isis_sr_cfg_prefix_find(struct isis_area
*area
, union prefixconstptr prefix
);
279 extern void isis_sr_prefix_cfg2subtlv(const struct sr_prefix_cfg
*pcfg
,
281 struct isis_prefix_sid
*psid
);
282 extern void isis_sr_nexthop_update(struct sr_nexthop_info
*srnh
,
284 extern void isis_sr_nexthop_reset(struct sr_nexthop_info
*srnh
);
285 extern void sr_adj_sid_add_single(struct isis_adjacency
*adj
, int family
,
286 bool backup
, struct list
*nexthops
);
287 extern struct sr_adjacency
*isis_sr_adj_sid_find(struct isis_adjacency
*adj
,
289 enum sr_adj_type type
);
290 extern void isis_area_delete_backup_adj_sids(struct isis_area
*area
, int level
);
291 extern void isis_area_verify_sr(struct isis_area
*area
);
292 extern int isis_sr_start(struct isis_area
*area
);
293 extern void isis_sr_stop(struct isis_area
*area
);
294 extern void isis_sr_area_init(struct isis_area
*area
);
295 extern void isis_sr_area_term(struct isis_area
*area
);
296 extern void isis_sr_init(void);
297 extern void isis_sr_term(void);
299 #endif /* _FRR_ISIS_SR_H */