cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

slic.h (16808B)


      1/* SPDX-License-Identifier: GPL-2.0 */
      2
      3#ifndef _SLIC_H
      4#define _SLIC_H
      5
      6#include <linux/types.h>
      7#include <linux/netdevice.h>
      8#include <linux/spinlock_types.h>
      9#include <linux/dma-mapping.h>
     10#include <linux/pci.h>
     11#include <linux/list.h>
     12#include <linux/u64_stats_sync.h>
     13
     14#define SLIC_VGBSTAT_XPERR		0x40000000
     15#define SLIC_VGBSTAT_XERRSHFT		25
     16#define SLIC_VGBSTAT_XCSERR		0x23
     17#define SLIC_VGBSTAT_XUFLOW		0x22
     18#define SLIC_VGBSTAT_XHLEN		0x20
     19#define SLIC_VGBSTAT_NETERR		0x01000000
     20#define SLIC_VGBSTAT_NERRSHFT		16
     21#define SLIC_VGBSTAT_NERRMSK		0x1ff
     22#define SLIC_VGBSTAT_NCSERR		0x103
     23#define SLIC_VGBSTAT_NUFLOW		0x102
     24#define SLIC_VGBSTAT_NHLEN		0x100
     25#define SLIC_VGBSTAT_LNKERR		0x00000080
     26#define SLIC_VGBSTAT_LERRMSK		0xff
     27#define SLIC_VGBSTAT_LDEARLY		0x86
     28#define SLIC_VGBSTAT_LBOFLO		0x85
     29#define SLIC_VGBSTAT_LCODERR		0x84
     30#define SLIC_VGBSTAT_LDBLNBL		0x83
     31#define SLIC_VGBSTAT_LCRCERR		0x82
     32#define SLIC_VGBSTAT_LOFLO		0x81
     33#define SLIC_VGBSTAT_LUFLO		0x80
     34
     35#define SLIC_IRHDDR_FLEN_MSK		0x0000ffff
     36#define SLIC_IRHDDR_SVALID		0x80000000
     37#define SLIC_IRHDDR_ERR			0x10000000
     38
     39#define SLIC_VRHSTAT_802OE		0x80000000
     40#define SLIC_VRHSTAT_TPOFLO		0x10000000
     41#define SLIC_VRHSTATB_802UE		0x80000000
     42#define SLIC_VRHSTATB_RCVE		0x40000000
     43#define SLIC_VRHSTATB_BUFF		0x20000000
     44#define SLIC_VRHSTATB_CARRE		0x08000000
     45#define SLIC_VRHSTATB_LONGE		0x02000000
     46#define SLIC_VRHSTATB_PREA		0x01000000
     47#define SLIC_VRHSTATB_CRC		0x00800000
     48#define SLIC_VRHSTATB_DRBL		0x00400000
     49#define SLIC_VRHSTATB_CODE		0x00200000
     50#define SLIC_VRHSTATB_TPCSUM		0x00100000
     51#define SLIC_VRHSTATB_TPHLEN		0x00080000
     52#define SLIC_VRHSTATB_IPCSUM		0x00040000
     53#define SLIC_VRHSTATB_IPLERR		0x00020000
     54#define SLIC_VRHSTATB_IPHERR		0x00010000
     55
     56#define SLIC_CMD_XMT_REQ		0x01
     57#define SLIC_CMD_TYPE_DUMB		3
     58
     59#define SLIC_RESET_MAGIC		0xDEAD
     60#define SLIC_ICR_INT_OFF		0
     61#define SLIC_ICR_INT_ON			1
     62#define SLIC_ICR_INT_MASK		2
     63
     64#define SLIC_ISR_ERR			0x80000000
     65#define SLIC_ISR_RCV			0x40000000
     66#define SLIC_ISR_CMD			0x20000000
     67#define SLIC_ISR_IO			0x60000000
     68#define SLIC_ISR_UPC			0x10000000
     69#define SLIC_ISR_LEVENT			0x08000000
     70#define SLIC_ISR_RMISS			0x02000000
     71#define SLIC_ISR_UPCERR			0x01000000
     72#define SLIC_ISR_XDROP			0x00800000
     73#define SLIC_ISR_UPCBSY			0x00020000
     74
     75#define SLIC_ISR_PING_MASK		0x00700000
     76#define SLIC_ISR_UPCERR_MASK		(SLIC_ISR_UPCERR | SLIC_ISR_UPCBSY)
     77#define SLIC_ISR_UPC_MASK		(SLIC_ISR_UPC | SLIC_ISR_UPCERR_MASK)
     78#define SLIC_WCS_START			0x80000000
     79#define SLIC_WCS_COMPARE		0x40000000
     80#define SLIC_RCVWCS_BEGIN		0x40000000
     81#define SLIC_RCVWCS_FINISH		0x80000000
     82
     83#define SLIC_MIICR_REG_16		0x00100000
     84#define SLIC_MRV_REG16_XOVERON		0x0068
     85
     86#define SLIC_GIG_LINKUP			0x0001
     87#define SLIC_GIG_FULLDUPLEX		0x0002
     88#define SLIC_GIG_SPEED_MASK		0x000C
     89#define SLIC_GIG_SPEED_1000		0x0008
     90#define SLIC_GIG_SPEED_100		0x0004
     91#define SLIC_GIG_SPEED_10		0x0000
     92
     93#define SLIC_GMCR_RESET			0x80000000
     94#define SLIC_GMCR_GBIT			0x20000000
     95#define SLIC_GMCR_FULLD			0x10000000
     96#define SLIC_GMCR_GAPBB_SHIFT		14
     97#define SLIC_GMCR_GAPR1_SHIFT		7
     98#define SLIC_GMCR_GAPR2_SHIFT		0
     99#define SLIC_GMCR_GAPBB_1000		0x60
    100#define SLIC_GMCR_GAPR1_1000		0x2C
    101#define SLIC_GMCR_GAPR2_1000		0x40
    102#define SLIC_GMCR_GAPBB_100		0x70
    103#define SLIC_GMCR_GAPR1_100		0x2C
    104#define SLIC_GMCR_GAPR2_100		0x40
    105
    106#define SLIC_XCR_RESET			0x80000000
    107#define SLIC_XCR_XMTEN			0x40000000
    108#define SLIC_XCR_PAUSEEN		0x20000000
    109#define SLIC_XCR_LOADRNG		0x10000000
    110
    111#define SLIC_GXCR_RESET			0x80000000
    112#define SLIC_GXCR_XMTEN			0x40000000
    113#define SLIC_GXCR_PAUSEEN		0x20000000
    114
    115#define SLIC_GRCR_RESET			0x80000000
    116#define SLIC_GRCR_RCVEN			0x40000000
    117#define SLIC_GRCR_RCVALL		0x20000000
    118#define SLIC_GRCR_RCVBAD		0x10000000
    119#define SLIC_GRCR_CTLEN			0x08000000
    120#define SLIC_GRCR_ADDRAEN		0x02000000
    121#define SLIC_GRCR_HASHSIZE_SHIFT	17
    122#define SLIC_GRCR_HASHSIZE		14
    123
    124/* Reset Register */
    125#define SLIC_REG_RESET			0x0000
    126/* Interrupt Control Register */
    127#define SLIC_REG_ICR			0x0008
    128/* Interrupt status pointer */
    129#define SLIC_REG_ISP			0x0010
    130/* Interrupt status */
    131#define SLIC_REG_ISR			0x0018
    132/* Header buffer address reg
    133 * 31-8 - phy addr of set of contiguous hdr buffers
    134 *  7-0 - number of buffers passed
    135 * Buffers are 256 bytes long on 256-byte boundaries.
    136 */
    137#define SLIC_REG_HBAR			0x0020
    138/* Data buffer handle & address reg
    139 * 4 sets of registers; Buffers are 2K bytes long 2 per 4K page.
    140 */
    141#define SLIC_REG_DBAR			0x0028
    142/* Xmt Cmd buf addr regs.
    143 * 1 per XMT interface
    144 * 31-5 - phy addr of host command buffer
    145 *  4-0 - length of cmd in multiples of 32 bytes
    146 * Buffers are 32 bytes up to 512 bytes long
    147 */
    148#define SLIC_REG_CBAR			0x0030
    149/* Write control store */
    150#define	SLIC_REG_WCS			0x0034
    151/*Response buffer address reg.
    152 * 31-8 - phy addr of set of contiguous response buffers
    153 * 7-0 - number of buffers passed
    154 * Buffers are 32 bytes long on 32-byte boundaries.
    155 */
    156#define	SLIC_REG_RBAR			0x0038
    157/* Read statistics (UPR) */
    158#define	SLIC_REG_RSTAT			0x0040
    159/* Read link status */
    160#define	SLIC_REG_LSTAT			0x0048
    161/* Write Mac Config */
    162#define	SLIC_REG_WMCFG			0x0050
    163/* Write phy register */
    164#define SLIC_REG_WPHY			0x0058
    165/* Rcv Cmd buf addr reg */
    166#define	SLIC_REG_RCBAR			0x0060
    167/* Read SLIC Config*/
    168#define SLIC_REG_RCONFIG		0x0068
    169/* Interrupt aggregation time */
    170#define SLIC_REG_INTAGG			0x0070
    171/* Write XMIT config reg */
    172#define	SLIC_REG_WXCFG			0x0078
    173/* Write RCV config reg */
    174#define	SLIC_REG_WRCFG			0x0080
    175/* Write rcv addr a low */
    176#define	SLIC_REG_WRADDRAL		0x0088
    177/* Write rcv addr a high */
    178#define	SLIC_REG_WRADDRAH		0x0090
    179/* Write rcv addr b low */
    180#define	SLIC_REG_WRADDRBL		0x0098
    181/* Write rcv addr b high */
    182#define	SLIC_REG_WRADDRBH		0x00a0
    183/* Low bits of mcast mask */
    184#define	SLIC_REG_MCASTLOW		0x00a8
    185/* High bits of mcast mask */
    186#define	SLIC_REG_MCASTHIGH		0x00b0
    187/* Ping the card */
    188#define SLIC_REG_PING			0x00b8
    189/* Dump command */
    190#define SLIC_REG_DUMP_CMD		0x00c0
    191/* Dump data pointer */
    192#define SLIC_REG_DUMP_DATA		0x00c8
    193/* Read card's pci_status register */
    194#define	SLIC_REG_PCISTATUS		0x00d0
    195/* Write hostid field */
    196#define SLIC_REG_WRHOSTID		0x00d8
    197/* Put card in a low power state */
    198#define SLIC_REG_LOW_POWER		0x00e0
    199/* Force slic into quiescent state  before soft reset */
    200#define SLIC_REG_QUIESCE		0x00e8
    201/* Reset interface queues */
    202#define SLIC_REG_RESET_IFACE		0x00f0
    203/* Register is only written when it has changed.
    204 * Bits 63-32 for host i/f addrs.
    205 */
    206#define SLIC_REG_ADDR_UPPER		0x00f8
    207/* 64 bit Header buffer address reg */
    208#define SLIC_REG_HBAR64			0x0100
    209/* 64 bit Data buffer handle & address reg */
    210#define SLIC_REG_DBAR64			0x0108
    211/* 64 bit Xmt Cmd buf addr regs. */
    212#define SLIC_REG_CBAR64			0x0110
    213/* 64 bit Response buffer address reg.*/
    214#define SLIC_REG_RBAR64			0x0118
    215/* 64 bit Rcv Cmd buf addr reg*/
    216#define	SLIC_REG_RCBAR64		0x0120
    217/* Read statistics (64 bit UPR) */
    218#define	SLIC_REG_RSTAT64		0x0128
    219/* Download Gigabit RCV sequencer ucode */
    220#define SLIC_REG_RCV_WCS		0x0130
    221/* Write VlanId field */
    222#define SLIC_REG_WRVLANID		0x0138
    223/* Read Transformer info */
    224#define SLIC_REG_READ_XF_INFO		0x0140
    225/* Write Transformer info */
    226#define SLIC_REG_WRITE_XF_INFO		0x0148
    227/* Write card ticks per second */
    228#define SLIC_REG_TICKS_PER_SEC		0x0170
    229#define SLIC_REG_HOSTID			0x1554
    230
    231#define PCI_VENDOR_ID_ALACRITECH		0x139A
    232#define PCI_DEVICE_ID_ALACRITECH_MOJAVE		0x0005
    233#define PCI_SUBDEVICE_ID_ALACRITECH_1000X1	0x0005
    234#define PCI_SUBDEVICE_ID_ALACRITECH_1000X1_2	0x0006
    235#define PCI_SUBDEVICE_ID_ALACRITECH_1000X1F	0x0007
    236#define PCI_SUBDEVICE_ID_ALACRITECH_CICADA	0x0008
    237#define PCI_SUBDEVICE_ID_ALACRITECH_SES1001T	0x2006
    238#define PCI_SUBDEVICE_ID_ALACRITECH_SES1001F	0x2007
    239#define PCI_DEVICE_ID_ALACRITECH_OASIS		0x0007
    240#define PCI_SUBDEVICE_ID_ALACRITECH_SEN2002XT	0x000B
    241#define PCI_SUBDEVICE_ID_ALACRITECH_SEN2002XF	0x000C
    242#define PCI_SUBDEVICE_ID_ALACRITECH_SEN2001XT	0x000D
    243#define PCI_SUBDEVICE_ID_ALACRITECH_SEN2001XF	0x000E
    244#define PCI_SUBDEVICE_ID_ALACRITECH_SEN2104EF	0x000F
    245#define PCI_SUBDEVICE_ID_ALACRITECH_SEN2104ET	0x0010
    246#define PCI_SUBDEVICE_ID_ALACRITECH_SEN2102EF	0x0011
    247#define PCI_SUBDEVICE_ID_ALACRITECH_SEN2102ET	0x0012
    248
    249/* Note: power of two required for number descriptors  */
    250#define SLIC_NUM_RX_LES			256
    251#define SLIC_RX_BUFF_SIZE		2048
    252#define SLIC_RX_BUFF_ALIGN		256
    253#define SLIC_RX_BUFF_HDR_SIZE		34
    254#define SLIC_MAX_REQ_RX_DESCS		1
    255
    256#define SLIC_NUM_TX_DESCS		256
    257#define SLIC_TX_DESC_ALIGN		32
    258#define SLIC_MIN_TX_WAKEUP_DESCS	10
    259#define SLIC_MAX_REQ_TX_DESCS		1
    260#define SLIC_MAX_TX_COMPLETIONS		100
    261
    262#define SLIC_NUM_STAT_DESCS		128
    263#define SLIC_STATS_DESC_ALIGN		256
    264
    265#define SLIC_NUM_STAT_DESC_ARRAYS	4
    266#define SLIC_INVALID_STAT_DESC_IDX	0xffffffff
    267
    268#define SLIC_UPR_LSTAT			0
    269#define SLIC_UPR_CONFIG			1
    270
    271#define SLIC_EEPROM_SIZE		128
    272#define SLIC_EEPROM_MAGIC		0xa5a5
    273
    274#define SLIC_FIRMWARE_MOJAVE		"slicoss/gbdownload.sys"
    275#define SLIC_FIRMWARE_OASIS		"slicoss/oasisdownload.sys"
    276#define SLIC_RCV_FIRMWARE_MOJAVE	"slicoss/gbrcvucode.sys"
    277#define SLIC_RCV_FIRMWARE_OASIS		"slicoss/oasisrcvucode.sys"
    278#define SLIC_FIRMWARE_MIN_SIZE		64
    279#define SLIC_FIRMWARE_MAX_SECTIONS	3
    280
    281#define SLIC_MODEL_MOJAVE		0
    282#define SLIC_MODEL_OASIS		1
    283
    284#define SLIC_INC_STATS_COUNTER(st, counter)	\
    285do {						\
    286	u64_stats_update_begin(&(st)->syncp);	\
    287	(st)->counter++;			\
    288	u64_stats_update_end(&(st)->syncp);	\
    289} while (0)
    290
    291#define SLIC_GET_STATS_COUNTER(newst, st, counter)			\
    292{									\
    293	unsigned int start;						\
    294	do {							\
    295		start = u64_stats_fetch_begin_irq(&(st)->syncp);	\
    296		newst = (st)->counter;					\
    297	} while (u64_stats_fetch_retry_irq(&(st)->syncp, start));	\
    298}
    299
    300struct slic_upr {
    301	dma_addr_t paddr;
    302	unsigned int type;
    303	struct list_head list;
    304};
    305
    306struct slic_upr_list {
    307	bool pending;
    308	struct list_head list;
    309	/* upr list lock */
    310	spinlock_t lock;
    311};
    312
    313/* SLIC EEPROM structure for Mojave */
    314struct slic_mojave_eeprom {
    315	__le16 id;		/* 00 EEPROM/FLASH Magic code 'A5A5'*/
    316	__le16 eeprom_code_size;/* 01 Size of EEPROM Codes (bytes * 4)*/
    317	__le16 flash_size;	/* 02 Flash size */
    318	__le16 eeprom_size;	/* 03 EEPROM Size */
    319	__le16 vendor_id;	/* 04 Vendor ID */
    320	__le16 dev_id;		/* 05 Device ID */
    321	u8 rev_id;		/* 06 Revision ID */
    322	u8 class_code[3];	/* 07 Class Code */
    323	u8 irqpin_dbg;		/* 08 Debug Interrupt pin */
    324	u8 irqpin;		/*    Network Interrupt Pin */
    325	u8 min_grant;		/* 09 Minimum grant */
    326	u8 max_lat;		/*    Maximum Latency */
    327	__le16 pci_stat;	/* 10 PCI Status */
    328	__le16 sub_vendor_id;	/* 11 Subsystem Vendor Id */
    329	__le16 sub_id;		/* 12 Subsystem ID */
    330	__le16 dev_id_dbg;	/* 13 Debug Device Id */
    331	__le16 ramrom;		/* 14 Dram/Rom function */
    332	__le16 dram_size2pci;	/* 15 DRAM size to PCI (bytes * 64K) */
    333	__le16 rom_size2pci;	/* 16 ROM extension size to PCI (bytes * 4k) */
    334	u8 pad[2];		/* 17 Padding */
    335	u8 freetime;		/* 18 FreeTime setting */
    336	u8 ifctrl;		/* 10-bit interface control (Mojave only) */
    337	__le16 dram_size;	/* 19 DRAM size (bytes * 64k) */
    338	u8 mac[ETH_ALEN];	/* 20 MAC addresses */
    339	u8 mac2[ETH_ALEN];
    340	u8 pad2[6];
    341	u16 dev_id2;		/* Device ID for 2nd PCI function */
    342	u8 irqpin2;		/* Interrupt pin for 2nd PCI function */
    343	u8 class_code2[3];	/* Class Code for 2nd PCI function */
    344	u16 cfg_byte6;		/* Config Byte 6 */
    345	u16 pme_cap;		/* Power Mgment capabilities */
    346	u16 nwclk_ctrl;		/* NetworkClockControls */
    347	u8 fru_format;		/* Alacritech FRU format type */
    348	u8 fru_assembly[6];	/* Alacritech FRU information */
    349	u8 fru_rev[2];
    350	u8 fru_serial[14];
    351	u8 fru_pad[3];
    352	u8 oem_fru[28];		/* optional OEM FRU format type */
    353	u8 pad3[4];		/* Pad to 128 bytes - includes 2 cksum bytes
    354				 * (if OEM FRU info exists) and two unusable
    355				 * bytes at the end
    356				 */
    357};
    358
    359/* SLIC EEPROM structure for Oasis */
    360struct slic_oasis_eeprom {
    361	__le16 id;		/* 00 EEPROM/FLASH Magic code 'A5A5' */
    362	__le16 eeprom_code_size;/* 01 Size of EEPROM Codes (bytes * 4)*/
    363	__le16 spidev0_cfg;	/* 02 Flash Config for SPI device 0 */
    364	__le16 spidev1_cfg;	/* 03 Flash Config for SPI device 1 */
    365	__le16 vendor_id;	/* 04 Vendor ID */
    366	__le16 dev_id;		/* 05 Device ID (function 0) */
    367	u8 rev_id;		/* 06 Revision ID */
    368	u8 class_code0[3];	/* 07 Class Code for PCI function 0 */
    369	u8 irqpin1;		/* 08 Interrupt pin for PCI function 1*/
    370	u8 class_code1[3];	/* 09 Class Code for PCI function 1 */
    371	u8 irqpin2;		/* 10 Interrupt pin for PCI function 2*/
    372	u8 irqpin0;		/*    Interrupt pin for PCI function 0*/
    373	u8 min_grant;		/* 11 Minimum grant */
    374	u8 max_lat;		/*    Maximum Latency */
    375	__le16 sub_vendor_id;	/* 12 Subsystem Vendor Id */
    376	__le16 sub_id;		/* 13 Subsystem ID */
    377	__le16 flash_size;	/* 14 Flash size (bytes / 4K) */
    378	__le16 dram_size2pci;	/* 15 DRAM size to PCI (bytes / 64K) */
    379	__le16 rom_size2pci;	/* 16 Flash (ROM extension) size to PCI
    380				 *   (bytes / 4K)
    381				 */
    382	__le16 dev_id1;		/* 17 Device Id (function 1) */
    383	__le16 dev_id2;		/* 18 Device Id (function 2) */
    384	__le16 dev_stat_cfg;	/* 19 Device Status Config Bytes 6-7 */
    385	__le16 pme_cap;		/* 20 Power Mgment capabilities */
    386	u8 msi_cap;		/* 21 MSI capabilities */
    387	u8 clock_div;		/*    Clock divider */
    388	__le16 pci_stat_lo;	/* 22 PCI Status bits 15:0 */
    389	__le16 pci_stat_hi;	/* 23 PCI Status bits 31:16 */
    390	__le16 dram_cfg_lo;	/* 24 DRAM Configuration bits 15:0 */
    391	__le16 dram_cfg_hi;	/* 25 DRAM Configuration bits 31:16 */
    392	__le16 dram_size;	/* 26 DRAM size (bytes / 64K) */
    393	__le16 gpio_tbi_ctrl;	/* 27 GPIO/TBI controls for functions 1/0 */
    394	__le16 eeprom_size;	/* 28 EEPROM Size */
    395	u8 mac[ETH_ALEN];	/* 29 MAC addresses (2 ports) */
    396	u8 mac2[ETH_ALEN];
    397	u8 fru_format;		/* 35 Alacritech FRU format type */
    398	u8 fru_assembly[6];	/* Alacritech FRU information */
    399	u8 fru_rev[2];
    400	u8 fru_serial[14];
    401	u8 fru_pad[3];
    402	u8 oem_fru[28];		/* optional OEM FRU information */
    403	u8 pad[4];		/* Pad to 128 bytes - includes 2 checksum bytes
    404				 * (if OEM FRU info exists) and two unusable
    405				 * bytes at the end
    406				 */
    407};
    408
    409struct slic_stats {
    410	u64 rx_packets;
    411	u64 rx_bytes;
    412	u64 rx_mcasts;
    413	u64 rx_errors;
    414	u64 tx_packets;
    415	u64 tx_bytes;
    416	/* HW STATS */
    417	u64 rx_buff_miss;
    418	u64 tx_dropped;
    419	u64 irq_errs;
    420	/* transport layer */
    421	u64 rx_tpcsum;
    422	u64 rx_tpoflow;
    423	u64 rx_tphlen;
    424	/* ip layer */
    425	u64 rx_ipcsum;
    426	u64 rx_iplen;
    427	u64 rx_iphlen;
    428	/* link layer */
    429	u64 rx_early;
    430	u64 rx_buffoflow;
    431	u64 rx_lcode;
    432	u64 rx_drbl;
    433	u64 rx_crc;
    434	u64 rx_oflow802;
    435	u64 rx_uflow802;
    436	/* oasis only */
    437	u64 tx_carrier;
    438	struct u64_stats_sync syncp;
    439};
    440
    441struct slic_shmem_data {
    442	__le32 isr;
    443	__le32 link;
    444};
    445
    446struct slic_shmem {
    447	dma_addr_t isr_paddr;
    448	dma_addr_t link_paddr;
    449	struct slic_shmem_data *shmem_data;
    450};
    451
    452struct slic_rx_info_oasis {
    453	__le32 frame_status;
    454	__le32 frame_status_b;
    455	__le32 time_stamp;
    456	__le32 checksum;
    457};
    458
    459struct slic_rx_info_mojave {
    460	__le32 frame_status;
    461	__le16 byte_cnt;
    462	__le16 tp_chksum;
    463	__le16 ctx_hash;
    464	__le16 mac_hash;
    465	__le16 buff_lnk;
    466};
    467
    468struct slic_stat_desc {
    469	__le32 hnd;
    470	__u8 pad[8];
    471	__le32 status;
    472	__u8 pad2[16];
    473};
    474
    475struct slic_stat_queue {
    476	struct slic_stat_desc *descs[SLIC_NUM_STAT_DESC_ARRAYS];
    477	dma_addr_t paddr[SLIC_NUM_STAT_DESC_ARRAYS];
    478	unsigned int addr_offset[SLIC_NUM_STAT_DESC_ARRAYS];
    479	unsigned int active_array;
    480	unsigned int len;
    481	unsigned int done_idx;
    482	size_t mem_size;
    483};
    484
    485struct slic_tx_desc {
    486	__le32 hnd;
    487	__le32 rsvd;
    488	u8 cmd;
    489	u8 flags;
    490	__le16 rsvd2;
    491	__le32 totlen;
    492	__le32 paddrl;
    493	__le32 paddrh;
    494	__le32 len;
    495	__le32 type;
    496};
    497
    498struct slic_tx_buffer {
    499	struct sk_buff *skb;
    500	DEFINE_DMA_UNMAP_ADDR(map_addr);
    501	DEFINE_DMA_UNMAP_LEN(map_len);
    502	struct slic_tx_desc *desc;
    503	dma_addr_t desc_paddr;
    504};
    505
    506struct slic_tx_queue {
    507	struct dma_pool *dma_pool;
    508	struct slic_tx_buffer *txbuffs;
    509	unsigned int len;
    510	unsigned int put_idx;
    511	unsigned int done_idx;
    512};
    513
    514struct slic_rx_desc {
    515	u8 pad[16];
    516	__le32 buffer;
    517	__le32 length;
    518	__le32 status;
    519};
    520
    521struct slic_rx_buffer {
    522	struct sk_buff *skb;
    523	DEFINE_DMA_UNMAP_ADDR(map_addr);
    524	DEFINE_DMA_UNMAP_LEN(map_len);
    525	unsigned int addr_offset;
    526};
    527
    528struct slic_rx_queue {
    529	struct slic_rx_buffer *rxbuffs;
    530	unsigned int len;
    531	unsigned int done_idx;
    532	unsigned int put_idx;
    533};
    534
    535struct slic_device {
    536	struct pci_dev *pdev;
    537	struct net_device *netdev;
    538	void __iomem *regs;
    539	/* upper address setting lock */
    540	spinlock_t upper_lock;
    541	struct slic_shmem shmem;
    542	struct napi_struct napi;
    543	struct slic_rx_queue rxq;
    544	struct slic_tx_queue txq;
    545	struct slic_stat_queue stq;
    546	struct slic_stats stats;
    547	struct slic_upr_list upr_list;
    548	/* link configuration lock */
    549	spinlock_t link_lock;
    550	bool promisc;
    551	int speed;
    552	unsigned int duplex;
    553	bool is_fiber;
    554	unsigned char model;
    555};
    556
    557static inline u32 slic_read(struct slic_device *sdev, unsigned int reg)
    558{
    559	return ioread32(sdev->regs + reg);
    560}
    561
    562static inline void slic_write(struct slic_device *sdev, unsigned int reg,
    563			      u32 val)
    564{
    565	iowrite32(val, sdev->regs + reg);
    566}
    567
    568static inline void slic_flush_write(struct slic_device *sdev)
    569{
    570	(void)ioread32(sdev->regs + SLIC_REG_HOSTID);
    571}
    572
    573#endif /* _SLIC_H */