74 u32 hw_if_index, *hw_if_indices = 0;
82 vec_add1 (hw_if_indices, hw_if_index);
85 else if (
unformat (input,
"%u", &hw_if_index))
86 vec_add1 (hw_if_indices, hw_if_index);
88 else if (
unformat (input,
"verbose"))
113 if (
vec_len (hw_if_indices) == 0)
126 for (i = 0; i <
vec_len (hw_if_indices); i++)
143 shi = vnet_get_hw_interface(vnm, hw_idx);
144 vlib_cli_output (vm,
"%U\n",
145 format_vnet_hw_interface, vnm, shi, verbose);
153 for (i = 0; i <
vec_len (hw_if_indices); i++)
160 if (dc->clear_counters)
243 .path =
"show hardware-interfaces",
244 .short_help =
"show hardware-interfaces [brief|verbose|detail] [bond] " 245 "[<interface> [<interface> [..]]] [<sw_idx> [<sw_idx> [..]]]",
264 .path =
"clear hardware-interfaces",
265 .short_help =
"clear hardware-interfaces " 266 "[<interface> [<interface> [..]]] [<sw_idx> [<sw_idx> [..]]]",
291 u8 show_addresses = 0;
292 u8 show_features = 0;
317 else if (
unformat (linput,
"verbose"))
329 if (show_features || show_tag)
331 if (sw_if_index == ~(
u32) 0)
365 tag ? (
char *) tag :
"(none)");
378 _vec_len (sorted_sis) = 0;
382 int visible = vnet_swif_is_api_visible (si);
384 vec_add1 (sorted_sis, si[0]);}
400 u32 fib_index4 = 0, fib_index6 = 0;
415 (vm,
"%U (%s): \n unnumbered, use %U",
433 l2_input->
bvi ?
"bvi" :
" ");
445 ip4_address_t *r4 = ip_interface_address_get_address (lm4, ia);
447 vlib_cli_output (vm,
" L3 %U/%d ip4 table-id %d fib-idx %d",
448 format_ip4_address, r4, ia->address_length,
450 ip4_fib_index_from_table_id (fib4->table_id));
452 vlib_cli_output (vm,
" L3 %U/%d",
453 format_ip4_address, r4, ia->address_length);
462 ip6_address_t *r6 = ip_interface_address_get_address (lm6, ia);
464 vlib_cli_output (vm,
" L3 %U/%d ip6 table-id %d fib-idx %d",
465 format_ip6_address, r6, ia->address_length,
467 ip6_fib_index_from_table_id (fib6->table_id));
469 vlib_cli_output (vm,
" L3 %U/%d",
470 format_ip6_address, r6, ia->address_length);
490 .path =
"show interface",
491 .short_help =
"show interface [address|addr|features|feat] [<interface> [<interface> [..]]] [verbose]",
501 .short_help =
"Interface commands",
507 .path =
"set interface",
508 .short_help =
"Interface commands",
524 for (j = 0; j < n_counters; j++)
533 for (j = 0; j < n_counters; j++)
553 .path =
"clear interfaces",
554 .short_help =
"clear interfaces",
626 u32 inner_vlan, outer_vlan;
628 if (
unformat (input,
"any inner-dot1q any"))
630 template->sub.eth.
flags.two_tags = 1;
631 template->sub.eth.flags.outer_vlan_id_any = 1;
632 template->sub.eth.flags.inner_vlan_id_any = 1;
636 template->sub.eth.flags.one_tag = 1;
637 template->sub.eth.flags.outer_vlan_id_any = 1;
639 else if (
unformat (input,
"%d inner-dot1q any", &outer_vlan))
641 template->sub.eth.flags.two_tags = 1;
642 template->sub.eth.flags.inner_vlan_id_any = 1;
643 template->sub.eth.outer_vlan_id = outer_vlan;
645 else if (
unformat (input,
"%d inner-dot1q %d", &outer_vlan, &inner_vlan))
647 template->sub.eth.flags.two_tags = 1;
648 template->sub.eth.outer_vlan_id = outer_vlan;
649 template->sub.eth.inner_vlan_id = inner_vlan;
651 else if (
unformat (input,
"%d", &outer_vlan))
653 template->sub.eth.flags.one_tag = 1;
654 template->sub.eth.outer_vlan_id = outer_vlan;
665 if (
unformat (input,
"exact-match"))
667 template->sub.eth.flags.exact_match = 1;
683 u32 id, id_min, id_max;
695 template.sub.eth.raw_flags = 0;
697 if (
unformat (input,
"%d default", &id_min))
700 template.sub.eth.flags.default_sub = 1;
702 else if (
unformat (input,
"%d untagged", &id_min))
705 template.sub.eth.flags.no_tags = 1;
706 template.sub.eth.flags.exact_match = 1;
708 else if (
unformat (input,
"%d dot1q", &id_min))
716 else if (
unformat (input,
"%d dot1ad", &id_min))
720 template.sub.eth.flags.dot1ad = 1;
725 else if (
unformat (input,
"%d-%d", &id_min, &id_max))
727 template.sub.eth.flags.one_tag = 1;
728 template.sub.eth.flags.exact_match = 1;
732 else if (
unformat (input,
"%d", &id_min))
735 template.sub.eth.flags.one_tag = 1;
736 template.sub.eth.outer_vlan_id = id_min;
737 template.sub.eth.flags.exact_match = 1;
753 "not allowed as %v belong to a BondEthernet interface",
758 for (
id = id_min;
id <= id_max;
id++)
769 clib_warning (
"sup sw_if_index %d, sub id %d already exists\n",
777 template.sub.id =
id;
779 template.sub.eth.outer_vlan_id =
id;
786 *kp = sup_and_sub_key;
884 .path =
"create sub-interfaces",
885 .short_help =
"create sub-interfaces <interface> " 886 "{<subId> [default|untagged]} | " 887 "{<subId>-<subId>} | " 888 "{<subId> dot1q|dot1ad <vlanId>|any [inner-dot1q <vlanId>|any] [exact-match]}",
941 .path =
"set interface state",
942 .short_help =
"set interface state <interface> [up|down|punt|enable]",
952 u32 unnumbered_sw_if_index = ~0;
953 u32 inherit_from_sw_if_index = ~0;
962 &unnumbered_sw_if_index))
968 if (~0 == unnumbered_sw_if_index)
970 if (enable && ~0 == inherit_from_sw_if_index)
972 " IP enabled interface that it uses");
975 inherit_from_sw_if_index, enable);
982 .path =
"set interface unnumbered",
983 .short_help =
"set interface unnumbered [<interface> use <interface> | del <interface>]",
997 u32 hw_if_index, hw_class_index;
1025 .path =
"set interface hw-class",
1026 .short_help =
"Set interface hardware class",
1045 u32 new_dev_instance;
1053 if (!
unformat (input,
"%d", &new_dev_instance))
1075 .path =
"renumber interface",
1076 .short_help =
"renumber interface <interface> <new-dev-instance>",
1094 else if (
unformat (input,
"off %U",
1111 .path =
"set interface promiscuous",
1112 .short_help =
"set interface promiscuous [on|off] <interface>",
1125 if (
unformat (input,
"%d %U", &mtu,
1138 if (mtu < hi->min_supported_packet_bytes)
1140 "must be >= min pkt bytes (%d)", mtu,
1150 else if (
unformat (input,
"packet %d %U", &mtu,
1154 else if (
unformat (input,
"ip4 %d %U", &mtu,
1157 else if (
unformat (input,
"ip6 %d %U", &mtu,
1160 else if (
unformat (input,
"mpls %d %U", &mtu,
1175 .path =
"set interface mtu",
1176 .short_help =
"set interface mtu [packet|ip4|ip6|mpls] <value> <interface>",
1225 .path =
"set interface mac address",
1226 .short_help =
"set interface mac address <interface> <mac-address>",
1239 vnm, &sw_if_index, &tag))
1250 .path =
"set interface tag",
1251 .short_help =
"set interface tag <interface> <tag>",
1274 .path =
"clear interface tag",
1275 .short_help =
"clear interface tag <interface>",
1289 else if (
unformat (input,
"enable"))
1291 else if (
unformat (input,
"disable"))
1297 if (~0 == sw_if_index)
1314 .path =
"set interface ip directed-broadcast",
1315 .short_help =
"set interface enable <interface> <enable|disable>",
1338 if (old_mode == mode)
1341 case VNET_API_ERROR_INVALID_INTERFACE:
1343 case VNET_API_ERROR_INVALID_QUEUE:
1349 if (dev_class->rx_mode_change_function)
1351 error = dev_class->rx_mode_change_function (vnm, hw_if_index, queue_id,
1362 case VNET_API_ERROR_UNSUPPORTED:
1364 case VNET_API_ERROR_INVALID_INTERFACE:
1366 case VNET_API_ERROR_INVALID_QUEUE:
1377 u8 queue_id_valid,
u32 queue_id,
1386 if (queue_id_valid == 0)
1409 u32 hw_if_index = (
u32) ~ 0;
1410 u32 queue_id = (
u32) ~ 0;
1412 u8 queue_id_valid = 0;
1422 else if (
unformat (line_input,
"queue %d", &queue_id))
1424 else if (
unformat (line_input,
"polling"))
1426 else if (
unformat (line_input,
"interrupt"))
1428 else if (
unformat (line_input,
"adaptive"))
1441 if (hw_if_index == (
u32) ~ 0)
1488 .path =
"set interface rx-mode",
1489 .short_help =
"set interface rx-mode <interface> [queue <n>] [polling | interrupt | adaptive]",
1510 rt = vlib_node_get_runtime_data (this_vlib_main, si);
1512 if (vec_len (rt->devices_and_queues))
1513 s = format (s,
" node %U:\n", format_vlib_node_name, vm, si);
1515 vec_foreach (dq, rt->devices_and_queues)
1517 vnet_hw_interface_t *hi = vnet_get_hw_interface (vnm,
1519 s = format (s,
" %U queue %u (%U)\n",
1520 format_vnet_sw_if_index_name, vnm, hi->sw_if_index,
1522 format_vnet_hw_interface_rx_mode, dq->mode);
1566 .path =
"show interface rx-placement",
1567 .short_help =
"show interface rx-placement",
1574 u32 thread_index,
u8 is_main)
1589 "please specify valid worker thread or main");
1615 u32 hw_if_index = (
u32) ~ 0;
1617 u32 thread_index = (
u32) ~ 0;
1628 else if (
unformat (line_input,
"queue %d", &queue_id))
1630 else if (
unformat (line_input,
"main", &thread_index))
1632 else if (
unformat (line_input,
"worker %d", &thread_index))
1645 if (hw_if_index == (
u32) ~ 0)
1704 .path =
"set interface rx-placement",
1705 .short_help =
"set interface rx-placement <interface> [queue <n>] " 1706 "[worker <n> | main]",
1716 int type = va_arg (*args,
int);
1742 s =
format (s,
"unknown type %d!", type);
1761 (vm,
"pcap %U dispatch capture enabled: %d of %d pkts...",
1777 return VNET_API_ERROR_INVALID_VALUE;
1782 return VNET_API_ERROR_VALUE_EXIST;
1788 return VNET_API_ERROR_INVALID_VALUE_2;
1794 (set->table_indices == 0 || set->table_indices[0] == ~0))
1795 return VNET_API_ERROR_NO_SUCH_LABEL;
1799 void *save_pcap_data;
1803 return VNET_API_ERROR_INVALID_MEMORY_SIZE;
1814 memset (pm, 0,
sizeof (*pm));
1827 stem =
format (stem,
"rx");
1829 stem =
format (stem,
"tx");
1831 stem =
format (stem,
"drop");
1877 return VNET_API_ERROR_SYSCALL_ERROR_1;
1885 return VNET_API_ERROR_NO_SUCH_ENTRY;
1900 u32 max_bytes_per_pkt = 512;
1904 int preallocate_data = 0;
1905 int drop_enable = 0;
1919 else if (
unformat (line_input,
"tx"))
1921 else if (
unformat (line_input,
"drop"))
1923 else if (
unformat (line_input,
"off"))
1924 rx_enable = tx_enable = drop_enable = 0;
1925 else if (
unformat (line_input,
"max-bytes-per-pkt %u",
1926 &max_bytes_per_pkt))
1928 else if (
unformat (line_input,
"max %d", &max))
1930 else if (
unformat (line_input,
"packets-to-capture %d", &max))
1935 else if (
unformat (line_input,
"status %=", &status, 1))
1937 else if (
unformat (line_input,
"intfc %U",
1940 else if (
unformat (line_input,
"interface %U",
1943 else if (
unformat (line_input,
"preallocate-data %=",
1944 &preallocate_data, 1))
1946 else if (
unformat (line_input,
"free-data %=", &free_data, 1))
1948 else if (
unformat (line_input,
"intfc any")
1949 ||
unformat (line_input,
"interface any"))
1951 else if (
unformat (line_input,
"filter"))
1982 case VNET_API_ERROR_INVALID_VALUE:
1985 case VNET_API_ERROR_VALUE_EXIST:
1988 case VNET_API_ERROR_INVALID_VALUE_2:
1990 (0,
"can't change number of records to capture while tracing...");
1992 case VNET_API_ERROR_SYSCALL_ERROR_1:
1995 case VNET_API_ERROR_NO_SUCH_ENTRY:
1998 case VNET_API_ERROR_INVALID_MEMORY_SIZE:
2000 "Max bytes per pkt must be > 32, < 9000...");
2002 case VNET_API_ERROR_NO_SUCH_LABEL:
2004 (0,
"No classify filter configured, see 'classify filter...'");
2090 .path =
"pcap trace",
2092 "pcap trace [rx] [tx] [drop] [off] [max <nn>] [intfc <interface>|any]\n" 2093 " [file <name>] [status] [max-bytes-per-pkt <nnnn>][filter]\n" 2094 " [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) ...
#define foreach_ip_interface_address(lm, a, sw_if_index, loop, body)
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_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)
static int sw_interface_name_compare(void *a1, void *a2)
void vnet_sw_interface_ip_directed_broadcast(vnet_main_t *vnm, u32 sw_if_index, u8 enable)
static clib_error_t * set_state(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
uword first_worker_thread_index
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
vnet_interface_main_t interface_main
clib_memset(h->entries, 0, sizeof(h->entries[0]) *entries)
static vnet_hw_interface_t * vnet_get_hw_interface(vnet_main_t *vnm, u32 hw_if_index)
#define vec_add1(V, E)
Add 1 element to end of vector (unspecified alignment).
word vnet_sw_interface_compare(vnet_main_t *vnm, uword sw_if_index0, uword sw_if_index1)
int vnet_interface_name_renumber(u32 sw_if_index, u32 new_show_dev_instance)
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
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
#define vec_reset_length(v)
Reset vector length to zero NULL-pointer tolerant.
uword last_worker_thread_index
ethernet_main_t ethernet_main
vnet_hw_interface_rx_mode
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 pool_foreach(VAR, POOL, BODY)
Iterate through pool.
vl_api_interface_index_t sw_if_index
#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.
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
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.
void vnet_sw_interface_set_protocol_mtu(vnet_main_t *vnm, u32 sw_if_index, u32 mtu[])
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_error_t * pcap_close(pcap_main_t *pm)
Close PCAP file.
vlib_worker_thread_t * vlib_worker_threads
#define clib_bitmap_foreach(i, ai, body)
Macro to iterate across set bits in a bitmap.
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.
u8 * pcap_data
Vector of pcap data.
int vnet_pcap_dispatch_trace_configure(vnet_pcap_dispatch_trace_args_t *a)
int vnet_hw_interface_get_rx_mode(vnet_main_t *vnm, u32 hw_if_index, u16 queue_id, vnet_hw_interface_rx_mode *mode)
uword * sw_if_index_by_sup_and_sub
vnet_sw_interface_flags_t flags
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_interface_rx_mode mode)
static clib_error_t * show_sw_interfaces(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
vlib_simple_counter_main_t * sw_if_counters
word vnet_hw_interface_compare(vnet_main_t *vnm, uword hw_if_index0, uword hw_if_index1)
static clib_error_t * set_interface_rx_placement(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void vnet_sw_interface_update_unnumbered(u32 unnumbered_sw_if_index, u32 ip_sw_if_index, u8 enable)
#define foreach_vlib_main(body)
static int compare_interface_names(void *a1, void *a2)
uword * hw_interface_class_by_name
#define VNET_HW_INTERFACE_BOND_INFO_SLAVE
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...
#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...)
#define ETHERNET_INTERFACE_FLAG_ACCEPT_ALL
vlib_node_t * vlib_get_node_by_name(vlib_main_t *vm, u8 *name)
static void show_bond(vlib_main_t *vm)
clib_error_t * pcap_write(pcap_main_t *pm)
Write PCAP file.
vl_api_vxlan_gbp_api_tunnel_mode_t mode
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)
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)
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)
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)
pcap_packet_type_t packet_type
Packet type.
void vnet_hw_interface_set_mtu(vnet_main_t *vnm, u32 hw_if_index, u32 mtu)
ethernet_interface_t * ethernet_get_interface(ethernet_main_t *em, u32 hw_if_index)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
unformat_function_t unformat_vnet_sw_interface_flags
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)
static clib_error_t * set_hw_interface_rx_mode(vnet_main_t *vnm, u32 hw_if_index, u32 queue_id, vnet_hw_interface_rx_mode mode)
l2_bridge_domain_t * bd_configs
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 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.
clib_error_t * vnet_sw_interface_set_flags(vnet_main_t *vnm, u32 sw_if_index, vnet_sw_interface_flags_t flags)
#define vec_foreach(var, vec)
Vector iterator.
vnet_hw_interface_rx_mode default_rx_mode
vnet_device_class_t * device_classes
u32 bd_find_index(bd_main_t *bdm, u32 bd_id)
Get a bridge domain.
int vnet_hw_interface_set_rx_mode(vnet_main_t *vnm, u32 hw_if_index, u16 queue_id, vnet_hw_interface_rx_mode mode)
static clib_error_t * set_interface_rx_mode(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
clib_error_t * vnet_hw_interface_change_mac_address(vnet_main_t *vnm, u32 hw_if_index, const u8 *mac_address)
clib_error_t * vnet_create_sw_interface(vnet_main_t *vnm, vnet_sw_interface_t *template, u32 *sw_if_index)
#define CLIB_CACHE_LINE_BYTES
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
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)
vnet_device_main_t vnet_device_main
u32 ethernet_set_flags(vnet_main_t *vnm, u32 hw_if_index, u32 flags)
clib_error_t * vnet_hw_interface_set_class(vnet_main_t *vnm, u32 hw_if_index, u32 hw_class_index)
static uword pool_elts(void *v)
Number of active elements in a pool.