Add code to query and set the number of channels on the primary VSI for a PF. This is accessed from the 'ethtool -l' and 'ethtool -L' commands, respectively. Though the ice driver supports asymmetric queues report an IRQ vector that has both Rx and Tx queues attached and is counted as a 'combined' channel. Signed-off-by: Henry Tieman <henry.w.tieman@intel.com> Co-developed-by: Maciej Fijalkowski <maciej.fijalkowski@intel.com> Signed-off-by: Maciej Fijalkowski <maciej.fijalkowski@intel.com> Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com> Tested-by: Andrew Bowers <andrewx.bowers@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
89 lines
2.6 KiB
C
89 lines
2.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/* Copyright (c) 2019, Intel Corporation. */
|
|
|
|
#ifndef _ICE_DCB_LIB_H_
|
|
#define _ICE_DCB_LIB_H_
|
|
|
|
#include "ice.h"
|
|
#include "ice_base.h"
|
|
#include "ice_lib.h"
|
|
|
|
#ifdef CONFIG_DCB
|
|
#define ICE_TC_MAX_BW 100 /* Default Max BW percentage */
|
|
#define ICE_DCB_HW_CHG_RST 0 /* DCB configuration changed with reset */
|
|
#define ICE_DCB_NO_HW_CHG 1 /* DCB configuration did not change */
|
|
#define ICE_DCB_HW_CHG 2 /* DCB configuration changed, no reset */
|
|
|
|
void ice_dcb_rebuild(struct ice_pf *pf);
|
|
u8 ice_dcb_get_ena_tc(struct ice_dcbx_cfg *dcbcfg);
|
|
u8 ice_dcb_get_num_tc(struct ice_dcbx_cfg *dcbcfg);
|
|
u8 ice_dcb_get_tc(struct ice_vsi *vsi, int queue_index);
|
|
int
|
|
ice_pf_dcb_cfg(struct ice_pf *pf, struct ice_dcbx_cfg *new_cfg, bool locked);
|
|
void ice_pf_dcb_recfg(struct ice_pf *pf);
|
|
void ice_vsi_cfg_dcb_rings(struct ice_vsi *vsi);
|
|
int ice_init_pf_dcb(struct ice_pf *pf, bool locked);
|
|
void ice_update_dcb_stats(struct ice_pf *pf);
|
|
int
|
|
ice_tx_prepare_vlan_flags_dcb(struct ice_ring *tx_ring,
|
|
struct ice_tx_buf *first);
|
|
void
|
|
ice_dcb_process_lldp_set_mib_change(struct ice_pf *pf,
|
|
struct ice_rq_event_info *event);
|
|
void ice_vsi_cfg_netdev_tc(struct ice_vsi *vsi, u8 ena_tc);
|
|
static inline void
|
|
ice_set_cgd_num(struct ice_tlan_ctx *tlan_ctx, struct ice_ring *ring)
|
|
{
|
|
tlan_ctx->cgd_num = ring->dcb_tc;
|
|
}
|
|
#else
|
|
#define ice_dcb_rebuild(pf) do {} while (0)
|
|
|
|
static inline u8 ice_dcb_get_ena_tc(struct ice_dcbx_cfg __always_unused *dcbcfg)
|
|
{
|
|
return ICE_DFLT_TRAFFIC_CLASS;
|
|
}
|
|
|
|
static inline u8 ice_dcb_get_num_tc(struct ice_dcbx_cfg __always_unused *dcbcfg)
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
static inline u8
|
|
ice_dcb_get_tc(struct ice_vsi __always_unused *vsi,
|
|
int __always_unused queue_index)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline int
|
|
ice_init_pf_dcb(struct ice_pf *pf, bool __always_unused locked)
|
|
{
|
|
dev_dbg(ice_pf_to_dev(pf), "DCB not supported\n");
|
|
return -EOPNOTSUPP;
|
|
}
|
|
|
|
static inline int
|
|
ice_pf_dcb_cfg(struct ice_pf __always_unused *pf,
|
|
struct ice_dcbx_cfg __always_unused *new_cfg,
|
|
bool __always_unused locked)
|
|
{
|
|
return -EOPNOTSUPP;
|
|
}
|
|
|
|
static inline int
|
|
ice_tx_prepare_vlan_flags_dcb(struct ice_ring __always_unused *tx_ring,
|
|
struct ice_tx_buf __always_unused *first)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
#define ice_update_dcb_stats(pf) do {} while (0)
|
|
#define ice_pf_dcb_recfg(pf) do {} while (0)
|
|
#define ice_vsi_cfg_dcb_rings(vsi) do {} while (0)
|
|
#define ice_dcb_process_lldp_set_mib_change(pf, event) do {} while (0)
|
|
#define ice_set_cgd_num(tlan_ctx, ring) do {} while (0)
|
|
#define ice_vsi_cfg_netdev_tc(vsi, ena_tc) do {} while (0)
|
|
#endif /* CONFIG_DCB */
|
|
#endif /* _ICE_DCB_LIB_H_ */
|