2019-09-09 21:47:44 +08:00
|
|
|
/* 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
|
|
|
|
|
2020-05-12 09:01:42 +08:00
|
|
|
bool
|
|
|
|
ice_get_open_tunnel_port(struct ice_hw *hw, enum ice_tunnel_type type,
|
|
|
|
u16 *port);
|
2020-05-07 00:32:30 +08:00
|
|
|
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);
|
|
|
|
|
2020-01-17 23:39:13 +08:00
|
|
|
enum ice_status
|
|
|
|
ice_add_prof(struct ice_hw *hw, enum ice_block blk, u64 id, u8 ptypes[],
|
|
|
|
struct ice_fv_word *es);
|
2020-01-17 23:39:14 +08:00
|
|
|
enum ice_status
|
|
|
|
ice_add_prof_id_flow(struct ice_hw *hw, enum ice_block blk, u16 vsi, u64 hdl);
|
2020-01-17 23:39:16 +08:00
|
|
|
enum ice_status
|
|
|
|
ice_rem_prof_id_flow(struct ice_hw *hw, enum ice_block blk, u16 vsi, u64 hdl);
|
2019-09-09 21:47:44 +08:00
|
|
|
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);
|
2019-09-09 21:47:45 +08:00
|
|
|
enum ice_status ice_init_hw_tbls(struct ice_hw *hw);
|
2019-09-09 21:47:44 +08:00
|
|
|
void ice_free_seg(struct ice_hw *hw);
|
2019-09-09 21:47:46 +08:00
|
|
|
void ice_fill_blk_tbls(struct ice_hw *hw);
|
2019-09-09 21:47:45 +08:00
|
|
|
void ice_clear_hw_tbls(struct ice_hw *hw);
|
|
|
|
void ice_free_hw_tbls(struct ice_hw *hw);
|
2020-01-17 23:39:16 +08:00
|
|
|
enum ice_status
|
|
|
|
ice_rem_prof(struct ice_hw *hw, enum ice_block blk, u64 id);
|
2019-09-09 21:47:44 +08:00
|
|
|
#endif /* _ICE_FLEX_PIPE_H_ */
|