64 lookup_main.if_address_pool_index_by_sw_if_index,
67 lookup_main.if_address_pool_index_by_sw_if_index,
88 sizeof (ip6_address_fib_t));
101 for (i = 0; i < 256; i++)
123 #define _(n,v) if (flow_hash_config & v) s = format (s, "%s ", #n); 133 u8 *packet_data = va_arg (*args,
u8 *);
134 u32 n_packet_data_bytes = va_arg (*args,
u32);
156 else if (
unformat (input,
"null-send-unreach"))
158 else if (
unformat (input,
"null-send-prohibit"))
162 else if (
unformat (input,
"classify"))
166 if (!
unformat (input,
"%d", &classify_table_index))
212 if (
unformat (line_input,
"table %d", &table_id))
214 else if (
unformat (line_input,
"count %f", &count))
217 else if (
unformat (line_input,
"%U/%d",
223 else if (
unformat (line_input,
"%U/%d",
229 else if (
unformat (line_input,
"via %U",
234 else if (
vec_len (prefixs) > 0 &&
240 else if (
unformat (line_input,
"del"))
242 else if (
unformat (line_input,
"add"))
282 for (i = 0; i <
vec_len (prefixs); i++)
284 if (is_del && 0 == vec_len (rpaths))
288 else if (!is_del && 1 == vec_len (dpos))
297 else if (vec_len (dpos) > 0)
301 "Load-balancing over multiple special adjacencies is unsupported");
304 else if (0 < vec_len (rpaths))
314 for (k = 0; k < n; k++)
334 clib_host_to_net_u32 (incr +
335 clib_net_to_host_u32 (dst.
340 int bucket = (incr < 64 ? 0 : 1);
341 dst.ip6.as_u64[bucket] =
342 clib_host_to_net_u64 (incr +
343 clib_net_to_host_u64 (dst.ip6.as_u64
386 if (
unformat (line_input,
"%d", &table_id))
388 else if (
unformat (line_input,
"del"))
390 else if (
unformat (line_input,
"add"))
392 else if (
unformat (line_input,
"name %s", &name))
406 else if (0 == table_id)
445 .short_help =
"Internet protocol (IP) commands",
452 .short_help =
"Internet protocol version 6 (IPv6) commands",
459 .short_help =
"Internet protocol (IP) show commands",
466 .short_help =
"Internet protocol version 6 (IPv6) show commands",
500 .short_help =
"ip route [add|del] [count <n>] <dst-ip-addr>/<width> [table <table-id>] via [next-hop-address] [next-hop-interface] [next-hop-table <value>] [weight <value>] [preference <value>] [udp-encap-id <value>] [ip4-lookup-in-table <value>] [ip6-lookup-in-table <value>] [mpls-lookup-in-table <value>] [resolve-via-host] [resolve-via-connected] [rx-ip4 <interface>] [out-labels <value value value>]",
515 .short_help =
"ip table [add|del] <table-id>",
530 .short_help =
"ip6 table [add|del] <table-id>",
554 if (
unformat (input,
"%d", &table_id))
565 if (VNET_API_ERROR_ADDRESS_FOUND_FOR_INTERFACE == rv)
572 else if (VNET_API_ERROR_NO_SUCH_FIB == rv)
623 .path =
"set interface ip table",
625 .short_help =
"set interface ip table <interface> <table-id>",
651 .path =
"set interface ip6 table",
653 .short_help =
"set interface ip6 table <interface> <table-id>" 668 u32 gcount, scount, ss, gg, incr;
685 if (
unformat (line_input,
"table %d", &table_id))
687 else if (
unformat (line_input,
"del"))
689 else if (
unformat (line_input,
"add"))
691 else if (
unformat (line_input,
"rpf-id %d", &rpf_id))
693 else if (
unformat (line_input,
"scount %d", &scount))
695 else if (
unformat (line_input,
"gcount %d", &gcount))
697 else if (
unformat (line_input,
"%U %U",
705 else if (
unformat (line_input,
"%U %U",
713 else if (
unformat (line_input,
"%U/%d",
720 else if (
unformat (line_input,
"%U/%d",
727 else if (
unformat (line_input,
"%U",
734 else if (
unformat (line_input,
"%U",
741 else if (
unformat (line_input,
"via local Forward"))
755 else if (
unformat (line_input,
"via %U",
760 else if (
unformat (line_input,
"%U",
792 incr = 1 << (32 - (pfx.
fp_len % 32));
796 incr = 1 << (128 - (pfx.
fp_len % 128));
799 for (ss = 0; ss < scount; ss++)
801 for (gg = 0; gg < gcount; gg++)
803 if (is_del && 0 ==
vec_len (rpaths))
826 clib_host_to_net_u32 (incr +
827 clib_net_to_host_u32 (pfx.
833 int bucket = (incr < 64 ? 0 : 1);
835 clib_host_to_net_u64 (incr +
836 clib_net_to_host_u64 (pfx.
837 fp_grp_addr.ip6.as_u64
845 clib_host_to_net_u32 (1 +
852 clib_host_to_net_u64 (1 +
860 if (scount > 1 || gcount > 1)
862 (scount * gcount) / (timet[1] - timet[0]));
896 .short_help =
"ip mroute [add|del] <dst-ip-addr>/<width> [table <table-id>] [rpf-id <ID>] [via <next-hop-ip-addr> [<interface>],",
909 "invalid sw_if_index");
917 args->sw_if_index, &proxy_dpo);
1000 fib_table_walk(fib_table->ft_index,
1002 ip_container_proxy_fib_table_walk,
1007 fib_table_walk(fib_table->ft_index,
1009 ip_container_proxy_fib_table_walk,
1021 u32 is_del, addr_set = 0;
1042 else if (
unformat (line_input,
"%U",
1049 else if (
unformat (line_input,
"%U",
1052 else if (
unformat (line_input,
"del"))
1062 if (~0 == sw_if_index || !addr_set)
1081 .path =
"ip container",
1083 .short_help =
"ip container <address> <interface>",
1107 else if (
unformat (line_input,
"%U",
1113 else if (
unformat (line_input,
"%U",
1124 if (~0 == sw_if_index)
1132 vlib_cli_output (vm,
"ip container proxy is: %s", has_proxy ?
"on" :
"off");
1140 .path =
"show ip container",
1142 .short_help =
"show ip container <address> <interface>",
fib_protocol_t fp_proto
protocol type
void mfib_table_entry_delete(u32 fib_index, const mfib_prefix_t *prefix, mfib_source_t source)
Delete a FIB entry.
clib_error_t * vnet_ip4_table_cmd(vlib_main_t *vm, unformat_input_t *main_input, vlib_cli_command_t *cmd)
void ip_null_dpo_add_and_lock(dpo_proto_t proto, ip_null_dpo_action_t action, dpo_id_t *dpo)
ip46_address_t frp_addr
The next-hop address.
Continue on to the next entry.
void ip_table_create(fib_protocol_t fproto, u32 table_id, u8 is_api, const u8 *name)
ip46_address_t fp_src_addr
void receive_dpo_add_or_lock(dpo_proto_t proto, u32 sw_if_index, const ip46_address_t *nh_addr, dpo_id_t *dpo)
fib_node_index_t fib_table_lookup_exact_match(u32 fib_index, const fib_prefix_t *prefix)
Perfom an exact match in the non-forwarding table.
enum mfib_entry_flags_t_ mfib_entry_flags_t
static uword unformat_dpo(unformat_input_t *input, va_list *args)
A representation of a path as described by a route producer.
vnet_main_t * vnet_get_main(void)
fib_node_index_t mfib_table_entry_path_update(u32 fib_index, const mfib_prefix_t *prefix, mfib_source_t source, const fib_route_path_t *rpath)
Add n paths to an entry (aka route) in the FIB.
uword unformat_fib_route_path(unformat_input_t *input, va_list *args)
Unformat a fib_route_path_t from CLI input.
u32 frp_mitf_flags
MFIB interface flags.
clib_memset(h->entries, 0, sizeof(h->entries[0]) *entries)
static f64 vlib_time_now(vlib_main_t *vm)
ip_container_proxy_cb_t cb
const dpo_id_t * fib_entry_contribute_ip_forwarding(fib_node_index_t fib_entry_index)
A route the is being 'proxied' on behalf of another device.
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 *rpaths)
Add n paths to an entry (aka route) in the FIB.
void dpo_copy(dpo_id_t *dst, const dpo_id_t *src)
atomic copy a data-plane object.
#define vec_add1(V, E)
Add 1 element to end of vector (unspecified alignment).
const fib_prefix_t * fib_entry_get_prefix(fib_node_index_t fib_entry_index)
fib_node_index_t mfib_table_entry_update(u32 fib_index, const mfib_prefix_t *prefix, mfib_source_t source, fib_rpf_id_t rpf_id, mfib_entry_flags_t entry_flags)
Add a new (with no replication) or lock an existing entry.
dpo_proto_t frp_proto
The protocol of the address below.
unformat_function_t unformat_vnet_sw_interface
The data-path object representing L3 proxy.
static clib_error_t * vnet_ip_route_cmd(vlib_main_t *vm, unformat_input_t *main_input, vlib_cli_command_t *cmd)
mhash_t address_to_if_address_index
Hash table mapping address to index in interface address pool.
format_function_t format_vnet_sw_if_index_name
static clib_error_t * ip_table_bind_cmd(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd, fib_protocol_t fproto)
enum fib_protocol_t_ fib_protocol_t
Protocol Type.
int ip_table_bind(fib_protocol_t fproto, u32 sw_if_index, u32 table_id, u8 is_api)
const dpo_id_t * drop_dpo_get(dpo_proto_t proto)
static clib_error_t * ip6_table_bind_cmd(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define pool_foreach(VAR, POOL, BODY)
Iterate through pool.
u32 frp_sw_if_index
The interface.
vl_api_interface_index_t sw_if_index
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.
clib_error_t * vnet_ip_container_proxy_add_del(vnet_ip_container_proxy_args_t *args)
struct _vnet_ip_container_proxy_args vnet_ip_container_proxy_args_t
Aggregate type for a prefix.
const dpo_id_t * punt_dpo_get(dpo_proto_t proto)
#define clib_error_return(e, args...)
enum dpo_proto_t_ dpo_proto_t
Data path protocol.
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.
u32 l3p_sw_if_index
The Software interface index on which traffic is l3_proxyd.
The identity of a DPO is a combination of its type and its instance number/index of objects of that t...
int(* ip_container_proxy_cb_t)(const fib_prefix_t *pfx, u32 sw_if_index, void *ctx)
ip46_address_t fp_addr
The address type is not deriveable from the fp_addr member.
index_t classify_dpo_create(dpo_proto_t proto, u32 classify_table_index)
dpo_type_t dpoi_type
the type
static const dpo_id_t * load_balance_get_bucket_i(const load_balance_t *lb, u32 bucket)
u8 local_next_by_ip_protocol[256]
Table mapping ip protocol to ip[46]-local node next index.
clib_error_t * ip_container_cmd(vlib_main_t *vm, unformat_input_t *main_input, vlib_cli_command_t *cmd)
clib_error_t * vnet_ip_table_cmd(vlib_main_t *vm, unformat_input_t *main_input, vlib_cli_command_t *cmd, fib_protocol_t fproto)
clib_error_t * vnet_ip_mroute_cmd(vlib_main_t *vm, unformat_input_t *main_input, vlib_cli_command_t *cmd)
int fib_entry_is_sourced(fib_node_index_t fib_entry_index, fib_source_t source)
uword unformat_mfib_entry_flags(unformat_input_t *input, va_list *args)
void fib_table_entry_path_remove2(u32 fib_index, const fib_prefix_t *prefix, fib_source_t source, fib_route_path_t *rpaths)
Remove n paths to an entry (aka route) in the FIB.
void mhash_init(mhash_t *h, uword n_value_bytes, uword n_key_bytes)
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).
struct ip_container_proxy_walk_ctx_t_ ip_container_proxy_walk_ctx_t
void fib_table_entry_delete(u32 fib_index, const fib_prefix_t *prefix, fib_source_t source)
Delete a FIB entry.
void ip_table_delete(fib_protocol_t fproto, u32 table_id, u8 is_api)
#define clib_warning(format, args...)
static fib_table_walk_rc_t ip_container_proxy_fib_table_walk(fib_node_index_t fei, void *arg)
u32 fib_node_index_t
A typedef of a node index.
void ip_lookup_init(ip_lookup_main_t *lm, u32 is_ip6)
void ip_container_proxy_walk(ip_container_proxy_cb_t cb, void *ctx)
void dpo_set(dpo_id_t *dpo, dpo_type_t type, dpo_proto_t proto, index_t index)
Set/create a DPO ID The DPO will be locked.
Aggregate type for a prefix.
u8 builtin_protocol_by_ip_protocol[256]
IP_BUILTIN_PROTOCOL_{TCP,UDP,ICMP,OTHER} by protocol in IP header.
#define VLIB_CLI_COMMAND(x,...)
#define foreach_flow_hash_bit
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...
u32 fib_table_get_table_id_for_sw_if_index(fib_protocol_t proto, u32 sw_if_index)
Get the Table-ID of the FIB bound to the interface.
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
static load_balance_t * load_balance_get(index_t lbi)
fib_route_path_flags_t frp_flags
flags on the path
dpo_proto_t fib_proto_to_dpo(fib_protocol_t fib_proto)
u32 flow_hash_config_t
A flow hash configuration is a mask of the flow hash options.
static l3_proxy_dpo_t * l3_proxy_dpo_get(index_t index)
static clib_error_t * ip4_table_bind_cmd(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
fib_protocol_t fp_proto
protocol type
static uword vnet_sw_interface_is_api_valid(vnet_main_t *vnm, u32 sw_if_index)
clib_error_t * vnet_ip6_table_cmd(vlib_main_t *vm, unformat_input_t *main_input, vlib_cli_command_t *cmd)
index_t dpoi_index
the index of objects of that type
static clib_error_t * ip_sw_interface_add_del(vnet_main_t *vnm, u32 sw_if_index, u32 is_add)
#define FIB_NODE_INDEX_INVALID
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
mhash_t prefix_to_if_prefix_index
Hash table mapping prefix to index in interface prefix pool.
u32 mfib_table_find(fib_protocol_t proto, u32 table_id)
Get the index of the FIB for a Table-ID.
u32 is_ip6
1 for ip6; 0 for ip4.
#define DPO_INVALID
An initialiser for DPOs declared on the stack.
clib_error_t * show_ip_container_cmd_fn(vlib_main_t *vm, unformat_input_t *main_input, vlib_cli_command_t *cmd)
ip4_main_t ip4_main
Global ip4 main structure.
#define clib_error_return_code(e, code, flags, args...)
u8 ip_container_proxy_is_set(fib_prefix_t *pfx, u32 sw_if_index)
struct fib_table_t_ * fibs
Vector of FIBs.
void dpo_reset(dpo_id_t *dpo)
reset a DPO ID The DPO will be unlocked.
u8 * format_ip_flow_hash_config(u8 *s, va_list *args)
u8 * format_ip_adjacency_packet_data(u8 *s, va_list *args)
u16 fp_len
The mask length.
#define vec_validate_init_empty(V, I, INIT)
Make sure vector is long enough for given index and initialize empty space (no header, unspecified alignment)
void mfib_table_entry_path_remove(u32 fib_index, const mfib_prefix_t *prefix, mfib_source_t source, const fib_route_path_t *rpath)
Remove n paths to an entry (aka route) in the FIB.
u8 frp_weight
[un]equal cost path weight
struct fib_table_t_ * fibs
VNET_SW_INTERFACE_ADD_DEL_FUNCTION(ip_sw_interface_add_del)
void l3_proxy_dpo_add_or_lock(dpo_proto_t proto, u32 sw_if_index, dpo_id_t *dpo)
const ip46_address_t zero_addr
u32 fib_result_n_bytes
Number of bytes in a fib result.
ip46_address_t fp_grp_addr
The address type is not deriveable from the fp_addr member.
A protocol Independent FIB table.
format_function_t * format_address_and_length
Either format_ip4_address_and_length or format_ip6_address_and_length.