Lines Matching refs:vsi

47 static int ice_vsi_ctrl_all_rx_rings(struct ice_vsi *vsi, bool ena)  in ice_vsi_ctrl_all_rx_rings()  argument
52 ice_for_each_rxq(vsi, i) in ice_vsi_ctrl_all_rx_rings()
53 ice_vsi_ctrl_one_rx_ring(vsi, ena, i, false); in ice_vsi_ctrl_all_rx_rings()
55 ice_flush(&vsi->back->hw); in ice_vsi_ctrl_all_rx_rings()
57 ice_for_each_rxq(vsi, i) { in ice_vsi_ctrl_all_rx_rings()
58 ret = ice_vsi_wait_one_rx_ring(vsi, ena, i); in ice_vsi_ctrl_all_rx_rings()
73 static int ice_vsi_alloc_arrays(struct ice_vsi *vsi) in ice_vsi_alloc_arrays() argument
75 struct ice_pf *pf = vsi->back; in ice_vsi_alloc_arrays()
79 if (vsi->type == ICE_VSI_CHNL) in ice_vsi_alloc_arrays()
83 vsi->tx_rings = devm_kcalloc(dev, vsi->alloc_txq, in ice_vsi_alloc_arrays()
84 sizeof(*vsi->tx_rings), GFP_KERNEL); in ice_vsi_alloc_arrays()
85 if (!vsi->tx_rings) in ice_vsi_alloc_arrays()
88 vsi->rx_rings = devm_kcalloc(dev, vsi->alloc_rxq, in ice_vsi_alloc_arrays()
89 sizeof(*vsi->rx_rings), GFP_KERNEL); in ice_vsi_alloc_arrays()
90 if (!vsi->rx_rings) in ice_vsi_alloc_arrays()
99 vsi->txq_map = devm_kcalloc(dev, (vsi->alloc_txq + num_possible_cpus()), in ice_vsi_alloc_arrays()
100 sizeof(*vsi->txq_map), GFP_KERNEL); in ice_vsi_alloc_arrays()
102 if (!vsi->txq_map) in ice_vsi_alloc_arrays()
105 vsi->rxq_map = devm_kcalloc(dev, vsi->alloc_rxq, in ice_vsi_alloc_arrays()
106 sizeof(*vsi->rxq_map), GFP_KERNEL); in ice_vsi_alloc_arrays()
107 if (!vsi->rxq_map) in ice_vsi_alloc_arrays()
111 if (vsi->type == ICE_VSI_LB) in ice_vsi_alloc_arrays()
115 vsi->q_vectors = devm_kcalloc(dev, vsi->num_q_vectors, in ice_vsi_alloc_arrays()
116 sizeof(*vsi->q_vectors), GFP_KERNEL); in ice_vsi_alloc_arrays()
117 if (!vsi->q_vectors) in ice_vsi_alloc_arrays()
123 devm_kfree(dev, vsi->rxq_map); in ice_vsi_alloc_arrays()
125 devm_kfree(dev, vsi->txq_map); in ice_vsi_alloc_arrays()
127 devm_kfree(dev, vsi->rx_rings); in ice_vsi_alloc_arrays()
129 devm_kfree(dev, vsi->tx_rings); in ice_vsi_alloc_arrays()
137 static void ice_vsi_set_num_desc(struct ice_vsi *vsi) in ice_vsi_set_num_desc() argument
139 switch (vsi->type) { in ice_vsi_set_num_desc()
148 if (!vsi->num_rx_desc) in ice_vsi_set_num_desc()
149 vsi->num_rx_desc = ICE_DFLT_NUM_RX_DESC; in ice_vsi_set_num_desc()
150 if (!vsi->num_tx_desc) in ice_vsi_set_num_desc()
151 vsi->num_tx_desc = ICE_DFLT_NUM_TX_DESC; in ice_vsi_set_num_desc()
154 dev_dbg(ice_pf_to_dev(vsi->back), "Not setting number of Tx/Rx descriptors for VSI type %d\n", in ice_vsi_set_num_desc()
155 vsi->type); in ice_vsi_set_num_desc()
166 static void ice_vsi_set_num_qs(struct ice_vsi *vsi) in ice_vsi_set_num_qs() argument
168 enum ice_vsi_type vsi_type = vsi->type; in ice_vsi_set_num_qs()
169 struct ice_pf *pf = vsi->back; in ice_vsi_set_num_qs()
170 struct ice_vf *vf = vsi->vf; in ice_vsi_set_num_qs()
177 if (vsi->req_txq) { in ice_vsi_set_num_qs()
178 vsi->alloc_txq = vsi->req_txq; in ice_vsi_set_num_qs()
179 vsi->num_txq = vsi->req_txq; in ice_vsi_set_num_qs()
181 vsi->alloc_txq = min3(pf->num_lan_msix, in ice_vsi_set_num_qs()
186 pf->num_lan_tx = vsi->alloc_txq; in ice_vsi_set_num_qs()
190 vsi->alloc_rxq = 1; in ice_vsi_set_num_qs()
192 if (vsi->req_rxq) { in ice_vsi_set_num_qs()
193 vsi->alloc_rxq = vsi->req_rxq; in ice_vsi_set_num_qs()
194 vsi->num_rxq = vsi->req_rxq; in ice_vsi_set_num_qs()
196 vsi->alloc_rxq = min3(pf->num_lan_msix, in ice_vsi_set_num_qs()
202 pf->num_lan_rx = vsi->alloc_rxq; in ice_vsi_set_num_qs()
204 vsi->num_q_vectors = min_t(int, pf->num_lan_msix, in ice_vsi_set_num_qs()
205 max_t(int, vsi->alloc_rxq, in ice_vsi_set_num_qs()
206 vsi->alloc_txq)); in ice_vsi_set_num_qs()
212 vsi->alloc_txq = ice_get_num_vfs(pf); in ice_vsi_set_num_qs()
213 vsi->alloc_rxq = vsi->alloc_txq; in ice_vsi_set_num_qs()
214 vsi->num_q_vectors = 1; in ice_vsi_set_num_qs()
219 vsi->alloc_txq = vf->num_vf_qs; in ice_vsi_set_num_qs()
220 vsi->alloc_rxq = vf->num_vf_qs; in ice_vsi_set_num_qs()
226 vsi->num_q_vectors = pf->vfs.num_msix_per - ICE_NONQ_VECS_VF; in ice_vsi_set_num_qs()
229 vsi->alloc_txq = 1; in ice_vsi_set_num_qs()
230 vsi->alloc_rxq = 1; in ice_vsi_set_num_qs()
231 vsi->num_q_vectors = 1; in ice_vsi_set_num_qs()
234 vsi->alloc_txq = 0; in ice_vsi_set_num_qs()
235 vsi->alloc_rxq = 0; in ice_vsi_set_num_qs()
238 vsi->alloc_txq = 1; in ice_vsi_set_num_qs()
239 vsi->alloc_rxq = 1; in ice_vsi_set_num_qs()
246 ice_vsi_set_num_desc(vsi); in ice_vsi_set_num_qs()
282 static void ice_vsi_delete_from_hw(struct ice_vsi *vsi) in ice_vsi_delete_from_hw() argument
284 struct ice_pf *pf = vsi->back; in ice_vsi_delete_from_hw()
288 ice_fltr_remove_all(vsi); in ice_vsi_delete_from_hw()
293 if (vsi->type == ICE_VSI_VF) in ice_vsi_delete_from_hw()
294 ctxt->vf_num = vsi->vf->vf_id; in ice_vsi_delete_from_hw()
295 ctxt->vsi_num = vsi->vsi_num; in ice_vsi_delete_from_hw()
297 memcpy(&ctxt->info, &vsi->info, sizeof(ctxt->info)); in ice_vsi_delete_from_hw()
299 status = ice_free_vsi(&pf->hw, vsi->idx, ctxt, false, NULL); in ice_vsi_delete_from_hw()
302 vsi->vsi_num, status); in ice_vsi_delete_from_hw()
311 static void ice_vsi_free_arrays(struct ice_vsi *vsi) in ice_vsi_free_arrays() argument
313 struct ice_pf *pf = vsi->back; in ice_vsi_free_arrays()
319 devm_kfree(dev, vsi->q_vectors); in ice_vsi_free_arrays()
320 vsi->q_vectors = NULL; in ice_vsi_free_arrays()
321 devm_kfree(dev, vsi->tx_rings); in ice_vsi_free_arrays()
322 vsi->tx_rings = NULL; in ice_vsi_free_arrays()
323 devm_kfree(dev, vsi->rx_rings); in ice_vsi_free_arrays()
324 vsi->rx_rings = NULL; in ice_vsi_free_arrays()
325 devm_kfree(dev, vsi->txq_map); in ice_vsi_free_arrays()
326 vsi->txq_map = NULL; in ice_vsi_free_arrays()
327 devm_kfree(dev, vsi->rxq_map); in ice_vsi_free_arrays()
328 vsi->rxq_map = NULL; in ice_vsi_free_arrays()
335 static void ice_vsi_free_stats(struct ice_vsi *vsi) in ice_vsi_free_stats() argument
338 struct ice_pf *pf = vsi->back; in ice_vsi_free_stats()
341 if (vsi->type == ICE_VSI_CHNL) in ice_vsi_free_stats()
346 vsi_stat = pf->vsi_stats[vsi->idx]; in ice_vsi_free_stats()
350 ice_for_each_alloc_txq(vsi, i) { in ice_vsi_free_stats()
357 ice_for_each_alloc_rxq(vsi, i) { in ice_vsi_free_stats()
367 pf->vsi_stats[vsi->idx] = NULL; in ice_vsi_free_stats()
374 static int ice_vsi_alloc_ring_stats(struct ice_vsi *vsi) in ice_vsi_alloc_ring_stats() argument
379 struct ice_pf *pf = vsi->back; in ice_vsi_alloc_ring_stats()
382 vsi_stats = pf->vsi_stats[vsi->idx]; in ice_vsi_alloc_ring_stats()
387 ice_for_each_alloc_txq(vsi, i) { in ice_vsi_alloc_ring_stats()
391 ring = vsi->tx_rings[i]; in ice_vsi_alloc_ring_stats()
406 ice_for_each_alloc_rxq(vsi, i) { in ice_vsi_alloc_ring_stats()
410 ring = vsi->rx_rings[i]; in ice_vsi_alloc_ring_stats()
427 ice_vsi_free_stats(vsi); in ice_vsi_alloc_ring_stats()
438 static void ice_vsi_free(struct ice_vsi *vsi) in ice_vsi_free() argument
443 if (!vsi || !vsi->back) in ice_vsi_free()
446 pf = vsi->back; in ice_vsi_free()
449 if (!pf->vsi[vsi->idx] || pf->vsi[vsi->idx] != vsi) { in ice_vsi_free()
450 dev_dbg(dev, "vsi does not exist at pf->vsi[%d]\n", vsi->idx); in ice_vsi_free()
457 pf->vsi[vsi->idx] = NULL; in ice_vsi_free()
458 pf->next_vsi = vsi->idx; in ice_vsi_free()
460 ice_vsi_free_stats(vsi); in ice_vsi_free()
461 ice_vsi_free_arrays(vsi); in ice_vsi_free()
462 mutex_destroy(&vsi->xdp_state_lock); in ice_vsi_free()
464 devm_kfree(dev, vsi); in ice_vsi_free()
467 void ice_vsi_delete(struct ice_vsi *vsi) in ice_vsi_delete() argument
469 ice_vsi_delete_from_hw(vsi); in ice_vsi_delete()
470 ice_vsi_free(vsi); in ice_vsi_delete()
514 struct ice_pf *pf = q_vector->vsi->back; in ice_eswitch_msix_clean_rings()
533 static int ice_vsi_alloc_stat_arrays(struct ice_vsi *vsi) in ice_vsi_alloc_stat_arrays() argument
536 struct ice_pf *pf = vsi->back; in ice_vsi_alloc_stat_arrays()
538 if (vsi->type == ICE_VSI_CHNL) in ice_vsi_alloc_stat_arrays()
543 if (pf->vsi_stats[vsi->idx]) in ice_vsi_alloc_stat_arrays()
552 kcalloc(vsi->alloc_txq, sizeof(*vsi_stat->tx_ring_stats), in ice_vsi_alloc_stat_arrays()
558 kcalloc(vsi->alloc_rxq, sizeof(*vsi_stat->rx_ring_stats), in ice_vsi_alloc_stat_arrays()
563 pf->vsi_stats[vsi->idx] = vsi_stat; in ice_vsi_alloc_stat_arrays()
572 pf->vsi_stats[vsi->idx] = NULL; in ice_vsi_alloc_stat_arrays()
582 ice_vsi_alloc_def(struct ice_vsi *vsi, struct ice_channel *ch) in ice_vsi_alloc_def() argument
584 if (vsi->type != ICE_VSI_CHNL) { in ice_vsi_alloc_def()
585 ice_vsi_set_num_qs(vsi); in ice_vsi_alloc_def()
586 if (ice_vsi_alloc_arrays(vsi)) in ice_vsi_alloc_def()
590 switch (vsi->type) { in ice_vsi_alloc_def()
593 vsi->irq_handler = ice_eswitch_msix_clean_rings; in ice_vsi_alloc_def()
597 vsi->irq_handler = ice_msix_clean_rings; in ice_vsi_alloc_def()
601 vsi->irq_handler = ice_msix_clean_ctrl_vsi; in ice_vsi_alloc_def()
607 vsi->num_rxq = ch->num_rxq; in ice_vsi_alloc_def()
608 vsi->num_txq = ch->num_txq; in ice_vsi_alloc_def()
609 vsi->next_base_q = ch->base_q; in ice_vsi_alloc_def()
615 ice_vsi_free_arrays(vsi); in ice_vsi_alloc_def()
635 struct ice_vsi *vsi = NULL; in ice_vsi_alloc() local
649 vsi = devm_kzalloc(dev, sizeof(*vsi), GFP_KERNEL); in ice_vsi_alloc()
650 if (!vsi) in ice_vsi_alloc()
653 vsi->back = pf; in ice_vsi_alloc()
654 set_bit(ICE_VSI_DOWN, vsi->state); in ice_vsi_alloc()
657 vsi->idx = pf->next_vsi; in ice_vsi_alloc()
658 pf->vsi[pf->next_vsi] = vsi; in ice_vsi_alloc()
661 pf->next_vsi = ice_get_free_slot(pf->vsi, pf->num_alloc_vsi, in ice_vsi_alloc()
664 mutex_init(&vsi->xdp_state_lock); in ice_vsi_alloc()
668 return vsi; in ice_vsi_alloc()
679 static int ice_alloc_fd_res(struct ice_vsi *vsi) in ice_alloc_fd_res() argument
681 struct ice_pf *pf = vsi->back; in ice_alloc_fd_res()
691 if (!(vsi->type == ICE_VSI_PF || vsi->type == ICE_VSI_VF || in ice_alloc_fd_res()
692 vsi->type == ICE_VSI_CHNL)) in ice_alloc_fd_res()
713 if (vsi->type == ICE_VSI_PF) { in ice_alloc_fd_res()
714 vsi->num_gfltr = g_val; in ice_alloc_fd_res()
722 vsi->num_gfltr = ICE_PF_VSI_GFLTR; in ice_alloc_fd_res()
726 vsi->num_bfltr = b_val; in ice_alloc_fd_res()
727 } else if (vsi->type == ICE_VSI_VF) { in ice_alloc_fd_res()
728 vsi->num_gfltr = 0; in ice_alloc_fd_res()
731 vsi->num_bfltr = b_val; in ice_alloc_fd_res()
754 vsi->num_gfltr = g_val / numtc; in ice_alloc_fd_res()
757 vsi->num_bfltr = b_val; in ice_alloc_fd_res()
769 static int ice_vsi_get_qs(struct ice_vsi *vsi) in ice_vsi_get_qs() argument
771 struct ice_pf *pf = vsi->back; in ice_vsi_get_qs()
776 .q_count = vsi->alloc_txq, in ice_vsi_get_qs()
778 .vsi_map = vsi->txq_map, in ice_vsi_get_qs()
786 .q_count = vsi->alloc_rxq, in ice_vsi_get_qs()
788 .vsi_map = vsi->rxq_map, in ice_vsi_get_qs()
794 if (vsi->type == ICE_VSI_CHNL) in ice_vsi_get_qs()
800 vsi->tx_mapping_mode = tx_qs_cfg.mapping_mode; in ice_vsi_get_qs()
805 vsi->rx_mapping_mode = rx_qs_cfg.mapping_mode; in ice_vsi_get_qs()
814 static void ice_vsi_put_qs(struct ice_vsi *vsi) in ice_vsi_put_qs() argument
816 struct ice_pf *pf = vsi->back; in ice_vsi_put_qs()
821 ice_for_each_alloc_txq(vsi, i) { in ice_vsi_put_qs()
822 clear_bit(vsi->txq_map[i], pf->avail_txqs); in ice_vsi_put_qs()
823 vsi->txq_map[i] = ICE_INVAL_Q_INDEX; in ice_vsi_put_qs()
826 ice_for_each_alloc_rxq(vsi, i) { in ice_vsi_put_qs()
827 clear_bit(vsi->rxq_map[i], pf->avail_rxqs); in ice_vsi_put_qs()
828 vsi->rxq_map[i] = ICE_INVAL_Q_INDEX; in ice_vsi_put_qs()
863 static void ice_vsi_clean_rss_flow_fld(struct ice_vsi *vsi) in ice_vsi_clean_rss_flow_fld() argument
865 struct ice_pf *pf = vsi->back; in ice_vsi_clean_rss_flow_fld()
871 status = ice_rem_vsi_rss_cfg(&pf->hw, vsi->idx); in ice_vsi_clean_rss_flow_fld()
874 vsi->vsi_num, status); in ice_vsi_clean_rss_flow_fld()
881 static void ice_rss_clean(struct ice_vsi *vsi) in ice_rss_clean() argument
883 struct ice_pf *pf = vsi->back; in ice_rss_clean()
888 devm_kfree(dev, vsi->rss_hkey_user); in ice_rss_clean()
889 devm_kfree(dev, vsi->rss_lut_user); in ice_rss_clean()
891 ice_vsi_clean_rss_flow_fld(vsi); in ice_rss_clean()
894 ice_rem_vsi_rss_list(&pf->hw, vsi->idx); in ice_rss_clean()
901 static void ice_vsi_set_rss_params(struct ice_vsi *vsi) in ice_vsi_set_rss_params() argument
904 struct ice_pf *pf = vsi->back; in ice_vsi_set_rss_params()
908 vsi->rss_size = 1; in ice_vsi_set_rss_params()
914 switch (vsi->type) { in ice_vsi_set_rss_params()
918 vsi->rss_table_size = (u16)cap->rss_table_size; in ice_vsi_set_rss_params()
919 if (vsi->type == ICE_VSI_CHNL) in ice_vsi_set_rss_params()
920 vsi->rss_size = min_t(u16, vsi->num_rxq, max_rss_size); in ice_vsi_set_rss_params()
922 vsi->rss_size = min_t(u16, num_online_cpus(), in ice_vsi_set_rss_params()
924 vsi->rss_lut_type = ICE_LUT_PF; in ice_vsi_set_rss_params()
927 vsi->rss_table_size = ICE_LUT_VSI_SIZE; in ice_vsi_set_rss_params()
928 vsi->rss_size = min_t(u16, num_online_cpus(), max_rss_size); in ice_vsi_set_rss_params()
929 vsi->rss_lut_type = ICE_LUT_VSI; in ice_vsi_set_rss_params()
935 vsi->rss_table_size = ICE_LUT_VSI_SIZE; in ice_vsi_set_rss_params()
936 vsi->rss_size = ICE_MAX_RSS_QS_PER_VF; in ice_vsi_set_rss_params()
937 vsi->rss_lut_type = ICE_LUT_VSI; in ice_vsi_set_rss_params()
943 ice_vsi_type_str(vsi->type)); in ice_vsi_set_rss_params()
1012 static int ice_vsi_setup_q_map(struct ice_vsi *vsi, struct ice_vsi_ctx *ctxt) in ice_vsi_setup_q_map() argument
1016 u16 qcount_tx = vsi->alloc_txq; in ice_vsi_setup_q_map()
1017 u16 qcount_rx = vsi->alloc_rxq; in ice_vsi_setup_q_map()
1021 if (!vsi->tc_cfg.numtc) { in ice_vsi_setup_q_map()
1023 vsi->tc_cfg.numtc = 1; in ice_vsi_setup_q_map()
1024 vsi->tc_cfg.ena_tc = 1; in ice_vsi_setup_q_map()
1027 num_rxq_per_tc = min_t(u16, qcount_rx / vsi->tc_cfg.numtc, ICE_MAX_RXQS_PER_TC); in ice_vsi_setup_q_map()
1030 num_txq_per_tc = qcount_tx / vsi->tc_cfg.numtc; in ice_vsi_setup_q_map()
1049 if (!(vsi->tc_cfg.ena_tc & BIT(i))) { in ice_vsi_setup_q_map()
1051 vsi->tc_cfg.tc_info[i].qoffset = 0; in ice_vsi_setup_q_map()
1052 vsi->tc_cfg.tc_info[i].qcount_rx = 1; in ice_vsi_setup_q_map()
1053 vsi->tc_cfg.tc_info[i].qcount_tx = 1; in ice_vsi_setup_q_map()
1054 vsi->tc_cfg.tc_info[i].netdev_tc = 0; in ice_vsi_setup_q_map()
1060 vsi->tc_cfg.tc_info[i].qoffset = offset; in ice_vsi_setup_q_map()
1061 vsi->tc_cfg.tc_info[i].qcount_rx = num_rxq_per_tc; in ice_vsi_setup_q_map()
1062 vsi->tc_cfg.tc_info[i].qcount_tx = num_txq_per_tc; in ice_vsi_setup_q_map()
1063 vsi->tc_cfg.tc_info[i].netdev_tc = netdev_tc++; in ice_vsi_setup_q_map()
1085 if (rx_count > vsi->alloc_rxq) { in ice_vsi_setup_q_map()
1086 …dev_err(ice_pf_to_dev(vsi->back), "Trying to use more Rx queues (%u), than were allocated (%u)!\n", in ice_vsi_setup_q_map()
1087 rx_count, vsi->alloc_rxq); in ice_vsi_setup_q_map()
1091 if (tx_count > vsi->alloc_txq) { in ice_vsi_setup_q_map()
1092 …dev_err(ice_pf_to_dev(vsi->back), "Trying to use more Tx queues (%u), than were allocated (%u)!\n", in ice_vsi_setup_q_map()
1093 tx_count, vsi->alloc_txq); in ice_vsi_setup_q_map()
1097 vsi->num_txq = tx_count; in ice_vsi_setup_q_map()
1098 vsi->num_rxq = rx_count; in ice_vsi_setup_q_map()
1100 if (vsi->type == ICE_VSI_VF && vsi->num_txq != vsi->num_rxq) { in ice_vsi_setup_q_map()
1101 …dev_dbg(ice_pf_to_dev(vsi->back), "VF VSI should have same number of Tx and Rx queues. Hence makin… in ice_vsi_setup_q_map()
1105 vsi->num_txq = vsi->num_rxq; in ice_vsi_setup_q_map()
1114 ctxt->info.q_mapping[0] = cpu_to_le16(vsi->rxq_map[0]); in ice_vsi_setup_q_map()
1115 ctxt->info.q_mapping[1] = cpu_to_le16(vsi->num_rxq); in ice_vsi_setup_q_map()
1125 static void ice_set_fd_vsi_ctx(struct ice_vsi_ctx *ctxt, struct ice_vsi *vsi) in ice_set_fd_vsi_ctx() argument
1130 if (vsi->type != ICE_VSI_PF && vsi->type != ICE_VSI_CTRL && in ice_set_fd_vsi_ctx()
1131 vsi->type != ICE_VSI_VF && vsi->type != ICE_VSI_CHNL) in ice_set_fd_vsi_ctx()
1146 cpu_to_le16(vsi->num_gfltr); in ice_set_fd_vsi_ctx()
1149 cpu_to_le16(vsi->num_bfltr); in ice_set_fd_vsi_ctx()
1171 static void ice_set_rss_vsi_ctx(struct ice_vsi_ctx *ctxt, struct ice_vsi *vsi) in ice_set_rss_vsi_ctx() argument
1177 pf = vsi->back; in ice_set_rss_vsi_ctx()
1180 switch (vsi->type) { in ice_set_rss_vsi_ctx()
1194 ice_vsi_type_str(vsi->type)); in ice_set_rss_vsi_ctx()
1204 ice_chnl_vsi_setup_q_map(struct ice_vsi *vsi, struct ice_vsi_ctx *ctxt) in ice_chnl_vsi_setup_q_map() argument
1206 struct ice_pf *pf = vsi->back; in ice_chnl_vsi_setup_q_map()
1211 qcount = min_t(int, vsi->num_rxq, pf->num_lan_msix); in ice_chnl_vsi_setup_q_map()
1221 ctxt->info.q_mapping[0] = cpu_to_le16(vsi->next_base_q); in ice_chnl_vsi_setup_q_map()
1231 static bool ice_vsi_is_vlan_pruning_ena(struct ice_vsi *vsi) in ice_vsi_is_vlan_pruning_ena() argument
1233 return vsi->info.sw_flags2 & ICE_AQ_VSI_SW_FLAG_RX_VLAN_PRUNE_ENA; in ice_vsi_is_vlan_pruning_ena()
1247 static int ice_vsi_init(struct ice_vsi *vsi, u32 vsi_flags) in ice_vsi_init() argument
1249 struct ice_pf *pf = vsi->back; in ice_vsi_init()
1260 switch (vsi->type) { in ice_vsi_init()
1273 ctxt->vf_num = vsi->vf->vf_id + hw->func_caps.vf_base_id; in ice_vsi_init()
1283 if (vsi->type == ICE_VSI_CHNL) { in ice_vsi_init()
1297 ice_set_fd_vsi_ctx(ctxt, vsi); in ice_vsi_init()
1299 if (vsi->vsw->bridge_mode == BRIDGE_MODE_VEB) in ice_vsi_init()
1304 vsi->type != ICE_VSI_CTRL) { in ice_vsi_init()
1305 ice_set_rss_vsi_ctx(ctxt, vsi); in ice_vsi_init()
1314 ctxt->info.sw_id = vsi->port_info->sw_id; in ice_vsi_init()
1315 if (vsi->type == ICE_VSI_CHNL) { in ice_vsi_init()
1316 ice_chnl_vsi_setup_q_map(vsi, ctxt); in ice_vsi_init()
1318 ret = ice_vsi_setup_q_map(vsi, ctxt); in ice_vsi_init()
1332 if (vsi->type == ICE_VSI_PF) { in ice_vsi_init()
1339 ret = ice_add_vsi(hw, vsi->idx, ctxt, NULL); in ice_vsi_init()
1346 ret = ice_update_vsi(hw, vsi->idx, ctxt, NULL); in ice_vsi_init()
1355 vsi->info = ctxt->info; in ice_vsi_init()
1358 vsi->vsi_num = ctxt->vsi_num; in ice_vsi_init()
1369 static void ice_vsi_clear_rings(struct ice_vsi *vsi) in ice_vsi_clear_rings() argument
1374 if (vsi->q_vectors) { in ice_vsi_clear_rings()
1375 ice_for_each_q_vector(vsi, i) { in ice_vsi_clear_rings()
1376 struct ice_q_vector *q_vector = vsi->q_vectors[i]; in ice_vsi_clear_rings()
1385 if (vsi->tx_rings) { in ice_vsi_clear_rings()
1386 ice_for_each_alloc_txq(vsi, i) { in ice_vsi_clear_rings()
1387 if (vsi->tx_rings[i]) { in ice_vsi_clear_rings()
1388 kfree_rcu(vsi->tx_rings[i], rcu); in ice_vsi_clear_rings()
1389 WRITE_ONCE(vsi->tx_rings[i], NULL); in ice_vsi_clear_rings()
1393 if (vsi->rx_rings) { in ice_vsi_clear_rings()
1394 ice_for_each_alloc_rxq(vsi, i) { in ice_vsi_clear_rings()
1395 if (vsi->rx_rings[i]) { in ice_vsi_clear_rings()
1396 kfree_rcu(vsi->rx_rings[i], rcu); in ice_vsi_clear_rings()
1397 WRITE_ONCE(vsi->rx_rings[i], NULL); in ice_vsi_clear_rings()
1407 static int ice_vsi_alloc_rings(struct ice_vsi *vsi) in ice_vsi_alloc_rings() argument
1409 bool dvm_ena = ice_is_dvm_ena(&vsi->back->hw); in ice_vsi_alloc_rings()
1410 struct ice_pf *pf = vsi->back; in ice_vsi_alloc_rings()
1416 ice_for_each_alloc_txq(vsi, i) { in ice_vsi_alloc_rings()
1426 ring->reg_idx = vsi->txq_map[i]; in ice_vsi_alloc_rings()
1427 ring->vsi = vsi; in ice_vsi_alloc_rings()
1430 ring->count = vsi->num_tx_desc; in ice_vsi_alloc_rings()
1436 WRITE_ONCE(vsi->tx_rings[i], ring); in ice_vsi_alloc_rings()
1440 ice_for_each_alloc_rxq(vsi, i) { in ice_vsi_alloc_rings()
1449 ring->reg_idx = vsi->rxq_map[i]; in ice_vsi_alloc_rings()
1450 ring->vsi = vsi; in ice_vsi_alloc_rings()
1451 ring->netdev = vsi->netdev; in ice_vsi_alloc_rings()
1453 ring->count = vsi->num_rx_desc; in ice_vsi_alloc_rings()
1455 WRITE_ONCE(vsi->rx_rings[i], ring); in ice_vsi_alloc_rings()
1461 ice_vsi_clear_rings(vsi); in ice_vsi_alloc_rings()
1474 void ice_vsi_manage_rss_lut(struct ice_vsi *vsi, bool ena) in ice_vsi_manage_rss_lut() argument
1478 lut = kzalloc(vsi->rss_table_size, GFP_KERNEL); in ice_vsi_manage_rss_lut()
1483 if (vsi->rss_lut_user) in ice_vsi_manage_rss_lut()
1484 memcpy(lut, vsi->rss_lut_user, vsi->rss_table_size); in ice_vsi_manage_rss_lut()
1486 ice_fill_rss_lut(lut, vsi->rss_table_size, in ice_vsi_manage_rss_lut()
1487 vsi->rss_size); in ice_vsi_manage_rss_lut()
1490 ice_set_rss_lut(vsi, lut, vsi->rss_table_size); in ice_vsi_manage_rss_lut()
1499 void ice_vsi_cfg_crc_strip(struct ice_vsi *vsi, bool disable) in ice_vsi_cfg_crc_strip() argument
1503 ice_for_each_rxq(vsi, i) in ice_vsi_cfg_crc_strip()
1505 vsi->rx_rings[i]->flags |= ICE_RX_FLAGS_CRC_STRIP_DIS; in ice_vsi_cfg_crc_strip()
1507 vsi->rx_rings[i]->flags &= ~ICE_RX_FLAGS_CRC_STRIP_DIS; in ice_vsi_cfg_crc_strip()
1514 int ice_vsi_cfg_rss_lut_key(struct ice_vsi *vsi) in ice_vsi_cfg_rss_lut_key() argument
1516 struct ice_pf *pf = vsi->back; in ice_vsi_cfg_rss_lut_key()
1522 if (vsi->type == ICE_VSI_PF && vsi->ch_rss_size && in ice_vsi_cfg_rss_lut_key()
1524 vsi->rss_size = min_t(u16, vsi->rss_size, vsi->ch_rss_size); in ice_vsi_cfg_rss_lut_key()
1526 vsi->rss_size = min_t(u16, vsi->rss_size, vsi->num_rxq); in ice_vsi_cfg_rss_lut_key()
1534 if (vsi->orig_rss_size && vsi->rss_size < vsi->orig_rss_size && in ice_vsi_cfg_rss_lut_key()
1535 vsi->orig_rss_size <= vsi->num_rxq) { in ice_vsi_cfg_rss_lut_key()
1536 vsi->rss_size = vsi->orig_rss_size; in ice_vsi_cfg_rss_lut_key()
1538 vsi->orig_rss_size = 0; in ice_vsi_cfg_rss_lut_key()
1542 lut = kzalloc(vsi->rss_table_size, GFP_KERNEL); in ice_vsi_cfg_rss_lut_key()
1546 if (vsi->rss_lut_user) in ice_vsi_cfg_rss_lut_key()
1547 memcpy(lut, vsi->rss_lut_user, vsi->rss_table_size); in ice_vsi_cfg_rss_lut_key()
1549 ice_fill_rss_lut(lut, vsi->rss_table_size, vsi->rss_size); in ice_vsi_cfg_rss_lut_key()
1551 err = ice_set_rss_lut(vsi, lut, vsi->rss_table_size); in ice_vsi_cfg_rss_lut_key()
1563 if (vsi->rss_hkey_user) in ice_vsi_cfg_rss_lut_key()
1564 memcpy(key, vsi->rss_hkey_user, ICE_GET_SET_RSS_KEY_EXTEND_KEY_SIZE); in ice_vsi_cfg_rss_lut_key()
1568 err = ice_set_rss_key(vsi, key); in ice_vsi_cfg_rss_lut_key()
1586 static void ice_vsi_set_vf_rss_flow_fld(struct ice_vsi *vsi) in ice_vsi_set_vf_rss_flow_fld() argument
1588 struct ice_pf *pf = vsi->back; in ice_vsi_set_vf_rss_flow_fld()
1595 vsi->vsi_num); in ice_vsi_set_vf_rss_flow_fld()
1599 status = ice_add_avf_rss_cfg(&pf->hw, vsi->idx, ICE_DEFAULT_RSS_HENA); in ice_vsi_set_vf_rss_flow_fld()
1602 vsi->vsi_num, status); in ice_vsi_set_vf_rss_flow_fld()
1616 static void ice_vsi_set_rss_flow_fld(struct ice_vsi *vsi) in ice_vsi_set_rss_flow_fld() argument
1618 u16 vsi_handle = vsi->idx, vsi_num = vsi->vsi_num; in ice_vsi_set_rss_flow_fld()
1619 struct ice_pf *pf = vsi->back; in ice_vsi_set_rss_flow_fld()
1697 static void ice_vsi_cfg_frame_size(struct ice_vsi *vsi) in ice_vsi_cfg_frame_size() argument
1699 if (!vsi->netdev || test_bit(ICE_FLAG_LEGACY_RX, vsi->back->flags)) { in ice_vsi_cfg_frame_size()
1700 vsi->max_frame = ICE_MAX_FRAME_LEGACY_RX; in ice_vsi_cfg_frame_size()
1701 vsi->rx_buf_len = ICE_RXBUF_1664; in ice_vsi_cfg_frame_size()
1704 (vsi->netdev->mtu <= ETH_DATA_LEN)) { in ice_vsi_cfg_frame_size()
1705 vsi->max_frame = ICE_RXBUF_1536 - NET_IP_ALIGN; in ice_vsi_cfg_frame_size()
1706 vsi->rx_buf_len = ICE_RXBUF_1536 - NET_IP_ALIGN; in ice_vsi_cfg_frame_size()
1709 vsi->max_frame = ICE_AQ_SET_MAC_FRAME_SIZE_MAX; in ice_vsi_cfg_frame_size()
1710 vsi->rx_buf_len = ICE_RXBUF_3072; in ice_vsi_cfg_frame_size()
1742 void ice_update_eth_stats(struct ice_vsi *vsi) in ice_update_eth_stats() argument
1745 struct ice_hw *hw = &vsi->back->hw; in ice_update_eth_stats()
1746 struct ice_pf *pf = vsi->back; in ice_update_eth_stats()
1747 u16 vsi_num = vsi->vsi_num; /* HW absolute index of a VSI */ in ice_update_eth_stats()
1749 prev_es = &vsi->eth_stats_prev; in ice_update_eth_stats()
1750 cur_es = &vsi->eth_stats; in ice_update_eth_stats()
1753 vsi->stat_offsets_loaded = false; in ice_update_eth_stats()
1755 ice_stat_update40(hw, GLV_GORCL(vsi_num), vsi->stat_offsets_loaded, in ice_update_eth_stats()
1758 ice_stat_update40(hw, GLV_UPRCL(vsi_num), vsi->stat_offsets_loaded, in ice_update_eth_stats()
1761 ice_stat_update40(hw, GLV_MPRCL(vsi_num), vsi->stat_offsets_loaded, in ice_update_eth_stats()
1764 ice_stat_update40(hw, GLV_BPRCL(vsi_num), vsi->stat_offsets_loaded, in ice_update_eth_stats()
1767 ice_stat_update32(hw, GLV_RDPC(vsi_num), vsi->stat_offsets_loaded, in ice_update_eth_stats()
1770 ice_stat_update40(hw, GLV_GOTCL(vsi_num), vsi->stat_offsets_loaded, in ice_update_eth_stats()
1773 ice_stat_update40(hw, GLV_UPTCL(vsi_num), vsi->stat_offsets_loaded, in ice_update_eth_stats()
1776 ice_stat_update40(hw, GLV_MPTCL(vsi_num), vsi->stat_offsets_loaded, in ice_update_eth_stats()
1779 ice_stat_update40(hw, GLV_BPTCL(vsi_num), vsi->stat_offsets_loaded, in ice_update_eth_stats()
1782 ice_stat_update32(hw, GLV_TEPC(vsi_num), vsi->stat_offsets_loaded, in ice_update_eth_stats()
1785 vsi->stat_offsets_loaded = true; in ice_update_eth_stats()
1820 int ice_vsi_cfg_single_rxq(struct ice_vsi *vsi, u16 q_idx) in ice_vsi_cfg_single_rxq() argument
1822 if (q_idx >= vsi->num_rxq) in ice_vsi_cfg_single_rxq()
1825 return ice_vsi_cfg_rxq(vsi->rx_rings[q_idx]); in ice_vsi_cfg_single_rxq()
1828 int ice_vsi_cfg_single_txq(struct ice_vsi *vsi, struct ice_tx_ring **tx_rings, u16 q_idx) in ice_vsi_cfg_single_txq() argument
1833 if (q_idx >= vsi->alloc_txq || !tx_rings || !tx_rings[q_idx]) in ice_vsi_cfg_single_txq()
1842 err = ice_vsi_cfg_txq(vsi, tx_rings[q_idx], qg_buf); in ice_vsi_cfg_single_txq()
1854 int ice_vsi_cfg_rxqs(struct ice_vsi *vsi) in ice_vsi_cfg_rxqs() argument
1858 if (vsi->type == ICE_VSI_VF) in ice_vsi_cfg_rxqs()
1861 ice_vsi_cfg_frame_size(vsi); in ice_vsi_cfg_rxqs()
1864 ice_for_each_rxq(vsi, i) { in ice_vsi_cfg_rxqs()
1865 int err = ice_vsi_cfg_rxq(vsi->rx_rings[i]); in ice_vsi_cfg_rxqs()
1884 ice_vsi_cfg_txqs(struct ice_vsi *vsi, struct ice_tx_ring **rings, u16 count) in ice_vsi_cfg_txqs() argument
1897 err = ice_vsi_cfg_txq(vsi, rings[q_idx], qg_buf); in ice_vsi_cfg_txqs()
1914 int ice_vsi_cfg_lan_txqs(struct ice_vsi *vsi) in ice_vsi_cfg_lan_txqs() argument
1916 return ice_vsi_cfg_txqs(vsi, vsi->tx_rings, vsi->num_txq); in ice_vsi_cfg_lan_txqs()
1926 int ice_vsi_cfg_xdp_txqs(struct ice_vsi *vsi) in ice_vsi_cfg_xdp_txqs() argument
1931 ret = ice_vsi_cfg_txqs(vsi, vsi->xdp_rings, vsi->num_xdp_txq); in ice_vsi_cfg_xdp_txqs()
1935 ice_for_each_rxq(vsi, i) in ice_vsi_cfg_xdp_txqs()
1936 ice_tx_xsk_pool(vsi, i); in ice_vsi_cfg_xdp_txqs()
1965 struct ice_hw *hw = &q_vector->vsi->back->hw; in ice_write_intrl()
1998 struct ice_hw *hw = &q_vector->vsi->back->hw; in __ice_write_itr()
2052 void ice_vsi_cfg_msix(struct ice_vsi *vsi) in ice_vsi_cfg_msix() argument
2054 struct ice_pf *pf = vsi->back; in ice_vsi_cfg_msix()
2059 ice_for_each_q_vector(vsi, i) { in ice_vsi_cfg_msix()
2060 struct ice_q_vector *q_vector = vsi->q_vectors[i]; in ice_vsi_cfg_msix()
2077 ice_cfg_txq_interrupt(vsi, txq, reg_idx, in ice_vsi_cfg_msix()
2083 ice_cfg_rxq_interrupt(vsi, rxq, reg_idx, in ice_vsi_cfg_msix()
2096 int ice_vsi_start_all_rx_rings(struct ice_vsi *vsi) in ice_vsi_start_all_rx_rings() argument
2098 return ice_vsi_ctrl_all_rx_rings(vsi, true); in ice_vsi_start_all_rx_rings()
2107 int ice_vsi_stop_all_rx_rings(struct ice_vsi *vsi) in ice_vsi_stop_all_rx_rings() argument
2109 return ice_vsi_ctrl_all_rx_rings(vsi, false); in ice_vsi_stop_all_rx_rings()
2121 ice_vsi_stop_tx_rings(struct ice_vsi *vsi, enum ice_disq_rst_src rst_src, in ice_vsi_stop_tx_rings() argument
2126 if (vsi->num_txq > ICE_LAN_TXQ_MAX_QDIS) in ice_vsi_stop_tx_rings()
2136 ice_fill_txq_meta(vsi, rings[q_idx], &txq_meta); in ice_vsi_stop_tx_rings()
2137 status = ice_vsi_stop_tx_ring(vsi, rst_src, rel_vmvf_num, in ice_vsi_stop_tx_rings()
2154 ice_vsi_stop_lan_tx_rings(struct ice_vsi *vsi, enum ice_disq_rst_src rst_src, in ice_vsi_stop_lan_tx_rings() argument
2157 return ice_vsi_stop_tx_rings(vsi, rst_src, rel_vmvf_num, vsi->tx_rings, vsi->num_txq); in ice_vsi_stop_lan_tx_rings()
2164 int ice_vsi_stop_xdp_tx_rings(struct ice_vsi *vsi) in ice_vsi_stop_xdp_tx_rings() argument
2166 return ice_vsi_stop_tx_rings(vsi, ICE_NO_RESET, 0, vsi->xdp_rings, vsi->num_xdp_txq); in ice_vsi_stop_xdp_tx_rings()
2175 bool ice_vsi_is_rx_queue_active(struct ice_vsi *vsi) in ice_vsi_is_rx_queue_active() argument
2177 struct ice_pf *pf = vsi->back; in ice_vsi_is_rx_queue_active()
2181 ice_for_each_rxq(vsi, i) { in ice_vsi_is_rx_queue_active()
2185 pf_q = vsi->rxq_map[i]; in ice_vsi_is_rx_queue_active()
2194 static void ice_vsi_set_tc_cfg(struct ice_vsi *vsi) in ice_vsi_set_tc_cfg() argument
2196 if (!test_bit(ICE_FLAG_DCB_ENA, vsi->back->flags)) { in ice_vsi_set_tc_cfg()
2197 vsi->tc_cfg.ena_tc = ICE_DFLT_TRAFFIC_CLASS; in ice_vsi_set_tc_cfg()
2198 vsi->tc_cfg.numtc = 1; in ice_vsi_set_tc_cfg()
2203 ice_vsi_set_dcb_tc_cfg(vsi); in ice_vsi_set_tc_cfg()
2212 void ice_cfg_sw_lldp(struct ice_vsi *vsi, bool tx, bool create) in ice_cfg_sw_lldp() argument
2216 struct ice_pf *pf = vsi->back; in ice_cfg_sw_lldp()
2224 status = eth_fltr(vsi, ETH_P_LLDP, ICE_FLTR_TX, in ice_cfg_sw_lldp()
2228 status = ice_lldp_fltr_add_remove(&pf->hw, vsi->vsi_num, in ice_cfg_sw_lldp()
2231 status = eth_fltr(vsi, ETH_P_LLDP, ICE_FLTR_RX, in ice_cfg_sw_lldp()
2239 vsi->vsi_num, status); in ice_cfg_sw_lldp()
2249 static void ice_set_agg_vsi(struct ice_vsi *vsi) in ice_set_agg_vsi() argument
2251 struct device *dev = ice_pf_to_dev(vsi->back); in ice_set_agg_vsi()
2257 struct ice_pf *pf = vsi->back; in ice_set_agg_vsi()
2270 switch (vsi->type) { in ice_set_agg_vsi()
2294 ice_vsi_type_str(vsi->type)); in ice_set_agg_vsi()
2332 (u8)vsi->tc_cfg.ena_tc); in ice_set_agg_vsi()
2344 status = ice_move_vsi_to_agg(port_info, agg_id, vsi->idx, in ice_set_agg_vsi()
2345 (u8)vsi->tc_cfg.ena_tc); in ice_set_agg_vsi()
2348 vsi->idx, agg_id); in ice_set_agg_vsi()
2358 vsi->agg_node = agg_node; in ice_set_agg_vsi()
2360 vsi->idx, vsi->tc_cfg.ena_tc, vsi->agg_node->agg_id, in ice_set_agg_vsi()
2361 vsi->agg_node->num_vsis); in ice_set_agg_vsi()
2364 static int ice_vsi_cfg_tc_lan(struct ice_pf *pf, struct ice_vsi *vsi) in ice_vsi_cfg_tc_lan() argument
2372 if (!(vsi->tc_cfg.ena_tc & BIT(i))) in ice_vsi_cfg_tc_lan()
2375 if (vsi->type == ICE_VSI_CHNL) { in ice_vsi_cfg_tc_lan()
2376 if (!vsi->alloc_txq && vsi->num_txq) in ice_vsi_cfg_tc_lan()
2377 max_txqs[i] = vsi->num_txq; in ice_vsi_cfg_tc_lan()
2381 max_txqs[i] = vsi->alloc_txq; in ice_vsi_cfg_tc_lan()
2384 if (vsi->type == ICE_VSI_PF) in ice_vsi_cfg_tc_lan()
2385 max_txqs[i] += vsi->num_xdp_txq; in ice_vsi_cfg_tc_lan()
2388 dev_dbg(dev, "vsi->tc_cfg.ena_tc = %d\n", vsi->tc_cfg.ena_tc); in ice_vsi_cfg_tc_lan()
2389 ret = ice_cfg_vsi_lan(vsi->port_info, vsi->idx, vsi->tc_cfg.ena_tc, in ice_vsi_cfg_tc_lan()
2393 vsi->vsi_num, ret); in ice_vsi_cfg_tc_lan()
2406 ice_vsi_cfg_def(struct ice_vsi *vsi, struct ice_vsi_cfg_params *params) in ice_vsi_cfg_def() argument
2408 struct device *dev = ice_pf_to_dev(vsi->back); in ice_vsi_cfg_def()
2409 struct ice_pf *pf = vsi->back; in ice_vsi_cfg_def()
2412 vsi->vsw = pf->first_sw; in ice_vsi_cfg_def()
2414 ret = ice_vsi_alloc_def(vsi, params->ch); in ice_vsi_cfg_def()
2419 ret = ice_vsi_alloc_stat_arrays(vsi); in ice_vsi_cfg_def()
2423 ice_alloc_fd_res(vsi); in ice_vsi_cfg_def()
2425 ret = ice_vsi_get_qs(vsi); in ice_vsi_cfg_def()
2428 vsi->idx); in ice_vsi_cfg_def()
2433 ice_vsi_set_rss_params(vsi); in ice_vsi_cfg_def()
2436 ice_vsi_set_tc_cfg(vsi); in ice_vsi_cfg_def()
2439 ret = ice_vsi_init(vsi, params->flags); in ice_vsi_cfg_def()
2443 ice_vsi_init_vlan_ops(vsi); in ice_vsi_cfg_def()
2445 switch (vsi->type) { in ice_vsi_cfg_def()
2449 ret = ice_vsi_alloc_q_vectors(vsi); in ice_vsi_cfg_def()
2453 ret = ice_vsi_alloc_rings(vsi); in ice_vsi_cfg_def()
2457 ret = ice_vsi_alloc_ring_stats(vsi); in ice_vsi_cfg_def()
2461 ice_vsi_map_rings_to_vectors(vsi); in ice_vsi_cfg_def()
2462 vsi->stat_offsets_loaded = false; in ice_vsi_cfg_def()
2464 if (ice_is_xdp_ena_vsi(vsi)) { in ice_vsi_cfg_def()
2465 ret = ice_vsi_determine_xdp_res(vsi); in ice_vsi_cfg_def()
2468 ret = ice_prepare_xdp_rings(vsi, vsi->xdp_prog, in ice_vsi_cfg_def()
2475 if (vsi->type != ICE_VSI_CTRL) in ice_vsi_cfg_def()
2481 ice_vsi_cfg_rss_lut_key(vsi); in ice_vsi_cfg_def()
2482 ice_vsi_set_rss_flow_fld(vsi); in ice_vsi_cfg_def()
2484 ice_init_arfs(vsi); in ice_vsi_cfg_def()
2488 ice_vsi_cfg_rss_lut_key(vsi); in ice_vsi_cfg_def()
2489 ice_vsi_set_rss_flow_fld(vsi); in ice_vsi_cfg_def()
2498 ret = ice_vsi_alloc_q_vectors(vsi); in ice_vsi_cfg_def()
2502 ret = ice_vsi_alloc_rings(vsi); in ice_vsi_cfg_def()
2506 ret = ice_vsi_alloc_ring_stats(vsi); in ice_vsi_cfg_def()
2510 vsi->stat_offsets_loaded = false; in ice_vsi_cfg_def()
2517 ice_vsi_cfg_rss_lut_key(vsi); in ice_vsi_cfg_def()
2518 ice_vsi_set_vf_rss_flow_fld(vsi); in ice_vsi_cfg_def()
2522 ret = ice_vsi_alloc_rings(vsi); in ice_vsi_cfg_def()
2526 ret = ice_vsi_alloc_ring_stats(vsi); in ice_vsi_cfg_def()
2542 ice_vsi_free_q_vectors(vsi); in ice_vsi_cfg_def()
2544 ice_vsi_delete_from_hw(vsi); in ice_vsi_cfg_def()
2546 ice_vsi_put_qs(vsi); in ice_vsi_cfg_def()
2548 ice_vsi_free_stats(vsi); in ice_vsi_cfg_def()
2550 ice_vsi_free_arrays(vsi); in ice_vsi_cfg_def()
2559 int ice_vsi_cfg(struct ice_vsi *vsi, struct ice_vsi_cfg_params *params) in ice_vsi_cfg() argument
2561 struct ice_pf *pf = vsi->back; in ice_vsi_cfg()
2567 vsi->type = params->type; in ice_vsi_cfg()
2568 vsi->port_info = params->pi; in ice_vsi_cfg()
2571 vsi->vf = params->vf; in ice_vsi_cfg()
2573 ret = ice_vsi_cfg_def(vsi, params); in ice_vsi_cfg()
2577 ret = ice_vsi_cfg_tc_lan(vsi->back, vsi); in ice_vsi_cfg()
2579 ice_vsi_decfg(vsi); in ice_vsi_cfg()
2581 if (vsi->type == ICE_VSI_CTRL) { in ice_vsi_cfg()
2582 if (vsi->vf) { in ice_vsi_cfg()
2583 WARN_ON(vsi->vf->ctrl_vsi_idx != ICE_NO_VSI); in ice_vsi_cfg()
2584 vsi->vf->ctrl_vsi_idx = vsi->idx; in ice_vsi_cfg()
2587 pf->ctrl_vsi_idx = vsi->idx; in ice_vsi_cfg()
2598 void ice_vsi_decfg(struct ice_vsi *vsi) in ice_vsi_decfg() argument
2600 struct ice_pf *pf = vsi->back; in ice_vsi_decfg()
2603 ice_rm_vsi_lan_cfg(vsi->port_info, vsi->idx); in ice_vsi_decfg()
2604 err = ice_rm_vsi_rdma_cfg(vsi->port_info, vsi->idx); in ice_vsi_decfg()
2607 vsi->vsi_num, err); in ice_vsi_decfg()
2609 if (ice_is_xdp_ena_vsi(vsi)) in ice_vsi_decfg()
2613 ice_destroy_xdp_rings(vsi, ICE_XDP_CFG_PART); in ice_vsi_decfg()
2615 ice_vsi_clear_rings(vsi); in ice_vsi_decfg()
2616 ice_vsi_free_q_vectors(vsi); in ice_vsi_decfg()
2617 ice_vsi_put_qs(vsi); in ice_vsi_decfg()
2618 ice_vsi_free_arrays(vsi); in ice_vsi_decfg()
2626 if (vsi->type == ICE_VSI_VF && in ice_vsi_decfg()
2627 vsi->agg_node && vsi->agg_node->valid) in ice_vsi_decfg()
2628 vsi->agg_node->num_vsis--; in ice_vsi_decfg()
2645 struct ice_vsi *vsi; in ice_vsi_setup() local
2655 vsi = ice_vsi_alloc(pf); in ice_vsi_setup()
2656 if (!vsi) { in ice_vsi_setup()
2661 ret = ice_vsi_cfg(vsi, params); in ice_vsi_setup()
2674 if (!ice_is_safe_mode(pf) && vsi->type == ICE_VSI_PF) { in ice_vsi_setup()
2675 ice_fltr_add_eth(vsi, ETH_P_PAUSE, ICE_FLTR_TX, in ice_vsi_setup()
2677 ice_cfg_sw_lldp(vsi, true, true); in ice_vsi_setup()
2680 if (!vsi->agg_node) in ice_vsi_setup()
2681 ice_set_agg_vsi(vsi); in ice_vsi_setup()
2683 return vsi; in ice_vsi_setup()
2686 ice_vsi_free(vsi); in ice_vsi_setup()
2695 static void ice_vsi_release_msix(struct ice_vsi *vsi) in ice_vsi_release_msix() argument
2697 struct ice_pf *pf = vsi->back; in ice_vsi_release_msix()
2703 ice_for_each_q_vector(vsi, i) { in ice_vsi_release_msix()
2704 struct ice_q_vector *q_vector = vsi->q_vectors[i]; in ice_vsi_release_msix()
2709 wr32(hw, QINT_TQCTL(vsi->txq_map[txq]), 0); in ice_vsi_release_msix()
2710 if (ice_is_xdp_ena_vsi(vsi)) { in ice_vsi_release_msix()
2711 u32 xdp_txq = txq + vsi->num_xdp_txq; in ice_vsi_release_msix()
2713 wr32(hw, QINT_TQCTL(vsi->txq_map[xdp_txq]), 0); in ice_vsi_release_msix()
2720 wr32(hw, QINT_RQCTL(vsi->rxq_map[rxq]), 0); in ice_vsi_release_msix()
2732 void ice_vsi_free_irq(struct ice_vsi *vsi) in ice_vsi_free_irq() argument
2734 struct ice_pf *pf = vsi->back; in ice_vsi_free_irq()
2737 if (!vsi->q_vectors || !vsi->irqs_ready) in ice_vsi_free_irq()
2740 ice_vsi_release_msix(vsi); in ice_vsi_free_irq()
2741 if (vsi->type == ICE_VSI_VF) in ice_vsi_free_irq()
2744 vsi->irqs_ready = false; in ice_vsi_free_irq()
2745 ice_free_cpu_rx_rmap(vsi); in ice_vsi_free_irq()
2747 ice_for_each_q_vector(vsi, i) { in ice_vsi_free_irq()
2750 irq_num = vsi->q_vectors[i]->irq.virq; in ice_vsi_free_irq()
2753 if (!vsi->q_vectors[i] || in ice_vsi_free_irq()
2754 !(vsi->q_vectors[i]->num_ring_tx || in ice_vsi_free_irq()
2755 vsi->q_vectors[i]->num_ring_rx)) in ice_vsi_free_irq()
2765 devm_free_irq(ice_pf_to_dev(pf), irq_num, vsi->q_vectors[i]); in ice_vsi_free_irq()
2773 void ice_vsi_free_tx_rings(struct ice_vsi *vsi) in ice_vsi_free_tx_rings() argument
2777 if (!vsi->tx_rings) in ice_vsi_free_tx_rings()
2780 ice_for_each_txq(vsi, i) in ice_vsi_free_tx_rings()
2781 if (vsi->tx_rings[i] && vsi->tx_rings[i]->desc) in ice_vsi_free_tx_rings()
2782 ice_free_tx_ring(vsi->tx_rings[i]); in ice_vsi_free_tx_rings()
2789 void ice_vsi_free_rx_rings(struct ice_vsi *vsi) in ice_vsi_free_rx_rings() argument
2793 if (!vsi->rx_rings) in ice_vsi_free_rx_rings()
2796 ice_for_each_rxq(vsi, i) in ice_vsi_free_rx_rings()
2797 if (vsi->rx_rings[i] && vsi->rx_rings[i]->desc) in ice_vsi_free_rx_rings()
2798 ice_free_rx_ring(vsi->rx_rings[i]); in ice_vsi_free_rx_rings()
2805 void ice_vsi_close(struct ice_vsi *vsi) in ice_vsi_close() argument
2807 if (!test_and_set_bit(ICE_VSI_DOWN, vsi->state)) in ice_vsi_close()
2808 ice_down(vsi); in ice_vsi_close()
2810 ice_vsi_free_irq(vsi); in ice_vsi_close()
2811 ice_vsi_free_tx_rings(vsi); in ice_vsi_close()
2812 ice_vsi_free_rx_rings(vsi); in ice_vsi_close()
2820 int ice_ena_vsi(struct ice_vsi *vsi, bool locked) in ice_ena_vsi() argument
2824 if (!test_bit(ICE_VSI_NEEDS_RESTART, vsi->state)) in ice_ena_vsi()
2827 clear_bit(ICE_VSI_NEEDS_RESTART, vsi->state); in ice_ena_vsi()
2829 if (vsi->netdev && vsi->type == ICE_VSI_PF) { in ice_ena_vsi()
2830 if (netif_running(vsi->netdev)) { in ice_ena_vsi()
2834 err = ice_open_internal(vsi->netdev); in ice_ena_vsi()
2839 } else if (vsi->type == ICE_VSI_CTRL) { in ice_ena_vsi()
2840 err = ice_vsi_open_ctrl(vsi); in ice_ena_vsi()
2851 void ice_dis_vsi(struct ice_vsi *vsi, bool locked) in ice_dis_vsi() argument
2853 if (test_bit(ICE_VSI_DOWN, vsi->state)) in ice_dis_vsi()
2856 set_bit(ICE_VSI_NEEDS_RESTART, vsi->state); in ice_dis_vsi()
2858 if (vsi->type == ICE_VSI_PF && vsi->netdev) { in ice_dis_vsi()
2859 if (netif_running(vsi->netdev)) { in ice_dis_vsi()
2863 ice_vsi_close(vsi); in ice_dis_vsi()
2868 ice_vsi_close(vsi); in ice_dis_vsi()
2870 } else if (vsi->type == ICE_VSI_CTRL || in ice_dis_vsi()
2871 vsi->type == ICE_VSI_SWITCHDEV_CTRL) { in ice_dis_vsi()
2872 ice_vsi_close(vsi); in ice_dis_vsi()
2880 void ice_vsi_dis_irq(struct ice_vsi *vsi) in ice_vsi_dis_irq() argument
2882 struct ice_pf *pf = vsi->back; in ice_vsi_dis_irq()
2888 if (vsi->tx_rings) { in ice_vsi_dis_irq()
2889 ice_for_each_txq(vsi, i) { in ice_vsi_dis_irq()
2890 if (vsi->tx_rings[i]) { in ice_vsi_dis_irq()
2893 reg = vsi->tx_rings[i]->reg_idx; in ice_vsi_dis_irq()
2901 if (vsi->rx_rings) { in ice_vsi_dis_irq()
2902 ice_for_each_rxq(vsi, i) { in ice_vsi_dis_irq()
2903 if (vsi->rx_rings[i]) { in ice_vsi_dis_irq()
2906 reg = vsi->rx_rings[i]->reg_idx; in ice_vsi_dis_irq()
2915 ice_for_each_q_vector(vsi, i) { in ice_vsi_dis_irq()
2916 if (!vsi->q_vectors[i]) in ice_vsi_dis_irq()
2918 wr32(hw, GLINT_DYN_CTL(vsi->q_vectors[i]->reg_idx), 0); in ice_vsi_dis_irq()
2924 if (vsi->type == ICE_VSI_VF) in ice_vsi_dis_irq()
2927 ice_for_each_q_vector(vsi, i) in ice_vsi_dis_irq()
2928 synchronize_irq(vsi->q_vectors[i]->irq.virq); in ice_vsi_dis_irq()
2937 int ice_vsi_release(struct ice_vsi *vsi) in ice_vsi_release() argument
2941 if (!vsi->back) in ice_vsi_release()
2943 pf = vsi->back; in ice_vsi_release()
2946 ice_rss_clean(vsi); in ice_vsi_release()
2948 ice_vsi_close(vsi); in ice_vsi_release()
2953 if (!ice_is_safe_mode(pf) && vsi->type == ICE_VSI_PF && in ice_vsi_release()
2955 ice_cfg_sw_lldp(vsi, false, false); in ice_vsi_release()
2957 ice_vsi_decfg(vsi); in ice_vsi_release()
2964 ice_vsi_delete(vsi); in ice_vsi_release()
2977 ice_vsi_rebuild_get_coalesce(struct ice_vsi *vsi, in ice_vsi_rebuild_get_coalesce() argument
2982 ice_for_each_q_vector(vsi, i) { in ice_vsi_rebuild_get_coalesce()
2983 struct ice_q_vector *q_vector = vsi->q_vectors[i]; in ice_vsi_rebuild_get_coalesce()
2989 if (i < vsi->num_txq) in ice_vsi_rebuild_get_coalesce()
2991 if (i < vsi->num_rxq) in ice_vsi_rebuild_get_coalesce()
2995 return vsi->num_q_vectors; in ice_vsi_rebuild_get_coalesce()
3009 ice_vsi_rebuild_set_coalesce(struct ice_vsi *vsi, in ice_vsi_rebuild_set_coalesce() argument
3015 if ((size && !coalesce) || !vsi) in ice_vsi_rebuild_set_coalesce()
3024 for (i = 0; i < size && i < vsi->num_q_vectors; i++) { in ice_vsi_rebuild_set_coalesce()
3040 if (i < vsi->alloc_rxq && coalesce[i].rx_valid) { in ice_vsi_rebuild_set_coalesce()
3041 rc = &vsi->q_vectors[i]->rx; in ice_vsi_rebuild_set_coalesce()
3044 } else if (i < vsi->alloc_rxq) { in ice_vsi_rebuild_set_coalesce()
3045 rc = &vsi->q_vectors[i]->rx; in ice_vsi_rebuild_set_coalesce()
3050 if (i < vsi->alloc_txq && coalesce[i].tx_valid) { in ice_vsi_rebuild_set_coalesce()
3051 rc = &vsi->q_vectors[i]->tx; in ice_vsi_rebuild_set_coalesce()
3054 } else if (i < vsi->alloc_txq) { in ice_vsi_rebuild_set_coalesce()
3055 rc = &vsi->q_vectors[i]->tx; in ice_vsi_rebuild_set_coalesce()
3060 vsi->q_vectors[i]->intrl = coalesce[i].intrl; in ice_vsi_rebuild_set_coalesce()
3061 ice_set_q_vector_intrl(vsi->q_vectors[i]); in ice_vsi_rebuild_set_coalesce()
3067 for (; i < vsi->num_q_vectors; i++) { in ice_vsi_rebuild_set_coalesce()
3069 rc = &vsi->q_vectors[i]->tx; in ice_vsi_rebuild_set_coalesce()
3074 rc = &vsi->q_vectors[i]->rx; in ice_vsi_rebuild_set_coalesce()
3078 vsi->q_vectors[i]->intrl = coalesce[0].intrl; in ice_vsi_rebuild_set_coalesce()
3079 ice_set_q_vector_intrl(vsi->q_vectors[i]); in ice_vsi_rebuild_set_coalesce()
3088 ice_vsi_realloc_stat_arrays(struct ice_vsi *vsi) in ice_vsi_realloc_stat_arrays() argument
3090 u16 req_txq = vsi->req_txq ? vsi->req_txq : vsi->alloc_txq; in ice_vsi_realloc_stat_arrays()
3091 u16 req_rxq = vsi->req_rxq ? vsi->req_rxq : vsi->alloc_rxq; in ice_vsi_realloc_stat_arrays()
3095 struct ice_pf *pf = vsi->back; in ice_vsi_realloc_stat_arrays()
3096 u16 prev_txq = vsi->alloc_txq; in ice_vsi_realloc_stat_arrays()
3097 u16 prev_rxq = vsi->alloc_rxq; in ice_vsi_realloc_stat_arrays()
3100 vsi_stat = pf->vsi_stats[vsi->idx]; in ice_vsi_realloc_stat_arrays()
3153 int ice_vsi_rebuild(struct ice_vsi *vsi, u32 vsi_flags) in ice_vsi_rebuild() argument
3161 if (!vsi) in ice_vsi_rebuild()
3164 params = ice_vsi_to_params(vsi); in ice_vsi_rebuild()
3167 pf = vsi->back; in ice_vsi_rebuild()
3168 if (WARN_ON(vsi->type == ICE_VSI_VF && !vsi->vf)) in ice_vsi_rebuild()
3171 mutex_lock(&vsi->xdp_state_lock); in ice_vsi_rebuild()
3173 ret = ice_vsi_realloc_stat_arrays(vsi); in ice_vsi_rebuild()
3177 ice_vsi_decfg(vsi); in ice_vsi_rebuild()
3178 ret = ice_vsi_cfg_def(vsi, &params); in ice_vsi_rebuild()
3182 coalesce = kcalloc(vsi->num_q_vectors, in ice_vsi_rebuild()
3189 prev_num_q_vectors = ice_vsi_rebuild_get_coalesce(vsi, coalesce); in ice_vsi_rebuild()
3191 ret = ice_vsi_cfg_tc_lan(pf, vsi); in ice_vsi_rebuild()
3202 ice_vsi_rebuild_set_coalesce(vsi, coalesce, prev_num_q_vectors); in ice_vsi_rebuild()
3203 clear_bit(ICE_VSI_REBUILD_PENDING, vsi->state); in ice_vsi_rebuild()
3209 ice_vsi_decfg(vsi); in ice_vsi_rebuild()
3211 mutex_unlock(&vsi->xdp_state_lock); in ice_vsi_rebuild()
3260 static void ice_vsi_update_q_map(struct ice_vsi *vsi, struct ice_vsi_ctx *ctx) in ice_vsi_update_q_map() argument
3262 vsi->info.mapping_flags = ctx->info.mapping_flags; in ice_vsi_update_q_map()
3263 memcpy(&vsi->info.q_mapping, &ctx->info.q_mapping, in ice_vsi_update_q_map()
3264 sizeof(vsi->info.q_mapping)); in ice_vsi_update_q_map()
3265 memcpy(&vsi->info.tc_mapping, ctx->info.tc_mapping, in ice_vsi_update_q_map()
3266 sizeof(vsi->info.tc_mapping)); in ice_vsi_update_q_map()
3274 void ice_vsi_cfg_netdev_tc(struct ice_vsi *vsi, u8 ena_tc) in ice_vsi_cfg_netdev_tc() argument
3276 struct net_device *netdev = vsi->netdev; in ice_vsi_cfg_netdev_tc()
3277 struct ice_pf *pf = vsi->back; in ice_vsi_cfg_netdev_tc()
3278 int numtc = vsi->tc_cfg.numtc; in ice_vsi_cfg_netdev_tc()
3287 if (vsi->type == ICE_VSI_CHNL) in ice_vsi_cfg_netdev_tc()
3295 if (vsi->type == ICE_VSI_PF && ice_is_adq_active(pf)) in ice_vsi_cfg_netdev_tc()
3296 numtc = vsi->all_numtc; in ice_vsi_cfg_netdev_tc()
3304 if (vsi->tc_cfg.ena_tc & BIT(i)) in ice_vsi_cfg_netdev_tc()
3306 vsi->tc_cfg.tc_info[i].netdev_tc, in ice_vsi_cfg_netdev_tc()
3307 vsi->tc_cfg.tc_info[i].qcount_tx, in ice_vsi_cfg_netdev_tc()
3308 vsi->tc_cfg.tc_info[i].qoffset); in ice_vsi_cfg_netdev_tc()
3311 if (!(vsi->all_enatc & BIT(i))) in ice_vsi_cfg_netdev_tc()
3313 if (!vsi->mqprio_qopt.qopt.count[i]) in ice_vsi_cfg_netdev_tc()
3316 vsi->mqprio_qopt.qopt.count[i], in ice_vsi_cfg_netdev_tc()
3317 vsi->mqprio_qopt.qopt.offset[i]); in ice_vsi_cfg_netdev_tc()
3327 netdev_tc = vsi->tc_cfg.tc_info[ets_tc].netdev_tc; in ice_vsi_cfg_netdev_tc()
3341 ice_vsi_setup_q_map_mqprio(struct ice_vsi *vsi, struct ice_vsi_ctx *ctxt, in ice_vsi_setup_q_map_mqprio() argument
3345 u16 tc0_offset = vsi->mqprio_qopt.qopt.offset[0]; in ice_vsi_setup_q_map_mqprio()
3346 int tc0_qcount = vsi->mqprio_qopt.qopt.count[0]; in ice_vsi_setup_q_map_mqprio()
3351 vsi->tc_cfg.ena_tc = ena_tc ? ena_tc : 1; in ice_vsi_setup_q_map_mqprio()
3359 if (!(vsi->tc_cfg.ena_tc & BIT(i))) { in ice_vsi_setup_q_map_mqprio()
3361 vsi->tc_cfg.tc_info[i].qoffset = 0; in ice_vsi_setup_q_map_mqprio()
3362 vsi->tc_cfg.tc_info[i].qcount_rx = 1; in ice_vsi_setup_q_map_mqprio()
3363 vsi->tc_cfg.tc_info[i].qcount_tx = 1; in ice_vsi_setup_q_map_mqprio()
3364 vsi->tc_cfg.tc_info[i].netdev_tc = 0; in ice_vsi_setup_q_map_mqprio()
3369 offset = vsi->mqprio_qopt.qopt.offset[i]; in ice_vsi_setup_q_map_mqprio()
3370 qcount_rx = vsi->mqprio_qopt.qopt.count[i]; in ice_vsi_setup_q_map_mqprio()
3371 qcount_tx = vsi->mqprio_qopt.qopt.count[i]; in ice_vsi_setup_q_map_mqprio()
3372 vsi->tc_cfg.tc_info[i].qoffset = offset; in ice_vsi_setup_q_map_mqprio()
3373 vsi->tc_cfg.tc_info[i].qcount_rx = qcount_rx; in ice_vsi_setup_q_map_mqprio()
3374 vsi->tc_cfg.tc_info[i].qcount_tx = qcount_tx; in ice_vsi_setup_q_map_mqprio()
3375 vsi->tc_cfg.tc_info[i].netdev_tc = netdev_tc++; in ice_vsi_setup_q_map_mqprio()
3378 if (vsi->all_numtc && vsi->all_numtc != vsi->tc_cfg.numtc) { in ice_vsi_setup_q_map_mqprio()
3380 if (!(vsi->all_enatc & BIT(i))) in ice_vsi_setup_q_map_mqprio()
3382 offset = vsi->mqprio_qopt.qopt.offset[i]; in ice_vsi_setup_q_map_mqprio()
3383 qcount_rx = vsi->mqprio_qopt.qopt.count[i]; in ice_vsi_setup_q_map_mqprio()
3384 qcount_tx = vsi->mqprio_qopt.qopt.count[i]; in ice_vsi_setup_q_map_mqprio()
3389 if (new_txq > vsi->alloc_txq) { in ice_vsi_setup_q_map_mqprio()
3390 …dev_err(ice_pf_to_dev(vsi->back), "Trying to use more Tx queues (%u), than were allocated (%u)!\n", in ice_vsi_setup_q_map_mqprio()
3391 new_txq, vsi->alloc_txq); in ice_vsi_setup_q_map_mqprio()
3396 if (new_rxq > vsi->alloc_rxq) { in ice_vsi_setup_q_map_mqprio()
3397 …dev_err(ice_pf_to_dev(vsi->back), "Trying to use more Rx queues (%u), than were allocated (%u)!\n", in ice_vsi_setup_q_map_mqprio()
3398 new_rxq, vsi->alloc_rxq); in ice_vsi_setup_q_map_mqprio()
3403 vsi->num_txq = new_txq; in ice_vsi_setup_q_map_mqprio()
3404 vsi->num_rxq = new_rxq; in ice_vsi_setup_q_map_mqprio()
3408 ctxt->info.q_mapping[0] = cpu_to_le16(vsi->rxq_map[0]); in ice_vsi_setup_q_map_mqprio()
3414 if (tc0_qcount && tc0_qcount < vsi->num_rxq) { in ice_vsi_setup_q_map_mqprio()
3415 vsi->cnt_q_avail = vsi->num_rxq - tc0_qcount; in ice_vsi_setup_q_map_mqprio()
3416 vsi->next_base_q = tc0_qcount; in ice_vsi_setup_q_map_mqprio()
3418 dev_dbg(ice_pf_to_dev(vsi->back), "vsi->num_txq = %d\n", vsi->num_txq); in ice_vsi_setup_q_map_mqprio()
3419 dev_dbg(ice_pf_to_dev(vsi->back), "vsi->num_rxq = %d\n", vsi->num_rxq); in ice_vsi_setup_q_map_mqprio()
3420 dev_dbg(ice_pf_to_dev(vsi->back), "all_numtc %u, all_enatc: 0x%04x, tc_cfg.numtc %u\n", in ice_vsi_setup_q_map_mqprio()
3421 vsi->all_numtc, vsi->all_enatc, vsi->tc_cfg.numtc); in ice_vsi_setup_q_map_mqprio()
3433 int ice_vsi_cfg_tc(struct ice_vsi *vsi, u8 ena_tc) in ice_vsi_cfg_tc() argument
3436 struct ice_pf *pf = vsi->back; in ice_vsi_cfg_tc()
3444 if (vsi->tc_cfg.ena_tc == ena_tc && in ice_vsi_cfg_tc()
3445 vsi->mqprio_qopt.mode != TC_MQPRIO_MODE_CHANNEL) in ice_vsi_cfg_tc()
3453 max_txqs[i] = vsi->alloc_txq; in ice_vsi_cfg_tc()
3457 if (vsi->type == ICE_VSI_CHNL && in ice_vsi_cfg_tc()
3459 max_txqs[i] = vsi->num_txq; in ice_vsi_cfg_tc()
3462 memcpy(&old_tc_cfg, &vsi->tc_cfg, sizeof(old_tc_cfg)); in ice_vsi_cfg_tc()
3463 vsi->tc_cfg.ena_tc = ena_tc; in ice_vsi_cfg_tc()
3464 vsi->tc_cfg.numtc = num_tc; in ice_vsi_cfg_tc()
3471 ctx->info = vsi->info; in ice_vsi_cfg_tc()
3473 if (vsi->type == ICE_VSI_PF && in ice_vsi_cfg_tc()
3475 ret = ice_vsi_setup_q_map_mqprio(vsi, ctx, ena_tc); in ice_vsi_cfg_tc()
3477 ret = ice_vsi_setup_q_map(vsi, ctx); in ice_vsi_cfg_tc()
3480 memcpy(&vsi->tc_cfg, &old_tc_cfg, sizeof(vsi->tc_cfg)); in ice_vsi_cfg_tc()
3486 ret = ice_update_vsi(&pf->hw, vsi->idx, ctx, NULL); in ice_vsi_cfg_tc()
3492 if (vsi->type == ICE_VSI_PF && in ice_vsi_cfg_tc()
3494 ret = ice_cfg_vsi_lan(vsi->port_info, vsi->idx, 1, max_txqs); in ice_vsi_cfg_tc()
3496 ret = ice_cfg_vsi_lan(vsi->port_info, vsi->idx, in ice_vsi_cfg_tc()
3497 vsi->tc_cfg.ena_tc, max_txqs); in ice_vsi_cfg_tc()
3501 vsi->vsi_num, ret); in ice_vsi_cfg_tc()
3504 ice_vsi_update_q_map(vsi, ctx); in ice_vsi_cfg_tc()
3505 vsi->info.valid_sections = 0; in ice_vsi_cfg_tc()
3507 ice_vsi_cfg_netdev_tc(vsi, ena_tc); in ice_vsi_cfg_tc()
3574 bool ice_is_vsi_dflt_vsi(struct ice_vsi *vsi) in ice_is_vsi_dflt_vsi() argument
3576 return ice_check_if_dflt_vsi(vsi->port_info, vsi->idx, NULL); in ice_is_vsi_dflt_vsi()
3589 int ice_set_dflt_vsi(struct ice_vsi *vsi) in ice_set_dflt_vsi() argument
3594 if (!vsi) in ice_set_dflt_vsi()
3597 dev = ice_pf_to_dev(vsi->back); in ice_set_dflt_vsi()
3599 if (ice_lag_is_switchdev_running(vsi->back)) { in ice_set_dflt_vsi()
3601 vsi->vsi_num); in ice_set_dflt_vsi()
3606 if (ice_is_vsi_dflt_vsi(vsi)) { in ice_set_dflt_vsi()
3608 vsi->vsi_num); in ice_set_dflt_vsi()
3612 status = ice_cfg_dflt_vsi(vsi->port_info, vsi->idx, true, ICE_FLTR_RX); in ice_set_dflt_vsi()
3615 vsi->vsi_num, status); in ice_set_dflt_vsi()
3630 int ice_clear_dflt_vsi(struct ice_vsi *vsi) in ice_clear_dflt_vsi() argument
3635 if (!vsi) in ice_clear_dflt_vsi()
3638 dev = ice_pf_to_dev(vsi->back); in ice_clear_dflt_vsi()
3641 if (!ice_is_dflt_vsi_in_use(vsi->port_info)) in ice_clear_dflt_vsi()
3644 status = ice_cfg_dflt_vsi(vsi->port_info, vsi->idx, false, in ice_clear_dflt_vsi()
3648 vsi->vsi_num, status); in ice_clear_dflt_vsi()
3661 int ice_get_link_speed_mbps(struct ice_vsi *vsi) in ice_get_link_speed_mbps() argument
3665 link_speed = vsi->port_info->phy.link_info.link_speed; in ice_get_link_speed_mbps()
3676 int ice_get_link_speed_kbps(struct ice_vsi *vsi) in ice_get_link_speed_kbps() argument
3680 speed_mbps = ice_get_link_speed_mbps(vsi); in ice_get_link_speed_kbps()
3694 int ice_set_min_bw_limit(struct ice_vsi *vsi, u64 min_tx_rate) in ice_set_min_bw_limit() argument
3696 struct ice_pf *pf = vsi->back; in ice_set_min_bw_limit()
3702 if (!vsi->port_info) { in ice_set_min_bw_limit()
3704 vsi->idx, vsi->type); in ice_set_min_bw_limit()
3708 speed = ice_get_link_speed_kbps(vsi); in ice_set_min_bw_limit()
3711 min_tx_rate, ice_vsi_type_str(vsi->type), vsi->idx, in ice_set_min_bw_limit()
3718 status = ice_cfg_vsi_bw_lmt_per_tc(vsi->port_info, vsi->idx, 0, in ice_set_min_bw_limit()
3722 min_tx_rate, ice_vsi_type_str(vsi->type), in ice_set_min_bw_limit()
3723 vsi->idx); in ice_set_min_bw_limit()
3728 min_tx_rate, ice_vsi_type_str(vsi->type)); in ice_set_min_bw_limit()
3730 status = ice_cfg_vsi_bw_dflt_lmt_per_tc(vsi->port_info, in ice_set_min_bw_limit()
3731 vsi->idx, 0, in ice_set_min_bw_limit()
3735 ice_vsi_type_str(vsi->type), vsi->idx); in ice_set_min_bw_limit()
3740 ice_vsi_type_str(vsi->type), vsi->idx); in ice_set_min_bw_limit()
3755 int ice_set_max_bw_limit(struct ice_vsi *vsi, u64 max_tx_rate) in ice_set_max_bw_limit() argument
3757 struct ice_pf *pf = vsi->back; in ice_set_max_bw_limit()
3763 if (!vsi->port_info) { in ice_set_max_bw_limit()
3765 vsi->idx, vsi->type); in ice_set_max_bw_limit()
3769 speed = ice_get_link_speed_kbps(vsi); in ice_set_max_bw_limit()
3772 max_tx_rate, ice_vsi_type_str(vsi->type), vsi->idx, in ice_set_max_bw_limit()
3779 status = ice_cfg_vsi_bw_lmt_per_tc(vsi->port_info, vsi->idx, 0, in ice_set_max_bw_limit()
3783 max_tx_rate, ice_vsi_type_str(vsi->type), in ice_set_max_bw_limit()
3784 vsi->idx); in ice_set_max_bw_limit()
3789 max_tx_rate, ice_vsi_type_str(vsi->type), vsi->idx); in ice_set_max_bw_limit()
3791 status = ice_cfg_vsi_bw_dflt_lmt_per_tc(vsi->port_info, in ice_set_max_bw_limit()
3792 vsi->idx, 0, in ice_set_max_bw_limit()
3796 ice_vsi_type_str(vsi->type), vsi->idx); in ice_set_max_bw_limit()
3801 ice_vsi_type_str(vsi->type), vsi->idx); in ice_set_max_bw_limit()
3812 int ice_set_link(struct ice_vsi *vsi, bool ena) in ice_set_link() argument
3814 struct device *dev = ice_pf_to_dev(vsi->back); in ice_set_link()
3815 struct ice_port_info *pi = vsi->port_info; in ice_set_link()
3819 if (vsi->type != ICE_VSI_PF) in ice_set_link()
3861 int ice_vsi_add_vlan_zero(struct ice_vsi *vsi) in ice_vsi_add_vlan_zero() argument
3863 struct ice_vsi_vlan_ops *vlan_ops = ice_get_compat_vsi_vlan_ops(vsi); in ice_vsi_add_vlan_zero()
3868 err = vlan_ops->add_vlan(vsi, &vlan); in ice_vsi_add_vlan_zero()
3873 if (!ice_is_dvm_ena(&vsi->back->hw)) in ice_vsi_add_vlan_zero()
3877 err = vlan_ops->add_vlan(vsi, &vlan); in ice_vsi_add_vlan_zero()
3891 int ice_vsi_del_vlan_zero(struct ice_vsi *vsi) in ice_vsi_del_vlan_zero() argument
3893 struct ice_vsi_vlan_ops *vlan_ops = ice_get_compat_vsi_vlan_ops(vsi); in ice_vsi_del_vlan_zero()
3898 err = vlan_ops->del_vlan(vsi, &vlan); in ice_vsi_del_vlan_zero()
3903 if (!ice_is_dvm_ena(&vsi->back->hw)) in ice_vsi_del_vlan_zero()
3907 err = vlan_ops->del_vlan(vsi, &vlan); in ice_vsi_del_vlan_zero()
3914 return ice_clear_vsi_promisc(&vsi->back->hw, vsi->idx, in ice_vsi_del_vlan_zero()
3925 static u16 ice_vsi_num_zero_vlans(struct ice_vsi *vsi) in ice_vsi_num_zero_vlans() argument
3930 if (vsi->type == ICE_VSI_VF) { in ice_vsi_num_zero_vlans()
3931 if (WARN_ON(!vsi->vf)) in ice_vsi_num_zero_vlans()
3934 if (ice_vf_is_port_vlan_ena(vsi->vf)) in ice_vsi_num_zero_vlans()
3938 if (ice_is_dvm_ena(&vsi->back->hw)) in ice_vsi_num_zero_vlans()
3948 bool ice_vsi_has_non_zero_vlans(struct ice_vsi *vsi) in ice_vsi_has_non_zero_vlans() argument
3950 return (vsi->num_vlan > ice_vsi_num_zero_vlans(vsi)); in ice_vsi_has_non_zero_vlans()
3957 u16 ice_vsi_num_non_zero_vlans(struct ice_vsi *vsi) in ice_vsi_num_non_zero_vlans() argument
3959 return (vsi->num_vlan - ice_vsi_num_zero_vlans(vsi)); in ice_vsi_num_non_zero_vlans()
4034 ice_vsi_update_security(struct ice_vsi *vsi, void (*fill)(struct ice_vsi_ctx *)) in ice_vsi_update_security() argument
4038 ctx.info = vsi->info; in ice_vsi_update_security()
4042 if (ice_update_vsi(&vsi->back->hw, vsi->idx, &ctx, NULL)) in ice_vsi_update_security()
4045 vsi->info = ctx.info; in ice_vsi_update_security()
4095 ice_vsi_update_local_lb(struct ice_vsi *vsi, bool set) in ice_vsi_update_local_lb() argument
4098 .info = vsi->info, in ice_vsi_update_local_lb()
4107 if (ice_update_vsi(&vsi->back->hw, vsi->idx, &ctx, NULL)) in ice_vsi_update_local_lb()
4110 vsi->info = ctx.info; in ice_vsi_update_local_lb()