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) \ 285 do { \ 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 300 struct slic_upr { 301 dma_addr_t paddr; 302 unsigned int type; 303 struct list_head list; 304 }; 305 306 struct 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 */ 314 struct 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 */ 360 struct 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 409 struct 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 441 struct slic_shmem_data { 442 __le32 isr; 443 __le32 link; 444 }; 445 446 struct slic_shmem { 447 dma_addr_t isr_paddr; 448 dma_addr_t link_paddr; 449 struct slic_shmem_data *shmem_data; 450 }; 451 452 struct slic_rx_info_oasis { 453 __le32 frame_status; 454 __le32 frame_status_b; 455 __le32 time_stamp; 456 __le32 checksum; 457 }; 458 459 struct 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 468 struct slic_stat_desc { 469 __le32 hnd; 470 __u8 pad[8]; 471 __le32 status; 472 __u8 pad2[16]; 473 }; 474 475 struct 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 485 struct 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 498 struct 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 506 struct 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 514 struct slic_rx_desc { 515 u8 pad[16]; 516 __le32 buffer; 517 __le32 length; 518 __le32 status; 519 }; 520 521 struct 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 528 struct 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 535 struct 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 557 static inline u32 slic_read(struct slic_device *sdev, unsigned int reg) 558 { 559 return ioread32(sdev->regs + reg); 560 } 561 562 static inline void slic_write(struct slic_device *sdev, unsigned int reg, 563 u32 val) 564 { 565 iowrite32(val, sdev->regs + reg); 566 } 567 568 static 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