1 /* SPDX-License-Identifier: GPL-2.0 */ 2 /* Copyright (c) 2019, Intel Corporation. */ 3 4 #ifndef _ICE_FLEX_PIPE_H_ 5 #define _ICE_FLEX_PIPE_H_ 6 7 #include "ice_type.h" 8 9 /* Package minimal version supported */ 10 #define ICE_PKG_SUPP_VER_MAJ 1 11 #define ICE_PKG_SUPP_VER_MNR 3 12 13 /* Package format version */ 14 #define ICE_PKG_FMT_VER_MAJ 1 15 #define ICE_PKG_FMT_VER_MNR 0 16 #define ICE_PKG_FMT_VER_UPD 0 17 #define ICE_PKG_FMT_VER_DFT 0 18 19 #define ICE_PKG_CNT 4 20 21 void 22 ice_get_sw_fv_bitmap(struct ice_hw *hw, enum ice_prof_type type, 23 unsigned long *bm); 24 void 25 ice_init_prof_result_bm(struct ice_hw *hw); 26 enum ice_status 27 ice_get_sw_fv_list(struct ice_hw *hw, u8 *prot_ids, u16 ids_cnt, 28 unsigned long *bm, struct list_head *fv_list); 29 bool 30 ice_get_open_tunnel_port(struct ice_hw *hw, u16 *port); 31 int ice_udp_tunnel_set_port(struct net_device *netdev, unsigned int table, 32 unsigned int idx, struct udp_tunnel_info *ti); 33 int ice_udp_tunnel_unset_port(struct net_device *netdev, unsigned int table, 34 unsigned int idx, struct udp_tunnel_info *ti); 35 36 enum ice_status 37 ice_add_prof(struct ice_hw *hw, enum ice_block blk, u64 id, u8 ptypes[], 38 const struct ice_ptype_attributes *attr, u16 attr_cnt, 39 struct ice_fv_word *es, u16 *masks); 40 enum ice_status 41 ice_add_prof_id_flow(struct ice_hw *hw, enum ice_block blk, u16 vsi, u64 hdl); 42 enum ice_status 43 ice_rem_prof_id_flow(struct ice_hw *hw, enum ice_block blk, u16 vsi, u64 hdl); 44 enum ice_status ice_init_pkg(struct ice_hw *hw, u8 *buff, u32 len); 45 enum ice_status 46 ice_copy_and_init_pkg(struct ice_hw *hw, const u8 *buf, u32 len); 47 enum ice_status ice_init_hw_tbls(struct ice_hw *hw); 48 void ice_free_seg(struct ice_hw *hw); 49 void ice_fill_blk_tbls(struct ice_hw *hw); 50 void ice_clear_hw_tbls(struct ice_hw *hw); 51 void ice_free_hw_tbls(struct ice_hw *hw); 52 enum ice_status 53 ice_rem_prof(struct ice_hw *hw, enum ice_block blk, u64 id); 54 #endif /* _ICE_FLEX_PIPE_H_ */ 55