> > + /* 4 bits per TC, 4th bit is reserved */ > > + veb->bw_info.bw_ets_max[i] = > > + (uint8_t)((bw_max >> (i * I40E_4_BIT_WIDTH)) & > > + I40E_3_BIT_MASK); > Use RTE_LEN2MASK() to replace I40E_3_BIT_MASK.
OK. > > > + PMD_DRV_LOG(DEBUG, "\tVEB TC%u:share credits %u", i, > > + veb->bw_info.bw_ets_share_credits[i]); > > + PMD_DRV_LOG(DEBUG, "\tVEB TC%u:credits %u", i, > > + veb->bw_info.bw_ets_credits[i]); > > + PMD_DRV_LOG(DEBUG, "\tVEB TC%u: max credits: %u", i, > > + veb->bw_info.bw_ets_max[i]); > > + } > > + > > + veb->enabled_tc = tc_map; > > + > > + return ret; > > +} > > + > > + > > +/* > > * i40e_vsi_config_tc - Configure VSI tc setting for given TC map > > * @vsi: VSI to be configured > > * @tc_map: enabled TC bitmap > > @@ -8152,7 +8252,7 @@ i40e_vsi_update_queue_mapping(struct i40e_vsi > > *vsi, > > * Returns 0 on success, negative value on failure > > */ > > static enum i40e_status_code > > -i40e_vsi_config_tc(struct i40e_vsi *vsi, u8 tc_map) > > +i40e_vsi_config_tc(struct i40e_vsi *vsi, uint8_t tc_map) > > { > > struct i40e_aqc_configure_vsi_tc_bw_data bw_data; > > struct i40e_vsi_context ctxt; > > @@ -8294,15 +8394,27 @@ i40e_dcb_hw_configure(struct i40e_pf *pf, > > i40e_aq_get_dcb_config(hw, I40E_AQ_LLDP_MIB_LOCAL, 0, > > &hw->local_dcbx_config); > > > > + /* if Veb is created, need to update TC of it at first */ > > + if (main_vsi->veb) { > > + ret = i40e_config_switch_comp_tc(main_vsi->veb, tc_map); > > + if (ret) > > + PMD_INIT_LOG(WARNING, > > + "Failed configuring TC for VEB seid=%d\n", > > + main_vsi->veb->seid); > > + } > How about if VEB hasn't been created? If VEB is not created, no need to update tc on switch comp. Thanks Jingjing > > > 2.4.0