32 u8 switching_active = 0;
41 if ((bif->
mode == BOND_MODE_ACTIVE_BACKUP) && (i == 0) &&
51 if (i < bif->n_numa_members)
162 if (bif->
mode == BOND_MODE_ACTIVE_BACKUP)
190 bondif->
id = bif->
id;
199 bondif->
lb = bif->
lb;
206 *out_bondifs = r_bondifs;
213 u32 bond_sw_if_index)
230 vec_add2 (r_memberifs, memberif, 1);
251 *out_memberifs = r_memberifs;
279 sec_mac->
bytes, is_add);
324 if (bif->
mode == BOND_MODE_LACP)
343 u32 *mif_sw_if_index;
348 return VNET_API_ERROR_INVALID_SW_IF_INDEX;
387 args->
rv = VNET_API_ERROR_FEATURE_DISABLED;
391 if (args->
mode > BOND_MODE_LACP || args->
mode < BOND_MODE_ROUND_ROBIN)
393 args->
rv = VNET_API_ERROR_INVALID_ARGUMENT;
397 if (args->
lb > BOND_LB_L23)
399 args->
rv = VNET_API_ERROR_INVALID_ARGUMENT;
416 args->
rv = VNET_API_ERROR_INSTANCE_IN_USE;
423 if (bif->
mode == BOND_MODE_ROUND_ROBIN)
424 bif->
lb = BOND_LB_RR;
425 else if (bif->
mode == BOND_MODE_BROADCAST)
426 bif->
lb = BOND_LB_BC;
427 else if (bif->
mode == BOND_MODE_ACTIVE_BACKUP)
428 bif->
lb = BOND_LB_AB;
435 rnd = (
u32) (now * 1e6);
438 memcpy (args->
hw_addr + 2, &rnd, sizeof (rnd));
450 args->
rv = VNET_API_ERROR_INVALID_REGISTRATION;
497 args.
lb = BOND_LB_L2;
503 else if (((args.
mode == BOND_MODE_LACP) || (args.
mode == BOND_MODE_XOR))
504 &&
unformat (line_input,
"load-balance %U",
507 else if (
unformat (line_input,
"hw-addr %U",
510 else if (
unformat (line_input,
"id %u", &args.
id))
512 else if (
unformat (line_input,
"gso"))
514 else if (
unformat (line_input,
"numa-only"))
516 if (args.
mode == BOND_MODE_LACP)
520 "Only lacp mode supports numa-only so far!");
528 if (mode_is_set == 0)
542 .path =
"create bond",
543 .short_help =
"create bond mode {round-robin | active-backup | broadcast | " 544 "{lacp | xor} [load-balance { l2 | l23 | l34 } [numa-only]]} " 545 "[hw-addr <mac-address>] [id <if-id>] [gso]",
565 if (
unformat (line_input,
"sw_if_index %d", &sw_if_index))
576 if (sw_if_index == ~0)
578 "please specify interface name or sw_if_index");
581 if (rv == VNET_API_ERROR_INVALID_SW_IF_INDEX)
592 .path =
"delete bond",
593 .short_help =
"delete bond {<interface> | sw_if_index <sw_idx>}",
614 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
621 args->
rv = VNET_API_ERROR_VALUE_EXIST;
623 (0,
"interface was already added as member");
629 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
636 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
641 if (bif->
mode == BOND_MODE_LACP)
651 if (args->
error != 0)
653 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
664 if (args->
error != 0)
666 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
738 if (bif->
mode == BOND_MODE_LACP)
769 "Error encountered on input feature arc enable");
793 else if (
unformat (line_input,
"passive"))
795 else if (
unformat (line_input,
"long-timeout"))
808 if (args.
group == ~0)
812 "please specify valid member interface name");
822 .short_help =
"bond add <BondEthernetx> <member-interface> " 823 "[passive] [long-timeout]",
837 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
876 "please specify valid member interface name");
886 .short_help =
"bond del <member-interface>",
898 "interface name",
"sw_if_index",
"mode",
899 "load balance",
"active members",
"members");
904 vlib_cli_output (vm,
"%-16U %-12d %-13U %-13U %-14u %u",
905 format_bond_interface_name, bif->dev_instance,
906 bif->sw_if_index, format_bond_mode, bif->mode,
907 format_bond_load_balance, bif->lb,
908 vec_len (bif->active_members), vec_len (bif->members));
923 vlib_cli_output (vm,
"%U", format_bond_interface_name, bif->dev_instance);
924 vlib_cli_output (vm,
" mode: %U",
925 format_bond_mode, bif->mode);
926 vlib_cli_output (vm,
" load balance: %U",
927 format_bond_load_balance, bif->lb);
929 vlib_cli_output (vm,
" gso enable");
930 if (bif->mode == BOND_MODE_ROUND_ROBIN)
931 vlib_cli_output (vm,
" last xmit member index: %u",
932 bif->lb_rr_last_index);
933 vlib_cli_output (vm,
" number of active members: %d",
934 vec_len (bif->active_members));
935 vec_foreach (sw_if_index, bif->active_members)
937 vlib_cli_output (vm,
" %U", format_vnet_sw_if_index_name,
938 vnet_get_main (), *sw_if_index);
939 if (bif->mode == BOND_MODE_ACTIVE_BACKUP)
941 member_if_t *mif = bond_get_member_by_sw_if_index (*sw_if_index);
943 vlib_cli_output (vm,
" weight: %u, is_local_numa: %u, " 944 "sw_if_index: %u", mif->weight,
945 mif->is_local_numa, mif->sw_if_index);
951 vlib_cli_output (vm,
" %U", format_vnet_sw_if_index_name,
952 vnet_get_main (), *sw_if_index);
990 .short_help =
"show bond [details]",
1006 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
1013 args->
rv = VNET_API_ERROR_INVALID_INTERFACE;
1017 if (bif->
mode != BOND_MODE_ACTIVE_BACKUP)
1019 args->
rv = VNET_API_ERROR_INVALID_ARGUMENT;
1025 old_weight = mif->
weight;
1036 (mif->
weight >= old_weight)))
1050 u8 weight_enter = 0;
1059 if (
unformat (line_input,
"sw_if_index %d", &sw_if_index))
1064 else if (
unformat (line_input,
"weight %u", &weight))
1075 if (sw_if_index == (
u32) ~ 0)
1077 args.
rv = VNET_API_ERROR_INVALID_INTERFACE;
1080 if (weight_enter == 0)
1082 args.
rv = VNET_API_ERROR_INVALID_ARGUMENT;
1095 .path =
"set interface bond",
1096 .short_help =
"set interface bond <interface> | sw_if_index <idx>"
#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.
void bond_create_if(vlib_main_t *vm, bond_create_if_args_t *args)
static clib_error_t * add_member_interface_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static uword unformat_bond_mode(unformat_input_t *input, va_list *args)
#define hash_set(h, key, value)
void bond_detach_member(vlib_main_t *vm, bond_detach_member_args_t *args)
#define hash_unset(h, key)
void ethernet_delete_interface(vnet_main_t *vnm, u32 hw_if_index)
member interface details struct
mac_address_t * secondary_addrs
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)
vnet_interface_main_t interface_main
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)
static bond_if_t * bond_get_bond_if_by_dev_instance(u32 dev_instance)
static bond_if_t * bond_get_bond_if_by_sw_if_index(u32 sw_if_index)
static clib_error_t * bond_delete_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#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
#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).
format_function_t format_vnet_sw_if_index_name
bond_per_thread_data_t * per_thread_data
#define vec_reset_length(v)
Reset vector length to zero NULL-pointer tolerant.
static clib_error_t * bond_create_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
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 void bond_sort_members(bond_if_t *bif)
ethernet_main_t ethernet_main
vlib_node_registration_t bond_process_node
(constructor) VLIB_REGISTER_NODE (bond_process_node)
#define pool_foreach(VAR, POOL, BODY)
Iterate through pool.
static clib_error_t * detach_interface_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define VLIB_INIT_FUNCTION(x)
vnet_hw_interface_flags_t flags
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
void bond_add_member(vlib_main_t *vm, bond_add_member_args_t *args)
#define clib_error_return(e, args...)
#define ALWAYS_ASSERT(truth)
static void clib_spinlock_init(clib_spinlock_t *p)
#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)
uword * member_by_sw_if_index
#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 * show_bond_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
sll srl srl sll sra u16x4 i
#define vec_free(V)
Free vector's memory (no header).
uword * bond_by_sw_if_index
#define ETHERNET_INTERFACE_FLAG_ACCEPT_ALL
int bond_dump_member_ifs(member_interface_details_t **out_memberifs, u32 bond_sw_if_index)
static int bond_member_sort(void *a1, void *a2)
BOND interface details struct.
#define VLIB_CLI_COMMAND(x,...)
clib_error_t * stat_segment_deregister_state_counter(u32 index)
void bond_disable_collecting_distributing(vlib_main_t *vm, member_if_t *mif)
uword unformat_ethernet_address(unformat_input_t *input, va_list *args)
static void bond_delete_neighbor(vlib_main_t *vm, bond_if_t *bif, member_if_t *mif)
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
static member_if_t * bond_get_member_by_sw_if_index(u32 sw_if_index)
#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.
ethernet_interface_t * ethernet_get_interface(ethernet_main_t *em, u32 hw_if_index)
static clib_error_t * bond_set_intf_cmd(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static void show_bond(vlib_main_t *vm)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
u8 persistent_hw_address[6]
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)
lacp_port_info_t actor_admin
uword * port_number_bitmap
#define vec_sort_with_function(vec, f)
Sort a vector using the supplied element comparison function.
void bond_set_intf_weight(vlib_main_t *vm, bond_set_intf_weight_args_t *args)
vnet_sw_interface_t * sw_interfaces
static void show_bond_details(vlib_main_t *vm)
int bond_delete_if(vlib_main_t *vm, u32 sw_if_index)
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.
int bond_dump_ifs(bond_interface_details_t **out_bondifs)
clib_error_t * bond_cli_init(vlib_main_t *vm)
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)
clib_error_t * vnet_hw_interface_change_mac_address(vnet_main_t *vnm, u32 hw_if_index, const u8 *mac_address)
#define CLIB_CACHE_LINE_BYTES
static_always_inline void clib_spinlock_lock_if_init(clib_spinlock_t *p)
vl_api_interface_index_t sw_if_index
clib_error_t * stat_segment_register_state_counter(u8 *name, u32 *index)
static void bond_member_add_del_mac_addrs(bond_if_t *bif, u32 mif_sw_if_index, u8 is_add)
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)
void bond_enable_collecting_distributing(vlib_main_t *vm, member_if_t *mif)