xref: /openbmc/linux/drivers/net/ethernet/microchip/encx24j600_hw.h (revision 762f99f4f3cb41a775b5157dd761217beba65873)
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