75 u32 hw_if_index, *hw_if_indices = 0;
83 vec_add1 (hw_if_indices, hw_if_index);
86 else if (
unformat (input,
"%u", &hw_if_index))
87 vec_add1 (hw_if_indices, hw_if_index);
89 else if (
unformat (input,
"verbose"))
114 if (
vec_len (hw_if_indices) == 0)
127 for (i = 0; i <
vec_len (hw_if_indices); i++)
154 for (i = 0; i <
vec_len (hw_if_indices); i++)
161 if (dc->clear_counters)
244 .path =
"show hardware-interfaces",
245 .short_help =
"show hardware-interfaces [brief|verbose|detail] [bond] " 246 "[<interface> [<interface> [..]]] [<sw_idx> [<sw_idx> [..]]]",
265 .path =
"clear hardware-interfaces",
266 .short_help =
"clear hardware-interfaces " 267 "[<interface> [<interface> [..]]] [<sw_idx> [<sw_idx> [..]]]",
292 u8 show_addresses = 0;
293 u8 show_features = 0;
321 else if (
unformat (linput,
"verbose"))
333 if (show_features || show_tag || show_vtr)
335 if (sw_if_index == ~(
u32) 0)
362 tag ? (
char *) tag :
"(none)");
373 u32 push_dot1q = 0, tag1 = 0, tag2 = 0;
376 &vtr_op, &push_dot1q, &tag1, &tag2) != 0)
396 _vec_len (sorted_sis) = 0;
418 u32 fib_index4 = 0, fib_index6 = 0;
433 (vm,
"%U (%s): \n unnumbered, use %U",
451 ip4_address_t *r4 = ip_interface_address_get_address (lm4, ia);
453 vlib_cli_output (vm,
" L3 %U/%d ip4 table-id %d fib-idx %d",
454 format_ip4_address, r4, ia->address_length,
456 ip4_fib_index_from_table_id (fib4->table_id));
458 vlib_cli_output (vm,
" L3 %U/%d",
459 format_ip4_address, r4, ia->address_length);
468 ip6_address_t *r6 = ip_interface_address_get_address (lm6, ia);
470 vlib_cli_output (vm,
" L3 %U/%d ip6 table-id %d fib-idx %d",
471 format_ip6_address, r6, ia->address_length,
473 ip6_fib_index_from_table_id (fib6->table_id));
475 vlib_cli_output (vm,
" L3 %U/%d",
476 format_ip6_address, r6, ia->address_length);
496 .path =
"show interface",
497 .short_help =
"show interface [address|addr|features|feat|vtr] [<interface> [<interface> [..]]] [verbose]",
507 .short_help =
"Interface commands",
513 .path =
"set interface",
514 .short_help =
"Interface commands",
530 for (j = 0; j < n_counters; j++)
539 for (j = 0; j < n_counters; j++)
559 .path =
"clear interfaces",
560 .short_help =
"clear interfaces",
632 u32 inner_vlan, outer_vlan;
634 if (
unformat (input,
"any inner-dot1q any"))
636 template->sub.eth.flags.two_tags = 1;
637 template->sub.eth.flags.outer_vlan_id_any = 1;
638 template->sub.eth.flags.inner_vlan_id_any = 1;
642 template->sub.eth.flags.one_tag = 1;
643 template->sub.eth.flags.outer_vlan_id_any = 1;
645 else if (
unformat (input,
"%d inner-dot1q any", &outer_vlan))
647 template->sub.eth.flags.two_tags = 1;
648 template->sub.eth.flags.inner_vlan_id_any = 1;
649 template->sub.eth.outer_vlan_id = outer_vlan;
651 else if (
unformat (input,
"%d inner-dot1q %d", &outer_vlan, &inner_vlan))
653 template->sub.eth.flags.two_tags = 1;
654 template->sub.eth.outer_vlan_id = outer_vlan;
655 template->sub.eth.inner_vlan_id = inner_vlan;
657 else if (
unformat (input,
"%d", &outer_vlan))
659 template->sub.eth.flags.one_tag = 1;
660 template->sub.eth.outer_vlan_id = outer_vlan;
671 if (
unformat (input,
"exact-match"))
673 template->sub.eth.flags.exact_match = 1;
689 u32 id, id_min, id_max;
701 template.sub.eth.raw_flags = 0;
703 if (
unformat (input,
"%d default", &id_min))
706 template.sub.eth.flags.default_sub = 1;
708 else if (
unformat (input,
"%d untagged", &id_min))
711 template.sub.eth.flags.no_tags = 1;
712 template.sub.eth.flags.exact_match = 1;
714 else if (
unformat (input,
"%d dot1q", &id_min))
722 else if (
unformat (input,
"%d dot1ad", &id_min))
726 template.sub.eth.flags.dot1ad = 1;
731 else if (
unformat (input,
"%d-%d", &id_min, &id_max))
733 template.sub.eth.flags.one_tag = 1;
734 template.sub.eth.flags.exact_match = 1;
738 else if (
unformat (input,
"%d", &id_min))
741 template.sub.eth.flags.one_tag = 1;
742 template.sub.eth.outer_vlan_id = id_min;
743 template.sub.eth.flags.exact_match = 1;
759 "not allowed as %v belong to a BondEthernet interface",
764 for (
id = id_min;
id <= id_max;
id++)
775 clib_warning (
"sup sw_if_index %d, sub id %d already exists\n",
783 template.sub.id =
id;
785 template.sub.eth.outer_vlan_id =
id;
792 *kp = sup_and_sub_key;
890 .path =
"create sub-interfaces",
891 .short_help =
"create sub-interfaces <interface> " 892 "{<subId> [default|untagged]} | " 893 "{<subId>-<subId>} | " 894 "{<subId> dot1q|dot1ad <vlanId>|any [inner-dot1q <vlanId>|any] [exact-match]}",
947 .path =
"set interface state",
948 .short_help =
"set interface state <interface> [up|down|punt|enable]",
958 u32 unnumbered_sw_if_index = ~0;
959 u32 inherit_from_sw_if_index = ~0;
968 &unnumbered_sw_if_index))
974 if (~0 == unnumbered_sw_if_index)
976 if (enable && ~0 == inherit_from_sw_if_index)
978 " IP enabled interface that it uses");
981 inherit_from_sw_if_index, enable);
988 .path =
"set interface unnumbered",
989 .short_help =
"set interface unnumbered [<interface> use <interface> | del <interface>]",
1003 u32 hw_if_index, hw_class_index;
1031 .path =
"set interface hw-class",
1032 .short_help =
"Set interface hardware class",
1051 u32 new_dev_instance;
1059 if (!
unformat (input,
"%d", &new_dev_instance))
1081 .path =
"renumber interface",
1082 .short_help =
"renumber interface <interface> <new-dev-instance>",
1100 else if (
unformat (input,
"off %U",
1117 .path =
"set interface promiscuous",
1118 .short_help =
"set interface promiscuous [on|off] <interface>",
1131 if (
unformat (input,
"%d %U", &mtu,
1144 if (mtu < hi->min_supported_packet_bytes)
1146 "must be >= min pkt bytes (%d)", mtu,
1156 else if (
unformat (input,
"packet %d %U", &mtu,
1160 else if (
unformat (input,
"ip4 %d %U", &mtu,
1163 else if (
unformat (input,
"ip6 %d %U", &mtu,
1166 else if (
unformat (input,
"mpls %d %U", &mtu,
1181 .path =
"set interface mtu",
1182 .short_help =
"set interface mtu [packet|ip4|ip6|mpls] <value> <interface>",
1204 if (
vec_len (sorted_sis) == 0)
1208 _vec_len (sorted_sis) = 0;
1259 .path =
"show interface secondary-mac-address",
1260 .short_help =
"show interface secondary-mac-address [<interface>]",
1276 is_add = is_del = 0;
1301 if (is_add == is_del)
1333 .path =
"set interface secondary-mac-address",
1334 .short_help =
"set interface secondary-mac-address <interface> <mac-address> [(add|del)]",
1383 .path =
"set interface mac address",
1384 .short_help =
"set interface mac address <interface> <mac-address>",
1397 vnm, &sw_if_index, &tag))
1408 .path =
"set interface tag",
1409 .short_help =
"set interface tag <interface> <tag>",
1432 .path =
"clear interface tag",
1433 .short_help =
"clear interface tag <interface>",
1447 else if (
unformat (input,
"enable"))
1449 else if (
unformat (input,
"disable"))
1455 if (~0 == sw_if_index)
1472 .path =
"set interface ip directed-broadcast",
1473 .short_help =
"set interface enable <interface> <enable|disable>",
1496 if (old_mode == mode)
1499 case VNET_API_ERROR_INVALID_INTERFACE:
1501 case VNET_API_ERROR_INVALID_QUEUE:
1507 if (dev_class->rx_mode_change_function)
1509 error = dev_class->rx_mode_change_function (vnm, hw_if_index, queue_id,
1520 case VNET_API_ERROR_UNSUPPORTED:
1522 case VNET_API_ERROR_INVALID_INTERFACE:
1524 case VNET_API_ERROR_INVALID_QUEUE:
1535 u8 queue_id_valid,
u32 queue_id,
1544 if (queue_id_valid == 0)
1567 u32 hw_if_index = (
u32) ~ 0;
1568 u32 queue_id = (
u32) ~ 0;
1570 u8 queue_id_valid = 0;
1580 else if (
unformat (line_input,
"queue %d", &queue_id))
1582 else if (
unformat (line_input,
"polling"))
1584 else if (
unformat (line_input,
"interrupt"))
1586 else if (
unformat (line_input,
"adaptive"))
1599 if (hw_if_index == (
u32) ~ 0)
1646 .path =
"set interface rx-mode",
1647 .short_help =
"set interface rx-mode <interface> [queue <n>] [polling | interrupt | adaptive]",
1677 s =
format (s,
" %U queue %u (%U)\n",
1724 .path =
"show interface rx-placement",
1725 .short_help =
"show interface rx-placement",
1732 u32 thread_index,
u8 is_main)
1747 "please specify valid worker thread or main");
1773 u32 hw_if_index = (
u32) ~ 0;
1775 u32 thread_index = (
u32) ~ 0;
1786 else if (
unformat (line_input,
"queue %d", &queue_id))
1788 else if (
unformat (line_input,
"main", &thread_index))
1790 else if (
unformat (line_input,
"worker %d", &thread_index))
1803 if (hw_if_index == (
u32) ~ 0)
1862 .path =
"set interface rx-placement",
1863 .short_help =
"set interface rx-placement <interface> [queue <n>] " 1864 "[worker <n> | main]",
1888 u32 hw_if_index = (
u32) ~ 0;
1900 if (
unformat (line_input,
"list %U", unformat_bitmap_list, &bitmap))
1913 if (hw_if_index == (
u32) ~ 0)
1947 .path =
"set interface rss queues",
1948 .short_help =
"set interface rss queues <interface> <list <queue-list>>",
1957 int type = va_arg (*args,
int);
1983 s =
format (s,
"unknown type %d!", type);
2001 (vm,
"pcap %U dispatch capture enabled: %d of %d pkts...",
2017 return VNET_API_ERROR_INVALID_VALUE;
2022 return VNET_API_ERROR_VALUE_EXIST;
2028 return VNET_API_ERROR_INVALID_VALUE_2;
2032 cm->classify_table_index_by_sw_if_index[0] == ~0)
2033 return VNET_API_ERROR_NO_SUCH_LABEL;
2037 void *save_pcap_data;
2041 return VNET_API_ERROR_INVALID_MEMORY_SIZE;
2052 memset (pm, 0,
sizeof (*pm));
2066 stem =
format (stem,
"rx");
2068 stem =
format (stem,
"tx");
2070 stem =
format (stem,
"drop");
2090 cm->classify_table_index_by_sw_if_index[0];
2117 return VNET_API_ERROR_SYSCALL_ERROR_1;
2125 return VNET_API_ERROR_NO_SUCH_ENTRY;
2140 u32 max_bytes_per_pkt = 512;
2144 int preallocate_data = 0;
2145 int drop_enable = 0;
2159 else if (
unformat (line_input,
"tx"))
2161 else if (
unformat (line_input,
"drop"))
2163 else if (
unformat (line_input,
"off"))
2164 rx_enable = tx_enable = drop_enable = 0;
2165 else if (
unformat (line_input,
"max-bytes-per-pkt %u",
2166 &max_bytes_per_pkt))
2168 else if (
unformat (line_input,
"max %d", &max))
2170 else if (
unformat (line_input,
"packets-to-capture %d", &max))
2175 else if (
unformat (line_input,
"status %=", &status, 1))
2177 else if (
unformat (line_input,
"intfc %U",
2180 else if (
unformat (line_input,
"interface %U",
2183 else if (
unformat (line_input,
"preallocate-data %=",
2184 &preallocate_data, 1))
2186 else if (
unformat (line_input,
"free-data %=", &free_data, 1))
2188 else if (
unformat (line_input,
"intfc any")
2189 ||
unformat (line_input,
"interface any"))
2191 else if (
unformat (line_input,
"filter"))
2222 case VNET_API_ERROR_INVALID_VALUE:
2225 case VNET_API_ERROR_VALUE_EXIST:
2228 case VNET_API_ERROR_INVALID_VALUE_2:
2230 (0,
"can't change number of records to capture while tracing...");
2232 case VNET_API_ERROR_SYSCALL_ERROR_1:
2235 case VNET_API_ERROR_NO_SUCH_ENTRY:
2238 case VNET_API_ERROR_INVALID_MEMORY_SIZE:
2240 "Max bytes per pkt must be > 32, < 9000...");
2242 case VNET_API_ERROR_NO_SUCH_LABEL:
2244 (0,
"No classify filter configured, see 'classify filter...'");
2330 .path =
"pcap trace",
2332 "pcap trace [rx] [tx] [drop] [off] [max <nn>] [intfc <interface>|any]\n" 2333 " [file <name>] [status] [max-bytes-per-pkt <nnnn>][filter]\n" 2334 " [preallocate-data][free-data]",
unformat_function_t unformat_vnet_hw_interface
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
static clib_error_t * clear_interface_counters(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
format_function_t format_vnet_hw_if_rx_mode
format_function_t format_vnet_sw_interface
static clib_error_t * create_sub_interfaces(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define hash_set(h, key, value)
char * file_name
File name of pcap output.
static clib_error_t * promiscuous_cmd(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static clib_error_t * set_hw_class(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
clib_error_t * set_hw_interface_rx_placement(u32 hw_if_index, u32 queue_id, u32 thread_index, u8 is_main)
clib_error_t * set_interface_rss_queues(vlib_main_t *vm, u32 hw_if_index, clib_bitmap_t *bitmap)
static int sw_interface_name_compare(void *a1, void *a2)
__clib_export clib_error_t * pcap_write(pcap_main_t *pm)
Write PCAP file.
static clib_error_t * set_state(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
word vnet_sw_interface_compare(vnet_main_t *vnm, uword sw_if_index0, uword sw_if_index1)
format_function_t format_vlib_node_name
vl_api_wireguard_peer_flags_t flags
uword first_worker_thread_index
clib_error_t * vnet_sw_interface_set_flags(vnet_main_t *vnm, u32 sw_if_index, vnet_sw_interface_flags_t flags)
u32 n_packets_to_capture
Number of packets to capture.
static ip6_fib_t * ip6_fib_get(fib_node_index_t index)
static clib_error_t * set_interface_mac_address(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
vnet_main_t * vnet_get_main(void)
u8 * format_l2_output_features(u8 *s, va_list *args)
unformat_function_t unformat_hash_string
#define pool_foreach(VAR, POOL)
Iterate through pool.
vnet_interface_main_t interface_main
clib_error_t * vnet_hw_interface_set_rss_queues(vnet_main_t *vnm, vnet_hw_interface_t *hi, clib_bitmap_t *bitmap)
clib_memset(h->entries, 0, sizeof(h->entries[0]) *entries)
#define clib_bitmap_foreach(i, ai)
Macro to iterate across set bits in a bitmap.
static vnet_hw_interface_t * vnet_get_hw_interface(vnet_main_t *vnm, u32 hw_if_index)
clib_error_t * vnet_hw_interface_change_mac_address(vnet_main_t *vnm, u32 hw_if_index, const u8 *mac_address)
#define vec_add1(V, E)
Add 1 element to end of vector (unspecified alignment).
static void vnet_clear_sw_interface_tag(vnet_main_t *vnm, u32 sw_if_index)
static clib_error_t * set_tag(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static clib_error_t * renumber_interface_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define hash_set_mem(h, key, value)
ip_lookup_main_t lookup_main
clib_error_t * set_hw_interface_change_rx_mode(vnet_main_t *vnm, u32 hw_if_index, u8 queue_id_valid, u32 queue_id, vnet_hw_if_rx_mode mode)
static vnet_sw_interface_t * vnet_get_sw_interface(vnet_main_t *vnm, u32 sw_if_index)
uword * sub_interface_sw_if_index_by_id
u32 * fib_index_by_sw_if_index
Table index indexed by software interface.
unformat_function_t unformat_vnet_sw_interface
#define vec_validate_aligned(V, I, A)
Make sure vector is long enough for given index (no header, specified alignment)
static clib_error_t * clear_hw_interfaces(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
struct _vnet_device_class vnet_device_class_t
uword * dq_runtime_index_by_queue
static u8 * format_vnet_pcap(u8 *s, va_list *args)
format_function_t format_vnet_sw_if_index_name
static clib_error_t * interface_add_del_mac_address(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define vec_reset_length(v)
Reset vector length to zero NULL-pointer tolerant.
uword last_worker_thread_index
ethernet_main_t ethernet_main
format_function_t format_vnet_hw_interface
PCAP main state data structure.
clib_spinlock_t lock
spinlock to protect e.g.
void vlib_clear_combined_counters(vlib_combined_counter_main_t *cm)
Clear a collection of combined counters.
#define VLIB_INIT_FUNCTION(x)
static vnet_device_class_t * vnet_get_device_class(vnet_main_t *vnm, u32 dev_class_index)
#define vec_new(T, N)
Create new vector of given type and length (unspecified alignment, no header).
vlib_combined_counter_main_t * combined_sw_if_counters
static clib_error_t * parse_vlan_sub_interfaces(unformat_input_t *input, vnet_sw_interface_t *template)
Parse subinterface names.
description fragment has unexpected format
vnet_hw_if_rx_mode default_rx_mode
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
static vnet_sw_interface_t * vnet_get_sup_sw_interface(vnet_main_t *vnm, u32 sw_if_index)
u32 filter_classify_table_index
#define clib_error_return(e, args...)
static clib_error_t * set_unnumbered(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
A collection of simple counters.
clib_error_t * vnet_hw_interface_add_del_mac_address(vnet_main_t *vnm, u32 hw_if_index, const u8 *mac_address, u8 is_add)
ethernet_interface_address_t * secondary_addrs
u8 * vnet_trace_placeholder
static clib_error_t * mtu_cmd(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static void clib_spinlock_init(clib_spinlock_t *p)
u32 max_supported_packet_bytes
vl_api_fib_path_type_t type
vnet_hw_interface_t * hw_interfaces
__clib_export clib_error_t * pcap_close(pcap_main_t *pm)
Close PCAP file.
vlib_worker_thread_t * vlib_worker_threads
l2_output_config_t * l2output_intf_config(u32 sw_if_index)
Get a pointer to the config for the given interface.
#define pool_elt_at_index(p, i)
Returns pointer to element at given index.
vlib_node_t * vlib_get_node_by_name(vlib_main_t *vm, u8 *name)
void vnet_sw_interface_update_unnumbered(u32 unnumbered_sw_if_index, u32 ip_sw_if_index, u8 enable)
u8 * pcap_data
Vector of pcap data.
int vnet_pcap_dispatch_trace_configure(vnet_pcap_dispatch_trace_args_t *a)
int vnet_hw_interface_set_rx_mode(vnet_main_t *vnm, u32 hw_if_index, u16 queue_id, vnet_hw_if_rx_mode mode)
uword * sw_if_index_by_sup_and_sub
void vnet_hw_interface_set_mtu(vnet_main_t *vnm, u32 hw_if_index, u32 mtu)
static void * vlib_node_get_runtime_data(vlib_main_t *vm, u32 node_index)
Get node runtime private data by node index.
vnet_sw_interface_flags_t flags
clib_error_t * vnet_create_sw_interface(vnet_main_t *vnm, vnet_sw_interface_t *template, u32 *sw_if_index)
static clib_error_t * show_sw_interfaces(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
clib_error_t * vnet_hw_interface_set_class(vnet_main_t *vnm, u32 hw_if_index, u32 hw_class_index)
vlib_simple_counter_main_t * sw_if_counters
static clib_error_t * set_interface_rx_placement(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define foreach_vlib_main(body)
static int compare_interface_names(void *a1, void *a2)
uword * hw_interface_class_by_name
vl_api_tunnel_mode_t mode
void vnet_sw_interface_ip_directed_broadcast(vnet_main_t *vnm, u32 sw_if_index, u8 enable)
word vnet_hw_interface_compare(vnet_main_t *vnm, uword hw_if_index0, uword hw_if_index1)
#define VNET_HW_INTERFACE_BOND_INFO_SLAVE
static clib_error_t * set_interface_rss_queues_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static clib_error_t * clear_tag(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void vnet_interface_features_show(vlib_main_t *vm, u32 sw_if_index, int verbose)
Display the set of driver features configured on a specific interface Called by "show interface" hand...
sll srl srl sll sra u16x4 i
#define vec_free(V)
Free vector's memory (no header).
static ip4_fib_t * ip4_fib_get(u32 index)
Get the FIB at the given index.
#define clib_warning(format, args...)
static uword vnet_swif_is_api_visible(vnet_sw_interface_t *si)
#define ETHERNET_INTERFACE_FLAG_ACCEPT_ALL
static clib_error_t * pcap_trace_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
u32 unnumbered_sw_if_index
#define VLIB_CLI_COMMAND(x,...)
struct _vnet_classify_main vnet_classify_main_t
uword unformat_ethernet_address(unformat_input_t *input, va_list *args)
#define PCAP_MAIN_INIT_DONE
void vnet_hw_interface_assign_rx_thread(vnet_main_t *vnm, u32 hw_if_index, u16 queue_id, uword thread_index)
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
ip_lookup_main_t lookup_main
static void vnet_set_sw_interface_tag(vnet_main_t *vnm, u8 *tag, u32 sw_if_index)
Bitmaps built as vectors of machine words.
#define clib_error_report(e)
#define clib_bitmap_free(v)
Free a bitmap.
vnet_classify_main_t vnet_classify_main
static u8 * vnet_get_sw_interface_tag(vnet_main_t *vnm, u32 sw_if_index)
static clib_error_t * show_hw_interfaces(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void vnet_sw_interface_set_protocol_mtu(vnet_main_t *vnm, u32 sw_if_index, u32 mtu[])
static void * clib_mem_alloc(uword size)
uword unformat_ethernet_interface(unformat_input_t *input, va_list *args)
static vlib_main_t * vlib_get_main(void)
#define vec_elt(v, i)
Get vector value at index i.
static clib_error_t * show_or_clear_hw_interfaces(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd, int is_show)
static clib_error_t * show_interface_sec_mac_addr_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
pcap_packet_type_t packet_type
Packet type.
ethernet_interface_t * ethernet_get_interface(ethernet_main_t *em, u32 hw_if_index)
static void show_bond(vlib_main_t *vm)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
unformat_function_t unformat_vnet_sw_interface_flags
#define foreach_ip_interface_address(lm, a, sw_if_index, loop, body)
static clib_error_t * vnet_interface_cli_init(vlib_main_t *vm)
#define vec_sort_with_function(vec, f)
Sort a vector using the supplied element comparison function.
vnet_sw_interface_t * sw_interfaces
static clib_error_t * set_ip_directed_broadcast(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
A collection of combined counters.
#define hash_get_mem(h, key)
int vnet_hw_interface_unassign_rx_thread(vnet_main_t *vnm, u32 hw_if_index, u16 queue_id)
u32 l2vtr_get(vlib_main_t *vlib_main, vnet_main_t *vnet_main, u32 sw_if_index, u32 *vtr_op, u32 *push_dot1q, u32 *vtr_tag1, u32 *vtr_tag2)
Get vtag tag rewrite on the given interface.
static clib_error_t * set_hw_interface_rx_mode(vnet_main_t *vnm, u32 hw_if_index, u32 queue_id, vnet_hw_if_rx_mode mode)
u32 min_supported_packet_bytes
void vlib_clear_simple_counters(vlib_simple_counter_main_t *cm)
Clear a collection of simple counters.
ip4_main_t ip4_main
Global ip4 main structure.
int vnet_interface_name_renumber(u32 sw_if_index, u32 new_show_dev_instance)
u8 * format_mac_address_t(u8 *s, va_list *args)
#define vec_foreach(var, vec)
Vector iterator.
vnet_device_class_t * device_classes
static clib_error_t * set_interface_rx_mode(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define CLIB_CACHE_LINE_BYTES
u32 * fib_index_by_sw_if_index
u32 n_packets_captured
Number of packets currently captured.
static clib_error_t * show_interface_rx_placement_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
format_function_t format_vtr
vnet_device_main_t vnet_device_main
vl_api_interface_index_t sw_if_index
u32 ethernet_set_flags(vnet_main_t *vnm, u32 hw_if_index, u32 flags)
int vnet_hw_interface_get_rx_mode(vnet_main_t *vnm, u32 hw_if_index, u16 queue_id, vnet_hw_if_rx_mode *mode)
static uword pool_elts(void *v)
Number of active elements in a pool.