mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-24 23:19:53 +07:00
94b3b54230
Setting up macvlan/macvtap networks over atlantic NIC results
in no traffic over these networks because ndo_set_rx_mode did
not listed UC MACs as registered in unicast filter.
Here we fix that taking into account maximum number of UC
filters supported by hardware. If more than MAX addresses were
registered, we just enable promisc and/or allmulti to pass
the traffic in.
We also remove MULTICAST_ADDRESS_MAX constant from aq_cfg since
thats not a configurable parameter at all.
Fixes: b21f502
("net:ethernet:aquantia: Fix for multicast filter handling.")
Signed-off-by: Igor Russkikh <igor.russkikh@aquantia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
93 lines
2.5 KiB
C
93 lines
2.5 KiB
C
/*
|
|
* aQuantia Corporation Network Driver
|
|
* Copyright (C) 2014-2017 aQuantia Corporation. All rights reserved
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms and conditions of the GNU General Public License,
|
|
* version 2, as published by the Free Software Foundation.
|
|
*/
|
|
|
|
/* File aq_cfg.h: Definition of configuration parameters and constants. */
|
|
|
|
#ifndef AQ_CFG_H
|
|
#define AQ_CFG_H
|
|
|
|
#define AQ_CFG_VECS_DEF 4U
|
|
#define AQ_CFG_TCS_DEF 1U
|
|
|
|
#define AQ_CFG_TXDS_DEF 4096U
|
|
#define AQ_CFG_RXDS_DEF 1024U
|
|
|
|
#define AQ_CFG_IS_POLLING_DEF 0U
|
|
|
|
#define AQ_CFG_FORCE_LEGACY_INT 0U
|
|
|
|
#define AQ_CFG_INTERRUPT_MODERATION_OFF 0
|
|
#define AQ_CFG_INTERRUPT_MODERATION_ON 1
|
|
#define AQ_CFG_INTERRUPT_MODERATION_AUTO 0xFFFFU
|
|
|
|
#define AQ_CFG_INTERRUPT_MODERATION_USEC_MAX (0x1FF * 2)
|
|
|
|
#define AQ_CFG_IRQ_MASK 0x1FFU
|
|
|
|
#define AQ_CFG_VECS_MAX 8U
|
|
#define AQ_CFG_TCS_MAX 8U
|
|
|
|
#define AQ_CFG_TX_FRAME_MAX (16U * 1024U)
|
|
#define AQ_CFG_RX_FRAME_MAX (4U * 1024U)
|
|
|
|
#define AQ_CFG_TX_CLEAN_BUDGET 256U
|
|
|
|
/* LRO */
|
|
#define AQ_CFG_IS_LRO_DEF 1U
|
|
|
|
/* RSS */
|
|
#define AQ_CFG_RSS_INDIRECTION_TABLE_MAX 128U
|
|
#define AQ_CFG_RSS_HASHKEY_SIZE 320U
|
|
|
|
#define AQ_CFG_IS_RSS_DEF 1U
|
|
#define AQ_CFG_NUM_RSS_QUEUES_DEF AQ_CFG_VECS_DEF
|
|
#define AQ_CFG_RSS_BASE_CPU_NUM_DEF 0U
|
|
|
|
#define AQ_CFG_PCI_FUNC_MSIX_IRQS 9U
|
|
#define AQ_CFG_PCI_FUNC_PORTS 2U
|
|
|
|
#define AQ_CFG_SERVICE_TIMER_INTERVAL (1 * HZ)
|
|
#define AQ_CFG_POLLING_TIMER_INTERVAL ((unsigned int)(2 * HZ))
|
|
|
|
#define AQ_CFG_SKB_FRAGS_MAX 32U
|
|
|
|
/* Number of descriptors available in one ring to resume this ring queue
|
|
*/
|
|
#define AQ_CFG_RESTART_DESC_THRES (AQ_CFG_SKB_FRAGS_MAX * 2)
|
|
|
|
#define AQ_CFG_NAPI_WEIGHT 64U
|
|
|
|
/*#define AQ_CFG_MAC_ADDR_PERMANENT {0x30, 0x0E, 0xE3, 0x12, 0x34, 0x56}*/
|
|
|
|
#define AQ_NIC_FC_OFF 0U
|
|
#define AQ_NIC_FC_TX 1U
|
|
#define AQ_NIC_FC_RX 2U
|
|
#define AQ_NIC_FC_FULL 3U
|
|
#define AQ_NIC_FC_AUTO 4U
|
|
|
|
#define AQ_CFG_FC_MODE AQ_NIC_FC_FULL
|
|
|
|
#define AQ_CFG_SPEED_MSK 0xFFFFU /* 0xFFFFU==auto_neg */
|
|
|
|
#define AQ_CFG_IS_AUTONEG_DEF 1U
|
|
#define AQ_CFG_MTU_DEF 1514U
|
|
|
|
#define AQ_CFG_LOCK_TRYS 100U
|
|
|
|
#define AQ_CFG_DRV_AUTHOR "aQuantia"
|
|
#define AQ_CFG_DRV_DESC "aQuantia Corporation(R) Network Driver"
|
|
#define AQ_CFG_DRV_NAME "atlantic"
|
|
#define AQ_CFG_DRV_VERSION __stringify(NIC_MAJOR_DRIVER_VERSION)"."\
|
|
__stringify(NIC_MINOR_DRIVER_VERSION)"."\
|
|
__stringify(NIC_BUILD_DRIVER_VERSION)"."\
|
|
__stringify(NIC_REVISION_DRIVER_VERSION) \
|
|
AQ_CFG_DRV_VERSION_SUFFIX
|
|
|
|
#endif /* AQ_CFG_H */
|