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