atwreg.h revision 1.1 1 1.1 dyoung /* $NetBSD: atwreg.h,v 1.1 2003/07/06 22:58:09 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.1 dyoung /* Macros for bit twiddling. */
51 1.1 dyoung
52 1.1 dyoung /* nth bit, BIT(0) == 0x1. */
53 1.1 dyoung #define BIT(n) (((n) == 32) ? 0 : ((u_int32_t) 1 << (n)))
54 1.1 dyoung
55 1.1 dyoung /* bits m through n, m < n. */
56 1.1 dyoung #define BITS(m, n) ((BIT(MAX((m), (n)) + 1) - 1) ^ (BIT(MIN((m), (n))) - 1))
57 1.1 dyoung
58 1.1 dyoung /* find least significant bit that is set */
59 1.1 dyoung #define LOWEST_SET_BIT(x) ((((x) - 1) & (x)) ^ (x))
60 1.1 dyoung
61 1.1 dyoung /* for x a power of two and p a non-negative integer, is x a greater power than 2**p? */
62 1.1 dyoung #define GTEQ_POWER(x, p) (((u_long)(x) >> (p)) != 0)
63 1.1 dyoung
64 1.1 dyoung #define MASK_TO_SHIFT(m) ((GTEQ_POWER(LOWEST_SET_BIT((m)), 31) ? 31 : \
65 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 30) ? 30 : \
66 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 29) ? 29 : \
67 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 28) ? 28 : \
68 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 27) ? 27 : \
69 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 26) ? 26 : \
70 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 25) ? 25 : \
71 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 24) ? 24 : \
72 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 23) ? 23 : \
73 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 22) ? 22 : \
74 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 21) ? 21 : \
75 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 20) ? 20 : \
76 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 19) ? 19 : \
77 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 18) ? 18 : \
78 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 17) ? 17 : \
79 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 16) ? 16 : \
80 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 15) ? 15 : \
81 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 14) ? 14 : \
82 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 13) ? 13 : \
83 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 12) ? 12 : \
84 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 11) ? 11 : \
85 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 10) ? 10 : \
86 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 9) ? 9 : \
87 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 8) ? 8 : \
88 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 7) ? 7 : \
89 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 6) ? 6 : \
90 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 5) ? 5 : \
91 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 4) ? 4 : \
92 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 3) ? 3 : \
93 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 2) ? 2 : \
94 1.1 dyoung (GTEQ_POWER(LOWEST_SET_BIT((m)), 1) ? 1 : 0))))))))))))))))))))))))))))))))
95 1.1 dyoung
96 1.1 dyoung #define MASK_AND_RSHIFT(x, mask) (((x) & (mask)) >> MASK_TO_SHIFT(mask))
97 1.1 dyoung #define LSHIFT(x, mask) ((x) << MASK_TO_SHIFT(mask))
98 1.1 dyoung #define MASK_AND_REPLACE(reg, val, mask) ((reg & ~mask) | LSHIFT(val, mask))
99 1.1 dyoung
100 1.1 dyoung /* ADM8211 Host Control and Status Registers */
101 1.1 dyoung
102 1.1 dyoung #define ATW_PAR 0x00 /* PCI access */
103 1.1 dyoung #define ATW_FRCTL 0x04 /* Frame control */
104 1.1 dyoung #define ATW_TDR 0x08 /* Transmit demand */
105 1.1 dyoung #define ATW_WTDP 0x0C /* Current transmit descriptor pointer */
106 1.1 dyoung #define ATW_RDR 0x10 /* Receive demand */
107 1.1 dyoung #define ATW_WRDP 0x14 /* Current receive descriptor pointer */
108 1.1 dyoung #define ATW_RDB 0x18 /* Receive descriptor base address */
109 1.1 dyoung #define ATW_CSR3A 0x1C /* Unused */
110 1.1 dyoung #define ATW_TDBD 0x20 /* Transmit descriptor base address, DCF */
111 1.1 dyoung #define ATW_TDBP 0x24 /* Transmit descriptor base address, PCF */
112 1.1 dyoung #define ATW_STSR 0x28 /* Status */
113 1.1 dyoung #define ATW_CSR5A 0x2C /* Unused */
114 1.1 dyoung #define ATW_NAR 0x30 /* Network access */
115 1.1 dyoung #define ATW_CSR6A 0x34 /* Unused */
116 1.1 dyoung #define ATW_IER 0x38 /* Interrupt enable */
117 1.1 dyoung #define ATW_CSR7A 0x3C
118 1.1 dyoung #define ATW_LPC 0x40 /* Lost packet counter */
119 1.1 dyoung #define ATW_TEST1 0x44 /* Test register 1 */
120 1.1 dyoung #define ATW_SPR 0x48 /* Serial port */
121 1.1 dyoung #define ATW_TEST0 0x4C /* Test register 0 */
122 1.1 dyoung #define ATW_WCSR 0x50 /* Wake-up control/status */
123 1.1 dyoung #define ATW_WPDR 0x54 /* Wake-up pattern data */
124 1.1 dyoung #define ATW_GPTMR 0x58 /* General purpose timer */
125 1.1 dyoung #define ATW_GPIO 0x5C /* GPIO[5:0] configuration and control */
126 1.1 dyoung #define ATW_BBPCTL 0x60 /* BBP control port */
127 1.1 dyoung #define ATW_SYNCTL 0x64 /* synthesizer control port */
128 1.1 dyoung #define ATW_PLCPHD 0x68 /* PLCP header setting */
129 1.1 dyoung #define ATW_MMIWADDR 0x6C /* MMI write address */
130 1.1 dyoung #define ATW_MMIRADDR1 0x70 /* MMI read address 1 */
131 1.1 dyoung #define ATW_MMIRADDR2 0x74 /* MMI read address 2 */
132 1.1 dyoung #define ATW_TXBR 0x78 /* Transmit burst counter */
133 1.1 dyoung #define ATW_CSR15A 0x7C /* Unused */
134 1.1 dyoung #define ATW_ALCSTAT 0x80 /* ALC statistics */
135 1.1 dyoung #define ATW_TOFS2 0x84 /* Timing offset parameter 2, 16b */
136 1.1 dyoung #define ATW_CMDR 0x88 /* Command */
137 1.1 dyoung #define ATW_PCIC 0x8C /* PCI bus performance counter */
138 1.1 dyoung #define ATW_PMCSR 0x90 /* Power management command and status */
139 1.1 dyoung #define ATW_PAR0 0x94 /* Local MAC address register 0, 32b */
140 1.1 dyoung #define ATW_PAR1 0x98 /* Local MAC address register 1, 16b */
141 1.1 dyoung #define ATW_MAR0 0x9C /* Multicast address hash table register 0 */
142 1.1 dyoung #define ATW_MAR1 0xA0 /* Multicast address hash table register 1 */
143 1.1 dyoung #define ATW_ATIMDA0 0xA4 /* Ad Hoc Traffic Indication Map (ATIM)
144 1.1 dyoung * frame DA, byte[3:0]
145 1.1 dyoung */
146 1.1 dyoung #define ATW_ABDA1 0xA8 /* BSSID address byte[5:4];
147 1.1 dyoung * ATIM frame DA byte[5:4]
148 1.1 dyoung */
149 1.1 dyoung #define ATW_BSSID0 0xAC /* BSSID address byte[3:0] */
150 1.1 dyoung #define ATW_TXLMT 0xB0 /* WLAN retry limit, 8b;
151 1.1 dyoung * Max TX MSDU lifetime, 16b
152 1.1 dyoung */
153 1.1 dyoung #define ATW_MIBCNT 0xB4 /* RTS/ACK/FCS MIB count, 32b */
154 1.1 dyoung #define ATW_BCNT 0xB8 /* Beacon transmission time, 32b */
155 1.1 dyoung #define ATW_TSFTH 0xBC /* TSFT[63:32], 32b */
156 1.1 dyoung #define ATW_TSC 0xC0 /* TSFT[39:32] down count value */
157 1.1 dyoung #define ATW_SYNRF 0xC4 /* SYN RF IF direct control */
158 1.1 dyoung #define ATW_BPLI 0xC8 /* Beacon interval, 16b.
159 1.1 dyoung * STA listen interval, 16b.
160 1.1 dyoung */
161 1.1 dyoung #define ATW_CAP0 0xCC /* Current channel, 4b. RCVDTIM, 1b. */
162 1.1 dyoung #define ATW_CAP1 0xD0 /* Capability information, 16b.
163 1.1 dyoung * ATIM window, 1b.
164 1.1 dyoung */
165 1.1 dyoung #define ATW_RMD 0xD4 /* RX max reception duration, 16b */
166 1.1 dyoung #define ATW_CFPP 0xD8 /* CFP parameter, 32b */
167 1.1 dyoung #define ATW_TOFS0 0xDC /* Timing offset parameter 0, 28b */
168 1.1 dyoung #define ATW_TOFS1 0xE0 /* Timing offset parameter 1, 24b */
169 1.1 dyoung #define ATW_IFST 0xE4 /* IFS timing parameter 1, 32b */
170 1.1 dyoung #define ATW_RSPT 0xE8 /* Response time, 24b */
171 1.1 dyoung #define ATW_TSFTL 0xEC /* TSFT[31:0], 32b */
172 1.1 dyoung #define ATW_WEPCTL 0xF0 /* WEP control */
173 1.1 dyoung #define ATW_WESK 0xF4 /* Write entry for shared/individual key */
174 1.1 dyoung #define ATW_WEPCNT 0xF8 /* WEP count */
175 1.1 dyoung #define ATW_MACTEST 0xFC
176 1.1 dyoung
177 1.1 dyoung #define ATW_FER 0x100 /* Function event */
178 1.1 dyoung #define ATW_FEMR 0x104 /* Function event mask */
179 1.1 dyoung #define ATW_FPSR 0x108 /* Function present state */
180 1.1 dyoung #define ATW_FFER 0x10C /* Function force event */
181 1.1 dyoung
182 1.1 dyoung
183 1.1 dyoung #define ATW_PAR_MWIE BIT(24) /* memory write and invalidate
184 1.1 dyoung * enable
185 1.1 dyoung */
186 1.1 dyoung #define ATW_PAR_MRLE BIT(23) /* memory read line enable */
187 1.1 dyoung #define ATW_PAR_MRME BIT(21) /* memory read multiple
188 1.1 dyoung * enable
189 1.1 dyoung */
190 1.1 dyoung #define ATW_PAR_RAP_MASK BITS(17, 18) /* receive auto-polling in
191 1.1 dyoung * receive suspended state
192 1.1 dyoung */
193 1.1 dyoung #define ATW_PAR_CAL_MASK BITS(14, 15) /* cache alignment */
194 1.1 dyoung #define ATW_PAR_CAL_PBL 0x0
195 1.1 dyoung /* min(8 DW, PBL) */
196 1.1 dyoung #define ATW_PAR_CAL_8DW LSHIFT(0x1, ATW_PAR_CAL_MASK)
197 1.1 dyoung /* min(16 DW, PBL) */
198 1.1 dyoung #define ATW_PAR_CAL_16DW LSHIFT(0x2, ATW_PAR_CAL_MASK)
199 1.1 dyoung /* min(32 DW, PBL) */
200 1.1 dyoung #define ATW_PAR_CAL_32DW LSHIFT(0x3, ATW_PAR_CAL_MASK)
201 1.1 dyoung #define ATW_PAR_PBL_MASK BITS(8, 13) /* programmable burst length */
202 1.1 dyoung #define ATW_PAR_PBL_UNLIMITED 0x0
203 1.1 dyoung #define ATW_PAR_PBL_1DW LSHIFT(0x1, ATW_PAR_PBL_MASK)
204 1.1 dyoung #define ATW_PAR_PBL_2DW LSHIFT(0x2, ATW_PAR_PBL_MASK)
205 1.1 dyoung #define ATW_PAR_PBL_4DW LSHIFT(0x4, ATW_PAR_PBL_MASK)
206 1.1 dyoung #define ATW_PAR_PBL_8DW LSHIFT(0x8, ATW_PAR_PBL_MASK)
207 1.1 dyoung #define ATW_PAR_PBL_16DW LSHIFT(0x16, ATW_PAR_PBL_MASK)
208 1.1 dyoung #define ATW_PAR_PBL_32DW LSHIFT(0x32, ATW_PAR_PBL_MASK)
209 1.1 dyoung #define ATW_PAR_BLE BIT(7) /* big/little endian selection */
210 1.1 dyoung #define ATW_PAR_DSL_MASK BITS(2, 6) /* descriptor skip length */
211 1.1 dyoung #define ATW_PAR_BAR BIT(1) /* bus arbitration */
212 1.1 dyoung #define ATW_PAR_SWR BIT(0) /* software reset */
213 1.1 dyoung
214 1.1 dyoung #define ATW_FRCTL_PWRMGMT BIT(31) /* power management */
215 1.1 dyoung #define ATW_FRCTL_VER_MASK BITS(29, 30) /* protocol version */
216 1.1 dyoung #define ATW_FRCTL_ORDER BIT(28) /* order bit */
217 1.1 dyoung #define ATW_FRCTL_MAXPSP BIT(27) /* maximum power saving */
218 1.1 dyoung #define ATW_FRCTL_DOZEFRM BIT(18) /* select pre-sleep frame */
219 1.1 dyoung #define ATW_FRCTL_PSAWAKE BIT(17) /* MAC is awake (?) */
220 1.1 dyoung #define ATW_FRCTL_PSMODE BIT(16) /* MAC is power-saving (?) */
221 1.1 dyoung #define ATW_FRCTL_AID_MASK BITS(0, 15) /* STA Association ID */
222 1.1 dyoung
223 1.1 dyoung #define ATW_INTR_PCF BIT(31) /* started/ended CFP */
224 1.1 dyoung #define ATW_INTR_BCNTC BIT(30) /* transmitted IBSS beacon */
225 1.1 dyoung #define ATW_INTR_GPINT BIT(29) /* GPIO interrupt */
226 1.1 dyoung #define ATW_INTR_LINKOFF BIT(28) /* lost ATW_WCSR_BLN beacons */
227 1.1 dyoung #define ATW_INTR_ATIMTC BIT(27) /* transmitted ATIM */
228 1.1 dyoung #define ATW_INTR_TSFTF BIT(26) /* TSFT out of range */
229 1.1 dyoung #define ATW_INTR_TSCZ BIT(25) /* TSC countdown expired */
230 1.1 dyoung #define ATW_INTR_LINKON BIT(24) /* matched SSID, BSSID */
231 1.1 dyoung #define ATW_INTR_SQL BIT(23) /* Marvel signal quality */
232 1.1 dyoung #define ATW_INTR_WEPTD BIT(22) /* switched WEP table */
233 1.1 dyoung #define ATW_INTR_ATIME BIT(21) /* ended ATIM window */
234 1.1 dyoung #define ATW_INTR_TBTT BIT(20) /* (TBTT) Target Beacon TX Time
235 1.1 dyoung * passed
236 1.1 dyoung */
237 1.1 dyoung #define ATW_INTR_NISS BIT(16) /* normal interrupt status
238 1.1 dyoung * summary: any of 31, 30, 27,
239 1.1 dyoung * 24, 14, 12, 6, 2, 0.
240 1.1 dyoung */
241 1.1 dyoung #define ATW_INTR_AISS BIT(15) /* abnormal interrupt status
242 1.1 dyoung * summary: any of 29, 28, 26,
243 1.1 dyoung * 25, 23, 22, 13, 11, 8, 7, 5,
244 1.1 dyoung * 4, 3, 1.
245 1.1 dyoung */
246 1.1 dyoung #define ATW_INTR_TEIS BIT(14) /* transmit early interrupt
247 1.1 dyoung * status: moved TX packet to
248 1.1 dyoung * FIFO
249 1.1 dyoung */
250 1.1 dyoung #define ATW_INTR_FBE BIT(13) /* fatal bus error */
251 1.1 dyoung #define ATW_INTR_REIS BIT(12) /* receive early interrupt
252 1.1 dyoung * status: RX packet filled
253 1.1 dyoung * its first descriptor
254 1.1 dyoung */
255 1.1 dyoung #define ATW_INTR_GPTT BIT(11) /* general purpose timer expired */
256 1.1 dyoung #define ATW_INTR_RPS BIT(8) /* stopped receive process */
257 1.1 dyoung #define ATW_INTR_RDU BIT(7) /* receive descriptor
258 1.1 dyoung * unavailable
259 1.1 dyoung */
260 1.1 dyoung #define ATW_INTR_RCI BIT(6) /* completed packet reception */
261 1.1 dyoung #define ATW_INTR_TUF BIT(5) /* transmit underflow */
262 1.1 dyoung #define ATW_INTR_TRT BIT(4) /* transmit retry count
263 1.1 dyoung * expired
264 1.1 dyoung */
265 1.1 dyoung #define ATW_INTR_TLT BIT(3) /* transmit lifetime exceeded */
266 1.1 dyoung #define ATW_INTR_TDU BIT(2) /* transmit descriptor
267 1.1 dyoung * unavailable
268 1.1 dyoung */
269 1.1 dyoung #define ATW_INTR_TPS BIT(1) /* stopped transmit process */
270 1.1 dyoung #define ATW_INTR_TCI BIT(0) /* completed transmit */
271 1.1 dyoung #define ATW_NAR_TXCF BIT(31) /* stop process on TX failure */
272 1.1 dyoung #define ATW_NAR_HF BIT(30) /* flush TX FIFO to host (?) */
273 1.1 dyoung #define ATW_NAR_UTR BIT(29) /* select retry count source */
274 1.1 dyoung #define ATW_NAR_PCF BIT(28) /* use one/both transmit
275 1.1 dyoung * descriptor base addresses
276 1.1 dyoung */
277 1.1 dyoung #define ATW_NAR_CFP BIT(27) /* indicate more TX data to
278 1.1 dyoung * point coordinator
279 1.1 dyoung */
280 1.1 dyoung #define ATW_NAR_SF BIT(21) /* store and forward: ignore
281 1.1 dyoung * TX threshold
282 1.1 dyoung */
283 1.1 dyoung #define ATW_NAR_TR_MASK BITS(14, 15) /* TX threshold */
284 1.1 dyoung #define ATW_NAR_TR_L64 LSHIFT(0x0, ATW_NAR_TR_MASK)
285 1.1 dyoung #define ATW_NAR_TR_L160 LSHIFT(0x2, ATW_NAR_TR_MASK)
286 1.1 dyoung #define ATW_NAR_TR_L192 LSHIFT(0x3, ATW_NAR_TR_MASK)
287 1.1 dyoung #define ATW_NAR_TR_H96 LSHIFT(0x0, ATW_NAR_TR_MASK)
288 1.1 dyoung #define ATW_NAR_TR_H288 LSHIFT(0x2, ATW_NAR_TR_MASK)
289 1.1 dyoung #define ATW_NAR_TR_H544 LSHIFT(0x3, ATW_NAR_TR_MASK)
290 1.1 dyoung #define ATW_NAR_ST BIT(13) /* start/stop transmit */
291 1.1 dyoung #define ATW_NAR_OM_MASK BITS(10, 11) /* operating mode */
292 1.1 dyoung #define ATW_NAR_OM_NORMAL 0x0
293 1.1 dyoung #define ATW_NAR_OM_LOOPBACK LSHIFT(0x1, ATW_NAR_OM_MASK)
294 1.1 dyoung #define ATW_NAR_MM BIT(7) /* RX any multicast */
295 1.1 dyoung #define ATW_NAR_PR BIT(6) /* promiscuous mode */
296 1.1 dyoung #define ATW_NAR_EA BIT(5) /* match ad hoc packets (?) */
297 1.1 dyoung #define ATW_NAR_PB BIT(3) /* pass bad packets */
298 1.1 dyoung #define ATW_NAR_STPDMA BIT(2) /* stop DMA, abort packet */
299 1.1 dyoung #define ATW_NAR_SR BIT(1) /* start/stop receive */
300 1.1 dyoung #define ATW_NAR_CTX BIT(0) /* continuous TX mode */
301 1.1 dyoung
302 1.1 dyoung /* IER bits are identical to STSR bits. Use ATW_INTR_*. */
303 1.1 dyoung #if 0
304 1.1 dyoung #define ATW_IER_NIE BIT(16) /* normal interrupt enable */
305 1.1 dyoung #define ATW_IER_AIE BIT(15) /* abnormal interrupt enable */
306 1.1 dyoung /* normal interrupts: combine with ATW_IER_NIE */
307 1.1 dyoung #define ATW_IER_PCFIE BIT(31) /* STA entered CFP */
308 1.1 dyoung #define ATW_IER_BCNTCIE BIT(30) /* STA TX'd beacon */
309 1.1 dyoung #define ATW_IER_ATIMTCIE BIT(27) /* transmitted ATIM */
310 1.1 dyoung #define ATW_IER_LINKONIE BIT(24) /* matched beacon */
311 1.1 dyoung #define ATW_IER_ATIMIE BIT(21) /* ended ATIM window */
312 1.1 dyoung #define ATW_IER_TBTTIE BIT(20) /* TBTT */
313 1.1 dyoung #define ATW_IER_TEIE BIT(14) /* moved TX packet to FIFO */
314 1.1 dyoung #define ATW_IER_REIE BIT(12) /* RX packet filled its first
315 1.1 dyoung * descriptor
316 1.1 dyoung */
317 1.1 dyoung #define ATW_IER_RCIE BIT(6) /* completed RX */
318 1.1 dyoung #define ATW_IER_TDUIE BIT(2) /* transmit descriptor
319 1.1 dyoung * unavailable
320 1.1 dyoung */
321 1.1 dyoung #define ATW_IER_TCIE BIT(0) /* completed TX */
322 1.1 dyoung /* abnormal interrupts: combine with ATW_IER_AIE */
323 1.1 dyoung #define ATW_IER_GPIE BIT(29) /* GPIO interrupt */
324 1.1 dyoung #define ATW_IER_LINKOFFIE BIT(28) /* lost beacon */
325 1.1 dyoung #define ATW_IER_TSFTFIE BIT(26) /* TSFT out of range */
326 1.1 dyoung #define ATW_IER_TSCIE BIT(25) /* TSC countdown expired */
327 1.1 dyoung #define ATW_IER_SQLIE BIT(23) /* signal quality */
328 1.1 dyoung #define ATW_IER_WEPIE BIT(22) /* finished WEP table switch */
329 1.1 dyoung #define ATW_IER_FBEIE BIT(13) /* fatal bus error */
330 1.1 dyoung #define ATW_IER_GPTIE BIT(11) /* general purpose timer expired */
331 1.1 dyoung #define ATW_IER_RPSIE BIT(8) /* stopped receive process */
332 1.1 dyoung #define ATW_IER_RUIE BIT(7) /* receive descriptor unavailable */
333 1.1 dyoung #define ATW_IER_TUIE BIT(5) /* transmit underflow */
334 1.1 dyoung #define ATW_IER_TRTIE BIT(4) /* exceeded transmit retry count */
335 1.1 dyoung #define ATW_IER_TLTTIE BIT(3) /* transmit lifetime exceeded */
336 1.1 dyoung #define ATW_IER_TPSIE BIT(1) /* stopped transmit process */
337 1.1 dyoung #endif
338 1.1 dyoung
339 1.1 dyoung #define ATW_LPC_LPCO BIT(16) /* lost packet counter overflow */
340 1.1 dyoung #define ATW_LPC_LPC_MASK BITS(0, 15) /* lost packet counter */
341 1.1 dyoung
342 1.1 dyoung #define ATW_SPR_SRS BIT(11) /* activate SEEPROM access */
343 1.1 dyoung #define ATW_SPR_SDO BIT(3) /* data out of SEEPROM */
344 1.1 dyoung #define ATW_SPR_SDI BIT(2) /* data into SEEPROM */
345 1.1 dyoung #define ATW_SPR_SCLK BIT(1) /* SEEPROM clock */
346 1.1 dyoung #define ATW_SPR_SCS BIT(0) /* SEEPROM chip select */
347 1.1 dyoung
348 1.1 dyoung /* TBD CSR_TEST0 */
349 1.1 dyoung #define ATW_TEST0_BE_MASK BITS(31, 29) /* Bus error state */
350 1.1 dyoung #define ATW_TEST0_TS_MASK BITS(28, 26) /* Transmit process state */
351 1.1 dyoung
352 1.1 dyoung /* Stopped */
353 1.1 dyoung #define ATW_TEST0_TS_STOPPED LSHIFT(0, ATW_TEST0_TS_MASK)
354 1.1 dyoung /* Running - fetch transmit descriptor */
355 1.1 dyoung #define ATW_TEST0_TS_FETCH LSHIFT(1, ATW_TEST0_TS_MASK)
356 1.1 dyoung /* Running - wait for end of transmission */
357 1.1 dyoung #define ATW_TEST0_TS_WAIT LSHIFT(2, ATW_TEST0_TS_MASK)
358 1.1 dyoung /* Running - read buffer from memory and queue into FIFO */
359 1.1 dyoung #define ATW_TEST0_TS_READING LSHIFT(3, ATW_TEST0_TS_MASK)
360 1.1 dyoung #define ATW_TEST0_TS_RESERVED1 LSHIFT(4, ATW_TEST0_TS_MASK)
361 1.1 dyoung #define ATW_TEST0_TS_RESERVED2 LSHIFT(5, ATW_TEST0_TS_MASK)
362 1.1 dyoung /* Suspended */
363 1.1 dyoung #define ATW_TEST0_TS_SUSPENDED LSHIFT(6, ATW_TEST0_TS_MASK)
364 1.1 dyoung /* Running - close transmit descriptor */
365 1.1 dyoung #define ATW_TEST0_TS_CLOSE LSHIFT(7, ATW_TEST0_TS_MASK)
366 1.1 dyoung
367 1.1 dyoung #define ATW_TEST0_RS_MASK BITS(25, 23) /* Receive process state */
368 1.1 dyoung
369 1.1 dyoung /* Stopped */
370 1.1 dyoung #define ATW_TEST0_RS_STOPPED LSHIFT(0, ATW_TEST0_RS_MASK)
371 1.1 dyoung /* Running - fetch receive descriptor */
372 1.1 dyoung #define ATW_TEST0_RS_FETCH LSHIFT(1, ATW_TEST0_RS_MASK)
373 1.1 dyoung /* Running - check for end of receive */
374 1.1 dyoung #define ATW_TEST0_RS_CHECK LSHIFT(2, ATW_TEST0_RS_MASK)
375 1.1 dyoung /* Running - wait for packet */
376 1.1 dyoung #define ATW_TEST0_RS_WAIT LSHIFT(3, ATW_TEST0_RS_MASK)
377 1.1 dyoung /* Suspended */
378 1.1 dyoung #define ATW_TEST0_RS_SUSPENDED LSHIFT(4, ATW_TEST0_RS_MASK)
379 1.1 dyoung /* Running - close receive descriptor */
380 1.1 dyoung #define ATW_TEST0_RS_CLOSE LSHIFT(5, ATW_TEST0_RS_MASK)
381 1.1 dyoung /* Running - flush current frame from FIFO */
382 1.1 dyoung #define ATW_TEST0_RS_FLUSH LSHIFT(6, ATW_TEST0_RS_MASK)
383 1.1 dyoung /* Running - queue current frame from FIFO into buffer */
384 1.1 dyoung #define ATW_TEST0_RS_QUEUE LSHIFT(7, ATW_TEST0_RS_MASK)
385 1.1 dyoung
386 1.1 dyoung #define ATW_TEST0_EPNE BIT(18) /* SEEPROM not detected */
387 1.1 dyoung #define ATW_TEST0_EPSNM BIT(17) /* SEEPROM bad signature */
388 1.1 dyoung #define ATW_TEST0_EPTYP_MASK BIT(16) /* SEEPROM type
389 1.1 dyoung * 1: 93c66,
390 1.1 dyoung * 0: 93c46
391 1.1 dyoung */
392 1.1 dyoung #define ATW_TEST0_EPTYP_93c66 ATW_TEST0_EPTYP_MASK
393 1.1 dyoung #define ATW_TEST0_EPTYP_93c46 0
394 1.1 dyoung #define ATW_TEST0_EPRLD BIT(15) /* recall SEEPROM (write 1) */
395 1.1 dyoung
396 1.1 dyoung #define ATW_WCSR_CRCT BIT(30) /* CRC-16 type */
397 1.1 dyoung #define ATW_WCSR_WP1E BIT(29) /* match wake-up pattern 1 */
398 1.1 dyoung #define ATW_WCSR_WP2E BIT(28) /* match wake-up pattern 2 */
399 1.1 dyoung #define ATW_WCSR_WP3E BIT(27) /* match wake-up pattern 3 */
400 1.1 dyoung #define ATW_WCSR_WP4E BIT(26) /* match wake-up pattern 4 */
401 1.1 dyoung #define ATW_WCSR_WP5E BIT(25) /* match wake-up pattern 5 */
402 1.1 dyoung #define ATW_WCSR_BLN_MASK BITS(21, 23) /* lose link after BLN lost
403 1.1 dyoung * beacons
404 1.1 dyoung */
405 1.1 dyoung #define ATW_WCSR_TSFTWE BIT(20) /* wake up on TSFT out of
406 1.1 dyoung * range
407 1.1 dyoung */
408 1.1 dyoung #define ATW_WCSR_TIMWE BIT(19) /* wake up on TIM */
409 1.1 dyoung #define ATW_WCSR_ATIMWE BIT(18) /* wake up on ATIM */
410 1.1 dyoung #define ATW_WCSR_KEYWE BIT(17) /* wake up on key update */
411 1.1 dyoung #define ATW_WCSR_WFRE BIT(10) /* wake up on wake-up frame */
412 1.1 dyoung #define ATW_WCSR_MPRE BIT(9) /* wake up on magic packet */
413 1.1 dyoung #define ATW_WCSR_LSOE BIT(8) /* wake up on link loss */
414 1.1 dyoung /* wake-up reasons correspond to enable bits */
415 1.1 dyoung #define ATW_WCSR_KEYUP BIT(6) /* */
416 1.1 dyoung #define ATW_WCSR_TSFTW BIT(5) /* */
417 1.1 dyoung #define ATW_WCSR_TIMW BIT(4) /* */
418 1.1 dyoung #define ATW_WCSR_ATIMW BIT(3) /* */
419 1.1 dyoung #define ATW_WCSR_WFR BIT(2) /* */
420 1.1 dyoung #define ATW_WCSR_MPR BIT(1) /* */
421 1.1 dyoung #define ATW_WCSR_LSO BIT(0) /* */
422 1.1 dyoung
423 1.1 dyoung #define ATW_GPTMR_COM_MASK BIT(16) /* continuous operation mode */
424 1.1 dyoung #define ATW_GPTMR_GTV_MASK BITS(0, 15) /* set countdown in 204us ticks */
425 1.1 dyoung
426 1.1 dyoung #define ATW_GPIO_EC1_MASK BITS(25, 24) /* GPIO1 event configuration */
427 1.1 dyoung #define ATW_GPIO_LAT_MASK BITS(21, 20) /* input latch */
428 1.1 dyoung #define ATW_GPIO_INTEN_MASK BITS(19, 18) /* interrupt enable */
429 1.1 dyoung #define ATW_GPIO_EN_MASK BITS(17, 12) /* output enable */
430 1.1 dyoung #define ATW_GPIO_O_MASK BITS(11, 6) /* output value */
431 1.1 dyoung #define ATW_GPIO_I_MASK BITS(5, 0) /* pin static input */
432 1.1 dyoung
433 1.1 dyoung #define ATW_BBPCTL_TWI BIT(31) /* Intersil 3-wire interface */
434 1.1 dyoung #define ATW_BBPCTL_RF3KADDR_MASK BITS(30, 24) /* Address for RF3000 */
435 1.1 dyoung #define ATW_BBPCTL_RF3KADDR_ADDR LSHIFT(0x20, ATW_BBPCTL_RF3KADDR_MASK)
436 1.1 dyoung #define ATW_BBPCTL_NEGEDGE_DO BIT(23) /* data-out on negative edge */
437 1.1 dyoung #define ATW_BBPCTL_NEGEDGE_DI BIT(22) /* data-in on negative edge */
438 1.1 dyoung #define ATW_BBPCTL_CCA_ACTLO BIT(21) /* CCA low when busy */
439 1.1 dyoung #define ATW_BBPCTL_TYPE_MASK BITS(20, 18) /* BBP type */
440 1.1 dyoung #define ATW_BBPCTL_WR BIT(17) /* start write; reset on
441 1.1 dyoung * completion
442 1.1 dyoung */
443 1.1 dyoung #define ATW_BBPCTL_RD BIT(16) /* start read; reset on
444 1.1 dyoung * completion
445 1.1 dyoung */
446 1.1 dyoung #define ATW_BBPCTL_ADDR_MASK BITS(15, 8) /* BBP address */
447 1.1 dyoung #define ATW_BBPCTL_DATA_MASK BITS(7, 0) /* BBP data */
448 1.1 dyoung
449 1.1 dyoung #define ATW_SYNCTL_WR BIT(31) /* start write; reset on
450 1.1 dyoung * completion
451 1.1 dyoung */
452 1.1 dyoung #define ATW_SYNCTL_RD BIT(30) /* start read; reset on
453 1.1 dyoung * completion
454 1.1 dyoung */
455 1.1 dyoung #define ATW_SYNCTL_CS0 BIT(29) /* chip select */
456 1.1 dyoung #define ATW_SYNCTL_CS1 BIT(28)
457 1.1 dyoung #define ATW_SYNCTL_CAL BIT(27) /* generate RF CAL pulse after
458 1.1 dyoung * Rx
459 1.1 dyoung */
460 1.1 dyoung #define ATW_SYNCTL_SELCAL BIT(26) /* RF CAL source, 0: CAL bit,
461 1.1 dyoung * 1: MAC; needed by Intersil
462 1.1 dyoung * BBP
463 1.1 dyoung */
464 1.1 dyoung #define ATW_SYNCTL_RFTYPE_MASK BITS(24, 22) /* RF type */
465 1.1 dyoung #define ATW_SYNCTL_DATA_MASK BITS(21, 0) /* synthesizer setting */
466 1.1 dyoung
467 1.1 dyoung #define ATW_PLCPHD_SIGNAL_MASK BITS(31, 24) /* signal field in PLCP header,
468 1.1 dyoung * only for beacon, ATIM, and
469 1.1 dyoung * RTS.
470 1.1 dyoung */
471 1.1 dyoung #define ATW_PLCPHD_SERVICE_MASK BITS(23, 16) /* service field in PLCP
472 1.1 dyoung * header
473 1.1 dyoung */
474 1.1 dyoung #define ATW_PLCPHD_PMBL BIT(15) /* 0: long preamble, 1: short */
475 1.1 dyoung
476 1.1 dyoung #define ATW_MMIWADDR_INTERSIL 0x100E0C0A
477 1.1 dyoung #define ATW_MMIWADDR_RFMD 0x00009101
478 1.1 dyoung
479 1.1 dyoung #define ATW_MMIRADDR1_INTERSIL 0x00007c7e
480 1.1 dyoung #define ATW_MMIRADDR1_RFMD 0x00000301
481 1.1 dyoung
482 1.1 dyoung #define ATW_MMIRADDR2_INTERSIL 0x00100000
483 1.1 dyoung #define ATW_MMIRADDR2_RFMD 0x7e100000
484 1.1 dyoung
485 1.1 dyoung #define ATW_TXBR_ALCUPDATE_MASK BIT(31) /* auto-update BBP with ALCSET */
486 1.1 dyoung #define ATW_TXBR_TBCNT_MASK BITS(16, 20) /* transmit burst count */
487 1.1 dyoung #define ATW_TXBR_ALCSET_MASK BITS(8, 15) /* TX power level set point */
488 1.1 dyoung #define ATW_TXBR_ALCREF_MASK BITS(0, 7) /* TX power level reference point */
489 1.1 dyoung
490 1.1 dyoung #define ATW_ALCSTAT_MCOV_MASK BIT(27) /* MPDU count overflow */
491 1.1 dyoung #define ATW_ALCSTAT_ESOV_MASK BIT(26) /* error sum overflow */
492 1.1 dyoung #define ATW_ALCSTAT_MCNT_MASK BITS(16, 25) /* MPDU count, unsigned integer */
493 1.1 dyoung #define ATW_ALCSTAT_ERSUM_MASK BITS(0, 15) /* power error sum,
494 1.1 dyoung * 2's complement signed integer
495 1.1 dyoung */
496 1.1 dyoung
497 1.1 dyoung #define ATW_TOFS2_PWR1UP_MASK BITS(31, 28) /* delay of Tx/Rx from PE1,
498 1.1 dyoung * Radio, PHYRST change after
499 1.1 dyoung * power-up, in 2ms units
500 1.1 dyoung */
501 1.1 dyoung #define ATW_TOFS2_PWR0PAPE_MASK BITS(27, 24) /* delay of PAPE going low
502 1.1 dyoung * after internal data
503 1.1 dyoung * transmit end, in us
504 1.1 dyoung */
505 1.1 dyoung #define ATW_TOFS2_PWR1PAPE_MASK BITS(23, 20) /* delay of PAPE going high
506 1.1 dyoung * after TXPE asserted, in us
507 1.1 dyoung */
508 1.1 dyoung #define ATW_TOFS2_PWR0TRSW_MASK BITS(19, 16) /* delay of TRSW going low
509 1.1 dyoung * after internal data transmit
510 1.1 dyoung * end, in us
511 1.1 dyoung */
512 1.1 dyoung #define ATW_TOFS2_PWR1TRSW_MASK BITS(15, 12) /* delay of TRSW going high
513 1.1 dyoung * after TXPE asserted, in us
514 1.1 dyoung */
515 1.1 dyoung #define ATW_TOFS2_PWR0PE2_MASK BITS(11, 8) /* delay of PE2 going low
516 1.1 dyoung * after internal data transmit
517 1.1 dyoung * end, in us
518 1.1 dyoung */
519 1.1 dyoung #define ATW_TOFS2_PWR1PE2_MASK BITS(7, 4) /* delay of PE2 going high
520 1.1 dyoung * after TXPE asserted, in us
521 1.1 dyoung */
522 1.1 dyoung #define ATW_TOFS2_PWR0TXPE_MASK BITS(3, 0) /* delay of TXPE going low
523 1.1 dyoung * after internal data transmit
524 1.1 dyoung * end, in us
525 1.1 dyoung */
526 1.1 dyoung
527 1.1 dyoung #define ATW_CMDR_PM BIT(19) /* enables power mgmt
528 1.1 dyoung * capabilities.
529 1.1 dyoung */
530 1.1 dyoung #define ATW_CMDR_APM BIT(18) /* APM mode, effective when
531 1.1 dyoung * PM = 1.
532 1.1 dyoung */
533 1.1 dyoung #define ATW_CMDR_RTE BIT(4) /* enable Rx FIFO threshold */
534 1.1 dyoung #define ATW_CMDR_DRT_MASK BITS(3, 2) /* drain Rx FIFO threshold */
535 1.1 dyoung #define ATW_CMDR_SINT_MASK BIT(1) /* software interrupt---huh? */
536 1.1 dyoung
537 1.1 dyoung /* TBD PCIC */
538 1.1 dyoung
539 1.1 dyoung /* TBD PMCSR */
540 1.1 dyoung
541 1.1 dyoung
542 1.1 dyoung #define ATW_PAR0_PAB0_MASK BITS(0, 7) /* MAC address byte 0 */
543 1.1 dyoung #define ATW_PAR0_PAB1_MASK BITS(8, 15) /* MAC address byte 1 */
544 1.1 dyoung #define ATW_PAR0_PAB2_MASK BITS(16, 23) /* MAC address byte 2 */
545 1.1 dyoung #define ATW_PAR0_PAB3_MASK BITS(24, 31) /* MAC address byte 3 */
546 1.1 dyoung
547 1.1 dyoung #define ATW_PAR1_PAB5_MASK BITS(8, 15) /* MAC address byte 5 */
548 1.1 dyoung #define ATW_PAR1_PAB4_MASK BITS(0, 7) /* MAC address byte 4 */
549 1.1 dyoung
550 1.1 dyoung #define ATW_MAR0_MAB3_MASK BITS(31, 24) /* multicast table bits 31:24 */
551 1.1 dyoung #define ATW_MAR0_MAB2_MASK BITS(23, 16) /* multicast table bits 23:16 */
552 1.1 dyoung #define ATW_MAR0_MAB1_MASK BITS(15, 8) /* multicast table bits 15:8 */
553 1.1 dyoung #define ATW_MAR0_MAB0_MASK BITS(7, 0) /* multicast table bits 7:0 */
554 1.1 dyoung
555 1.1 dyoung #define ATW_MAR1_MAB7_MASK BITS(31, 24) /* multicast table bits 63:56 */
556 1.1 dyoung #define ATW_MAR1_MAB6_MASK BITS(23, 16) /* multicast table bits 55:48 */
557 1.1 dyoung #define ATW_MAR1_MAB5_MASK BITS(15, 8) /* multicast table bits 47:40 */
558 1.1 dyoung #define ATW_MAR1_MAB4_MASK BITS(7, 0) /* multicast table bits 39:32 */
559 1.1 dyoung
560 1.1 dyoung /* ATIM destination address */
561 1.1 dyoung #define ATW_ATIMDA0_ATIMB3_MASK BITS(31,24)
562 1.1 dyoung #define ATW_ATIMDA0_ATIMB2_MASK BITS(23,16)
563 1.1 dyoung #define ATW_ATIMDA0_ATIMB1_MASK BITS(15,8)
564 1.1 dyoung #define ATW_ATIMDA0_ATIMB0_MASK BITS(7,0)
565 1.1 dyoung
566 1.1 dyoung /* ATIM destination address, BSSID */
567 1.1 dyoung #define ATW_ABDA1_BSSIDB5_MASK BITS(31,24)
568 1.1 dyoung #define ATW_ABDA1_BSSIDB4_MASK BITS(23,16)
569 1.1 dyoung #define ATW_ABDA1_ATIMB5_MASK BITS(15,8)
570 1.1 dyoung #define ATW_ABDA1_ATIMB4_MASK BITS(7,0)
571 1.1 dyoung
572 1.1 dyoung /* BSSID */
573 1.1 dyoung #define ATW_BSSID0_BSSIDB3_MASK BITS(31,24)
574 1.1 dyoung #define ATW_BSSID0_BSSIDB2_MASK BITS(23,16)
575 1.1 dyoung #define ATW_BSSID0_BSSIDB1_MASK BITS(15,8)
576 1.1 dyoung #define ATW_BSSID0_BSSIDB0_MASK BITS(7,0)
577 1.1 dyoung
578 1.1 dyoung #define ATW_TXLMT_MTMLT_MASK BITS(31,16) /* max TX MSDU lifetime in TU */
579 1.1 dyoung #define ATW_TXLMT_SRTYLIM_MASK BITS(7,0) /* short retry limit */
580 1.1 dyoung
581 1.1 dyoung #define ATW_MIBCNT_FFCNT_MASK BITS(31,24) /* FCS failure count */
582 1.1 dyoung #define ATW_MIBCNT_AFCNT_MASK BITS(23,16) /* ACK failure count */
583 1.1 dyoung #define ATW_MIBCNT_RSCNT_MASK BITS(15,8) /* RTS success count */
584 1.1 dyoung #define ATW_MIBCNT_RFCNT_MASK BITS(7,0) /* RTS failure count */
585 1.1 dyoung
586 1.1 dyoung #define ATW_BCNT_PLCPH_MASK BITS(23,16) /* 11M PLCP length (us) */
587 1.1 dyoung #define ATW_BCNT_PLCPL_MASK BITS(15,8) /* 5.5M PLCP length (us) */
588 1.1 dyoung #define ATW_BCNT_BCNT_MASK BITS(7,0) /* byte count of beacon frame */
589 1.1 dyoung
590 1.1 dyoung #define ATW_TSC_TSC_MASK BITS(3,0) /* TSFT countdown value */
591 1.1 dyoung
592 1.1 dyoung #define ATW_SYNRF_SELSYN BIT(31) /* 0: MAC controls SYN IF pins,
593 1.1 dyoung * 1: ATW_SYNRF controls SYN IF pins.
594 1.1 dyoung */
595 1.1 dyoung #define ATW_SYNRF_SELRF BIT(30) /* 0: MAC controls RF IF pins,
596 1.1 dyoung * 1: ATW_SYNRF controls RF IF pins.
597 1.1 dyoung */
598 1.1 dyoung #define ATW_SYNRF_LERF BIT(29) /* if SELSYN = 1, direct control of
599 1.1 dyoung * LERF# pin
600 1.1 dyoung */
601 1.1 dyoung #define ATW_SYNRF_LEIF BIT(28) /* if SELSYN = 1, direct control of
602 1.1 dyoung * LEIF# pin
603 1.1 dyoung */
604 1.1 dyoung #define ATW_SYNRF_SYNCLK BIT(27) /* if SELSYN = 1, direct control of
605 1.1 dyoung * SYNCLK pin
606 1.1 dyoung */
607 1.1 dyoung #define ATW_SYNRF_SYNDATA BIT(26) /* if SELSYN = 1, direct control of
608 1.1 dyoung * SYNDATA pin
609 1.1 dyoung */
610 1.1 dyoung #define ATW_SYNRF_PE1 BIT(25) /* if SELRF = 1, direct control of
611 1.1 dyoung * PE1 pin
612 1.1 dyoung */
613 1.1 dyoung #define ATW_SYNRF_PE2 BIT(24) /* if SELRF = 1, direct control of
614 1.1 dyoung * PE2 pin
615 1.1 dyoung */
616 1.1 dyoung #define ATW_SYNRF_PAPE BIT(23) /* if SELRF = 1, direct control of
617 1.1 dyoung * PAPE pin
618 1.1 dyoung */
619 1.1 dyoung #define ATW_SYNRF_INTERSIL_EN BIT(20) /* if SELRF = 1, enables
620 1.1 dyoung * some signal used by the
621 1.1 dyoung * Intersil RF front-end?
622 1.1 dyoung * Undocumented.
623 1.1 dyoung */
624 1.1 dyoung #define ATW_SYNRF_PHYRST BIT(18) /* if SELRF = 1, direct control of
625 1.1 dyoung * PHYRST# pin
626 1.1 dyoung */
627 1.1 dyoung
628 1.1 dyoung #define ATW_BPLI_BP_MASK BITS(31,16) /* beacon interval in TU */
629 1.1 dyoung #define ATW_BPLI_LI_MASK BITS(15,0) /* STA listen interval in
630 1.1 dyoung * beacon intervals
631 1.1 dyoung */
632 1.1 dyoung
633 1.1 dyoung #define ATW_CAP0_RCVDTIM BIT(4) /* receive every DTIM */
634 1.1 dyoung #define ATW_CAP0_CHN_MASK BITS(3,0) /* current DSSS channel */
635 1.1 dyoung
636 1.1 dyoung #define ATW_CAP1_CAPI_MASK BITS(31,16) /* capability information */
637 1.1 dyoung #define ATW_CAP1_ATIMW_MASK BITS(15,0) /* ATIM window in TU */
638 1.1 dyoung
639 1.1 dyoung #define ATW_RMD_ATIMST BIT(31) /* ATIM frame TX status */
640 1.1 dyoung #define ATW_RMD_CFP BIT(30) /* CFP indicator */
641 1.1 dyoung #define ATW_RMD_PCNT BITS(27,16) /* idle time between
642 1.1 dyoung * awake/ps mode
643 1.1 dyoung */
644 1.1 dyoung #define ATW_RMD_RMRD BITS(15,0) /* max RX reception duration
645 1.1 dyoung * in us
646 1.1 dyoung */
647 1.1 dyoung
648 1.1 dyoung #define ATW_CFPP_CFPP BITS(31,24) /* CFP unit DTIM */
649 1.1 dyoung #define ATW_CFPP_CFPMD BITS(23,8) /* CFP max duration in TU */
650 1.1 dyoung #define ATW_CFPP_DTIMP BITS(7,0) /* DTIM period in beacon
651 1.1 dyoung * intervals
652 1.1 dyoung */
653 1.1 dyoung #define ATW_TOFS0_USCNT_MASK BITS(29,24) /* number of system clocks
654 1.1 dyoung * in 1 microsecond.
655 1.1 dyoung * Depends PCI bus speed?
656 1.1 dyoung */
657 1.1 dyoung #define ATW_TOFS0_TUCNT_MASK BITS(9,0) /* TU counter in microseconds */
658 1.1 dyoung
659 1.1 dyoung /* TBD TOFS1 */
660 1.1 dyoung #define ATW_TOFS1_TSFTOFSR_MASK BITS(31,24) /* RX TSFT offset in
661 1.1 dyoung * microseconds: RF+BBP
662 1.1 dyoung * latency
663 1.1 dyoung */
664 1.1 dyoung #define ATW_TOFS1_TBTTPRE_MASK BITS(23,8) /* prediction time, (next
665 1.1 dyoung * Nth TBTT - TBTTOFS) in
666 1.1 dyoung * microseconds (huh?). To
667 1.1 dyoung * match TSFT[25:10] (huh?).
668 1.1 dyoung */
669 1.1 dyoung #define ATW_TOFS1_TBTTOFS_MASK BITS(7,0) /* wake-up time offset before
670 1.1 dyoung * TBTT in TU
671 1.1 dyoung */
672 1.1 dyoung #define ATW_IFST_SLOT_MASK BITS(27,23) /* SLOT time in us */
673 1.1 dyoung #define ATW_IFST_SIFS_MASK BITS(22,15) /* SIFS time in us */
674 1.1 dyoung #define ATW_IFST_DIFS_MASK BITS(14,9) /* DIFS time in us */
675 1.1 dyoung #define ATW_IFST_EIFS_MASK BITS(8,0) /* EIFS time in us */
676 1.1 dyoung
677 1.1 dyoung #define ATW_RSPT_MART_MASK BITS(31,16) /* max response time in us */
678 1.1 dyoung #define ATW_RSPT_MIRT_MASK BITS(15,8) /* min response time in us */
679 1.1 dyoung #define ATW_RSPT_TSFTOFST_MASK BITS(7,0) /* TX TSFT offset in us */
680 1.1 dyoung
681 1.1 dyoung #define ATW_WEPCTL_WEPENABLE BIT(31) /* enable WEP engine */
682 1.1 dyoung #define ATW_WEPCTL_AUTOSWITCH BIT(30) /* auto-switch enable (huh?) */
683 1.1 dyoung #define ATW_WEPCTL_CURTBL BIT(29) /* current table in use */
684 1.1 dyoung #define ATW_WEPCTL_WR BIT(28) /* */
685 1.1 dyoung #define ATW_WEPCTL_RD BIT(27) /* */
686 1.1 dyoung #define ATW_WEPCTL_WEPRXBYP BIT(25) /* bypass WEP on RX */
687 1.1 dyoung #define ATW_WEPCTL_UNKNOWN0 BIT(23) /* has something to do with
688 1.1 dyoung * revision 0x20. Possibly
689 1.1 dyoung * selects a different WEP
690 1.1 dyoung * table.
691 1.1 dyoung */
692 1.1 dyoung #define ATW_WEPCTL_TBLADD_MASK BITS(8,0) /* add to table */
693 1.1 dyoung
694 1.1 dyoung /* set these bits in the second byte of a SRAM shared key record to affect
695 1.1 dyoung * the use and interpretation of the key in the record.
696 1.1 dyoung */
697 1.1 dyoung #define ATW_WEP_ENABLED BIT(7)
698 1.1 dyoung #define ATW_WEP_104BIT BIT(6)
699 1.1 dyoung
700 1.1 dyoung #define ATW_WESK_DATA_MASK BITS(15,0) /* data */
701 1.1 dyoung #define ATW_WEPCNT_WIEC_MASK BITS(15,0) /* WEP ICV error count */
702 1.1 dyoung
703 1.1 dyoung #define ATW_MACTEST_FORCE_IV BIT(23)
704 1.1 dyoung #define ATW_MACTEST_FORCE_KEYID BIT(22)
705 1.1 dyoung #define ATW_MACTEST_KEYID_MASK BITS(21,20)
706 1.1 dyoung #define ATW_MACTEST_MMI_USETXCLK BIT(11)
707 1.1 dyoung
708 1.1 dyoung /* Function Event/Status registers */
709 1.1 dyoung
710 1.1 dyoung #define ATW_FER_INTR BIT(15) /* interrupt: set regardless of mask */
711 1.1 dyoung #define ATW_FER_GWAKE BIT(4) /* general wake-up: set regardless of mask */
712 1.1 dyoung
713 1.1 dyoung #define ATW_FEMR_INTR_EN BIT(15) /* enable INTA# */
714 1.1 dyoung #define ATW_FEMR_WAKEUP_EN BIT(14) /* enable wake-up */
715 1.1 dyoung #define ATW_FEMR_GWAKE_EN BIT(4) /* enable general wake-up */
716 1.1 dyoung
717 1.1 dyoung #define ATW_FPSR_INTR_STATUS BIT(15) /* interrupt status */
718 1.1 dyoung #define ATW_FPSR_WAKEUP_STATUS BIT(4) /* CSTSCHG state */
719 1.1 dyoung #define ATW_FFER_INTA_FORCE BIT(15) /* activate INTA (if not masked) */
720 1.1 dyoung #define ATW_FFER_GWAKE_FORCE BIT(4) /* activate CSTSCHG (if not masked) */
721 1.1 dyoung
722 1.1 dyoung /* Serial EEPROM offsets */
723 1.1 dyoung #define ATW_SR_CLASS_CODE (0x00/2)
724 1.1 dyoung #define ATW_SR_FORMAT_VERSION (0x02/2)
725 1.1 dyoung #define ATW_SR_MAC00 (0x08/2) /* CSR21 */
726 1.1 dyoung #define ATW_SR_MAC01 (0x0A/2) /* CSR21/22 */
727 1.1 dyoung #define ATW_SR_MAC10 (0x0C/2) /* CSR22 */
728 1.1 dyoung #define ATW_SR_CSR20 (0x16/2)
729 1.1 dyoung #define ATW_SR_ANT_MASK BITS(12, 10)
730 1.1 dyoung #define ATW_SR_PWRSCALE_MASK BITS(9, 8)
731 1.1 dyoung #define ATW_SR_CLKSAVE_MASK BITS(7, 6)
732 1.1 dyoung #define ATW_SR_RFTYPE_MASK BITS(5, 3)
733 1.1 dyoung #define ATW_SR_BBPTYPE_MASK BITS(2, 0)
734 1.1 dyoung #define ATW_SR_CR28_CR03 (0x18/2)
735 1.1 dyoung #define ATW_SR_CTRY_CR29 (0x1A/2)
736 1.1 dyoung #define ATW_SR_CTRY_MASK BITS(15,8) /* country code */
737 1.1 dyoung #define COUNTRY_FCC LSHIFT(0, ATW_SR_CTRY_MASK)
738 1.1 dyoung #define COUNTRY_IC LSHIFT(1, ATW_SR_CTRY_MASK)
739 1.1 dyoung #define COUNTRY_ETSI LSHIFT(2, ATW_SR_CTRY_MASK)
740 1.1 dyoung #define COUNTRY_SPAIN LSHIFT(3, ATW_SR_CTRY_MASK)
741 1.1 dyoung #define COUNTRY_FRANCE LSHIFT(4, ATW_SR_CTRY_MASK)
742 1.1 dyoung #define COUNTRY_MMK LSHIFT(5, ATW_SR_CTRY_MASK)
743 1.1 dyoung #define COUNTRY_MMK2 LSHIFT(6, ATW_SR_CTRY_MASK)
744 1.1 dyoung #define ATW_SR_PCI_DEVICE (0x20/2) /* CR0 */
745 1.1 dyoung #define ATW_SR_PCI_VENDOR (0x22/2) /* CR0 */
746 1.1 dyoung #define ATW_SR_SUB_DEVICE (0x24/2) /* CR11 */
747 1.1 dyoung #define ATW_SR_SUB_VENDOR (0x26/2) /* CR11 */
748 1.1 dyoung #define ATW_SR_CR15 (0x28/2)
749 1.1 dyoung #define ATW_SR_LOCISPTR (0x2A/2) /* CR10 */
750 1.1 dyoung #define ATW_SR_HICISPTR (0x2C/2) /* CR10 */
751 1.1 dyoung #define ATW_SR_CSR18 (0x2E/2)
752 1.1 dyoung #define ATW_SR_D0_D1_PWR (0x40/2) /* CR49 */
753 1.1 dyoung #define ATW_SR_D2_D3_PWR (0x42/2) /* CR49 */
754 1.1 dyoung #define ATW_SR_CIS_WORDS (0x52/2)
755 1.1 dyoung /* CR17 of RFMD RF3000 BBP: returns TWO channels */
756 1.1 dyoung #define ATW_SR_TXPOWER(chnl) (0x54/2 + ((chnl) - 1)/2)
757 1.1 dyoung /* CR20 of RFMD RF3000 BBP: returns TWO channels */
758 1.1 dyoung #define ATW_SR_LPF_CUTOFF(chnl) (0x62/2 + ((chnl) - 1)/2)
759 1.1 dyoung /* CR21 of RFMD RF3000 BBP: returns TWO channels */
760 1.1 dyoung #define ATW_SR_LNA_GS_THRESH(chnl) (0x70/2 + ((chnl) - 1)/2)
761 1.1 dyoung #define ATW_SR_CHECKSUM (0x7e/2) /* for data 0x00-0x7d */
762 1.1 dyoung #define ATW_SR_CIS (0x80/2) /* Cardbus CIS */
763 1.1 dyoung
764 1.1 dyoung /* Tx descriptor */
765 1.1 dyoung struct atw_txdesc {
766 1.1 dyoung u_int32_t at_ctl;
767 1.1 dyoung #define at_stat at_ctl
768 1.1 dyoung u_int32_t at_flags;
769 1.1 dyoung u_int32_t at_buf1;
770 1.1 dyoung u_int32_t at_buf2;
771 1.1 dyoung };
772 1.1 dyoung
773 1.1 dyoung #define ATW_TXCTL_OWN BIT(31) /* 1: ready to transmit */
774 1.1 dyoung #define ATW_TXCTL_DONE BIT(30) /* 0: not processed */
775 1.1 dyoung #define ATW_TXCTL_TXDR_MASK BITS(27,20) /* TX data rate (?) */
776 1.1 dyoung #define ATW_TXCTL_TL_MASK BITS(19,0) /* retry limit, 0 - 255 */
777 1.1 dyoung
778 1.1 dyoung #define ATW_TXSTAT_OWN ATW_TXCTL_OWN /* 0: not for transmission */
779 1.1 dyoung #define ATW_TXSTAT_DONE ATW_TXCTL_DONE /* 1: been processed */
780 1.1 dyoung #define ATW_TXSTAT_ES BIT(29) /* 0: TX successful */
781 1.1 dyoung #define ATW_TXSTAT_TLT BIT(28) /* TX lifetime expired */
782 1.1 dyoung #define ATW_TXSTAT_TRT BIT(27) /* TX retry limit expired */
783 1.1 dyoung #define ATW_TXSTAT_TUF BIT(26) /* TX under-run error */
784 1.1 dyoung #define ATW_TXSTAT_TRO BIT(25) /* TX over-run error */
785 1.1 dyoung #define ATW_TXSTAT_SOFBR BIT(24) /* packet size != buffer size
786 1.1 dyoung * (?)
787 1.1 dyoung */
788 1.1 dyoung #define ATW_TXSTAT_ARC_MASK BITS(11,0) /* accumulated retry count */
789 1.1 dyoung
790 1.1 dyoung #define ATW_TXFLAG_IC BIT(31) /* interrupt on completion */
791 1.1 dyoung #define ATW_TXFLAG_LS BIT(30) /* packet's last descriptor */
792 1.1 dyoung #define ATW_TXFLAG_FS BIT(29) /* packet's first descriptor */
793 1.1 dyoung #define ATW_TXFLAG_TER BIT(25) /* end of ring */
794 1.1 dyoung #define ATW_TXFLAG_TCH BIT(24) /* at_buf2 is 2nd chain */
795 1.1 dyoung #define ATW_TXFLAG_TBS2_MASK BITS(23,12) /* at_buf2 byte count */
796 1.1 dyoung #define ATW_TXFLAG_TBS1_MASK BITS(11,0) /* at_buf1 byte count */
797 1.1 dyoung
798 1.1 dyoung /* Rx descriptor */
799 1.1 dyoung struct atw_rxdesc {
800 1.1 dyoung u_int32_t ar_stat;
801 1.1 dyoung u_int32_t ar_ctl;
802 1.1 dyoung u_int32_t ar_buf1;
803 1.1 dyoung u_int32_t ar_buf2;
804 1.1 dyoung };
805 1.1 dyoung
806 1.1 dyoung #define ar_rssi ar_ctl
807 1.1 dyoung
808 1.1 dyoung #define ATW_RXCTL_RER BIT(25) /* end of ring */
809 1.1 dyoung #define ATW_RXCTL_RCH BIT(24) /* ar_buf2 is 2nd chain */
810 1.1 dyoung #define ATW_RXCTL_RBS2_MASK BITS(23,12) /* ar_buf2 byte count */
811 1.1 dyoung #define ATW_RXCTL_RBS1_MASK BITS(11,0) /* ar_buf1 byte count */
812 1.1 dyoung
813 1.1 dyoung #define ATW_RXSTAT_OWN BIT(31) /* 1: NIC may fill descriptor */
814 1.1 dyoung #define ATW_RXSTAT_ES BIT(30) /* error summary, 0 on
815 1.1 dyoung * success
816 1.1 dyoung */
817 1.1 dyoung #define ATW_RXSTAT_SQL BIT(29) /* has signal quality (?) */
818 1.1 dyoung #define ATW_RXSTAT_DE BIT(28) /* descriptor error---packet is
819 1.1 dyoung * truncated. last descriptor
820 1.1 dyoung * only
821 1.1 dyoung */
822 1.1 dyoung #define ATW_RXSTAT_FS BIT(27) /* packet's first descriptor */
823 1.1 dyoung #define ATW_RXSTAT_LS BIT(26) /* packet's last descriptor */
824 1.1 dyoung #define ATW_RXSTAT_PCF BIT(25) /* received during CFP */
825 1.1 dyoung #define ATW_RXSTAT_SFDE BIT(24) /* PLCP SFD error */
826 1.1 dyoung #define ATW_RXSTAT_SIGE BIT(23) /* PLCP signal error */
827 1.1 dyoung #define ATW_RXSTAT_CRC16E BIT(22) /* PLCP CRC16 error */
828 1.1 dyoung #define ATW_RXSTAT_RXTOE BIT(21) /* RX time-out, last descriptor
829 1.1 dyoung * only.
830 1.1 dyoung */
831 1.1 dyoung #define ATW_RXSTAT_CRC32E BIT(20) /* CRC32 error */
832 1.1 dyoung #define ATW_RXSTAT_ICVE BIT(19) /* WEP ICV error */
833 1.1 dyoung #define ATW_RXSTAT_DA1 BIT(17) /* DA bit 1, admin'd address */
834 1.1 dyoung #define ATW_RXSTAT_DA0 BIT(16) /* DA bit 0, group address */
835 1.1 dyoung #define ATW_RXSTAT_RXDR_MASK BITS(15,12) /* RX data rate */
836 1.1 dyoung #define ATW_RXSTAT_FL_MASK BITS(11,0) /* RX frame length, last
837 1.1 dyoung * descriptor only
838 1.1 dyoung */
839 1.1 dyoung
840 1.1 dyoung /* Static RAM (contains WEP keys, beacon content). Addresses and size
841 1.1 dyoung * are in 16-bit words.
842 1.1 dyoung */
843 1.1 dyoung #define ATW_SRAM_ADDR_INDIVL_KEY 0x0
844 1.1 dyoung #define ATW_SRAM_ADDR_SHARED_KEY (0x160 * 2)
845 1.1 dyoung #define ATW_SRAM_ADDR_SSID (0x180 * 2)
846 1.1 dyoung #define ATW_SRAM_ADDR_SUPRATES (0x191 * 2)
847 1.1 dyoung #define ATW_SRAM_SIZE (0x200 * 2)
848 1.1 dyoung
849 1.1 dyoung /*
850 1.1 dyoung * Registers for Silicon Laboratories Si4126/Si4126 RF synthesizer.
851 1.1 dyoung */
852 1.1 dyoung #define SI4126_MAIN 0 /* main configuration */
853 1.1 dyoung #define SI4126_MAIN_AUXSEL_MASK BITS(13, 12)
854 1.1 dyoung #define SI4126_MAIN_IFDIV_MASK BITS(11, 10)
855 1.1 dyoung #define SI4126_MAIN_XINDIV2 BIT(6)
856 1.1 dyoung #define SI4126_MAIN_LPWR BIT(5)
857 1.1 dyoung #define SI4126_MAIN_AUTOPDB BIT(3)
858 1.1 dyoung #define SI4126_GAIN 1 /* phase detector gain */
859 1.1 dyoung #define SI4126_GAIN_KPI_MASK BITS(5, 4)
860 1.1 dyoung #define SI4126_GAIN_KP2_MASK BITS(3, 2)
861 1.1 dyoung #define SI4126_GAIN_KP1_MASK BITS(1, 0)
862 1.1 dyoung #define SI4126_POWER 2 /* powerdown */
863 1.1 dyoung #define SI4126_POWER_PDIB BIT(1)
864 1.1 dyoung #define SI4126_POWER_PDRB BIT(0)
865 1.1 dyoung #define SI4126_RF1N 3 /* RF1 N divider */
866 1.1 dyoung #define SI4126_RF2N 4 /* RF2 N divider */
867 1.1 dyoung #define SI4126_IFN 5 /* IF N divider */
868 1.1 dyoung #define SI4126_RF1R 6 /* RF1 R divider */
869 1.1 dyoung #define SI4126_RF2R 7 /* RF2 R divider */
870 1.1 dyoung #define SI4126_IFR 8 /* IF R divider */
871 1.1 dyoung
872 1.1 dyoung /*
873 1.1 dyoung * Registers for RF Microdevices RF3000 spread-spectrum baseband modem.
874 1.1 dyoung */
875 1.1 dyoung #define RF3000_CTL 0x01 /* modem control */
876 1.1 dyoung #define RF3000_RXSTAT RF3000_CTL /* RX status */
877 1.1 dyoung #define RF3000_CTL_MODE_MASK BITS(7, 4)
878 1.1 dyoung #define RF3000_RXSTAT_ACQ BIT(2)
879 1.1 dyoung #define RF3000_RXSTAT_SFD BIT(1)
880 1.1 dyoung #define RF3000_RXSTAT_CRC BIT(0)
881 1.1 dyoung #define RF3000_CCACTL 0x02 /* CCA control */
882 1.1 dyoung /* CCA mode */
883 1.1 dyoung #define RF3000_CCACTL_MODE_MASK BITS(7, 6)
884 1.1 dyoung #define RF3000_CCACTL_MODE_RSSIT 0 /* RSSI threshold */
885 1.1 dyoung #define RF3000_CCACTL_MODE_ACQ 1 /* acquisition */
886 1.1 dyoung #define RF3000_CCACTL_MODE_BOTH 2 /* threshold or acq. */
887 1.1 dyoung /* RSSI threshold for CCA */
888 1.1 dyoung #define RF3000_CCACTL_RSSIT_MASK BITS(5, 0)
889 1.1 dyoung #define RF3000_DIVCTL 0x03 /* diversity control */
890 1.1 dyoung #define RF3000_DIVCTL_ENABLE BIT(7) /* enable diversity */
891 1.1 dyoung #define RF3000_DIVCTL_ANTSEL BIT(6) /* if ENABLE = 0, set
892 1.1 dyoung * ANT SEL
893 1.1 dyoung */
894 1.1 dyoung #define RF3000_RSSI RF3000_DIVCTL /* RSSI value */
895 1.1 dyoung #define RF3000_RSSI_MASK BITS(5, 0)
896 1.1 dyoung #define RF3000_GAINCTL 0x11 /* TX variable gain control */
897 1.1 dyoung #define RF3000_GAINCTL_TXVGC_MASK BITS(7, 2)
898 1.1 dyoung #define RF3000_GAINCTL_SCRAMBLER BIT(1)
899 1.1 dyoung #define RF3000_LOGAINCAL 0x14 /* low gain calibration */
900 1.1 dyoung #define RF3000_LOGAINCAL_CAL_MASK BITS(5, 0)
901 1.1 dyoung #define RF3000_HIGAINCAL 0x15 /* high gain calibration */
902 1.1 dyoung #define RF3000_HIGAINCAL_CAL_MASK BITS(5, 0)
903 1.1 dyoung #define RF3000_HIGAINCAL_DSSSPAD BIT(6) /* 6dB gain pad for DSSS
904 1.1 dyoung * modes (meaning?)
905 1.1 dyoung */
906 1.1 dyoung #define RF3000_MAGIC0 0x1C /* magic register derived from
907 1.1 dyoung * a binary-only driver
908 1.1 dyoung */
909 1.1 dyoung #define RF3000_MAGIC0_VAL 0x00
910 1.1 dyoung #define RF3000_MAGIC1 0x1D /* magic register derived from
911 1.1 dyoung * a binary-only driver
912 1.1 dyoung */
913 1.1 dyoung #define RF3000_MAGIC1_VAL 0x80
914 1.1 dyoung
915