elinkxlreg.h revision 1.3 1 1.3 fvdl /* $NetBSD: elinkxlreg.h,v 1.3 2000/09/19 01:15:28 fvdl Exp $ */
2 1.1 fvdl
3 1.1 fvdl /*-
4 1.1 fvdl * Copyright (c) 1998 The NetBSD Foundation, Inc.
5 1.1 fvdl * All rights reserved.
6 1.1 fvdl *
7 1.1 fvdl * This code is derived from software contributed to The NetBSD Foundation
8 1.1 fvdl * by Frank van der Linden.
9 1.1 fvdl *
10 1.1 fvdl * Redistribution and use in source and binary forms, with or without
11 1.1 fvdl * modification, are permitted provided that the following conditions
12 1.1 fvdl * are met:
13 1.1 fvdl * 1. Redistributions of source code must retain the above copyright
14 1.1 fvdl * notice, this list of conditions and the following disclaimer.
15 1.1 fvdl * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 fvdl * notice, this list of conditions and the following disclaimer in the
17 1.1 fvdl * documentation and/or other materials provided with the distribution.
18 1.1 fvdl * 3. All advertising materials mentioning features or use of this software
19 1.1 fvdl * must display the following acknowledgement:
20 1.1 fvdl * This product includes software developed by the NetBSD
21 1.1 fvdl * Foundation, Inc. and its contributors.
22 1.1 fvdl * 4. Neither the name of The NetBSD Foundation nor the names of its
23 1.1 fvdl * contributors may be used to endorse or promote products derived
24 1.1 fvdl * from this software without specific prior written permission.
25 1.1 fvdl *
26 1.1 fvdl * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
27 1.1 fvdl * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
28 1.1 fvdl * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29 1.1 fvdl * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
30 1.1 fvdl * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31 1.1 fvdl * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
32 1.1 fvdl * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
33 1.1 fvdl * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
34 1.1 fvdl * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
35 1.1 fvdl * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36 1.1 fvdl * POSSIBILITY OF SUCH DAMAGE.
37 1.1 fvdl */
38 1.1 fvdl
39 1.1 fvdl /*
40 1.1 fvdl * This file defines the registers specific to the EtherLink XL family
41 1.1 fvdl * of NICs.
42 1.1 fvdl */
43 1.1 fvdl
44 1.1 fvdl #define EEPROM_SOFTINFO3 0x15 /* Software info #3 */
45 1.1 fvdl #define EEPROM_SUBVENDOR_ELXL 0x17 /* Subsys vendor id */
46 1.1 fvdl #define EEPROM_SUBSYSID 0x18 /* Subsys id */
47 1.1 fvdl #define EEPROM_MEDIA 0x19 /* Media options (90xB) */
48 1.1 fvdl #define EEPROM_CHECKSUM_ELXL 0x20 /* EEPROM checksum */
49 1.1 fvdl
50 1.3 fvdl #define READ_EEPROM8 0x0200 /* 8 bit EEPROM read command */
51 1.3 fvdl
52 1.1 fvdl /*
53 1.1 fvdl * Flat address space registers (outside the windows)
54 1.1 fvdl */
55 1.1 fvdl
56 1.1 fvdl #define ELINK_TXPKTID 0x18 /* 90xB only */
57 1.1 fvdl #define ELINK_TIMER 0x1a
58 1.1 fvdl #define ELINK_TXSTATUS 0x1b
59 1.1 fvdl #define ELINK_INTSTATUSAUTO 0x1e
60 1.1 fvdl #define ELINK_DMACTRL 0x20
61 1.1 fvdl # define ELINK_DMAC_DNCMPLREQ 0x00000002
62 1.1 fvdl # define ELINK_DMAC_DNSTALLED 0x00000004
63 1.1 fvdl # define ELINK_DMAC_UPCOMPLETE 0x00000008
64 1.1 fvdl # define ELINK_DMAC_DNCOMPLETE 0x00000010
65 1.1 fvdl # define ELINK_DMAC_UPRXEAREN 0x00000020
66 1.1 fvdl # define ELINK_DMAC_ARNCNTDN 0x00000040
67 1.1 fvdl # define ELINK_DMAC_DNINPROG 0x00000080
68 1.1 fvdl # define ELINK_DMAC_CNTSPEED 0x00000100
69 1.1 fvdl # define ELINK_DMAC_CNTDNMODE 0x00000200
70 1.1 fvdl # define ELINK_DMAC_ALTSEQDIS 0x00010000
71 1.1 fvdl # define ELINK_DMAC_DEFEATMWI 0x00100000
72 1.1 fvdl # define ELINK_DMAC_DEFEATMRL 0x00200000
73 1.1 fvdl # define ELINK_DMAC_UPOVERDIS 0x00400000
74 1.1 fvdl # define ELINK_DMAC_TARGABORT 0x40000000
75 1.1 fvdl # define ELINK_DMAC_MSTRABORT 0x80000000
76 1.1 fvdl #define ELINK_DNLISTPTR 0x24
77 1.1 fvdl #define ELINK_DNBURSTTHRESH 0x2a /* 90xB only */
78 1.1 fvdl #define ELINK_DNPRIOTHRESH 0x2c /* 90xB only */
79 1.1 fvdl #define ELINK_DNPOLL 0x2d /* 90xB only */
80 1.1 fvdl #define ELINK_TXFREETHRESH 0x2f /* 90x only */
81 1.1 fvdl #define ELINK_UPPKTSTATUS 0x30
82 1.1 fvdl #define ELINK_FREETIMER 0x34
83 1.1 fvdl #define ELINK_COUNTDOWN 0x36
84 1.1 fvdl #define ELINK_UPLISTPTR 0x38
85 1.1 fvdl #define ELINK_UPPRIOTHRESH 0x3c /* 90xB only */
86 1.1 fvdl #define ELINK_UPPOLL 0x3d /* 90xB only */
87 1.1 fvdl #define ELINK_UPBURSTTHRESH 0x3e /* 90xB only */
88 1.1 fvdl #define ELINK_REALTIMECNT 0x40 /* 90xB only */
89 1.1 fvdl #define ELINK_DNMAXBURST 0x78 /* 90xB only */
90 1.1 fvdl #define ELINK_UPMAXBURST 0x7a /* 90xB only */
91 1.1 fvdl
92 1.1 fvdl /*
93 1.1 fvdl * This is reset options for the other cards, media options for
94 1.1 fvdl * the 90xB NICs. Reset options are in a seperate register for
95 1.1 fvdl * the 90xB.
96 1.1 fvdl */
97 1.1 fvdl #define ELINK_W3_MEDIA_OPTIONS 0x08
98 1.1 fvdl # define ELINK_MEDIACAP_100BASET4 0x0001
99 1.1 fvdl # define ELINK_MEDIACAP_100BASETX 0x0002
100 1.1 fvdl # define ELINK_MEDIACAP_100BASEFX 0x0004
101 1.1 fvdl # define ELINK_MEDIACAP_10BASET 0x0008
102 1.1 fvdl # define ELINK_MEDIACAP_10BASE2 0x0010
103 1.1 fvdl # define ELINK_MEDIACAP_10BASE5 0x0020
104 1.1 fvdl # define ELINK_MEDIACAP_MII 0x0040
105 1.1 fvdl # define ELINK_MEDIACAP_10BASEFL 0x0080
106 1.3 fvdl
107 1.3 fvdl /*
108 1.3 fvdl * Reset options for the 90xB
109 1.3 fvdl */
110 1.3 fvdl #define ELINK_W2_RESET_OPTIONS 0x0c
111 1.3 fvdl # define ELINK_RESET_OPT_LEDPOLAR 0x0010
112 1.3 fvdl # define ELINK_RESET_OPT_PHYPOWER 0x4000
113 1.1 fvdl
114 1.1 fvdl /*
115 1.1 fvdl * Window 4, offset 8 is defined for MII/PHY access for EtherLink XL
116 1.1 fvdl * cards.
117 1.1 fvdl */
118 1.1 fvdl #define ELINK_W4_PHYSMGMT 0x08
119 1.1 fvdl # define ELINK_PHY_CLK 0x0001
120 1.1 fvdl # define ELINK_PHY_DATA 0x0002
121 1.1 fvdl # define ELINK_PHY_DIR 0x0004
122 1.1 fvdl
123 1.1 fvdl /*
124 1.1 fvdl * Counter in window 4 for packets with a bad start-of-stream delimiter/
125 1.1 fvdl */
126 1.1 fvdl #define ELINK_W4_BADSSD 0x0c
127 1.1 fvdl #define ELINK_W4_UBYTESOK 0x0c
128 1.1 fvdl
129 1.1 fvdl /*
130 1.1 fvdl * Define for extra multicast hash filter bit implemented in the 90xB
131 1.1 fvdl */
132 1.1 fvdl #define FIL_MULTIHASH 0x10
133 1.1 fvdl
134 1.1 fvdl /*
135 1.1 fvdl * Defines for the interrupt status register, only for the 90x[B]
136 1.1 fvdl */
137 1.1 fvdl #define S_HOST_ERROR 0x0002
138 1.1 fvdl #define S_LINK_EVENT 0x0100
139 1.1 fvdl #define S_DN_COMPLETE 0x0200
140 1.1 fvdl #define S_UP_COMPLETE 0x0400
141 1.1 fvdl
142 1.1 fvdl #define S_MASK \
143 1.1 fvdl (S_HOST_ERROR | S_TX_COMPLETE | S_UPD_STATS | S_DN_COMPLETE | S_UP_COMPLETE)
144 1.1 fvdl
145 1.1 fvdl
146 1.1 fvdl /*
147 1.1 fvdl * Window 7 registers. These are different for 90x and 90xB than
148 1.1 fvdl * for the EtherLink III / Fast EtherLink cards.
149 1.1 fvdl */
150 1.1 fvdl
151 1.1 fvdl #define ELINK_W7_VLANMASK 0x00 /* 90xB only */
152 1.1 fvdl #define ELINK_W7_VLANTYPE 0x04 /* 90xB only */
153 1.1 fvdl #define ELINK_W7_TIMER 0x0a /* 90x only */
154 1.1 fvdl #define ELINK_W7_TXSTATUS 0x0b /* 90x only */
155 1.1 fvdl #define ELINK_W7_POWEREVENT 0x0c /* 90xB only */
156 1.1 fvdl #define ELINK_W7_INTSTATUS 0x0e
157 1.1 fvdl
158 1.1 fvdl /*
159 1.1 fvdl * Command definitions.
160 1.1 fvdl */
161 1.1 fvdl #define ELINK_UPSTALL 0x3000
162 1.1 fvdl #define ELINK_UPUNSTALL 0x3001
163 1.1 fvdl #define ELINK_DNSTALL 0x3002
164 1.1 fvdl #define ELINK_DNUNSTALL 0x3003
165 1.1 fvdl #define ELINK_TXRECLTHRESH 0xc000
166 1.1 fvdl #define ELINK_TXSTARTTHRESH 0x9800
167 1.1 fvdl #define ELINK_SETHASHFILBIT 0xcc00
168 1.1 fvdl
169 1.1 fvdl /*
170 1.1 fvdl * The Internal Config register is different on 90xB cards. The
171 1.1 fvdl * different masks / shifts are defined here.
172 1.1 fvdl */
173 1.1 fvdl
174 1.1 fvdl /*
175 1.1 fvdl * Lower 16 bits.
176 1.1 fvdl */
177 1.1 fvdl #define CONFIG_TXLARGE (u_int16_t) 0x4000
178 1.1 fvdl #define CONFIG_TXLARGE_SHIFT 14
179 1.1 fvdl
180 1.1 fvdl #define CONFIG_RXLARGE (u_int16_t) 0x8000
181 1.1 fvdl #define CONFIG_RXLARGE_SHIFT 15
182 1.1 fvdl
183 1.1 fvdl /*
184 1.1 fvdl * Upper 16 bits.
185 1.1 fvdl */
186 1.1 fvdl #define CONFIG_XCVR_SEL (u_int16_t) 0x00f0
187 1.1 fvdl #define CONFIG_XCVR_SEL_SHIFT 4
188 1.2 fvdl
189 1.2 fvdl #define ELINKMEDIA_AUTO 8
190 1.1 fvdl
191 1.1 fvdl #define CONFIG_AUTOSEL (u_int16_t) 0x0100
192 1.1 fvdl #define CONFIG_AUTOSEL_SHIFT 8
193 1.1 fvdl
194 1.1 fvdl #define CONFIG_DISABLEROM (u_int16_t) 0x0200
195 1.1 fvdl #define CONFIG_DISABLEROM_SHIFT 9
196 1.1 fvdl
197 1.1 fvdl /*
198 1.1 fvdl * ID of internal PHY.
199 1.1 fvdl */
200 1.1 fvdl
201 1.1 fvdl #define ELINK_INTPHY_ID 24
202 1.1 fvdl
203 1.1 fvdl /*
204 1.1 fvdl * Fragment header as laid out in memory for DMA access.
205 1.1 fvdl */
206 1.1 fvdl
207 1.1 fvdl struct ex_fraghdr {
208 1.1 fvdl volatile u_int32_t fr_addr; /* phys addr of frag */
209 1.1 fvdl volatile u_int32_t fr_len; /* length of frag */
210 1.1 fvdl };
211 1.1 fvdl
212 1.1 fvdl #define EX_FR_LENMASK 0x00001fff /* mask for length in fr_len field */
213 1.1 fvdl #define EX_FR_LAST 0x80000000 /* indicates last fragment */
214 1.1 fvdl
215 1.1 fvdl #define EX_NDPD 128
216 1.1 fvdl #define EX_NUPD 64
217 1.1 fvdl
218 1.1 fvdl /*
219 1.1 fvdl * Note: the number of receive fragments in an UPD is 1, since we're
220 1.1 fvdl * receiving into one contiguous mbuf.
221 1.1 fvdl */
222 1.1 fvdl #define EX_NRFRAGS 1 /* # fragments in rcv pkt (< 64) */
223 1.1 fvdl #define EX_NTFRAGS 32 /* # fragments in tx pkt (< 64) */
224 1.1 fvdl
225 1.1 fvdl /*
226 1.1 fvdl * Type 0 Download Packet Descriptor (DPD).
227 1.1 fvdl */
228 1.1 fvdl struct ex_dpd {
229 1.1 fvdl volatile u_int32_t dpd_nextptr; /* prt to next fragheader */
230 1.1 fvdl volatile u_int32_t dpd_fsh; /* frame start header */
231 1.1 fvdl volatile struct ex_fraghdr dpd_frags[EX_NTFRAGS];
232 1.1 fvdl };
233 1.1 fvdl
234 1.1 fvdl /*
235 1.1 fvdl * Type 1 DPD, supported by 90xB.
236 1.1 fvdl */
237 1.1 fvdl struct ex_dpd1 {
238 1.1 fvdl volatile u_int32_t dpd_nextptr;
239 1.1 fvdl volatile u_int32_t dpd_schedtime; /* time to download */
240 1.1 fvdl volatile u_int32_t dpd_fsh;
241 1.1 fvdl volatile struct ex_fraghdr dpd_frags[EX_NTFRAGS];
242 1.1 fvdl };
243 1.1 fvdl
244 1.1 fvdl struct ex_upd {
245 1.1 fvdl volatile u_int32_t upd_nextptr;
246 1.1 fvdl volatile u_int32_t upd_pktstatus;
247 1.1 fvdl volatile struct ex_fraghdr upd_frags[EX_NRFRAGS];
248 1.1 fvdl };
249 1.1 fvdl
250 1.1 fvdl /*
251 1.1 fvdl * Higher level linked list of upload packet descriptors.
252 1.1 fvdl */
253 1.1 fvdl struct ex_rxdesc {
254 1.1 fvdl struct ex_rxdesc *rx_next;
255 1.1 fvdl struct mbuf *rx_mbhead;
256 1.1 fvdl bus_dmamap_t rx_dmamap;
257 1.1 fvdl struct ex_upd *rx_upd;
258 1.1 fvdl };
259 1.1 fvdl
260 1.1 fvdl /*
261 1.1 fvdl * .. and for download packet descriptors.
262 1.1 fvdl */
263 1.1 fvdl struct ex_txdesc {
264 1.1 fvdl struct ex_txdesc *tx_next;
265 1.1 fvdl struct mbuf *tx_mbhead;
266 1.1 fvdl bus_dmamap_t tx_dmamap;
267 1.1 fvdl struct ex_dpd *tx_dpd;
268 1.1 fvdl };
269 1.1 fvdl
270 1.1 fvdl #define DPD_DMADDR(s,t) \
271 1.1 fvdl ((s)->sc_dpddma + ((caddr_t)((t)->tx_dpd) - (caddr_t)((s)->sc_dpd)))
272 1.1 fvdl
273 1.1 fvdl /*
274 1.1 fvdl * Frame Start Header bitfields.
275 1.1 fvdl */
276 1.1 fvdl
277 1.1 fvdl #define EX_DPD_DNIND 0x80000000 /* intr on download done */
278 1.1 fvdl #define EX_DPD_TXIND 0x00008000 /* intr on tx done */
279 1.1 fvdl #define EX_DPD_NOCRC 0x00002000 /* no CRC append */
280 1.1 fvdl
281 1.1 fvdl /*
282 1.1 fvdl * Lower 12 bits are the tx length for the 90x family. The 90xB
283 1.1 fvdl * assumes that the tx length is the sum of all frame lengths,
284 1.1 fvdl * and uses the bits as below. It also defines some more bits in
285 1.1 fvdl * the upper part.
286 1.1 fvdl */
287 1.1 fvdl #define EX_DPD_EMPTY 0x20000000 /* no data in this DPD */
288 1.1 fvdl #define EX_DPD_UPDEFEAT 0x10000000 /* don't round tx lengths up */
289 1.1 fvdl #define EX_DPD_UDPCKSUM 0x08000000 /* do hardware UDP checksum */
290 1.1 fvdl #define EX_DPD_TCPCKSUM 0x04000000 /* do hardware TCP checksum */
291 1.1 fvdl #define EX_DPD_IPCKSUM 0x02000000 /* do hardware IP checksum */
292 1.1 fvdl #define EX_DPD_DNCMPLT 0x01000000 /* packet has been downloaded */
293 1.1 fvdl #define EX_DPD_IDMASK 0x000003fc /* mask for packet id */
294 1.1 fvdl # define EX_DPD_IDSHIFT 2
295 1.1 fvdl #define EX_DPD_RNDMASK 0x00000003 /* mask for rounding */
296 1.1 fvdl /* 0 -> dword, 2 -> word, 1,3 -> none */
297 1.1 fvdl
298 1.1 fvdl /*
299 1.1 fvdl * Schedtime bitfields.
300 1.1 fvdl */
301 1.1 fvdl #define EX_SCHED_TIMEVALID 0x20000000 /* field contains value */
302 1.1 fvdl #define EX_SCHED_LDCOUNT 0x10000000 /* load schedtime onto NIC */
303 1.1 fvdl #define EX_SCHED_TIMEMASK 0x00ffffff
304 1.1 fvdl
305 1.1 fvdl /*
306 1.1 fvdl * upd_pktstatus bitfields.
307 1.1 fvdl */
308 1.1 fvdl #define EX_UPD_PKTLENMASK 0x00001fff /* 12:0 -> packet length */
309 1.1 fvdl #define EX_UPD_ERROR 0x00004000 /* rcv error */
310 1.1 fvdl #define EX_UPD_COMPLETE 0x00008000 /* rcv complete */
311 1.1 fvdl #define EX_UPD_OVERRUN 0x00010000 /* rcv overrun */
312 1.1 fvdl #define EX_UPD_RUNT 0x00020000 /* pkt < 60 bytes */
313 1.1 fvdl #define EX_UPD_ALIGNERR 0x00040000 /* alignment error */
314 1.1 fvdl #define EX_UPD_CRCERR 0x00080000 /* CRC error */
315 1.1 fvdl #define EX_UPD_OVERSIZED 0x00100000 /* oversize frame */
316 1.1 fvdl #define EX_UPD_DRIBBLEBITS 0x00800000 /* pkt had dribble bits */
317 1.1 fvdl #define EX_UPD_OVERFLOW 0x01000000 /* insufficient space for pkt */
318 1.1 fvdl #define EX_UPD_IPCKSUMERR 0x02000000 /* IP cksum error (90xB) */
319 1.1 fvdl #define EX_UPD_TCPCKSUMERR 0x04000000 /* TCP cksum error (90xB) */
320 1.1 fvdl #define EX_UPD_UDPCKSUMERR 0x08000000 /* UDP cksum error (90xB) */
321 1.1 fvdl
322 1.1 fvdl #define EX_UPD_ERR 0x001f4000 /* Errors we check for */
323