53 pfx.
fp_addr.ip6.as_u64[0] = clib_host_to_net_u64 (0xFE80000000000000ULL);
184 const ip6_address_t *
addr,
195 kv.
key[0] = addr->as_u64[0];
196 kv.
key[1] = addr->as_u64[1];
197 fib = ((
u64)((fib_index))<<32);
204 while (i < n_p && table->prefix_lengths_in_search_order[i] > len)
214 ASSERT(dst_address_length >= 0 && dst_address_length <= 128);
216 kv.
key[0] &= mask->as_u64[0];
217 kv.
key[1] &= mask->as_u64[1];
218 kv.
key[2] = fib | dst_address_length;
220 rv = clib_bihash_search_inline_2_24_8(&table->
ip6_hash, &kv, &value);
230 const ip6_address_t *
addr,
241 fib = ((
u64)((fib_index))<<32);
243 kv.
key[0] = addr->as_u64[0] & mask->as_u64[0];
244 kv.
key[1] = addr->as_u64[1] & mask->as_u64[1];
247 rv = clib_bihash_search_inline_2_24_8(&table->
ip6_hash, &kv, &value);
257 u8 *old, *prefix_lengths_in_search_order = NULL;
269 int dst_address_length = 128 -
i;
270 vec_add1(prefix_lengths_in_search_order, dst_address_length);
284 const ip6_address_t *
addr,
294 fib = ((
u64)((fib_index))<<32);
296 kv.
key[0] = addr->as_u64[0] & mask->as_u64[0];
297 kv.
key[1] = addr->as_u64[1] & mask->as_u64[1];
300 clib_bihash_add_del_24_8(&table->
ip6_hash, &kv, 0);
315 const ip6_address_t *
addr,
326 fib = ((
u64)((fib_index))<<32);
328 kv.
key[0] = addr->as_u64[0] & mask->as_u64[0];
329 kv.
key[1] = addr->as_u64[1] & mask->as_u64[1];
331 kv.
value = fib_entry_index;
333 clib_bihash_add_del_24_8(&table->
ip6_hash, &kv, 1);
346 const ip6_address_t *
dst)
368 const ip6_address_t *
addr,
379 fib = ((
u64)((fib_index))<<32);
381 kv.
key[0] = addr->as_u64[0] & mask->as_u64[0];
382 kv.
key[1] = addr->as_u64[1] & mask->as_u64[1];
386 clib_bihash_add_del_24_8(&table->
ip6_hash, &kv, 1);
399 const ip6_address_t *
addr,
410 fib = ((
u64)((fib_index))<<32);
412 kv.
key[0] = addr->as_u64[0] & mask->as_u64[0];
413 kv.
key[1] = addr->as_u64[1] & mask->as_u64[1];
417 clib_bihash_add_del_24_8(&table->
ip6_hash, &kv, 0);
452 key.as_u64[0] = kvp->
key[0];
453 key.as_u64[1] = kvp->
key[1];
487 .fp_len = kvp->
key[2] & 0xffffffff,
510 .i6w_fib_index = fib_index,
516 .i6w_sub_trees = NULL,
519 clib_bihash_foreach_key_value_pair_24_8(
534 .i6w_fib_index = fib_index,
540 clib_bihash_foreach_key_value_pair_24_8(
607 s =
format(s,
"%=30s %=6d %=12ld\n",
616 u64 count_by_prefix_length[129];
627 return (BIHASH_WALK_CONTINUE);
629 mask_width = kvp->
key[2] & 0xFF;
633 return (BIHASH_WALK_CONTINUE);
645 int verbose, matching;
646 ip6_address_t matching_address;
662 else if (
unformat (input,
"detail") ||
666 else if (
unformat (input,
"hash") ||
678 else if (
unformat (input,
"table %d", &table_id))
680 else if (
unformat (input,
"index %d", &fib_index))
705 if (table_id >= 0 && table_id != (
int)fib->
table_id)
707 if (fib_index != ~0 && fib_index != (
int)fib->
index)
712 s =
format(s,
"%U, fib_index:%d, flow hash:[%U] epoch:%d flags:%U locks:[",
723 if (0 != fib_table->
ft_locks[source])
745 clib_bihash_foreach_key_value_pair_24_8
748 for (len = 128; len >= 0; len--)
866 .path =
"show ip6 fib",
867 .short_help =
"show ip6 fib [summary] [table <table-id>] [index <fib-id>] [<ip6-addr>[/<width>]] [detail]",
880 if (
unformat (input,
"hash-buckets %d", &nbuckets))
882 else if (
unformat (input,
"heap-size %U",
910 "ip6 FIB fwding table",
913 "ip6 FIB non-fwding table",
fib_protocol_t fp_proto
protocol type
u8 * format_fib_entry(u8 *s, va_list *args)
enum fib_source_t_ fib_source_t
The different sources that can create a route.
#define vec_foreach_index(var, v)
Iterate over vector indices.
Continue on to the next entry.
#define hash_set(h, key, value)
void vlib_worker_wait_one_loop(void)
Wait until each of the workers has been once around the track.
fib_protocol_t ft_proto
Which protocol this table serves.
The table that stores ALL routes learned by the DP.
static u32 ip6_fib_table_fwding_lookup(u32 fib_index, const ip6_address_t *dst)
#define hash_unset(h, key)
vl_api_wireguard_peer_flags_t flags
#define pool_foreach(VAR, POOL)
Iterate through pool.
#define IP6_FIB_DEFAULT_HASH_MEMORY_SIZE
#define FIB_ENTRY_FORMAT_DETAIL
static fib_table_walk_rc_t ip6_fib_table_show_walk(fib_node_index_t fib_entry_index, void *arg)
clib_memset(h->entries, 0, sizeof(h->entries[0]) *entries)
u8 * format_ip6_fib_table_memory(u8 *s, va_list *args)
#define clib_bitmap_foreach(i, ai)
Macro to iterate across set bits in a bitmap.
enum fib_table_flags_t_ fib_table_flags_t
#define vec_add1(V, E)
Add 1 element to end of vector (unspecified alignment).
static uword * clib_bitmap_set(uword *ai, uword i, uword value)
Sets the ith bit of a bitmap to new_value Removes trailing zeros from the bitmap. ...
#define IP6_FIB_DEFAULT_HASH_NUM_BUCKETS
#define pool_get(P, E)
Allocate an object E from a pool P (unspecified alignment).
static void ip6_fib_table_show_all(ip6_fib_t *fib, vlib_main_t *vm)
u64 count_by_prefix_length[129]
u8 * prefix_lengths_in_search_order
static void vnet_ip6_fib_init(u32 fib_index)
fib_node_index_t ip6_fib_table_lookup_exact_match(u32 fib_index, const ip6_address_t *addr, u32 len)
clib_bihash_24_8_t ip6_hash
#define VLIB_INIT_FUNCTION(x)
u32 ft_epoch
Epoch - number of resyncs performed.
void fib_table_entry_special_remove(u32 fib_index, const fib_prefix_t *prefix, fib_source_t source)
Remove a 'special' entry from the FIB.
static uword ip6_destination_matches_route(const ip6_main_t *im, const ip6_address_t *key, const ip6_address_t *dest, uword dest_length)
description fragment has unexpected format
fib_prefix_t * i6w_sub_trees
Aggregate type for a prefix.
#define clib_error_return(e, args...)
A representation of a single IP6 table.
u16 fp_len
The mask length.
static clib_error_t * ip6_fib_init(vlib_main_t *vm)
static u32 create_fib_with_table_id(u32 table_id, fib_source_t src, fib_table_flags_t flags, u8 *desc)
int fib_entry_cmp_for_sort(void *i1, void *i2)
u32 ip6_fib_table_get_index_for_sw_if_index(u32 sw_if_index)
u32 * ft_locks
per-source number of locks on the table
The identity of a DPO is a combination of its type and its instance number/index of objects of that t...
#define pool_elt_at_index(p, i)
Returns pointer to element at given index.
void ip6_fib_table_fwding_dpo_update(u32 fib_index, const ip6_address_t *addr, u32 len, const dpo_id_t *dpo)
ip46_address_t fp_addr
The address type is not deriveable from the fp_addr member.
u8 * format_fib_table_flags(u8 *s, va_list *args)
#define pool_put(P, E)
Free an object E in pool P.
void ip6_fib_table_fwding_dpo_remove(u32 fib_index, const ip6_address_t *addr, u32 len, const dpo_id_t *dpo)
u32 ft_total_route_counts
Total route counters.
#define IP_FLOW_HASH_DEFAULT
Default: 5-tuple without the "reverse" bit.
void ip6_fib_table_walk(u32 fib_index, fib_table_walk_fn_t fn, void *arg)
Walk all entries in a FIB table N.B: This is NOT safe to deletes.
u32 ip6_fib_table_find_or_create_and_lock(u32 table_id, fib_source_t src)
Get or create an IPv6 fib.
Stop the walk completely.
void ip6_fib_table_entry_remove(u32 fib_index, const ip6_address_t *addr, u32 len)
Context when walking the IPv6 table.
uword * fib_index_by_table_id
#define pool_get_aligned(P, E, A)
Allocate an object E from a pool P with alignment A.
ip6_address_t fib_masks[129]
fib_node_index_t fib_table_entry_special_add(u32 fib_index, const fib_prefix_t *prefix, fib_source_t source, fib_entry_flag_t flags)
Add a 'special' entry to the FIB.
fib_node_index_t ft_index
Index into FIB vector.
#define VLIB_EARLY_CONFIG_FUNCTION(x, n,...)
void ip6_fib_table_destroy(u32 fib_index)
This table stores the routes that are used to forward traffic.
u32 ft_table_id
Table ID (hash key) for this FIB.
u32 ft_flow_hash_config
flow hash configuration
sll srl srl sll sra u16x4 i
enum fib_table_walk_rc_t_ fib_table_walk_rc_t
return code controlling how a table walk proceeds
#define vec_free(V)
Free vector's memory (no header).
void fib_table_entry_delete(u32 fib_index, const fib_prefix_t *prefix, fib_source_t source)
Delete a FIB entry.
u32 ip6_fib_table_create_and_lock(fib_source_t src, fib_table_flags_t flags, u8 *desc)
u8 * ft_desc
Table description.
fib_table_flags_t ft_flags
Table flags.
const dpo_id_t * ip6_ll_dpo_get(void)
The IP6 link-local DPO represents the lookup of a packet in the link-local IPv6 FIB.
static void compute_prefix_lengths_in_search_order(ip6_fib_table_instance_t *table)
u32 fib_node_index_t
A typedef of a node index.
fib_node_index_t * entries
fib_table_walk_fn_t i6w_fn
fib_table_walk_rc_t(* fib_table_walk_fn_t)(fib_node_index_t fei, void *ctx)
Call back function when walking entries in a FIB table.
static int ip6_fib_walk_cb(clib_bihash_kv_24_8_t *kvp, void *arg)
void fib_table_lock(u32 fib_index, fib_protocol_t proto, fib_source_t source)
Release a reference counting lock on the table.
#define VLIB_CLI_COMMAND(x,...)
fib_node_index_t fib_table_entry_special_dpo_add(u32 fib_index, const fib_prefix_t *prefix, fib_source_t source, fib_entry_flag_t flags, const dpo_id_t *dpo)
Add a 'special' entry to the FIB that links to the DPO passed A special entry is an entry that the FI...
#define IP6_FIB_NUM_TABLES
#define pool_put_index(p, i)
Free pool element with given index.
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
manual_print typedef address
u8 * format_fib_source(u8 *s, va_list *args)
i32 dst_address_length_refcounts[129]
static void ip6_fib_table_show_one(ip6_fib_t *fib, vlib_main_t *vm, ip6_address_t *address, u32 mask_len, int detail)
static int count_routes_in_fib_at_prefix_length(clib_bihash_kv_24_8_t *kvp, void *arg)
Do no traverse down this sub-tree.
#define vec_elt(v, i)
Get vector value at index i.
#define FIB_ENTRY_FORMAT_BRIEF
struct ip6_fib_show_ctx_t_ ip6_fib_show_ctx_t
u32 ip6_fib_table_fwding_lookup_with_if_index(ip6_main_t *im, u32 sw_if_index, const ip6_address_t *dst)
index_t dpoi_index
the index of objects of that type
#define FIB_NODE_INDEX_INVALID
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
static clib_error_t * ip6_config(vlib_main_t *vm, unformat_input_t *input)
static clib_error_t * ip6_show_fib(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static uword max_log2(uword x)
#define vec_sort_with_function(vec, f)
Sort a vector using the supplied element comparison function.
void ip6_fib_table_entry_insert(u32 fib_index, const ip6_address_t *addr, u32 len, fib_node_index_t fib_entry_index)
The default route source.
uword * non_empty_dst_address_length_bitmap
fib_table_t * fib_table_get(fib_node_index_t index, fib_protocol_t proto)
Get a pointer to a FIB table.
struct ip6_fib_walk_ctx_t_ ip6_fib_walk_ctx_t
Context when walking the IPv6 table.
u32 * ft_src_route_counts
Per-source route counters.
u8 * format_fib_table_name(u8 *s, va_list *ap)
Format the description/name of the table.
#define FIB_ENTRY_FORMAT_DETAIL2
#define vec_foreach(var, vec)
Vector iterator.
fib_node_index_t ip6_fib_table_lookup(u32 fib_index, const ip6_address_t *addr, u32 len)
void fib_table_assert_empty(const fib_table_t *fib_table)
Debug function.
u8 * format_ip_flow_hash_config(u8 *s, va_list *args)
#define CLIB_CACHE_LINE_BYTES
void ip6_fib_table_sub_tree_walk(u32 fib_index, const fib_prefix_t *root, fib_table_walk_fn_t fn, void *arg)
Walk all entries in a sub-tree of the FIB table N.B: This is NOT safe to deletes. ...
struct fib_table_t_ * fibs
u32 * fib_index_by_sw_if_index
u32 ip6_fib_table_nbuckets
vl_api_interface_index_t sw_if_index
A protocol Independent FIB table.
static uword pool_elts(void *v)
Number of active elements in a pool.