vmxnet3_int.h revision b0eb57cb97e7837ebb746404c2c58c6f536f23fa
1d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara/* 2d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * Linux driver for VMware's vmxnet3 ethernet NIC. 3d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * 4d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * Copyright (C) 2008-2009, VMware, Inc. All Rights Reserved. 5d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * 6d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * This program is free software; you can redistribute it and/or modify it 7d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * under the terms of the GNU General Public License as published by the 8d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * Free Software Foundation; version 2 of the License and no later version. 9d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * 10d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * This program is distributed in the hope that it will be useful, but 11d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * WITHOUT ANY WARRANTY; without even the implied warranty of 12d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or 13d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * NON INFRINGEMENT. See the GNU General Public License for more 14d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * details. 15d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * 16d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * You should have received a copy of the GNU General Public License 17d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * along with this program; if not, write to the Free Software 18d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 19d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * 20d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * The full GNU General Public License is included in this distribution in 21d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * the file called "COPYING". 22d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * 23d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * Maintained by: Shreyas Bhatewara <pv-drivers@vmware.com> 24d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * 25d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara */ 26d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 27d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#ifndef _VMXNET3_INT_H 28d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define _VMXNET3_INT_H 29d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 3072e85c45b9541e1f3d233e775da1dc6f68b85867Jesse Gross#include <linux/bitops.h> 31d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/ethtool.h> 32d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/delay.h> 33d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/netdevice.h> 34d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/pci.h> 35d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/compiler.h> 36d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/slab.h> 37d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/spinlock.h> 38d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/ioport.h> 39d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/highmem.h> 40d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/init.h> 41d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/timer.h> 42d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/skbuff.h> 43d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/interrupt.h> 44d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/workqueue.h> 45d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/uaccess.h> 46d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <asm/dma.h> 47d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <asm/page.h> 48d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 49d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/tcp.h> 50d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/udp.h> 51d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/ip.h> 52d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/ipv6.h> 53d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/in.h> 54d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/etherdevice.h> 55d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <asm/checksum.h> 56d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/if_vlan.h> 57d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/if_arp.h> 58d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include <linux/inetdevice.h> 59eebb02b1f03b3722d678bfcb560f3b26661ab0d2Shreyas Bhatewara#include <linux/log2.h> 60d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 61d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#include "vmxnet3_defs.h" 62d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 63d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#ifdef DEBUG 64d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara# define VMXNET3_DRIVER_VERSION_REPORT VMXNET3_DRIVER_VERSION_STRING"-NAPI(debug)" 65d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#else 66d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara# define VMXNET3_DRIVER_VERSION_REPORT VMXNET3_DRIVER_VERSION_STRING"-NAPI" 67d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#endif 68d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 69d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 70d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara/* 71d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * Version numbers 72d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara */ 73b0eb57cb97e7837ebb746404c2c58c6f536f23faAndy King#define VMXNET3_DRIVER_VERSION_STRING "1.2.0.0-k" 74d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 75d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara/* a 32-bit int, each byte encode a verion number in VMXNET3_DRIVER_VERSION */ 76b0eb57cb97e7837ebb746404c2c58c6f536f23faAndy King#define VMXNET3_DRIVER_VERSION_NUM 0x01020000 77d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 7809c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#if defined(CONFIG_PCI_MSI) 7909c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara /* RSS only makes sense if MSI-X is supported. */ 8009c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara #define VMXNET3_RSS 8109c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#endif 82d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 83d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara/* 84d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * Capabilities 85d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara */ 86d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 87d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaraenum { 88d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_SG = 0x0001, /* Can do scatter-gather transmits. */ 89d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_IP4_CSUM = 0x0002, /* Can checksum only TCP/UDP over 90d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * IPv4 */ 91d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_HW_CSUM = 0x0004, /* Can checksum all packets. */ 92d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_HIGH_DMA = 0x0008, /* Can DMA to high memory. */ 93d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_TOE = 0x0010, /* Supports TCP/IP offload. */ 94d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_TSO = 0x0020, /* Supports TCP Segmentation 95d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * offload */ 96d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_SW_TSO = 0x0040, /* Supports SW TCP Segmentation */ 97d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_VMXNET_APROM = 0x0080, /* Vmxnet APROM support */ 98d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_HW_TX_VLAN = 0x0100, /* Can we do VLAN tagging in HW */ 99d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_HW_RX_VLAN = 0x0200, /* Can we do VLAN untagging in HW */ 100d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_SW_VLAN = 0x0400, /* VLAN tagging/untagging in SW */ 101d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_WAKE_PCKT_RCV = 0x0800, /* Can wake on network packet recv? */ 102d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_ENABLE_INT_INLINE = 0x1000, /* Enable Interrupt Inline */ 103d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_ENABLE_HEADER_COPY = 0x2000, /* copy header for vmkernel */ 104d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_TX_CHAIN = 0x4000, /* Guest can use multiple tx entries 105d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * for a pkt */ 106d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_RX_CHAIN = 0x8000, /* pkt can span multiple rx entries */ 107d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_LPD = 0x10000, /* large pkt delivery */ 108d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_BPF = 0x20000, /* BPF Support in VMXNET Virtual HW*/ 109d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_SG_SPAN_PAGES = 0x40000, /* Scatter-gather can span multiple*/ 110d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara /* pages transmits */ 111d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_IP6_CSUM = 0x80000, /* Can do IPv6 csum offload. */ 112d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_TSO6 = 0x100000, /* TSO seg. offload for IPv6 pkts. */ 113d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_TSO256k = 0x200000, /* Can do TSO seg offload for */ 114d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara /* pkts up to 256kB. */ 115d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMNET_CAP_UPT = 0x400000 /* Support UPT */ 116d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 117d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 118d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara/* 119d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * PCI vendor and device IDs. 120d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara */ 121d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define PCI_VENDOR_ID_VMWARE 0x15AD 122d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define PCI_DEVICE_ID_VMWARE_VMXNET3 0x07B0 123d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define MAX_ETHERNET_CARDS 10 124d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define MAX_PCI_PASSTHRU_DEVICE 6 125d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 126d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_cmd_ring { 127d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara union Vmxnet3_GenericDesc *base; 128d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 size; 129d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 next2fill; 130d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 next2comp; 131d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u8 gen; 132d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara dma_addr_t basePA; 133d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 134d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 135d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastatic inline void 136d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravmxnet3_cmd_ring_adv_next2fill(struct vmxnet3_cmd_ring *ring) 137d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara{ 138d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara ring->next2fill++; 139d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara if (unlikely(ring->next2fill == ring->size)) { 140d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara ring->next2fill = 0; 141d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMXNET3_FLIP_RING_GEN(ring->gen); 142d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara } 143d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara} 144d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 145d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastatic inline void 146d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravmxnet3_cmd_ring_adv_next2comp(struct vmxnet3_cmd_ring *ring) 147d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara{ 148d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMXNET3_INC_RING_IDX_ONLY(ring->next2comp, ring->size); 149d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara} 150d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 151d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastatic inline int 152d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravmxnet3_cmd_ring_desc_avail(struct vmxnet3_cmd_ring *ring) 153d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara{ 154d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara return (ring->next2comp > ring->next2fill ? 0 : ring->size) + 155d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara ring->next2comp - ring->next2fill - 1; 156d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara} 157d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 158d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_comp_ring { 159d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara union Vmxnet3_GenericDesc *base; 160d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 size; 161d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 next2proc; 162d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u8 gen; 163d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u8 intr_idx; 164d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara dma_addr_t basePA; 165d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 166d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 167d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastatic inline void 168d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravmxnet3_comp_ring_adv_next2proc(struct vmxnet3_comp_ring *ring) 169d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara{ 170d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara ring->next2proc++; 171d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara if (unlikely(ring->next2proc == ring->size)) { 172d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara ring->next2proc = 0; 173d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMXNET3_FLIP_RING_GEN(ring->gen); 174d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara } 175d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara} 176d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 177d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_tx_data_ring { 178d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct Vmxnet3_TxDataDesc *base; 179d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 size; 180d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara dma_addr_t basePA; 181d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 182d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 183d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaraenum vmxnet3_buf_map_type { 184d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMXNET3_MAP_INVALID = 0, 185d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMXNET3_MAP_NONE, 186d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMXNET3_MAP_SINGLE, 187d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMXNET3_MAP_PAGE, 188d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 189d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 190d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_tx_buf_info { 191d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 map_type; 192d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u16 len; 193d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u16 sop_idx; 194d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara dma_addr_t dma_addr; 195d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct sk_buff *skb; 196d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 197d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 198d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_tq_driver_stats { 199d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 drop_total; /* # of pkts dropped by the driver, the 200d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * counters below track droppings due to 201d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * different reasons 202d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara */ 203d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 drop_too_many_frags; 204d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 drop_oversized_hdr; 205d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 drop_hdr_inspect_err; 206d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 drop_tso; 207d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 208d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 tx_ring_full; 209d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 linearized; /* # of pkts linearized */ 210d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 copy_skb_header; /* # of times we have to copy skb header */ 211d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 oversized_hdr; 212d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 213d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 214d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_tx_ctx { 215d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara bool ipv4; 216d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u16 mss; 217d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 eth_ip_hdr_size; /* only valid for pkts requesting tso or csum 218d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * offloading 219d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara */ 220d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 l4_hdr_size; /* only valid if mss != 0 */ 221d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 copy_size; /* # of bytes copied into the data ring */ 222d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara union Vmxnet3_GenericDesc *sop_txd; 223d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara union Vmxnet3_GenericDesc *eop_txd; 224d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 225d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 226d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_tx_queue { 22709c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara char name[IFNAMSIZ+8]; /* To identify interrupt */ 22809c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct vmxnet3_adapter *adapter; 229d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara spinlock_t tx_lock; 230d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct vmxnet3_cmd_ring tx_ring; 23109c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct vmxnet3_tx_buf_info *buf_info; 232b0eb57cb97e7837ebb746404c2c58c6f536f23faAndy King dma_addr_t buf_info_pa; 233d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct vmxnet3_tx_data_ring data_ring; 234d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct vmxnet3_comp_ring comp_ring; 23509c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct Vmxnet3_TxQueueCtrl *shared; 236d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct vmxnet3_tq_driver_stats stats; 237d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara bool stopped; 238d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara int num_stop; /* # of times the queue is 239d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara * stopped */ 24009c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara int qid; 241d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara} __attribute__((__aligned__(SMP_CACHE_BYTES))); 242d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 243d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaraenum vmxnet3_rx_buf_type { 244d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMXNET3_RX_BUF_NONE = 0, 245d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMXNET3_RX_BUF_SKB = 1, 246d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara VMXNET3_RX_BUF_PAGE = 2 247d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 248d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 249d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_rx_buf_info { 250d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara enum vmxnet3_rx_buf_type buf_type; 251d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u16 len; 252d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara union { 253d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct sk_buff *skb; 254d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct page *page; 255d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara }; 256d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara dma_addr_t dma_addr; 257d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 258d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 259d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_rx_ctx { 260d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct sk_buff *skb; 261d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 sop_idx; 262d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 263d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 264d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_rq_driver_stats { 265d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 drop_total; 266d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 drop_err; 267d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 drop_fcs; 268d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 rx_buf_alloc_failure; 269d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 270d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 271d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_rx_queue { 27209c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara char name[IFNAMSIZ + 8]; /* To identify interrupt */ 27309c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct vmxnet3_adapter *adapter; 27409c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct napi_struct napi; 275d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct vmxnet3_cmd_ring rx_ring[2]; 276d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct vmxnet3_comp_ring comp_ring; 277d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct vmxnet3_rx_ctx rx_ctx; 278d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 qid; /* rqID in RCD for buffer from 1st ring */ 279d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 qid2; /* rqID in RCD for buffer from 2nd ring */ 280d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct vmxnet3_rx_buf_info *buf_info[2]; 281b0eb57cb97e7837ebb746404c2c58c6f536f23faAndy King dma_addr_t buf_info_pa; 282d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct Vmxnet3_RxQueueCtrl *shared; 283d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct vmxnet3_rq_driver_stats stats; 284d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara} __attribute__((__aligned__(SMP_CACHE_BYTES))); 285d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 28609c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#define VMXNET3_DEVICE_MAX_TX_QUEUES 8 28709c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#define VMXNET3_DEVICE_MAX_RX_QUEUES 8 /* Keep this value as a power of 2 */ 28809c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara 28909c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara/* Should be less than UPT1_RSS_MAX_IND_TABLE_SIZE */ 29009c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#define VMXNET3_RSS_IND_TABLE_SIZE (VMXNET3_DEVICE_MAX_RX_QUEUES * 4) 29109c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara 29209c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#define VMXNET3_LINUX_MAX_MSIX_VECT (VMXNET3_DEVICE_MAX_TX_QUEUES + \ 29309c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara VMXNET3_DEVICE_MAX_RX_QUEUES + 1) 2947e96fbf2320782fb8f0970928026105cd34b41bdShreyas Bhatewara#define VMXNET3_LINUX_MIN_MSIX_VECT 2 /* 1 for tx-rx pair and 1 for event */ 29509c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara 296d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 297d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_intr { 298d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara enum vmxnet3_intr_mask_mode mask_mode; 299d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara enum vmxnet3_intr_type type; /* MSI-X, MSI, or INTx? */ 300d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u8 num_intrs; /* # of intr vectors */ 301d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u8 event_intr_idx; /* idx of the intr vector for event */ 302d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u8 mod_levels[VMXNET3_LINUX_MAX_MSIX_VECT]; /* moderation level */ 30309c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara char event_msi_vector_name[IFNAMSIZ+11]; 304d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#ifdef CONFIG_PCI_MSI 305d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct msix_entry msix_entries[VMXNET3_LINUX_MAX_MSIX_VECT]; 306d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#endif 307d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 308d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 30909c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara/* Interrupt sharing schemes, share_intr */ 31009c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#define VMXNET3_INTR_BUDDYSHARE 0 /* Corresponding tx,rx queues share irq */ 31109c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#define VMXNET3_INTR_TXSHARE 1 /* All tx queues share one irq */ 31209c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#define VMXNET3_INTR_DONTSHARE 2 /* each queue has its own irq */ 31309c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara 31409c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara 315d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_STATE_BIT_RESETTING 0 316d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_STATE_BIT_QUIESCED 1 317d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewarastruct vmxnet3_adapter { 31809c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct vmxnet3_tx_queue tx_queue[VMXNET3_DEVICE_MAX_TX_QUEUES]; 31909c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct vmxnet3_rx_queue rx_queue[VMXNET3_DEVICE_MAX_RX_QUEUES]; 32072e85c45b9541e1f3d233e775da1dc6f68b85867Jesse Gross unsigned long active_vlans[BITS_TO_LONGS(VLAN_N_VID)]; 32109c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct vmxnet3_intr intr; 32283d0feffc5695d7dc24c6b8dac9ab265533beb78Shreyas Bhatewara spinlock_t cmd_lock; 32309c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct Vmxnet3_DriverShared *shared; 32409c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct Vmxnet3_PMConf *pm_conf; 32509c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct Vmxnet3_TxQueueDesc *tqd_start; /* all tx queue desc */ 32609c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct Vmxnet3_RxQueueDesc *rqd_start; /* all rx queue desc */ 32709c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct net_device *netdev; 32809c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct pci_dev *pdev; 329d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 33081e8e5601fba4ea5bc3bfbed0fec074cf65feca5Harvey Harrison u8 __iomem *hw_addr0; /* for BAR 0 */ 33181e8e5601fba4ea5bc3bfbed0fec074cf65feca5Harvey Harrison u8 __iomem *hw_addr1; /* for BAR 1 */ 332d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 33309c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#ifdef VMXNET3_RSS 33409c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara struct UPT1_RSSConf *rss_conf; 33509c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara bool rss; 33609c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara#endif 33709c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara u32 num_rx_queues; 33809c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara u32 num_tx_queues; 339d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 340d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara /* rx buffer related */ 341d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara unsigned skb_buf_size; 342d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara int rx_buf_per_pkt; /* only apply to the 1st ring */ 343d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara dma_addr_t shared_pa; 344d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara dma_addr_t queue_desc_pa; 345d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 346d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara /* Wake-on-LAN */ 347d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 wol; 348d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 349d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara /* Link speed */ 350d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 link_speed; /* in mbps */ 351d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 352d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u64 tx_timeout_count; 353d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara struct work_struct work; 354d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 355d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara unsigned long state; /* VMXNET3_STATE_BIT_xxx */ 356d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 35709c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewara int share_intr; 358b0eb57cb97e7837ebb746404c2c58c6f536f23faAndy King 359b0eb57cb97e7837ebb746404c2c58c6f536f23faAndy King dma_addr_t adapter_pa; 360b0eb57cb97e7837ebb746404c2c58c6f536f23faAndy King dma_addr_t pm_conf_pa; 361b0eb57cb97e7837ebb746404c2c58c6f536f23faAndy King dma_addr_t rss_conf_pa; 362d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara}; 363d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 364d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_WRITE_BAR0_REG(adapter, reg, val) \ 365b8744cabb79a6522bb2e1c22c4edd8fb39fcfc7eHarvey Harrison writel((val), (adapter)->hw_addr0 + (reg)) 366d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_READ_BAR0_REG(adapter, reg) \ 367b8744cabb79a6522bb2e1c22c4edd8fb39fcfc7eHarvey Harrison readl((adapter)->hw_addr0 + (reg)) 368d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 369d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_WRITE_BAR1_REG(adapter, reg, val) \ 370b8744cabb79a6522bb2e1c22c4edd8fb39fcfc7eHarvey Harrison writel((val), (adapter)->hw_addr1 + (reg)) 371d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_READ_BAR1_REG(adapter, reg) \ 372b8744cabb79a6522bb2e1c22c4edd8fb39fcfc7eHarvey Harrison readl((adapter)->hw_addr1 + (reg)) 373d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 374d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_WAKE_QUEUE_THRESHOLD(tq) (5) 375d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_RX_ALLOC_THRESHOLD(rq, ring_idx, adapter) \ 376d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara ((rq)->rx_ring[ring_idx].size >> 3) 377d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 378d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_GET_ADDR_LO(dma) ((u32)(dma)) 379d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_GET_ADDR_HI(dma) ((u32)(((u64)(dma)) >> 32)) 380d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 381d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara/* must be a multiple of VMXNET3_RING_SIZE_ALIGN */ 382d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_DEF_TX_RING_SIZE 512 383d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_DEF_RX_RING_SIZE 256 384d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 385d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_MAX_ETH_HDR_SIZE 22 386d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#define VMXNET3_MAX_SKB_BUF_SIZE (3*1024) 387d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 388d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaraint 389d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravmxnet3_quiesce_dev(struct vmxnet3_adapter *adapter); 390d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 391d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaraint 392d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravmxnet3_activate_dev(struct vmxnet3_adapter *adapter); 393d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 394d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravoid 395d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravmxnet3_force_close(struct vmxnet3_adapter *adapter); 396d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 397d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravoid 398d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravmxnet3_reset_dev(struct vmxnet3_adapter *adapter); 399d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 400d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravoid 40109c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewaravmxnet3_tq_destroy_all(struct vmxnet3_adapter *adapter); 402d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 403d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravoid 40409c5088e5c5993be217a2c85dca088147ffc9b72Shreyas Bhatewaravmxnet3_rq_destroy_all(struct vmxnet3_adapter *adapter); 405d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 406d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaraint 407c8f44affb7244f2ac3e703cab13d55ede27621bbMichał Mirosławvmxnet3_set_features(struct net_device *netdev, netdev_features_t features); 408a0d2730c9571aeba793cb5d3009094ee1d8fda35Michał Mirosław 409a0d2730c9571aeba793cb5d3009094ee1d8fda35Michał Mirosławint 410d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaravmxnet3_create_queues(struct vmxnet3_adapter *adapter, 411d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara u32 tx_ring_size, u32 rx_ring_size, u32 rx_ring2_size); 412d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 413d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaraextern void vmxnet3_set_ethtool_ops(struct net_device *netdev); 41495305f6c3b4e8c0bdd5044604c418a8ad2defc4estephen hemminger 41595305f6c3b4e8c0bdd5044604c418a8ad2defc4estephen hemmingerextern struct rtnl_link_stats64 * 41695305f6c3b4e8c0bdd5044604c418a8ad2defc4estephen hemmingervmxnet3_get_stats64(struct net_device *dev, struct rtnl_link_stats64 *stats); 417d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara 418d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewaraextern char vmxnet3_driver_name[]; 419d1a890fa37f27d6aca3abc6e25e4148efc3223a6Shreyas Bhatewara#endif 420