1
2
3
4
5
6#ifndef _ENCX24J600_HW_H
7#define _ENCX24J600_HW_H
8
9struct encx24j600_context {
10 struct spi_device *spi;
11 struct regmap *regmap;
12 struct regmap *phymap;
13 struct mutex mutex;
14 int bank;
15};
16
17void devm_regmap_init_encx24j600(struct device *dev,
18 struct encx24j600_context *ctx);
19
20
21#define BANK_SELECT(bank) (0xC0 | ((bank & (BANK_MASK >> BANK_SHIFT)) << 1))
22#define B0SEL 0xC0
23#define B1SEL 0xC2
24#define B2SEL 0xC4
25#define B3SEL 0xC6
26#define SETETHRST 0xCA
27#define FCDISABLE 0xE0
28#define FCSINGLE 0xE2
29#define FCMULTIPLE 0xE4
30#define FCCLEAR 0xE6
31#define SETPKTDEC 0xCC
32#define DMASTOP 0xD2
33#define DMACKSUM 0xD8
34#define DMACKSUMS 0xDA
35#define DMACOPY 0xDC
36#define DMACOPYS 0xDE
37#define SETTXRTS 0xD4
38#define ENABLERX 0xE8
39#define DISABLERX 0xEA
40#define SETEIE 0xEC
41#define CLREIE 0xEE
42
43
44#define RBSEL 0xC8
45
46
47#define WGPRDPT 0x60
48#define RGPRDPT 0x62
49#define WRXRDPT 0x64
50#define RRXRDPT 0x66
51#define WUDARDPT 0x68
52#define RUDARDPT 0x6A
53#define WGPWRPT 0x6C
54#define RGPWRPT 0x6E
55#define WRXWRPT 0x70
56#define RRXWRPT 0x72
57#define WUDAWRPT 0x74
58#define RUDAWRPT 0x76
59
60
61#define RCRCODE 0x00
62#define WCRCODE 0x40
63#define BFSCODE 0x80
64#define BFCCODE 0xA0
65#define RCR(addr) (RCRCODE | (addr & ADDR_MASK))
66#define WCR(addr) (WCRCODE | (addr & ADDR_MASK))
67#define RCRU 0x20
68#define WCRU 0x22
69#define BFS(addr) (BFSCODE | (addr & ADDR_MASK))
70#define BFC(addr) (BFCCODE | (addr & ADDR_MASK))
71#define BFSU 0x24
72#define BFCU 0x26
73#define RGPDATA 0x28
74#define WGPDATA 0x2A
75#define RRXDATA 0x2C
76#define WRXDATA 0x2E
77#define RUDADATA 0x30
78#define WUDADATA 0x32
79
80#define SFR_REG_COUNT 0xA0
81
82
83
84
85
86
87
88#define ADDR_MASK 0x1F
89#define BANK_MASK 0x60
90#define BANK_SHIFT 5
91
92
93#define EUDAST 0x16
94#define EUDAND 0x18
95#define ESTAT 0x1A
96#define EIR 0x1C
97#define ECON1 0x1E
98
99
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
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
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
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
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
161
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
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
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
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
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
226#define LOOPBK (1 << 4)
227#define RXPAUS (1 << 2)
228#define PASSALL (1 << 1)
229
230
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
244
245
246
247
248#define MAIPGH_VAL 0x0C
249#define MAIPGL_VAL 0x12
250
251
252#define MIREGADR_VAL (1 << 8)
253
254
255#define PHREG_MASK 0x1F
256
257
258#define MIISCAN (1 << 1)
259#define MIIRD (1 << 0)
260
261
262#define NVALID (1 << 2)
263#define SCAN (1 << 1)
264#define BUSY (1 << 0)
265
266
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
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
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
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
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
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
342#define PLRITY (1 << 4)
343
344
345#define PHY3SPD100 (1 << 3)
346#define PHY3DPX (1 << 4)
347#define SPDDPX_SHIFT 2
348#define SPDDPX_MASK (0x7 << SPDDPX_SHIFT)
349
350
351
352#define PHANA_DEFAULT 0x05E1
353
354
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
366
367
368
369
370#define LED_A_SETTINGS 0xC
371
372
373#define LED_B_SETTINGS 0x8
374
375
376
377
378
379
380#define MAX_FRAMELEN 1518
381
382
383
384
385#define RX_BUFFER_SIZE (15 * MAX_FRAMELEN)
386
387
388#define SRAM_GP_START 0x0
389
390
391#define SRAM_SIZE 0x6000
392
393
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
421struct rsv {
422 u16 next_packet;
423 u16 len;
424 u32 rxstat;
425};
426
427
428
429#define RXSTART_INIT ERXST_VAL
430#define RXEND_INIT 0x5FFF
431
432int regmap_encx24j600_spi_write(void *context, u8 reg, const u8 *data,
433 size_t count);
434int regmap_encx24j600_spi_read(void *context, u8 reg, u8 *data, size_t count);
435
436
437#endif
438