100 строки
2.8 KiB
C
100 строки
2.8 KiB
C
/*
|
|
* Linux driver for VMware's vmxnet3 ethernet NIC.
|
|
*
|
|
* Copyright (C) 2008-2020, VMware, Inc. All Rights Reserved.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the
|
|
* Free Software Foundation; version 2 of the License and no later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or
|
|
* NON INFRINGEMENT. See the GNU General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*
|
|
* The full GNU General Public License is included in this distribution in
|
|
* the file called "COPYING".
|
|
*
|
|
* Maintained by: pv-drivers@vmware.com
|
|
*
|
|
*/
|
|
|
|
#ifndef _UPT1_DEFS_H
|
|
#define _UPT1_DEFS_H
|
|
|
|
struct UPT1_TxStats {
|
|
u64 TSOPktsTxOK; /* TSO pkts post-segmentation */
|
|
u64 TSOBytesTxOK;
|
|
u64 ucastPktsTxOK;
|
|
u64 ucastBytesTxOK;
|
|
u64 mcastPktsTxOK;
|
|
u64 mcastBytesTxOK;
|
|
u64 bcastPktsTxOK;
|
|
u64 bcastBytesTxOK;
|
|
u64 pktsTxError;
|
|
u64 pktsTxDiscard;
|
|
};
|
|
|
|
struct UPT1_RxStats {
|
|
u64 LROPktsRxOK; /* LRO pkts */
|
|
u64 LROBytesRxOK; /* bytes from LRO pkts */
|
|
/* the following counters are for pkts from the wire, i.e., pre-LRO */
|
|
u64 ucastPktsRxOK;
|
|
u64 ucastBytesRxOK;
|
|
u64 mcastPktsRxOK;
|
|
u64 mcastBytesRxOK;
|
|
u64 bcastPktsRxOK;
|
|
u64 bcastBytesRxOK;
|
|
u64 pktsRxOutOfBuf;
|
|
u64 pktsRxError;
|
|
};
|
|
|
|
/* interrupt moderation level */
|
|
enum {
|
|
UPT1_IML_NONE = 0, /* no interrupt moderation */
|
|
UPT1_IML_HIGHEST = 7, /* least intr generated */
|
|
UPT1_IML_ADAPTIVE = 8, /* adpative intr moderation */
|
|
};
|
|
/* values for UPT1_RSSConf.hashFunc */
|
|
enum {
|
|
UPT1_RSS_HASH_TYPE_NONE = 0x0,
|
|
UPT1_RSS_HASH_TYPE_IPV4 = 0x01,
|
|
UPT1_RSS_HASH_TYPE_TCP_IPV4 = 0x02,
|
|
UPT1_RSS_HASH_TYPE_IPV6 = 0x04,
|
|
UPT1_RSS_HASH_TYPE_TCP_IPV6 = 0x08,
|
|
};
|
|
|
|
enum {
|
|
UPT1_RSS_HASH_FUNC_NONE = 0x0,
|
|
UPT1_RSS_HASH_FUNC_TOEPLITZ = 0x01,
|
|
};
|
|
|
|
#define UPT1_RSS_MAX_KEY_SIZE 40
|
|
#define UPT1_RSS_MAX_IND_TABLE_SIZE 128
|
|
|
|
struct UPT1_RSSConf {
|
|
u16 hashType;
|
|
u16 hashFunc;
|
|
u16 hashKeySize;
|
|
u16 indTableSize;
|
|
u8 hashKey[UPT1_RSS_MAX_KEY_SIZE];
|
|
u8 indTable[UPT1_RSS_MAX_IND_TABLE_SIZE];
|
|
};
|
|
|
|
/* features */
|
|
enum {
|
|
UPT1_F_RXCSUM = cpu_to_le64(0x0001), /* rx csum verification */
|
|
UPT1_F_RSS = cpu_to_le64(0x0002),
|
|
UPT1_F_RXVLAN = cpu_to_le64(0x0004), /* VLAN tag stripping */
|
|
UPT1_F_LRO = cpu_to_le64(0x0008),
|
|
UPT1_F_RXINNEROFLD = cpu_to_le64(0x00010), /* Geneve/Vxlan rx csum
|
|
* offloading
|
|
*/
|
|
};
|
|
#endif
|