Home
last modified time | relevance | path

Searched refs:ice_vsi (Results 1 – 25 of 51) sorted by relevance

123

/openbmc/linux/drivers/net/ethernet/intel/ice/
H A Dice_lib.h39 static inline struct ice_vsi_cfg_params ice_vsi_to_params(struct ice_vsi *vsi) in ice_vsi_to_params()
55 void ice_update_eth_stats(struct ice_vsi *vsi);
57 int ice_vsi_cfg_single_rxq(struct ice_vsi *vsi, u16 q_idx);
59 int ice_vsi_cfg_single_txq(struct ice_vsi *vsi, struct ice_tx_ring **tx_rings, u16 q_idx);
61 int ice_vsi_cfg_rxqs(struct ice_vsi *vsi);
63 int ice_vsi_cfg_lan_txqs(struct ice_vsi *vsi);
65 void ice_vsi_cfg_msix(struct ice_vsi *vsi);
67 int ice_vsi_start_all_rx_rings(struct ice_vsi *vsi);
69 int ice_vsi_stop_all_rx_rings(struct ice_vsi *vsi);
72 ice_vsi_stop_lan_tx_rings(struct ice_vsi *vsi, enum ice_disq_rst_src rst_src,
[all …]
H A Dice_vsi_vlan_lib.h16 struct ice_vsi;
18 int ice_vsi_add_vlan(struct ice_vsi *vsi, struct ice_vlan *vlan);
19 int ice_vsi_del_vlan(struct ice_vsi *vsi, struct ice_vlan *vlan);
21 int ice_vsi_ena_inner_stripping(struct ice_vsi *vsi, u16 tpid);
22 int ice_vsi_dis_inner_stripping(struct ice_vsi *vsi);
23 int ice_vsi_ena_inner_insertion(struct ice_vsi *vsi, u16 tpid);
24 int ice_vsi_dis_inner_insertion(struct ice_vsi *vsi);
25 int ice_vsi_set_inner_port_vlan(struct ice_vsi *vsi, struct ice_vlan *vlan);
26 int ice_vsi_clear_inner_port_vlan(struct ice_vsi *vsi);
28 int ice_vsi_ena_rx_vlan_filtering(struct ice_vsi *vsi);
[all …]
H A Dice_vsi_vlan_ops.h10 struct ice_vsi;
13 int (*add_vlan)(struct ice_vsi *vsi, struct ice_vlan *vlan);
14 int (*del_vlan)(struct ice_vsi *vsi, struct ice_vlan *vlan);
15 int (*ena_stripping)(struct ice_vsi *vsi, const u16 tpid);
16 int (*dis_stripping)(struct ice_vsi *vsi);
17 int (*ena_insertion)(struct ice_vsi *vsi, const u16 tpid);
18 int (*dis_insertion)(struct ice_vsi *vsi);
19 int (*ena_rx_filtering)(struct ice_vsi *vsi);
20 int (*dis_rx_filtering)(struct ice_vsi *vsi);
21 int (*ena_tx_filtering)(struct ice_vsi *vsi);
[all …]
H A Dice_fltr.h11 ice_fltr_set_vlan_vsi_promisc(struct ice_hw *hw, struct ice_vsi *vsi,
14 ice_fltr_clear_vlan_vsi_promisc(struct ice_hw *hw, struct ice_vsi *vsi,
23 ice_fltr_add_mac_to_list(struct ice_vsi *vsi, struct list_head *list,
26 ice_fltr_add_mac(struct ice_vsi *vsi, const u8 *mac,
29 ice_fltr_add_mac_and_broadcast(struct ice_vsi *vsi, const u8 *mac,
31 int ice_fltr_add_mac_list(struct ice_vsi *vsi, struct list_head *list);
33 ice_fltr_remove_mac(struct ice_vsi *vsi, const u8 *mac,
35 int ice_fltr_remove_mac_list(struct ice_vsi *vsi, struct list_head *list);
37 int ice_fltr_add_vlan(struct ice_vsi *vsi, struct ice_vlan *vlan);
38 int ice_fltr_remove_vlan(struct ice_vsi *vsi, struct ice_vlan *vlan);
[all …]
H A Dice_fltr.c58 ice_fltr_set_vlan_vsi_promisc(struct ice_hw *hw, struct ice_vsi *vsi, in ice_fltr_set_vlan_vsi_promisc()
82 ice_fltr_clear_vlan_vsi_promisc(struct ice_hw *hw, struct ice_vsi *vsi, in ice_fltr_clear_vlan_vsi_promisc()
148 int ice_fltr_add_mac_list(struct ice_vsi *vsi, struct list_head *list) in ice_fltr_add_mac_list()
158 int ice_fltr_remove_mac_list(struct ice_vsi *vsi, struct list_head *list) in ice_fltr_remove_mac_list()
168 static int ice_fltr_add_vlan_list(struct ice_vsi *vsi, struct list_head *list) in ice_fltr_add_vlan_list()
179 ice_fltr_remove_vlan_list(struct ice_vsi *vsi, struct list_head *list) in ice_fltr_remove_vlan_list()
189 static int ice_fltr_add_eth_list(struct ice_vsi *vsi, struct list_head *list) in ice_fltr_add_eth_list()
199 static int ice_fltr_remove_eth_list(struct ice_vsi *vsi, struct list_head *list) in ice_fltr_remove_eth_list()
208 void ice_fltr_remove_all(struct ice_vsi *vsi) in ice_fltr_remove_all()
226 ice_fltr_add_mac_to_list(struct ice_vsi *vsi, struct list_head *list, in ice_fltr_add_mac_to_list()
[all …]
H A Dice_vf_vsi_vlan_ops.h9 struct ice_vsi;
11 void ice_vf_vsi_cfg_dvm_legacy_vlan_mode(struct ice_vsi *vsi);
12 void ice_vf_vsi_cfg_svm_legacy_vlan_mode(struct ice_vsi *vsi);
15 void ice_vf_vsi_init_vlan_ops(struct ice_vsi *vsi);
16 void ice_vf_vsi_enable_port_vlan(struct ice_vsi *vsi);
17 void ice_vf_vsi_disable_port_vlan(struct ice_vsi *vsi);
19 static inline void ice_vf_vsi_init_vlan_ops(struct ice_vsi *vsi) { } in ice_vf_vsi_init_vlan_ops()
20 static inline void ice_vf_vsi_enable_port_vlan(struct ice_vsi *vsi) { } in ice_vf_vsi_enable_port_vlan()
21 static inline void ice_vf_vsi_disable_port_vlan(struct ice_vsi *vsi) { } in ice_vf_vsi_disable_port_vlan()
H A Dice_base.h12 ice_vsi_ctrl_one_rx_ring(struct ice_vsi *vsi, bool ena, u16 rxq_idx, bool wait);
13 int ice_vsi_wait_one_rx_ring(struct ice_vsi *vsi, bool ena, u16 rxq_idx);
14 int ice_vsi_alloc_q_vectors(struct ice_vsi *vsi);
15 void ice_vsi_map_rings_to_vectors(struct ice_vsi *vsi);
16 void ice_vsi_free_q_vectors(struct ice_vsi *vsi);
18 ice_vsi_cfg_txq(struct ice_vsi *vsi, struct ice_tx_ring *ring,
22 ice_cfg_txq_interrupt(struct ice_vsi *vsi, u16 txq, u16 msix_idx, u16 itr_idx);
24 ice_cfg_rxq_interrupt(struct ice_vsi *vsi, u16 rxq, u16 msix_idx, u16 itr_idx);
27 ice_vsi_stop_tx_ring(struct ice_vsi *vsi, enum ice_disq_rst_src rst_src,
31 ice_fill_txq_meta(struct ice_vsi *vsi, struct ice_tx_ring *ring,
H A Dice.h224 struct ice_vsi *ch_vsi;
327 struct ice_vsi {
421 struct ice_vsi *tc_map_vsi[ICE_CHNL_MAX_TC]; argument
455 struct ice_vsi *vsi;
523 struct ice_vsi *control_vsi;
524 struct ice_vsi *uplink_vsi;
557 struct ice_vsi **vsi; /* VSIs created by the driver */
650 struct ice_vsi *vsi;
679 ice_irq_dynamic_ena(struct ice_hw *hw, struct ice_vsi *vsi, in ice_irq_dynamic_ena()
709 static inline bool ice_is_xdp_ena_vsi(struct ice_vsi *vs in ice_is_xdp_ena_vsi()
326 struct ice_vsi { global() struct
348 typeice_vsi global() argument
349 vsi_numice_vsi global() argument
350 idxice_vsi global() argument
352 vfice_vsi global() argument
376 vlan_infoice_vsi global() argument
390 inner_vlan_opsice_vsi global() argument
391 outer_vlan_opsice_vsi global() argument
392 num_vlanice_vsi global() argument
395 tx_mapping_modeice_vsi global() argument
396 rx_mapping_modeice_vsi global() argument
420 tc_map_vsiice_vsi global() argument
422 next_base_qice_vsi global() argument
423 ch_listice_vsi global() argument
424 num_chnl_rxqice_vsi global() argument
425 num_chnl_txqice_vsi global() argument
426 ch_rss_sizeice_vsi global() argument
427 num_chnl_fltrice_vsi global() argument
454 agg_nodeice_vsi global() argument
[all...]
H A Dice_arfs.h47 void ice_clear_arfs(struct ice_vsi *vsi);
48 void ice_free_cpu_rx_rmap(struct ice_vsi *vsi);
49 void ice_init_arfs(struct ice_vsi *vsi);
51 int ice_set_cpu_rx_rmap(struct ice_vsi *vsi);
58 static inline void ice_clear_arfs(struct ice_vsi *vsi) { } in ice_clear_arfs()
59 static inline void ice_free_cpu_rx_rmap(struct ice_vsi *vsi) { } in ice_free_cpu_rx_rmap()
60 static inline void ice_init_arfs(struct ice_vsi *vsi) { } in ice_init_arfs()
65 static inline int ice_set_cpu_rx_rmap(struct ice_vsi __always_unused *vsi) in ice_set_cpu_rx_rmap()
H A Dice_xsk.h18 struct ice_vsi;
21 int ice_xsk_pool_setup(struct ice_vsi *vsi, struct xsk_buff_pool *pool,
26 bool ice_xsk_any_rx_ring_ena(struct ice_vsi *vsi);
30 int ice_realloc_zc_buf(struct ice_vsi *vsi, bool zc);
38 ice_xsk_pool_setup(struct ice_vsi __always_unused *vsi, in ice_xsk_pool_setup()
59 static inline bool ice_xsk_any_rx_ring_ena(struct ice_vsi __always_unused *vsi) in ice_xsk_any_rx_ring_ena()
75 ice_realloc_zc_buf(struct ice_vsi __always_unused *vsi, in ice_realloc_zc_buf()
H A Dice_vsi_vlan_lib.c9 static void print_invalid_tpid(struct ice_vsi *vsi, u16 tpid) in print_invalid_tpid()
24 static bool validate_vlan(struct ice_vsi *vsi, struct ice_vlan *vlan) in validate_vlan()
40 int ice_vsi_add_vlan(struct ice_vsi *vsi, struct ice_vlan *vlan) in ice_vsi_add_vlan()
64 int ice_vsi_del_vlan(struct ice_vsi *vsi, struct ice_vlan *vlan) in ice_vsi_del_vlan()
91 static int ice_vsi_manage_vlan_insertion(struct ice_vsi *vsi) in ice_vsi_manage_vlan_insertion()
131 static int ice_vsi_manage_vlan_stripping(struct ice_vsi *vsi, bool ena) in ice_vsi_manage_vlan_stripping()
182 int ice_vsi_ena_inner_stripping(struct ice_vsi *vsi, const u16 tpid) in ice_vsi_ena_inner_stripping()
192 int ice_vsi_dis_inner_stripping(struct ice_vsi *vsi) in ice_vsi_dis_inner_stripping()
197 int ice_vsi_ena_inner_insertion(struct ice_vsi *vsi, const u16 tpid) in ice_vsi_ena_inner_insertion()
207 int ice_vsi_dis_inner_insertion(struct ice_vsi *vsi) in ice_vsi_dis_inner_insertion()
[all …]
H A Dice_vf_lib.h215 struct ice_vsi *ice_get_vf_vsi(struct ice_vf *vf);
221 ice_vf_get_promisc_masks(struct ice_vf *vf, struct ice_vsi *vsi,
224 ice_vf_set_vsi_promisc(struct ice_vf *vf, struct ice_vsi *vsi, u8 promisc_m);
226 ice_vf_clear_vsi_promisc(struct ice_vf *vf, struct ice_vsi *vsi, u8 promisc_m);
229 struct ice_vsi *ice_get_vf_ctrl_vsi(struct ice_pf *pf, struct ice_vsi *vsi);
250 static inline struct ice_vsi *ice_get_vf_vsi(struct ice_vf *vf) in ice_get_vf_vsi()
275 ice_vf_set_vsi_promisc(struct ice_vf *vf, struct ice_vsi *vsi, u8 promisc_m) in ice_vf_set_vsi_promisc()
281 ice_vf_clear_vsi_promisc(struct ice_vf *vf, struct ice_vsi *vsi, u8 promisc_m) in ice_vf_clear_vsi_promisc()
295 static inline struct ice_vsi *
296 ice_get_vf_ctrl_vsi(struct ice_pf *pf, struct ice_vsi *vsi) in ice_get_vf_ctrl_vsi()
H A Dice_vsi_vlan_ops.c10 op_unsupported_vlan_arg(struct ice_vsi * __always_unused vsi, in op_unsupported_vlan_arg()
17 op_unsupported_tpid_arg(struct ice_vsi *__always_unused vsi, in op_unsupported_tpid_arg()
23 static int op_unsupported(struct ice_vsi *__always_unused vsi) in op_unsupported()
54 static void ice_vsi_init_unsupported_vlan_ops(struct ice_vsi *vsi) in ice_vsi_init_unsupported_vlan_ops()
68 void ice_vsi_init_vlan_ops(struct ice_vsi *vsi) in ice_vsi_init_vlan_ops()
97 struct ice_vsi_vlan_ops *ice_get_compat_vsi_vlan_ops(struct ice_vsi *vsi) in ice_get_compat_vsi_vlan_ops()
H A Dice_vf_vsi_vlan_ops.c12 noop_vlan_arg(struct ice_vsi __always_unused *vsi, in noop_vlan_arg()
19 noop_vlan(struct ice_vsi __always_unused *vsi) in noop_vlan()
24 static void ice_port_vlan_on(struct ice_vsi *vsi) in ice_port_vlan_on()
57 static void ice_port_vlan_off(struct ice_vsi *vsi) in ice_port_vlan_off()
98 void ice_vf_vsi_enable_port_vlan(struct ice_vsi *vsi) in ice_vf_vsi_enable_port_vlan()
113 void ice_vf_vsi_disable_port_vlan(struct ice_vsi *vsi) in ice_vf_vsi_disable_port_vlan()
130 void ice_vf_vsi_init_vlan_ops(struct ice_vsi *vsi) in ice_vf_vsi_init_vlan_ops()
165 void ice_vf_vsi_cfg_dvm_legacy_vlan_mode(struct ice_vsi *vsi) in ice_vf_vsi_cfg_dvm_legacy_vlan_mode()
236 void ice_vf_vsi_cfg_svm_legacy_vlan_mode(struct ice_vsi *vsi) in ice_vf_vsi_cfg_svm_legacy_vlan_mode()
H A Dice_lib.c47 static int ice_vsi_ctrl_all_rx_rings(struct ice_vsi *vsi, bool ena) in ice_vsi_ctrl_all_rx_rings()
73 static int ice_vsi_alloc_arrays(struct ice_vsi *vsi) in ice_vsi_alloc_arrays()
137 static void ice_vsi_set_num_desc(struct ice_vsi *vsi) in ice_vsi_set_num_desc()
166 static void ice_vsi_set_num_qs(struct ice_vsi *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()
311 static void ice_vsi_free_arrays(struct ice_vsi *vsi) in ice_vsi_free_arrays()
335 static void ice_vsi_free_stats(struct ice_vsi *vsi) in ice_vsi_free_stats()
374 static int ice_vsi_alloc_ring_stats(struct ice_vsi *vsi) in ice_vsi_alloc_ring_stats()
438 static void ice_vsi_free(struct ice_vsi *vsi) in ice_vsi_free()
467 void ice_vsi_delete(struct ice_vsi *vs
[all...]
H A Dice_arfs.c10 static bool ice_is_arfs_active(struct ice_vsi *vsi) in ice_is_arfs_active()
28 struct ice_vsi *vsi; in ice_is_arfs_using_perfect_flow()
59 ice_arfs_update_active_fltr_cntrs(struct ice_vsi *vsi, in ice_arfs_update_active_fltr_cntrs()
105 ice_arfs_del_flow_rules(struct ice_vsi *vsi, struct hlist_head *del_list_head) in ice_arfs_del_flow_rules()
142 ice_arfs_add_flow_rules(struct ice_vsi *vsi, struct hlist_head *add_list_head) in ice_arfs_add_flow_rules()
181 ice_arfs_is_flow_expired(struct ice_vsi *vsi, struct ice_arfs_entry *arfs_entry) in ice_arfs_is_flow_expired()
214 ice_arfs_update_flow_rules(struct ice_vsi *vsi, u16 idx, in ice_arfs_update_flow_rules()
266 struct ice_vsi *pf_vsi; in ice_sync_arfs_fltrs()
300 ice_arfs_build_entry(struct ice_vsi *vsi, const struct flow_keys *fk, in ice_arfs_build_entry()
401 struct ice_vsi *vsi = np->vsi; in ice_rx_flow_steer()
[all …]
H A Dice_vf_lib.c121 struct ice_vsi *ice_get_vf_vsi(struct ice_vf *vf) in ice_get_vf_vsi()
221 struct ice_vsi *vsi = ice_get_vf_vsi(vf); in ice_vf_clear_counters()
286 struct ice_vsi *vsi = ice_get_vf_vsi(vf); in ice_vf_rebuild_vsi()
314 static int ice_vf_rebuild_host_vlan_cfg(struct ice_vf *vf, struct ice_vsi *vsi) in ice_vf_rebuild_host_vlan_cfg()
358 struct ice_vsi *vsi = ice_get_vf_vsi(vf); in ice_vf_rebuild_host_tx_rate_cfg()
404 struct ice_vsi *vsi = ice_get_vf_vsi(vf); in ice_vf_rebuild_host_mac_cfg()
448 static void ice_vf_rebuild_aggregator_node_cfg(struct ice_vsi *vsi) in ice_vf_rebuild_aggregator_node_cfg()
481 struct ice_vsi *vsi = ice_get_vf_vsi(vf); in ice_vf_rebuild_host_cfg()
590 ice_vf_get_promisc_masks(struct ice_vf *vf, struct ice_vsi *vsi, in ice_vf_get_promisc_masks()
611 ice_vf_clear_all_promisc_modes(struct ice_vf *vf, struct ice_vsi *vs
[all...]
H A Dice_dcb_nl.h8 void ice_dcbnl_setup(struct ice_vsi *vsi);
9 void ice_dcbnl_set_all(struct ice_vsi *vsi);
14 static inline void ice_dcbnl_setup(struct ice_vsi *vsi) { } in ice_dcbnl_setup()
15 static inline void ice_dcbnl_set_all(struct ice_vsi *vsi) { } in ice_dcbnl_set_all()
H A Dice_dcb_lib.h20 void ice_vsi_set_dcb_tc_cfg(struct ice_vsi *vsi);
22 u8 ice_dcb_get_tc(struct ice_vsi *vsi, int queue_index);
27 void ice_vsi_cfg_dcb_rings(struct ice_vsi *vsi);
69 static inline void ice_vsi_set_dcb_tc_cfg(struct ice_vsi *vsi) in ice_vsi_set_dcb_tc_cfg()
86 ice_dcb_get_tc(struct ice_vsi __always_unused *vsi, in ice_dcb_get_tc()
132 static inline void ice_vsi_cfg_dcb_rings(struct ice_vsi *vsi) { } in ice_vsi_cfg_dcb_rings()
H A Dice_eswitch.c24 struct ice_vsi *ctrl_vsi = pf->eswitch.control_vsi; in ice_eswitch_add_vf_sp_rule()
81 struct ice_vsi *uplink_vsi = pf->eswitch.uplink_vsi; in ice_eswitch_setup_env()
82 struct ice_vsi *ctrl_vsi = pf->eswitch.control_vsi; in ice_eswitch_setup_env()
147 struct ice_vsi *vsi = pf->eswitch.control_vsi; in ice_eswitch_remap_rings_to_vectors()
195 ice_eswitch_release_reprs(struct ice_pf *pf, struct ice_vsi *ctrl_vsi) in ice_eswitch_release_reprs()
203 struct ice_vsi *vsi = vf->repr->src_vsi; in ice_eswitch_release_reprs()
226 struct ice_vsi *ctrl_vsi = pf->eswitch.control_vsi; in ice_eswitch_setup_reprs()
234 struct ice_vsi *vsi = vf->repr->src_vsi; in ice_eswitch_setup_reprs()
281 struct ice_vsi *vsi = repr->src_vsi; in ice_eswitch_setup_reprs()
302 void ice_eswitch_update_repr(struct ice_vsi *vsi) in ice_eswitch_update_repr()
[all …]
H A Dice_tc_lib.h153 struct ice_vsi *dest_vsi;
160 struct ice_vsi *src_vsi;
207 struct ice_vsi *ice_locate_vsi_using_queue(struct ice_vsi *vsi, int queue);
209 ice_add_cls_flower(struct net_device *netdev, struct ice_vsi *vsi,
212 ice_del_cls_flower(struct ice_vsi *vsi, struct flow_cls_offload *cls_flower);
H A Dice_vf_lib_private.h32 int ice_vsi_apply_spoofchk(struct ice_vsi *vsi, bool enable);
38 struct ice_vsi *ice_vf_ctrl_vsi_setup(struct ice_vf *vf);
39 int ice_vf_init_host_cfg(struct ice_vf *vf, struct ice_vsi *vsi);
H A Dice_base.c102 static int ice_vsi_alloc_q_vector(struct ice_vsi *vsi, u16 v_idx) in ice_vsi_alloc_q_vector()
127 struct ice_vsi *ctrl_vsi = ice_get_vf_ctrl_vsi(pf, vsi); in ice_vsi_alloc_q_vector()
177 static void ice_free_q_vector(struct ice_vsi *vsi, int v_idx) in ice_free_q_vector()
254 static u16 ice_calc_txq_handle(struct ice_vsi *vsi, struct ice_tx_ring *ring, u8 tc) in ice_calc_txq_handle()
281 struct ice_vsi *vsi = ring->vsi; in ice_eswitch_calc_txq_handle()
323 struct ice_vsi *vsi = ring->vsi; in ice_setup_tx_ctx()
411 struct ice_vsi *vsi = ring->vsi; in ice_setup_rx_ctx()
674 ice_vsi_ctrl_one_rx_ring(struct ice_vsi *vsi, bool ena, u16 rxq_idx, bool wait) in ice_vsi_ctrl_one_rx_ring()
712 int ice_vsi_wait_one_rx_ring(struct ice_vsi *vsi, bool ena, u16 rxq_idx) in ice_vsi_wait_one_rx_ring()
727 int ice_vsi_alloc_q_vectors(struct ice_vsi *vsi) in ice_vsi_alloc_q_vectors()
[all …]
H A Dice_virtchnl_fdir.h9 struct ice_vsi;
49 ice_vc_fdir_irq_handler(struct ice_vsi *ctrl_vsi,
54 ice_vc_fdir_irq_handler(struct ice_vsi *ctrl_vsi, union ice_32b_rx_flex_desc *rx_desc) { } in ice_vc_fdir_irq_handler()
H A Dice_main.c77 static void ice_remove_q_channels(struct ice_vsi *vsi, bool rem_adv_fltr);
114 struct ice_vsi *vsi = NULL; in ice_check_for_hang_subtask()
182 struct ice_vsi *vsi; in ice_init_mac_fltr()
206 struct ice_vsi *vsi = np->vsi; in ice_add_mac_to_sync_list()
228 struct ice_vsi *vsi = np->vsi; in ice_add_mac_to_unsync_list()
251 static bool ice_vsi_fltr_changed(struct ice_vsi *vsi) in ice_vsi_fltr_changed()
263 static int ice_set_promisc(struct ice_vsi *vsi, u8 promisc_m) in ice_set_promisc()
292 static int ice_clear_promisc(struct ice_vsi *vsi, u8 promisc_m) in ice_clear_promisc()
319 static int ice_vsi_sync_fltr(struct ice_vsi *vsi) in ice_vsi_sync_fltr()
532 struct ice_vsi *vs in ice_prepare_for_reset()
[all...]

123