67   memset (segment_list, 0, 
sizeof (*segment_list));
    81       .frp_sw_if_index = ~0,
    83       .frp_weight = segment_list->
weight,
    85       .frp_label_stack = 
NULL,
    86       .frp_local_label = sl[0],
    92         for (ii = 1; ii < 
vec_len (sl); ii++)
   115         .fp_label = sr_policy->
bsid,
   153                     u8 behavior, 
u32 weight)
   164     return (VNET_API_ERROR_NO_SUCH_TABLE);
   175   memset (sr_policy, 0, 
sizeof (*sr_policy));
   183   sr_policy->
bsid = bsid;
   184   sr_policy->
type = behavior;
   232       .frp_sw_if_index = ~0,
   234       .frp_weight = segment_list->
weight,
   236       .frp_local_label = segment_list->
segments[0],
   252                                 .fp_label = sr_policy->
bsid,
   305   u32 *sl_index_iterate;
   320       segment_list = 
create_sl (sr_policy, segments, weight);
   323   else if (operation == 2)
   335         if (*sl_index_iterate == sl_index)
   338       if (*sl_index_iterate != sl_index)
   347         .frp_sw_if_index = ~0,
   349         .frp_weight = segment_list->
weight,
   351         .frp_local_label = segment_list->
segments[0],
   366                                 .fp_label = sr_policy->
bsid,
   381   else if (operation == 3)
   386         if (*sl_index_iterate == sl_index)
   389       if (*sl_index_iterate != sl_index)
   399         .frp_sw_if_index = ~0,
   401         .frp_weight = segment_list->
weight,
   403         .frp_local_label = segment_list->
segments[0],
   418                                 .fp_label = sr_policy->
bsid,
   427       segment_list->
weight = weight;
   441                                 .fp_label = sr_policy->
bsid,
   467   char is_del = 0, is_add = 0, is_mod = 0;
   478       if (!is_add && !is_mod && !is_del && 
unformat (input, 
"add"))
   480       else if (!is_add && !is_mod && !is_del && 
unformat (input, 
"del"))
   482       else if (!is_add && !is_mod && !is_del && 
unformat (input, 
"mod"))
   488       else if (
unformat (input, 
"weight %d", &weight));
   492           vec_add (segments, &next_label, 1);
   494       else if (
unformat (input, 
"add sl"))
   496       else if (
unformat (input, 
"del sl index %d", &sl_index))
   498       else if (
unformat (input, 
"mod sl index %d", &sl_index))
   506   if (!is_add && !is_mod && !is_del)
   528       if (operation != 1 && sl_index == (
u32) ~ 0)
   530       if (operation == 1 && 
vec_len (segments) == 0)
   532       if (operation == 3 && weight == (
u32) ~ 0)
   545                                 "There is already a FIB entry for the BindingSID address.\n"   546                                 "The SR policy could not be created.");
   549                                 "The selected SR policy only contains ONE segment list. "   550                                 "Please remove the SR policy instead");
   553                                 "Could not delete the segment list. "   554                                 "It is not associated with that SR policy.");
   557                                 "Could not delete the segment list. "   558                                 "It is not associated with that SR policy.");
   561                                 "Could not modify the segment list. "   562                                 "The given SL is not associated with such SR policy.");
   563     case VNET_API_ERROR_NO_SUCH_TABLE:
   574         .path = 
"sr mpls policy",
   575                 .short_help = 
"sr mpls policy [add||del||mod] bsid 2999 "   576                 "next 10 next 20 next 30 (weight 1) (spray)",
   577                 .long_help = 
"TBD.\n",
   602                 vec_add1(vec_policies, sr_policy);
   608     sr_policy = vec_policies[
i];
   635       s = 
format (s, 
"\t[%u].- ", *sl_index);
   641       s = 
format (s, 
"\b\b > ");
   653         .path = 
"show sr mpls policies",
   654                 .short_help = 
"show sr mpls policies",
   672                                       ip46_address_t * endpoint,
   673                                       u8 endpoint_type, 
u32 color)
   677   uword *endpoint_table, *p, *old_value;
   680   any.as_u64[0] = any.as_u64[1] = (
u64) ~ 0;
   750       sr_policy->
endpoint.as_u64[0] = endpoint->as_u64[0];
   751       sr_policy->
endpoint.as_u64[1] = endpoint->as_u64[1];
   752       sr_policy->
color = color;
   762                                                         "SR-MPLS Traffic Engineering (NextHop,Color)");
   774         .frp_sw_if_index = ~0,
   837   ip46_address_t endpoint;
   840   u8 endpoint_type = 0;
   841   char clear = 0, color_set = 0, bsid_set = 0;
   843   memset (&endpoint, 0, 
sizeof (ip46_address_t));
   852       else if (!endpoint_type
   856       else if (!color_set && 
unformat (input, 
"color %u", &color))
   862       else if (!clear && 
unformat (input, 
"clear"))
   870   if (!endpoint_type && !clear)
   872   if (!color_set && !clear)
   894         .path = 
"sr mpls policy te",
   895                 .short_help = 
"sr mpls policy te bsid xxxxx endpoint x.x.x.x color 12341234",
 
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
fib_protocol_t fp_proto
protocol type 
static clib_error_t * sr_mpls_policy_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
CLI for 'sr mpls policies' command family. 
#define vec_foreach_index(var, v)
Iterate over vector indices. 
#define hash_set(h, key, value)
mpls_eos_bit_t frp_eos
EOS bit for the resolving label. 
#define hash_unset(h, key)
int sr_mpls_policy_del(mpls_label_t bsid)
Delete a SR policy. 
A representation of a path as described by a route producer. 
fib_node_index_t fib_table_entry_update(u32 fib_index, const fib_prefix_t *prefix, fib_source_t source, fib_entry_flag_t flags, fib_route_path_t *paths)
Update an entry to have a new set of paths. 
fib_node_index_t fib_table_entry_path_add2(u32 fib_index, const fib_prefix_t *prefix, fib_source_t source, fib_entry_flag_t flags, fib_route_path_t *rpath)
Add n paths to an entry (aka route) in the FIB. 
u32 mpls_label_t
A label value only, i.e. 
#define MPLS_IETF_IMPLICIT_NULL_LABEL
#define vec_add1(V, E)
Add 1 element to end of vector (unspecified alignment). 
int sr_mpls_policy_assign_endpoint_color(mpls_label_t bsid, ip46_address_t *endpoint, u8 endpoint_type, u32 color)
Update the Endpoint,Color tuple of an SR policy. 
dpo_proto_t frp_proto
The protocol of the address below. 
SR Segment List (SID list) 
#define pool_get(P, E)
Allocate an object E from a pool P (unspecified alignment). 
unformat_function_t unformat_mpls_unicast_label
static clib_error_t * cli_sr_mpls_policy_ec_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
CLI to modify the Endpoint,Color of an SR policy. 
#define vec_add(V, E, N)
Add N elements to end of vector V (no header, unspecified alignment) 
memset(h->entries, 0, sizeof(h->entries[0])*entries)
#define pool_foreach(VAR, POOL, BODY)
Iterate through pool. 
#define VLIB_INIT_FUNCTION(x)
clib_error_t * sr_mpls_policy_rewrite_init(vlib_main_t *vm)
SR MPLS Policy initialization. 
void fib_table_flush(u32 fib_index, fib_protocol_t proto, fib_source_t source)
Flush all entries from a table for the source. 
Aggregrate type for a prefix. 
#define clib_error_return(e, args...)
mpls_sr_main_t sr_mpls_main
u32 fib_table_find(fib_protocol_t proto, u32 table_id)
Get the index of the FIB for a Table-ID. 
u16 fp_len
The mask length. 
#define SR_POLICY_TYPE_DEFAULT
#define pool_elt_at_index(p, i)
Returns pointer to element at given index. 
#define pool_put(P, E)
Free an object E in pool P. 
#define vec_dup(V)
Return copy of vector (no header, no alignment) 
void fib_table_entry_path_remove2(u32 fib_index, const fib_prefix_t *prefix, fib_source_t source, fib_route_path_t *rpath)
Remove n paths to an entry (aka route) in the FIB. 
Configuration for each label value in the output-stack. 
fib_mpls_label_t * frp_label_stack
The outgoing MPLS label Stack. 
#define vec_del1(v, i)
Delete the element at index I. 
void fib_table_unlock(u32 fib_index, fib_protocol_t proto, fib_source_t source)
Take a reference counting lock on the table. 
mpls_label_t bsid
BindingSID (key) 
int sr_mpls_policy_add(mpls_label_t bsid, mpls_label_t *segments, u8 behavior, u32 weight)
Create a new SR policy. 
static clib_error_t * show_sr_mpls_policies_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
CLI to display onscreen all the SR MPLS policies. 
The fine-grained event logger allows lightweight, thread-safe event logging at minimum cost...
int sr_mpls_policy_mod(mpls_label_t bsid, u8 operation, mpls_label_t *segments, u32 sl_index, u32 weight)
Modify an existing SR policy. 
#define MPLS_FIB_DEFAULT_TABLE_ID
static void ip6_address_set_zero(ip6_address_t *a)
#define vec_free(V)
Free vector's memory (no header). 
mpls_label_t fml_value
The label value. 
mpls_sr_policy_t * sr_policies
static mpls_sr_sl_t * create_sl(mpls_sr_policy_t *sr_policy, mpls_label_t *sl, u32 weight)
Creates a Segment List and adds it to an SR policy. 
#define VLIB_CLI_COMMAND(x,...)
#define FOR_EACH_MPLS_EOS_BIT(_eos)
#define hash_create(elts, value_bytes)
Segment Routing main datastructure. 
#define pool_put_index(p, i)
Free pool element with given index. 
static uword * mhash_get(mhash_t *h, const void *key)
void internal_label_lock(ip46_address_t endpoint, u32 color)
lock the label for (NH, C) endpoint might be NULL or ANY NULL = 0, ANY=~0 
#define SR_POLICY_TYPE_SPRAY
ip46_address_t endpoint
Optional NH for SR TE. 
u32 fib_table_find_or_create_and_lock(fib_protocol_t proto, u32 table_id, fib_source_t src)
Get the index of the FIB for a Table-ID. 
uword * sr_policies_index_hash
u32 find_or_create_internal_label(ip46_address_t endpoint, u32 color)
find the corresponding label for (endpoint, color) and lock it endpoint might be NULL or ANY NULL = 0...
void fib_table_entry_path_remove(u32 fib_index, const fib_prefix_t *prefix, fib_source_t source, dpo_proto_t next_hop_proto, const ip46_address_t *next_hop, u32 next_hop_sw_if_index, u32 next_hop_fib_index, u32 next_hop_weight, fib_route_path_flags_t path_flags)
remove one path to an entry (aka route) in the FIB. 
#define SR_SEGMENT_LIST_WEIGHT_DEFAULT
format_function_t format_mpls_unicast_label
mpls_label_t frp_local_label
The MPLS local Label to reursively resolve through. 
mhash_t sr_policies_c2e2eclabel_hash
SR TE. 
u32 color
Optional color for SR TE. 
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant) 
u8 type
Type (default is 0) 
Segment Routing MPLS data structures definitions. 
u32 * segments_lists
Pool of SID lists indexes. 
#define vec_foreach(var, vec)
Vector iterator. 
u8 frp_weight
[un]equal cost path weight 
void internal_label_unlock(ip46_address_t endpoint, u32 color)
Release lock on label for (endpoint, color) endpoint might be NULL or ANY NULL = 0, ANY=~0. 
u32 fib_table_create_and_lock(fib_protocol_t proto, fib_source_t src, const char *const fmt,...)
Create a new table with no table ID. 
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
enum mpls_eos_bit_t_ mpls_eos_bit_t
static uword pool_elts(void *v)
Number of active elements in a pool.