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(&(st)->syncp); \
296 newst = (st)->counter; \
297 } while (u64_stats_fetch_retry(&(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 */
574

source code of linux/drivers/net/ethernet/alacritech/slic.h