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