Lines Matching refs:veb
34 static int i40e_add_veb(struct i40e_veb *veb, struct i40e_vsi *vsi);
49 static int i40e_veb_get_bw_info(struct i40e_veb *veb);
545 if (pf->veb[i]) { in i40e_pf_reset_stats()
546 memset(&pf->veb[i]->stats, 0, in i40e_pf_reset_stats()
547 sizeof(pf->veb[i]->stats)); in i40e_pf_reset_stats()
548 memset(&pf->veb[i]->stats_offsets, 0, in i40e_pf_reset_stats()
549 sizeof(pf->veb[i]->stats_offsets)); in i40e_pf_reset_stats()
550 memset(&pf->veb[i]->tc_stats, 0, in i40e_pf_reset_stats()
551 sizeof(pf->veb[i]->tc_stats)); in i40e_pf_reset_stats()
552 memset(&pf->veb[i]->tc_stats_offsets, 0, in i40e_pf_reset_stats()
553 sizeof(pf->veb[i]->tc_stats_offsets)); in i40e_pf_reset_stats()
554 pf->veb[i]->stat_offsets_loaded = false; in i40e_pf_reset_stats()
770 void i40e_update_veb_stats(struct i40e_veb *veb) in i40e_update_veb_stats() argument
772 struct i40e_pf *pf = veb->pf; in i40e_update_veb_stats()
780 idx = veb->stats_idx; in i40e_update_veb_stats()
781 es = &veb->stats; in i40e_update_veb_stats()
782 oes = &veb->stats_offsets; in i40e_update_veb_stats()
783 veb_es = &veb->tc_stats; in i40e_update_veb_stats()
784 veb_oes = &veb->tc_stats_offsets; in i40e_update_veb_stats()
788 veb->stat_offsets_loaded, in i40e_update_veb_stats()
792 veb->stat_offsets_loaded, in i40e_update_veb_stats()
796 veb->stat_offsets_loaded, in i40e_update_veb_stats()
799 veb->stat_offsets_loaded, in i40e_update_veb_stats()
802 veb->stat_offsets_loaded, in i40e_update_veb_stats()
805 veb->stat_offsets_loaded, in i40e_update_veb_stats()
809 veb->stat_offsets_loaded, in i40e_update_veb_stats()
812 veb->stat_offsets_loaded, in i40e_update_veb_stats()
815 veb->stat_offsets_loaded, in i40e_update_veb_stats()
818 veb->stat_offsets_loaded, in i40e_update_veb_stats()
823 veb->stat_offsets_loaded, in i40e_update_veb_stats()
828 veb->stat_offsets_loaded, in i40e_update_veb_stats()
833 veb->stat_offsets_loaded, in i40e_update_veb_stats()
838 veb->stat_offsets_loaded, in i40e_update_veb_stats()
842 veb->stat_offsets_loaded = true; in i40e_update_veb_stats()
6694 int i40e_veb_config_tc(struct i40e_veb *veb, u8 enabled_tc) in i40e_veb_config_tc() argument
6697 struct i40e_pf *pf = veb->pf; in i40e_veb_config_tc()
6702 if (!enabled_tc || veb->enabled_tc == enabled_tc) in i40e_veb_config_tc()
6714 ret = i40e_aq_config_switch_comp_bw_config(&pf->hw, veb->seid, in i40e_veb_config_tc()
6725 ret = i40e_veb_get_bw_info(veb); in i40e_veb_config_tc()
6758 if (!pf->veb[v]) in i40e_dcb_reconfigure()
6760 ret = i40e_veb_config_tc(pf->veb[v], tc_map); in i40e_dcb_reconfigure()
6764 pf->veb[v]->seid); in i40e_dcb_reconfigure()
9857 static void i40e_veb_link_event(struct i40e_veb *veb, bool link_up) in i40e_veb_link_event() argument
9862 if (!veb || !veb->pf) in i40e_veb_link_event()
9864 pf = veb->pf; in i40e_veb_link_event()
9868 if (pf->veb[i] && (pf->veb[i]->uplink_seid == veb->seid)) in i40e_veb_link_event()
9869 i40e_veb_link_event(pf->veb[i], link_up); in i40e_veb_link_event()
9873 if (pf->vsi[i] && (pf->vsi[i]->uplink_seid == veb->seid)) in i40e_veb_link_event()
9923 if (pf->lan_veb < I40E_MAX_VEB && pf->veb[pf->lan_veb]) in i40e_link_event()
9924 i40e_veb_link_event(pf->veb[pf->lan_veb], new_link); in i40e_link_event()
9993 if (pf->veb[i]) in i40e_watchdog_subtask()
9994 i40e_update_veb_stats(pf->veb[i]); in i40e_watchdog_subtask()
10325 static void i40e_config_bridge_mode(struct i40e_veb *veb) in i40e_config_bridge_mode() argument
10327 struct i40e_pf *pf = veb->pf; in i40e_config_bridge_mode()
10331 veb->bridge_mode == BRIDGE_MODE_VEPA ? "VEPA" : "VEB"); in i40e_config_bridge_mode()
10332 if (veb->bridge_mode & BRIDGE_MODE_VEPA) in i40e_config_bridge_mode()
10347 static int i40e_reconstitute_veb(struct i40e_veb *veb) in i40e_reconstitute_veb() argument
10350 struct i40e_pf *pf = veb->pf; in i40e_reconstitute_veb()
10357 pf->vsi[v]->veb_idx == veb->idx && in i40e_reconstitute_veb()
10365 "missing owner VSI for veb_idx %d\n", veb->idx); in i40e_reconstitute_veb()
10375 veb->idx, ret); in i40e_reconstitute_veb()
10381 ret = i40e_add_veb(veb, ctl_vsi); in i40e_reconstitute_veb()
10386 veb->bridge_mode = BRIDGE_MODE_VEB; in i40e_reconstitute_veb()
10388 veb->bridge_mode = BRIDGE_MODE_VEPA; in i40e_reconstitute_veb()
10389 i40e_config_bridge_mode(veb); in i40e_reconstitute_veb()
10396 if (pf->vsi[v]->veb_idx == veb->idx) { in i40e_reconstitute_veb()
10399 vsi->uplink_seid = veb->seid; in i40e_reconstitute_veb()
10413 if (pf->veb[veb_idx] && pf->veb[veb_idx]->veb_idx == veb->idx) { in i40e_reconstitute_veb()
10414 pf->veb[veb_idx]->uplink_seid = veb->seid; in i40e_reconstitute_veb()
10415 ret = i40e_reconstitute_veb(pf->veb[veb_idx]); in i40e_reconstitute_veb()
10962 if (!pf->veb[v]) in i40e_rebuild()
10965 if (pf->veb[v]->uplink_seid == pf->mac_seid || in i40e_rebuild()
10966 pf->veb[v]->uplink_seid == 0) { in i40e_rebuild()
10967 ret = i40e_reconstitute_veb(pf->veb[v]); in i40e_rebuild()
10978 if (pf->veb[v]->uplink_seid == pf->mac_seid) { in i40e_rebuild()
10984 } else if (pf->veb[v]->uplink_seid == 0) { in i40e_rebuild()
13127 struct i40e_veb *veb = NULL; in i40e_ndo_bridge_setlink() local
13136 for (i = 0; i < I40E_MAX_VEB && !veb; i++) { in i40e_ndo_bridge_setlink()
13137 if (pf->veb[i] && pf->veb[i]->seid == vsi->uplink_seid) in i40e_ndo_bridge_setlink()
13138 veb = pf->veb[i]; in i40e_ndo_bridge_setlink()
13157 if (!veb) { in i40e_ndo_bridge_setlink()
13158 veb = i40e_veb_setup(pf, 0, vsi->uplink_seid, vsi->seid, in i40e_ndo_bridge_setlink()
13160 if (veb) { in i40e_ndo_bridge_setlink()
13161 veb->bridge_mode = mode; in i40e_ndo_bridge_setlink()
13162 i40e_config_bridge_mode(veb); in i40e_ndo_bridge_setlink()
13168 } else if (mode != veb->bridge_mode) { in i40e_ndo_bridge_setlink()
13170 veb->bridge_mode = mode; in i40e_ndo_bridge_setlink()
13204 struct i40e_veb *veb = NULL; in i40e_ndo_bridge_getlink() local
13212 for (i = 0; i < I40E_MAX_VEB && !veb; i++) { in i40e_ndo_bridge_getlink()
13213 if (pf->veb[i] && pf->veb[i]->seid == vsi->uplink_seid) in i40e_ndo_bridge_getlink()
13214 veb = pf->veb[i]; in i40e_ndo_bridge_getlink()
13217 if (!veb) in i40e_ndo_bridge_getlink()
13220 return ndo_dflt_bridge_getlink(skb, pid, seq, dev, veb->bridge_mode, in i40e_ndo_bridge_getlink()
13839 struct i40e_veb *veb; in i40e_is_vsi_uplink_mode_veb() local
13846 veb = pf->veb[vsi->veb_idx]; in i40e_is_vsi_uplink_mode_veb()
13847 if (!veb) { in i40e_is_vsi_uplink_mode_veb()
13854 if (veb->bridge_mode & BRIDGE_MODE_VEPA) { in i40e_is_vsi_uplink_mode_veb()
14122 struct i40e_veb *veb = NULL; in i40e_vsi_release() local
14196 if (!pf->veb[i]) in i40e_vsi_release()
14198 if (pf->veb[i]->uplink_seid == uplink_seid) in i40e_vsi_release()
14200 if (pf->veb[i]->seid == uplink_seid) in i40e_vsi_release()
14201 veb = pf->veb[i]; in i40e_vsi_release()
14203 if (n == 0 && veb && veb->uplink_seid != 0) in i40e_vsi_release()
14204 i40e_veb_release(veb); in i40e_vsi_release()
14358 struct i40e_veb *veb = NULL; in i40e_vsi_setup() local
14377 if (pf->veb[i] && pf->veb[i]->seid == uplink_seid) { in i40e_vsi_setup()
14378 veb = pf->veb[i]; in i40e_vsi_setup()
14383 if (!veb && uplink_seid != pf->mac_seid) { in i40e_vsi_setup()
14398 veb = i40e_veb_setup(pf, 0, pf->mac_seid, vsi->seid, in i40e_vsi_setup()
14401 veb = i40e_veb_setup(pf, 0, vsi->uplink_seid, vsi->seid, in i40e_vsi_setup()
14403 if (veb) { in i40e_vsi_setup()
14414 veb->bridge_mode = BRIDGE_MODE_VEPA; in i40e_vsi_setup()
14417 i40e_config_bridge_mode(veb); in i40e_vsi_setup()
14419 for (i = 0; i < I40E_MAX_VEB && !veb; i++) { in i40e_vsi_setup()
14420 if (pf->veb[i] && pf->veb[i]->seid == vsi->uplink_seid) in i40e_vsi_setup()
14421 veb = pf->veb[i]; in i40e_vsi_setup()
14423 if (!veb) { in i40e_vsi_setup()
14429 uplink_seid = veb->seid; in i40e_vsi_setup()
14440 vsi->veb_idx = (veb ? veb->idx : I40E_NO_VEB); in i40e_vsi_setup()
14534 static int i40e_veb_get_bw_info(struct i40e_veb *veb) in i40e_veb_get_bw_info() argument
14538 struct i40e_pf *pf = veb->pf; in i40e_veb_get_bw_info()
14544 ret = i40e_aq_query_switch_comp_bw_config(hw, veb->seid, in i40e_veb_get_bw_info()
14554 ret = i40e_aq_query_switch_comp_ets_config(hw, veb->seid, in i40e_veb_get_bw_info()
14564 veb->bw_limit = le16_to_cpu(ets_data.port_bw_limit); in i40e_veb_get_bw_info()
14565 veb->bw_max_quanta = ets_data.tc_bw_max; in i40e_veb_get_bw_info()
14566 veb->is_abs_credits = bw_data.absolute_credits_enable; in i40e_veb_get_bw_info()
14567 veb->enabled_tc = ets_data.tc_valid_bits; in i40e_veb_get_bw_info()
14571 veb->bw_tc_share_credits[i] = bw_data.tc_bw_share_credits[i]; in i40e_veb_get_bw_info()
14572 veb->bw_tc_limit_credits[i] = in i40e_veb_get_bw_info()
14574 veb->bw_tc_max_quanta[i] = ((tc_bw_max >> (i*4)) & 0x7); in i40e_veb_get_bw_info()
14591 struct i40e_veb *veb; in i40e_veb_mem_alloc() local
14604 while ((i < I40E_MAX_VEB) && (pf->veb[i] != NULL)) in i40e_veb_mem_alloc()
14611 veb = kzalloc(sizeof(*veb), GFP_KERNEL); in i40e_veb_mem_alloc()
14612 if (!veb) { in i40e_veb_mem_alloc()
14616 veb->pf = pf; in i40e_veb_mem_alloc()
14617 veb->idx = i; in i40e_veb_mem_alloc()
14618 veb->enabled_tc = 1; in i40e_veb_mem_alloc()
14620 pf->veb[i] = veb; in i40e_veb_mem_alloc()
14643 if (!pf->veb[i]) in i40e_switch_branch_release()
14645 if (pf->veb[i]->uplink_seid == branch->seid) in i40e_switch_branch_release()
14646 i40e_switch_branch_release(pf->veb[i]); in i40e_switch_branch_release()
14668 if (pf->veb[veb_idx]) in i40e_switch_branch_release()
14669 i40e_veb_release(pf->veb[veb_idx]); in i40e_switch_branch_release()
14676 static void i40e_veb_clear(struct i40e_veb *veb) in i40e_veb_clear() argument
14678 if (!veb) in i40e_veb_clear()
14681 if (veb->pf) { in i40e_veb_clear()
14682 struct i40e_pf *pf = veb->pf; in i40e_veb_clear()
14685 if (pf->veb[veb->idx] == veb) in i40e_veb_clear()
14686 pf->veb[veb->idx] = NULL; in i40e_veb_clear()
14690 kfree(veb); in i40e_veb_clear()
14697 void i40e_veb_release(struct i40e_veb *veb) in i40e_veb_release() argument
14703 pf = veb->pf; in i40e_veb_release()
14707 if (pf->vsi[i] && pf->vsi[i]->uplink_seid == veb->seid) { in i40e_veb_release()
14715 veb->seid, n); in i40e_veb_release()
14721 if (veb->uplink_seid) { in i40e_veb_release()
14722 vsi->uplink_seid = veb->uplink_seid; in i40e_veb_release()
14723 if (veb->uplink_seid == pf->mac_seid) in i40e_veb_release()
14726 vsi->veb_idx = veb->veb_idx; in i40e_veb_release()
14733 i40e_aq_delete_element(&pf->hw, veb->seid, NULL); in i40e_veb_release()
14734 i40e_veb_clear(veb); in i40e_veb_release()
14742 static int i40e_add_veb(struct i40e_veb *veb, struct i40e_vsi *vsi) in i40e_add_veb() argument
14744 struct i40e_pf *pf = veb->pf; in i40e_add_veb()
14748 ret = i40e_aq_add_veb(&pf->hw, veb->uplink_seid, vsi->seid, in i40e_add_veb()
14749 veb->enabled_tc, false, in i40e_add_veb()
14750 &veb->seid, enable_stats, NULL); in i40e_add_veb()
14762 ret = i40e_aq_get_veb_parameters(&pf->hw, veb->seid, NULL, NULL, in i40e_add_veb()
14763 &veb->stats_idx, NULL, NULL, NULL); in i40e_add_veb()
14771 ret = i40e_veb_get_bw_info(veb); in i40e_add_veb()
14777 i40e_aq_delete_element(&pf->hw, veb->seid, NULL); in i40e_add_veb()
14781 vsi->uplink_seid = veb->seid; in i40e_add_veb()
14782 vsi->veb_idx = veb->idx; in i40e_add_veb()
14808 struct i40e_veb *veb, *uplink_veb = NULL; in i40e_veb_setup() local
14833 if (pf->veb[veb_idx] && in i40e_veb_setup()
14834 pf->veb[veb_idx]->seid == uplink_seid) { in i40e_veb_setup()
14835 uplink_veb = pf->veb[veb_idx]; in i40e_veb_setup()
14850 veb = pf->veb[veb_idx]; in i40e_veb_setup()
14851 veb->flags = flags; in i40e_veb_setup()
14852 veb->uplink_seid = uplink_seid; in i40e_veb_setup()
14853 veb->veb_idx = (uplink_veb ? uplink_veb->idx : I40E_NO_VEB); in i40e_veb_setup()
14854 veb->enabled_tc = (enabled_tc ? enabled_tc : 0x1); in i40e_veb_setup()
14857 ret = i40e_add_veb(veb, pf->vsi[vsi_idx]); in i40e_veb_setup()
14861 pf->lan_veb = veb->idx; in i40e_veb_setup()
14863 return veb; in i40e_veb_setup()
14866 i40e_veb_clear(veb); in i40e_veb_setup()
14907 if (pf->veb[v] && (pf->veb[v]->seid == seid)) { in i40e_setup_pf_switch_element()
14922 pf->veb[pf->lan_veb]->seid = seid; in i40e_setup_pf_switch_element()
14923 pf->veb[pf->lan_veb]->uplink_seid = pf->mac_seid; in i40e_setup_pf_switch_element()
14924 pf->veb[pf->lan_veb]->pf = pf; in i40e_setup_pf_switch_element()
14925 pf->veb[pf->lan_veb]->veb_idx = I40E_NO_VEB; in i40e_setup_pf_switch_element()
15075 if (pf->lan_veb < I40E_MAX_VEB && pf->veb[pf->lan_veb]) in i40e_setup_pf_switch()
15076 uplink_seid = pf->veb[pf->lan_veb]->seid; in i40e_setup_pf_switch()
16259 if (!pf->veb[i]) in i40e_remove()
16262 if (pf->veb[i]->uplink_seid == pf->mac_seid || in i40e_remove()
16263 pf->veb[i]->uplink_seid == 0) in i40e_remove()
16264 i40e_switch_branch_release(pf->veb[i]); in i40e_remove()
16323 kfree(pf->veb[i]); in i40e_remove()
16324 pf->veb[i] = NULL; in i40e_remove()