34 u8 switching_active = 0;
46 if (bif->
mode == BOND_MODE_ACTIVE_BACKUP)
55 if (i < bif->n_numa_slaves)
66 if ((bif->
mode == BOND_MODE_ACTIVE_BACKUP) && switching_active)
99 if (bif->
mode == BOND_MODE_LACP)
137 (bif->
mode == BOND_MODE_ACTIVE_BACKUP))
145 && (bif->
mode == BOND_MODE_ACTIVE_BACKUP)
169 if (bif->
mode == BOND_MODE_LACP)
188 bondif->
id = bif->
id;
197 bondif->
lb = bif->
lb;
204 *out_bondifs = r_bondifs;
211 u32 bond_sw_if_index)
247 *out_slaveifs = r_slaveifs;
290 if (bif->
mode == BOND_MODE_LACP)
305 u32 *sif_sw_if_index;
310 return VNET_API_ERROR_INVALID_SW_IF_INDEX;
348 args->
rv = VNET_API_ERROR_FEATURE_DISABLED;
352 if (args->
mode > BOND_MODE_LACP || args->
mode < BOND_MODE_ROUND_ROBIN)
354 args->
rv = VNET_API_ERROR_INVALID_ARGUMENT;
358 if (args->
lb > BOND_LB_L23)
360 args->
rv = VNET_API_ERROR_INVALID_ARGUMENT;
377 args->
rv = VNET_API_ERROR_INSTANCE_IN_USE;
384 if (bif->
mode == BOND_MODE_ROUND_ROBIN)
385 bif->
lb = BOND_LB_RR;
386 else if (bif->
mode == BOND_MODE_BROADCAST)
387 bif->
lb = BOND_LB_BC;
388 else if (bif->
mode == BOND_MODE_ACTIVE_BACKUP)
389 bif->
lb = BOND_LB_AB;
396 rnd = (
u32) (now * 1e6);
399 memcpy (args->
hw_addr + 2, &rnd, sizeof (rnd));
411 args->
rv = VNET_API_ERROR_INVALID_REGISTRATION;
459 args.
lb = BOND_LB_L2;
465 else if (((args.
mode == BOND_MODE_LACP) || (args.
mode == BOND_MODE_XOR))
466 &&
unformat (line_input,
"load-balance %U",
469 else if (
unformat (line_input,
"hw-addr %U",
472 else if (
unformat (line_input,
"id %u", &args.
id))
474 else if (
unformat (line_input,
"gso"))
476 else if (
unformat (line_input,
"numa-only"))
478 if (args.
mode == BOND_MODE_LACP)
482 "Only lacp mode supports numa-only so far!");
490 if (mode_is_set == 0)
504 .path =
"create bond",
505 .short_help =
"create bond mode {round-robin | active-backup | broadcast | " 506 "{lacp | xor} [load-balance { l2 | l23 | l34 } [numa-only]]} " 507 "[hw-addr <mac-address>] [id <if-id>] [gso]",
527 if (
unformat (line_input,
"sw_if_index %d", &sw_if_index))
538 if (sw_if_index == ~0)
540 "please specify interface name or sw_if_index");
543 if (rv == VNET_API_ERROR_INVALID_SW_IF_INDEX)
554 .path =
"delete bond",
555 .short_help =
"delete bond {<interface> | sw_if_index <sw_idx>}",
576 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
583 args->
rv = VNET_API_ERROR_VALUE_EXIST;
590 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
597 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
602 if (bif->
mode == BOND_MODE_LACP)
613 if (args->
error != 0)
615 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
684 if (bif->
mode == BOND_MODE_LACP)
715 "Error encountered on input feature arc enable");
739 else if (
unformat (line_input,
"passive"))
741 else if (
unformat (line_input,
"long-timeout"))
754 if (args.
group == ~0)
756 if (args.
slave == ~0)
767 .short_help =
"bond add <BondEthernetx> <slave-interface> " 768 "[passive] [long-timeout]",
782 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
819 if (args.
slave == ~0)
830 .short_help =
"bond del <slave-interface>",
842 "interface name",
"sw_if_index",
"mode",
843 "load balance",
"active slaves",
"slaves");
848 vlib_cli_output (vm,
"%-16U %-12d %-13U %-13U %-14u %u",
849 format_bond_interface_name, bif->dev_instance,
850 bif->sw_if_index, format_bond_mode, bif->mode,
851 format_bond_load_balance, bif->lb,
852 vec_len (bif->active_slaves), vec_len (bif->slaves));
867 vlib_cli_output (vm,
"%U", format_bond_interface_name, bif->dev_instance);
868 vlib_cli_output (vm,
" mode: %U",
869 format_bond_mode, bif->mode);
870 vlib_cli_output (vm,
" load balance: %U",
871 format_bond_load_balance, bif->lb);
873 vlib_cli_output (vm,
" gso enable");
874 if (bif->mode == BOND_MODE_ROUND_ROBIN)
875 vlib_cli_output (vm,
" last xmit slave index: %u",
876 bif->lb_rr_last_index);
877 vlib_cli_output (vm,
" number of active slaves: %d",
878 vec_len (bif->active_slaves));
879 vec_foreach (sw_if_index, bif->active_slaves)
881 vlib_cli_output (vm,
" %U", format_vnet_sw_if_index_name,
882 vnet_get_main (), *sw_if_index);
887 vlib_cli_output (vm,
" %U", format_vnet_sw_if_index_name,
888 vnet_get_main (), *sw_if_index);
926 .short_help =
"show bond [details]",
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
static uword vnet_sw_interface_is_up(vnet_main_t *vnm, u32 sw_if_index)
#define vec_foreach_index(var, v)
Iterate over vector indices.
static uword unformat_bond_mode(unformat_input_t *input, va_list *args)
#define hash_set(h, key, value)
static void bond_delete_neighbor(vlib_main_t *vm, bond_if_t *bif, slave_if_t *sif)
static void show_bond_details(vlib_main_t *vm)
vlib_node_registration_t bond_process_node
(constructor) VLIB_REGISTER_NODE (bond_process_node)
int bond_delete_if(vlib_main_t *vm, u32 sw_if_index)
#define hash_unset(h, key)
void ethernet_delete_interface(vnet_main_t *vnm, u32 hw_if_index)
vnet_main_t * vnet_get_main(void)
static vnet_hw_interface_t * vnet_get_sup_hw_interface(vnet_main_t *vnm, u32 sw_if_index)
static clib_error_t * detach_interface_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
vnet_interface_main_t interface_main
int bond_dump_ifs(bond_interface_details_t **out_bondifs)
static bond_if_t * bond_get_master_by_sw_if_index(u32 sw_if_index)
clib_memset(h->entries, 0, sizeof(h->entries[0]) *entries)
static f64 vlib_time_now(vlib_main_t *vm)
static_always_inline void clib_spinlock_unlock_if_init(clib_spinlock_t *p)
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).
#define vec_add2(V, P, N)
Add N elements to end of vector V, return pointer to new elements in P.
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. ...
static vnet_sw_interface_t * vnet_get_sw_interface(vnet_main_t *vnm, u32 sw_if_index)
lacp_enable_disable_func lacp_enable_disable
unformat_function_t unformat_vnet_sw_interface
static clib_error_t * enslave_interface_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define vec_validate_aligned(V, I, A)
Make sure vector is long enough for given index (no header, specified alignment)
#define pool_get(P, E)
Allocate an object E from a pool P (unspecified alignment).
void bond_enable_collecting_distributing(vlib_main_t *vm, slave_if_t *sif)
format_function_t format_vnet_sw_if_index_name
bond_per_thread_data_t * per_thread_data
static vnet_sw_interface_t * vnet_get_hw_sw_interface(vnet_main_t *vnm, u32 hw_if_index)
#define clib_memcpy(d, s, n)
static clib_error_t * show_bond_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define pool_foreach(VAR, POOL, BODY)
Iterate through pool.
vl_api_interface_index_t sw_if_index
#define VLIB_INIT_FUNCTION(x)
vnet_hw_interface_flags_t flags
void bond_enslave(vlib_main_t *vm, bond_enslave_args_t *args)
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
#define clib_error_return(e, args...)
static void clib_spinlock_init(clib_spinlock_t *p)
static clib_error_t * bond_create_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define LACP_LONG_TIMOUT_TIME
vnet_device_class_t bond_dev_class
#define pool_elt_at_index(p, i)
Returns pointer to element at given index.
static void vlib_process_signal_event(vlib_main_t *vm, uword node_index, uword type_opaque, uword data)
static uword unformat_bond_load_balance(unformat_input_t *input, va_list *args)
u8 persistent_hw_address[6]
#define pool_put(P, E)
Free an object E in pool P.
#define vec_del1(v, i)
Delete the element at index I.
#define LACP_SHORT_TIMOUT_TIME
static clib_error_t * bond_delete_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void bond_detach_slave(vlib_main_t *vm, bond_detach_slave_args_t *args)
#define vec_free(V)
Free vector's memory (no header).
uword * bond_by_sw_if_index
void bond_disable_collecting_distributing(vlib_main_t *vm, slave_if_t *sif)
#define ETHERNET_INTERFACE_FLAG_ACCEPT_ALL
static void show_bond(vlib_main_t *vm)
BOND interface details struct.
#define VLIB_CLI_COMMAND(x,...)
uword * slave_by_sw_if_index
clib_error_t * stat_segment_deregister_state_counter(u32 index)
uword unformat_ethernet_address(unformat_input_t *input, va_list *args)
void bond_create_if(vlib_main_t *vm, bond_create_if_args_t *args)
static bond_if_t * bond_get_master_by_dev_instance(u32 dev_instance)
#define vec_insert_elts(V, E, N, M)
Insert N vector elements starting at element M, insert given elements (no header, unspecified alignme...
#define vec_append(v1, v2)
Append v2 after v1.
#define clib_bitmap_free(v)
Free a bitmap.
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
clib_error_t * ethernet_register_interface(vnet_main_t *vnm, u32 dev_class_index, u32 dev_instance, const u8 *address, u32 *hw_if_index_return, ethernet_flag_change_function_t flag_change)
clib_error_t * vnet_hw_interface_set_flags(vnet_main_t *vnm, u32 hw_if_index, vnet_hw_interface_flags_t flags)
uword * port_number_bitmap
vnet_sw_interface_t * sw_interfaces
int bond_dump_slave_ifs(slave_interface_details_t **out_slaveifs, u32 bond_sw_if_index)
slave interface details struct
static u32 random_u32(u32 *seed)
32-bit random number generator
clib_error_t * vnet_sw_interface_set_flags(vnet_main_t *vnm, u32 sw_if_index, vnet_sw_interface_flags_t flags)
static vlib_thread_main_t * vlib_get_thread_main()
#define vec_foreach(var, vec)
Vector iterator.
clib_error_t * vnet_hw_interface_change_mac_address(vnet_main_t *vnm, u32 hw_if_index, const u8 *mac_address)
static slave_if_t * bond_get_slave_by_sw_if_index(u32 sw_if_index)
lacp_port_info_t actor_admin
clib_error_t * bond_cli_init(vlib_main_t *vm)
#define CLIB_CACHE_LINE_BYTES
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
static_always_inline void clib_spinlock_lock_if_init(clib_spinlock_t *p)
clib_error_t * stat_segment_register_state_counter(u8 *name, u32 *index)
void stat_segment_set_state_counter(u32 index, u64 value)
int vnet_feature_enable_disable(const char *arc_name, const char *node_name, u32 sw_if_index, int enable_disable, void *feature_config, u32 n_feature_config_bytes)
bond_per_port_queue_t * per_port_queue
u32 ethernet_set_flags(vnet_main_t *vnm, u32 hw_if_index, u32 flags)