1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */ 2503c599aSAditya Srivastava /* 3d70e5326SJon Ringle * encx24j600_hw.h: Register definitions 4d70e5326SJon Ringle * 5d70e5326SJon Ringle */ 6d70e5326SJon Ringle 7d70e5326SJon Ringle #ifndef _ENCX24J600_HW_H 8d70e5326SJon Ringle #define _ENCX24J600_HW_H 9d70e5326SJon Ringle 10d70e5326SJon Ringle struct encx24j600_context { 11d70e5326SJon Ringle struct spi_device *spi; 12d70e5326SJon Ringle struct regmap *regmap; 13d70e5326SJon Ringle struct regmap *phymap; 14d70e5326SJon Ringle struct mutex mutex; /* mutex to protect access to regmap */ 15d70e5326SJon Ringle int bank; 16d70e5326SJon Ringle }; 17d70e5326SJon Ringle 18*f03dca0cSNanyong Sun int devm_regmap_init_encx24j600(struct device *dev, 19d70e5326SJon Ringle struct encx24j600_context *ctx); 20d70e5326SJon Ringle 21d70e5326SJon Ringle /* Single-byte instructions */ 22d70e5326SJon Ringle #define BANK_SELECT(bank) (0xC0 | ((bank & (BANK_MASK >> BANK_SHIFT)) << 1)) 23d70e5326SJon Ringle #define B0SEL 0xC0 /* Bank 0 Select */ 24d70e5326SJon Ringle #define B1SEL 0xC2 /* Bank 1 Select */ 25d70e5326SJon Ringle #define B2SEL 0xC4 /* Bank 2 Select */ 26d70e5326SJon Ringle #define B3SEL 0xC6 /* Bank 3 Select */ 27d70e5326SJon Ringle #define SETETHRST 0xCA /* System Reset */ 28d70e5326SJon Ringle #define FCDISABLE 0xE0 /* Flow Control Disable */ 29d70e5326SJon Ringle #define FCSINGLE 0xE2 /* Flow Control Single */ 30d70e5326SJon Ringle #define FCMULTIPLE 0xE4 /* Flow Control Multiple */ 31d70e5326SJon Ringle #define FCCLEAR 0xE6 /* Flow Control Clear */ 32d70e5326SJon Ringle #define SETPKTDEC 0xCC /* Decrement Packet Counter */ 33d70e5326SJon Ringle #define DMASTOP 0xD2 /* DMA Stop */ 34d70e5326SJon Ringle #define DMACKSUM 0xD8 /* DMA Start Checksum */ 35d70e5326SJon Ringle #define DMACKSUMS 0xDA /* DMA Start Checksum with Seed */ 36d70e5326SJon Ringle #define DMACOPY 0xDC /* DMA Start Copy */ 37d70e5326SJon Ringle #define DMACOPYS 0xDE /* DMA Start Copy and Checksum with Seed */ 38d70e5326SJon Ringle #define SETTXRTS 0xD4 /* Request Packet Transmission */ 39d70e5326SJon Ringle #define ENABLERX 0xE8 /* Enable RX */ 40d70e5326SJon Ringle #define DISABLERX 0xEA /* Disable RX */ 41d70e5326SJon Ringle #define SETEIE 0xEC /* Enable Interrupts */ 42d70e5326SJon Ringle #define CLREIE 0xEE /* Disable Interrupts */ 43d70e5326SJon Ringle 44d70e5326SJon Ringle /* Two byte instructions */ 45d70e5326SJon Ringle #define RBSEL 0xC8 /* Read Bank Select */ 46d70e5326SJon Ringle 47d70e5326SJon Ringle /* Three byte instructions */ 48d70e5326SJon Ringle #define WGPRDPT 0x60 /* Write EGPRDPT */ 49d70e5326SJon Ringle #define RGPRDPT 0x62 /* Read EGPRDPT */ 50d70e5326SJon Ringle #define WRXRDPT 0x64 /* Write ERXRDPT */ 51d70e5326SJon Ringle #define RRXRDPT 0x66 /* Read ERXRDPT */ 52d70e5326SJon Ringle #define WUDARDPT 0x68 /* Write EUDARDPT */ 53d70e5326SJon Ringle #define RUDARDPT 0x6A /* Read EUDARDPT */ 54d70e5326SJon Ringle #define WGPWRPT 0x6C /* Write EGPWRPT */ 55d70e5326SJon Ringle #define RGPWRPT 0x6E /* Read EGPWRPT */ 56d70e5326SJon Ringle #define WRXWRPT 0x70 /* Write ERXWRPT */ 57d70e5326SJon Ringle #define RRXWRPT 0x72 /* Read ERXWRPT */ 58d70e5326SJon Ringle #define WUDAWRPT 0x74 /* Write EUDAWRPT */ 59d70e5326SJon Ringle #define RUDAWRPT 0x76 /* Read EUDAWRPT */ 60d70e5326SJon Ringle 61d70e5326SJon Ringle /* n byte instructions */ 62d70e5326SJon Ringle #define RCRCODE 0x00 63d70e5326SJon Ringle #define WCRCODE 0x40 64d70e5326SJon Ringle #define BFSCODE 0x80 65d70e5326SJon Ringle #define BFCCODE 0xA0 66d70e5326SJon Ringle #define RCR(addr) (RCRCODE | (addr & ADDR_MASK)) /* Read Control Register */ 67d70e5326SJon Ringle #define WCR(addr) (WCRCODE | (addr & ADDR_MASK)) /* Write Control Register */ 68d70e5326SJon Ringle #define RCRU 0x20 /* Read Control Register Unbanked */ 69d70e5326SJon Ringle #define WCRU 0x22 /* Write Control Register Unbanked */ 70d70e5326SJon Ringle #define BFS(addr) (BFSCODE | (addr & ADDR_MASK)) /* Bit Field Set */ 71d70e5326SJon Ringle #define BFC(addr) (BFCCODE | (addr & ADDR_MASK)) /* Bit Field Clear */ 72d70e5326SJon Ringle #define BFSU 0x24 /* Bit Field Set Unbanked */ 73d70e5326SJon Ringle #define BFCU 0x26 /* Bit Field Clear Unbanked */ 74d70e5326SJon Ringle #define RGPDATA 0x28 /* Read EGPDATA */ 75d70e5326SJon Ringle #define WGPDATA 0x2A /* Write EGPDATA */ 76d70e5326SJon Ringle #define RRXDATA 0x2C /* Read ERXDATA */ 77d70e5326SJon Ringle #define WRXDATA 0x2E /* Write ERXDATA */ 78d70e5326SJon Ringle #define RUDADATA 0x30 /* Read EUDADATA */ 79d70e5326SJon Ringle #define WUDADATA 0x32 /* Write EUDADATA */ 80d70e5326SJon Ringle 81d70e5326SJon Ringle #define SFR_REG_COUNT 0xA0 82d70e5326SJon Ringle 83d70e5326SJon Ringle /* ENC424J600 Control Registers 84d70e5326SJon Ringle * Control register definitions are a combination of address 85d70e5326SJon Ringle * and bank number 86d70e5326SJon Ringle * - Register address (bits 0-4) 87d70e5326SJon Ringle * - Bank number (bits 5-6) 88d70e5326SJon Ringle */ 89d70e5326SJon Ringle #define ADDR_MASK 0x1F 90d70e5326SJon Ringle #define BANK_MASK 0x60 91d70e5326SJon Ringle #define BANK_SHIFT 5 92d70e5326SJon Ringle 93d70e5326SJon Ringle /* All-bank registers */ 94d70e5326SJon Ringle #define EUDAST 0x16 95d70e5326SJon Ringle #define EUDAND 0x18 96d70e5326SJon Ringle #define ESTAT 0x1A 97d70e5326SJon Ringle #define EIR 0x1C 98d70e5326SJon Ringle #define ECON1 0x1E 99d70e5326SJon Ringle 100d70e5326SJon Ringle /* Bank 0 registers */ 101d70e5326SJon Ringle #define ETXST (0x00 | 0x00) 102d70e5326SJon Ringle #define ETXLEN (0x02 | 0x00) 103d70e5326SJon Ringle #define ERXST (0x04 | 0x00) 104d70e5326SJon Ringle #define ERXTAIL (0x06 | 0x00) 105d70e5326SJon Ringle #define ERXHEAD (0x08 | 0x00) 106d70e5326SJon Ringle #define EDMAST (0x0A | 0x00) 107d70e5326SJon Ringle #define EDMALEN (0x0C | 0x00) 108d70e5326SJon Ringle #define EDMADST (0x0E | 0x00) 109d70e5326SJon Ringle #define EDMACS (0x10 | 0x00) 110d70e5326SJon Ringle #define ETXSTAT (0x12 | 0x00) 111d70e5326SJon Ringle #define ETXWIRE (0x14 | 0x00) 112d70e5326SJon Ringle 113d70e5326SJon Ringle /* Bank 1 registers */ 114d70e5326SJon Ringle #define EHT1 (0x00 | 0x20) 115d70e5326SJon Ringle #define EHT2 (0x02 | 0x20) 116d70e5326SJon Ringle #define EHT3 (0x04 | 0x20) 117d70e5326SJon Ringle #define EHT4 (0x06 | 0x20) 118d70e5326SJon Ringle #define EPMM1 (0x08 | 0x20) 119d70e5326SJon Ringle #define EPMM2 (0x0A | 0x20) 120d70e5326SJon Ringle #define EPMM3 (0x0C | 0x20) 121d70e5326SJon Ringle #define EPMM4 (0x0E | 0x20) 122d70e5326SJon Ringle #define EPMCS (0x10 | 0x20) 123d70e5326SJon Ringle #define EPMO (0x12 | 0x20) 124d70e5326SJon Ringle #define ERXFCON (0x14 | 0x20) 125d70e5326SJon Ringle 126d70e5326SJon Ringle /* Bank 2 registers */ 127d70e5326SJon Ringle #define MACON1 (0x00 | 0x40) 128d70e5326SJon Ringle #define MACON2 (0x02 | 0x40) 129d70e5326SJon Ringle #define MABBIPG (0x04 | 0x40) 130d70e5326SJon Ringle #define MAIPG (0x06 | 0x40) 131d70e5326SJon Ringle #define MACLCON (0x08 | 0x40) 132d70e5326SJon Ringle #define MAMXFL (0x0A | 0x40) 133d70e5326SJon Ringle #define MICMD (0x12 | 0x40) 134d70e5326SJon Ringle #define MIREGADR (0x14 | 0x40) 135d70e5326SJon Ringle 136d70e5326SJon Ringle /* Bank 3 registers */ 137d70e5326SJon Ringle #define MAADR3 (0x00 | 0x60) 138d70e5326SJon Ringle #define MAADR2 (0x02 | 0x60) 139d70e5326SJon Ringle #define MAADR1 (0x04 | 0x60) 140d70e5326SJon Ringle #define MIWR (0x06 | 0x60) 141d70e5326SJon Ringle #define MIRD (0x08 | 0x60) 142d70e5326SJon Ringle #define MISTAT (0x0A | 0x60) 143d70e5326SJon Ringle #define EPAUS (0x0C | 0x60) 144d70e5326SJon Ringle #define ECON2 (0x0E | 0x60) 145d70e5326SJon Ringle #define ERXWM (0x10 | 0x60) 146d70e5326SJon Ringle #define EIE (0x12 | 0x60) 147d70e5326SJon Ringle #define EIDLED (0x14 | 0x60) 148d70e5326SJon Ringle 149d70e5326SJon Ringle /* Unbanked registers */ 150d70e5326SJon Ringle #define EGPDATA (0x00 | 0x80) 151d70e5326SJon Ringle #define ERXDATA (0x02 | 0x80) 152d70e5326SJon Ringle #define EUDADATA (0x04 | 0x80) 153d70e5326SJon Ringle #define EGPRDPT (0x06 | 0x80) 154d70e5326SJon Ringle #define EGPWRPT (0x08 | 0x80) 155d70e5326SJon Ringle #define ERXRDPT (0x0A | 0x80) 156d70e5326SJon Ringle #define ERXWRPT (0x0C | 0x80) 157d70e5326SJon Ringle #define EUDARDPT (0x0E | 0x80) 158d70e5326SJon Ringle #define EUDAWRPT (0x10 | 0x80) 159d70e5326SJon Ringle 160d70e5326SJon Ringle 161d70e5326SJon Ringle /* Register bit definitions */ 162d70e5326SJon Ringle /* ESTAT */ 163d70e5326SJon Ringle #define INT (1 << 15) 164d70e5326SJon Ringle #define FCIDLE (1 << 14) 165d70e5326SJon Ringle #define RXBUSY (1 << 13) 166d70e5326SJon Ringle #define CLKRDY (1 << 12) 167d70e5326SJon Ringle #define PHYDPX (1 << 10) 168d70e5326SJon Ringle #define PHYLNK (1 << 8) 169d70e5326SJon Ringle 170d70e5326SJon Ringle /* EIR */ 171d70e5326SJon Ringle #define CRYPTEN (1 << 15) 172d70e5326SJon Ringle #define MODEXIF (1 << 14) 173d70e5326SJon Ringle #define HASHIF (1 << 13) 174d70e5326SJon Ringle #define AESIF (1 << 12) 175d70e5326SJon Ringle #define LINKIF (1 << 11) 176d70e5326SJon Ringle #define PKTIF (1 << 6) 177d70e5326SJon Ringle #define DMAIF (1 << 5) 178d70e5326SJon Ringle #define TXIF (1 << 3) 179d70e5326SJon Ringle #define TXABTIF (1 << 2) 180d70e5326SJon Ringle #define RXABTIF (1 << 1) 181d70e5326SJon Ringle #define PCFULIF (1 << 0) 182d70e5326SJon Ringle 183d70e5326SJon Ringle /* ECON1 */ 184d70e5326SJon Ringle #define MODEXST (1 << 15) 185d70e5326SJon Ringle #define HASHEN (1 << 14) 186d70e5326SJon Ringle #define HASHOP (1 << 13) 187d70e5326SJon Ringle #define HASHLST (1 << 12) 188d70e5326SJon Ringle #define AESST (1 << 11) 189d70e5326SJon Ringle #define AESOP1 (1 << 10) 190d70e5326SJon Ringle #define AESOP0 (1 << 9) 191d70e5326SJon Ringle #define PKTDEC (1 << 8) 192d70e5326SJon Ringle #define FCOP1 (1 << 7) 193d70e5326SJon Ringle #define FCOP0 (1 << 6) 194d70e5326SJon Ringle #define DMAST (1 << 5) 195d70e5326SJon Ringle #define DMACPY (1 << 4) 196d70e5326SJon Ringle #define DMACSSD (1 << 3) 197d70e5326SJon Ringle #define DMANOCS (1 << 2) 198d70e5326SJon Ringle #define TXRTS (1 << 1) 199d70e5326SJon Ringle #define RXEN (1 << 0) 200d70e5326SJon Ringle 201d70e5326SJon Ringle /* ETXSTAT */ 202d70e5326SJon Ringle #define LATECOL (1 << 10) 203d70e5326SJon Ringle #define MAXCOL (1 << 9) 204d70e5326SJon Ringle #define EXDEFER (1 << 8) 205d70e5326SJon Ringle #define ETXSTATL_DEFER (1 << 7) 206d70e5326SJon Ringle #define CRCBAD (1 << 4) 207d70e5326SJon Ringle #define COLCNT_MASK 0xF 208d70e5326SJon Ringle 209d70e5326SJon Ringle /* ERXFCON */ 210d70e5326SJon Ringle #define HTEN (1 << 15) 211d70e5326SJon Ringle #define MPEN (1 << 14) 212d70e5326SJon Ringle #define NOTPM (1 << 12) 213d70e5326SJon Ringle #define PMEN3 (1 << 11) 214d70e5326SJon Ringle #define PMEN2 (1 << 10) 215d70e5326SJon Ringle #define PMEN1 (1 << 9) 216d70e5326SJon Ringle #define PMEN0 (1 << 8) 217d70e5326SJon Ringle #define CRCEEN (1 << 7) 218d70e5326SJon Ringle #define CRCEN (1 << 6) 219d70e5326SJon Ringle #define RUNTEEN (1 << 5) 220d70e5326SJon Ringle #define RUNTEN (1 << 4) 221d70e5326SJon Ringle #define UCEN (1 << 3) 222d70e5326SJon Ringle #define NOTMEEN (1 << 2) 223d70e5326SJon Ringle #define MCEN (1 << 1) 224d70e5326SJon Ringle #define BCEN (1 << 0) 225d70e5326SJon Ringle 226d70e5326SJon Ringle /* MACON1 */ 227d70e5326SJon Ringle #define LOOPBK (1 << 4) 228d70e5326SJon Ringle #define RXPAUS (1 << 2) 229d70e5326SJon Ringle #define PASSALL (1 << 1) 230d70e5326SJon Ringle 231d70e5326SJon Ringle /* MACON2 */ 232d70e5326SJon Ringle #define MACON2_DEFER (1 << 14) 233d70e5326SJon Ringle #define BPEN (1 << 13) 234d70e5326SJon Ringle #define NOBKOFF (1 << 12) 235d70e5326SJon Ringle #define PADCFG2 (1 << 7) 236d70e5326SJon Ringle #define PADCFG1 (1 << 6) 237d70e5326SJon Ringle #define PADCFG0 (1 << 5) 238d70e5326SJon Ringle #define TXCRCEN (1 << 4) 239d70e5326SJon Ringle #define PHDREN (1 << 3) 240d70e5326SJon Ringle #define HFRMEN (1 << 2) 241d70e5326SJon Ringle #define MACON2_RSV1 (1 << 1) 242d70e5326SJon Ringle #define FULDPX (1 << 0) 243d70e5326SJon Ringle 244d70e5326SJon Ringle /* MAIPG */ 245d70e5326SJon Ringle /* value of the high byte is given by the reserved bits, 246d70e5326SJon Ringle * value of the low byte is recomended setting of the 247d70e5326SJon Ringle * IPG parameter. 248d70e5326SJon Ringle */ 249d70e5326SJon Ringle #define MAIPGH_VAL 0x0C 250d70e5326SJon Ringle #define MAIPGL_VAL 0x12 251d70e5326SJon Ringle 252d70e5326SJon Ringle /* MIREGADRH */ 253d70e5326SJon Ringle #define MIREGADR_VAL (1 << 8) 254d70e5326SJon Ringle 255d70e5326SJon Ringle /* MIREGADRL */ 256d70e5326SJon Ringle #define PHREG_MASK 0x1F 257d70e5326SJon Ringle 258d70e5326SJon Ringle /* MICMD */ 259d70e5326SJon Ringle #define MIISCAN (1 << 1) 260d70e5326SJon Ringle #define MIIRD (1 << 0) 261d70e5326SJon Ringle 262d70e5326SJon Ringle /* MISTAT */ 263d70e5326SJon Ringle #define NVALID (1 << 2) 264d70e5326SJon Ringle #define SCAN (1 << 1) 265d70e5326SJon Ringle #define BUSY (1 << 0) 266d70e5326SJon Ringle 267d70e5326SJon Ringle /* ECON2 */ 268d70e5326SJon Ringle #define ETHEN (1 << 15) 269d70e5326SJon Ringle #define STRCH (1 << 14) 270d70e5326SJon Ringle #define TXMAC (1 << 13) 271d70e5326SJon Ringle #define SHA1MD5 (1 << 12) 272d70e5326SJon Ringle #define COCON3 (1 << 11) 273d70e5326SJon Ringle #define COCON2 (1 << 10) 274d70e5326SJon Ringle #define COCON1 (1 << 9) 275d70e5326SJon Ringle #define COCON0 (1 << 8) 276d70e5326SJon Ringle #define AUTOFC (1 << 7) 277d70e5326SJon Ringle #define TXRST (1 << 6) 278d70e5326SJon Ringle #define RXRST (1 << 5) 279d70e5326SJon Ringle #define ETHRST (1 << 4) 280d70e5326SJon Ringle #define MODLEN1 (1 << 3) 281d70e5326SJon Ringle #define MODLEN0 (1 << 2) 282d70e5326SJon Ringle #define AESLEN1 (1 << 1) 283d70e5326SJon Ringle #define AESLEN0 (1 << 0) 284d70e5326SJon Ringle 285d70e5326SJon Ringle /* EIE */ 286d70e5326SJon Ringle #define INTIE (1 << 15) 287d70e5326SJon Ringle #define MODEXIE (1 << 14) 288d70e5326SJon Ringle #define HASHIE (1 << 13) 289d70e5326SJon Ringle #define AESIE (1 << 12) 290d70e5326SJon Ringle #define LINKIE (1 << 11) 291d70e5326SJon Ringle #define PKTIE (1 << 6) 292d70e5326SJon Ringle #define DMAIE (1 << 5) 293d70e5326SJon Ringle #define TXIE (1 << 3) 294d70e5326SJon Ringle #define TXABTIE (1 << 2) 295d70e5326SJon Ringle #define RXABTIE (1 << 1) 296d70e5326SJon Ringle #define PCFULIE (1 << 0) 297d70e5326SJon Ringle 298d70e5326SJon Ringle /* EIDLED */ 299d70e5326SJon Ringle #define LACFG3 (1 << 15) 300d70e5326SJon Ringle #define LACFG2 (1 << 14) 301d70e5326SJon Ringle #define LACFG1 (1 << 13) 302d70e5326SJon Ringle #define LACFG0 (1 << 12) 303d70e5326SJon Ringle #define LBCFG3 (1 << 11) 304d70e5326SJon Ringle #define LBCFG2 (1 << 10) 305d70e5326SJon Ringle #define LBCFG1 (1 << 9) 306d70e5326SJon Ringle #define LBCFG0 (1 << 8) 307d70e5326SJon Ringle #define DEVID_SHIFT 5 308d70e5326SJon Ringle #define DEVID_MASK (0x7 << DEVID_SHIFT) 309d70e5326SJon Ringle #define REVID_SHIFT 0 310d70e5326SJon Ringle #define REVID_MASK (0x1F << REVID_SHIFT) 311d70e5326SJon Ringle 312d70e5326SJon Ringle /* PHY registers */ 313d70e5326SJon Ringle #define PHCON1 0x00 314d70e5326SJon Ringle #define PHSTAT1 0x01 315d70e5326SJon Ringle #define PHANA 0x04 316d70e5326SJon Ringle #define PHANLPA 0x05 317d70e5326SJon Ringle #define PHANE 0x06 318d70e5326SJon Ringle #define PHCON2 0x11 319d70e5326SJon Ringle #define PHSTAT2 0x1B 320d70e5326SJon Ringle #define PHSTAT3 0x1F 321d70e5326SJon Ringle 322d70e5326SJon Ringle /* PHCON1 */ 323d70e5326SJon Ringle #define PRST (1 << 15) 324d70e5326SJon Ringle #define PLOOPBK (1 << 14) 325d70e5326SJon Ringle #define SPD100 (1 << 13) 326d70e5326SJon Ringle #define ANEN (1 << 12) 327d70e5326SJon Ringle #define PSLEEP (1 << 11) 328d70e5326SJon Ringle #define RENEG (1 << 9) 329d70e5326SJon Ringle #define PFULDPX (1 << 8) 330d70e5326SJon Ringle 331d70e5326SJon Ringle /* PHSTAT1 */ 332d70e5326SJon Ringle #define FULL100 (1 << 14) 333d70e5326SJon Ringle #define HALF100 (1 << 13) 334d70e5326SJon Ringle #define FULL10 (1 << 12) 335d70e5326SJon Ringle #define HALF10 (1 << 11) 336d70e5326SJon Ringle #define ANDONE (1 << 5) 337d70e5326SJon Ringle #define LRFAULT (1 << 4) 338d70e5326SJon Ringle #define ANABLE (1 << 3) 339d70e5326SJon Ringle #define LLSTAT (1 << 2) 340d70e5326SJon Ringle #define EXTREGS (1 << 0) 341d70e5326SJon Ringle 342d70e5326SJon Ringle /* PHSTAT2 */ 343d70e5326SJon Ringle #define PLRITY (1 << 4) 344d70e5326SJon Ringle 345d70e5326SJon Ringle /* PHSTAT3 */ 346d70e5326SJon Ringle #define PHY3SPD100 (1 << 3) 347d70e5326SJon Ringle #define PHY3DPX (1 << 4) 348d70e5326SJon Ringle #define SPDDPX_SHIFT 2 349d70e5326SJon Ringle #define SPDDPX_MASK (0x7 << SPDDPX_SHIFT) 350d70e5326SJon Ringle 351d70e5326SJon Ringle /* PHANA */ 352d70e5326SJon Ringle /* Default value for PHY initialization*/ 353d70e5326SJon Ringle #define PHANA_DEFAULT 0x05E1 354d70e5326SJon Ringle 355d70e5326SJon Ringle /* PHANE */ 356d70e5326SJon Ringle #define PDFLT (1 << 4) 357d70e5326SJon Ringle #define LPARCD (1 << 1) 358d70e5326SJon Ringle #define LPANABL (1 << 0) 359d70e5326SJon Ringle 360d70e5326SJon Ringle #define EUDAST_TEST_VAL 0x1234 361d70e5326SJon Ringle 362d70e5326SJon Ringle #define TSV_SIZE 7 363d70e5326SJon Ringle 364d70e5326SJon Ringle #define ENCX24J600_DEV_ID 0x1 365d70e5326SJon Ringle 366d70e5326SJon Ringle /* Configuration */ 367d70e5326SJon Ringle 368d70e5326SJon Ringle /* Led is on when the link is present and driven low 369d70e5326SJon Ringle * temporarily when packet is TX'd or RX'd 370d70e5326SJon Ringle */ 371d70e5326SJon Ringle #define LED_A_SETTINGS 0xC 372d70e5326SJon Ringle 373d70e5326SJon Ringle /* Led is on if the link is in 100 Mbps mode */ 374d70e5326SJon Ringle #define LED_B_SETTINGS 0x8 375d70e5326SJon Ringle 376d70e5326SJon Ringle /* maximum ethernet frame length 377d70e5326SJon Ringle * Currently not used as a limit anywhere 378d70e5326SJon Ringle * (we're using the "huge frame enable" feature of 379d70e5326SJon Ringle * enc424j600). 380d70e5326SJon Ringle */ 381d70e5326SJon Ringle #define MAX_FRAMELEN 1518 382d70e5326SJon Ringle 383d70e5326SJon Ringle /* Size in bytes of the receive buffer in enc424j600. 384d70e5326SJon Ringle * Must be word aligned (even). 385d70e5326SJon Ringle */ 386d70e5326SJon Ringle #define RX_BUFFER_SIZE (15 * MAX_FRAMELEN) 387d70e5326SJon Ringle 388d70e5326SJon Ringle /* Start of the general purpose area in sram */ 389d70e5326SJon Ringle #define SRAM_GP_START 0x0 390d70e5326SJon Ringle 391d70e5326SJon Ringle /* SRAM size */ 392d70e5326SJon Ringle #define SRAM_SIZE 0x6000 393d70e5326SJon Ringle 394d70e5326SJon Ringle /* Start of the receive buffer */ 395d70e5326SJon Ringle #define ERXST_VAL (SRAM_SIZE - RX_BUFFER_SIZE) 396d70e5326SJon Ringle 397d70e5326SJon Ringle #define RSV_RXLONGEVDROPEV 16 398d70e5326SJon Ringle #define RSV_CARRIEREV 18 399d70e5326SJon Ringle #define RSV_CRCERROR 20 400d70e5326SJon Ringle #define RSV_LENCHECKERR 21 401d70e5326SJon Ringle #define RSV_LENOUTOFRANGE 22 402d70e5326SJon Ringle #define RSV_RXOK 23 403d70e5326SJon Ringle #define RSV_RXMULTICAST 24 404d70e5326SJon Ringle #define RSV_RXBROADCAST 25 405d70e5326SJon Ringle #define RSV_DRIBBLENIBBLE 26 406d70e5326SJon Ringle #define RSV_RXCONTROLFRAME 27 407d70e5326SJon Ringle #define RSV_RXPAUSEFRAME 28 408d70e5326SJon Ringle #define RSV_RXUNKNOWNOPCODE 29 409d70e5326SJon Ringle #define RSV_RXTYPEVLAN 30 410d70e5326SJon Ringle 411d70e5326SJon Ringle #define RSV_RUNTFILTERMATCH 31 412d70e5326SJon Ringle #define RSV_NOTMEFILTERMATCH 32 413d70e5326SJon Ringle #define RSV_HASHFILTERMATCH 33 414d70e5326SJon Ringle #define RSV_MAGICPKTFILTERMATCH 34 415d70e5326SJon Ringle #define RSV_PTRNMTCHFILTERMATCH 35 416d70e5326SJon Ringle #define RSV_UNICASTFILTERMATCH 36 417d70e5326SJon Ringle 418d70e5326SJon Ringle #define RSV_SIZE 8 419d70e5326SJon Ringle #define RSV_BITMASK(x) (1 << ((x) - 16)) 420d70e5326SJon Ringle #define RSV_GETBIT(x, y) (((x) & RSV_BITMASK(y)) ? 1 : 0) 421d70e5326SJon Ringle 422d70e5326SJon Ringle struct rsv { 423d70e5326SJon Ringle u16 next_packet; 424d70e5326SJon Ringle u16 len; 425d70e5326SJon Ringle u32 rxstat; 426d70e5326SJon Ringle }; 427d70e5326SJon Ringle 428d70e5326SJon Ringle /* Put RX buffer at 0 as suggested by the Errata datasheet */ 429d70e5326SJon Ringle 430d70e5326SJon Ringle #define RXSTART_INIT ERXST_VAL 431d70e5326SJon Ringle #define RXEND_INIT 0x5FFF 432d70e5326SJon Ringle 433d70e5326SJon Ringle int regmap_encx24j600_spi_write(void *context, u8 reg, const u8 *data, 434d70e5326SJon Ringle size_t count); 435d70e5326SJon Ringle int regmap_encx24j600_spi_read(void *context, u8 reg, u8 *data, size_t count); 436d70e5326SJon Ringle 437d70e5326SJon Ringle 438d70e5326SJon Ringle #endif 439