1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun /* Copyright (c) 2018, Intel Corporation. */ 3*4882a593Smuzhiyun 4*4882a593Smuzhiyun #ifndef _ICE_LIB_H_ 5*4882a593Smuzhiyun #define _ICE_LIB_H_ 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun #include "ice.h" 8*4882a593Smuzhiyun 9*4882a593Smuzhiyun const char *ice_vsi_type_str(enum ice_vsi_type vsi_type); 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun bool ice_pf_state_is_nominal(struct ice_pf *pf); 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun void ice_update_eth_stats(struct ice_vsi *vsi); 14*4882a593Smuzhiyun 15*4882a593Smuzhiyun int ice_vsi_cfg_rxqs(struct ice_vsi *vsi); 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun int ice_vsi_cfg_lan_txqs(struct ice_vsi *vsi); 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun void ice_vsi_cfg_msix(struct ice_vsi *vsi); 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun int 22*4882a593Smuzhiyun ice_vsi_add_vlan(struct ice_vsi *vsi, u16 vid, enum ice_sw_fwd_act_type action); 23*4882a593Smuzhiyun 24*4882a593Smuzhiyun int ice_vsi_kill_vlan(struct ice_vsi *vsi, u16 vid); 25*4882a593Smuzhiyun 26*4882a593Smuzhiyun int ice_vsi_manage_vlan_insertion(struct ice_vsi *vsi); 27*4882a593Smuzhiyun 28*4882a593Smuzhiyun int ice_vsi_manage_vlan_stripping(struct ice_vsi *vsi, bool ena); 29*4882a593Smuzhiyun 30*4882a593Smuzhiyun int ice_vsi_start_all_rx_rings(struct ice_vsi *vsi); 31*4882a593Smuzhiyun 32*4882a593Smuzhiyun int ice_vsi_stop_all_rx_rings(struct ice_vsi *vsi); 33*4882a593Smuzhiyun 34*4882a593Smuzhiyun int 35*4882a593Smuzhiyun ice_vsi_stop_lan_tx_rings(struct ice_vsi *vsi, enum ice_disq_rst_src rst_src, 36*4882a593Smuzhiyun u16 rel_vmvf_num); 37*4882a593Smuzhiyun 38*4882a593Smuzhiyun int ice_vsi_cfg_xdp_txqs(struct ice_vsi *vsi); 39*4882a593Smuzhiyun 40*4882a593Smuzhiyun int ice_vsi_stop_xdp_tx_rings(struct ice_vsi *vsi); 41*4882a593Smuzhiyun 42*4882a593Smuzhiyun bool ice_vsi_is_vlan_pruning_ena(struct ice_vsi *vsi); 43*4882a593Smuzhiyun 44*4882a593Smuzhiyun int ice_cfg_vlan_pruning(struct ice_vsi *vsi, bool ena, bool vlan_promisc); 45*4882a593Smuzhiyun 46*4882a593Smuzhiyun void ice_cfg_sw_lldp(struct ice_vsi *vsi, bool tx, bool create); 47*4882a593Smuzhiyun 48*4882a593Smuzhiyun #ifdef CONFIG_DCB 49*4882a593Smuzhiyun int ice_vsi_cfg_tc(struct ice_vsi *vsi, u8 ena_tc); 50*4882a593Smuzhiyun #endif /* CONFIG_DCB */ 51*4882a593Smuzhiyun 52*4882a593Smuzhiyun struct ice_vsi * 53*4882a593Smuzhiyun ice_vsi_setup(struct ice_pf *pf, struct ice_port_info *pi, 54*4882a593Smuzhiyun enum ice_vsi_type vsi_type, u16 vf_id); 55*4882a593Smuzhiyun 56*4882a593Smuzhiyun void ice_napi_del(struct ice_vsi *vsi); 57*4882a593Smuzhiyun 58*4882a593Smuzhiyun int ice_vsi_release(struct ice_vsi *vsi); 59*4882a593Smuzhiyun 60*4882a593Smuzhiyun void ice_vsi_close(struct ice_vsi *vsi); 61*4882a593Smuzhiyun 62*4882a593Smuzhiyun int ice_ena_vsi(struct ice_vsi *vsi, bool locked); 63*4882a593Smuzhiyun 64*4882a593Smuzhiyun void ice_dis_vsi(struct ice_vsi *vsi, bool locked); 65*4882a593Smuzhiyun 66*4882a593Smuzhiyun int ice_free_res(struct ice_res_tracker *res, u16 index, u16 id); 67*4882a593Smuzhiyun 68*4882a593Smuzhiyun int 69*4882a593Smuzhiyun ice_get_res(struct ice_pf *pf, struct ice_res_tracker *res, u16 needed, u16 id); 70*4882a593Smuzhiyun 71*4882a593Smuzhiyun int ice_vsi_rebuild(struct ice_vsi *vsi, bool init_vsi); 72*4882a593Smuzhiyun 73*4882a593Smuzhiyun bool ice_is_reset_in_progress(unsigned long *state); 74*4882a593Smuzhiyun 75*4882a593Smuzhiyun void 76*4882a593Smuzhiyun ice_write_qrxflxp_cntxt(struct ice_hw *hw, u16 pf_q, u32 rxdid, u32 prio); 77*4882a593Smuzhiyun 78*4882a593Smuzhiyun void ice_vsi_dis_irq(struct ice_vsi *vsi); 79*4882a593Smuzhiyun 80*4882a593Smuzhiyun void ice_vsi_free_irq(struct ice_vsi *vsi); 81*4882a593Smuzhiyun 82*4882a593Smuzhiyun void ice_vsi_free_rx_rings(struct ice_vsi *vsi); 83*4882a593Smuzhiyun 84*4882a593Smuzhiyun void ice_vsi_free_tx_rings(struct ice_vsi *vsi); 85*4882a593Smuzhiyun 86*4882a593Smuzhiyun int ice_vsi_manage_rss_lut(struct ice_vsi *vsi, bool ena); 87*4882a593Smuzhiyun 88*4882a593Smuzhiyun void ice_update_tx_ring_stats(struct ice_ring *ring, u64 pkts, u64 bytes); 89*4882a593Smuzhiyun 90*4882a593Smuzhiyun void ice_update_rx_ring_stats(struct ice_ring *ring, u64 pkts, u64 bytes); 91*4882a593Smuzhiyun 92*4882a593Smuzhiyun void ice_vsi_cfg_frame_size(struct ice_vsi *vsi); 93*4882a593Smuzhiyun 94*4882a593Smuzhiyun int ice_status_to_errno(enum ice_status err); 95*4882a593Smuzhiyun 96*4882a593Smuzhiyun u32 ice_intrl_usec_to_reg(u8 intrl, u8 gran); 97*4882a593Smuzhiyun 98*4882a593Smuzhiyun enum ice_status 99*4882a593Smuzhiyun ice_vsi_cfg_mac_fltr(struct ice_vsi *vsi, const u8 *macaddr, bool set); 100*4882a593Smuzhiyun 101*4882a593Smuzhiyun bool ice_is_safe_mode(struct ice_pf *pf); 102*4882a593Smuzhiyun 103*4882a593Smuzhiyun bool ice_is_dflt_vsi_in_use(struct ice_sw *sw); 104*4882a593Smuzhiyun 105*4882a593Smuzhiyun bool ice_is_vsi_dflt_vsi(struct ice_sw *sw, struct ice_vsi *vsi); 106*4882a593Smuzhiyun 107*4882a593Smuzhiyun int ice_set_dflt_vsi(struct ice_sw *sw, struct ice_vsi *vsi); 108*4882a593Smuzhiyun 109*4882a593Smuzhiyun int ice_clear_dflt_vsi(struct ice_sw *sw); 110*4882a593Smuzhiyun #endif /* !_ICE_LIB_H_ */ 111