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