c2fec27b5c
Currently, when more than 1 receive queues are configured, the driver always enables RSS with the driver's own default hash type, key, and RETA. The user is unable to change any of the RSS settings. Address this by implementing the ethdev RSS API as follows. Correctly report the RETA size, key size, and supported hash types through rte_eth_dev_info. During dev_configure(), initialize RSS according to the device's mq_mode and rss_conf. Start with the default RETA, and use the default key unless a custom key is provided. Add the RETA and rss_conf query/set handlers to let the user change RSS settings after the initial configuration. The hardware is able to change hash type, key, and RETA individually. So, the handlers change only the affected settings. Refactor/rename several functions in order to make their intentions clear. For example, remove all traces of RSS from enicpmd_vlan_offload_set() as it is confusing. Signed-off-by: Hyong Youb Kim <hyonkim@cisco.com> Reviewed-by: John Daley <johndale@cisco.com>
59 lines
1.8 KiB
C
59 lines
1.8 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause
|
|
* Copyright 2008-2017 Cisco Systems, Inc. All rights reserved.
|
|
* Copyright 2007 Nuova Systems, Inc. All rights reserved.
|
|
*/
|
|
|
|
#ifndef _ENIC_RES_H_
|
|
#define _ENIC_RES_H_
|
|
|
|
#include "wq_enet_desc.h"
|
|
#include "rq_enet_desc.h"
|
|
#include "vnic_wq.h"
|
|
#include "vnic_rq.h"
|
|
|
|
#define ENIC_MIN_WQ_DESCS 64
|
|
#define ENIC_MAX_WQ_DESCS 4096
|
|
#define ENIC_MIN_RQ_DESCS 64
|
|
#define ENIC_MAX_RQ_DESCS 4096
|
|
|
|
#define ENIC_MIN_MTU 68
|
|
|
|
/* Does not include (possible) inserted VLAN tag and FCS */
|
|
#define ENIC_DEFAULT_RX_MAX_PKT_SIZE 9022
|
|
|
|
/* Does not include (possible) inserted VLAN tag and FCS */
|
|
#define ENIC_TX_MAX_PKT_SIZE 9208
|
|
|
|
#define ENIC_MULTICAST_PERFECT_FILTERS 32
|
|
#define ENIC_UNICAST_PERFECT_FILTERS 32
|
|
|
|
#define ENIC_NON_TSO_MAX_DESC 16
|
|
#define ENIC_DEFAULT_RX_FREE_THRESH 32
|
|
#define ENIC_TX_XMIT_MAX 64
|
|
|
|
#define ENIC_RSS_DEFAULT_CPU 0
|
|
#define ENIC_RSS_BASE_CPU 0
|
|
#define ENIC_RSS_HASH_BITS 7
|
|
#define ENIC_RSS_RETA_SIZE (1 << ENIC_RSS_HASH_BITS)
|
|
#define ENIC_RSS_HASH_KEY_SIZE 40
|
|
|
|
#define ENIC_SETTING(enic, f) ((enic->config.flags & VENETF_##f) ? 1 : 0)
|
|
|
|
|
|
struct enic;
|
|
|
|
int enic_get_vnic_config(struct enic *);
|
|
int enic_add_vlan(struct enic *enic, u16 vlanid);
|
|
int enic_del_vlan(struct enic *enic, u16 vlanid);
|
|
int enic_set_nic_cfg(struct enic *enic, u8 rss_default_cpu, u8 rss_hash_type,
|
|
u8 rss_hash_bits, u8 rss_base_cpu, u8 rss_enable, u8 tso_ipid_split_en,
|
|
u8 ig_vlan_strip_en);
|
|
int enic_set_rss_key(struct enic *enic, dma_addr_t key_pa, u64 len);
|
|
int enic_set_rss_cpu(struct enic *enic, dma_addr_t cpu_pa, u64 len);
|
|
void enic_get_res_counts(struct enic *enic);
|
|
void enic_init_vnic_resources(struct enic *enic);
|
|
int enic_alloc_vnic_resources(struct enic *);
|
|
void enic_free_vnic_resources(struct enic *);
|
|
|
|
#endif /* _ENIC_RES_H_ */
|