mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-27 04:54:41 +08:00
e5dd661b8b
Checking only protocol ids while searching for correct FVs can lead to a situation, when incorrect FV will be added to the list. Incorrect means that FV has correct protocol id but incorrect offset. Call ice_get_sw_fv_list with ice_prot_lkup_ext struct which contains all protocol ids with offsets. With this modification allocating and collecting protocol ids list is not longer needed. Signed-off-by: Michal Swiatkowski <michal.swiatkowski@linux.intel.com> Tested-by: Sandeep Penigalapati <sandeep.penigalapati@intel.com> Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
136 lines
4.3 KiB
C
136 lines
4.3 KiB
C
/* 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
|
|
|
|
enum ice_ddp_state {
|
|
/* Indicates that this call to ice_init_pkg
|
|
* successfully loaded the requested DDP package
|
|
*/
|
|
ICE_DDP_PKG_SUCCESS = 0,
|
|
|
|
/* Generic error for already loaded errors, it is mapped later to
|
|
* the more specific one (one of the next 3)
|
|
*/
|
|
ICE_DDP_PKG_ALREADY_LOADED = -1,
|
|
|
|
/* Indicates that a DDP package of the same version has already been
|
|
* loaded onto the device by a previous call or by another PF
|
|
*/
|
|
ICE_DDP_PKG_SAME_VERSION_ALREADY_LOADED = -2,
|
|
|
|
/* The device has a DDP package that is not supported by the driver */
|
|
ICE_DDP_PKG_ALREADY_LOADED_NOT_SUPPORTED = -3,
|
|
|
|
/* The device has a compatible package
|
|
* (but different from the request) already loaded
|
|
*/
|
|
ICE_DDP_PKG_COMPATIBLE_ALREADY_LOADED = -4,
|
|
|
|
/* The firmware loaded on the device is not compatible with
|
|
* the DDP package loaded
|
|
*/
|
|
ICE_DDP_PKG_FW_MISMATCH = -5,
|
|
|
|
/* The DDP package file is invalid */
|
|
ICE_DDP_PKG_INVALID_FILE = -6,
|
|
|
|
/* The version of the DDP package provided is higher than
|
|
* the driver supports
|
|
*/
|
|
ICE_DDP_PKG_FILE_VERSION_TOO_HIGH = -7,
|
|
|
|
/* The version of the DDP package provided is lower than the
|
|
* driver supports
|
|
*/
|
|
ICE_DDP_PKG_FILE_VERSION_TOO_LOW = -8,
|
|
|
|
/* The signature of the DDP package file provided is invalid */
|
|
ICE_DDP_PKG_FILE_SIGNATURE_INVALID = -9,
|
|
|
|
/* The DDP package file security revision is too low and not
|
|
* supported by firmware
|
|
*/
|
|
ICE_DDP_PKG_FILE_REVISION_TOO_LOW = -10,
|
|
|
|
/* An error occurred in firmware while loading the DDP package */
|
|
ICE_DDP_PKG_LOAD_ERROR = -11,
|
|
|
|
/* Other errors */
|
|
ICE_DDP_PKG_ERR = -12
|
|
};
|
|
|
|
int
|
|
ice_acquire_change_lock(struct ice_hw *hw, enum ice_aq_res_access_type access);
|
|
void ice_release_change_lock(struct ice_hw *hw);
|
|
int
|
|
ice_find_prot_off(struct ice_hw *hw, enum ice_block blk, u8 prof, u16 fv_idx,
|
|
u8 *prot, u16 *off);
|
|
void
|
|
ice_get_sw_fv_bitmap(struct ice_hw *hw, enum ice_prof_type type,
|
|
unsigned long *bm);
|
|
void
|
|
ice_init_prof_result_bm(struct ice_hw *hw);
|
|
int
|
|
ice_get_sw_fv_list(struct ice_hw *hw, struct ice_prot_lkup_ext *lkups,
|
|
unsigned long *bm, struct list_head *fv_list);
|
|
int
|
|
ice_pkg_buf_unreserve_section(struct ice_buf_build *bld, u16 count);
|
|
u16 ice_pkg_buf_get_free_space(struct ice_buf_build *bld);
|
|
int
|
|
ice_aq_upload_section(struct ice_hw *hw, struct ice_buf_hdr *pkg_buf,
|
|
u16 buf_size, struct ice_sq_cd *cd);
|
|
bool
|
|
ice_get_open_tunnel_port(struct ice_hw *hw, u16 *port,
|
|
enum ice_tunnel_type type);
|
|
int ice_udp_tunnel_set_port(struct net_device *netdev, unsigned int table,
|
|
unsigned int idx, struct udp_tunnel_info *ti);
|
|
int ice_udp_tunnel_unset_port(struct net_device *netdev, unsigned int table,
|
|
unsigned int idx, struct udp_tunnel_info *ti);
|
|
int ice_set_dvm_boost_entries(struct ice_hw *hw);
|
|
|
|
/* Rx parser PTYPE functions */
|
|
bool ice_hw_ptype_ena(struct ice_hw *hw, u16 ptype);
|
|
|
|
/* XLT2/VSI group functions */
|
|
int
|
|
ice_add_prof(struct ice_hw *hw, enum ice_block blk, u64 id, u8 ptypes[],
|
|
const struct ice_ptype_attributes *attr, u16 attr_cnt,
|
|
struct ice_fv_word *es, u16 *masks);
|
|
int
|
|
ice_add_prof_id_flow(struct ice_hw *hw, enum ice_block blk, u16 vsi, u64 hdl);
|
|
int
|
|
ice_rem_prof_id_flow(struct ice_hw *hw, enum ice_block blk, u16 vsi, u64 hdl);
|
|
enum ice_ddp_state ice_init_pkg(struct ice_hw *hw, u8 *buff, u32 len);
|
|
enum ice_ddp_state
|
|
ice_copy_and_init_pkg(struct ice_hw *hw, const u8 *buf, u32 len);
|
|
bool ice_is_init_pkg_successful(enum ice_ddp_state state);
|
|
int 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);
|
|
int ice_rem_prof(struct ice_hw *hw, enum ice_block blk, u64 id);
|
|
struct ice_buf_build *
|
|
ice_pkg_buf_alloc_single_section(struct ice_hw *hw, u32 type, u16 size,
|
|
void **section);
|
|
struct ice_buf *ice_pkg_buf(struct ice_buf_build *bld);
|
|
void ice_pkg_buf_free(struct ice_hw *hw, struct ice_buf_build *bld);
|
|
|
|
#endif /* _ICE_FLEX_PIPE_H_ */
|