X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Finterface_funcs.h;h=6e188f7f543abc94f8e3df87f3e0090cd0708d5a;hb=fe7d4a2e31529eed5416b38b520fdc84687df03c;hp=6f7ed111e4628314e02fc622ebe2579588fca173;hpb=ad8015be47a8d7d4c1f94b51ad9c70e37cc29cbf;p=vpp.git diff --git a/src/vnet/interface_funcs.h b/src/vnet/interface_funcs.h index 6f7ed111e46..6e188f7f543 100644 --- a/src/vnet/interface_funcs.h +++ b/src/vnet/interface_funcs.h @@ -160,6 +160,14 @@ u32 vnet_register_interface (vnet_main_t * vnm, u32 dev_instance, u32 hw_class_index, u32 hw_instance); +/** + * Set interface output node - for interface registered without its output/tx + * nodes created because its VNET_DEVICE_CLASS did not specify any tx_function. + * This is typically the case for tunnel interfaces. + */ +void vnet_set_interface_output_node (vnet_main_t * vnm, + u32 hw_if_index, u32 node_index); + /* Creates a software interface given template. */ clib_error_t *vnet_create_sw_interface (vnet_main_t * vnm, vnet_sw_interface_t * template, @@ -237,7 +245,7 @@ always_inline vlib_frame_t * vnet_get_frame_to_sw_interface (vnet_main_t * vnm, u32 sw_if_index) { vnet_hw_interface_t *hw = vnet_get_sup_hw_interface (vnm, sw_if_index); - return vlib_get_frame_to_node (vnm->vlib_main, hw->output_node_index); + return vlib_get_frame_to_node (vlib_get_main (), hw->output_node_index); } always_inline void @@ -245,7 +253,7 @@ vnet_put_frame_to_sw_interface (vnet_main_t * vnm, u32 sw_if_index, vlib_frame_t * f) { vnet_hw_interface_t *hw = vnet_get_sup_hw_interface (vnm, sw_if_index); - return vlib_put_frame_to_node (vnm->vlib_main, hw->output_node_index, f); + return vlib_put_frame_to_node (vlib_get_main (), hw->output_node_index, f); } /* Change interface flags (e.g. up, down, enable, disable). */ @@ -274,7 +282,7 @@ clib_error_t *vnet_rename_interface (vnet_main_t * vnm, u32 hw_if_index, /* Change interface mac address*/ clib_error_t *vnet_hw_interface_change_mac_address (vnet_main_t * vnm, u32 hw_if_index, - u64 mac_address); + u8 * mac_address); /* Change rx-mode */ clib_error_t *set_hw_interface_change_rx_mode (vnet_main_t * vnm, @@ -284,6 +292,16 @@ clib_error_t *set_hw_interface_change_rx_mode (vnet_main_t * vnm, vnet_hw_interface_rx_mode mode); +/* Set the MTU on the HW interface */ +void vnet_hw_interface_set_mtu (vnet_main_t * vnm, u32 hw_if_index, u32 mtu); + +/* update the unnumbered state of an interface */ +void vnet_sw_interface_update_unnumbered (u32 sw_if_index, + u32 ip_sw_if_index, u8 enable); + +int vnet_sw_interface_stats_collect_enable_disable (u32 sw_if_index, + u8 enable); + /* Formats sw/hw interface. */ format_function_t format_vnet_hw_interface; format_function_t format_vnet_hw_interface_rx_mode;