atwreg.h revision 1.14 1 1.14 dyoung /* $NetBSD: atwreg.h,v 1.14 2006/03/08 08:26:50 dyoung Exp $ */
2 1.1 dyoung
3 1.1 dyoung /*
4 1.1 dyoung * Copyright (c) 2003 The NetBSD Foundation, Inc. All rights reserved.
5 1.1 dyoung *
6 1.1 dyoung * This code is derived from software contributed to The NetBSD Foundation
7 1.1 dyoung * by David Young.
8 1.1 dyoung *
9 1.1 dyoung * Redistribution and use in source and binary forms, with or without
10 1.1 dyoung * modification, are permitted provided that the following conditions
11 1.1 dyoung * are met:
12 1.1 dyoung * 1. Redistributions of source code must retain the above copyright
13 1.1 dyoung * notice, this list of conditions and the following disclaimer.
14 1.1 dyoung * 2. Redistributions in binary form must reproduce the above copyright
15 1.1 dyoung * notice, this list of conditions and the following disclaimer in the
16 1.1 dyoung * documentation and/or other materials provided with the distribution.
17 1.1 dyoung * 3. All advertising materials mentioning features or use of this software
18 1.1 dyoung * must display the following acknowledgement:
19 1.1 dyoung * This product includes software developed by the NetBSD
20 1.1 dyoung * Foundation, Inc. and its contributors.
21 1.1 dyoung * 4. Neither the name of the author nor the names of any co-contributors
22 1.1 dyoung * may be used to endorse or promote products derived from this software
23 1.1 dyoung * without specific prior written permission.
24 1.1 dyoung *
25 1.1 dyoung * THIS SOFTWARE IS PROVIDED BY David Young AND CONTRIBUTORS ``AS IS'' AND
26 1.1 dyoung * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27 1.1 dyoung * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28 1.1 dyoung * ARE DISCLAIMED. IN NO EVENT SHALL David Young
29 1.1 dyoung * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30 1.1 dyoung * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31 1.1 dyoung * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 1.1 dyoung * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33 1.1 dyoung * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34 1.1 dyoung * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
35 1.1 dyoung * THE POSSIBILITY OF SUCH DAMAGE.
36 1.1 dyoung */
37 1.1 dyoung
38 1.1 dyoung /* glossary */
39 1.1 dyoung
40 1.1 dyoung /* DTIM Delivery Traffic Indication Map, sent by AP
41 1.1 dyoung * ATIM Ad Hoc Traffic Indication Map
42 1.1 dyoung * TU 1024 microseconds
43 1.1 dyoung * TSF time synchronization function
44 1.1 dyoung * TBTT target beacon transmission time
45 1.1 dyoung * DIFS distributed inter-frame space
46 1.1 dyoung * SIFS short inter-frame space
47 1.1 dyoung * EIFS extended inter-frame space
48 1.1 dyoung */
49 1.1 dyoung
50 1.13 dyoung #include <lib/libkern/libkern.h>
51 1.5 dyoung
52 1.1 dyoung /* ADM8211 Host Control and Status Registers */
53 1.1 dyoung
54 1.1 dyoung #define ATW_PAR 0x00 /* PCI access */
55 1.1 dyoung #define ATW_FRCTL 0x04 /* Frame control */
56 1.1 dyoung #define ATW_TDR 0x08 /* Transmit demand */
57 1.1 dyoung #define ATW_WTDP 0x0C /* Current transmit descriptor pointer */
58 1.1 dyoung #define ATW_RDR 0x10 /* Receive demand */
59 1.1 dyoung #define ATW_WRDP 0x14 /* Current receive descriptor pointer */
60 1.1 dyoung #define ATW_RDB 0x18 /* Receive descriptor base address */
61 1.8 dyoung #define ATW_CSR3A 0x1C /* Unused (on ADM8211A) */
62 1.8 dyoung #define ATW_C_TDBH 0x1C /* Transmit descriptor base address,
63 1.8 dyoung * high-priority packet
64 1.8 dyoung */
65 1.1 dyoung #define ATW_TDBD 0x20 /* Transmit descriptor base address, DCF */
66 1.1 dyoung #define ATW_TDBP 0x24 /* Transmit descriptor base address, PCF */
67 1.1 dyoung #define ATW_STSR 0x28 /* Status */
68 1.1 dyoung #define ATW_CSR5A 0x2C /* Unused */
69 1.8 dyoung #define ATW_C_TDBB 0x2C /* Transmit descriptor base address, buffered
70 1.8 dyoung * broadcast/multicast packet
71 1.8 dyoung */
72 1.1 dyoung #define ATW_NAR 0x30 /* Network access */
73 1.1 dyoung #define ATW_CSR6A 0x34 /* Unused */
74 1.1 dyoung #define ATW_IER 0x38 /* Interrupt enable */
75 1.1 dyoung #define ATW_CSR7A 0x3C
76 1.1 dyoung #define ATW_LPC 0x40 /* Lost packet counter */
77 1.1 dyoung #define ATW_TEST1 0x44 /* Test register 1 */
78 1.1 dyoung #define ATW_SPR 0x48 /* Serial port */
79 1.1 dyoung #define ATW_TEST0 0x4C /* Test register 0 */
80 1.1 dyoung #define ATW_WCSR 0x50 /* Wake-up control/status */
81 1.1 dyoung #define ATW_WPDR 0x54 /* Wake-up pattern data */
82 1.1 dyoung #define ATW_GPTMR 0x58 /* General purpose timer */
83 1.1 dyoung #define ATW_GPIO 0x5C /* GPIO[5:0] configuration and control */
84 1.1 dyoung #define ATW_BBPCTL 0x60 /* BBP control port */
85 1.1 dyoung #define ATW_SYNCTL 0x64 /* synthesizer control port */
86 1.1 dyoung #define ATW_PLCPHD 0x68 /* PLCP header setting */
87 1.1 dyoung #define ATW_MMIWADDR 0x6C /* MMI write address */
88 1.1 dyoung #define ATW_MMIRADDR1 0x70 /* MMI read address 1 */
89 1.1 dyoung #define ATW_MMIRADDR2 0x74 /* MMI read address 2 */
90 1.1 dyoung #define ATW_TXBR 0x78 /* Transmit burst counter */
91 1.1 dyoung #define ATW_CSR15A 0x7C /* Unused */
92 1.1 dyoung #define ATW_ALCSTAT 0x80 /* ALC statistics */
93 1.1 dyoung #define ATW_TOFS2 0x84 /* Timing offset parameter 2, 16b */
94 1.1 dyoung #define ATW_CMDR 0x88 /* Command */
95 1.1 dyoung #define ATW_PCIC 0x8C /* PCI bus performance counter */
96 1.1 dyoung #define ATW_PMCSR 0x90 /* Power management command and status */
97 1.1 dyoung #define ATW_PAR0 0x94 /* Local MAC address register 0, 32b */
98 1.1 dyoung #define ATW_PAR1 0x98 /* Local MAC address register 1, 16b */
99 1.1 dyoung #define ATW_MAR0 0x9C /* Multicast address hash table register 0 */
100 1.1 dyoung #define ATW_MAR1 0xA0 /* Multicast address hash table register 1 */
101 1.1 dyoung #define ATW_ATIMDA0 0xA4 /* Ad Hoc Traffic Indication Map (ATIM)
102 1.1 dyoung * frame DA, byte[3:0]
103 1.1 dyoung */
104 1.1 dyoung #define ATW_ABDA1 0xA8 /* BSSID address byte[5:4];
105 1.1 dyoung * ATIM frame DA byte[5:4]
106 1.1 dyoung */
107 1.1 dyoung #define ATW_BSSID0 0xAC /* BSSID address byte[3:0] */
108 1.1 dyoung #define ATW_TXLMT 0xB0 /* WLAN retry limit, 8b;
109 1.1 dyoung * Max TX MSDU lifetime, 16b
110 1.1 dyoung */
111 1.1 dyoung #define ATW_MIBCNT 0xB4 /* RTS/ACK/FCS MIB count, 32b */
112 1.1 dyoung #define ATW_BCNT 0xB8 /* Beacon transmission time, 32b */
113 1.1 dyoung #define ATW_TSFTH 0xBC /* TSFT[63:32], 32b */
114 1.1 dyoung #define ATW_TSC 0xC0 /* TSFT[39:32] down count value */
115 1.1 dyoung #define ATW_SYNRF 0xC4 /* SYN RF IF direct control */
116 1.1 dyoung #define ATW_BPLI 0xC8 /* Beacon interval, 16b.
117 1.1 dyoung * STA listen interval, 16b.
118 1.1 dyoung */
119 1.1 dyoung #define ATW_CAP0 0xCC /* Current channel, 4b. RCVDTIM, 1b. */
120 1.1 dyoung #define ATW_CAP1 0xD0 /* Capability information, 16b.
121 1.1 dyoung * ATIM window, 1b.
122 1.1 dyoung */
123 1.1 dyoung #define ATW_RMD 0xD4 /* RX max reception duration, 16b */
124 1.1 dyoung #define ATW_CFPP 0xD8 /* CFP parameter, 32b */
125 1.1 dyoung #define ATW_TOFS0 0xDC /* Timing offset parameter 0, 28b */
126 1.1 dyoung #define ATW_TOFS1 0xE0 /* Timing offset parameter 1, 24b */
127 1.1 dyoung #define ATW_IFST 0xE4 /* IFS timing parameter 1, 32b */
128 1.1 dyoung #define ATW_RSPT 0xE8 /* Response time, 24b */
129 1.1 dyoung #define ATW_TSFTL 0xEC /* TSFT[31:0], 32b */
130 1.1 dyoung #define ATW_WEPCTL 0xF0 /* WEP control */
131 1.1 dyoung #define ATW_WESK 0xF4 /* Write entry for shared/individual key */
132 1.1 dyoung #define ATW_WEPCNT 0xF8 /* WEP count */
133 1.1 dyoung #define ATW_MACTEST 0xFC
134 1.1 dyoung
135 1.1 dyoung #define ATW_FER 0x100 /* Function event */
136 1.1 dyoung #define ATW_FEMR 0x104 /* Function event mask */
137 1.1 dyoung #define ATW_FPSR 0x108 /* Function present state */
138 1.1 dyoung #define ATW_FFER 0x10C /* Function force event */
139 1.1 dyoung
140 1.1 dyoung
141 1.14 dyoung #define ATW_PAR_MWIE __BIT(24) /* memory write and invalidate
142 1.1 dyoung * enable
143 1.1 dyoung */
144 1.14 dyoung #define ATW_PAR_MRLE __BIT(23) /* memory read line enable */
145 1.14 dyoung #define ATW_PAR_MRME __BIT(21) /* memory read multiple
146 1.1 dyoung * enable
147 1.1 dyoung */
148 1.14 dyoung #define ATW_PAR_RAP_MASK __BITS(17, 18) /* receive auto-polling in
149 1.1 dyoung * receive suspended state
150 1.1 dyoung */
151 1.14 dyoung #define ATW_PAR_CAL_MASK __BITS(14, 15) /* cache alignment */
152 1.1 dyoung #define ATW_PAR_CAL_PBL 0x0
153 1.1 dyoung /* min(8 DW, PBL) */
154 1.13 dyoung #define ATW_PAR_CAL_8DW SHIFTIN(0x1, ATW_PAR_CAL_MASK)
155 1.1 dyoung /* min(16 DW, PBL) */
156 1.13 dyoung #define ATW_PAR_CAL_16DW SHIFTIN(0x2, ATW_PAR_CAL_MASK)
157 1.1 dyoung /* min(32 DW, PBL) */
158 1.13 dyoung #define ATW_PAR_CAL_32DW SHIFTIN(0x3, ATW_PAR_CAL_MASK)
159 1.14 dyoung #define ATW_PAR_PBL_MASK __BITS(8, 13) /* programmable burst length */
160 1.1 dyoung #define ATW_PAR_PBL_UNLIMITED 0x0
161 1.13 dyoung #define ATW_PAR_PBL_1DW SHIFTIN(0x1, ATW_PAR_PBL_MASK)
162 1.13 dyoung #define ATW_PAR_PBL_2DW SHIFTIN(0x2, ATW_PAR_PBL_MASK)
163 1.13 dyoung #define ATW_PAR_PBL_4DW SHIFTIN(0x4, ATW_PAR_PBL_MASK)
164 1.13 dyoung #define ATW_PAR_PBL_8DW SHIFTIN(0x8, ATW_PAR_PBL_MASK)
165 1.13 dyoung #define ATW_PAR_PBL_16DW SHIFTIN(0x16, ATW_PAR_PBL_MASK)
166 1.13 dyoung #define ATW_PAR_PBL_32DW SHIFTIN(0x32, ATW_PAR_PBL_MASK)
167 1.14 dyoung #define ATW_PAR_BLE __BIT(7) /* big/little endian selection */
168 1.14 dyoung #define ATW_PAR_DSL_MASK __BITS(2, 6) /* descriptor skip length */
169 1.14 dyoung #define ATW_PAR_BAR __BIT(1) /* bus arbitration */
170 1.14 dyoung #define ATW_PAR_SWR __BIT(0) /* software reset */
171 1.14 dyoung
172 1.14 dyoung #define ATW_FRCTL_PWRMGMT __BIT(31) /* power management */
173 1.14 dyoung #define ATW_FRCTL_VER_MASK __BITS(29, 30) /* protocol version */
174 1.14 dyoung #define ATW_FRCTL_ORDER __BIT(28) /* order bit */
175 1.14 dyoung #define ATW_FRCTL_MAXPSP __BIT(27) /* maximum power saving */
176 1.14 dyoung #define ATW_C_FRCTL_PRSP __BIT(26) /* 1: driver sends probe
177 1.8 dyoung * response
178 1.8 dyoung * 0: ASIC sends prresp
179 1.8 dyoung */
180 1.14 dyoung #define ATW_C_FRCTL_DRVBCON __BIT(25) /* 1: driver sends beacons
181 1.8 dyoung * 0: ASIC sends beacons
182 1.8 dyoung */
183 1.14 dyoung #define ATW_C_FRCTL_DRVLINKCTRL __BIT(24) /* 1: driver controls link LED
184 1.8 dyoung * 0: ASIC controls link LED
185 1.8 dyoung */
186 1.14 dyoung #define ATW_C_FRCTL_DRVLINKON __BIT(23) /* 1: turn on link LED
187 1.8 dyoung * 0: turn off link LED
188 1.8 dyoung */
189 1.14 dyoung #define ATW_C_FRCTL_CTX_DATA __BIT(22) /* 0: set by CSR28
190 1.8 dyoung * 1: random
191 1.8 dyoung */
192 1.14 dyoung #define ATW_C_FRCTL_RSVFRM __BIT(21) /* 1: receive "reserved"
193 1.8 dyoung * frames, 0: ignore
194 1.8 dyoung * reserved frames
195 1.8 dyoung */
196 1.14 dyoung #define ATW_C_FRCTL_CFEND __BIT(19) /* write to send CF_END,
197 1.8 dyoung * ADM8211C/CR clears
198 1.8 dyoung */
199 1.14 dyoung #define ATW_FRCTL_DOZEFRM __BIT(18) /* select pre-sleep frame */
200 1.14 dyoung #define ATW_FRCTL_PSAWAKE __BIT(17) /* MAC is awake (?) */
201 1.14 dyoung #define ATW_FRCTL_PSMODE __BIT(16) /* MAC is power-saving (?) */
202 1.14 dyoung #define ATW_FRCTL_AID_MASK __BITS(0, 15) /* STA Association ID */
203 1.14 dyoung
204 1.14 dyoung #define ATW_INTR_PCF __BIT(31) /* started/ended CFP */
205 1.14 dyoung #define ATW_INTR_BCNTC __BIT(30) /* transmitted IBSS beacon */
206 1.14 dyoung #define ATW_INTR_GPINT __BIT(29) /* GPIO interrupt */
207 1.14 dyoung #define ATW_INTR_LINKOFF __BIT(28) /* lost ATW_WCSR_BLN beacons */
208 1.14 dyoung #define ATW_INTR_ATIMTC __BIT(27) /* transmitted ATIM */
209 1.14 dyoung #define ATW_INTR_TSFTF __BIT(26) /* TSFT out of range */
210 1.14 dyoung #define ATW_INTR_TSCZ __BIT(25) /* TSC countdown expired */
211 1.14 dyoung #define ATW_INTR_LINKON __BIT(24) /* matched SSID, BSSID */
212 1.14 dyoung #define ATW_INTR_SQL __BIT(23) /* Marvel signal quality */
213 1.14 dyoung #define ATW_INTR_WEPTD __BIT(22) /* switched WEP table */
214 1.14 dyoung #define ATW_INTR_ATIME __BIT(21) /* ended ATIM window */
215 1.14 dyoung #define ATW_INTR_TBTT __BIT(20) /* (TBTT) Target Beacon TX Time
216 1.1 dyoung * passed
217 1.1 dyoung */
218 1.14 dyoung #define ATW_INTR_NISS __BIT(16) /* normal interrupt status
219 1.1 dyoung * summary: any of 31, 30, 27,
220 1.1 dyoung * 24, 14, 12, 6, 2, 0.
221 1.1 dyoung */
222 1.14 dyoung #define ATW_INTR_AISS __BIT(15) /* abnormal interrupt status
223 1.1 dyoung * summary: any of 29, 28, 26,
224 1.1 dyoung * 25, 23, 22, 13, 11, 8, 7, 5,
225 1.1 dyoung * 4, 3, 1.
226 1.1 dyoung */
227 1.14 dyoung #define ATW_INTR_TEIS __BIT(14) /* transmit early interrupt
228 1.1 dyoung * status: moved TX packet to
229 1.1 dyoung * FIFO
230 1.1 dyoung */
231 1.14 dyoung #define ATW_INTR_FBE __BIT(13) /* fatal bus error */
232 1.14 dyoung #define ATW_INTR_REIS __BIT(12) /* receive early interrupt
233 1.1 dyoung * status: RX packet filled
234 1.1 dyoung * its first descriptor
235 1.1 dyoung */
236 1.14 dyoung #define ATW_INTR_GPTT __BIT(11) /* general purpose timer expired */
237 1.14 dyoung #define ATW_INTR_RPS __BIT(8) /* stopped receive process */
238 1.14 dyoung #define ATW_INTR_RDU __BIT(7) /* receive descriptor
239 1.1 dyoung * unavailable
240 1.1 dyoung */
241 1.14 dyoung #define ATW_INTR_RCI __BIT(6) /* completed packet reception */
242 1.14 dyoung #define ATW_INTR_TUF __BIT(5) /* transmit underflow */
243 1.14 dyoung #define ATW_INTR_TRT __BIT(4) /* transmit retry count
244 1.1 dyoung * expired
245 1.1 dyoung */
246 1.14 dyoung #define ATW_INTR_TLT __BIT(3) /* transmit lifetime exceeded */
247 1.14 dyoung #define ATW_INTR_TDU __BIT(2) /* transmit descriptor
248 1.1 dyoung * unavailable
249 1.1 dyoung */
250 1.14 dyoung #define ATW_INTR_TPS __BIT(1) /* stopped transmit process */
251 1.14 dyoung #define ATW_INTR_TCI __BIT(0) /* completed transmit */
252 1.14 dyoung #define ATW_NAR_TXCF __BIT(31) /* stop process on TX failure */
253 1.14 dyoung #define ATW_NAR_HF __BIT(30) /* flush TX FIFO to host (?) */
254 1.14 dyoung #define ATW_NAR_UTR __BIT(29) /* select retry count source */
255 1.14 dyoung #define ATW_NAR_PCF __BIT(28) /* use one/both transmit
256 1.1 dyoung * descriptor base addresses
257 1.1 dyoung */
258 1.14 dyoung #define ATW_NAR_CFP __BIT(27) /* indicate more TX data to
259 1.1 dyoung * point coordinator
260 1.1 dyoung */
261 1.14 dyoung #define ATW_C_NAR_APSTA __BIT(26) /* 0: STA mode
262 1.8 dyoung * 1: AP mode
263 1.8 dyoung */
264 1.14 dyoung #define ATW_C_NAR_TDBBE __BIT(25) /* 0: disable TDBB
265 1.8 dyoung * 1: enable TDBB
266 1.8 dyoung */
267 1.14 dyoung #define ATW_C_NAR_TDBHE __BIT(24) /* 0: disable TDBH
268 1.8 dyoung * 1: enable TDBH
269 1.8 dyoung */
270 1.14 dyoung #define ATW_C_NAR_TDBHT __BIT(23) /* write 1 to make ASIC
271 1.8 dyoung * poll TDBH once; ASIC clears
272 1.8 dyoung */
273 1.14 dyoung #define ATW_NAR_SF __BIT(21) /* store and forward: ignore
274 1.1 dyoung * TX threshold
275 1.1 dyoung */
276 1.14 dyoung #define ATW_NAR_TR_MASK __BITS(14, 15) /* TX threshold */
277 1.13 dyoung #define ATW_NAR_TR_L64 SHIFTIN(0x0, ATW_NAR_TR_MASK)
278 1.13 dyoung #define ATW_NAR_TR_L160 SHIFTIN(0x2, ATW_NAR_TR_MASK)
279 1.13 dyoung #define ATW_NAR_TR_L192 SHIFTIN(0x3, ATW_NAR_TR_MASK)
280 1.13 dyoung #define ATW_NAR_TR_H96 SHIFTIN(0x0, ATW_NAR_TR_MASK)
281 1.13 dyoung #define ATW_NAR_TR_H288 SHIFTIN(0x2, ATW_NAR_TR_MASK)
282 1.13 dyoung #define ATW_NAR_TR_H544 SHIFTIN(0x3, ATW_NAR_TR_MASK)
283 1.14 dyoung #define ATW_NAR_ST __BIT(13) /* start/stop transmit */
284 1.14 dyoung #define ATW_NAR_OM_MASK __BITS(10, 11) /* operating mode */
285 1.1 dyoung #define ATW_NAR_OM_NORMAL 0x0
286 1.13 dyoung #define ATW_NAR_OM_LOOPBACK SHIFTIN(0x1, ATW_NAR_OM_MASK)
287 1.14 dyoung #define ATW_NAR_MM __BIT(7) /* RX any multicast */
288 1.14 dyoung #define ATW_NAR_PR __BIT(6) /* promiscuous mode */
289 1.14 dyoung #define ATW_NAR_EA __BIT(5) /* match ad hoc packets (?) */
290 1.14 dyoung #define ATW_NAR_DISPCF __BIT(4) /* 1: PCF *not* supported
291 1.8 dyoung * 0: PCF supported
292 1.8 dyoung */
293 1.14 dyoung #define ATW_NAR_PB __BIT(3) /* pass bad packets */
294 1.14 dyoung #define ATW_NAR_STPDMA __BIT(2) /* stop DMA, abort packet */
295 1.14 dyoung #define ATW_NAR_SR __BIT(1) /* start/stop receive */
296 1.14 dyoung #define ATW_NAR_CTX __BIT(0) /* continuous TX mode */
297 1.1 dyoung
298 1.1 dyoung /* IER bits are identical to STSR bits. Use ATW_INTR_*. */
299 1.1 dyoung #if 0
300 1.14 dyoung #define ATW_IER_NIE __BIT(16) /* normal interrupt enable */
301 1.14 dyoung #define ATW_IER_AIE __BIT(15) /* abnormal interrupt enable */
302 1.1 dyoung /* normal interrupts: combine with ATW_IER_NIE */
303 1.14 dyoung #define ATW_IER_PCFIE __BIT(31) /* STA entered CFP */
304 1.14 dyoung #define ATW_IER_BCNTCIE __BIT(30) /* STA TX'd beacon */
305 1.14 dyoung #define ATW_IER_ATIMTCIE __BIT(27) /* transmitted ATIM */
306 1.14 dyoung #define ATW_IER_LINKONIE __BIT(24) /* matched beacon */
307 1.14 dyoung #define ATW_IER_ATIMIE __BIT(21) /* ended ATIM window */
308 1.14 dyoung #define ATW_IER_TBTTIE __BIT(20) /* TBTT */
309 1.14 dyoung #define ATW_IER_TEIE __BIT(14) /* moved TX packet to FIFO */
310 1.14 dyoung #define ATW_IER_REIE __BIT(12) /* RX packet filled its first
311 1.1 dyoung * descriptor
312 1.1 dyoung */
313 1.14 dyoung #define ATW_IER_RCIE __BIT(6) /* completed RX */
314 1.14 dyoung #define ATW_IER_TDUIE __BIT(2) /* transmit descriptor
315 1.1 dyoung * unavailable
316 1.1 dyoung */
317 1.14 dyoung #define ATW_IER_TCIE __BIT(0) /* completed TX */
318 1.1 dyoung /* abnormal interrupts: combine with ATW_IER_AIE */
319 1.14 dyoung #define ATW_IER_GPIE __BIT(29) /* GPIO interrupt */
320 1.14 dyoung #define ATW_IER_LINKOFFIE __BIT(28) /* lost beacon */
321 1.14 dyoung #define ATW_IER_TSFTFIE __BIT(26) /* TSFT out of range */
322 1.14 dyoung #define ATW_IER_TSCIE __BIT(25) /* TSC countdown expired */
323 1.14 dyoung #define ATW_IER_SQLIE __BIT(23) /* signal quality */
324 1.14 dyoung #define ATW_IER_WEPIE __BIT(22) /* finished WEP table switch */
325 1.14 dyoung #define ATW_IER_FBEIE __BIT(13) /* fatal bus error */
326 1.14 dyoung #define ATW_IER_GPTIE __BIT(11) /* general purpose timer expired */
327 1.14 dyoung #define ATW_IER_RPSIE __BIT(8) /* stopped receive process */
328 1.14 dyoung #define ATW_IER_RUIE __BIT(7) /* receive descriptor unavailable */
329 1.14 dyoung #define ATW_IER_TUIE __BIT(5) /* transmit underflow */
330 1.14 dyoung #define ATW_IER_TRTIE __BIT(4) /* exceeded transmit retry count */
331 1.14 dyoung #define ATW_IER_TLTTIE __BIT(3) /* transmit lifetime exceeded */
332 1.14 dyoung #define ATW_IER_TPSIE __BIT(1) /* stopped transmit process */
333 1.1 dyoung #endif
334 1.1 dyoung
335 1.14 dyoung #define ATW_LPC_LPCO __BIT(16) /* lost packet counter overflow */
336 1.14 dyoung #define ATW_LPC_LPC_MASK __BITS(0, 15) /* lost packet counter */
337 1.1 dyoung
338 1.14 dyoung #define ATW_TEST1_CONTROL __BIT(31) /* "0: read from dxfer_control,
339 1.8 dyoung * 1: read from dxfer_state"
340 1.8 dyoung */
341 1.14 dyoung #define ATW_TEST1_DBGREAD_MASK __BITS(30,28) /* "control of read data,
342 1.8 dyoung * debug only"
343 1.8 dyoung */
344 1.14 dyoung #define ATW_TEST1_TXWP_MASK __BITS(27,25) /* select ATW_WTDP content? */
345 1.13 dyoung #define ATW_TEST1_TXWP_TDBD SHIFTIN(0x0, ATW_TEST1_TXWP_MASK)
346 1.13 dyoung #define ATW_TEST1_TXWP_TDBH SHIFTIN(0x1, ATW_TEST1_TXWP_MASK)
347 1.13 dyoung #define ATW_TEST1_TXWP_TDBB SHIFTIN(0x2, ATW_TEST1_TXWP_MASK)
348 1.13 dyoung #define ATW_TEST1_TXWP_TDBP SHIFTIN(0x3, ATW_TEST1_TXWP_MASK)
349 1.14 dyoung #define ATW_TEST1_RSVD0_MASK __BITS(24,6) /* reserved */
350 1.14 dyoung #define ATW_TEST1_TESTMODE_MASK __BITS(5,4)
351 1.10 dyoung /* normal operation */
352 1.13 dyoung #define ATW_TEST1_TESTMODE_NORMAL SHIFTIN(0x0, ATW_TEST1_TESTMODE_MASK)
353 1.10 dyoung /* MAC-only mode */
354 1.13 dyoung #define ATW_TEST1_TESTMODE_MACONLY SHIFTIN(0x1, ATW_TEST1_TESTMODE_MASK)
355 1.10 dyoung /* normal operation */
356 1.13 dyoung #define ATW_TEST1_TESTMODE_NORMAL2 SHIFTIN(0x2, ATW_TEST1_TESTMODE_MASK)
357 1.10 dyoung /* monitor mode */
358 1.13 dyoung #define ATW_TEST1_TESTMODE_MONITOR SHIFTIN(0x3, ATW_TEST1_TESTMODE_MASK)
359 1.8 dyoung
360 1.14 dyoung #define ATW_TEST1_DUMP_MASK __BITS(3,0) /* select dump signal
361 1.14 dyoung * from dxfer (huh?)
362 1.14 dyoung */
363 1.8 dyoung
364 1.14 dyoung #define ATW_SPR_SRS __BIT(11) /* activate SEEPROM access */
365 1.14 dyoung #define ATW_SPR_SDO __BIT(3) /* data out of SEEPROM */
366 1.14 dyoung #define ATW_SPR_SDI __BIT(2) /* data into SEEPROM */
367 1.14 dyoung #define ATW_SPR_SCLK __BIT(1) /* SEEPROM clock */
368 1.14 dyoung #define ATW_SPR_SCS __BIT(0) /* SEEPROM chip select */
369 1.1 dyoung
370 1.14 dyoung #define ATW_TEST0_BE_MASK __BITS(31, 29) /* Bus error state */
371 1.14 dyoung #define ATW_TEST0_TS_MASK __BITS(28, 26) /* Transmit process state */
372 1.1 dyoung
373 1.1 dyoung /* Stopped */
374 1.13 dyoung #define ATW_TEST0_TS_STOPPED SHIFTIN(0, ATW_TEST0_TS_MASK)
375 1.1 dyoung /* Running - fetch transmit descriptor */
376 1.13 dyoung #define ATW_TEST0_TS_FETCH SHIFTIN(1, ATW_TEST0_TS_MASK)
377 1.1 dyoung /* Running - wait for end of transmission */
378 1.13 dyoung #define ATW_TEST0_TS_WAIT SHIFTIN(2, ATW_TEST0_TS_MASK)
379 1.1 dyoung /* Running - read buffer from memory and queue into FIFO */
380 1.13 dyoung #define ATW_TEST0_TS_READING SHIFTIN(3, ATW_TEST0_TS_MASK)
381 1.13 dyoung #define ATW_TEST0_TS_RESERVED1 SHIFTIN(4, ATW_TEST0_TS_MASK)
382 1.13 dyoung #define ATW_TEST0_TS_RESERVED2 SHIFTIN(5, ATW_TEST0_TS_MASK)
383 1.1 dyoung /* Suspended */
384 1.13 dyoung #define ATW_TEST0_TS_SUSPENDED SHIFTIN(6, ATW_TEST0_TS_MASK)
385 1.1 dyoung /* Running - close transmit descriptor */
386 1.13 dyoung #define ATW_TEST0_TS_CLOSE SHIFTIN(7, ATW_TEST0_TS_MASK)
387 1.1 dyoung
388 1.11 perry /* ADM8211C/CR registers */
389 1.8 dyoung /* Suspended */
390 1.13 dyoung #define ATW_C_TEST0_TS_SUSPENDED SHIFTIN(4, ATW_TEST0_TS_MASK)
391 1.8 dyoung /* Descriptor write */
392 1.13 dyoung #define ATW_C_TEST0_TS_CLOSE SHIFTIN(5, ATW_TEST0_TS_MASK)
393 1.8 dyoung /* Last descriptor write */
394 1.13 dyoung #define ATW_C_TEST0_TS_CLOSELAST SHIFTIN(6, ATW_TEST0_TS_MASK)
395 1.8 dyoung /* FIFO full */
396 1.13 dyoung #define ATW_C_TEST0_TS_FIFOFULL SHIFTIN(7, ATW_TEST0_TS_MASK)
397 1.8 dyoung
398 1.14 dyoung #define ATW_TEST0_RS_MASK __BITS(25, 23) /* Receive process state */
399 1.1 dyoung
400 1.1 dyoung /* Stopped */
401 1.13 dyoung #define ATW_TEST0_RS_STOPPED SHIFTIN(0, ATW_TEST0_RS_MASK)
402 1.1 dyoung /* Running - fetch receive descriptor */
403 1.13 dyoung #define ATW_TEST0_RS_FETCH SHIFTIN(1, ATW_TEST0_RS_MASK)
404 1.1 dyoung /* Running - check for end of receive */
405 1.13 dyoung #define ATW_TEST0_RS_CHECK SHIFTIN(2, ATW_TEST0_RS_MASK)
406 1.1 dyoung /* Running - wait for packet */
407 1.13 dyoung #define ATW_TEST0_RS_WAIT SHIFTIN(3, ATW_TEST0_RS_MASK)
408 1.1 dyoung /* Suspended */
409 1.13 dyoung #define ATW_TEST0_RS_SUSPENDED SHIFTIN(4, ATW_TEST0_RS_MASK)
410 1.1 dyoung /* Running - close receive descriptor */
411 1.13 dyoung #define ATW_TEST0_RS_CLOSE SHIFTIN(5, ATW_TEST0_RS_MASK)
412 1.1 dyoung /* Running - flush current frame from FIFO */
413 1.13 dyoung #define ATW_TEST0_RS_FLUSH SHIFTIN(6, ATW_TEST0_RS_MASK)
414 1.1 dyoung /* Running - queue current frame from FIFO into buffer */
415 1.13 dyoung #define ATW_TEST0_RS_QUEUE SHIFTIN(7, ATW_TEST0_RS_MASK)
416 1.1 dyoung
417 1.14 dyoung #define ATW_TEST0_EPNE __BIT(18) /* SEEPROM not detected */
418 1.14 dyoung #define ATW_TEST0_EPSNM __BIT(17) /* SEEPROM bad signature */
419 1.14 dyoung #define ATW_TEST0_EPTYP_MASK __BIT(16) /* SEEPROM type
420 1.1 dyoung * 1: 93c66,
421 1.1 dyoung * 0: 93c46
422 1.1 dyoung */
423 1.1 dyoung #define ATW_TEST0_EPTYP_93c66 ATW_TEST0_EPTYP_MASK
424 1.1 dyoung #define ATW_TEST0_EPTYP_93c46 0
425 1.14 dyoung #define ATW_TEST0_EPRLD __BIT(15) /* recall SEEPROM (write 1) */
426 1.1 dyoung
427 1.14 dyoung #define ATW_WCSR_CRCT __BIT(30) /* CRC-16 type */
428 1.14 dyoung #define ATW_WCSR_WP1E __BIT(29) /* match wake-up pattern 1 */
429 1.14 dyoung #define ATW_WCSR_WP2E __BIT(28) /* match wake-up pattern 2 */
430 1.14 dyoung #define ATW_WCSR_WP3E __BIT(27) /* match wake-up pattern 3 */
431 1.14 dyoung #define ATW_WCSR_WP4E __BIT(26) /* match wake-up pattern 4 */
432 1.14 dyoung #define ATW_WCSR_WP5E __BIT(25) /* match wake-up pattern 5 */
433 1.14 dyoung #define ATW_WCSR_BLN_MASK __BITS(21, 23) /* lose link after BLN lost
434 1.1 dyoung * beacons
435 1.1 dyoung */
436 1.14 dyoung #define ATW_WCSR_TSFTWE __BIT(20) /* wake up on TSFT out of
437 1.1 dyoung * range
438 1.1 dyoung */
439 1.14 dyoung #define ATW_WCSR_TIMWE __BIT(19) /* wake up on TIM */
440 1.14 dyoung #define ATW_WCSR_ATIMWE __BIT(18) /* wake up on ATIM */
441 1.14 dyoung #define ATW_WCSR_KEYWE __BIT(17) /* wake up on key update */
442 1.14 dyoung #define ATW_WCSR_WFRE __BIT(10) /* wake up on wake-up frame */
443 1.14 dyoung #define ATW_WCSR_MPRE __BIT(9) /* wake up on magic packet */
444 1.14 dyoung #define ATW_WCSR_LSOE __BIT(8) /* wake up on link loss */
445 1.1 dyoung /* wake-up reasons correspond to enable bits */
446 1.14 dyoung #define ATW_WCSR_KEYUP __BIT(6) /* */
447 1.14 dyoung #define ATW_WCSR_TSFTW __BIT(5) /* */
448 1.14 dyoung #define ATW_WCSR_TIMW __BIT(4) /* */
449 1.14 dyoung #define ATW_WCSR_ATIMW __BIT(3) /* */
450 1.14 dyoung #define ATW_WCSR_WFR __BIT(2) /* */
451 1.14 dyoung #define ATW_WCSR_MPR __BIT(1) /* */
452 1.14 dyoung #define ATW_WCSR_LSO __BIT(0) /* */
453 1.14 dyoung
454 1.14 dyoung #define ATW_GPTMR_COM_MASK __BIT(16) /* continuous operation mode */
455 1.14 dyoung #define ATW_GPTMR_GTV_MASK __BITS(0, 15) /* set countdown in 204us ticks */
456 1.14 dyoung
457 1.14 dyoung #define ATW_GPIO_EC1_MASK __BITS(25, 24) /* GPIO1 event configuration */
458 1.14 dyoung #define ATW_GPIO_LAT_MASK __BITS(21, 20) /* input latch */
459 1.14 dyoung #define ATW_GPIO_INTEN_MASK __BITS(19, 18) /* interrupt enable */
460 1.14 dyoung #define ATW_GPIO_EN_MASK __BITS(17, 12) /* output enable */
461 1.14 dyoung #define ATW_GPIO_O_MASK __BITS(11, 6) /* output value */
462 1.14 dyoung #define ATW_GPIO_I_MASK __BITS(5, 0) /* pin static input */
463 1.14 dyoung
464 1.14 dyoung /* Intersil 3-wire interface */
465 1.14 dyoung #define ATW_BBPCTL_TWI __BIT(31)
466 1.14 dyoung #define ATW_BBPCTL_RF3KADDR_MASK __BITS(30, 24) /* Address for RF3000 */
467 1.13 dyoung #define ATW_BBPCTL_RF3KADDR_ADDR SHIFTIN(0x20, ATW_BBPCTL_RF3KADDR_MASK)
468 1.14 dyoung /* data-out on negative edge */
469 1.14 dyoung #define ATW_BBPCTL_NEGEDGE_DO __BIT(23)
470 1.14 dyoung /* data-in on negative edge */
471 1.14 dyoung #define ATW_BBPCTL_NEGEDGE_DI __BIT(22)
472 1.14 dyoung #define ATW_BBPCTL_CCA_ACTLO __BIT(21) /* CCA low when busy */
473 1.14 dyoung #define ATW_BBPCTL_TYPE_MASK __BITS(20, 18) /* BBP type */
474 1.14 dyoung /* start write; reset on completion */
475 1.14 dyoung #define ATW_BBPCTL_WR __BIT(17)
476 1.14 dyoung #define ATW_BBPCTL_RD __BIT(16) /* start read; reset on
477 1.14 dyoung * completion
478 1.14 dyoung */
479 1.14 dyoung #define ATW_BBPCTL_ADDR_MASK __BITS(15, 8) /* BBP address */
480 1.14 dyoung #define ATW_BBPCTL_DATA_MASK __BITS(7, 0) /* BBP data */
481 1.1 dyoung
482 1.14 dyoung #define ATW_SYNCTL_WR __BIT(31) /* start write; reset on
483 1.1 dyoung * completion
484 1.1 dyoung */
485 1.14 dyoung #define ATW_SYNCTL_RD __BIT(30) /* start read; reset on
486 1.1 dyoung * completion
487 1.1 dyoung */
488 1.14 dyoung #define ATW_SYNCTL_CS0 __BIT(29) /* chip select */
489 1.14 dyoung #define ATW_SYNCTL_CS1 __BIT(28)
490 1.14 dyoung #define ATW_SYNCTL_CAL __BIT(27) /* generate RF CAL pulse after
491 1.1 dyoung * Rx
492 1.1 dyoung */
493 1.14 dyoung #define ATW_SYNCTL_SELCAL __BIT(26) /* RF CAL source, 0: CAL bit,
494 1.1 dyoung * 1: MAC; needed by Intersil
495 1.1 dyoung * BBP
496 1.1 dyoung */
497 1.14 dyoung #define ATW_C_SYNCTL_MMICE __BIT(25) /* ADM8211C/CR define this
498 1.8 dyoung * bit. 0: latch data on
499 1.8 dyoung * negative edge, 1: positive
500 1.8 dyoung * edge.
501 1.8 dyoung */
502 1.14 dyoung #define ATW_SYNCTL_RFTYPE_MASK __BITS(24, 22) /* RF type */
503 1.14 dyoung #define ATW_SYNCTL_DATA_MASK __BITS(21, 0) /* synthesizer setting */
504 1.1 dyoung
505 1.14 dyoung #define ATW_PLCPHD_SIGNAL_MASK __BITS(31, 24) /* signal field in PLCP header,
506 1.1 dyoung * only for beacon, ATIM, and
507 1.1 dyoung * RTS.
508 1.1 dyoung */
509 1.14 dyoung #define ATW_PLCPHD_SERVICE_MASK __BITS(23, 16) /* service field in PLCP
510 1.8 dyoung * header; with RFMD BBP,
511 1.8 dyoung * sets Tx power for beacon,
512 1.8 dyoung * RTS, ATIM.
513 1.1 dyoung */
514 1.14 dyoung #define ATW_PLCPHD_PMBL __BIT(15) /* 0: long preamble, 1: short */
515 1.1 dyoung
516 1.14 dyoung #define ATW_MMIWADDR_LENLO_MASK __BITS(31,24) /* tx: written 4th */
517 1.14 dyoung #define ATW_MMIWADDR_LENHI_MASK __BITS(23,16) /* tx: written 3rd */
518 1.14 dyoung #define ATW_MMIWADDR_GAIN_MASK __BITS(15,8) /* tx: written 2nd */
519 1.14 dyoung #define ATW_MMIWADDR_RATE_MASK __BITS(7,0) /* tx: written 1st */
520 1.10 dyoung
521 1.10 dyoung /* was magic 0x100E0C0A */
522 1.10 dyoung #define ATW_MMIWADDR_INTERSIL \
523 1.13 dyoung (SHIFTIN(0x0c, ATW_MMIWADDR_GAIN_MASK) | \
524 1.13 dyoung SHIFTIN(0x0a, ATW_MMIWADDR_RATE_MASK) | \
525 1.13 dyoung SHIFTIN(0x0e, ATW_MMIWADDR_LENHI_MASK) | \
526 1.13 dyoung SHIFTIN(0x10, ATW_MMIWADDR_LENLO_MASK))
527 1.1 dyoung
528 1.10 dyoung /* was magic 0x00009101
529 1.10 dyoung *
530 1.10 dyoung * ADMtek sets the AI bit on the ATW_MMIWADDR_GAIN_MASK address to
531 1.10 dyoung * put the RF3000 into auto-increment mode so that it can write Tx gain,
532 1.10 dyoung * Tx length (high) and Tx length (low) registers back-to-back.
533 1.10 dyoung */
534 1.10 dyoung #define ATW_MMIWADDR_RFMD \
535 1.13 dyoung (SHIFTIN(RF3000_TWI_AI|RF3000_GAINCTL, ATW_MMIWADDR_GAIN_MASK) | \
536 1.13 dyoung SHIFTIN(RF3000_CTL, ATW_MMIWADDR_RATE_MASK))
537 1.10 dyoung
538 1.14 dyoung #define ATW_MMIRADDR1_RSVD_MASK __BITS(31, 24)
539 1.14 dyoung #define ATW_MMIRADDR1_PWRLVL_MASK __BITS(23, 16)
540 1.14 dyoung #define ATW_MMIRADDR1_RSSI_MASK __BITS(15, 8)
541 1.14 dyoung #define ATW_MMIRADDR1_RXSTAT_MASK __BITS(7, 0)
542 1.1 dyoung
543 1.10 dyoung /* was magic 0x00007c7e
544 1.10 dyoung *
545 1.10 dyoung * TBD document registers for Intersil 3861 baseband
546 1.10 dyoung */
547 1.10 dyoung #define ATW_MMIRADDR1_INTERSIL \
548 1.13 dyoung (SHIFTIN(0x7c, ATW_MMIRADDR1_RSSI_MASK) | \
549 1.13 dyoung SHIFTIN(0x7e, ATW_MMIRADDR1_RXSTAT_MASK))
550 1.10 dyoung
551 1.10 dyoung /* was magic 0x00000301 */
552 1.10 dyoung #define ATW_MMIRADDR1_RFMD \
553 1.13 dyoung (SHIFTIN(RF3000_RSSI, ATW_MMIRADDR1_RSSI_MASK) | \
554 1.13 dyoung SHIFTIN(RF3000_RXSTAT, ATW_MMIRADDR1_RXSTAT_MASK))
555 1.10 dyoung
556 1.10 dyoung /* was magic 0x00100000 */
557 1.10 dyoung #define ATW_MMIRADDR2_INTERSIL \
558 1.13 dyoung (SHIFTIN(0x0, ATW_MMIRADDR2_ID_MASK) | \
559 1.13 dyoung SHIFTIN(0x10, ATW_MMIRADDR2_RXPECNT_MASK))
560 1.10 dyoung
561 1.10 dyoung /* was magic 0x7e100000 */
562 1.10 dyoung #define ATW_MMIRADDR2_RFMD \
563 1.13 dyoung (SHIFTIN(0x7e, ATW_MMIRADDR2_ID_MASK) | \
564 1.13 dyoung SHIFTIN(0x10, ATW_MMIRADDR2_RXPECNT_MASK))
565 1.10 dyoung
566 1.14 dyoung #define ATW_MMIRADDR2_ID_MASK __BITS(31, 24) /* 1st element ID in WEP table
567 1.10 dyoung * for Probe Response (huh?)
568 1.10 dyoung */
569 1.10 dyoung /* RXPE is re-asserted after RXPECNT * 22MHz. */
570 1.14 dyoung #define ATW_MMIRADDR2_RXPECNT_MASK __BITS(23, 16)
571 1.14 dyoung #define ATW_MMIRADDR2_PROREXT __BIT(15) /* Probe Response
572 1.10 dyoung * 11Mb/s length
573 1.10 dyoung * extension.
574 1.10 dyoung */
575 1.14 dyoung #define ATW_MMIRADDR2_PRORLEN_MASK __BITS(14, 0) /* Probe Response
576 1.10 dyoung * microsecond length
577 1.10 dyoung */
578 1.1 dyoung
579 1.14 dyoung /* auto-update BBP with ALCSET */
580 1.14 dyoung #define ATW_TXBR_ALCUPDATE_MASK __BIT(31)
581 1.14 dyoung #define ATW_TXBR_TBCNT_MASK __BITS(16, 20) /* transmit burst count */
582 1.14 dyoung #define ATW_TXBR_ALCSET_MASK __BITS(8, 15) /* TX power level set point */
583 1.14 dyoung #define ATW_TXBR_ALCREF_MASK __BITS(0, 7) /* TX power level reference point */
584 1.14 dyoung
585 1.14 dyoung #define ATW_ALCSTAT_MCOV_MASK __BIT(27) /* MPDU count overflow */
586 1.14 dyoung #define ATW_ALCSTAT_ESOV_MASK __BIT(26) /* error sum overflow */
587 1.14 dyoung #define ATW_ALCSTAT_MCNT_MASK __BITS(16, 25) /* MPDU count, unsigned integer */
588 1.14 dyoung #define ATW_ALCSTAT_ERSUM_MASK __BITS(0, 15) /* power error sum,
589 1.1 dyoung * 2's complement signed integer
590 1.1 dyoung */
591 1.1 dyoung
592 1.14 dyoung #define ATW_TOFS2_PWR1UP_MASK __BITS(31, 28) /* delay of Tx/Rx from PE1,
593 1.1 dyoung * Radio, PHYRST change after
594 1.1 dyoung * power-up, in 2ms units
595 1.1 dyoung */
596 1.14 dyoung #define ATW_TOFS2_PWR0PAPE_MASK __BITS(27, 24) /* delay of PAPE going low
597 1.1 dyoung * after internal data
598 1.1 dyoung * transmit end, in us
599 1.1 dyoung */
600 1.14 dyoung #define ATW_TOFS2_PWR1PAPE_MASK __BITS(23, 20) /* delay of PAPE going high
601 1.1 dyoung * after TXPE asserted, in us
602 1.1 dyoung */
603 1.14 dyoung #define ATW_TOFS2_PWR0TRSW_MASK __BITS(19, 16) /* delay of TRSW going low
604 1.1 dyoung * after internal data transmit
605 1.1 dyoung * end, in us
606 1.1 dyoung */
607 1.14 dyoung #define ATW_TOFS2_PWR1TRSW_MASK __BITS(15, 12) /* delay of TRSW going high
608 1.1 dyoung * after TXPE asserted, in us
609 1.1 dyoung */
610 1.14 dyoung #define ATW_TOFS2_PWR0PE2_MASK __BITS(11, 8) /* delay of PE2 going low
611 1.1 dyoung * after internal data transmit
612 1.1 dyoung * end, in us
613 1.1 dyoung */
614 1.14 dyoung #define ATW_TOFS2_PWR1PE2_MASK __BITS(7, 4) /* delay of PE2 going high
615 1.1 dyoung * after TXPE asserted, in us
616 1.1 dyoung */
617 1.14 dyoung #define ATW_TOFS2_PWR0TXPE_MASK __BITS(3, 0) /* delay of TXPE going low
618 1.1 dyoung * after internal data transmit
619 1.1 dyoung * end, in us
620 1.1 dyoung */
621 1.1 dyoung
622 1.14 dyoung #define ATW_CMDR_PM __BIT(19) /* enables power mgmt
623 1.1 dyoung * capabilities.
624 1.1 dyoung */
625 1.14 dyoung #define ATW_CMDR_APM __BIT(18) /* APM mode, effective when
626 1.1 dyoung * PM = 1.
627 1.1 dyoung */
628 1.14 dyoung #define ATW_CMDR_RTE __BIT(4) /* enable Rx FIFO threshold */
629 1.14 dyoung #define ATW_CMDR_DRT_MASK __BITS(3, 2) /* drain Rx FIFO threshold */
630 1.9 dyoung /* 32 bytes */
631 1.13 dyoung #define ATW_CMDR_DRT_8DW SHIFTIN(0x0, ATW_CMDR_DRT_MASK)
632 1.9 dyoung /* 64 bytes */
633 1.13 dyoung #define ATW_CMDR_DRT_16DW SHIFTIN(0x1, ATW_CMDR_DRT_MASK)
634 1.9 dyoung /* Store & Forward */
635 1.13 dyoung #define ATW_CMDR_DRT_SF SHIFTIN(0x2, ATW_CMDR_DRT_MASK)
636 1.9 dyoung /* Reserved */
637 1.13 dyoung #define ATW_CMDR_DRT_RSVD SHIFTIN(0x3, ATW_CMDR_DRT_MASK)
638 1.14 dyoung #define ATW_CMDR_SINT_MASK __BIT(1) /* software interrupt---huh? */
639 1.1 dyoung
640 1.1 dyoung /* TBD PCIC */
641 1.1 dyoung
642 1.1 dyoung /* TBD PMCSR */
643 1.1 dyoung
644 1.1 dyoung
645 1.14 dyoung #define ATW_PAR0_PAB0_MASK __BITS(0, 7) /* MAC address byte 0 */
646 1.14 dyoung #define ATW_PAR0_PAB1_MASK __BITS(8, 15) /* MAC address byte 1 */
647 1.14 dyoung #define ATW_PAR0_PAB2_MASK __BITS(16, 23) /* MAC address byte 2 */
648 1.14 dyoung #define ATW_PAR0_PAB3_MASK __BITS(24, 31) /* MAC address byte 3 */
649 1.14 dyoung
650 1.14 dyoung #define ATW_C_PAR1_CTD __BITS(16,31) /* Continuous Tx pattern */
651 1.14 dyoung #define ATW_PAR1_PAB5_MASK __BITS(8, 15) /* MAC address byte 5 */
652 1.14 dyoung #define ATW_PAR1_PAB4_MASK __BITS(0, 7) /* MAC address byte 4 */
653 1.14 dyoung
654 1.14 dyoung #define ATW_MAR0_MAB3_MASK __BITS(31, 24) /* multicast table bits 31:24 */
655 1.14 dyoung #define ATW_MAR0_MAB2_MASK __BITS(23, 16) /* multicast table bits 23:16 */
656 1.14 dyoung #define ATW_MAR0_MAB1_MASK __BITS(15, 8) /* multicast table bits 15:8 */
657 1.14 dyoung #define ATW_MAR0_MAB0_MASK __BITS(7, 0) /* multicast table bits 7:0 */
658 1.14 dyoung
659 1.14 dyoung #define ATW_MAR1_MAB7_MASK __BITS(31, 24) /* multicast table bits 63:56 */
660 1.14 dyoung #define ATW_MAR1_MAB6_MASK __BITS(23, 16) /* multicast table bits 55:48 */
661 1.14 dyoung #define ATW_MAR1_MAB5_MASK __BITS(15, 8) /* multicast table bits 47:40 */
662 1.14 dyoung #define ATW_MAR1_MAB4_MASK __BITS(7, 0) /* multicast table bits 39:32 */
663 1.1 dyoung
664 1.1 dyoung /* ATIM destination address */
665 1.14 dyoung #define ATW_ATIMDA0_ATIMB3_MASK __BITS(31,24)
666 1.14 dyoung #define ATW_ATIMDA0_ATIMB2_MASK __BITS(23,16)
667 1.14 dyoung #define ATW_ATIMDA0_ATIMB1_MASK __BITS(15,8)
668 1.14 dyoung #define ATW_ATIMDA0_ATIMB0_MASK __BITS(7,0)
669 1.1 dyoung
670 1.1 dyoung /* ATIM destination address, BSSID */
671 1.14 dyoung #define ATW_ABDA1_BSSIDB5_MASK __BITS(31,24)
672 1.14 dyoung #define ATW_ABDA1_BSSIDB4_MASK __BITS(23,16)
673 1.14 dyoung #define ATW_ABDA1_ATIMB5_MASK __BITS(15,8)
674 1.14 dyoung #define ATW_ABDA1_ATIMB4_MASK __BITS(7,0)
675 1.1 dyoung
676 1.1 dyoung /* BSSID */
677 1.14 dyoung #define ATW_BSSID0_BSSIDB3_MASK __BITS(31,24)
678 1.14 dyoung #define ATW_BSSID0_BSSIDB2_MASK __BITS(23,16)
679 1.14 dyoung #define ATW_BSSID0_BSSIDB1_MASK __BITS(15,8)
680 1.14 dyoung #define ATW_BSSID0_BSSIDB0_MASK __BITS(7,0)
681 1.14 dyoung
682 1.14 dyoung #define ATW_TXLMT_MTMLT_MASK __BITS(31,16) /* max TX MSDU lifetime in TU */
683 1.14 dyoung #define ATW_TXLMT_SRTYLIM_MASK __BITS(7,0) /* short retry limit */
684 1.14 dyoung
685 1.14 dyoung #define ATW_MIBCNT_FFCNT_MASK __BITS(31,24) /* FCS failure count */
686 1.14 dyoung #define ATW_MIBCNT_AFCNT_MASK __BITS(23,16) /* ACK failure count */
687 1.14 dyoung #define ATW_MIBCNT_RSCNT_MASK __BITS(15,8) /* RTS success count */
688 1.14 dyoung #define ATW_MIBCNT_RFCNT_MASK __BITS(7,0) /* RTS failure count */
689 1.14 dyoung
690 1.14 dyoung #define ATW_BCNT_PLCPH_MASK __BITS(23,16) /* 11M PLCP length (us) */
691 1.14 dyoung #define ATW_BCNT_PLCPL_MASK __BITS(15,8) /* 5.5M PLCP length (us) */
692 1.14 dyoung #define ATW_BCNT_BCNT_MASK __BITS(7,0) /* byte count of beacon frame */
693 1.1 dyoung
694 1.8 dyoung /* For ADM8211C/CR */
695 1.8 dyoung /* ATW_C_TSC_TIMTABSEL = 1 */
696 1.14 dyoung #define ATW_C_BCNT_EXTEN1 __BIT(31) /* 11M beacon len. extension */
697 1.14 dyoung #define ATW_C_BCNT_BEANLEN1 __BITS(30,16) /* beacon length in us */
698 1.8 dyoung /* ATW_C_TSC_TIMTABSEL = 0 */
699 1.14 dyoung #define ATW_C_BCNT_EXTEN0 __BIT(15) /* 11M beacon len. extension */
700 1.14 dyoung #define ATW_C_BCNT_BEANLEN0 __BIT(14,0) /* beacon length in us */
701 1.8 dyoung
702 1.14 dyoung #define ATW_C_TSC_TIMOFS __BITS(31,24) /* I think this is the
703 1.8 dyoung * SRAM offset for the TIM
704 1.8 dyoung */
705 1.14 dyoung #define ATW_C_TSC_TIMLEN __BITS(21,12) /* length of TIM */
706 1.14 dyoung #define ATW_C_TSC_TIMTABSEL __BIT(4) /* select TIM table 0 or 1 */
707 1.14 dyoung #define ATW_TSC_TSC_MASK __BITS(3,0) /* TSFT countdown value, 0
708 1.8 dyoung * disables
709 1.8 dyoung */
710 1.1 dyoung
711 1.14 dyoung #define ATW_SYNRF_SELSYN __BIT(31) /* 0: MAC controls SYN IF pins,
712 1.14 dyoung * 1: ATW_SYNRF
713 1.14 dyoung * controls SYN IF
714 1.14 dyoung * pins.
715 1.14 dyoung */
716 1.14 dyoung #define ATW_SYNRF_SELRF __BIT(30) /* 0: MAC controls RF IF pins,
717 1.14 dyoung * 1: ATW_SYNRF
718 1.14 dyoung * controls RF IF pins.
719 1.14 dyoung */
720 1.14 dyoung #define ATW_SYNRF_LERF __BIT(29) /* if SELSYN = 1, direct control
721 1.14 dyoung * of LERF# pin
722 1.14 dyoung */
723 1.14 dyoung #define ATW_SYNRF_LEIF __BIT(28) /* if SELSYN = 1, direct control
724 1.14 dyoung * of LEIF# pin
725 1.14 dyoung */
726 1.14 dyoung #define ATW_SYNRF_SYNCLK __BIT(27) /* if SELSYN = 1, direct control
727 1.14 dyoung * of SYNCLK pin
728 1.14 dyoung */
729 1.14 dyoung #define ATW_SYNRF_SYNDATA __BIT(26) /* if SELSYN = 1, direct control
730 1.14 dyoung * of SYNDATA pin
731 1.14 dyoung */
732 1.14 dyoung #define ATW_SYNRF_PE1 __BIT(25) /* if SELRF = 1, direct control
733 1.14 dyoung * of PE1 pin
734 1.14 dyoung */
735 1.14 dyoung #define ATW_SYNRF_PE2 __BIT(24) /* if SELRF = 1, direct control
736 1.14 dyoung * of PE2 pin
737 1.14 dyoung */
738 1.14 dyoung #define ATW_SYNRF_PAPE __BIT(23) /* if SELRF = 1, direct control
739 1.14 dyoung * of PAPE pin
740 1.14 dyoung */
741 1.14 dyoung #define ATW_C_SYNRF_TRSW __BIT(22) /* if SELRF = 1, direct control
742 1.14 dyoung * of TRSW pin
743 1.14 dyoung */
744 1.14 dyoung #define ATW_C_SYNRF_TRSWN __BIT(21) /* if SELRF = 1, direct control
745 1.14 dyoung * of TRSWn pin
746 1.14 dyoung */
747 1.14 dyoung #define ATW_SYNRF_INTERSIL_EN __BIT(20) /* if SELRF = 1, enables
748 1.14 dyoung * some signal used by the
749 1.14 dyoung * Intersil RF front-end?
750 1.14 dyoung * Undocumented.
751 1.14 dyoung */
752 1.14 dyoung #define ATW_SYNRF_PHYRST __BIT(18) /* if SELRF = 1, direct control
753 1.14 dyoung * of PHYRST# pin
754 1.14 dyoung */
755 1.8 dyoung /* 1: force TXPE = RXPE = 1 if ATW_CMDR[27] = 0. */
756 1.8 dyoung #define ATW_C_SYNRF_RF2958PD ATW_SYNRF_PHYRST
757 1.1 dyoung
758 1.14 dyoung #define ATW_BPLI_BP_MASK __BITS(31,16) /* beacon interval in TU */
759 1.14 dyoung #define ATW_BPLI_LI_MASK __BITS(15,0) /* STA listen interval in
760 1.1 dyoung * beacon intervals
761 1.1 dyoung */
762 1.1 dyoung
763 1.14 dyoung #define ATW_C_CAP0_TIMLEN1 __BITS(31,24) /* TIM table 1 len in bytes
764 1.8 dyoung * including TIM ID (XXX huh?)
765 1.8 dyoung */
766 1.14 dyoung #define ATW_C_CAP0_TIMLEN0 __BITS(23,16) /* TIM table 0 len in bytes,
767 1.8 dyoung * including TIM ID (XXX huh?)
768 1.8 dyoung */
769 1.14 dyoung #define ATW_C_CAP0_CWMAX __BITS(11,8) /* 1 <= CWMAX <= 5 fixes CW?
770 1.8 dyoung * 5 < CWMAX <= 9 sets max?
771 1.8 dyoung * 10?
772 1.8 dyoung * default 0
773 1.8 dyoung */
774 1.14 dyoung #define ATW_CAP0_RCVDTIM __BIT(4) /* receive every DTIM */
775 1.14 dyoung #define ATW_CAP0_CHN_MASK __BITS(3,0) /* current DSSS channel */
776 1.1 dyoung
777 1.14 dyoung #define ATW_CAP1_CAPI_MASK __BITS(31,16) /* capability information */
778 1.14 dyoung #define ATW_CAP1_ATIMW_MASK __BITS(15,0) /* ATIM window in TU */
779 1.1 dyoung
780 1.14 dyoung #define ATW_RMD_ATIMST __BIT(31) /* ATIM frame TX status */
781 1.14 dyoung #define ATW_RMD_CFP __BIT(30) /* CFP indicator */
782 1.14 dyoung #define ATW_RMD_PCNT __BITS(27,16) /* idle time between
783 1.9 dyoung * awake/ps mode, in seconds
784 1.1 dyoung */
785 1.14 dyoung #define ATW_RMD_RMRD_MASK __BITS(15,0) /* max RX reception duration
786 1.1 dyoung * in us
787 1.1 dyoung */
788 1.1 dyoung
789 1.14 dyoung #define ATW_CFPP_CFPP __BITS(31,24) /* CFP unit DTIM */
790 1.14 dyoung #define ATW_CFPP_CFPMD __BITS(23,8) /* CFP max duration in TU */
791 1.14 dyoung #define ATW_CFPP_DTIMP __BITS(7,0) /* DTIM period in beacon
792 1.1 dyoung * intervals
793 1.1 dyoung */
794 1.14 dyoung #define ATW_TOFS0_USCNT_MASK __BITS(29,24) /* number of system clocks
795 1.1 dyoung * in 1 microsecond.
796 1.1 dyoung * Depends PCI bus speed?
797 1.1 dyoung */
798 1.14 dyoung #define ATW_C_TOFS0_TUCNT_MASK __BITS(14,10) /* PIFS (microseconds) */
799 1.14 dyoung #define ATW_TOFS0_TUCNT_MASK __BITS(9,0) /* TU counter in microseconds */
800 1.1 dyoung
801 1.1 dyoung /* TBD TOFS1 */
802 1.14 dyoung #define ATW_TOFS1_TSFTOFSR_MASK __BITS(31,24) /* RX TSFT offset in
803 1.1 dyoung * microseconds: RF+BBP
804 1.1 dyoung * latency
805 1.1 dyoung */
806 1.14 dyoung #define ATW_TOFS1_TBTTPRE_MASK __BITS(23,8) /* prediction time, (next
807 1.1 dyoung * Nth TBTT - TBTTOFS) in
808 1.1 dyoung * microseconds (huh?). To
809 1.1 dyoung * match TSFT[25:10] (huh?).
810 1.1 dyoung */
811 1.14 dyoung #define ATW_TBTTPRE_MASK __BITS(25, 10)
812 1.14 dyoung #define ATW_TOFS1_TBTTOFS_MASK __BITS(7,0) /* wake-up time offset before
813 1.1 dyoung * TBTT in TU
814 1.1 dyoung */
815 1.14 dyoung #define ATW_IFST_SLOT_MASK __BITS(27,23) /* SLOT time in us */
816 1.14 dyoung #define ATW_IFST_SIFS_MASK __BITS(22,15) /* SIFS time in us */
817 1.14 dyoung #define ATW_IFST_DIFS_MASK __BITS(14,9) /* DIFS time in us */
818 1.14 dyoung #define ATW_IFST_EIFS_MASK __BITS(8,0) /* EIFS time in us */
819 1.14 dyoung
820 1.14 dyoung #define ATW_RSPT_MART_MASK __BITS(31,16) /* max response time in us */
821 1.14 dyoung #define ATW_RSPT_MIRT_MASK __BITS(15,8) /* min response time in us */
822 1.14 dyoung #define ATW_RSPT_TSFTOFST_MASK __BITS(7,0) /* TX TSFT offset in us */
823 1.14 dyoung
824 1.14 dyoung #define ATW_WEPCTL_WEPENABLE __BIT(31) /* enable WEP engine */
825 1.14 dyoung #define ATW_WEPCTL_AUTOSWITCH __BIT(30) /* auto-switch enable (huh?) */
826 1.14 dyoung #define ATW_WEPCTL_CURTBL __BIT(29) /* current table in use */
827 1.14 dyoung #define ATW_WEPCTL_WR __BIT(28) /* */
828 1.14 dyoung #define ATW_WEPCTL_RD __BIT(27) /* */
829 1.14 dyoung #define ATW_WEPCTL_WEPRXBYP __BIT(25) /* bypass WEP on RX */
830 1.14 dyoung #define ATW_WEPCTL_SHKEY __BIT(24) /* 1: pass to host if tbl
831 1.8 dyoung * lookup fails, 0: use
832 1.8 dyoung * shared-key
833 1.8 dyoung */
834 1.14 dyoung #define ATW_WEPCTL_UNKNOWN0 __BIT(23) /* has something to do with
835 1.1 dyoung * revision 0x20. Possibly
836 1.1 dyoung * selects a different WEP
837 1.1 dyoung * table.
838 1.1 dyoung */
839 1.14 dyoung #define ATW_WEPCTL_TBLADD_MASK __BITS(8,0) /* add to table */
840 1.1 dyoung
841 1.1 dyoung /* set these bits in the second byte of a SRAM shared key record to affect
842 1.1 dyoung * the use and interpretation of the key in the record.
843 1.1 dyoung */
844 1.14 dyoung #define ATW_WEP_ENABLED __BIT(7)
845 1.14 dyoung #define ATW_WEP_104BIT __BIT(6)
846 1.1 dyoung
847 1.14 dyoung #define ATW_WESK_DATA_MASK __BITS(15,0) /* data */
848 1.14 dyoung #define ATW_WEPCNT_WIEC_MASK __BITS(15,0) /* WEP ICV error count */
849 1.1 dyoung
850 1.14 dyoung #define ATW_MACTEST_FORCE_IV __BIT(23)
851 1.14 dyoung #define ATW_MACTEST_FORCE_KEYID __BIT(22)
852 1.14 dyoung #define ATW_MACTEST_KEYID_MASK __BITS(21,20)
853 1.14 dyoung #define ATW_MACTEST_MMI_USETXCLK __BIT(11)
854 1.1 dyoung
855 1.1 dyoung /* Function Event/Status registers */
856 1.1 dyoung
857 1.14 dyoung /* interrupt: set regardless of mask */
858 1.14 dyoung #define ATW_FER_INTR __BIT(15)
859 1.14 dyoung /* general wake-up: set regardless of mask */
860 1.14 dyoung #define ATW_FER_GWAKE __BIT(4)
861 1.14 dyoung
862 1.14 dyoung #define ATW_FEMR_INTR_EN __BIT(15) /* enable INTA# */
863 1.14 dyoung #define ATW_FEMR_WAKEUP_EN __BIT(14) /* enable wake-up */
864 1.14 dyoung #define ATW_FEMR_GWAKE_EN __BIT(4) /* enable general wake-up */
865 1.14 dyoung
866 1.14 dyoung #define ATW_FPSR_INTR_STATUS __BIT(15) /* interrupt status */
867 1.14 dyoung #define ATW_FPSR_WAKEUP_STATUS __BIT(4) /* CSTSCHG state */
868 1.14 dyoung /* activate INTA (if not masked) */
869 1.14 dyoung #define ATW_FFER_INTA_FORCE __BIT(15)
870 1.14 dyoung /* activate CSTSCHG (if not masked) */
871 1.14 dyoung #define ATW_FFER_GWAKE_FORCE __BIT(4)
872 1.1 dyoung
873 1.1 dyoung /* Serial EEPROM offsets */
874 1.1 dyoung #define ATW_SR_CLASS_CODE (0x00/2)
875 1.1 dyoung #define ATW_SR_FORMAT_VERSION (0x02/2)
876 1.14 dyoung #define ATW_SR_MAJOR_MASK __BITS(7, 0)
877 1.14 dyoung #define ATW_SR_MINOR_MASK __BITS(15,8)
878 1.1 dyoung #define ATW_SR_MAC00 (0x08/2) /* CSR21 */
879 1.1 dyoung #define ATW_SR_MAC01 (0x0A/2) /* CSR21/22 */
880 1.1 dyoung #define ATW_SR_MAC10 (0x0C/2) /* CSR22 */
881 1.1 dyoung #define ATW_SR_CSR20 (0x16/2)
882 1.14 dyoung #define ATW_SR_ANT_MASK __BITS(12, 10)
883 1.14 dyoung #define ATW_SR_PWRSCALE_MASK __BITS(9, 8)
884 1.14 dyoung #define ATW_SR_CLKSAVE_MASK __BITS(7, 6)
885 1.14 dyoung #define ATW_SR_RFTYPE_MASK __BITS(5, 3)
886 1.14 dyoung #define ATW_SR_BBPTYPE_MASK __BITS(2, 0)
887 1.1 dyoung #define ATW_SR_CR28_CR03 (0x18/2)
888 1.14 dyoung #define ATW_SR_CR28_MASK __BITS(15,8)
889 1.14 dyoung #define ATW_SR_CR03_MASK __BITS(7, 0)
890 1.1 dyoung #define ATW_SR_CTRY_CR29 (0x1A/2)
891 1.14 dyoung #define ATW_SR_CTRY_MASK __BITS(15,8) /* country code */
892 1.2 dyoung #define COUNTRY_FCC 0
893 1.2 dyoung #define COUNTRY_IC 1
894 1.2 dyoung #define COUNTRY_ETSI 2
895 1.2 dyoung #define COUNTRY_SPAIN 3
896 1.2 dyoung #define COUNTRY_FRANCE 4
897 1.2 dyoung #define COUNTRY_MMK 5
898 1.2 dyoung #define COUNTRY_MMK2 6
899 1.14 dyoung #define ATW_SR_CR29_MASK __BITS(7, 0)
900 1.1 dyoung #define ATW_SR_PCI_DEVICE (0x20/2) /* CR0 */
901 1.1 dyoung #define ATW_SR_PCI_VENDOR (0x22/2) /* CR0 */
902 1.1 dyoung #define ATW_SR_SUB_DEVICE (0x24/2) /* CR11 */
903 1.1 dyoung #define ATW_SR_SUB_VENDOR (0x26/2) /* CR11 */
904 1.1 dyoung #define ATW_SR_CR15 (0x28/2)
905 1.1 dyoung #define ATW_SR_LOCISPTR (0x2A/2) /* CR10 */
906 1.1 dyoung #define ATW_SR_HICISPTR (0x2C/2) /* CR10 */
907 1.1 dyoung #define ATW_SR_CSR18 (0x2E/2)
908 1.1 dyoung #define ATW_SR_D0_D1_PWR (0x40/2) /* CR49 */
909 1.1 dyoung #define ATW_SR_D2_D3_PWR (0x42/2) /* CR49 */
910 1.1 dyoung #define ATW_SR_CIS_WORDS (0x52/2)
911 1.1 dyoung /* CR17 of RFMD RF3000 BBP: returns TWO channels */
912 1.1 dyoung #define ATW_SR_TXPOWER(chnl) (0x54/2 + ((chnl) - 1)/2)
913 1.1 dyoung /* CR20 of RFMD RF3000 BBP: returns TWO channels */
914 1.1 dyoung #define ATW_SR_LPF_CUTOFF(chnl) (0x62/2 + ((chnl) - 1)/2)
915 1.1 dyoung /* CR21 of RFMD RF3000 BBP: returns TWO channels */
916 1.1 dyoung #define ATW_SR_LNA_GS_THRESH(chnl) (0x70/2 + ((chnl) - 1)/2)
917 1.1 dyoung #define ATW_SR_CHECKSUM (0x7e/2) /* for data 0x00-0x7d */
918 1.1 dyoung #define ATW_SR_CIS (0x80/2) /* Cardbus CIS */
919 1.1 dyoung
920 1.11 perry /* Tx descriptor */
921 1.1 dyoung struct atw_txdesc {
922 1.1 dyoung u_int32_t at_ctl;
923 1.1 dyoung #define at_stat at_ctl
924 1.1 dyoung u_int32_t at_flags;
925 1.1 dyoung u_int32_t at_buf1;
926 1.1 dyoung u_int32_t at_buf2;
927 1.1 dyoung };
928 1.1 dyoung
929 1.14 dyoung #define ATW_TXCTL_OWN __BIT(31) /* 1: ready to transmit */
930 1.14 dyoung #define ATW_TXCTL_DONE __BIT(30) /* 0: not processed */
931 1.14 dyoung #define ATW_TXCTL_TXDR_MASK __BITS(27,20) /* TX data rate (?) */
932 1.14 dyoung #define ATW_TXCTL_TL_MASK __BITS(19,0) /* retry limit, 0 - 255 */
933 1.1 dyoung
934 1.1 dyoung #define ATW_TXSTAT_OWN ATW_TXCTL_OWN /* 0: not for transmission */
935 1.1 dyoung #define ATW_TXSTAT_DONE ATW_TXCTL_DONE /* 1: been processed */
936 1.14 dyoung #define ATW_TXSTAT_ES __BIT(29) /* 0: TX successful */
937 1.14 dyoung #define ATW_TXSTAT_TLT __BIT(28) /* TX lifetime expired */
938 1.14 dyoung #define ATW_TXSTAT_TRT __BIT(27) /* TX retry limit expired */
939 1.14 dyoung #define ATW_TXSTAT_TUF __BIT(26) /* TX under-run error */
940 1.14 dyoung #define ATW_TXSTAT_TRO __BIT(25) /* TX over-run error */
941 1.14 dyoung #define ATW_TXSTAT_SOFBR __BIT(24) /* packet size != buffer size
942 1.1 dyoung * (?)
943 1.1 dyoung */
944 1.14 dyoung #define ATW_TXSTAT_ARC_MASK __BITS(11,0) /* accumulated retry count */
945 1.1 dyoung
946 1.14 dyoung #define ATW_TXFLAG_IC __BIT(31) /* interrupt on completion */
947 1.14 dyoung #define ATW_TXFLAG_LS __BIT(30) /* packet's last descriptor */
948 1.14 dyoung #define ATW_TXFLAG_FS __BIT(29) /* packet's first descriptor */
949 1.14 dyoung #define ATW_TXFLAG_TER __BIT(25) /* end of ring */
950 1.14 dyoung #define ATW_TXFLAG_TCH __BIT(24) /* at_buf2 is 2nd chain */
951 1.14 dyoung #define ATW_TXFLAG_TBS2_MASK __BITS(23,12) /* at_buf2 byte count */
952 1.14 dyoung #define ATW_TXFLAG_TBS1_MASK __BITS(11,0) /* at_buf1 byte count */
953 1.1 dyoung
954 1.11 perry /* Rx descriptor */
955 1.1 dyoung struct atw_rxdesc {
956 1.1 dyoung u_int32_t ar_stat;
957 1.1 dyoung u_int32_t ar_ctl;
958 1.1 dyoung u_int32_t ar_buf1;
959 1.1 dyoung u_int32_t ar_buf2;
960 1.1 dyoung };
961 1.1 dyoung
962 1.1 dyoung #define ar_rssi ar_ctl
963 1.1 dyoung
964 1.14 dyoung #define ATW_RXCTL_RER __BIT(25) /* end of ring */
965 1.14 dyoung #define ATW_RXCTL_RCH __BIT(24) /* ar_buf2 is 2nd chain */
966 1.14 dyoung #define ATW_RXCTL_RBS2_MASK __BITS(23,12) /* ar_buf2 byte count */
967 1.14 dyoung #define ATW_RXCTL_RBS1_MASK __BITS(11,0) /* ar_buf1 byte count */
968 1.1 dyoung
969 1.14 dyoung #define ATW_RXSTAT_OWN __BIT(31) /* 1: NIC may fill descriptor */
970 1.14 dyoung #define ATW_RXSTAT_ES __BIT(30) /* error summary, 0 on
971 1.1 dyoung * success
972 1.1 dyoung */
973 1.14 dyoung #define ATW_RXSTAT_SQL __BIT(29) /* has signal quality (?) */
974 1.14 dyoung #define ATW_RXSTAT_DE __BIT(28) /* descriptor error---packet is
975 1.1 dyoung * truncated. last descriptor
976 1.1 dyoung * only
977 1.1 dyoung */
978 1.14 dyoung #define ATW_RXSTAT_FS __BIT(27) /* packet's first descriptor */
979 1.14 dyoung #define ATW_RXSTAT_LS __BIT(26) /* packet's last descriptor */
980 1.14 dyoung #define ATW_RXSTAT_PCF __BIT(25) /* received during CFP */
981 1.14 dyoung #define ATW_RXSTAT_SFDE __BIT(24) /* PLCP SFD error */
982 1.14 dyoung #define ATW_RXSTAT_SIGE __BIT(23) /* PLCP signal error */
983 1.14 dyoung #define ATW_RXSTAT_CRC16E __BIT(22) /* PLCP CRC16 error */
984 1.14 dyoung #define ATW_RXSTAT_RXTOE __BIT(21) /* RX time-out, last descriptor
985 1.1 dyoung * only.
986 1.1 dyoung */
987 1.14 dyoung #define ATW_RXSTAT_CRC32E __BIT(20) /* CRC32 error */
988 1.14 dyoung #define ATW_RXSTAT_ICVE __BIT(19) /* WEP ICV error */
989 1.14 dyoung #define ATW_RXSTAT_DA1 __BIT(17) /* DA bit 1, admin'd address */
990 1.14 dyoung #define ATW_RXSTAT_DA0 __BIT(16) /* DA bit 0, group address */
991 1.14 dyoung #define ATW_RXSTAT_RXDR_MASK __BITS(15,12) /* RX data rate */
992 1.14 dyoung #define ATW_RXSTAT_FL_MASK __BITS(11,0) /* RX frame length, last
993 1.1 dyoung * descriptor only
994 1.1 dyoung */
995 1.1 dyoung
996 1.1 dyoung /* Static RAM (contains WEP keys, beacon content). Addresses and size
997 1.1 dyoung * are in 16-bit words.
998 1.1 dyoung */
999 1.1 dyoung #define ATW_SRAM_ADDR_INDIVL_KEY 0x0
1000 1.1 dyoung #define ATW_SRAM_ADDR_SHARED_KEY (0x160 * 2)
1001 1.1 dyoung #define ATW_SRAM_ADDR_SSID (0x180 * 2)
1002 1.1 dyoung #define ATW_SRAM_ADDR_SUPRATES (0x191 * 2)
1003 1.10 dyoung #define ATW_SRAM_MAXSIZE (0x200 * 2)
1004 1.10 dyoung #define ATW_SRAM_A_SIZE ATW_SRAM_MAXSIZE
1005 1.10 dyoung #define ATW_SRAM_B_SIZE (0x1c0 * 2)
1006 1.1 dyoung
1007