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 enum ice_status 22 ice_add_prof(struct ice_hw *hw, enum ice_block blk, u64 id, u8 ptypes[], 23 struct ice_fv_word *es); 24 enum ice_status 25 ice_add_prof_id_flow(struct ice_hw *hw, enum ice_block blk, u16 vsi, u64 hdl); 26 enum ice_status 27 ice_rem_prof_id_flow(struct ice_hw *hw, enum ice_block blk, u16 vsi, u64 hdl); 28 enum ice_status ice_init_pkg(struct ice_hw *hw, u8 *buff, u32 len); 29 enum ice_status 30 ice_copy_and_init_pkg(struct ice_hw *hw, const u8 *buf, u32 len); 31 enum ice_status ice_init_hw_tbls(struct ice_hw *hw); 32 void ice_free_seg(struct ice_hw *hw); 33 void ice_fill_blk_tbls(struct ice_hw *hw); 34 void ice_clear_hw_tbls(struct ice_hw *hw); 35 void ice_free_hw_tbls(struct ice_hw *hw); 36 enum ice_status 37 ice_rem_prof(struct ice_hw *hw, enum ice_block blk, u64 id); 38 #endif /* _ICE_FLEX_PIPE_H_ */ 39