| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* Copyright (c) 2019, Intel Corporation. */ |
| |
| #ifndef _ICE_FLEX_PIPE_H_ |
| #define _ICE_FLEX_PIPE_H_ |
| |
| #include "ice_type.h" |
| |
| /* Package minimal version supported */ |
| #define ICE_PKG_SUPP_VER_MAJ 1 |
| #define ICE_PKG_SUPP_VER_MNR 3 |
| |
| /* Package format version */ |
| #define ICE_PKG_FMT_VER_MAJ 1 |
| #define ICE_PKG_FMT_VER_MNR 0 |
| #define ICE_PKG_FMT_VER_UPD 0 |
| #define ICE_PKG_FMT_VER_DFT 0 |
| |
| #define ICE_PKG_CNT 4 |
| |
| bool |
| ice_get_open_tunnel_port(struct ice_hw *hw, enum ice_tunnel_type type, |
| u16 *port); |
| enum ice_status |
| ice_create_tunnel(struct ice_hw *hw, enum ice_tunnel_type type, u16 port); |
| enum ice_status ice_destroy_tunnel(struct ice_hw *hw, u16 port, bool all); |
| bool ice_tunnel_port_in_use(struct ice_hw *hw, u16 port, u16 *index); |
| |
| enum ice_status |
| ice_add_prof(struct ice_hw *hw, enum ice_block blk, u64 id, u8 ptypes[], |
| struct ice_fv_word *es); |
| enum ice_status |
| ice_add_prof_id_flow(struct ice_hw *hw, enum ice_block blk, u16 vsi, u64 hdl); |
| enum ice_status |
| ice_rem_prof_id_flow(struct ice_hw *hw, enum ice_block blk, u16 vsi, u64 hdl); |
| enum ice_status ice_init_pkg(struct ice_hw *hw, u8 *buff, u32 len); |
| enum ice_status |
| ice_copy_and_init_pkg(struct ice_hw *hw, const u8 *buf, u32 len); |
| enum ice_status ice_init_hw_tbls(struct ice_hw *hw); |
| void ice_free_seg(struct ice_hw *hw); |
| void ice_fill_blk_tbls(struct ice_hw *hw); |
| void ice_clear_hw_tbls(struct ice_hw *hw); |
| void ice_free_hw_tbls(struct ice_hw *hw); |
| enum ice_status |
| ice_rem_prof(struct ice_hw *hw, enum ice_block blk, u64 id); |
| #endif /* _ICE_FLEX_PIPE_H_ */ |