X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fethernet%2Fp2p_ethernet.c;h=ddf23901419a5094c699663565f6dc005cd848f0;hb=b474380f;hp=e3f667b5ffee9134e99a3a12ae8f4bb649c59c30;hpb=15ac81c16fba83033090299413a3a2dbb848a0f9;p=vpp.git diff --git a/src/vnet/ethernet/p2p_ethernet.c b/src/vnet/ethernet/p2p_ethernet.c index e3f667b5ffe..ddf23901419 100644 --- a/src/vnet/ethernet/p2p_ethernet.c +++ b/src/vnet/ethernet/p2p_ethernet.c @@ -96,6 +96,31 @@ p2p_ethernet_add_del (vlib_main_t * vm, u32 parent_if_index, if (vnet_create_sw_interface (vnm, &template, &p2pe_sw_if_index)) return VNET_API_ERROR_SUBIF_CREATE_FAILED; + /* Allocate counters for this interface. */ + { + u32 i; + + vnet_interface_counter_lock (im); + + for (i = 0; i < vec_len (im->sw_if_counters); i++) + { + vlib_validate_simple_counter (&im->sw_if_counters[i], + p2pe_sw_if_index); + vlib_zero_simple_counter (&im->sw_if_counters[i], + p2pe_sw_if_index); + } + + for (i = 0; i < vec_len (im->combined_sw_if_counters); i++) + { + vlib_validate_combined_counter (&im->combined_sw_if_counters + [i], p2pe_sw_if_index); + vlib_zero_combined_counter (&im->combined_sw_if_counters[i], + p2pe_sw_if_index); + } + + vnet_interface_counter_unlock (im); + } + vnet_interface_main_t *im = &vnm->interface_main; sup_and_sub_key = ((u64) (hi->sw_if_index) << 32) | (u64) p2pe_subif_id; @@ -128,7 +153,8 @@ p2p_ethernet_add_del (vlib_main_t * vm, u32 parent_if_index, } p2pm->p2p_ethernet_by_sw_if_index[parent_if_index]++; /* set the interface mode */ - set_int_l2_mode (vm, vnm, MODE_L3, p2pe_subif_id, 0, 0, 0, 0); + set_int_l2_mode (vm, vnm, MODE_L3, p2pe_subif_id, 0, + L2_BD_PORT_TYPE_NORMAL, 0, 0); return 0; } return VNET_API_ERROR_SUBIF_ALREADY_EXISTS;