xref: /freebsd/sys/dev/usb/wlan/if_urtw.c (revision a18eacbefdfa1085ca3db829e86ece78cd416493)
1 /*-
2  * Copyright (c) 2008 Weongyo Jeong <weongyo@FreeBSD.org>
3  *
4  * Permission to use, copy, modify, and distribute this software for any
5  * purpose with or without fee is hereby granted, provided that the above
6  * copyright notice and this permission notice appear in all copies.
7  *
8  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15  */
16 
17 #include <sys/cdefs.h>
18 __FBSDID("$FreeBSD$");
19 #include <sys/param.h>
20 #include <sys/sockio.h>
21 #include <sys/sysctl.h>
22 #include <sys/lock.h>
23 #include <sys/mutex.h>
24 #include <sys/mbuf.h>
25 #include <sys/kernel.h>
26 #include <sys/socket.h>
27 #include <sys/systm.h>
28 #include <sys/malloc.h>
29 #include <sys/module.h>
30 #include <sys/bus.h>
31 #include <sys/endian.h>
32 #include <sys/kdb.h>
33 
34 #include <machine/bus.h>
35 #include <machine/resource.h>
36 #include <sys/rman.h>
37 
38 #include <net/if.h>
39 #include <net/if_var.h>
40 #include <net/if_arp.h>
41 #include <net/ethernet.h>
42 #include <net/if_dl.h>
43 #include <net/if_media.h>
44 #include <net/if_types.h>
45 
46 #ifdef INET
47 #include <netinet/in.h>
48 #include <netinet/in_systm.h>
49 #include <netinet/in_var.h>
50 #include <netinet/if_ether.h>
51 #include <netinet/ip.h>
52 #endif
53 
54 #include <net80211/ieee80211_var.h>
55 #include <net80211/ieee80211_regdomain.h>
56 #include <net80211/ieee80211_radiotap.h>
57 
58 #include <dev/usb/usb.h>
59 #include <dev/usb/usbdi.h>
60 #include "usbdevs.h"
61 
62 #include <dev/usb/wlan/if_urtwreg.h>
63 #include <dev/usb/wlan/if_urtwvar.h>
64 
65 static SYSCTL_NODE(_hw_usb, OID_AUTO, urtw, CTLFLAG_RW, 0, "USB Realtek 8187L");
66 #ifdef URTW_DEBUG
67 int urtw_debug = 0;
68 SYSCTL_INT(_hw_usb_urtw, OID_AUTO, debug, CTLFLAG_RW | CTLFLAG_TUN, &urtw_debug, 0,
69     "control debugging printfs");
70 TUNABLE_INT("hw.usb.urtw.debug", &urtw_debug);
71 enum {
72 	URTW_DEBUG_XMIT		= 0x00000001,	/* basic xmit operation */
73 	URTW_DEBUG_RECV		= 0x00000002,	/* basic recv operation */
74 	URTW_DEBUG_RESET	= 0x00000004,	/* reset processing */
75 	URTW_DEBUG_TX_PROC	= 0x00000008,	/* tx ISR proc */
76 	URTW_DEBUG_RX_PROC	= 0x00000010,	/* rx ISR proc */
77 	URTW_DEBUG_STATE	= 0x00000020,	/* 802.11 state transitions */
78 	URTW_DEBUG_STAT		= 0x00000040,	/* statistic */
79 	URTW_DEBUG_INIT		= 0x00000080,	/* initialization of dev */
80 	URTW_DEBUG_TXSTATUS	= 0x00000100,	/* tx status */
81 	URTW_DEBUG_ANY		= 0xffffffff
82 };
83 #define	DPRINTF(sc, m, fmt, ...) do {				\
84 	if (sc->sc_debug & (m))					\
85 		printf(fmt, __VA_ARGS__);			\
86 } while (0)
87 #else
88 #define	DPRINTF(sc, m, fmt, ...) do {				\
89 	(void) sc;						\
90 } while (0)
91 #endif
92 static int urtw_preamble_mode = URTW_PREAMBLE_MODE_LONG;
93 SYSCTL_INT(_hw_usb_urtw, OID_AUTO, preamble_mode, CTLFLAG_RW | CTLFLAG_TUN,
94     &urtw_preamble_mode, 0, "set the preable mode (long or short)");
95 TUNABLE_INT("hw.usb.urtw.preamble_mode", &urtw_preamble_mode);
96 
97 /* recognized device vendors/products */
98 #define urtw_lookup(v, p)						\
99 	((const struct urtw_type *)usb_lookup(urtw_devs, v, p))
100 #define	URTW_DEV_B(v,p)							\
101 	{ USB_VPI(USB_VENDOR_##v, USB_PRODUCT_##v##_##p, URTW_REV_RTL8187B) }
102 #define	URTW_DEV_L(v,p)							\
103 	{ USB_VPI(USB_VENDOR_##v, USB_PRODUCT_##v##_##p, URTW_REV_RTL8187L) }
104 #define	URTW_REV_RTL8187B	0
105 #define	URTW_REV_RTL8187L	1
106 static const STRUCT_USB_HOST_ID urtw_devs[] = {
107 	URTW_DEV_B(NETGEAR, WG111V3),
108 	URTW_DEV_B(REALTEK, RTL8187B_0),
109 	URTW_DEV_B(REALTEK, RTL8187B_1),
110 	URTW_DEV_B(REALTEK, RTL8187B_2),
111 	URTW_DEV_B(SITECOMEU, WL168V4),
112 	URTW_DEV_L(ASUS, P5B_WIFI),
113 	URTW_DEV_L(BELKIN, F5D7050E),
114 	URTW_DEV_L(LINKSYS4, WUSB54GCV2),
115 	URTW_DEV_L(NETGEAR, WG111V2),
116 	URTW_DEV_L(REALTEK, RTL8187),
117 	URTW_DEV_L(SITECOMEU, WL168V1),
118 	URTW_DEV_L(SURECOM, EP9001G2A),
119 	{ USB_VPI(USB_VENDOR_OVISLINK, 0x8187, URTW_REV_RTL8187L) },
120 	{ USB_VPI(USB_VENDOR_DICKSMITH, 0x9401, URTW_REV_RTL8187L) },
121 	{ USB_VPI(USB_VENDOR_HP, 0xca02, URTW_REV_RTL8187L) },
122 	{ USB_VPI(USB_VENDOR_LOGITEC, 0x010c, URTW_REV_RTL8187L) },
123 	{ USB_VPI(USB_VENDOR_NETGEAR, 0x6100, URTW_REV_RTL8187L) },
124 	{ USB_VPI(USB_VENDOR_SPHAIRON, 0x0150, URTW_REV_RTL8187L) },
125 	{ USB_VPI(USB_VENDOR_QCOM, 0x6232, URTW_REV_RTL8187L) },
126 #undef URTW_DEV_L
127 #undef URTW_DEV_B
128 };
129 
130 #define urtw_read8_m(sc, val, data)	do {			\
131 	error = urtw_read8_c(sc, val, data);			\
132 	if (error != 0)						\
133 		goto fail;					\
134 } while (0)
135 #define urtw_write8_m(sc, val, data)	do {			\
136 	error = urtw_write8_c(sc, val, data);			\
137 	if (error != 0)						\
138 		goto fail;					\
139 } while (0)
140 #define urtw_read16_m(sc, val, data)	do {			\
141 	error = urtw_read16_c(sc, val, data);			\
142 	if (error != 0)						\
143 		goto fail;					\
144 } while (0)
145 #define urtw_write16_m(sc, val, data)	do {			\
146 	error = urtw_write16_c(sc, val, data);			\
147 	if (error != 0)						\
148 		goto fail;					\
149 } while (0)
150 #define urtw_read32_m(sc, val, data)	do {			\
151 	error = urtw_read32_c(sc, val, data);			\
152 	if (error != 0)						\
153 		goto fail;					\
154 } while (0)
155 #define urtw_write32_m(sc, val, data)	do {			\
156 	error = urtw_write32_c(sc, val, data);			\
157 	if (error != 0)						\
158 		goto fail;					\
159 } while (0)
160 #define urtw_8187_write_phy_ofdm(sc, val, data)	do {		\
161 	error = urtw_8187_write_phy_ofdm_c(sc, val, data);	\
162 	if (error != 0)						\
163 		goto fail;					\
164 } while (0)
165 #define urtw_8187_write_phy_cck(sc, val, data)	do {		\
166 	error = urtw_8187_write_phy_cck_c(sc, val, data);	\
167 	if (error != 0)						\
168 		goto fail;					\
169 } while (0)
170 #define urtw_8225_write(sc, val, data)	do {			\
171 	error = urtw_8225_write_c(sc, val, data);		\
172 	if (error != 0)						\
173 		goto fail;					\
174 } while (0)
175 
176 struct urtw_pair {
177 	uint32_t	reg;
178 	uint32_t	val;
179 };
180 
181 static uint8_t urtw_8225_agc[] = {
182 	0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9d, 0x9c, 0x9b,
183 	0x9a, 0x99, 0x98, 0x97, 0x96, 0x95, 0x94, 0x93, 0x92, 0x91, 0x90,
184 	0x8f, 0x8e, 0x8d, 0x8c, 0x8b, 0x8a, 0x89, 0x88, 0x87, 0x86, 0x85,
185 	0x84, 0x83, 0x82, 0x81, 0x80, 0x3f, 0x3e, 0x3d, 0x3c, 0x3b, 0x3a,
186 	0x39, 0x38, 0x37, 0x36, 0x35, 0x34, 0x33, 0x32, 0x31, 0x30, 0x2f,
187 	0x2e, 0x2d, 0x2c, 0x2b, 0x2a, 0x29, 0x28, 0x27, 0x26, 0x25, 0x24,
188 	0x23, 0x22, 0x21, 0x20, 0x1f, 0x1e, 0x1d, 0x1c, 0x1b, 0x1a, 0x19,
189 	0x18, 0x17, 0x16, 0x15, 0x14, 0x13, 0x12, 0x11, 0x10, 0x0f, 0x0e,
190 	0x0d, 0x0c, 0x0b, 0x0a, 0x09, 0x08, 0x07, 0x06, 0x05, 0x04, 0x03,
191 	0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01,
192 	0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01,
193 	0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01
194 };
195 
196 static uint8_t urtw_8225z2_agc[] = {
197 	0x5e, 0x5e, 0x5e, 0x5e, 0x5d, 0x5b, 0x59, 0x57, 0x55, 0x53, 0x51,
198 	0x4f, 0x4d, 0x4b, 0x49, 0x47, 0x45, 0x43, 0x41, 0x3f, 0x3d, 0x3b,
199 	0x39, 0x37, 0x35, 0x33, 0x31, 0x2f, 0x2d, 0x2b, 0x29, 0x27, 0x25,
200 	0x23, 0x21, 0x1f, 0x1d, 0x1b, 0x19, 0x17, 0x15, 0x13, 0x11, 0x0f,
201 	0x0d, 0x0b, 0x09, 0x07, 0x05, 0x03, 0x01, 0x01, 0x01, 0x01, 0x01,
202 	0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x19, 0x19,
203 	0x19, 0x19, 0x19, 0x19, 0x19, 0x19, 0x19, 0x20, 0x21, 0x22, 0x23,
204 	0x24, 0x25, 0x26, 0x26, 0x27, 0x27, 0x28, 0x28, 0x29, 0x2a, 0x2a,
205 	0x2a, 0x2b, 0x2b, 0x2b, 0x2c, 0x2c, 0x2c, 0x2d, 0x2d, 0x2d, 0x2d,
206 	0x2e, 0x2e, 0x2e, 0x2e, 0x2f, 0x2f, 0x2f, 0x30, 0x30, 0x31, 0x31,
207 	0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31,
208 	0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31
209 };
210 
211 static uint32_t urtw_8225_channel[] = {
212 	0x0000,		/* dummy channel 0  */
213 	0x085c,		/* 1  */
214 	0x08dc,		/* 2  */
215 	0x095c,		/* 3  */
216 	0x09dc,		/* 4  */
217 	0x0a5c,		/* 5  */
218 	0x0adc,		/* 6  */
219 	0x0b5c,		/* 7  */
220 	0x0bdc,		/* 8  */
221 	0x0c5c,		/* 9  */
222 	0x0cdc,		/* 10  */
223 	0x0d5c,		/* 11  */
224 	0x0ddc,		/* 12  */
225 	0x0e5c,		/* 13  */
226 	0x0f72,		/* 14  */
227 };
228 
229 static uint8_t urtw_8225_gain[] = {
230 	0x23, 0x88, 0x7c, 0xa5,		/* -82dbm  */
231 	0x23, 0x88, 0x7c, 0xb5,		/* -82dbm  */
232 	0x23, 0x88, 0x7c, 0xc5,		/* -82dbm  */
233 	0x33, 0x80, 0x79, 0xc5,		/* -78dbm  */
234 	0x43, 0x78, 0x76, 0xc5,		/* -74dbm  */
235 	0x53, 0x60, 0x73, 0xc5,		/* -70dbm  */
236 	0x63, 0x58, 0x70, 0xc5,		/* -66dbm  */
237 };
238 
239 static struct urtw_pair urtw_8225_rf_part1[] = {
240 	{ 0x00, 0x0067 }, { 0x01, 0x0fe0 }, { 0x02, 0x044d }, { 0x03, 0x0441 },
241 	{ 0x04, 0x0486 }, { 0x05, 0x0bc0 }, { 0x06, 0x0ae6 }, { 0x07, 0x082a },
242 	{ 0x08, 0x001f }, { 0x09, 0x0334 }, { 0x0a, 0x0fd4 }, { 0x0b, 0x0391 },
243 	{ 0x0c, 0x0050 }, { 0x0d, 0x06db }, { 0x0e, 0x0029 }, { 0x0f, 0x0914 },
244 };
245 
246 static struct urtw_pair urtw_8225_rf_part2[] = {
247 	{ 0x00, 0x01 }, { 0x01, 0x02 }, { 0x02, 0x42 }, { 0x03, 0x00 },
248 	{ 0x04, 0x00 }, { 0x05, 0x00 }, { 0x06, 0x40 }, { 0x07, 0x00 },
249 	{ 0x08, 0x40 }, { 0x09, 0xfe }, { 0x0a, 0x09 }, { 0x0b, 0x80 },
250 	{ 0x0c, 0x01 }, { 0x0e, 0xd3 }, { 0x0f, 0x38 }, { 0x10, 0x84 },
251 	{ 0x11, 0x06 }, { 0x12, 0x20 }, { 0x13, 0x20 }, { 0x14, 0x00 },
252 	{ 0x15, 0x40 }, { 0x16, 0x00 }, { 0x17, 0x40 }, { 0x18, 0xef },
253 	{ 0x19, 0x19 }, { 0x1a, 0x20 }, { 0x1b, 0x76 }, { 0x1c, 0x04 },
254 	{ 0x1e, 0x95 }, { 0x1f, 0x75 }, { 0x20, 0x1f }, { 0x21, 0x27 },
255 	{ 0x22, 0x16 }, { 0x24, 0x46 }, { 0x25, 0x20 }, { 0x26, 0x90 },
256 	{ 0x27, 0x88 }
257 };
258 
259 static struct urtw_pair urtw_8225_rf_part3[] = {
260 	{ 0x00, 0x98 }, { 0x03, 0x20 }, { 0x04, 0x7e }, { 0x05, 0x12 },
261 	{ 0x06, 0xfc }, { 0x07, 0x78 }, { 0x08, 0x2e }, { 0x10, 0x9b },
262 	{ 0x11, 0x88 }, { 0x12, 0x47 }, { 0x13, 0xd0 }, { 0x19, 0x00 },
263 	{ 0x1a, 0xa0 }, { 0x1b, 0x08 }, { 0x40, 0x86 }, { 0x41, 0x8d },
264 	{ 0x42, 0x15 }, { 0x43, 0x18 }, { 0x44, 0x1f }, { 0x45, 0x1e },
265 	{ 0x46, 0x1a }, { 0x47, 0x15 }, { 0x48, 0x10 }, { 0x49, 0x0a },
266 	{ 0x4a, 0x05 }, { 0x4b, 0x02 }, { 0x4c, 0x05 }
267 };
268 
269 static uint16_t urtw_8225_rxgain[] = {
270 	0x0400, 0x0401, 0x0402, 0x0403, 0x0404, 0x0405, 0x0408, 0x0409,
271 	0x040a, 0x040b, 0x0502, 0x0503, 0x0504, 0x0505, 0x0540, 0x0541,
272 	0x0542, 0x0543, 0x0544, 0x0545, 0x0580, 0x0581, 0x0582, 0x0583,
273 	0x0584, 0x0585, 0x0588, 0x0589, 0x058a, 0x058b, 0x0643, 0x0644,
274 	0x0645, 0x0680, 0x0681, 0x0682, 0x0683, 0x0684, 0x0685, 0x0688,
275 	0x0689, 0x068a, 0x068b, 0x068c, 0x0742, 0x0743, 0x0744, 0x0745,
276 	0x0780, 0x0781, 0x0782, 0x0783, 0x0784, 0x0785, 0x0788, 0x0789,
277 	0x078a, 0x078b, 0x078c, 0x078d, 0x0790, 0x0791, 0x0792, 0x0793,
278 	0x0794, 0x0795, 0x0798, 0x0799, 0x079a, 0x079b, 0x079c, 0x079d,
279 	0x07a0, 0x07a1, 0x07a2, 0x07a3, 0x07a4, 0x07a5, 0x07a8, 0x07a9,
280 	0x07aa, 0x07ab, 0x07ac, 0x07ad, 0x07b0, 0x07b1, 0x07b2, 0x07b3,
281 	0x07b4, 0x07b5, 0x07b8, 0x07b9, 0x07ba, 0x07bb, 0x07bb
282 };
283 
284 static uint8_t urtw_8225_threshold[] = {
285 	0x8d, 0x8d, 0x8d, 0x8d, 0x9d, 0xad, 0xbd,
286 };
287 
288 static uint8_t urtw_8225_tx_gain_cck_ofdm[] = {
289 	0x02, 0x06, 0x0e, 0x1e, 0x3e, 0x7e
290 };
291 
292 static uint8_t urtw_8225_txpwr_cck[] = {
293 	0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02,
294 	0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02,
295 	0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02,
296 	0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02,
297 	0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03,
298 	0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03
299 };
300 
301 static uint8_t urtw_8225_txpwr_cck_ch14[] = {
302 	0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00,
303 	0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00,
304 	0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00,
305 	0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00,
306 	0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00,
307 	0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00
308 };
309 
310 static uint8_t urtw_8225_txpwr_ofdm[]={
311 	0x80, 0x90, 0xa2, 0xb5, 0xcb, 0xe4
312 };
313 
314 static uint8_t urtw_8225v2_gain_bg[]={
315 	0x23, 0x15, 0xa5,		/* -82-1dbm  */
316 	0x23, 0x15, 0xb5,		/* -82-2dbm  */
317 	0x23, 0x15, 0xc5,		/* -82-3dbm  */
318 	0x33, 0x15, 0xc5,		/* -78dbm  */
319 	0x43, 0x15, 0xc5,		/* -74dbm  */
320 	0x53, 0x15, 0xc5,		/* -70dbm  */
321 	0x63, 0x15, 0xc5,		/* -66dbm  */
322 };
323 
324 static struct urtw_pair urtw_8225v2_rf_part1[] = {
325 	{ 0x00, 0x02bf }, { 0x01, 0x0ee0 }, { 0x02, 0x044d }, { 0x03, 0x0441 },
326 	{ 0x04, 0x08c3 }, { 0x05, 0x0c72 }, { 0x06, 0x00e6 }, { 0x07, 0x082a },
327 	{ 0x08, 0x003f }, { 0x09, 0x0335 }, { 0x0a, 0x09d4 }, { 0x0b, 0x07bb },
328 	{ 0x0c, 0x0850 }, { 0x0d, 0x0cdf }, { 0x0e, 0x002b }, { 0x0f, 0x0114 }
329 };
330 
331 static struct urtw_pair urtw_8225v2b_rf_part0[] = {
332 	{ 0x00, 0x00b7 }, { 0x01, 0x0ee0 }, { 0x02, 0x044d }, { 0x03, 0x0441 },
333 	{ 0x04, 0x08c3 }, { 0x05, 0x0c72 }, { 0x06, 0x00e6 }, { 0x07, 0x082a },
334 	{ 0x08, 0x003f }, { 0x09, 0x0335 }, { 0x0a, 0x09d4 }, { 0x0b, 0x07bb },
335 	{ 0x0c, 0x0850 }, { 0x0d, 0x0cdf }, { 0x0e, 0x002b }, { 0x0f, 0x0114 }
336 };
337 
338 static struct urtw_pair urtw_8225v2b_rf_part1[] = {
339 	{0x0f0, 0x32}, {0x0f1, 0x32}, {0x0f2, 0x00},
340 	{0x0f3, 0x00}, {0x0f4, 0x32}, {0x0f5, 0x43},
341 	{0x0f6, 0x00}, {0x0f7, 0x00}, {0x0f8, 0x46},
342 	{0x0f9, 0xa4}, {0x0fa, 0x00}, {0x0fb, 0x00},
343 	{0x0fc, 0x96}, {0x0fd, 0xa4}, {0x0fe, 0x00},
344 	{0x0ff, 0x00}, {0x158, 0x4b}, {0x159, 0x00},
345 	{0x15a, 0x4b}, {0x15b, 0x00}, {0x160, 0x4b},
346 	{0x161, 0x09}, {0x162, 0x4b}, {0x163, 0x09},
347 	{0x1ce, 0x0f}, {0x1cf, 0x00}, {0x1e0, 0xff},
348 	{0x1e1, 0x0f}, {0x1e2, 0x00}, {0x1f0, 0x4e},
349 	{0x1f1, 0x01}, {0x1f2, 0x02}, {0x1f3, 0x03},
350 	{0x1f4, 0x04}, {0x1f5, 0x05}, {0x1f6, 0x06},
351 	{0x1f7, 0x07}, {0x1f8, 0x08}, {0x24e, 0x00},
352 	{0x20c, 0x04}, {0x221, 0x61}, {0x222, 0x68},
353 	{0x223, 0x6f}, {0x224, 0x76}, {0x225, 0x7d},
354 	{0x226, 0x84}, {0x227, 0x8d}, {0x24d, 0x08},
355 	{0x250, 0x05}, {0x251, 0xf5}, {0x252, 0x04},
356 	{0x253, 0xa0}, {0x254, 0x1f}, {0x255, 0x23},
357 	{0x256, 0x45}, {0x257, 0x67}, {0x258, 0x08},
358 	{0x259, 0x08}, {0x25a, 0x08}, {0x25b, 0x08},
359 	{0x260, 0x08}, {0x261, 0x08}, {0x262, 0x08},
360 	{0x263, 0x08}, {0x264, 0xcf}, {0x272, 0x56},
361 	{0x273, 0x9a}, {0x034, 0xf0}, {0x035, 0x0f},
362 	{0x05b, 0x40}, {0x084, 0x88}, {0x085, 0x24},
363 	{0x088, 0x54}, {0x08b, 0xb8}, {0x08c, 0x07},
364 	{0x08d, 0x00}, {0x094, 0x1b}, {0x095, 0x12},
365 	{0x096, 0x00}, {0x097, 0x06}, {0x09d, 0x1a},
366 	{0x09f, 0x10}, {0x0b4, 0x22}, {0x0be, 0x80},
367 	{0x0db, 0x00}, {0x0ee, 0x00}, {0x091, 0x03},
368 	{0x24c, 0x00}, {0x39f, 0x00}, {0x08c, 0x01},
369 	{0x08d, 0x10}, {0x08e, 0x08}, {0x08f, 0x00}
370 };
371 
372 static struct urtw_pair urtw_8225v2_rf_part2[] = {
373 	{ 0x00, 0x01 }, { 0x01, 0x02 }, { 0x02, 0x42 }, { 0x03, 0x00 },
374 	{ 0x04, 0x00 },	{ 0x05, 0x00 }, { 0x06, 0x40 }, { 0x07, 0x00 },
375 	{ 0x08, 0x40 }, { 0x09, 0xfe }, { 0x0a, 0x08 }, { 0x0b, 0x80 },
376 	{ 0x0c, 0x01 }, { 0x0d, 0x43 }, { 0x0e, 0xd3 }, { 0x0f, 0x38 },
377 	{ 0x10, 0x84 }, { 0x11, 0x07 }, { 0x12, 0x20 }, { 0x13, 0x20 },
378 	{ 0x14, 0x00 }, { 0x15, 0x40 }, { 0x16, 0x00 }, { 0x17, 0x40 },
379 	{ 0x18, 0xef }, { 0x19, 0x19 }, { 0x1a, 0x20 }, { 0x1b, 0x15 },
380 	{ 0x1c, 0x04 }, { 0x1d, 0xc5 }, { 0x1e, 0x95 }, { 0x1f, 0x75 },
381 	{ 0x20, 0x1f }, { 0x21, 0x17 }, { 0x22, 0x16 }, { 0x23, 0x80 },
382 	{ 0x24, 0x46 }, { 0x25, 0x00 }, { 0x26, 0x90 }, { 0x27, 0x88 }
383 };
384 
385 static struct urtw_pair urtw_8225v2b_rf_part2[] = {
386 	{ 0x00, 0x10 }, { 0x01, 0x0d }, { 0x02, 0x01 }, { 0x03, 0x00 },
387 	{ 0x04, 0x14 }, { 0x05, 0xfb }, { 0x06, 0xfb }, { 0x07, 0x60 },
388 	{ 0x08, 0x00 }, { 0x09, 0x60 }, { 0x0a, 0x00 }, { 0x0b, 0x00 },
389 	{ 0x0c, 0x00 }, { 0x0d, 0x5c }, { 0x0e, 0x00 }, { 0x0f, 0x00 },
390 	{ 0x10, 0x40 }, { 0x11, 0x00 }, { 0x12, 0x40 }, { 0x13, 0x00 },
391 	{ 0x14, 0x00 }, { 0x15, 0x00 }, { 0x16, 0xa8 }, { 0x17, 0x26 },
392 	{ 0x18, 0x32 }, { 0x19, 0x33 }, { 0x1a, 0x07 }, { 0x1b, 0xa5 },
393 	{ 0x1c, 0x6f }, { 0x1d, 0x55 }, { 0x1e, 0xc8 }, { 0x1f, 0xb3 },
394 	{ 0x20, 0x0a }, { 0x21, 0xe1 }, { 0x22, 0x2C }, { 0x23, 0x8a },
395 	{ 0x24, 0x86 }, { 0x25, 0x83 }, { 0x26, 0x34 }, { 0x27, 0x0f },
396 	{ 0x28, 0x4f }, { 0x29, 0x24 }, { 0x2a, 0x6f }, { 0x2b, 0xc2 },
397 	{ 0x2c, 0x6b }, { 0x2d, 0x40 }, { 0x2e, 0x80 }, { 0x2f, 0x00 },
398 	{ 0x30, 0xc0 }, { 0x31, 0xc1 }, { 0x32, 0x58 }, { 0x33, 0xf1 },
399 	{ 0x34, 0x00 }, { 0x35, 0xe4 }, { 0x36, 0x90 }, { 0x37, 0x3e },
400 	{ 0x38, 0x6d }, { 0x39, 0x3c }, { 0x3a, 0xfb }, { 0x3b, 0x07 }
401 };
402 
403 static struct urtw_pair urtw_8225v2_rf_part3[] = {
404 	{ 0x00, 0x98 }, { 0x03, 0x20 }, { 0x04, 0x7e }, { 0x05, 0x12 },
405 	{ 0x06, 0xfc }, { 0x07, 0x78 }, { 0x08, 0x2e }, { 0x09, 0x11 },
406 	{ 0x0a, 0x17 }, { 0x0b, 0x11 }, { 0x10, 0x9b }, { 0x11, 0x88 },
407 	{ 0x12, 0x47 }, { 0x13, 0xd0 }, { 0x19, 0x00 }, { 0x1a, 0xa0 },
408 	{ 0x1b, 0x08 }, { 0x1d, 0x00 }, { 0x40, 0x86 }, { 0x41, 0x9d },
409 	{ 0x42, 0x15 }, { 0x43, 0x18 }, { 0x44, 0x36 }, { 0x45, 0x35 },
410 	{ 0x46, 0x2e }, { 0x47, 0x25 }, { 0x48, 0x1c }, { 0x49, 0x12 },
411 	{ 0x4a, 0x09 }, { 0x4b, 0x04 }, { 0x4c, 0x05 }
412 };
413 
414 static uint16_t urtw_8225v2_rxgain[] = {
415 	0x0000, 0x0001, 0x0002, 0x0003, 0x0004, 0x0005, 0x0008, 0x0009,
416 	0x000a, 0x000b, 0x0102, 0x0103, 0x0104, 0x0105, 0x0140, 0x0141,
417 	0x0142, 0x0143, 0x0144, 0x0145, 0x0180, 0x0181, 0x0182, 0x0183,
418 	0x0184, 0x0185, 0x0188, 0x0189, 0x018a, 0x018b, 0x0243, 0x0244,
419 	0x0245, 0x0280, 0x0281, 0x0282, 0x0283, 0x0284, 0x0285, 0x0288,
420 	0x0289, 0x028a, 0x028b, 0x028c, 0x0342, 0x0343, 0x0344, 0x0345,
421 	0x0380, 0x0381, 0x0382, 0x0383, 0x0384, 0x0385, 0x0388, 0x0389,
422 	0x038a, 0x038b, 0x038c, 0x038d, 0x0390, 0x0391, 0x0392, 0x0393,
423 	0x0394, 0x0395, 0x0398, 0x0399, 0x039a, 0x039b, 0x039c, 0x039d,
424 	0x03a0, 0x03a1, 0x03a2, 0x03a3, 0x03a4, 0x03a5, 0x03a8, 0x03a9,
425 	0x03aa, 0x03ab, 0x03ac, 0x03ad, 0x03b0, 0x03b1, 0x03b2, 0x03b3,
426 	0x03b4, 0x03b5, 0x03b8, 0x03b9, 0x03ba, 0x03bb, 0x03bb
427 };
428 
429 static uint16_t urtw_8225v2b_rxgain[] = {
430 	0x0400, 0x0401, 0x0402, 0x0403, 0x0404, 0x0405, 0x0408, 0x0409,
431 	0x040a, 0x040b, 0x0502, 0x0503, 0x0504, 0x0505, 0x0540, 0x0541,
432 	0x0542, 0x0543, 0x0544, 0x0545, 0x0580, 0x0581, 0x0582, 0x0583,
433 	0x0584, 0x0585, 0x0588, 0x0589, 0x058a, 0x058b, 0x0643, 0x0644,
434 	0x0645, 0x0680, 0x0681, 0x0682, 0x0683, 0x0684, 0x0685, 0x0688,
435 	0x0689, 0x068a, 0x068b, 0x068c, 0x0742, 0x0743, 0x0744, 0x0745,
436 	0x0780, 0x0781, 0x0782, 0x0783, 0x0784, 0x0785, 0x0788, 0x0789,
437 	0x078a, 0x078b, 0x078c, 0x078d, 0x0790, 0x0791, 0x0792, 0x0793,
438 	0x0794, 0x0795, 0x0798, 0x0799, 0x079a, 0x079b, 0x079c, 0x079d,
439 	0x07a0, 0x07a1, 0x07a2, 0x07a3, 0x07a4, 0x07a5, 0x07a8, 0x07a9,
440 	0x03aa, 0x03ab, 0x03ac, 0x03ad, 0x03b0, 0x03b1, 0x03b2, 0x03b3,
441 	0x03b4, 0x03b5, 0x03b8, 0x03b9, 0x03ba, 0x03bb, 0x03bb
442 };
443 
444 static uint8_t urtw_8225v2_tx_gain_cck_ofdm[] = {
445 	0x00, 0x01, 0x02, 0x03, 0x04, 0x05,
446 	0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b,
447 	0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11,
448 	0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
449 	0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d,
450 	0x1e, 0x1f, 0x20, 0x21, 0x22, 0x23,
451 };
452 
453 static uint8_t urtw_8225v2_txpwr_cck[] = {
454 	0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04
455 };
456 
457 static uint8_t urtw_8225v2_txpwr_cck_ch14[] = {
458 	0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00
459 };
460 
461 static uint8_t urtw_8225v2b_txpwr_cck[] = {
462 	0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04,
463 	0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03,
464 	0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03,
465 	0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03
466 };
467 
468 static uint8_t urtw_8225v2b_txpwr_cck_ch14[] = {
469 	0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00,
470 	0x30, 0x2f, 0x29, 0x15, 0x00, 0x00, 0x00, 0x00,
471 	0x30, 0x2f, 0x29, 0x15, 0x00, 0x00, 0x00, 0x00,
472 	0x30, 0x2f, 0x29, 0x15, 0x00, 0x00, 0x00, 0x00
473 };
474 
475 static struct urtw_pair urtw_ratetable[] = {
476 	{  2,  0 }, {   4,  1 }, { 11, 2 }, { 12, 4 }, { 18, 5 },
477 	{ 22,  3 }, {  24,  6 }, { 36, 7 }, { 48, 8 }, { 72, 9 },
478 	{ 96, 10 }, { 108, 11 }
479 };
480 
481 static const uint8_t urtw_8187b_reg_table[][3] = {
482 	{ 0xf0, 0x32, 0 }, { 0xf1, 0x32, 0 }, { 0xf2, 0x00, 0 },
483 	{ 0xf3, 0x00, 0 }, { 0xf4, 0x32, 0 }, { 0xf5, 0x43, 0 },
484 	{ 0xf6, 0x00, 0 }, { 0xf7, 0x00, 0 }, { 0xf8, 0x46, 0 },
485 	{ 0xf9, 0xa4, 0 }, { 0xfa, 0x00, 0 }, { 0xfb, 0x00, 0 },
486 	{ 0xfc, 0x96, 0 }, { 0xfd, 0xa4, 0 }, { 0xfe, 0x00, 0 },
487 	{ 0xff, 0x00, 0 }, { 0x58, 0x4b, 1 }, { 0x59, 0x00, 1 },
488 	{ 0x5a, 0x4b, 1 }, { 0x5b, 0x00, 1 }, { 0x60, 0x4b, 1 },
489 	{ 0x61, 0x09, 1 }, { 0x62, 0x4b, 1 }, { 0x63, 0x09, 1 },
490 	{ 0xce, 0x0f, 1 }, { 0xcf, 0x00, 1 }, { 0xe0, 0xff, 1 },
491 	{ 0xe1, 0x0f, 1 }, { 0xe2, 0x00, 1 }, { 0xf0, 0x4e, 1 },
492 	{ 0xf1, 0x01, 1 }, { 0xf2, 0x02, 1 }, { 0xf3, 0x03, 1 },
493 	{ 0xf4, 0x04, 1 }, { 0xf5, 0x05, 1 }, { 0xf6, 0x06, 1 },
494 	{ 0xf7, 0x07, 1 }, { 0xf8, 0x08, 1 }, { 0x4e, 0x00, 2 },
495 	{ 0x0c, 0x04, 2 }, { 0x21, 0x61, 2 }, { 0x22, 0x68, 2 },
496 	{ 0x23, 0x6f, 2 }, { 0x24, 0x76, 2 }, { 0x25, 0x7d, 2 },
497 	{ 0x26, 0x84, 2 }, { 0x27, 0x8d, 2 }, { 0x4d, 0x08, 2 },
498 	{ 0x50, 0x05, 2 }, { 0x51, 0xf5, 2 }, { 0x52, 0x04, 2 },
499 	{ 0x53, 0xa0, 2 }, { 0x54, 0x1f, 2 }, { 0x55, 0x23, 2 },
500 	{ 0x56, 0x45, 2 }, { 0x57, 0x67, 2 }, { 0x58, 0x08, 2 },
501 	{ 0x59, 0x08, 2 }, { 0x5a, 0x08, 2 }, { 0x5b, 0x08, 2 },
502 	{ 0x60, 0x08, 2 }, { 0x61, 0x08, 2 }, { 0x62, 0x08, 2 },
503 	{ 0x63, 0x08, 2 }, { 0x64, 0xcf, 2 }, { 0x72, 0x56, 2 },
504 	{ 0x73, 0x9a, 2 }, { 0x34, 0xf0, 0 }, { 0x35, 0x0f, 0 },
505 	{ 0x5b, 0x40, 0 }, { 0x84, 0x88, 0 }, { 0x85, 0x24, 0 },
506 	{ 0x88, 0x54, 0 }, { 0x8b, 0xb8, 0 }, { 0x8c, 0x07, 0 },
507 	{ 0x8d, 0x00, 0 }, { 0x94, 0x1b, 0 }, { 0x95, 0x12, 0 },
508 	{ 0x96, 0x00, 0 }, { 0x97, 0x06, 0 }, { 0x9d, 0x1a, 0 },
509 	{ 0x9f, 0x10, 0 }, { 0xb4, 0x22, 0 }, { 0xbe, 0x80, 0 },
510 	{ 0xdb, 0x00, 0 }, { 0xee, 0x00, 0 }, { 0x91, 0x03, 0 },
511 	{ 0x4c, 0x00, 2 }, { 0x9f, 0x00, 3 }, { 0x8c, 0x01, 0 },
512 	{ 0x8d, 0x10, 0 }, { 0x8e, 0x08, 0 }, { 0x8f, 0x00, 0 }
513 };
514 
515 static usb_callback_t urtw_bulk_rx_callback;
516 static usb_callback_t urtw_bulk_tx_callback;
517 static usb_callback_t urtw_bulk_tx_status_callback;
518 
519 static const struct usb_config urtw_8187b_usbconfig[URTW_8187B_N_XFERS] = {
520 	[URTW_8187B_BULK_RX] = {
521 		.type = UE_BULK,
522 		.endpoint = 0x83,
523 		.direction = UE_DIR_IN,
524 		.bufsize = MCLBYTES,
525 		.flags = {
526 			.ext_buffer = 1,
527 			.pipe_bof = 1,
528 			.short_xfer_ok = 1
529 		},
530 		.callback = urtw_bulk_rx_callback
531 	},
532 	[URTW_8187B_BULK_TX_STATUS] = {
533 		.type = UE_BULK,
534 		.endpoint = 0x89,
535 		.direction = UE_DIR_IN,
536 		.bufsize = sizeof(uint64_t),
537 		.flags = {
538 			.pipe_bof = 1,
539 			.short_xfer_ok = 1
540 		},
541 		.callback = urtw_bulk_tx_status_callback
542 	},
543 	[URTW_8187B_BULK_TX_BE] = {
544 		.type = UE_BULK,
545 		.endpoint = URTW_8187B_TXPIPE_BE,
546 		.direction = UE_DIR_OUT,
547 		.bufsize = URTW_TX_MAXSIZE * URTW_TX_DATA_LIST_COUNT,
548 		.flags = {
549 			.force_short_xfer = 1,
550 			.pipe_bof = 1,
551 		},
552 		.callback = urtw_bulk_tx_callback,
553 		.timeout = URTW_DATA_TIMEOUT
554 	},
555 	[URTW_8187B_BULK_TX_BK] = {
556 		.type = UE_BULK,
557 		.endpoint = URTW_8187B_TXPIPE_BK,
558 		.direction = UE_DIR_OUT,
559 		.bufsize = URTW_TX_MAXSIZE,
560 		.flags = {
561 			.ext_buffer = 1,
562 			.force_short_xfer = 1,
563 			.pipe_bof = 1,
564 		},
565 		.callback = urtw_bulk_tx_callback,
566 		.timeout = URTW_DATA_TIMEOUT
567 	},
568 	[URTW_8187B_BULK_TX_VI] = {
569 		.type = UE_BULK,
570 		.endpoint = URTW_8187B_TXPIPE_VI,
571 		.direction = UE_DIR_OUT,
572 		.bufsize = URTW_TX_MAXSIZE,
573 		.flags = {
574 			.ext_buffer = 1,
575 			.force_short_xfer = 1,
576 			.pipe_bof = 1,
577 		},
578 		.callback = urtw_bulk_tx_callback,
579 		.timeout = URTW_DATA_TIMEOUT
580 	},
581 	[URTW_8187B_BULK_TX_VO] = {
582 		.type = UE_BULK,
583 		.endpoint = URTW_8187B_TXPIPE_VO,
584 		.direction = UE_DIR_OUT,
585 		.bufsize = URTW_TX_MAXSIZE,
586 		.flags = {
587 			.ext_buffer = 1,
588 			.force_short_xfer = 1,
589 			.pipe_bof = 1,
590 		},
591 		.callback = urtw_bulk_tx_callback,
592 		.timeout = URTW_DATA_TIMEOUT
593 	},
594 	[URTW_8187B_BULK_TX_EP12] = {
595 		.type = UE_BULK,
596 		.endpoint = 0xc,
597 		.direction = UE_DIR_OUT,
598 		.bufsize = URTW_TX_MAXSIZE,
599 		.flags = {
600 			.ext_buffer = 1,
601 			.force_short_xfer = 1,
602 			.pipe_bof = 1,
603 		},
604 		.callback = urtw_bulk_tx_callback,
605 		.timeout = URTW_DATA_TIMEOUT
606 	}
607 };
608 
609 static const struct usb_config urtw_8187l_usbconfig[URTW_8187L_N_XFERS] = {
610 	[URTW_8187L_BULK_RX] = {
611 		.type = UE_BULK,
612 		.endpoint = 0x81,
613 		.direction = UE_DIR_IN,
614 		.bufsize = MCLBYTES,
615 		.flags = {
616 			.ext_buffer = 1,
617 			.pipe_bof = 1,
618 			.short_xfer_ok = 1
619 		},
620 		.callback = urtw_bulk_rx_callback
621 	},
622 	[URTW_8187L_BULK_TX_LOW] = {
623 		.type = UE_BULK,
624 		.endpoint = 0x2,
625 		.direction = UE_DIR_OUT,
626 		.bufsize = URTW_TX_MAXSIZE * URTW_TX_DATA_LIST_COUNT,
627 		.flags = {
628 			.force_short_xfer = 1,
629 			.pipe_bof = 1,
630 		},
631 		.callback = urtw_bulk_tx_callback,
632 		.timeout = URTW_DATA_TIMEOUT
633 	},
634 	[URTW_8187L_BULK_TX_NORMAL] = {
635 		.type = UE_BULK,
636 		.endpoint = 0x3,
637 		.direction = UE_DIR_OUT,
638 		.bufsize = URTW_TX_MAXSIZE,
639 		.flags = {
640 			.ext_buffer = 1,
641 			.force_short_xfer = 1,
642 			.pipe_bof = 1,
643 		},
644 		.callback = urtw_bulk_tx_callback,
645 		.timeout = URTW_DATA_TIMEOUT
646 	},
647 };
648 
649 static struct ieee80211vap *urtw_vap_create(struct ieee80211com *,
650 			    const char [IFNAMSIZ], int, enum ieee80211_opmode,
651 			    int, const uint8_t [IEEE80211_ADDR_LEN],
652 			    const uint8_t [IEEE80211_ADDR_LEN]);
653 static void		urtw_vap_delete(struct ieee80211vap *);
654 static void		urtw_init(void *);
655 static void		urtw_stop(struct ifnet *);
656 static void		urtw_stop_locked(struct ifnet *);
657 static int		urtw_ioctl(struct ifnet *, u_long, caddr_t);
658 static void		urtw_start(struct ifnet *);
659 static int		urtw_alloc_rx_data_list(struct urtw_softc *);
660 static int		urtw_alloc_tx_data_list(struct urtw_softc *);
661 static int		urtw_raw_xmit(struct ieee80211_node *, struct mbuf *,
662 			    const struct ieee80211_bpf_params *);
663 static void		urtw_scan_start(struct ieee80211com *);
664 static void		urtw_scan_end(struct ieee80211com *);
665 static void		urtw_set_channel(struct ieee80211com *);
666 static void		urtw_update_mcast(struct ifnet *);
667 static int		urtw_tx_start(struct urtw_softc *,
668 			    struct ieee80211_node *, struct mbuf *,
669 			    struct urtw_data *, int);
670 static int		urtw_newstate(struct ieee80211vap *,
671 			    enum ieee80211_state, int);
672 static void		urtw_led_ch(void *);
673 static void		urtw_ledtask(void *, int);
674 static void		urtw_watchdog(void *);
675 static void		urtw_set_multi(void *);
676 static int		urtw_isbmode(uint16_t);
677 static uint16_t		urtw_rate2rtl(uint32_t);
678 static uint16_t		urtw_rtl2rate(uint32_t);
679 static usb_error_t	urtw_set_rate(struct urtw_softc *);
680 static usb_error_t	urtw_update_msr(struct urtw_softc *);
681 static usb_error_t	urtw_read8_c(struct urtw_softc *, int, uint8_t *);
682 static usb_error_t	urtw_read16_c(struct urtw_softc *, int, uint16_t *);
683 static usb_error_t	urtw_read32_c(struct urtw_softc *, int, uint32_t *);
684 static usb_error_t	urtw_write8_c(struct urtw_softc *, int, uint8_t);
685 static usb_error_t	urtw_write16_c(struct urtw_softc *, int, uint16_t);
686 static usb_error_t	urtw_write32_c(struct urtw_softc *, int, uint32_t);
687 static usb_error_t	urtw_eprom_cs(struct urtw_softc *, int);
688 static usb_error_t	urtw_eprom_ck(struct urtw_softc *);
689 static usb_error_t	urtw_eprom_sendbits(struct urtw_softc *, int16_t *,
690 			    int);
691 static usb_error_t	urtw_eprom_read32(struct urtw_softc *, uint32_t,
692 			    uint32_t *);
693 static usb_error_t	urtw_eprom_readbit(struct urtw_softc *, int16_t *);
694 static usb_error_t	urtw_eprom_writebit(struct urtw_softc *, int16_t);
695 static usb_error_t	urtw_get_macaddr(struct urtw_softc *);
696 static usb_error_t	urtw_get_txpwr(struct urtw_softc *);
697 static usb_error_t	urtw_get_rfchip(struct urtw_softc *);
698 static usb_error_t	urtw_led_init(struct urtw_softc *);
699 static usb_error_t	urtw_8185_rf_pins_enable(struct urtw_softc *);
700 static usb_error_t	urtw_8185_tx_antenna(struct urtw_softc *, uint8_t);
701 static usb_error_t	urtw_8187_write_phy(struct urtw_softc *, uint8_t,
702 			    uint32_t);
703 static usb_error_t	urtw_8187_write_phy_ofdm_c(struct urtw_softc *,
704 			    uint8_t, uint32_t);
705 static usb_error_t	urtw_8187_write_phy_cck_c(struct urtw_softc *, uint8_t,
706 			    uint32_t);
707 static usb_error_t	urtw_8225_setgain(struct urtw_softc *, int16_t);
708 static usb_error_t	urtw_8225_usb_init(struct urtw_softc *);
709 static usb_error_t	urtw_8225_write_c(struct urtw_softc *, uint8_t,
710 			    uint16_t);
711 static usb_error_t	urtw_8225_write_s16(struct urtw_softc *, uint8_t, int,
712 			    uint16_t *);
713 static usb_error_t	urtw_8225_read(struct urtw_softc *, uint8_t,
714 			    uint32_t *);
715 static usb_error_t	urtw_8225_rf_init(struct urtw_softc *);
716 static usb_error_t	urtw_8225_rf_set_chan(struct urtw_softc *, int);
717 static usb_error_t	urtw_8225_rf_set_sens(struct urtw_softc *, int);
718 static usb_error_t	urtw_8225_set_txpwrlvl(struct urtw_softc *, int);
719 static usb_error_t	urtw_8225_rf_stop(struct urtw_softc *);
720 static usb_error_t	urtw_8225v2_rf_init(struct urtw_softc *);
721 static usb_error_t	urtw_8225v2_rf_set_chan(struct urtw_softc *, int);
722 static usb_error_t	urtw_8225v2_set_txpwrlvl(struct urtw_softc *, int);
723 static usb_error_t	urtw_8225v2_setgain(struct urtw_softc *, int16_t);
724 static usb_error_t	urtw_8225_isv2(struct urtw_softc *, int *);
725 static usb_error_t	urtw_8225v2b_rf_init(struct urtw_softc *);
726 static usb_error_t	urtw_8225v2b_rf_set_chan(struct urtw_softc *, int);
727 static usb_error_t	urtw_read8e(struct urtw_softc *, int, uint8_t *);
728 static usb_error_t	urtw_write8e(struct urtw_softc *, int, uint8_t);
729 static usb_error_t	urtw_8180_set_anaparam(struct urtw_softc *, uint32_t);
730 static usb_error_t	urtw_8185_set_anaparam2(struct urtw_softc *, uint32_t);
731 static usb_error_t	urtw_intr_enable(struct urtw_softc *);
732 static usb_error_t	urtw_intr_disable(struct urtw_softc *);
733 static usb_error_t	urtw_reset(struct urtw_softc *);
734 static usb_error_t	urtw_led_on(struct urtw_softc *, int);
735 static usb_error_t	urtw_led_ctl(struct urtw_softc *, int);
736 static usb_error_t	urtw_led_blink(struct urtw_softc *);
737 static usb_error_t	urtw_led_mode0(struct urtw_softc *, int);
738 static usb_error_t	urtw_led_mode1(struct urtw_softc *, int);
739 static usb_error_t	urtw_led_mode2(struct urtw_softc *, int);
740 static usb_error_t	urtw_led_mode3(struct urtw_softc *, int);
741 static usb_error_t	urtw_rx_setconf(struct urtw_softc *);
742 static usb_error_t	urtw_rx_enable(struct urtw_softc *);
743 static usb_error_t	urtw_tx_enable(struct urtw_softc *sc);
744 static void		urtw_free_tx_data_list(struct urtw_softc *);
745 static void		urtw_free_rx_data_list(struct urtw_softc *);
746 static void		urtw_free_data_list(struct urtw_softc *,
747 			    struct urtw_data data[], int, int);
748 static usb_error_t	urtw_adapter_start(struct urtw_softc *);
749 static usb_error_t	urtw_adapter_start_b(struct urtw_softc *);
750 static usb_error_t	urtw_set_mode(struct urtw_softc *, uint32_t);
751 static usb_error_t	urtw_8187b_cmd_reset(struct urtw_softc *);
752 static usb_error_t	urtw_do_request(struct urtw_softc *,
753 			    struct usb_device_request *, void *);
754 static usb_error_t	urtw_8225v2b_set_txpwrlvl(struct urtw_softc *, int);
755 static usb_error_t	urtw_led_off(struct urtw_softc *, int);
756 static void		urtw_abort_xfers(struct urtw_softc *);
757 static struct urtw_data *
758 			urtw_getbuf(struct urtw_softc *sc);
759 static int		urtw_compute_txtime(uint16_t, uint16_t, uint8_t,
760 			    uint8_t);
761 static void		urtw_updateslot(struct ifnet *);
762 static void		urtw_updateslottask(void *, int);
763 static void		urtw_sysctl_node(struct urtw_softc *);
764 
765 static int
766 urtw_match(device_t dev)
767 {
768 	struct usb_attach_arg *uaa = device_get_ivars(dev);
769 
770 	if (uaa->usb_mode != USB_MODE_HOST)
771 		return (ENXIO);
772 	if (uaa->info.bConfigIndex != URTW_CONFIG_INDEX)
773 		return (ENXIO);
774 	if (uaa->info.bIfaceIndex != URTW_IFACE_INDEX)
775 		return (ENXIO);
776 
777 	return (usbd_lookup_id_by_uaa(urtw_devs, sizeof(urtw_devs), uaa));
778 }
779 
780 static int
781 urtw_attach(device_t dev)
782 {
783 	const struct usb_config *setup_start;
784 	int ret = ENXIO;
785 	struct urtw_softc *sc = device_get_softc(dev);
786 	struct usb_attach_arg *uaa = device_get_ivars(dev);
787 	struct ieee80211com *ic;
788 	struct ifnet *ifp;
789 	uint8_t bands, iface_index = URTW_IFACE_INDEX;		/* XXX */
790 	uint16_t n_setup;
791 	uint32_t data;
792 	usb_error_t error;
793 
794 	device_set_usb_desc(dev);
795 
796 	sc->sc_dev = dev;
797 	sc->sc_udev = uaa->device;
798 	if (USB_GET_DRIVER_INFO(uaa) == URTW_REV_RTL8187B)
799 		sc->sc_flags |= URTW_RTL8187B;
800 #ifdef URTW_DEBUG
801 	sc->sc_debug = urtw_debug;
802 #endif
803 
804 	mtx_init(&sc->sc_mtx, device_get_nameunit(sc->sc_dev), MTX_NETWORK_LOCK,
805 	    MTX_DEF);
806 	usb_callout_init_mtx(&sc->sc_led_ch, &sc->sc_mtx, 0);
807 	TASK_INIT(&sc->sc_led_task, 0, urtw_ledtask, sc);
808 	TASK_INIT(&sc->sc_updateslot_task, 0, urtw_updateslottask, sc);
809 	callout_init(&sc->sc_watchdog_ch, 0);
810 
811 	if (sc->sc_flags & URTW_RTL8187B) {
812 		setup_start = urtw_8187b_usbconfig;
813 		n_setup = URTW_8187B_N_XFERS;
814 	} else {
815 		setup_start = urtw_8187l_usbconfig;
816 		n_setup = URTW_8187L_N_XFERS;
817 	}
818 
819 	error = usbd_transfer_setup(uaa->device, &iface_index, sc->sc_xfer,
820 	    setup_start, n_setup, sc, &sc->sc_mtx);
821 	if (error) {
822 		device_printf(dev, "could not allocate USB transfers, "
823 		    "err=%s\n", usbd_errstr(error));
824 		ret = ENXIO;
825 		goto fail0;
826 	}
827 
828 	if (sc->sc_flags & URTW_RTL8187B) {
829 		sc->sc_tx_dma_buf =
830 		    usbd_xfer_get_frame_buffer(sc->sc_xfer[
831 		    URTW_8187B_BULK_TX_BE], 0);
832 	} else {
833 		sc->sc_tx_dma_buf =
834 		    usbd_xfer_get_frame_buffer(sc->sc_xfer[
835 		    URTW_8187L_BULK_TX_LOW], 0);
836 	}
837 
838 	URTW_LOCK(sc);
839 
840 	urtw_read32_m(sc, URTW_RX, &data);
841 	sc->sc_epromtype = (data & URTW_RX_9356SEL) ? URTW_EEPROM_93C56 :
842 	    URTW_EEPROM_93C46;
843 
844 	error = urtw_get_rfchip(sc);
845 	if (error != 0)
846 		goto fail;
847 	error = urtw_get_macaddr(sc);
848 	if (error != 0)
849 		goto fail;
850 	error = urtw_get_txpwr(sc);
851 	if (error != 0)
852 		goto fail;
853 	error = urtw_led_init(sc);
854 	if (error != 0)
855 		goto fail;
856 
857 	URTW_UNLOCK(sc);
858 
859 	sc->sc_rts_retry = URTW_DEFAULT_RTS_RETRY;
860 	sc->sc_tx_retry = URTW_DEFAULT_TX_RETRY;
861 	sc->sc_currate = 3;
862 	sc->sc_preamble_mode = urtw_preamble_mode;
863 
864 	ifp = sc->sc_ifp = if_alloc(IFT_IEEE80211);
865 	if (ifp == NULL) {
866 		device_printf(sc->sc_dev, "can not allocate ifnet\n");
867 		ret = ENOMEM;
868 		goto fail1;
869 	}
870 
871 	ifp->if_softc = sc;
872 	if_initname(ifp, "urtw", device_get_unit(sc->sc_dev));
873 	ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST;
874 	ifp->if_init = urtw_init;
875 	ifp->if_ioctl = urtw_ioctl;
876 	ifp->if_start = urtw_start;
877 	/* XXX URTW_TX_DATA_LIST_COUNT */
878 	IFQ_SET_MAXLEN(&ifp->if_snd, ifqmaxlen);
879 	ifp->if_snd.ifq_drv_maxlen = ifqmaxlen;
880 	IFQ_SET_READY(&ifp->if_snd);
881 
882 	ic = ifp->if_l2com;
883 	ic->ic_ifp = ifp;
884 	ic->ic_phytype = IEEE80211_T_OFDM;	/* not only, but not used */
885 	ic->ic_opmode = IEEE80211_M_STA;	/* default to BSS mode */
886 
887 	/* set device capabilities */
888 	ic->ic_caps =
889 	    IEEE80211_C_STA |		/* station mode */
890 	    IEEE80211_C_MONITOR |	/* monitor mode supported */
891 	    IEEE80211_C_TXPMGT |	/* tx power management */
892 	    IEEE80211_C_SHPREAMBLE |	/* short preamble supported */
893 	    IEEE80211_C_SHSLOT |	/* short slot time supported */
894 	    IEEE80211_C_BGSCAN |	/* capable of bg scanning */
895 	    IEEE80211_C_WPA;		/* 802.11i */
896 
897 	bands = 0;
898 	setbit(&bands, IEEE80211_MODE_11B);
899 	setbit(&bands, IEEE80211_MODE_11G);
900 	ieee80211_init_channels(ic, NULL, &bands);
901 
902 	ieee80211_ifattach(ic, sc->sc_bssid);
903 	ic->ic_raw_xmit = urtw_raw_xmit;
904 	ic->ic_scan_start = urtw_scan_start;
905 	ic->ic_scan_end = urtw_scan_end;
906 	ic->ic_set_channel = urtw_set_channel;
907 	ic->ic_updateslot = urtw_updateslot;
908 	ic->ic_vap_create = urtw_vap_create;
909 	ic->ic_vap_delete = urtw_vap_delete;
910 	ic->ic_update_mcast = urtw_update_mcast;
911 
912 	ieee80211_radiotap_attach(ic,
913 	    &sc->sc_txtap.wt_ihdr, sizeof(sc->sc_txtap),
914 	    URTW_TX_RADIOTAP_PRESENT,
915 	    &sc->sc_rxtap.wr_ihdr, sizeof(sc->sc_rxtap),
916 	    URTW_RX_RADIOTAP_PRESENT);
917 
918 	urtw_sysctl_node(sc);
919 
920 	if (bootverbose)
921 		ieee80211_announce(ic);
922 	return (0);
923 
924 fail:	URTW_UNLOCK(sc);
925 fail1:	usbd_transfer_unsetup(sc->sc_xfer, (sc->sc_flags & URTW_RTL8187B) ?
926 	    URTW_8187B_N_XFERS : URTW_8187L_N_XFERS);
927 fail0:
928 	return (ret);
929 }
930 
931 static int
932 urtw_detach(device_t dev)
933 {
934 	struct urtw_softc *sc = device_get_softc(dev);
935 	struct ifnet *ifp = sc->sc_ifp;
936 	struct ieee80211com *ic = ifp->if_l2com;
937 	unsigned int x;
938 	unsigned int n_xfers;
939 
940 	/* Prevent further ioctls */
941 	URTW_LOCK(sc);
942 	sc->sc_flags |= URTW_DETACHED;
943 	URTW_UNLOCK(sc);
944 
945 	urtw_stop(ifp);
946 
947 	ieee80211_draintask(ic, &sc->sc_updateslot_task);
948 	ieee80211_draintask(ic, &sc->sc_led_task);
949 
950 	usb_callout_drain(&sc->sc_led_ch);
951 	callout_drain(&sc->sc_watchdog_ch);
952 
953 	n_xfers = (sc->sc_flags & URTW_RTL8187B) ?
954 	    URTW_8187B_N_XFERS : URTW_8187L_N_XFERS;
955 
956 	/* prevent further allocations from RX/TX data lists */
957 	URTW_LOCK(sc);
958 	STAILQ_INIT(&sc->sc_tx_active);
959 	STAILQ_INIT(&sc->sc_tx_inactive);
960 	STAILQ_INIT(&sc->sc_tx_pending);
961 
962 	STAILQ_INIT(&sc->sc_rx_active);
963 	STAILQ_INIT(&sc->sc_rx_inactive);
964 	URTW_UNLOCK(sc);
965 
966 	/* drain USB transfers */
967 	for (x = 0; x != n_xfers; x++)
968 		usbd_transfer_drain(sc->sc_xfer[x]);
969 
970 	/* free data buffers */
971 	URTW_LOCK(sc);
972 	urtw_free_tx_data_list(sc);
973 	urtw_free_rx_data_list(sc);
974 	URTW_UNLOCK(sc);
975 
976 	/* free USB transfers and some data buffers */
977 	usbd_transfer_unsetup(sc->sc_xfer, n_xfers);
978 
979 	ieee80211_ifdetach(ic);
980 	if_free(ifp);
981 	mtx_destroy(&sc->sc_mtx);
982 	return (0);
983 }
984 
985 static void
986 urtw_free_tx_data_list(struct urtw_softc *sc)
987 {
988 	urtw_free_data_list(sc, sc->sc_tx, URTW_TX_DATA_LIST_COUNT, 0);
989 }
990 
991 static void
992 urtw_free_rx_data_list(struct urtw_softc *sc)
993 {
994 	urtw_free_data_list(sc, sc->sc_rx, URTW_RX_DATA_LIST_COUNT, 1);
995 }
996 
997 static void
998 urtw_free_data_list(struct urtw_softc *sc, struct urtw_data data[], int ndata,
999     int fillmbuf)
1000 {
1001 	int i;
1002 
1003 	for (i = 0; i < ndata; i++) {
1004 		struct urtw_data *dp = &data[i];
1005 
1006 		if (fillmbuf == 1) {
1007 			if (dp->m != NULL) {
1008 				m_freem(dp->m);
1009 				dp->m = NULL;
1010 				dp->buf = NULL;
1011 			}
1012 		} else {
1013 			dp->buf = NULL;
1014 		}
1015 		if (dp->ni != NULL) {
1016 			ieee80211_free_node(dp->ni);
1017 			dp->ni = NULL;
1018 		}
1019 	}
1020 }
1021 
1022 static struct ieee80211vap *
1023 urtw_vap_create(struct ieee80211com *ic, const char name[IFNAMSIZ], int unit,
1024     enum ieee80211_opmode opmode, int flags,
1025     const uint8_t bssid[IEEE80211_ADDR_LEN],
1026     const uint8_t mac[IEEE80211_ADDR_LEN])
1027 {
1028 	struct urtw_vap *uvp;
1029 	struct ieee80211vap *vap;
1030 
1031 	if (!TAILQ_EMPTY(&ic->ic_vaps))		/* only one at a time */
1032 		return (NULL);
1033 	uvp = (struct urtw_vap *) malloc(sizeof(struct urtw_vap),
1034 	    M_80211_VAP, M_NOWAIT | M_ZERO);
1035 	if (uvp == NULL)
1036 		return (NULL);
1037 	vap = &uvp->vap;
1038 	/* enable s/w bmiss handling for sta mode */
1039 
1040 	if (ieee80211_vap_setup(ic, vap, name, unit, opmode,
1041 	    flags | IEEE80211_CLONE_NOBEACONS, bssid, mac) != 0) {
1042 		/* out of memory */
1043 		free(uvp, M_80211_VAP);
1044 		return (NULL);
1045 	}
1046 
1047 	/* override state transition machine */
1048 	uvp->newstate = vap->iv_newstate;
1049 	vap->iv_newstate = urtw_newstate;
1050 
1051 	/* complete setup */
1052 	ieee80211_vap_attach(vap, ieee80211_media_change,
1053 	    ieee80211_media_status);
1054 	ic->ic_opmode = opmode;
1055 	return (vap);
1056 }
1057 
1058 static void
1059 urtw_vap_delete(struct ieee80211vap *vap)
1060 {
1061 	struct urtw_vap *uvp = URTW_VAP(vap);
1062 
1063 	ieee80211_vap_detach(vap);
1064 	free(uvp, M_80211_VAP);
1065 }
1066 
1067 static void
1068 urtw_init_locked(void *arg)
1069 {
1070 	int ret;
1071 	struct urtw_softc *sc = arg;
1072 	struct ifnet *ifp = sc->sc_ifp;
1073 	usb_error_t error;
1074 
1075 	if (ifp->if_drv_flags & IFF_DRV_RUNNING)
1076 		urtw_stop_locked(ifp);
1077 
1078 	error = (sc->sc_flags & URTW_RTL8187B) ? urtw_adapter_start_b(sc) :
1079 	    urtw_adapter_start(sc);
1080 	if (error != 0)
1081 		goto fail;
1082 
1083 	/* reset softc variables  */
1084 	sc->sc_txtimer = 0;
1085 
1086 	if (!(sc->sc_flags & URTW_INIT_ONCE)) {
1087 		ret = urtw_alloc_rx_data_list(sc);
1088 		if (ret != 0)
1089 			goto fail;
1090 		ret = urtw_alloc_tx_data_list(sc);
1091 		if (ret != 0)
1092 			goto fail;
1093 		sc->sc_flags |= URTW_INIT_ONCE;
1094 	}
1095 
1096 	error = urtw_rx_enable(sc);
1097 	if (error != 0)
1098 		goto fail;
1099 	error = urtw_tx_enable(sc);
1100 	if (error != 0)
1101 		goto fail;
1102 
1103 	if (sc->sc_flags & URTW_RTL8187B)
1104 		usbd_transfer_start(sc->sc_xfer[URTW_8187B_BULK_TX_STATUS]);
1105 
1106 	ifp->if_drv_flags &= ~IFF_DRV_OACTIVE;
1107 	ifp->if_drv_flags |= IFF_DRV_RUNNING;
1108 
1109 	callout_reset(&sc->sc_watchdog_ch, hz, urtw_watchdog, sc);
1110 fail:
1111 	return;
1112 }
1113 
1114 static void
1115 urtw_init(void *arg)
1116 {
1117 	struct urtw_softc *sc = arg;
1118 
1119 	URTW_LOCK(sc);
1120 	urtw_init_locked(arg);
1121 	URTW_UNLOCK(sc);
1122 }
1123 
1124 static usb_error_t
1125 urtw_adapter_start_b(struct urtw_softc *sc)
1126 {
1127 #define N(a)	((int)(sizeof(a) / sizeof((a)[0])))
1128 	uint8_t data8;
1129 	usb_error_t error;
1130 
1131 	error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG);
1132 	if (error)
1133 		goto fail;
1134 
1135 	urtw_read8_m(sc, URTW_CONFIG3, &data8);
1136 	urtw_write8_m(sc, URTW_CONFIG3,
1137 	    data8 | URTW_CONFIG3_ANAPARAM_WRITE | URTW_CONFIG3_GNT_SELECT);
1138 	urtw_write32_m(sc, URTW_ANAPARAM2, URTW_8187B_8225_ANAPARAM2_ON);
1139 	urtw_write32_m(sc, URTW_ANAPARAM, URTW_8187B_8225_ANAPARAM_ON);
1140 	urtw_write8_m(sc, URTW_ANAPARAM3, URTW_8187B_8225_ANAPARAM3_ON);
1141 
1142 	urtw_write8_m(sc, 0x61, 0x10);
1143 	urtw_read8_m(sc, 0x62, &data8);
1144 	urtw_write8_m(sc, 0x62, data8 & ~(1 << 5));
1145 	urtw_write8_m(sc, 0x62, data8 | (1 << 5));
1146 
1147 	urtw_read8_m(sc, URTW_CONFIG3, &data8);
1148 	data8 &= ~URTW_CONFIG3_ANAPARAM_WRITE;
1149 	urtw_write8_m(sc, URTW_CONFIG3, data8);
1150 
1151 	error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL);
1152 	if (error)
1153 		goto fail;
1154 
1155 	error = urtw_8187b_cmd_reset(sc);
1156 	if (error)
1157 		goto fail;
1158 
1159 	error = sc->sc_rf_init(sc);
1160 	if (error != 0)
1161 		goto fail;
1162 	urtw_write8_m(sc, URTW_CMD, URTW_CMD_RX_ENABLE | URTW_CMD_TX_ENABLE);
1163 
1164 	/* fix RTL8187B RX stall */
1165 	error = urtw_intr_enable(sc);
1166 	if (error)
1167 		goto fail;
1168 
1169 	error = urtw_write8e(sc, 0x41, 0xf4);
1170 	if (error)
1171 		goto fail;
1172 	error = urtw_write8e(sc, 0x40, 0x00);
1173 	if (error)
1174 		goto fail;
1175 	error = urtw_write8e(sc, 0x42, 0x00);
1176 	if (error)
1177 		goto fail;
1178 	error = urtw_write8e(sc, 0x42, 0x01);
1179 	if (error)
1180 		goto fail;
1181 	error = urtw_write8e(sc, 0x40, 0x0f);
1182 	if (error)
1183 		goto fail;
1184 	error = urtw_write8e(sc, 0x42, 0x00);
1185 	if (error)
1186 		goto fail;
1187 	error = urtw_write8e(sc, 0x42, 0x01);
1188 	if (error)
1189 		goto fail;
1190 
1191 	urtw_read8_m(sc, 0xdb, &data8);
1192 	urtw_write8_m(sc, 0xdb, data8 | (1 << 2));
1193 	urtw_write16_m(sc, 0x372, 0x59fa);
1194 	urtw_write16_m(sc, 0x374, 0x59d2);
1195 	urtw_write16_m(sc, 0x376, 0x59d2);
1196 	urtw_write16_m(sc, 0x378, 0x19fa);
1197 	urtw_write16_m(sc, 0x37a, 0x19fa);
1198 	urtw_write16_m(sc, 0x37c, 0x00d0);
1199 	urtw_write8_m(sc, 0x61, 0);
1200 
1201 	urtw_write8_m(sc, 0x180, 0x0f);
1202 	urtw_write8_m(sc, 0x183, 0x03);
1203 	urtw_write8_m(sc, 0xda, 0x10);
1204 	urtw_write8_m(sc, 0x24d, 0x08);
1205 	urtw_write32_m(sc, URTW_HSSI_PARA, 0x0600321b);
1206 
1207 	urtw_write16_m(sc, 0x1ec, 0x800);	/* RX MAX SIZE */
1208 fail:
1209 	return (error);
1210 #undef N
1211 }
1212 
1213 static usb_error_t
1214 urtw_adapter_start(struct urtw_softc *sc)
1215 {
1216 	usb_error_t error;
1217 
1218 	error = urtw_reset(sc);
1219 	if (error)
1220 		goto fail;
1221 
1222 	urtw_write8_m(sc, URTW_ADDR_MAGIC1, 0);
1223 	urtw_write8_m(sc, URTW_GPIO, 0);
1224 
1225 	/* for led  */
1226 	urtw_write8_m(sc, URTW_ADDR_MAGIC1, 4);
1227 	error = urtw_led_ctl(sc, URTW_LED_CTL_POWER_ON);
1228 	if (error != 0)
1229 		goto fail;
1230 
1231 	error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG);
1232 	if (error)
1233 		goto fail;
1234 	/* applying MAC address again.  */
1235 	urtw_write32_m(sc, URTW_MAC0, ((uint32_t *)sc->sc_bssid)[0]);
1236 	urtw_write16_m(sc, URTW_MAC4, ((uint32_t *)sc->sc_bssid)[1] & 0xffff);
1237 	error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL);
1238 	if (error)
1239 		goto fail;
1240 
1241 	error = urtw_update_msr(sc);
1242 	if (error)
1243 		goto fail;
1244 
1245 	urtw_write32_m(sc, URTW_INT_TIMEOUT, 0);
1246 	urtw_write8_m(sc, URTW_WPA_CONFIG, 0);
1247 	urtw_write8_m(sc, URTW_RATE_FALLBACK, URTW_RATE_FALLBACK_ENABLE | 0x1);
1248 	error = urtw_set_rate(sc);
1249 	if (error != 0)
1250 		goto fail;
1251 
1252 	error = sc->sc_rf_init(sc);
1253 	if (error != 0)
1254 		goto fail;
1255 	if (sc->sc_rf_set_sens != NULL)
1256 		sc->sc_rf_set_sens(sc, sc->sc_sens);
1257 
1258 	/* XXX correct? to call write16  */
1259 	urtw_write16_m(sc, URTW_PSR, 1);
1260 	urtw_write16_m(sc, URTW_ADDR_MAGIC2, 0x10);
1261 	urtw_write8_m(sc, URTW_TALLY_SEL, 0x80);
1262 	urtw_write8_m(sc, URTW_ADDR_MAGIC3, 0x60);
1263 	/* XXX correct? to call write16  */
1264 	urtw_write16_m(sc, URTW_PSR, 0);
1265 	urtw_write8_m(sc, URTW_ADDR_MAGIC1, 4);
1266 
1267 	error = urtw_intr_enable(sc);
1268 	if (error != 0)
1269 		goto fail;
1270 
1271 fail:
1272 	return (error);
1273 }
1274 
1275 static usb_error_t
1276 urtw_set_mode(struct urtw_softc *sc, uint32_t mode)
1277 {
1278 	uint8_t data;
1279 	usb_error_t error;
1280 
1281 	urtw_read8_m(sc, URTW_EPROM_CMD, &data);
1282 	data = (data & ~URTW_EPROM_CMD_MASK) | (mode << URTW_EPROM_CMD_SHIFT);
1283 	data = data & ~(URTW_EPROM_CS | URTW_EPROM_CK);
1284 	urtw_write8_m(sc, URTW_EPROM_CMD, data);
1285 fail:
1286 	return (error);
1287 }
1288 
1289 static usb_error_t
1290 urtw_8187b_cmd_reset(struct urtw_softc *sc)
1291 {
1292 	int i;
1293 	uint8_t data8;
1294 	usb_error_t error;
1295 
1296 	/* XXX the code can be duplicate with urtw_reset().  */
1297 	urtw_read8_m(sc, URTW_CMD, &data8);
1298 	data8 = (data8 & 0x2) | URTW_CMD_RST;
1299 	urtw_write8_m(sc, URTW_CMD, data8);
1300 
1301 	for (i = 0; i < 20; i++) {
1302 		usb_pause_mtx(&sc->sc_mtx, 2);
1303 		urtw_read8_m(sc, URTW_CMD, &data8);
1304 		if (!(data8 & URTW_CMD_RST))
1305 			break;
1306 	}
1307 	if (i >= 20) {
1308 		device_printf(sc->sc_dev, "reset timeout\n");
1309 		goto fail;
1310 	}
1311 fail:
1312 	return (error);
1313 }
1314 
1315 static usb_error_t
1316 urtw_do_request(struct urtw_softc *sc,
1317     struct usb_device_request *req, void *data)
1318 {
1319 	usb_error_t err;
1320 	int ntries = 10;
1321 
1322 	URTW_ASSERT_LOCKED(sc);
1323 
1324 	while (ntries--) {
1325 		err = usbd_do_request_flags(sc->sc_udev, &sc->sc_mtx,
1326 		    req, data, 0, NULL, 250 /* ms */);
1327 		if (err == 0)
1328 			break;
1329 
1330 		DPRINTF(sc, URTW_DEBUG_INIT,
1331 		    "Control request failed, %s (retrying)\n",
1332 		    usbd_errstr(err));
1333 		usb_pause_mtx(&sc->sc_mtx, hz / 100);
1334 	}
1335 	return (err);
1336 }
1337 
1338 static void
1339 urtw_stop_locked(struct ifnet *ifp)
1340 {
1341 	struct urtw_softc *sc = ifp->if_softc;
1342 	uint8_t data8;
1343 	usb_error_t error;
1344 
1345 	ifp->if_drv_flags &= ~(IFF_DRV_RUNNING | IFF_DRV_OACTIVE);
1346 
1347 	error = urtw_intr_disable(sc);
1348 	if (error)
1349 		goto fail;
1350 	urtw_read8_m(sc, URTW_CMD, &data8);
1351 	data8 &= ~(URTW_CMD_RX_ENABLE | URTW_CMD_TX_ENABLE);
1352 	urtw_write8_m(sc, URTW_CMD, data8);
1353 
1354 	error = sc->sc_rf_stop(sc);
1355 	if (error != 0)
1356 		goto fail;
1357 
1358 	error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG);
1359 	if (error)
1360 		goto fail;
1361 	urtw_read8_m(sc, URTW_CONFIG4, &data8);
1362 	urtw_write8_m(sc, URTW_CONFIG4, data8 | URTW_CONFIG4_VCOOFF);
1363 	error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL);
1364 	if (error)
1365 		goto fail;
1366 fail:
1367 	if (error)
1368 		device_printf(sc->sc_dev, "failed to stop (%s)\n",
1369 		    usbd_errstr(error));
1370 
1371 	usb_callout_stop(&sc->sc_led_ch);
1372 	callout_stop(&sc->sc_watchdog_ch);
1373 
1374 	urtw_abort_xfers(sc);
1375 }
1376 
1377 static void
1378 urtw_stop(struct ifnet *ifp)
1379 {
1380 	struct urtw_softc *sc = ifp->if_softc;
1381 
1382 	URTW_LOCK(sc);
1383 	urtw_stop_locked(ifp);
1384 	URTW_UNLOCK(sc);
1385 }
1386 
1387 static void
1388 urtw_abort_xfers(struct urtw_softc *sc)
1389 {
1390 	int i, max;
1391 
1392 	URTW_ASSERT_LOCKED(sc);
1393 
1394 	max = (sc->sc_flags & URTW_RTL8187B) ? URTW_8187B_N_XFERS :
1395 	    URTW_8187L_N_XFERS;
1396 
1397 	/* abort any pending transfers */
1398 	for (i = 0; i < max; i++)
1399 		usbd_transfer_stop(sc->sc_xfer[i]);
1400 }
1401 
1402 static int
1403 urtw_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data)
1404 {
1405 	struct urtw_softc *sc = ifp->if_softc;
1406 	struct ieee80211com *ic = ifp->if_l2com;
1407 	struct ifreq *ifr = (struct ifreq *) data;
1408 	int error;
1409 	int startall = 0;
1410 
1411 	URTW_LOCK(sc);
1412 	error = (sc->sc_flags & URTW_DETACHED) ? ENXIO : 0;
1413 	URTW_UNLOCK(sc);
1414 	if (error)
1415 		return (error);
1416 
1417 	switch (cmd) {
1418 	case SIOCSIFFLAGS:
1419 		if (ifp->if_flags & IFF_UP) {
1420 			if (ifp->if_drv_flags & IFF_DRV_RUNNING) {
1421 				if ((ifp->if_flags ^ sc->sc_if_flags) &
1422 				    (IFF_ALLMULTI | IFF_PROMISC))
1423 					urtw_set_multi(sc);
1424 			} else {
1425 				urtw_init(ifp->if_softc);
1426 				startall = 1;
1427 			}
1428 		} else {
1429 			if (ifp->if_drv_flags & IFF_DRV_RUNNING)
1430 				urtw_stop(ifp);
1431 		}
1432 		sc->sc_if_flags = ifp->if_flags;
1433 		if (startall)
1434 			ieee80211_start_all(ic);
1435 		break;
1436 	case SIOCGIFMEDIA:
1437 		error = ifmedia_ioctl(ifp, ifr, &ic->ic_media, cmd);
1438 		break;
1439 	case SIOCGIFADDR:
1440 		error = ether_ioctl(ifp, cmd, data);
1441 		break;
1442 	default:
1443 		error = EINVAL;
1444 		break;
1445 	}
1446 	return (error);
1447 }
1448 
1449 static void
1450 urtw_start(struct ifnet *ifp)
1451 {
1452 	struct urtw_data *bf;
1453 	struct urtw_softc *sc = ifp->if_softc;
1454 	struct ieee80211_node *ni;
1455 	struct mbuf *m;
1456 
1457 	if ((ifp->if_drv_flags & IFF_DRV_RUNNING) == 0)
1458 		return;
1459 
1460 	URTW_LOCK(sc);
1461 	for (;;) {
1462 		IFQ_DRV_DEQUEUE(&ifp->if_snd, m);
1463 		if (m == NULL)
1464 			break;
1465 		bf = urtw_getbuf(sc);
1466 		if (bf == NULL) {
1467 			IFQ_DRV_PREPEND(&ifp->if_snd, m);
1468 			break;
1469 		}
1470 
1471 		ni = (struct ieee80211_node *)m->m_pkthdr.rcvif;
1472 		m->m_pkthdr.rcvif = NULL;
1473 
1474 		if (urtw_tx_start(sc, ni, m, bf, URTW_PRIORITY_NORMAL) != 0) {
1475 			ifp->if_oerrors++;
1476 			STAILQ_INSERT_HEAD(&sc->sc_tx_inactive, bf, next);
1477 			ieee80211_free_node(ni);
1478 			break;
1479 		}
1480 
1481 		sc->sc_txtimer = 5;
1482 		callout_reset(&sc->sc_watchdog_ch, hz, urtw_watchdog, sc);
1483 	}
1484 	URTW_UNLOCK(sc);
1485 }
1486 
1487 static int
1488 urtw_alloc_data_list(struct urtw_softc *sc, struct urtw_data data[],
1489     int ndata, int maxsz, void *dma_buf)
1490 {
1491 	int i, error;
1492 
1493 	for (i = 0; i < ndata; i++) {
1494 		struct urtw_data *dp = &data[i];
1495 
1496 		dp->sc = sc;
1497 		if (dma_buf == NULL) {
1498 			dp->m = m_getcl(M_NOWAIT, MT_DATA, M_PKTHDR);
1499 			if (dp->m == NULL) {
1500 				device_printf(sc->sc_dev,
1501 				    "could not allocate rx mbuf\n");
1502 				error = ENOMEM;
1503 				goto fail;
1504 			}
1505 			dp->buf = mtod(dp->m, uint8_t *);
1506 		} else {
1507 			dp->m = NULL;
1508 			dp->buf = ((uint8_t *)dma_buf) +
1509 			    (i * maxsz);
1510 		}
1511 		dp->ni = NULL;
1512 	}
1513 	return (0);
1514 
1515 fail:	urtw_free_data_list(sc, data, ndata, 1);
1516 	return (error);
1517 }
1518 
1519 static int
1520 urtw_alloc_rx_data_list(struct urtw_softc *sc)
1521 {
1522 	int error, i;
1523 
1524 	error = urtw_alloc_data_list(sc,
1525 	    sc->sc_rx, URTW_RX_DATA_LIST_COUNT,
1526 	    MCLBYTES, NULL /* mbufs */);
1527 	if (error != 0)
1528 		return (error);
1529 
1530 	STAILQ_INIT(&sc->sc_rx_active);
1531 	STAILQ_INIT(&sc->sc_rx_inactive);
1532 
1533 	for (i = 0; i < URTW_RX_DATA_LIST_COUNT; i++)
1534 		STAILQ_INSERT_HEAD(&sc->sc_rx_inactive, &sc->sc_rx[i], next);
1535 
1536 	return (0);
1537 }
1538 
1539 static int
1540 urtw_alloc_tx_data_list(struct urtw_softc *sc)
1541 {
1542 	int error, i;
1543 
1544 	error = urtw_alloc_data_list(sc,
1545 	    sc->sc_tx, URTW_TX_DATA_LIST_COUNT, URTW_TX_MAXSIZE,
1546 	    sc->sc_tx_dma_buf /* no mbufs */);
1547 	if (error != 0)
1548 		return (error);
1549 
1550 	STAILQ_INIT(&sc->sc_tx_active);
1551 	STAILQ_INIT(&sc->sc_tx_inactive);
1552 	STAILQ_INIT(&sc->sc_tx_pending);
1553 
1554 	for (i = 0; i < URTW_TX_DATA_LIST_COUNT; i++)
1555 		STAILQ_INSERT_HEAD(&sc->sc_tx_inactive, &sc->sc_tx[i],
1556 		    next);
1557 
1558 	return (0);
1559 }
1560 
1561 static int
1562 urtw_raw_xmit(struct ieee80211_node *ni, struct mbuf *m,
1563     const struct ieee80211_bpf_params *params)
1564 {
1565 	struct ieee80211com *ic = ni->ni_ic;
1566 	struct ifnet *ifp = ic->ic_ifp;
1567 	struct urtw_data *bf;
1568 	struct urtw_softc *sc = ifp->if_softc;
1569 
1570 	/* prevent management frames from being sent if we're not ready */
1571 	if (!(ifp->if_drv_flags & IFF_DRV_RUNNING)) {
1572 		m_freem(m);
1573 		ieee80211_free_node(ni);
1574 		return ENETDOWN;
1575 	}
1576 	URTW_LOCK(sc);
1577 	bf = urtw_getbuf(sc);
1578 	if (bf == NULL) {
1579 		ieee80211_free_node(ni);
1580 		m_freem(m);
1581 		URTW_UNLOCK(sc);
1582 		return (ENOBUFS);		/* XXX */
1583 	}
1584 
1585 	ifp->if_opackets++;
1586 	if (urtw_tx_start(sc, ni, m, bf, URTW_PRIORITY_LOW) != 0) {
1587 		ieee80211_free_node(ni);
1588 		ifp->if_oerrors++;
1589 		STAILQ_INSERT_HEAD(&sc->sc_tx_inactive, bf, next);
1590 		URTW_UNLOCK(sc);
1591 		return (EIO);
1592 	}
1593 	URTW_UNLOCK(sc);
1594 
1595 	sc->sc_txtimer = 5;
1596 	return (0);
1597 }
1598 
1599 static void
1600 urtw_scan_start(struct ieee80211com *ic)
1601 {
1602 
1603 	/* XXX do nothing?  */
1604 }
1605 
1606 static void
1607 urtw_scan_end(struct ieee80211com *ic)
1608 {
1609 
1610 	/* XXX do nothing?  */
1611 }
1612 
1613 static void
1614 urtw_set_channel(struct ieee80211com *ic)
1615 {
1616 	struct urtw_softc *sc  = ic->ic_ifp->if_softc;
1617 	struct ifnet *ifp = sc->sc_ifp;
1618 	uint32_t data, orig;
1619 	usb_error_t error;
1620 
1621 	/*
1622 	 * if the user set a channel explicitly using ifconfig(8) this function
1623 	 * can be called earlier than we're expected that in some cases the
1624 	 * initialization would be failed if setting a channel is called before
1625 	 * the init have done.
1626 	 */
1627 	if (!(ifp->if_drv_flags & IFF_DRV_RUNNING))
1628 		return;
1629 
1630 	if (sc->sc_curchan != NULL && sc->sc_curchan == ic->ic_curchan)
1631 		return;
1632 
1633 	URTW_LOCK(sc);
1634 
1635 	/*
1636 	 * during changing th channel we need to temporarily be disable
1637 	 * TX.
1638 	 */
1639 	urtw_read32_m(sc, URTW_TX_CONF, &orig);
1640 	data = orig & ~URTW_TX_LOOPBACK_MASK;
1641 	urtw_write32_m(sc, URTW_TX_CONF, data | URTW_TX_LOOPBACK_MAC);
1642 
1643 	error = sc->sc_rf_set_chan(sc, ieee80211_chan2ieee(ic, ic->ic_curchan));
1644 	if (error != 0)
1645 		goto fail;
1646 	usb_pause_mtx(&sc->sc_mtx, 10);
1647 	urtw_write32_m(sc, URTW_TX_CONF, orig);
1648 
1649 	urtw_write16_m(sc, URTW_ATIM_WND, 2);
1650 	urtw_write16_m(sc, URTW_ATIM_TR_ITV, 100);
1651 	urtw_write16_m(sc, URTW_BEACON_INTERVAL, 100);
1652 	urtw_write16_m(sc, URTW_BEACON_INTERVAL_TIME, 100);
1653 
1654 fail:
1655 	URTW_UNLOCK(sc);
1656 
1657 	sc->sc_curchan = ic->ic_curchan;
1658 
1659 	if (error != 0)
1660 		device_printf(sc->sc_dev, "could not change the channel\n");
1661 }
1662 
1663 static void
1664 urtw_update_mcast(struct ifnet *ifp)
1665 {
1666 
1667 	/* XXX do nothing?  */
1668 }
1669 
1670 static int
1671 urtw_tx_start(struct urtw_softc *sc, struct ieee80211_node *ni, struct mbuf *m0,
1672     struct urtw_data *data, int prior)
1673 {
1674 	struct ifnet *ifp = sc->sc_ifp;
1675 	struct ieee80211_frame *wh = mtod(m0, struct ieee80211_frame *);
1676 	struct ieee80211_key *k;
1677 	const struct ieee80211_txparam *tp;
1678 	struct ieee80211com *ic = ifp->if_l2com;
1679 	struct ieee80211vap *vap = ni->ni_vap;
1680 	struct usb_xfer *rtl8187b_pipes[URTW_8187B_TXPIPE_MAX] = {
1681 		sc->sc_xfer[URTW_8187B_BULK_TX_BE],
1682 		sc->sc_xfer[URTW_8187B_BULK_TX_BK],
1683 		sc->sc_xfer[URTW_8187B_BULK_TX_VI],
1684 		sc->sc_xfer[URTW_8187B_BULK_TX_VO]
1685 	};
1686 	struct usb_xfer *xfer;
1687 	int dur = 0, rtsdur = 0, rtsenable = 0, ctsenable = 0, rate,
1688 	    pkttime = 0, txdur = 0, isshort = 0, xferlen;
1689 	uint16_t acktime, rtstime, ctstime;
1690 	uint32_t flags;
1691 	usb_error_t error;
1692 
1693 	URTW_ASSERT_LOCKED(sc);
1694 
1695 	/*
1696 	 * Software crypto.
1697 	 */
1698 	if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
1699 		k = ieee80211_crypto_encap(ni, m0);
1700 		if (k == NULL) {
1701 			device_printf(sc->sc_dev,
1702 			    "ieee80211_crypto_encap returns NULL.\n");
1703 			/* XXX we don't expect the fragmented frames  */
1704 			m_freem(m0);
1705 			return (ENOBUFS);
1706 		}
1707 
1708 		/* in case packet header moved, reset pointer */
1709 		wh = mtod(m0, struct ieee80211_frame *);
1710 	}
1711 
1712 	if (ieee80211_radiotap_active_vap(vap)) {
1713 		struct urtw_tx_radiotap_header *tap = &sc->sc_txtap;
1714 
1715 		/* XXX Are variables correct?  */
1716 		tap->wt_flags = 0;
1717 		tap->wt_chan_freq = htole16(ic->ic_curchan->ic_freq);
1718 		tap->wt_chan_flags = htole16(ic->ic_curchan->ic_flags);
1719 
1720 		ieee80211_radiotap_tx(vap, m0);
1721 	}
1722 
1723 	if ((wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK) == IEEE80211_FC0_TYPE_MGT ||
1724 	    (wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK) == IEEE80211_FC0_TYPE_CTL) {
1725 		tp = &vap->iv_txparms[ieee80211_chan2mode(ic->ic_curchan)];
1726 		rate = tp->mgmtrate;
1727 	} else {
1728 		tp = &vap->iv_txparms[ieee80211_chan2mode(ni->ni_chan)];
1729 		/* for data frames */
1730 		if (IEEE80211_IS_MULTICAST(wh->i_addr1))
1731 			rate = tp->mcastrate;
1732 		else if (tp->ucastrate != IEEE80211_FIXED_RATE_NONE)
1733 			rate = tp->ucastrate;
1734 		else
1735 			rate = urtw_rtl2rate(sc->sc_currate);
1736 	}
1737 
1738 	sc->sc_stats.txrates[sc->sc_currate]++;
1739 
1740 	if (IEEE80211_IS_MULTICAST(wh->i_addr1))
1741 		txdur = pkttime = urtw_compute_txtime(m0->m_pkthdr.len +
1742 		    IEEE80211_CRC_LEN, rate, 0, 0);
1743 	else {
1744 		acktime = urtw_compute_txtime(14, 2,0, 0);
1745 		if ((m0->m_pkthdr.len + 4) > vap->iv_rtsthreshold) {
1746 			rtsenable = 1;
1747 			ctsenable = 0;
1748 			rtstime = urtw_compute_txtime(URTW_ACKCTS_LEN, 2, 0, 0);
1749 			ctstime = urtw_compute_txtime(14, 2, 0, 0);
1750 			pkttime = urtw_compute_txtime(m0->m_pkthdr.len +
1751 			    IEEE80211_CRC_LEN, rate, 0, isshort);
1752 			rtsdur = ctstime + pkttime + acktime +
1753 			    3 * URTW_ASIFS_TIME;
1754 			txdur = rtstime + rtsdur;
1755 		} else {
1756 			rtsenable = ctsenable = rtsdur = 0;
1757 			pkttime = urtw_compute_txtime(m0->m_pkthdr.len +
1758 			    IEEE80211_CRC_LEN, rate, 0, isshort);
1759 			txdur = pkttime + URTW_ASIFS_TIME + acktime;
1760 		}
1761 
1762 		if (wh->i_fc[1] & IEEE80211_FC1_MORE_FRAG)
1763 			dur = urtw_compute_txtime(m0->m_pkthdr.len +
1764 			    IEEE80211_CRC_LEN, rate, 0, isshort) +
1765 			    3 * URTW_ASIFS_TIME +
1766 			    2 * acktime;
1767 		else
1768 			dur = URTW_ASIFS_TIME + acktime;
1769 	}
1770 	*(uint16_t *)wh->i_dur = htole16(dur);
1771 
1772 	xferlen = m0->m_pkthdr.len;
1773 	xferlen += (sc->sc_flags & URTW_RTL8187B) ? (4 * 8) : (4 * 3);
1774 	if ((0 == xferlen % 64) || (0 == xferlen % 512))
1775 		xferlen += 1;
1776 
1777 	memset(data->buf, 0, URTW_TX_MAXSIZE);
1778 	flags = m0->m_pkthdr.len & 0xfff;
1779 	flags |= URTW_TX_FLAG_NO_ENC;
1780 	if ((ic->ic_flags & IEEE80211_F_SHPREAMBLE) &&
1781 	    (ni->ni_capinfo & IEEE80211_CAPINFO_SHORT_PREAMBLE) &&
1782 	    (sc->sc_preamble_mode == URTW_PREAMBLE_MODE_SHORT) &&
1783 	    (sc->sc_currate != 0))
1784 		flags |= URTW_TX_FLAG_SPLCP;
1785 	if (wh->i_fc[1] & IEEE80211_FC1_MORE_FRAG)
1786 		flags |= URTW_TX_FLAG_MOREFRAG;
1787 
1788 	flags |= (sc->sc_currate & 0xf) << URTW_TX_FLAG_TXRATE_SHIFT;
1789 
1790 	if (sc->sc_flags & URTW_RTL8187B) {
1791 		struct urtw_8187b_txhdr *tx;
1792 
1793 		tx = (struct urtw_8187b_txhdr *)data->buf;
1794 		if (ctsenable)
1795 			flags |= URTW_TX_FLAG_CTS;
1796 		if (rtsenable) {
1797 			flags |= URTW_TX_FLAG_RTS;
1798 			flags |= (urtw_rate2rtl(11) & 0xf) <<
1799 			    URTW_TX_FLAG_RTSRATE_SHIFT;
1800 			tx->rtsdur = rtsdur;
1801 		}
1802 		tx->flag = htole32(flags);
1803 		tx->txdur = txdur;
1804 		if ((wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK) ==
1805 		    IEEE80211_FC0_TYPE_MGT &&
1806 		    (wh->i_fc[0] & IEEE80211_FC0_SUBTYPE_MASK) ==
1807 		    IEEE80211_FC0_SUBTYPE_PROBE_RESP)
1808 			tx->retry = 1;
1809 		else
1810 			tx->retry = URTW_TX_MAXRETRY;
1811 		m_copydata(m0, 0, m0->m_pkthdr.len, (uint8_t *)(tx + 1));
1812 	} else {
1813 		struct urtw_8187l_txhdr *tx;
1814 
1815 		tx = (struct urtw_8187l_txhdr *)data->buf;
1816 		if (rtsenable) {
1817 			flags |= URTW_TX_FLAG_RTS;
1818 			tx->rtsdur = rtsdur;
1819 		}
1820 		flags |= (urtw_rate2rtl(11) & 0xf) << URTW_TX_FLAG_RTSRATE_SHIFT;
1821 		tx->flag = htole32(flags);
1822 		tx->retry = 3;		/* CW minimum  */
1823 		tx->retry = 7 << 4;	/* CW maximum  */
1824 		tx->retry = URTW_TX_MAXRETRY << 8;	/* retry limitation  */
1825 		m_copydata(m0, 0, m0->m_pkthdr.len, (uint8_t *)(tx + 1));
1826 	}
1827 
1828 	data->buflen = xferlen;
1829 	data->ni = ni;
1830 	data->m = m0;
1831 
1832 	if (sc->sc_flags & URTW_RTL8187B) {
1833 		switch (wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK) {
1834 		case IEEE80211_FC0_TYPE_CTL:
1835 		case IEEE80211_FC0_TYPE_MGT:
1836 			xfer = sc->sc_xfer[URTW_8187B_BULK_TX_EP12];
1837 			break;
1838 		default:
1839 			KASSERT(M_WME_GETAC(m0) < URTW_8187B_TXPIPE_MAX,
1840 			    ("unsupported WME pipe %d", M_WME_GETAC(m0)));
1841 			xfer = rtl8187b_pipes[M_WME_GETAC(m0)];
1842 			break;
1843 		}
1844 	} else
1845 		xfer = (prior == URTW_PRIORITY_LOW) ?
1846 		    sc->sc_xfer[URTW_8187L_BULK_TX_LOW] :
1847 		    sc->sc_xfer[URTW_8187L_BULK_TX_NORMAL];
1848 
1849 	STAILQ_INSERT_TAIL(&sc->sc_tx_pending, data, next);
1850 	usbd_transfer_start(xfer);
1851 
1852 	error = urtw_led_ctl(sc, URTW_LED_CTL_TX);
1853 	if (error != 0)
1854 		device_printf(sc->sc_dev, "could not control LED (%d)\n",
1855 		    error);
1856 	return (0);
1857 }
1858 
1859 static int
1860 urtw_newstate(struct ieee80211vap *vap, enum ieee80211_state nstate, int arg)
1861 {
1862 	struct ieee80211com *ic = vap->iv_ic;
1863 	struct urtw_softc *sc = ic->ic_ifp->if_softc;
1864 	struct urtw_vap *uvp = URTW_VAP(vap);
1865 	struct ieee80211_node *ni;
1866 	usb_error_t error = 0;
1867 
1868 	DPRINTF(sc, URTW_DEBUG_STATE, "%s: %s -> %s\n", __func__,
1869 	    ieee80211_state_name[vap->iv_state],
1870 	    ieee80211_state_name[nstate]);
1871 
1872 	sc->sc_state = nstate;
1873 
1874 	IEEE80211_UNLOCK(ic);
1875 	URTW_LOCK(sc);
1876 	usb_callout_stop(&sc->sc_led_ch);
1877 	callout_stop(&sc->sc_watchdog_ch);
1878 
1879 	switch (nstate) {
1880 	case IEEE80211_S_INIT:
1881 	case IEEE80211_S_SCAN:
1882 	case IEEE80211_S_AUTH:
1883 	case IEEE80211_S_ASSOC:
1884 		break;
1885 	case IEEE80211_S_RUN:
1886 		ni = ieee80211_ref_node(vap->iv_bss);
1887 		/* setting bssid.  */
1888 		urtw_write32_m(sc, URTW_BSSID, ((uint32_t *)ni->ni_bssid)[0]);
1889 		urtw_write16_m(sc, URTW_BSSID + 4,
1890 		    ((uint16_t *)ni->ni_bssid)[2]);
1891 		urtw_update_msr(sc);
1892 		/* XXX maybe the below would be incorrect.  */
1893 		urtw_write16_m(sc, URTW_ATIM_WND, 2);
1894 		urtw_write16_m(sc, URTW_ATIM_TR_ITV, 100);
1895 		urtw_write16_m(sc, URTW_BEACON_INTERVAL, 0x64);
1896 		urtw_write16_m(sc, URTW_BEACON_INTERVAL_TIME, 100);
1897 		error = urtw_led_ctl(sc, URTW_LED_CTL_LINK);
1898 		if (error != 0)
1899 			device_printf(sc->sc_dev,
1900 			    "could not control LED (%d)\n", error);
1901 		ieee80211_free_node(ni);
1902 		break;
1903 	default:
1904 		break;
1905 	}
1906 fail:
1907 	URTW_UNLOCK(sc);
1908 	IEEE80211_LOCK(ic);
1909 	return (uvp->newstate(vap, nstate, arg));
1910 }
1911 
1912 static void
1913 urtw_watchdog(void *arg)
1914 {
1915 	struct urtw_softc *sc = arg;
1916 	struct ifnet *ifp = sc->sc_ifp;
1917 
1918 	if (sc->sc_txtimer > 0) {
1919 		if (--sc->sc_txtimer == 0) {
1920 			device_printf(sc->sc_dev, "device timeout\n");
1921 			ifp->if_oerrors++;
1922 			return;
1923 		}
1924 		callout_reset(&sc->sc_watchdog_ch, hz, urtw_watchdog, sc);
1925 	}
1926 }
1927 
1928 static void
1929 urtw_set_multi(void *arg)
1930 {
1931 	struct urtw_softc *sc = arg;
1932 	struct ifnet *ifp = sc->sc_ifp;
1933 
1934 	if (!(ifp->if_flags & IFF_UP))
1935 		return;
1936 
1937 	/*
1938 	 * XXX don't know how to set a device.  Lack of docs.  Just try to set
1939 	 * IFF_ALLMULTI flag here.
1940 	 */
1941 	ifp->if_flags |= IFF_ALLMULTI;
1942 }
1943 
1944 static usb_error_t
1945 urtw_set_rate(struct urtw_softc *sc)
1946 {
1947 	int i, basic_rate, min_rr_rate, max_rr_rate;
1948 	uint16_t data;
1949 	usb_error_t error;
1950 
1951 	basic_rate = urtw_rate2rtl(48);
1952 	min_rr_rate = urtw_rate2rtl(12);
1953 	max_rr_rate = urtw_rate2rtl(48);
1954 
1955 	urtw_write8_m(sc, URTW_RESP_RATE,
1956 	    max_rr_rate << URTW_RESP_MAX_RATE_SHIFT |
1957 	    min_rr_rate << URTW_RESP_MIN_RATE_SHIFT);
1958 
1959 	urtw_read16_m(sc, URTW_BRSR, &data);
1960 	data &= ~URTW_BRSR_MBR_8185;
1961 
1962 	for (i = 0; i <= basic_rate; i++)
1963 		data |= (1 << i);
1964 
1965 	urtw_write16_m(sc, URTW_BRSR, data);
1966 fail:
1967 	return (error);
1968 }
1969 
1970 static uint16_t
1971 urtw_rate2rtl(uint32_t rate)
1972 {
1973 #define N(a)	((int)(sizeof(a) / sizeof((a)[0])))
1974 	int i;
1975 
1976 	for (i = 0; i < N(urtw_ratetable); i++) {
1977 		if (rate == urtw_ratetable[i].reg)
1978 			return urtw_ratetable[i].val;
1979 	}
1980 
1981 	return (3);
1982 #undef N
1983 }
1984 
1985 static uint16_t
1986 urtw_rtl2rate(uint32_t rate)
1987 {
1988 #define N(a)	((int)(sizeof(a) / sizeof((a)[0])))
1989 	int i;
1990 
1991 	for (i = 0; i < N(urtw_ratetable); i++) {
1992 		if (rate == urtw_ratetable[i].val)
1993 			return urtw_ratetable[i].reg;
1994 	}
1995 
1996 	return (0);
1997 #undef N
1998 }
1999 
2000 static usb_error_t
2001 urtw_update_msr(struct urtw_softc *sc)
2002 {
2003 	struct ifnet *ifp = sc->sc_ifp;
2004 	struct ieee80211com *ic = ifp->if_l2com;
2005 	uint8_t data;
2006 	usb_error_t error;
2007 
2008 	urtw_read8_m(sc, URTW_MSR, &data);
2009 	data &= ~URTW_MSR_LINK_MASK;
2010 
2011 	if (sc->sc_state == IEEE80211_S_RUN) {
2012 		switch (ic->ic_opmode) {
2013 		case IEEE80211_M_STA:
2014 		case IEEE80211_M_MONITOR:
2015 			data |= URTW_MSR_LINK_STA;
2016 			if (sc->sc_flags & URTW_RTL8187B)
2017 				data |= URTW_MSR_LINK_ENEDCA;
2018 			break;
2019 		case IEEE80211_M_IBSS:
2020 			data |= URTW_MSR_LINK_ADHOC;
2021 			break;
2022 		case IEEE80211_M_HOSTAP:
2023 			data |= URTW_MSR_LINK_HOSTAP;
2024 			break;
2025 		default:
2026 			DPRINTF(sc, URTW_DEBUG_STATE,
2027 			    "unsupported operation mode 0x%x\n",
2028 			    ic->ic_opmode);
2029 			error = USB_ERR_INVAL;
2030 			goto fail;
2031 		}
2032 	} else
2033 		data |= URTW_MSR_LINK_NONE;
2034 
2035 	urtw_write8_m(sc, URTW_MSR, data);
2036 fail:
2037 	return (error);
2038 }
2039 
2040 static usb_error_t
2041 urtw_read8_c(struct urtw_softc *sc, int val, uint8_t *data)
2042 {
2043 	struct usb_device_request req;
2044 	usb_error_t error;
2045 
2046 	URTW_ASSERT_LOCKED(sc);
2047 
2048 	req.bmRequestType = UT_READ_VENDOR_DEVICE;
2049 	req.bRequest = URTW_8187_GETREGS_REQ;
2050 	USETW(req.wValue, (val & 0xff) | 0xff00);
2051 	USETW(req.wIndex, (val >> 8) & 0x3);
2052 	USETW(req.wLength, sizeof(uint8_t));
2053 
2054 	error = urtw_do_request(sc, &req, data);
2055 	return (error);
2056 }
2057 
2058 static usb_error_t
2059 urtw_read16_c(struct urtw_softc *sc, int val, uint16_t *data)
2060 {
2061 	struct usb_device_request req;
2062 	usb_error_t error;
2063 
2064 	URTW_ASSERT_LOCKED(sc);
2065 
2066 	req.bmRequestType = UT_READ_VENDOR_DEVICE;
2067 	req.bRequest = URTW_8187_GETREGS_REQ;
2068 	USETW(req.wValue, (val & 0xff) | 0xff00);
2069 	USETW(req.wIndex, (val >> 8) & 0x3);
2070 	USETW(req.wLength, sizeof(uint16_t));
2071 
2072 	error = urtw_do_request(sc, &req, data);
2073 	return (error);
2074 }
2075 
2076 static usb_error_t
2077 urtw_read32_c(struct urtw_softc *sc, int val, uint32_t *data)
2078 {
2079 	struct usb_device_request req;
2080 	usb_error_t error;
2081 
2082 	URTW_ASSERT_LOCKED(sc);
2083 
2084 	req.bmRequestType = UT_READ_VENDOR_DEVICE;
2085 	req.bRequest = URTW_8187_GETREGS_REQ;
2086 	USETW(req.wValue, (val & 0xff) | 0xff00);
2087 	USETW(req.wIndex, (val >> 8) & 0x3);
2088 	USETW(req.wLength, sizeof(uint32_t));
2089 
2090 	error = urtw_do_request(sc, &req, data);
2091 	return (error);
2092 }
2093 
2094 static usb_error_t
2095 urtw_write8_c(struct urtw_softc *sc, int val, uint8_t data)
2096 {
2097 	struct usb_device_request req;
2098 
2099 	URTW_ASSERT_LOCKED(sc);
2100 
2101 	req.bmRequestType = UT_WRITE_VENDOR_DEVICE;
2102 	req.bRequest = URTW_8187_SETREGS_REQ;
2103 	USETW(req.wValue, (val & 0xff) | 0xff00);
2104 	USETW(req.wIndex, (val >> 8) & 0x3);
2105 	USETW(req.wLength, sizeof(uint8_t));
2106 
2107 	return (urtw_do_request(sc, &req, &data));
2108 }
2109 
2110 static usb_error_t
2111 urtw_write16_c(struct urtw_softc *sc, int val, uint16_t data)
2112 {
2113 	struct usb_device_request req;
2114 
2115 	URTW_ASSERT_LOCKED(sc);
2116 
2117 	req.bmRequestType = UT_WRITE_VENDOR_DEVICE;
2118 	req.bRequest = URTW_8187_SETREGS_REQ;
2119 	USETW(req.wValue, (val & 0xff) | 0xff00);
2120 	USETW(req.wIndex, (val >> 8) & 0x3);
2121 	USETW(req.wLength, sizeof(uint16_t));
2122 
2123 	return (urtw_do_request(sc, &req, &data));
2124 }
2125 
2126 static usb_error_t
2127 urtw_write32_c(struct urtw_softc *sc, int val, uint32_t data)
2128 {
2129 	struct usb_device_request req;
2130 
2131 	URTW_ASSERT_LOCKED(sc);
2132 
2133 	req.bmRequestType = UT_WRITE_VENDOR_DEVICE;
2134 	req.bRequest = URTW_8187_SETREGS_REQ;
2135 	USETW(req.wValue, (val & 0xff) | 0xff00);
2136 	USETW(req.wIndex, (val >> 8) & 0x3);
2137 	USETW(req.wLength, sizeof(uint32_t));
2138 
2139 	return (urtw_do_request(sc, &req, &data));
2140 }
2141 
2142 static usb_error_t
2143 urtw_get_macaddr(struct urtw_softc *sc)
2144 {
2145 	uint32_t data;
2146 	usb_error_t error;
2147 
2148 	error = urtw_eprom_read32(sc, URTW_EPROM_MACADDR, &data);
2149 	if (error != 0)
2150 		goto fail;
2151 	sc->sc_bssid[0] = data & 0xff;
2152 	sc->sc_bssid[1] = (data & 0xff00) >> 8;
2153 	error = urtw_eprom_read32(sc, URTW_EPROM_MACADDR + 1, &data);
2154 	if (error != 0)
2155 		goto fail;
2156 	sc->sc_bssid[2] = data & 0xff;
2157 	sc->sc_bssid[3] = (data & 0xff00) >> 8;
2158 	error = urtw_eprom_read32(sc, URTW_EPROM_MACADDR + 2, &data);
2159 	if (error != 0)
2160 		goto fail;
2161 	sc->sc_bssid[4] = data & 0xff;
2162 	sc->sc_bssid[5] = (data & 0xff00) >> 8;
2163 fail:
2164 	return (error);
2165 }
2166 
2167 static usb_error_t
2168 urtw_eprom_read32(struct urtw_softc *sc, uint32_t addr, uint32_t *data)
2169 {
2170 #define URTW_READCMD_LEN		3
2171 	int addrlen, i;
2172 	int16_t addrstr[8], data16, readcmd[] = { 1, 1, 0 };
2173 	usb_error_t error;
2174 
2175 	/* NB: make sure the buffer is initialized  */
2176 	*data = 0;
2177 
2178 	/* enable EPROM programming */
2179 	urtw_write8_m(sc, URTW_EPROM_CMD, URTW_EPROM_CMD_PROGRAM_MODE);
2180 	DELAY(URTW_EPROM_DELAY);
2181 
2182 	error = urtw_eprom_cs(sc, URTW_EPROM_ENABLE);
2183 	if (error != 0)
2184 		goto fail;
2185 	error = urtw_eprom_ck(sc);
2186 	if (error != 0)
2187 		goto fail;
2188 	error = urtw_eprom_sendbits(sc, readcmd, URTW_READCMD_LEN);
2189 	if (error != 0)
2190 		goto fail;
2191 	if (sc->sc_epromtype == URTW_EEPROM_93C56) {
2192 		addrlen = 8;
2193 		addrstr[0] = addr & (1 << 7);
2194 		addrstr[1] = addr & (1 << 6);
2195 		addrstr[2] = addr & (1 << 5);
2196 		addrstr[3] = addr & (1 << 4);
2197 		addrstr[4] = addr & (1 << 3);
2198 		addrstr[5] = addr & (1 << 2);
2199 		addrstr[6] = addr & (1 << 1);
2200 		addrstr[7] = addr & (1 << 0);
2201 	} else {
2202 		addrlen=6;
2203 		addrstr[0] = addr & (1 << 5);
2204 		addrstr[1] = addr & (1 << 4);
2205 		addrstr[2] = addr & (1 << 3);
2206 		addrstr[3] = addr & (1 << 2);
2207 		addrstr[4] = addr & (1 << 1);
2208 		addrstr[5] = addr & (1 << 0);
2209 	}
2210 	error = urtw_eprom_sendbits(sc, addrstr, addrlen);
2211 	if (error != 0)
2212 		goto fail;
2213 
2214 	error = urtw_eprom_writebit(sc, 0);
2215 	if (error != 0)
2216 		goto fail;
2217 
2218 	for (i = 0; i < 16; i++) {
2219 		error = urtw_eprom_ck(sc);
2220 		if (error != 0)
2221 			goto fail;
2222 		error = urtw_eprom_readbit(sc, &data16);
2223 		if (error != 0)
2224 			goto fail;
2225 
2226 		(*data) |= (data16 << (15 - i));
2227 	}
2228 
2229 	error = urtw_eprom_cs(sc, URTW_EPROM_DISABLE);
2230 	if (error != 0)
2231 		goto fail;
2232 	error = urtw_eprom_ck(sc);
2233 	if (error != 0)
2234 		goto fail;
2235 
2236 	/* now disable EPROM programming */
2237 	urtw_write8_m(sc, URTW_EPROM_CMD, URTW_EPROM_CMD_NORMAL_MODE);
2238 fail:
2239 	return (error);
2240 #undef URTW_READCMD_LEN
2241 }
2242 
2243 static usb_error_t
2244 urtw_eprom_cs(struct urtw_softc *sc, int able)
2245 {
2246 	uint8_t data;
2247 	usb_error_t error;
2248 
2249 	urtw_read8_m(sc, URTW_EPROM_CMD, &data);
2250 	if (able == URTW_EPROM_ENABLE)
2251 		urtw_write8_m(sc, URTW_EPROM_CMD, data | URTW_EPROM_CS);
2252 	else
2253 		urtw_write8_m(sc, URTW_EPROM_CMD, data & ~URTW_EPROM_CS);
2254 	DELAY(URTW_EPROM_DELAY);
2255 fail:
2256 	return (error);
2257 }
2258 
2259 static usb_error_t
2260 urtw_eprom_ck(struct urtw_softc *sc)
2261 {
2262 	uint8_t data;
2263 	usb_error_t error;
2264 
2265 	/* masking  */
2266 	urtw_read8_m(sc, URTW_EPROM_CMD, &data);
2267 	urtw_write8_m(sc, URTW_EPROM_CMD, data | URTW_EPROM_CK);
2268 	DELAY(URTW_EPROM_DELAY);
2269 	/* unmasking  */
2270 	urtw_read8_m(sc, URTW_EPROM_CMD, &data);
2271 	urtw_write8_m(sc, URTW_EPROM_CMD, data & ~URTW_EPROM_CK);
2272 	DELAY(URTW_EPROM_DELAY);
2273 fail:
2274 	return (error);
2275 }
2276 
2277 static usb_error_t
2278 urtw_eprom_readbit(struct urtw_softc *sc, int16_t *data)
2279 {
2280 	uint8_t data8;
2281 	usb_error_t error;
2282 
2283 	urtw_read8_m(sc, URTW_EPROM_CMD, &data8);
2284 	*data = (data8 & URTW_EPROM_READBIT) ? 1 : 0;
2285 	DELAY(URTW_EPROM_DELAY);
2286 
2287 fail:
2288 	return (error);
2289 }
2290 
2291 static usb_error_t
2292 urtw_eprom_writebit(struct urtw_softc *sc, int16_t bit)
2293 {
2294 	uint8_t data;
2295 	usb_error_t error;
2296 
2297 	urtw_read8_m(sc, URTW_EPROM_CMD, &data);
2298 	if (bit != 0)
2299 		urtw_write8_m(sc, URTW_EPROM_CMD, data | URTW_EPROM_WRITEBIT);
2300 	else
2301 		urtw_write8_m(sc, URTW_EPROM_CMD, data & ~URTW_EPROM_WRITEBIT);
2302 	DELAY(URTW_EPROM_DELAY);
2303 fail:
2304 	return (error);
2305 }
2306 
2307 static usb_error_t
2308 urtw_eprom_sendbits(struct urtw_softc *sc, int16_t *buf, int buflen)
2309 {
2310 	int i = 0;
2311 	usb_error_t error = 0;
2312 
2313 	for (i = 0; i < buflen; i++) {
2314 		error = urtw_eprom_writebit(sc, buf[i]);
2315 		if (error != 0)
2316 			goto fail;
2317 		error = urtw_eprom_ck(sc);
2318 		if (error != 0)
2319 			goto fail;
2320 	}
2321 fail:
2322 	return (error);
2323 }
2324 
2325 
2326 static usb_error_t
2327 urtw_get_txpwr(struct urtw_softc *sc)
2328 {
2329 	int i, j;
2330 	uint32_t data;
2331 	usb_error_t error;
2332 
2333 	error = urtw_eprom_read32(sc, URTW_EPROM_TXPW_BASE, &data);
2334 	if (error != 0)
2335 		goto fail;
2336 	sc->sc_txpwr_cck_base = data & 0xf;
2337 	sc->sc_txpwr_ofdm_base = (data >> 4) & 0xf;
2338 
2339 	for (i = 1, j = 0; i < 6; i += 2, j++) {
2340 		error = urtw_eprom_read32(sc, URTW_EPROM_TXPW0 + j, &data);
2341 		if (error != 0)
2342 			goto fail;
2343 		sc->sc_txpwr_cck[i] = data & 0xf;
2344 		sc->sc_txpwr_cck[i + 1] = (data & 0xf00) >> 8;
2345 		sc->sc_txpwr_ofdm[i] = (data & 0xf0) >> 4;
2346 		sc->sc_txpwr_ofdm[i + 1] = (data & 0xf000) >> 12;
2347 	}
2348 	for (i = 1, j = 0; i < 4; i += 2, j++) {
2349 		error = urtw_eprom_read32(sc, URTW_EPROM_TXPW1 + j, &data);
2350 		if (error != 0)
2351 			goto fail;
2352 		sc->sc_txpwr_cck[i + 6] = data & 0xf;
2353 		sc->sc_txpwr_cck[i + 6 + 1] = (data & 0xf00) >> 8;
2354 		sc->sc_txpwr_ofdm[i + 6] = (data & 0xf0) >> 4;
2355 		sc->sc_txpwr_ofdm[i + 6 + 1] = (data & 0xf000) >> 12;
2356 	}
2357 	if (sc->sc_flags & URTW_RTL8187B) {
2358 		error = urtw_eprom_read32(sc, URTW_EPROM_TXPW2, &data);
2359 		if (error != 0)
2360 			goto fail;
2361 		sc->sc_txpwr_cck[1 + 6 + 4] = data & 0xf;
2362 		sc->sc_txpwr_ofdm[1 + 6 + 4] = (data & 0xf0) >> 4;
2363 		error = urtw_eprom_read32(sc, 0x0a, &data);
2364 		if (error != 0)
2365 			goto fail;
2366 		sc->sc_txpwr_cck[2 + 6 + 4] = data & 0xf;
2367 		sc->sc_txpwr_ofdm[2 + 6 + 4] = (data & 0xf0) >> 4;
2368 		error = urtw_eprom_read32(sc, 0x1c, &data);
2369 		if (error != 0)
2370 			goto fail;
2371 		sc->sc_txpwr_cck[3 + 6 + 4] = data & 0xf;
2372 		sc->sc_txpwr_cck[3 + 6 + 4 + 1] = (data & 0xf00) >> 8;
2373 		sc->sc_txpwr_ofdm[3 + 6 + 4] = (data & 0xf0) >> 4;
2374 		sc->sc_txpwr_ofdm[3 + 6 + 4 + 1] = (data & 0xf000) >> 12;
2375 	} else {
2376 		for (i = 1, j = 0; i < 4; i += 2, j++) {
2377 			error = urtw_eprom_read32(sc, URTW_EPROM_TXPW2 + j,
2378 			    &data);
2379 			if (error != 0)
2380 				goto fail;
2381 			sc->sc_txpwr_cck[i + 6 + 4] = data & 0xf;
2382 			sc->sc_txpwr_cck[i + 6 + 4 + 1] = (data & 0xf00) >> 8;
2383 			sc->sc_txpwr_ofdm[i + 6 + 4] = (data & 0xf0) >> 4;
2384 			sc->sc_txpwr_ofdm[i + 6 + 4 + 1] = (data & 0xf000) >> 12;
2385 		}
2386 	}
2387 fail:
2388 	return (error);
2389 }
2390 
2391 
2392 static usb_error_t
2393 urtw_get_rfchip(struct urtw_softc *sc)
2394 {
2395 	int ret;
2396 	uint8_t data8;
2397 	uint32_t data;
2398 	usb_error_t error;
2399 
2400 	if (sc->sc_flags & URTW_RTL8187B) {
2401 		urtw_read8_m(sc, 0xe1, &data8);
2402 		switch (data8) {
2403 		case 0:
2404 			sc->sc_flags |= URTW_RTL8187B_REV_B;
2405 			break;
2406 		case 1:
2407 			sc->sc_flags |= URTW_RTL8187B_REV_D;
2408 			break;
2409 		case 2:
2410 			sc->sc_flags |= URTW_RTL8187B_REV_E;
2411 			break;
2412 		default:
2413 			device_printf(sc->sc_dev, "unknown type: %#x\n", data8);
2414 			sc->sc_flags |= URTW_RTL8187B_REV_B;
2415 			break;
2416 		}
2417 	} else {
2418 		urtw_read32_m(sc, URTW_TX_CONF, &data);
2419 		switch (data & URTW_TX_HWMASK) {
2420 		case URTW_TX_R8187vD_B:
2421 			sc->sc_flags |= URTW_RTL8187B;
2422 			break;
2423 		case URTW_TX_R8187vD:
2424 			break;
2425 		default:
2426 			device_printf(sc->sc_dev, "unknown RTL8187L type: %#x\n",
2427 			    data & URTW_TX_HWMASK);
2428 			break;
2429 		}
2430 	}
2431 
2432 	error = urtw_eprom_read32(sc, URTW_EPROM_RFCHIPID, &data);
2433 	if (error != 0)
2434 		goto fail;
2435 	switch (data & 0xff) {
2436 	case URTW_EPROM_RFCHIPID_RTL8225U:
2437 		error = urtw_8225_isv2(sc, &ret);
2438 		if (error != 0)
2439 			goto fail;
2440 		if (ret == 0) {
2441 			sc->sc_rf_init = urtw_8225_rf_init;
2442 			sc->sc_rf_set_sens = urtw_8225_rf_set_sens;
2443 			sc->sc_rf_set_chan = urtw_8225_rf_set_chan;
2444 			sc->sc_rf_stop = urtw_8225_rf_stop;
2445 		} else {
2446 			sc->sc_rf_init = urtw_8225v2_rf_init;
2447 			sc->sc_rf_set_chan = urtw_8225v2_rf_set_chan;
2448 			sc->sc_rf_stop = urtw_8225_rf_stop;
2449 		}
2450 		sc->sc_max_sens = URTW_8225_RF_MAX_SENS;
2451 		sc->sc_sens = URTW_8225_RF_DEF_SENS;
2452 		break;
2453 	case URTW_EPROM_RFCHIPID_RTL8225Z2:
2454 		sc->sc_rf_init = urtw_8225v2b_rf_init;
2455 		sc->sc_rf_set_chan = urtw_8225v2b_rf_set_chan;
2456 		sc->sc_max_sens = URTW_8225_RF_MAX_SENS;
2457 		sc->sc_sens = URTW_8225_RF_DEF_SENS;
2458 		sc->sc_rf_stop = urtw_8225_rf_stop;
2459 		break;
2460 	default:
2461 		DPRINTF(sc, URTW_DEBUG_STATE,
2462 		    "unsupported RF chip %d\n", data & 0xff);
2463 		error = USB_ERR_INVAL;
2464 		goto fail;
2465 	}
2466 
2467 	device_printf(sc->sc_dev, "%s rf %s hwrev %s\n",
2468 	    (sc->sc_flags & URTW_RTL8187B) ? "rtl8187b" : "rtl8187l",
2469 	    ((data & 0xff) == URTW_EPROM_RFCHIPID_RTL8225U) ? "rtl8225u" :
2470 	    "rtl8225z2",
2471 	    (sc->sc_flags & URTW_RTL8187B) ? ((data8 == 0) ? "b" :
2472 		(data8 == 1) ? "d" : "e") : "none");
2473 
2474 fail:
2475 	return (error);
2476 }
2477 
2478 
2479 static usb_error_t
2480 urtw_led_init(struct urtw_softc *sc)
2481 {
2482 	uint32_t rev;
2483 	usb_error_t error;
2484 
2485 	urtw_read8_m(sc, URTW_PSR, &sc->sc_psr);
2486 	error = urtw_eprom_read32(sc, URTW_EPROM_SWREV, &rev);
2487 	if (error != 0)
2488 		goto fail;
2489 
2490 	switch (rev & URTW_EPROM_CID_MASK) {
2491 	case URTW_EPROM_CID_ALPHA0:
2492 		sc->sc_strategy = URTW_SW_LED_MODE1;
2493 		break;
2494 	case URTW_EPROM_CID_SERCOMM_PS:
2495 		sc->sc_strategy = URTW_SW_LED_MODE3;
2496 		break;
2497 	case URTW_EPROM_CID_HW_LED:
2498 		sc->sc_strategy = URTW_HW_LED;
2499 		break;
2500 	case URTW_EPROM_CID_RSVD0:
2501 	case URTW_EPROM_CID_RSVD1:
2502 	default:
2503 		sc->sc_strategy = URTW_SW_LED_MODE0;
2504 		break;
2505 	}
2506 
2507 	sc->sc_gpio_ledpin = URTW_LED_PIN_GPIO0;
2508 
2509 fail:
2510 	return (error);
2511 }
2512 
2513 
2514 static usb_error_t
2515 urtw_8225_rf_init(struct urtw_softc *sc)
2516 {
2517 #define N(a)	((int)(sizeof(a) / sizeof((a)[0])))
2518 	int i;
2519 	uint16_t data;
2520 	usb_error_t error;
2521 
2522 	error = urtw_8180_set_anaparam(sc, URTW_8225_ANAPARAM_ON);
2523 	if (error)
2524 		goto fail;
2525 
2526 	error = urtw_8225_usb_init(sc);
2527 	if (error)
2528 		goto fail;
2529 
2530 	urtw_write32_m(sc, URTW_RF_TIMING, 0x000a8008);
2531 	urtw_read16_m(sc, URTW_BRSR, &data);		/* XXX ??? */
2532 	urtw_write16_m(sc, URTW_BRSR, 0xffff);
2533 	urtw_write32_m(sc, URTW_RF_PARA, 0x100044);
2534 
2535 	error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG);
2536 	if (error)
2537 		goto fail;
2538 	urtw_write8_m(sc, URTW_CONFIG3, 0x44);
2539 	error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL);
2540 	if (error)
2541 		goto fail;
2542 
2543 	error = urtw_8185_rf_pins_enable(sc);
2544 	if (error)
2545 		goto fail;
2546 	usb_pause_mtx(&sc->sc_mtx, 1000);
2547 
2548 	for (i = 0; i < N(urtw_8225_rf_part1); i++) {
2549 		urtw_8225_write(sc, urtw_8225_rf_part1[i].reg,
2550 		    urtw_8225_rf_part1[i].val);
2551 		usb_pause_mtx(&sc->sc_mtx, 1);
2552 	}
2553 	usb_pause_mtx(&sc->sc_mtx, 100);
2554 	urtw_8225_write(sc,
2555 	    URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC1);
2556 	usb_pause_mtx(&sc->sc_mtx, 200);
2557 	urtw_8225_write(sc,
2558 	    URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC2);
2559 	usb_pause_mtx(&sc->sc_mtx, 200);
2560 	urtw_8225_write(sc,
2561 	    URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC3);
2562 
2563 	for (i = 0; i < 95; i++) {
2564 		urtw_8225_write(sc, URTW_8225_ADDR_1_MAGIC, (uint8_t)(i + 1));
2565 		urtw_8225_write(sc, URTW_8225_ADDR_2_MAGIC, urtw_8225_rxgain[i]);
2566 	}
2567 
2568 	urtw_8225_write(sc,
2569 	    URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC4);
2570 	urtw_8225_write(sc,
2571 	    URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC5);
2572 
2573 	for (i = 0; i < 128; i++) {
2574 		urtw_8187_write_phy_ofdm(sc, 0xb, urtw_8225_agc[i]);
2575 		usb_pause_mtx(&sc->sc_mtx, 1);
2576 		urtw_8187_write_phy_ofdm(sc, 0xa, (uint8_t)i + 0x80);
2577 		usb_pause_mtx(&sc->sc_mtx, 1);
2578 	}
2579 
2580 	for (i = 0; i < N(urtw_8225_rf_part2); i++) {
2581 		urtw_8187_write_phy_ofdm(sc, urtw_8225_rf_part2[i].reg,
2582 		    urtw_8225_rf_part2[i].val);
2583 		usb_pause_mtx(&sc->sc_mtx, 1);
2584 	}
2585 
2586 	error = urtw_8225_setgain(sc, 4);
2587 	if (error)
2588 		goto fail;
2589 
2590 	for (i = 0; i < N(urtw_8225_rf_part3); i++) {
2591 		urtw_8187_write_phy_cck(sc, urtw_8225_rf_part3[i].reg,
2592 		    urtw_8225_rf_part3[i].val);
2593 		usb_pause_mtx(&sc->sc_mtx, 1);
2594 	}
2595 
2596 	urtw_write8_m(sc, URTW_TESTR, 0x0d);
2597 
2598 	error = urtw_8225_set_txpwrlvl(sc, 1);
2599 	if (error)
2600 		goto fail;
2601 
2602 	urtw_8187_write_phy_cck(sc, 0x10, 0x9b);
2603 	usb_pause_mtx(&sc->sc_mtx, 1);
2604 	urtw_8187_write_phy_ofdm(sc, 0x26, 0x90);
2605 	usb_pause_mtx(&sc->sc_mtx, 1);
2606 
2607 	/* TX ant A, 0x0 for B */
2608 	error = urtw_8185_tx_antenna(sc, 0x3);
2609 	if (error)
2610 		goto fail;
2611 	urtw_write32_m(sc, URTW_HSSI_PARA, 0x3dc00002);
2612 
2613 	error = urtw_8225_rf_set_chan(sc, 1);
2614 fail:
2615 	return (error);
2616 #undef N
2617 }
2618 
2619 static usb_error_t
2620 urtw_8185_rf_pins_enable(struct urtw_softc *sc)
2621 {
2622 	usb_error_t error = 0;
2623 
2624 	urtw_write16_m(sc, URTW_RF_PINS_ENABLE, 0x1ff7);
2625 fail:
2626 	return (error);
2627 }
2628 
2629 static usb_error_t
2630 urtw_8185_tx_antenna(struct urtw_softc *sc, uint8_t ant)
2631 {
2632 	usb_error_t error;
2633 
2634 	urtw_write8_m(sc, URTW_TX_ANTENNA, ant);
2635 	usb_pause_mtx(&sc->sc_mtx, 1);
2636 fail:
2637 	return (error);
2638 }
2639 
2640 static usb_error_t
2641 urtw_8187_write_phy_ofdm_c(struct urtw_softc *sc, uint8_t addr, uint32_t data)
2642 {
2643 
2644 	data = data & 0xff;
2645 	return urtw_8187_write_phy(sc, addr, data);
2646 }
2647 
2648 static usb_error_t
2649 urtw_8187_write_phy_cck_c(struct urtw_softc *sc, uint8_t addr, uint32_t data)
2650 {
2651 
2652 	data = data & 0xff;
2653 	return urtw_8187_write_phy(sc, addr, data | 0x10000);
2654 }
2655 
2656 static usb_error_t
2657 urtw_8187_write_phy(struct urtw_softc *sc, uint8_t addr, uint32_t data)
2658 {
2659 	uint32_t phyw;
2660 	usb_error_t error;
2661 
2662 	phyw = ((data << 8) | (addr | 0x80));
2663 	urtw_write8_m(sc, URTW_PHY_MAGIC4, ((phyw & 0xff000000) >> 24));
2664 	urtw_write8_m(sc, URTW_PHY_MAGIC3, ((phyw & 0x00ff0000) >> 16));
2665 	urtw_write8_m(sc, URTW_PHY_MAGIC2, ((phyw & 0x0000ff00) >> 8));
2666 	urtw_write8_m(sc, URTW_PHY_MAGIC1, ((phyw & 0x000000ff)));
2667 	usb_pause_mtx(&sc->sc_mtx, 1);
2668 fail:
2669 	return (error);
2670 }
2671 
2672 static usb_error_t
2673 urtw_8225_setgain(struct urtw_softc *sc, int16_t gain)
2674 {
2675 	usb_error_t error;
2676 
2677 	urtw_8187_write_phy_ofdm(sc, 0x0d, urtw_8225_gain[gain * 4]);
2678 	urtw_8187_write_phy_ofdm(sc, 0x1b, urtw_8225_gain[gain * 4 + 2]);
2679 	urtw_8187_write_phy_ofdm(sc, 0x1d, urtw_8225_gain[gain * 4 + 3]);
2680 	urtw_8187_write_phy_ofdm(sc, 0x23, urtw_8225_gain[gain * 4 + 1]);
2681 fail:
2682 	return (error);
2683 }
2684 
2685 static usb_error_t
2686 urtw_8225_usb_init(struct urtw_softc *sc)
2687 {
2688 	uint8_t data;
2689 	usb_error_t error;
2690 
2691 	urtw_write8_m(sc, URTW_RF_PINS_SELECT + 1, 0);
2692 	urtw_write8_m(sc, URTW_GPIO, 0);
2693 	error = urtw_read8e(sc, 0x53, &data);
2694 	if (error)
2695 		goto fail;
2696 	error = urtw_write8e(sc, 0x53, data | (1 << 7));
2697 	if (error)
2698 		goto fail;
2699 	urtw_write8_m(sc, URTW_RF_PINS_SELECT + 1, 4);
2700 	urtw_write8_m(sc, URTW_GPIO, 0x20);
2701 	urtw_write8_m(sc, URTW_GP_ENABLE, 0);
2702 
2703 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, 0x80);
2704 	urtw_write16_m(sc, URTW_RF_PINS_SELECT, 0x80);
2705 	urtw_write16_m(sc, URTW_RF_PINS_ENABLE, 0x80);
2706 
2707 	usb_pause_mtx(&sc->sc_mtx, 500);
2708 fail:
2709 	return (error);
2710 }
2711 
2712 static usb_error_t
2713 urtw_8225_write_c(struct urtw_softc *sc, uint8_t addr, uint16_t data)
2714 {
2715 	uint16_t d80, d82, d84;
2716 	usb_error_t error;
2717 
2718 	urtw_read16_m(sc, URTW_RF_PINS_OUTPUT, &d80);
2719 	d80 &= URTW_RF_PINS_MAGIC1;
2720 	urtw_read16_m(sc, URTW_RF_PINS_ENABLE, &d82);
2721 	urtw_read16_m(sc, URTW_RF_PINS_SELECT, &d84);
2722 	d84 &= URTW_RF_PINS_MAGIC2;
2723 	urtw_write16_m(sc, URTW_RF_PINS_ENABLE, d82 | URTW_RF_PINS_MAGIC3);
2724 	urtw_write16_m(sc, URTW_RF_PINS_SELECT, d84 | URTW_RF_PINS_MAGIC3);
2725 	DELAY(10);
2726 
2727 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, d80 | URTW_BB_HOST_BANG_EN);
2728 	DELAY(2);
2729 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, d80);
2730 	DELAY(10);
2731 
2732 	error = urtw_8225_write_s16(sc, addr, 0x8225, &data);
2733 	if (error != 0)
2734 		goto fail;
2735 
2736 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, d80 | URTW_BB_HOST_BANG_EN);
2737 	DELAY(10);
2738 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, d80 | URTW_BB_HOST_BANG_EN);
2739 	urtw_write16_m(sc, URTW_RF_PINS_SELECT, d84);
2740 	usb_pause_mtx(&sc->sc_mtx, 2);
2741 fail:
2742 	return (error);
2743 }
2744 
2745 static usb_error_t
2746 urtw_8225_write_s16(struct urtw_softc *sc, uint8_t addr, int index,
2747     uint16_t *data)
2748 {
2749 	uint8_t buf[2];
2750 	uint16_t data16;
2751 	struct usb_device_request req;
2752 	usb_error_t error = 0;
2753 
2754 	data16 = *data;
2755 
2756 	req.bmRequestType = UT_WRITE_VENDOR_DEVICE;
2757 	req.bRequest = URTW_8187_SETREGS_REQ;
2758 	USETW(req.wValue, addr);
2759 	USETW(req.wIndex, index);
2760 	USETW(req.wLength, sizeof(uint16_t));
2761 	buf[0] = (data16 & 0x00ff);
2762 	buf[1] = (data16 & 0xff00) >> 8;
2763 
2764 	error = urtw_do_request(sc, &req, buf);
2765 
2766 	return (error);
2767 }
2768 
2769 static usb_error_t
2770 urtw_8225_rf_set_chan(struct urtw_softc *sc, int chan)
2771 {
2772 	usb_error_t error;
2773 
2774 	error = urtw_8225_set_txpwrlvl(sc, chan);
2775 	if (error)
2776 		goto fail;
2777 	urtw_8225_write(sc, URTW_8225_ADDR_7_MAGIC, urtw_8225_channel[chan]);
2778 	usb_pause_mtx(&sc->sc_mtx, 10);
2779 fail:
2780 	return (error);
2781 }
2782 
2783 static usb_error_t
2784 urtw_8225_rf_set_sens(struct urtw_softc *sc, int sens)
2785 {
2786 	usb_error_t error;
2787 
2788 	if (sens < 0 || sens > 6)
2789 		return -1;
2790 
2791 	if (sens > 4)
2792 		urtw_8225_write(sc,
2793 		    URTW_8225_ADDR_C_MAGIC, URTW_8225_ADDR_C_DATA_MAGIC1);
2794 	else
2795 		urtw_8225_write(sc,
2796 		    URTW_8225_ADDR_C_MAGIC, URTW_8225_ADDR_C_DATA_MAGIC2);
2797 
2798 	sens = 6 - sens;
2799 	error = urtw_8225_setgain(sc, sens);
2800 	if (error)
2801 		goto fail;
2802 
2803 	urtw_8187_write_phy_cck(sc, 0x41, urtw_8225_threshold[sens]);
2804 
2805 fail:
2806 	return (error);
2807 }
2808 
2809 static usb_error_t
2810 urtw_8225_set_txpwrlvl(struct urtw_softc *sc, int chan)
2811 {
2812 	int i, idx, set;
2813 	uint8_t *cck_pwltable;
2814 	uint8_t cck_pwrlvl_max, ofdm_pwrlvl_min, ofdm_pwrlvl_max;
2815 	uint8_t cck_pwrlvl = sc->sc_txpwr_cck[chan] & 0xff;
2816 	uint8_t ofdm_pwrlvl = sc->sc_txpwr_ofdm[chan] & 0xff;
2817 	usb_error_t error;
2818 
2819 	cck_pwrlvl_max = 11;
2820 	ofdm_pwrlvl_max = 25;	/* 12 -> 25  */
2821 	ofdm_pwrlvl_min = 10;
2822 
2823 	/* CCK power setting */
2824 	cck_pwrlvl = (cck_pwrlvl > cck_pwrlvl_max) ? cck_pwrlvl_max : cck_pwrlvl;
2825 	idx = cck_pwrlvl % 6;
2826 	set = cck_pwrlvl / 6;
2827 	cck_pwltable = (chan == 14) ? urtw_8225_txpwr_cck_ch14 :
2828 	    urtw_8225_txpwr_cck;
2829 
2830 	urtw_write8_m(sc, URTW_TX_GAIN_CCK,
2831 	    urtw_8225_tx_gain_cck_ofdm[set] >> 1);
2832 	for (i = 0; i < 8; i++) {
2833 		urtw_8187_write_phy_cck(sc, 0x44 + i,
2834 		    cck_pwltable[idx * 8 + i]);
2835 	}
2836 	usb_pause_mtx(&sc->sc_mtx, 1);
2837 
2838 	/* OFDM power setting */
2839 	ofdm_pwrlvl = (ofdm_pwrlvl > (ofdm_pwrlvl_max - ofdm_pwrlvl_min)) ?
2840 	    ofdm_pwrlvl_max : ofdm_pwrlvl + ofdm_pwrlvl_min;
2841 	ofdm_pwrlvl = (ofdm_pwrlvl > 35) ? 35 : ofdm_pwrlvl;
2842 
2843 	idx = ofdm_pwrlvl % 6;
2844 	set = ofdm_pwrlvl / 6;
2845 
2846 	error = urtw_8185_set_anaparam2(sc, URTW_8225_ANAPARAM2_ON);
2847 	if (error)
2848 		goto fail;
2849 	urtw_8187_write_phy_ofdm(sc, 2, 0x42);
2850 	urtw_8187_write_phy_ofdm(sc, 6, 0);
2851 	urtw_8187_write_phy_ofdm(sc, 8, 0);
2852 
2853 	urtw_write8_m(sc, URTW_TX_GAIN_OFDM,
2854 	    urtw_8225_tx_gain_cck_ofdm[set] >> 1);
2855 	urtw_8187_write_phy_ofdm(sc, 0x5, urtw_8225_txpwr_ofdm[idx]);
2856 	urtw_8187_write_phy_ofdm(sc, 0x7, urtw_8225_txpwr_ofdm[idx]);
2857 	usb_pause_mtx(&sc->sc_mtx, 1);
2858 fail:
2859 	return (error);
2860 }
2861 
2862 
2863 static usb_error_t
2864 urtw_8225_rf_stop(struct urtw_softc *sc)
2865 {
2866 	uint8_t data;
2867 	usb_error_t error;
2868 
2869 	urtw_8225_write(sc, 0x4, 0x1f);
2870 
2871 	error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG);
2872 	if (error)
2873 		goto fail;
2874 
2875 	urtw_read8_m(sc, URTW_CONFIG3, &data);
2876 	urtw_write8_m(sc, URTW_CONFIG3, data | URTW_CONFIG3_ANAPARAM_WRITE);
2877 	if (sc->sc_flags & URTW_RTL8187B) {
2878 		urtw_write32_m(sc, URTW_ANAPARAM2,
2879 		    URTW_8187B_8225_ANAPARAM2_OFF);
2880 		urtw_write32_m(sc, URTW_ANAPARAM, URTW_8187B_8225_ANAPARAM_OFF);
2881 		urtw_write32_m(sc, URTW_ANAPARAM3,
2882 		    URTW_8187B_8225_ANAPARAM3_OFF);
2883 	} else {
2884 		urtw_write32_m(sc, URTW_ANAPARAM2, URTW_8225_ANAPARAM2_OFF);
2885 		urtw_write32_m(sc, URTW_ANAPARAM, URTW_8225_ANAPARAM_OFF);
2886 	}
2887 
2888 	urtw_write8_m(sc, URTW_CONFIG3, data & ~URTW_CONFIG3_ANAPARAM_WRITE);
2889 	error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL);
2890 	if (error)
2891 		goto fail;
2892 
2893 fail:
2894 	return (error);
2895 }
2896 
2897 static usb_error_t
2898 urtw_8225v2_rf_init(struct urtw_softc *sc)
2899 {
2900 #define N(a)	((int)(sizeof(a) / sizeof((a)[0])))
2901 	int i;
2902 	uint16_t data;
2903 	uint32_t data32;
2904 	usb_error_t error;
2905 
2906 	error = urtw_8180_set_anaparam(sc, URTW_8225_ANAPARAM_ON);
2907 	if (error)
2908 		goto fail;
2909 
2910 	error = urtw_8225_usb_init(sc);
2911 	if (error)
2912 		goto fail;
2913 
2914 	urtw_write32_m(sc, URTW_RF_TIMING, 0x000a8008);
2915 	urtw_read16_m(sc, URTW_BRSR, &data);		/* XXX ??? */
2916 	urtw_write16_m(sc, URTW_BRSR, 0xffff);
2917 	urtw_write32_m(sc, URTW_RF_PARA, 0x100044);
2918 
2919 	error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG);
2920 	if (error)
2921 		goto fail;
2922 	urtw_write8_m(sc, URTW_CONFIG3, 0x44);
2923 	error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL);
2924 	if (error)
2925 		goto fail;
2926 
2927 	error = urtw_8185_rf_pins_enable(sc);
2928 	if (error)
2929 		goto fail;
2930 
2931 	usb_pause_mtx(&sc->sc_mtx, 500);
2932 
2933 	for (i = 0; i < N(urtw_8225v2_rf_part1); i++) {
2934 		urtw_8225_write(sc, urtw_8225v2_rf_part1[i].reg,
2935 		    urtw_8225v2_rf_part1[i].val);
2936 	}
2937 	usb_pause_mtx(&sc->sc_mtx, 50);
2938 
2939 	urtw_8225_write(sc,
2940 	    URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC1);
2941 
2942 	for (i = 0; i < 95; i++) {
2943 		urtw_8225_write(sc, URTW_8225_ADDR_1_MAGIC, (uint8_t)(i + 1));
2944 		urtw_8225_write(sc, URTW_8225_ADDR_2_MAGIC,
2945 		    urtw_8225v2_rxgain[i]);
2946 	}
2947 
2948 	urtw_8225_write(sc,
2949 	    URTW_8225_ADDR_3_MAGIC, URTW_8225_ADDR_3_DATA_MAGIC1);
2950 	urtw_8225_write(sc,
2951 	    URTW_8225_ADDR_5_MAGIC, URTW_8225_ADDR_5_DATA_MAGIC1);
2952 	urtw_8225_write(sc,
2953 	    URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC2);
2954 	urtw_8225_write(sc,
2955 	    URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC1);
2956 	usb_pause_mtx(&sc->sc_mtx, 100);
2957 	urtw_8225_write(sc,
2958 	    URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC2);
2959 	usb_pause_mtx(&sc->sc_mtx, 100);
2960 
2961 	error = urtw_8225_read(sc, URTW_8225_ADDR_6_MAGIC, &data32);
2962 	if (error != 0)
2963 		goto fail;
2964 	if (data32 != URTW_8225_ADDR_6_DATA_MAGIC1)
2965 		device_printf(sc->sc_dev, "expect 0xe6!! (0x%x)\n", data32);
2966 	if (!(data32 & URTW_8225_ADDR_6_DATA_MAGIC2)) {
2967 		urtw_8225_write(sc,
2968 		    URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC1);
2969 		usb_pause_mtx(&sc->sc_mtx, 100);
2970 		urtw_8225_write(sc,
2971 		    URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC2);
2972 		usb_pause_mtx(&sc->sc_mtx, 50);
2973 		error = urtw_8225_read(sc, URTW_8225_ADDR_6_MAGIC, &data32);
2974 		if (error != 0)
2975 			goto fail;
2976 		if (!(data32 & URTW_8225_ADDR_6_DATA_MAGIC2))
2977 			device_printf(sc->sc_dev, "RF calibration failed\n");
2978 	}
2979 	usb_pause_mtx(&sc->sc_mtx, 100);
2980 
2981 	urtw_8225_write(sc,
2982 	    URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC6);
2983 	for (i = 0; i < 128; i++) {
2984 		urtw_8187_write_phy_ofdm(sc, 0xb, urtw_8225_agc[i]);
2985 		urtw_8187_write_phy_ofdm(sc, 0xa, (uint8_t)i + 0x80);
2986 	}
2987 
2988 	for (i = 0; i < N(urtw_8225v2_rf_part2); i++) {
2989 		urtw_8187_write_phy_ofdm(sc, urtw_8225v2_rf_part2[i].reg,
2990 		    urtw_8225v2_rf_part2[i].val);
2991 	}
2992 
2993 	error = urtw_8225v2_setgain(sc, 4);
2994 	if (error)
2995 		goto fail;
2996 
2997 	for (i = 0; i < N(urtw_8225v2_rf_part3); i++) {
2998 		urtw_8187_write_phy_cck(sc, urtw_8225v2_rf_part3[i].reg,
2999 		    urtw_8225v2_rf_part3[i].val);
3000 	}
3001 
3002 	urtw_write8_m(sc, URTW_TESTR, 0x0d);
3003 
3004 	error = urtw_8225v2_set_txpwrlvl(sc, 1);
3005 	if (error)
3006 		goto fail;
3007 
3008 	urtw_8187_write_phy_cck(sc, 0x10, 0x9b);
3009 	urtw_8187_write_phy_ofdm(sc, 0x26, 0x90);
3010 
3011 	/* TX ant A, 0x0 for B */
3012 	error = urtw_8185_tx_antenna(sc, 0x3);
3013 	if (error)
3014 		goto fail;
3015 	urtw_write32_m(sc, URTW_HSSI_PARA, 0x3dc00002);
3016 
3017 	error = urtw_8225_rf_set_chan(sc, 1);
3018 fail:
3019 	return (error);
3020 #undef N
3021 }
3022 
3023 static usb_error_t
3024 urtw_8225v2_rf_set_chan(struct urtw_softc *sc, int chan)
3025 {
3026 	usb_error_t error;
3027 
3028 	error = urtw_8225v2_set_txpwrlvl(sc, chan);
3029 	if (error)
3030 		goto fail;
3031 
3032 	urtw_8225_write(sc, URTW_8225_ADDR_7_MAGIC, urtw_8225_channel[chan]);
3033 	usb_pause_mtx(&sc->sc_mtx, 10);
3034 fail:
3035 	return (error);
3036 }
3037 
3038 static usb_error_t
3039 urtw_8225_read(struct urtw_softc *sc, uint8_t addr, uint32_t *data)
3040 {
3041 	int i;
3042 	int16_t bit;
3043 	uint8_t rlen = 12, wlen = 6;
3044 	uint16_t o1, o2, o3, tmp;
3045 	uint32_t d2w = ((uint32_t)(addr & 0x1f)) << 27;
3046 	uint32_t mask = 0x80000000, value = 0;
3047 	usb_error_t error;
3048 
3049 	urtw_read16_m(sc, URTW_RF_PINS_OUTPUT, &o1);
3050 	urtw_read16_m(sc, URTW_RF_PINS_ENABLE, &o2);
3051 	urtw_read16_m(sc, URTW_RF_PINS_SELECT, &o3);
3052 	urtw_write16_m(sc, URTW_RF_PINS_ENABLE, o2 | URTW_RF_PINS_MAGIC4);
3053 	urtw_write16_m(sc, URTW_RF_PINS_SELECT, o3 | URTW_RF_PINS_MAGIC4);
3054 	o1 &= ~URTW_RF_PINS_MAGIC4;
3055 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, o1 | URTW_BB_HOST_BANG_EN);
3056 	DELAY(5);
3057 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, o1);
3058 	DELAY(5);
3059 
3060 	for (i = 0; i < (wlen / 2); i++, mask = mask >> 1) {
3061 		bit = ((d2w & mask) != 0) ? 1 : 0;
3062 
3063 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1);
3064 		DELAY(2);
3065 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 |
3066 		    URTW_BB_HOST_BANG_CLK);
3067 		DELAY(2);
3068 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 |
3069 		    URTW_BB_HOST_BANG_CLK);
3070 		DELAY(2);
3071 		mask = mask >> 1;
3072 		if (i == 2)
3073 			break;
3074 		bit = ((d2w & mask) != 0) ? 1 : 0;
3075 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 |
3076 		    URTW_BB_HOST_BANG_CLK);
3077 		DELAY(2);
3078 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 |
3079 		    URTW_BB_HOST_BANG_CLK);
3080 		DELAY(2);
3081 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1);
3082 		DELAY(1);
3083 	}
3084 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 | URTW_BB_HOST_BANG_RW |
3085 	    URTW_BB_HOST_BANG_CLK);
3086 	DELAY(2);
3087 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 | URTW_BB_HOST_BANG_RW);
3088 	DELAY(2);
3089 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, o1 | URTW_BB_HOST_BANG_RW);
3090 	DELAY(2);
3091 
3092 	mask = 0x800;
3093 	for (i = 0; i < rlen; i++, mask = mask >> 1) {
3094 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT,
3095 		    o1 | URTW_BB_HOST_BANG_RW);
3096 		DELAY(2);
3097 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT,
3098 		    o1 | URTW_BB_HOST_BANG_RW | URTW_BB_HOST_BANG_CLK);
3099 		DELAY(2);
3100 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT,
3101 		    o1 | URTW_BB_HOST_BANG_RW | URTW_BB_HOST_BANG_CLK);
3102 		DELAY(2);
3103 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT,
3104 		    o1 | URTW_BB_HOST_BANG_RW | URTW_BB_HOST_BANG_CLK);
3105 		DELAY(2);
3106 
3107 		urtw_read16_m(sc, URTW_RF_PINS_INPUT, &tmp);
3108 		value |= ((tmp & URTW_BB_HOST_BANG_CLK) ? mask : 0);
3109 		urtw_write16_m(sc, URTW_RF_PINS_OUTPUT,
3110 		    o1 | URTW_BB_HOST_BANG_RW);
3111 		DELAY(2);
3112 	}
3113 
3114 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, o1 | URTW_BB_HOST_BANG_EN |
3115 	    URTW_BB_HOST_BANG_RW);
3116 	DELAY(2);
3117 
3118 	urtw_write16_m(sc, URTW_RF_PINS_ENABLE, o2);
3119 	urtw_write16_m(sc, URTW_RF_PINS_SELECT, o3);
3120 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, URTW_RF_PINS_OUTPUT_MAGIC1);
3121 
3122 	if (data != NULL)
3123 		*data = value;
3124 fail:
3125 	return (error);
3126 }
3127 
3128 
3129 static usb_error_t
3130 urtw_8225v2_set_txpwrlvl(struct urtw_softc *sc, int chan)
3131 {
3132 	int i;
3133 	uint8_t *cck_pwrtable;
3134 	uint8_t cck_pwrlvl_max = 15, ofdm_pwrlvl_max = 25, ofdm_pwrlvl_min = 10;
3135 	uint8_t cck_pwrlvl = sc->sc_txpwr_cck[chan] & 0xff;
3136 	uint8_t ofdm_pwrlvl = sc->sc_txpwr_ofdm[chan] & 0xff;
3137 	usb_error_t error;
3138 
3139 	/* CCK power setting */
3140 	cck_pwrlvl = (cck_pwrlvl > cck_pwrlvl_max) ? cck_pwrlvl_max : cck_pwrlvl;
3141 	cck_pwrlvl += sc->sc_txpwr_cck_base;
3142 	cck_pwrlvl = (cck_pwrlvl > 35) ? 35 : cck_pwrlvl;
3143 	cck_pwrtable = (chan == 14) ? urtw_8225v2_txpwr_cck_ch14 :
3144 	    urtw_8225v2_txpwr_cck;
3145 
3146 	for (i = 0; i < 8; i++)
3147 		urtw_8187_write_phy_cck(sc, 0x44 + i, cck_pwrtable[i]);
3148 
3149 	urtw_write8_m(sc, URTW_TX_GAIN_CCK,
3150 	    urtw_8225v2_tx_gain_cck_ofdm[cck_pwrlvl]);
3151 	usb_pause_mtx(&sc->sc_mtx, 1);
3152 
3153 	/* OFDM power setting */
3154 	ofdm_pwrlvl = (ofdm_pwrlvl > (ofdm_pwrlvl_max - ofdm_pwrlvl_min)) ?
3155 		ofdm_pwrlvl_max : ofdm_pwrlvl + ofdm_pwrlvl_min;
3156 	ofdm_pwrlvl += sc->sc_txpwr_ofdm_base;
3157 	ofdm_pwrlvl = (ofdm_pwrlvl > 35) ? 35 : ofdm_pwrlvl;
3158 
3159 	error = urtw_8185_set_anaparam2(sc, URTW_8225_ANAPARAM2_ON);
3160 	if (error)
3161 		goto fail;
3162 
3163 	urtw_8187_write_phy_ofdm(sc, 2, 0x42);
3164 	urtw_8187_write_phy_ofdm(sc, 5, 0x0);
3165 	urtw_8187_write_phy_ofdm(sc, 6, 0x40);
3166 	urtw_8187_write_phy_ofdm(sc, 7, 0x0);
3167 	urtw_8187_write_phy_ofdm(sc, 8, 0x40);
3168 
3169 	urtw_write8_m(sc, URTW_TX_GAIN_OFDM,
3170 	    urtw_8225v2_tx_gain_cck_ofdm[ofdm_pwrlvl]);
3171 	usb_pause_mtx(&sc->sc_mtx, 1);
3172 fail:
3173 	return (error);
3174 }
3175 
3176 static usb_error_t
3177 urtw_8225v2_setgain(struct urtw_softc *sc, int16_t gain)
3178 {
3179 	uint8_t *gainp;
3180 	usb_error_t error;
3181 
3182 	/* XXX for A?  */
3183 	gainp = urtw_8225v2_gain_bg;
3184 	urtw_8187_write_phy_ofdm(sc, 0x0d, gainp[gain * 3]);
3185 	usb_pause_mtx(&sc->sc_mtx, 1);
3186 	urtw_8187_write_phy_ofdm(sc, 0x1b, gainp[gain * 3 + 1]);
3187 	usb_pause_mtx(&sc->sc_mtx, 1);
3188 	urtw_8187_write_phy_ofdm(sc, 0x1d, gainp[gain * 3 + 2]);
3189 	usb_pause_mtx(&sc->sc_mtx, 1);
3190 	urtw_8187_write_phy_ofdm(sc, 0x21, 0x17);
3191 	usb_pause_mtx(&sc->sc_mtx, 1);
3192 fail:
3193 	return (error);
3194 }
3195 
3196 static usb_error_t
3197 urtw_8225_isv2(struct urtw_softc *sc, int *ret)
3198 {
3199 	uint32_t data;
3200 	usb_error_t error;
3201 
3202 	*ret = 1;
3203 
3204 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, URTW_RF_PINS_MAGIC5);
3205 	urtw_write16_m(sc, URTW_RF_PINS_SELECT, URTW_RF_PINS_MAGIC5);
3206 	urtw_write16_m(sc, URTW_RF_PINS_ENABLE, URTW_RF_PINS_MAGIC5);
3207 	usb_pause_mtx(&sc->sc_mtx, 500);
3208 
3209 	urtw_8225_write(sc, URTW_8225_ADDR_0_MAGIC,
3210 	    URTW_8225_ADDR_0_DATA_MAGIC1);
3211 
3212 	error = urtw_8225_read(sc, URTW_8225_ADDR_8_MAGIC, &data);
3213 	if (error != 0)
3214 		goto fail;
3215 	if (data != URTW_8225_ADDR_8_DATA_MAGIC1)
3216 		*ret = 0;
3217 	else {
3218 		error = urtw_8225_read(sc, URTW_8225_ADDR_9_MAGIC, &data);
3219 		if (error != 0)
3220 			goto fail;
3221 		if (data != URTW_8225_ADDR_9_DATA_MAGIC1)
3222 			*ret = 0;
3223 	}
3224 
3225 	urtw_8225_write(sc, URTW_8225_ADDR_0_MAGIC,
3226 	    URTW_8225_ADDR_0_DATA_MAGIC2);
3227 fail:
3228 	return (error);
3229 }
3230 
3231 static usb_error_t
3232 urtw_8225v2b_rf_init(struct urtw_softc *sc)
3233 {
3234 #define N(a)	((int)(sizeof(a) / sizeof((a)[0])))
3235 	int i;
3236 	uint8_t data8;
3237 	usb_error_t error;
3238 
3239 	error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG);
3240 	if (error)
3241 		goto fail;
3242 
3243 	/*
3244 	 * initialize extra registers on 8187
3245 	 */
3246 	urtw_write16_m(sc, URTW_BRSR_8187B, 0xfff);
3247 
3248 	/* retry limit */
3249 	urtw_read8_m(sc, URTW_CW_CONF, &data8);
3250 	data8 |= URTW_CW_CONF_PERPACKET_RETRY;
3251 	urtw_write8_m(sc, URTW_CW_CONF, data8);
3252 
3253 	/* TX AGC */
3254 	urtw_read8_m(sc, URTW_TX_AGC_CTL, &data8);
3255 	data8 |= URTW_TX_AGC_CTL_PERPACKET_GAIN;
3256 	urtw_write8_m(sc, URTW_TX_AGC_CTL, data8);
3257 
3258 	/* Auto Rate Fallback Control */
3259 #define	URTW_ARFR	0x1e0
3260 	urtw_write16_m(sc, URTW_ARFR, 0xfff);
3261 	urtw_read8_m(sc, URTW_RATE_FALLBACK, &data8);
3262 	urtw_write8_m(sc, URTW_RATE_FALLBACK,
3263 	    data8 | URTW_RATE_FALLBACK_ENABLE);
3264 
3265 	urtw_read8_m(sc, URTW_MSR, &data8);
3266 	urtw_write8_m(sc, URTW_MSR, data8 & 0xf3);
3267 	urtw_read8_m(sc, URTW_MSR, &data8);
3268 	urtw_write8_m(sc, URTW_MSR, data8 | URTW_MSR_LINK_ENEDCA);
3269 	urtw_write8_m(sc, URTW_ACM_CONTROL, sc->sc_acmctl);
3270 
3271 	urtw_write16_m(sc, URTW_ATIM_WND, 2);
3272 	urtw_write16_m(sc, URTW_BEACON_INTERVAL, 100);
3273 #define	URTW_FEMR_FOR_8187B	0x1d4
3274 	urtw_write16_m(sc, URTW_FEMR_FOR_8187B, 0xffff);
3275 
3276 	/* led type */
3277 	urtw_read8_m(sc, URTW_CONFIG1, &data8);
3278 	data8 = (data8 & 0x3f) | 0x80;
3279 	urtw_write8_m(sc, URTW_CONFIG1, data8);
3280 
3281 	/* applying MAC address again.  */
3282 	urtw_write32_m(sc, URTW_MAC0, ((uint32_t *)sc->sc_bssid)[0]);
3283 	urtw_write16_m(sc, URTW_MAC4, ((uint32_t *)sc->sc_bssid)[1] & 0xffff);
3284 
3285 	error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL);
3286 	if (error)
3287 		goto fail;
3288 
3289 	urtw_write8_m(sc, URTW_WPA_CONFIG, 0);
3290 
3291 	/*
3292 	 * MAC configuration
3293 	 */
3294 	for (i = 0; i < N(urtw_8225v2b_rf_part1); i++)
3295 		urtw_write8_m(sc, urtw_8225v2b_rf_part1[i].reg,
3296 		    urtw_8225v2b_rf_part1[i].val);
3297 	urtw_write16_m(sc, URTW_TID_AC_MAP, 0xfa50);
3298 	urtw_write16_m(sc, URTW_INT_MIG, 0x0000);
3299 	urtw_write32_m(sc, 0x1f0, 0);
3300 	urtw_write32_m(sc, 0x1f4, 0);
3301 	urtw_write8_m(sc, 0x1f8, 0);
3302 	urtw_write32_m(sc, URTW_RF_TIMING, 0x4001);
3303 
3304 #define	URTW_RFSW_CTRL	0x272
3305 	urtw_write16_m(sc, URTW_RFSW_CTRL, 0x569a);
3306 
3307 	/*
3308 	 * initialize PHY
3309 	 */
3310 	error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG);
3311 	if (error)
3312 		goto fail;
3313 	urtw_read8_m(sc, URTW_CONFIG3, &data8);
3314 	urtw_write8_m(sc, URTW_CONFIG3,
3315 	    data8 | URTW_CONFIG3_ANAPARAM_WRITE);
3316 
3317 	error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL);
3318 	if (error)
3319 		goto fail;
3320 
3321 	/* setup RFE initial timing */
3322 	urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, 0x0480);
3323 	urtw_write16_m(sc, URTW_RF_PINS_SELECT, 0x2488);
3324 	urtw_write16_m(sc, URTW_RF_PINS_ENABLE, 0x1fff);
3325 	usb_pause_mtx(&sc->sc_mtx, 1100);
3326 
3327 	for (i = 0; i < N(urtw_8225v2b_rf_part0); i++) {
3328 		urtw_8225_write(sc, urtw_8225v2b_rf_part0[i].reg,
3329 		    urtw_8225v2b_rf_part0[i].val);
3330 		usb_pause_mtx(&sc->sc_mtx, 1);
3331 	}
3332 	urtw_8225_write(sc, 0x00, 0x01b7);
3333 
3334 	for (i = 0; i < 95; i++) {
3335 		urtw_8225_write(sc, URTW_8225_ADDR_1_MAGIC, (uint8_t)(i + 1));
3336 		usb_pause_mtx(&sc->sc_mtx, 1);
3337 		urtw_8225_write(sc, URTW_8225_ADDR_2_MAGIC,
3338 		    urtw_8225v2b_rxgain[i]);
3339 		usb_pause_mtx(&sc->sc_mtx, 1);
3340 	}
3341 
3342 	urtw_8225_write(sc, URTW_8225_ADDR_3_MAGIC, 0x080);
3343 	usb_pause_mtx(&sc->sc_mtx, 1);
3344 	urtw_8225_write(sc, URTW_8225_ADDR_5_MAGIC, 0x004);
3345 	usb_pause_mtx(&sc->sc_mtx, 1);
3346 	urtw_8225_write(sc, URTW_8225_ADDR_0_MAGIC, 0x0b7);
3347 	usb_pause_mtx(&sc->sc_mtx, 1);
3348 	usb_pause_mtx(&sc->sc_mtx, 3000);
3349 	urtw_8225_write(sc, URTW_8225_ADDR_2_MAGIC, 0xc4d);
3350 	usb_pause_mtx(&sc->sc_mtx, 2000);
3351 	urtw_8225_write(sc, URTW_8225_ADDR_2_MAGIC, 0x44d);
3352 	usb_pause_mtx(&sc->sc_mtx, 1);
3353 	urtw_8225_write(sc, URTW_8225_ADDR_0_MAGIC, 0x2bf);
3354 	usb_pause_mtx(&sc->sc_mtx, 1);
3355 
3356 	urtw_write8_m(sc, URTW_TX_GAIN_CCK, 0x03);
3357 	urtw_write8_m(sc, URTW_TX_GAIN_OFDM, 0x07);
3358 	urtw_write8_m(sc, URTW_TX_ANTENNA, 0x03);
3359 
3360 	urtw_8187_write_phy_ofdm(sc, 0x80, 0x12);
3361 	for (i = 0; i < 128; i++) {
3362 		uint32_t addr, data;
3363 
3364 		data = (urtw_8225z2_agc[i] << 8) | 0x0000008f;
3365 		addr = ((i + 0x80) << 8) | 0x0000008e;
3366 
3367 		urtw_8187_write_phy_ofdm(sc, data & 0x7f, (data >> 8) & 0xff);
3368 		urtw_8187_write_phy_ofdm(sc, addr & 0x7f, (addr >> 8) & 0xff);
3369 		urtw_8187_write_phy_ofdm(sc, 0x0e, 0x00);
3370 	}
3371 	urtw_8187_write_phy_ofdm(sc, 0x80, 0x10);
3372 
3373 	for (i = 0; i < N(urtw_8225v2b_rf_part2); i++)
3374 		urtw_8187_write_phy_ofdm(sc, i, urtw_8225v2b_rf_part2[i].val);
3375 
3376 	urtw_write32_m(sc, URTW_8187B_AC_VO, (7 << 12) | (3 << 8) | 0x1c);
3377 	urtw_write32_m(sc, URTW_8187B_AC_VI, (7 << 12) | (3 << 8) | 0x1c);
3378 	urtw_write32_m(sc, URTW_8187B_AC_BE, (7 << 12) | (3 << 8) | 0x1c);
3379 	urtw_write32_m(sc, URTW_8187B_AC_BK, (7 << 12) | (3 << 8) | 0x1c);
3380 
3381 	urtw_8187_write_phy_ofdm(sc, 0x97, 0x46);
3382 	urtw_8187_write_phy_ofdm(sc, 0xa4, 0xb6);
3383 	urtw_8187_write_phy_ofdm(sc, 0x85, 0xfc);
3384 	urtw_8187_write_phy_cck(sc, 0xc1, 0x88);
3385 
3386 fail:
3387 	return (error);
3388 #undef N
3389 }
3390 
3391 static usb_error_t
3392 urtw_8225v2b_rf_set_chan(struct urtw_softc *sc, int chan)
3393 {
3394 	usb_error_t error;
3395 
3396 	error = urtw_8225v2b_set_txpwrlvl(sc, chan);
3397 	if (error)
3398 		goto fail;
3399 
3400 	urtw_8225_write(sc, URTW_8225_ADDR_7_MAGIC, urtw_8225_channel[chan]);
3401 	usb_pause_mtx(&sc->sc_mtx, 10);
3402 fail:
3403 	return (error);
3404 }
3405 
3406 static usb_error_t
3407 urtw_8225v2b_set_txpwrlvl(struct urtw_softc *sc, int chan)
3408 {
3409 	int i;
3410 	uint8_t *cck_pwrtable;
3411 	uint8_t cck_pwrlvl_max = 15;
3412 	uint8_t cck_pwrlvl = sc->sc_txpwr_cck[chan] & 0xff;
3413 	uint8_t ofdm_pwrlvl = sc->sc_txpwr_ofdm[chan] & 0xff;
3414 	usb_error_t error;
3415 
3416 	/* CCK power setting */
3417 	cck_pwrlvl = (cck_pwrlvl > cck_pwrlvl_max) ?
3418 	    ((sc->sc_flags & URTW_RTL8187B_REV_B) ? cck_pwrlvl_max : 22) :
3419 	    (cck_pwrlvl + ((sc->sc_flags & URTW_RTL8187B_REV_B) ? 0 : 7));
3420 	cck_pwrlvl += sc->sc_txpwr_cck_base;
3421 	cck_pwrlvl = (cck_pwrlvl > 35) ? 35 : cck_pwrlvl;
3422 	cck_pwrtable = (chan == 14) ? urtw_8225v2b_txpwr_cck_ch14 :
3423 	    urtw_8225v2b_txpwr_cck;
3424 
3425 	if (sc->sc_flags & URTW_RTL8187B_REV_B)
3426 		cck_pwrtable += (cck_pwrlvl <= 6) ? 0 :
3427 		    ((cck_pwrlvl <= 11) ? 8 : 16);
3428 	else
3429 		cck_pwrtable += (cck_pwrlvl <= 5) ? 0 :
3430 		    ((cck_pwrlvl <= 11) ? 8 : ((cck_pwrlvl <= 17) ? 16 : 24));
3431 
3432 	for (i = 0; i < 8; i++)
3433 		urtw_8187_write_phy_cck(sc, 0x44 + i, cck_pwrtable[i]);
3434 
3435 	urtw_write8_m(sc, URTW_TX_GAIN_CCK,
3436 	    urtw_8225v2_tx_gain_cck_ofdm[cck_pwrlvl] << 1);
3437 	usb_pause_mtx(&sc->sc_mtx, 1);
3438 
3439 	/* OFDM power setting */
3440 	ofdm_pwrlvl = (ofdm_pwrlvl > 15) ?
3441 	    ((sc->sc_flags & URTW_RTL8187B_REV_B) ? 17 : 25) :
3442 	    (ofdm_pwrlvl + ((sc->sc_flags & URTW_RTL8187B_REV_B) ? 2 : 10));
3443 	ofdm_pwrlvl += sc->sc_txpwr_ofdm_base;
3444 	ofdm_pwrlvl = (ofdm_pwrlvl > 35) ? 35 : ofdm_pwrlvl;
3445 
3446 	urtw_write8_m(sc, URTW_TX_GAIN_OFDM,
3447 	    urtw_8225v2_tx_gain_cck_ofdm[ofdm_pwrlvl] << 1);
3448 
3449 	if (sc->sc_flags & URTW_RTL8187B_REV_B) {
3450 		if (ofdm_pwrlvl <= 11) {
3451 			urtw_8187_write_phy_ofdm(sc, 0x87, 0x60);
3452 			urtw_8187_write_phy_ofdm(sc, 0x89, 0x60);
3453 		} else {
3454 			urtw_8187_write_phy_ofdm(sc, 0x87, 0x5c);
3455 			urtw_8187_write_phy_ofdm(sc, 0x89, 0x5c);
3456 		}
3457 	} else {
3458 		if (ofdm_pwrlvl <= 11) {
3459 			urtw_8187_write_phy_ofdm(sc, 0x87, 0x5c);
3460 			urtw_8187_write_phy_ofdm(sc, 0x89, 0x5c);
3461 		} else if (ofdm_pwrlvl <= 17) {
3462 			urtw_8187_write_phy_ofdm(sc, 0x87, 0x54);
3463 			urtw_8187_write_phy_ofdm(sc, 0x89, 0x54);
3464 		} else {
3465 			urtw_8187_write_phy_ofdm(sc, 0x87, 0x50);
3466 			urtw_8187_write_phy_ofdm(sc, 0x89, 0x50);
3467 		}
3468 	}
3469 	usb_pause_mtx(&sc->sc_mtx, 1);
3470 fail:
3471 	return (error);
3472 }
3473 
3474 static usb_error_t
3475 urtw_read8e(struct urtw_softc *sc, int val, uint8_t *data)
3476 {
3477 	struct usb_device_request req;
3478 	usb_error_t error;
3479 
3480 	req.bmRequestType = UT_READ_VENDOR_DEVICE;
3481 	req.bRequest = URTW_8187_GETREGS_REQ;
3482 	USETW(req.wValue, val | 0xfe00);
3483 	USETW(req.wIndex, 0);
3484 	USETW(req.wLength, sizeof(uint8_t));
3485 
3486 	error = urtw_do_request(sc, &req, data);
3487 	return (error);
3488 }
3489 
3490 static usb_error_t
3491 urtw_write8e(struct urtw_softc *sc, int val, uint8_t data)
3492 {
3493 	struct usb_device_request req;
3494 
3495 	req.bmRequestType = UT_WRITE_VENDOR_DEVICE;
3496 	req.bRequest = URTW_8187_SETREGS_REQ;
3497 	USETW(req.wValue, val | 0xfe00);
3498 	USETW(req.wIndex, 0);
3499 	USETW(req.wLength, sizeof(uint8_t));
3500 
3501 	return (urtw_do_request(sc, &req, &data));
3502 }
3503 
3504 static usb_error_t
3505 urtw_8180_set_anaparam(struct urtw_softc *sc, uint32_t val)
3506 {
3507 	uint8_t data;
3508 	usb_error_t error;
3509 
3510 	error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG);
3511 	if (error)
3512 		goto fail;
3513 
3514 	urtw_read8_m(sc, URTW_CONFIG3, &data);
3515 	urtw_write8_m(sc, URTW_CONFIG3, data | URTW_CONFIG3_ANAPARAM_WRITE);
3516 	urtw_write32_m(sc, URTW_ANAPARAM, val);
3517 	urtw_read8_m(sc, URTW_CONFIG3, &data);
3518 	urtw_write8_m(sc, URTW_CONFIG3, data & ~URTW_CONFIG3_ANAPARAM_WRITE);
3519 
3520 	error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL);
3521 	if (error)
3522 		goto fail;
3523 fail:
3524 	return (error);
3525 }
3526 
3527 static usb_error_t
3528 urtw_8185_set_anaparam2(struct urtw_softc *sc, uint32_t val)
3529 {
3530 	uint8_t data;
3531 	usb_error_t error;
3532 
3533 	error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG);
3534 	if (error)
3535 		goto fail;
3536 
3537 	urtw_read8_m(sc, URTW_CONFIG3, &data);
3538 	urtw_write8_m(sc, URTW_CONFIG3, data | URTW_CONFIG3_ANAPARAM_WRITE);
3539 	urtw_write32_m(sc, URTW_ANAPARAM2, val);
3540 	urtw_read8_m(sc, URTW_CONFIG3, &data);
3541 	urtw_write8_m(sc, URTW_CONFIG3, data & ~URTW_CONFIG3_ANAPARAM_WRITE);
3542 
3543 	error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL);
3544 	if (error)
3545 		goto fail;
3546 fail:
3547 	return (error);
3548 }
3549 
3550 static usb_error_t
3551 urtw_intr_enable(struct urtw_softc *sc)
3552 {
3553 	usb_error_t error;
3554 
3555 	urtw_write16_m(sc, URTW_INTR_MASK, 0xffff);
3556 fail:
3557 	return (error);
3558 }
3559 
3560 static usb_error_t
3561 urtw_intr_disable(struct urtw_softc *sc)
3562 {
3563 	usb_error_t error;
3564 
3565 	urtw_write16_m(sc, URTW_INTR_MASK, 0);
3566 fail:
3567 	return (error);
3568 }
3569 
3570 static usb_error_t
3571 urtw_reset(struct urtw_softc *sc)
3572 {
3573 	uint8_t data;
3574 	usb_error_t error;
3575 
3576 	error = urtw_8180_set_anaparam(sc, URTW_8225_ANAPARAM_ON);
3577 	if (error)
3578 		goto fail;
3579 	error = urtw_8185_set_anaparam2(sc, URTW_8225_ANAPARAM2_ON);
3580 	if (error)
3581 		goto fail;
3582 
3583 	error = urtw_intr_disable(sc);
3584 	if (error)
3585 		goto fail;
3586 	usb_pause_mtx(&sc->sc_mtx, 100);
3587 
3588 	error = urtw_write8e(sc, 0x18, 0x10);
3589 	if (error != 0)
3590 		goto fail;
3591 	error = urtw_write8e(sc, 0x18, 0x11);
3592 	if (error != 0)
3593 		goto fail;
3594 	error = urtw_write8e(sc, 0x18, 0x00);
3595 	if (error != 0)
3596 		goto fail;
3597 	usb_pause_mtx(&sc->sc_mtx, 100);
3598 
3599 	urtw_read8_m(sc, URTW_CMD, &data);
3600 	data = (data & 0x2) | URTW_CMD_RST;
3601 	urtw_write8_m(sc, URTW_CMD, data);
3602 	usb_pause_mtx(&sc->sc_mtx, 100);
3603 
3604 	urtw_read8_m(sc, URTW_CMD, &data);
3605 	if (data & URTW_CMD_RST) {
3606 		device_printf(sc->sc_dev, "reset timeout\n");
3607 		goto fail;
3608 	}
3609 
3610 	error = urtw_set_mode(sc, URTW_EPROM_CMD_LOAD);
3611 	if (error)
3612 		goto fail;
3613 	usb_pause_mtx(&sc->sc_mtx, 100);
3614 
3615 	error = urtw_8180_set_anaparam(sc, URTW_8225_ANAPARAM_ON);
3616 	if (error)
3617 		goto fail;
3618 	error = urtw_8185_set_anaparam2(sc, URTW_8225_ANAPARAM2_ON);
3619 	if (error)
3620 		goto fail;
3621 fail:
3622 	return (error);
3623 }
3624 
3625 static usb_error_t
3626 urtw_led_ctl(struct urtw_softc *sc, int mode)
3627 {
3628 	usb_error_t error = 0;
3629 
3630 	switch (sc->sc_strategy) {
3631 	case URTW_SW_LED_MODE0:
3632 		error = urtw_led_mode0(sc, mode);
3633 		break;
3634 	case URTW_SW_LED_MODE1:
3635 		error = urtw_led_mode1(sc, mode);
3636 		break;
3637 	case URTW_SW_LED_MODE2:
3638 		error = urtw_led_mode2(sc, mode);
3639 		break;
3640 	case URTW_SW_LED_MODE3:
3641 		error = urtw_led_mode3(sc, mode);
3642 		break;
3643 	default:
3644 		DPRINTF(sc, URTW_DEBUG_STATE,
3645 		    "unsupported LED mode %d\n", sc->sc_strategy);
3646 		error = USB_ERR_INVAL;
3647 		break;
3648 	}
3649 
3650 	return (error);
3651 }
3652 
3653 static usb_error_t
3654 urtw_led_mode0(struct urtw_softc *sc, int mode)
3655 {
3656 
3657 	switch (mode) {
3658 	case URTW_LED_CTL_POWER_ON:
3659 		sc->sc_gpio_ledstate = URTW_LED_POWER_ON_BLINK;
3660 		break;
3661 	case URTW_LED_CTL_TX:
3662 		if (sc->sc_gpio_ledinprogress == 1)
3663 			return (0);
3664 
3665 		sc->sc_gpio_ledstate = URTW_LED_BLINK_NORMAL;
3666 		sc->sc_gpio_blinktime = 2;
3667 		break;
3668 	case URTW_LED_CTL_LINK:
3669 		sc->sc_gpio_ledstate = URTW_LED_ON;
3670 		break;
3671 	default:
3672 		DPRINTF(sc, URTW_DEBUG_STATE,
3673 		    "unsupported LED mode 0x%x", mode);
3674 		return (USB_ERR_INVAL);
3675 	}
3676 
3677 	switch (sc->sc_gpio_ledstate) {
3678 	case URTW_LED_ON:
3679 		if (sc->sc_gpio_ledinprogress != 0)
3680 			break;
3681 		urtw_led_on(sc, URTW_LED_GPIO);
3682 		break;
3683 	case URTW_LED_BLINK_NORMAL:
3684 		if (sc->sc_gpio_ledinprogress != 0)
3685 			break;
3686 		sc->sc_gpio_ledinprogress = 1;
3687 		sc->sc_gpio_blinkstate = (sc->sc_gpio_ledon != 0) ?
3688 			URTW_LED_OFF : URTW_LED_ON;
3689 		usb_callout_reset(&sc->sc_led_ch, hz, urtw_led_ch, sc);
3690 		break;
3691 	case URTW_LED_POWER_ON_BLINK:
3692 		urtw_led_on(sc, URTW_LED_GPIO);
3693 		usb_pause_mtx(&sc->sc_mtx, 100);
3694 		urtw_led_off(sc, URTW_LED_GPIO);
3695 		break;
3696 	default:
3697 		DPRINTF(sc, URTW_DEBUG_STATE,
3698 		    "unknown LED status 0x%x", sc->sc_gpio_ledstate);
3699 		return (USB_ERR_INVAL);
3700 	}
3701 	return (0);
3702 }
3703 
3704 static usb_error_t
3705 urtw_led_mode1(struct urtw_softc *sc, int mode)
3706 {
3707 	return (USB_ERR_INVAL);
3708 }
3709 
3710 static usb_error_t
3711 urtw_led_mode2(struct urtw_softc *sc, int mode)
3712 {
3713 	return (USB_ERR_INVAL);
3714 }
3715 
3716 static usb_error_t
3717 urtw_led_mode3(struct urtw_softc *sc, int mode)
3718 {
3719 	return (USB_ERR_INVAL);
3720 }
3721 
3722 static usb_error_t
3723 urtw_led_on(struct urtw_softc *sc, int type)
3724 {
3725 	usb_error_t error;
3726 
3727 	if (type == URTW_LED_GPIO) {
3728 		switch (sc->sc_gpio_ledpin) {
3729 		case URTW_LED_PIN_GPIO0:
3730 			urtw_write8_m(sc, URTW_GPIO, 0x01);
3731 			urtw_write8_m(sc, URTW_GP_ENABLE, 0x00);
3732 			break;
3733 		default:
3734 			DPRINTF(sc, URTW_DEBUG_STATE,
3735 			    "unsupported LED PIN type 0x%x",
3736 			    sc->sc_gpio_ledpin);
3737 			error = USB_ERR_INVAL;
3738 			goto fail;
3739 		}
3740 	} else {
3741 		DPRINTF(sc, URTW_DEBUG_STATE,
3742 		    "unsupported LED type 0x%x", type);
3743 		error = USB_ERR_INVAL;
3744 		goto fail;
3745 	}
3746 
3747 	sc->sc_gpio_ledon = 1;
3748 fail:
3749 	return (error);
3750 }
3751 
3752 static usb_error_t
3753 urtw_led_off(struct urtw_softc *sc, int type)
3754 {
3755 	usb_error_t error;
3756 
3757 	if (type == URTW_LED_GPIO) {
3758 		switch (sc->sc_gpio_ledpin) {
3759 		case URTW_LED_PIN_GPIO0:
3760 			urtw_write8_m(sc, URTW_GPIO, URTW_GPIO_DATA_MAGIC1);
3761 			urtw_write8_m(sc,
3762 			    URTW_GP_ENABLE, URTW_GP_ENABLE_DATA_MAGIC1);
3763 			break;
3764 		default:
3765 			DPRINTF(sc, URTW_DEBUG_STATE,
3766 			    "unsupported LED PIN type 0x%x",
3767 			    sc->sc_gpio_ledpin);
3768 			error = USB_ERR_INVAL;
3769 			goto fail;
3770 		}
3771 	} else {
3772 		DPRINTF(sc, URTW_DEBUG_STATE,
3773 		    "unsupported LED type 0x%x", type);
3774 		error = USB_ERR_INVAL;
3775 		goto fail;
3776 	}
3777 
3778 	sc->sc_gpio_ledon = 0;
3779 
3780 fail:
3781 	return (error);
3782 }
3783 
3784 static void
3785 urtw_led_ch(void *arg)
3786 {
3787 	struct urtw_softc *sc = arg;
3788 	struct ifnet *ifp = sc->sc_ifp;
3789 	struct ieee80211com *ic = ifp->if_l2com;
3790 
3791 	ieee80211_runtask(ic, &sc->sc_led_task);
3792 }
3793 
3794 static void
3795 urtw_ledtask(void *arg, int pending)
3796 {
3797 	struct urtw_softc *sc = arg;
3798 
3799 	if (sc->sc_strategy != URTW_SW_LED_MODE0) {
3800 		DPRINTF(sc, URTW_DEBUG_STATE,
3801 		    "could not process a LED strategy 0x%x",
3802 		    sc->sc_strategy);
3803 		return;
3804 	}
3805 
3806 	URTW_LOCK(sc);
3807 	urtw_led_blink(sc);
3808 	URTW_UNLOCK(sc);
3809 }
3810 
3811 static usb_error_t
3812 urtw_led_blink(struct urtw_softc *sc)
3813 {
3814 	uint8_t ing = 0;
3815 	usb_error_t error;
3816 
3817 	if (sc->sc_gpio_blinkstate == URTW_LED_ON)
3818 		error = urtw_led_on(sc, URTW_LED_GPIO);
3819 	else
3820 		error = urtw_led_off(sc, URTW_LED_GPIO);
3821 	sc->sc_gpio_blinktime--;
3822 	if (sc->sc_gpio_blinktime == 0)
3823 		ing = 1;
3824 	else {
3825 		if (sc->sc_gpio_ledstate != URTW_LED_BLINK_NORMAL &&
3826 		    sc->sc_gpio_ledstate != URTW_LED_BLINK_SLOWLY &&
3827 		    sc->sc_gpio_ledstate != URTW_LED_BLINK_CM3)
3828 			ing = 1;
3829 	}
3830 	if (ing == 1) {
3831 		if (sc->sc_gpio_ledstate == URTW_LED_ON &&
3832 		    sc->sc_gpio_ledon == 0)
3833 			error = urtw_led_on(sc, URTW_LED_GPIO);
3834 		else if (sc->sc_gpio_ledstate == URTW_LED_OFF &&
3835 		    sc->sc_gpio_ledon == 1)
3836 			error = urtw_led_off(sc, URTW_LED_GPIO);
3837 
3838 		sc->sc_gpio_blinktime = 0;
3839 		sc->sc_gpio_ledinprogress = 0;
3840 		return (0);
3841 	}
3842 
3843 	sc->sc_gpio_blinkstate = (sc->sc_gpio_blinkstate != URTW_LED_ON) ?
3844 	    URTW_LED_ON : URTW_LED_OFF;
3845 
3846 	switch (sc->sc_gpio_ledstate) {
3847 	case URTW_LED_BLINK_NORMAL:
3848 		usb_callout_reset(&sc->sc_led_ch, hz, urtw_led_ch, sc);
3849 		break;
3850 	default:
3851 		DPRINTF(sc, URTW_DEBUG_STATE,
3852 		    "unknown LED status 0x%x",
3853 		    sc->sc_gpio_ledstate);
3854 		return (USB_ERR_INVAL);
3855 	}
3856 	return (0);
3857 }
3858 
3859 static usb_error_t
3860 urtw_rx_enable(struct urtw_softc *sc)
3861 {
3862 	uint8_t data;
3863 	usb_error_t error;
3864 
3865 	usbd_transfer_start((sc->sc_flags & URTW_RTL8187B) ?
3866 	    sc->sc_xfer[URTW_8187B_BULK_RX] : sc->sc_xfer[URTW_8187L_BULK_RX]);
3867 
3868 	error = urtw_rx_setconf(sc);
3869 	if (error != 0)
3870 		goto fail;
3871 
3872 	if ((sc->sc_flags & URTW_RTL8187B) == 0) {
3873 		urtw_read8_m(sc, URTW_CMD, &data);
3874 		urtw_write8_m(sc, URTW_CMD, data | URTW_CMD_RX_ENABLE);
3875 	}
3876 fail:
3877 	return (error);
3878 }
3879 
3880 static usb_error_t
3881 urtw_tx_enable(struct urtw_softc *sc)
3882 {
3883 	uint8_t data8;
3884 	uint32_t data;
3885 	usb_error_t error;
3886 
3887 	if (sc->sc_flags & URTW_RTL8187B) {
3888 		urtw_read32_m(sc, URTW_TX_CONF, &data);
3889 		data &= ~URTW_TX_LOOPBACK_MASK;
3890 		data &= ~(URTW_TX_DPRETRY_MASK | URTW_TX_RTSRETRY_MASK);
3891 		data &= ~(URTW_TX_NOCRC | URTW_TX_MXDMA_MASK);
3892 		data &= ~URTW_TX_SWPLCPLEN;
3893 		data |= URTW_TX_HW_SEQNUM | URTW_TX_DISREQQSIZE |
3894 		    (7 << 8) |	/* short retry limit */
3895 		    (7 << 0) |	/* long retry limit */
3896 		    (7 << 21);	/* MAX TX DMA */
3897 		urtw_write32_m(sc, URTW_TX_CONF, data);
3898 
3899 		urtw_read8_m(sc, URTW_MSR, &data8);
3900 		data8 |= URTW_MSR_LINK_ENEDCA;
3901 		urtw_write8_m(sc, URTW_MSR, data8);
3902 		return (error);
3903 	}
3904 
3905 	urtw_read8_m(sc, URTW_CW_CONF, &data8);
3906 	data8 &= ~(URTW_CW_CONF_PERPACKET_CW | URTW_CW_CONF_PERPACKET_RETRY);
3907 	urtw_write8_m(sc, URTW_CW_CONF, data8);
3908 
3909 	urtw_read8_m(sc, URTW_TX_AGC_CTL, &data8);
3910 	data8 &= ~URTW_TX_AGC_CTL_PERPACKET_GAIN;
3911 	data8 &= ~URTW_TX_AGC_CTL_PERPACKET_ANTSEL;
3912 	data8 &= ~URTW_TX_AGC_CTL_FEEDBACK_ANT;
3913 	urtw_write8_m(sc, URTW_TX_AGC_CTL, data8);
3914 
3915 	urtw_read32_m(sc, URTW_TX_CONF, &data);
3916 	data &= ~URTW_TX_LOOPBACK_MASK;
3917 	data |= URTW_TX_LOOPBACK_NONE;
3918 	data &= ~(URTW_TX_DPRETRY_MASK | URTW_TX_RTSRETRY_MASK);
3919 	data |= sc->sc_tx_retry << URTW_TX_DPRETRY_SHIFT;
3920 	data |= sc->sc_rts_retry << URTW_TX_RTSRETRY_SHIFT;
3921 	data &= ~(URTW_TX_NOCRC | URTW_TX_MXDMA_MASK);
3922 	data |= URTW_TX_MXDMA_2048 | URTW_TX_CWMIN | URTW_TX_DISCW;
3923 	data &= ~URTW_TX_SWPLCPLEN;
3924 	data |= URTW_TX_NOICV;
3925 	urtw_write32_m(sc, URTW_TX_CONF, data);
3926 
3927 	urtw_read8_m(sc, URTW_CMD, &data8);
3928 	urtw_write8_m(sc, URTW_CMD, data8 | URTW_CMD_TX_ENABLE);
3929 fail:
3930 	return (error);
3931 }
3932 
3933 static usb_error_t
3934 urtw_rx_setconf(struct urtw_softc *sc)
3935 {
3936 	struct ifnet *ifp = sc->sc_ifp;
3937 	struct ieee80211com *ic = ifp->if_l2com;
3938 	uint32_t data;
3939 	usb_error_t error;
3940 
3941 	urtw_read32_m(sc, URTW_RX, &data);
3942 	data = data &~ URTW_RX_FILTER_MASK;
3943 	if (sc->sc_flags & URTW_RTL8187B) {
3944 		data = data | URTW_RX_FILTER_MNG | URTW_RX_FILTER_DATA |
3945 		    URTW_RX_FILTER_MCAST | URTW_RX_FILTER_BCAST |
3946 		    URTW_RX_FILTER_NICMAC | URTW_RX_CHECK_BSSID |
3947 		    URTW_RX_FIFO_THRESHOLD_NONE |
3948 		    URTW_MAX_RX_DMA_2048 |
3949 		    URTW_RX_AUTORESETPHY | URTW_RCR_ONLYERLPKT;
3950 	} else {
3951 		data = data | URTW_RX_FILTER_MNG | URTW_RX_FILTER_DATA;
3952 		data = data | URTW_RX_FILTER_BCAST | URTW_RX_FILTER_MCAST;
3953 
3954 		if (ic->ic_opmode == IEEE80211_M_MONITOR) {
3955 			data = data | URTW_RX_FILTER_ICVERR;
3956 			data = data | URTW_RX_FILTER_PWR;
3957 		}
3958 		if (sc->sc_crcmon == 1 && ic->ic_opmode == IEEE80211_M_MONITOR)
3959 			data = data | URTW_RX_FILTER_CRCERR;
3960 
3961 		if (ic->ic_opmode == IEEE80211_M_MONITOR ||
3962 		    (ifp->if_flags & (IFF_ALLMULTI | IFF_PROMISC))) {
3963 			data = data | URTW_RX_FILTER_ALLMAC;
3964 		} else {
3965 			data = data | URTW_RX_FILTER_NICMAC;
3966 			data = data | URTW_RX_CHECK_BSSID;
3967 		}
3968 
3969 		data = data &~ URTW_RX_FIFO_THRESHOLD_MASK;
3970 		data = data | URTW_RX_FIFO_THRESHOLD_NONE |
3971 		    URTW_RX_AUTORESETPHY;
3972 		data = data &~ URTW_MAX_RX_DMA_MASK;
3973 		data = data | URTW_MAX_RX_DMA_2048 | URTW_RCR_ONLYERLPKT;
3974 	}
3975 
3976 	urtw_write32_m(sc, URTW_RX, data);
3977 fail:
3978 	return (error);
3979 }
3980 
3981 static struct mbuf *
3982 urtw_rxeof(struct usb_xfer *xfer, struct urtw_data *data, int *rssi_p,
3983     int8_t *nf_p)
3984 {
3985 	int actlen, flen, rssi;
3986 	struct ieee80211_frame *wh;
3987 	struct mbuf *m, *mnew;
3988 	struct urtw_softc *sc = data->sc;
3989 	struct ifnet *ifp = sc->sc_ifp;
3990 	struct ieee80211com *ic = ifp->if_l2com;
3991 	uint8_t noise = 0, rate;
3992 
3993 	usbd_xfer_status(xfer, &actlen, NULL, NULL, NULL);
3994 
3995 	if (actlen < (int)URTW_MIN_RXBUFSZ) {
3996 		ifp->if_ierrors++;
3997 		return (NULL);
3998 	}
3999 
4000 	if (sc->sc_flags & URTW_RTL8187B) {
4001 		struct urtw_8187b_rxhdr *rx;
4002 
4003 		rx = (struct urtw_8187b_rxhdr *)(data->buf +
4004 		    (actlen - (sizeof(struct urtw_8187b_rxhdr))));
4005 		flen = le32toh(rx->flag) & 0xfff;
4006 		if (flen > actlen) {
4007 			ifp->if_ierrors++;
4008 			return (NULL);
4009 		}
4010 		rate = (le32toh(rx->flag) >> URTW_RX_FLAG_RXRATE_SHIFT) & 0xf;
4011 		/* XXX correct? */
4012 		rssi = rx->rssi & URTW_RX_RSSI_MASK;
4013 		noise = rx->noise;
4014 	} else {
4015 		struct urtw_8187l_rxhdr *rx;
4016 
4017 		rx = (struct urtw_8187l_rxhdr *)(data->buf +
4018 		    (actlen - (sizeof(struct urtw_8187l_rxhdr))));
4019 		flen = le32toh(rx->flag) & 0xfff;
4020 		if (flen > actlen) {
4021 			ifp->if_ierrors++;
4022 			return (NULL);
4023 		}
4024 
4025 		rate = (le32toh(rx->flag) >> URTW_RX_FLAG_RXRATE_SHIFT) & 0xf;
4026 		/* XXX correct? */
4027 		rssi = rx->rssi & URTW_RX_8187L_RSSI_MASK;
4028 		noise = rx->noise;
4029 	}
4030 
4031 	mnew = m_getcl(M_NOWAIT, MT_DATA, M_PKTHDR);
4032 	if (mnew == NULL) {
4033 		ifp->if_ierrors++;
4034 		return (NULL);
4035 	}
4036 
4037 	m = data->m;
4038 	data->m = mnew;
4039 	data->buf = mtod(mnew, uint8_t *);
4040 
4041 	/* finalize mbuf */
4042 	m->m_pkthdr.rcvif = ifp;
4043 	m->m_pkthdr.len = m->m_len = flen - IEEE80211_CRC_LEN;
4044 
4045 	if (ieee80211_radiotap_active(ic)) {
4046 		struct urtw_rx_radiotap_header *tap = &sc->sc_rxtap;
4047 
4048 		/* XXX Are variables correct?  */
4049 		tap->wr_chan_freq = htole16(ic->ic_curchan->ic_freq);
4050 		tap->wr_chan_flags = htole16(ic->ic_curchan->ic_flags);
4051 		tap->wr_dbm_antsignal = (int8_t)rssi;
4052 	}
4053 
4054 	wh = mtod(m, struct ieee80211_frame *);
4055 	if ((wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK) == IEEE80211_FC0_TYPE_DATA)
4056 		sc->sc_currate = (rate > 0) ? rate : sc->sc_currate;
4057 
4058 	*rssi_p = rssi;
4059 	*nf_p = noise;		/* XXX correct? */
4060 
4061 	return (m);
4062 }
4063 
4064 static void
4065 urtw_bulk_rx_callback(struct usb_xfer *xfer, usb_error_t error)
4066 {
4067 	struct urtw_softc *sc = usbd_xfer_softc(xfer);
4068 	struct ifnet *ifp = sc->sc_ifp;
4069 	struct ieee80211com *ic = ifp->if_l2com;
4070 	struct ieee80211_frame *wh;
4071 	struct ieee80211_node *ni;
4072 	struct mbuf *m = NULL;
4073 	struct urtw_data *data;
4074 	int8_t nf = -95;
4075 	int rssi = 1;
4076 
4077 	URTW_ASSERT_LOCKED(sc);
4078 
4079 	switch (USB_GET_STATE(xfer)) {
4080 	case USB_ST_TRANSFERRED:
4081 		data = STAILQ_FIRST(&sc->sc_rx_active);
4082 		if (data == NULL)
4083 			goto setup;
4084 		STAILQ_REMOVE_HEAD(&sc->sc_rx_active, next);
4085 		m = urtw_rxeof(xfer, data, &rssi, &nf);
4086 		STAILQ_INSERT_TAIL(&sc->sc_rx_inactive, data, next);
4087 		/* FALLTHROUGH */
4088 	case USB_ST_SETUP:
4089 setup:
4090 		data = STAILQ_FIRST(&sc->sc_rx_inactive);
4091 		if (data == NULL) {
4092 			KASSERT(m == NULL, ("mbuf isn't NULL"));
4093 			return;
4094 		}
4095 		STAILQ_REMOVE_HEAD(&sc->sc_rx_inactive, next);
4096 		STAILQ_INSERT_TAIL(&sc->sc_rx_active, data, next);
4097 		usbd_xfer_set_frame_data(xfer, 0, data->buf,
4098 		    usbd_xfer_max_len(xfer));
4099 		usbd_transfer_submit(xfer);
4100 
4101 		/*
4102 		 * To avoid LOR we should unlock our private mutex here to call
4103 		 * ieee80211_input() because here is at the end of a USB
4104 		 * callback and safe to unlock.
4105 		 */
4106 		URTW_UNLOCK(sc);
4107 		if (m != NULL) {
4108 			wh = mtod(m, struct ieee80211_frame *);
4109 			ni = ieee80211_find_rxnode(ic,
4110 			    (struct ieee80211_frame_min *)wh);
4111 			if (ni != NULL) {
4112 				(void) ieee80211_input(ni, m, rssi, nf);
4113 				/* node is no longer needed */
4114 				ieee80211_free_node(ni);
4115 			} else
4116 				(void) ieee80211_input_all(ic, m, rssi, nf);
4117 			m = NULL;
4118 		}
4119 		URTW_LOCK(sc);
4120 		break;
4121 	default:
4122 		/* needs it to the inactive queue due to a error.  */
4123 		data = STAILQ_FIRST(&sc->sc_rx_active);
4124 		if (data != NULL) {
4125 			STAILQ_REMOVE_HEAD(&sc->sc_rx_active, next);
4126 			STAILQ_INSERT_TAIL(&sc->sc_rx_inactive, data, next);
4127 		}
4128 		if (error != USB_ERR_CANCELLED) {
4129 			usbd_xfer_set_stall(xfer);
4130 			ifp->if_ierrors++;
4131 			goto setup;
4132 		}
4133 		break;
4134 	}
4135 }
4136 
4137 #define	URTW_STATUS_TYPE_TXCLOSE	1
4138 #define	URTW_STATUS_TYPE_BEACON_INTR	0
4139 
4140 static void
4141 urtw_txstatus_eof(struct usb_xfer *xfer)
4142 {
4143 	struct urtw_softc *sc = usbd_xfer_softc(xfer);
4144 	struct ifnet *ifp = sc->sc_ifp;
4145 	int actlen, type, pktretry, seq;
4146 	uint64_t val;
4147 
4148 	usbd_xfer_status(xfer, &actlen, NULL, NULL, NULL);
4149 
4150 	if (actlen != sizeof(uint64_t))
4151 		return;
4152 
4153 	val = le64toh(sc->sc_txstatus);
4154 	type = (val >> 30) & 0x3;
4155 	if (type == URTW_STATUS_TYPE_TXCLOSE) {
4156 		pktretry = val & 0xff;
4157 		seq = (val >> 16) & 0xff;
4158 		if (pktretry == URTW_TX_MAXRETRY)
4159 			ifp->if_oerrors++;
4160 		DPRINTF(sc, URTW_DEBUG_TXSTATUS, "pktretry %d seq %#x\n",
4161 		    pktretry, seq);
4162 	}
4163 }
4164 
4165 static void
4166 urtw_bulk_tx_status_callback(struct usb_xfer *xfer, usb_error_t error)
4167 {
4168 	struct urtw_softc *sc = usbd_xfer_softc(xfer);
4169 	struct ifnet *ifp = sc->sc_ifp;
4170 	void *dma_buf = usbd_xfer_get_frame_buffer(xfer, 0);
4171 
4172 	URTW_ASSERT_LOCKED(sc);
4173 
4174 	switch (USB_GET_STATE(xfer)) {
4175 	case USB_ST_TRANSFERRED:
4176 		urtw_txstatus_eof(xfer);
4177 		/* FALLTHROUGH */
4178 	case USB_ST_SETUP:
4179 setup:
4180 		memcpy(dma_buf, &sc->sc_txstatus, sizeof(uint64_t));
4181 		usbd_xfer_set_frame_len(xfer, 0, sizeof(uint64_t));
4182 		usbd_transfer_submit(xfer);
4183 		break;
4184 	default:
4185 		if (error != USB_ERR_CANCELLED) {
4186 			usbd_xfer_set_stall(xfer);
4187 			ifp->if_ierrors++;
4188 			goto setup;
4189 		}
4190 		break;
4191 	}
4192 }
4193 
4194 static void
4195 urtw_txeof(struct usb_xfer *xfer, struct urtw_data *data)
4196 {
4197 	struct urtw_softc *sc = usbd_xfer_softc(xfer);
4198 	struct ifnet *ifp = sc->sc_ifp;
4199 	struct mbuf *m;
4200 
4201 	URTW_ASSERT_LOCKED(sc);
4202 
4203 	/*
4204 	 * Do any tx complete callback.  Note this must be done before releasing
4205 	 * the node reference.
4206 	 */
4207 	if (data->m) {
4208 		m = data->m;
4209 		if (m->m_flags & M_TXCB) {
4210 			/* XXX status? */
4211 			ieee80211_process_callback(data->ni, m, 0);
4212 		}
4213 		m_freem(m);
4214 		data->m = NULL;
4215 	}
4216 	if (data->ni) {
4217 		ieee80211_free_node(data->ni);
4218 		data->ni = NULL;
4219 	}
4220 	sc->sc_txtimer = 0;
4221 	ifp->if_opackets++;
4222 	ifp->if_drv_flags &= ~IFF_DRV_OACTIVE;
4223 }
4224 
4225 static void
4226 urtw_bulk_tx_callback(struct usb_xfer *xfer, usb_error_t error)
4227 {
4228 	struct urtw_softc *sc = usbd_xfer_softc(xfer);
4229 	struct ifnet *ifp = sc->sc_ifp;
4230 	struct urtw_data *data;
4231 
4232 	URTW_ASSERT_LOCKED(sc);
4233 
4234 	switch (USB_GET_STATE(xfer)) {
4235 	case USB_ST_TRANSFERRED:
4236 		data = STAILQ_FIRST(&sc->sc_tx_active);
4237 		if (data == NULL)
4238 			goto setup;
4239 		STAILQ_REMOVE_HEAD(&sc->sc_tx_active, next);
4240 		urtw_txeof(xfer, data);
4241 		STAILQ_INSERT_TAIL(&sc->sc_tx_inactive, data, next);
4242 		/* FALLTHROUGH */
4243 	case USB_ST_SETUP:
4244 setup:
4245 		data = STAILQ_FIRST(&sc->sc_tx_pending);
4246 		if (data == NULL) {
4247 			DPRINTF(sc, URTW_DEBUG_XMIT,
4248 			    "%s: empty pending queue\n", __func__);
4249 			return;
4250 		}
4251 		STAILQ_REMOVE_HEAD(&sc->sc_tx_pending, next);
4252 		STAILQ_INSERT_TAIL(&sc->sc_tx_active, data, next);
4253 
4254 		usbd_xfer_set_frame_data(xfer, 0, data->buf, data->buflen);
4255 		usbd_transfer_submit(xfer);
4256 
4257 		URTW_UNLOCK(sc);
4258 		urtw_start(ifp);
4259 		URTW_LOCK(sc);
4260 		break;
4261 	default:
4262 		data = STAILQ_FIRST(&sc->sc_tx_active);
4263 		if (data == NULL)
4264 			goto setup;
4265 		if (data->ni != NULL) {
4266 			ieee80211_free_node(data->ni);
4267 			data->ni = NULL;
4268 			ifp->if_oerrors++;
4269 		}
4270 		if (error != USB_ERR_CANCELLED) {
4271 			usbd_xfer_set_stall(xfer);
4272 			goto setup;
4273 		}
4274 		break;
4275 	}
4276 }
4277 
4278 static struct urtw_data *
4279 _urtw_getbuf(struct urtw_softc *sc)
4280 {
4281 	struct urtw_data *bf;
4282 
4283 	bf = STAILQ_FIRST(&sc->sc_tx_inactive);
4284 	if (bf != NULL)
4285 		STAILQ_REMOVE_HEAD(&sc->sc_tx_inactive, next);
4286 	else
4287 		bf = NULL;
4288 	if (bf == NULL)
4289 		DPRINTF(sc, URTW_DEBUG_XMIT, "%s: %s\n", __func__,
4290 		    "out of xmit buffers");
4291 	return (bf);
4292 }
4293 
4294 static struct urtw_data *
4295 urtw_getbuf(struct urtw_softc *sc)
4296 {
4297 	struct urtw_data *bf;
4298 
4299 	URTW_ASSERT_LOCKED(sc);
4300 
4301 	bf = _urtw_getbuf(sc);
4302 	if (bf == NULL) {
4303 		struct ifnet *ifp = sc->sc_ifp;
4304 
4305 		DPRINTF(sc, URTW_DEBUG_XMIT, "%s: stop queue\n", __func__);
4306 		ifp->if_drv_flags |= IFF_DRV_OACTIVE;
4307 	}
4308 	return (bf);
4309 }
4310 
4311 static int
4312 urtw_isbmode(uint16_t rate)
4313 {
4314 
4315 	return ((rate <= 22 && rate != 12 && rate != 18) ||
4316 	    rate == 44) ? (1) : (0);
4317 }
4318 
4319 static uint16_t
4320 urtw_rate2dbps(uint16_t rate)
4321 {
4322 
4323 	switch(rate) {
4324 	case 12:
4325 	case 18:
4326 	case 24:
4327 	case 36:
4328 	case 48:
4329 	case 72:
4330 	case 96:
4331 	case 108:
4332 		return (rate * 2);
4333 	default:
4334 		break;
4335 	}
4336 	return (24);
4337 }
4338 
4339 static int
4340 urtw_compute_txtime(uint16_t framelen, uint16_t rate,
4341     uint8_t ismgt, uint8_t isshort)
4342 {
4343 	uint16_t     ceiling, frametime, n_dbps;
4344 
4345 	if (urtw_isbmode(rate)) {
4346 		if (ismgt || !isshort || rate == 2)
4347 			frametime = (uint16_t)(144 + 48 +
4348 			    (framelen * 8 / (rate / 2)));
4349 		else
4350 			frametime = (uint16_t)(72 + 24 +
4351 			    (framelen * 8 / (rate / 2)));
4352 		if ((framelen * 8 % (rate / 2)) != 0)
4353 			frametime++;
4354 	} else {
4355 		n_dbps = urtw_rate2dbps(rate);
4356 		ceiling = (16 + 8 * framelen + 6) / n_dbps
4357 		    + (((16 + 8 * framelen + 6) % n_dbps) ? 1 : 0);
4358 		frametime = (uint16_t)(16 + 4 + 4 * ceiling + 6);
4359 	}
4360 	return (frametime);
4361 }
4362 
4363 /*
4364  * Callback from the 802.11 layer to update the
4365  * slot time based on the current setting.
4366  */
4367 static void
4368 urtw_updateslot(struct ifnet *ifp)
4369 {
4370 	struct urtw_softc *sc = ifp->if_softc;
4371 	struct ieee80211com *ic = ifp->if_l2com;
4372 
4373 	ieee80211_runtask(ic, &sc->sc_updateslot_task);
4374 }
4375 
4376 static void
4377 urtw_updateslottask(void *arg, int pending)
4378 {
4379 	struct urtw_softc *sc = arg;
4380 	struct ifnet *ifp = sc->sc_ifp;
4381 	struct ieee80211com *ic = ifp->if_l2com;
4382 	int error;
4383 
4384 	if ((ifp->if_drv_flags & IFF_DRV_RUNNING) == 0)
4385 		return;
4386 
4387 	URTW_LOCK(sc);
4388 	if (sc->sc_flags & URTW_RTL8187B) {
4389 		urtw_write8_m(sc, URTW_SIFS, 0x22);
4390 		if (IEEE80211_IS_CHAN_ANYG(ic->ic_curchan))
4391 			urtw_write8_m(sc, URTW_SLOT, 0x9);
4392 		else
4393 			urtw_write8_m(sc, URTW_SLOT, 0x14);
4394 		urtw_write8_m(sc, URTW_8187B_EIFS, 0x5b);
4395 		urtw_write8_m(sc, URTW_CARRIER_SCOUNT, 0x5b);
4396 	} else {
4397 		urtw_write8_m(sc, URTW_SIFS, 0x22);
4398 		if (sc->sc_state == IEEE80211_S_ASSOC &&
4399 		    ic->ic_flags & IEEE80211_F_SHSLOT)
4400 			urtw_write8_m(sc, URTW_SLOT, 0x9);
4401 		else
4402 			urtw_write8_m(sc, URTW_SLOT, 0x14);
4403 		if (IEEE80211_IS_CHAN_ANYG(ic->ic_curchan)) {
4404 			urtw_write8_m(sc, URTW_DIFS, 0x14);
4405 			urtw_write8_m(sc, URTW_EIFS, 0x5b - 0x14);
4406 			urtw_write8_m(sc, URTW_CW_VAL, 0x73);
4407 		} else {
4408 			urtw_write8_m(sc, URTW_DIFS, 0x24);
4409 			urtw_write8_m(sc, URTW_EIFS, 0x5b - 0x24);
4410 			urtw_write8_m(sc, URTW_CW_VAL, 0xa5);
4411 		}
4412 	}
4413 fail:
4414 	URTW_UNLOCK(sc);
4415 }
4416 
4417 static void
4418 urtw_sysctl_node(struct urtw_softc *sc)
4419 {
4420 #define	URTW_SYSCTL_STAT_ADD32(c, h, n, p, d)	\
4421 	SYSCTL_ADD_UINT(c, h, OID_AUTO, n, CTLFLAG_RD, p, 0, d)
4422 	struct sysctl_ctx_list *ctx;
4423 	struct sysctl_oid_list *child, *parent;
4424 	struct sysctl_oid *tree;
4425 	struct urtw_stats *stats = &sc->sc_stats;
4426 
4427 	ctx = device_get_sysctl_ctx(sc->sc_dev);
4428 	child = SYSCTL_CHILDREN(device_get_sysctl_tree(sc->sc_dev));
4429 
4430 	tree = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, "stats", CTLFLAG_RD,
4431 	    NULL, "URTW statistics");
4432 	parent = SYSCTL_CHILDREN(tree);
4433 
4434 	/* Tx statistics. */
4435 	tree = SYSCTL_ADD_NODE(ctx, parent, OID_AUTO, "tx", CTLFLAG_RD,
4436 	    NULL, "Tx MAC statistics");
4437 	child = SYSCTL_CHILDREN(tree);
4438 	URTW_SYSCTL_STAT_ADD32(ctx, child, "1m", &stats->txrates[0],
4439 	    "1 Mbit/s");
4440 	URTW_SYSCTL_STAT_ADD32(ctx, child, "2m", &stats->txrates[1],
4441 	    "2 Mbit/s");
4442 	URTW_SYSCTL_STAT_ADD32(ctx, child, "5.5m", &stats->txrates[2],
4443 	    "5.5 Mbit/s");
4444 	URTW_SYSCTL_STAT_ADD32(ctx, child, "6m", &stats->txrates[4],
4445 	    "6 Mbit/s");
4446 	URTW_SYSCTL_STAT_ADD32(ctx, child, "9m", &stats->txrates[5],
4447 	    "9 Mbit/s");
4448 	URTW_SYSCTL_STAT_ADD32(ctx, child, "11m", &stats->txrates[3],
4449 	    "11 Mbit/s");
4450 	URTW_SYSCTL_STAT_ADD32(ctx, child, "12m", &stats->txrates[6],
4451 	    "12 Mbit/s");
4452 	URTW_SYSCTL_STAT_ADD32(ctx, child, "18m", &stats->txrates[7],
4453 	    "18 Mbit/s");
4454 	URTW_SYSCTL_STAT_ADD32(ctx, child, "24m", &stats->txrates[8],
4455 	    "24 Mbit/s");
4456 	URTW_SYSCTL_STAT_ADD32(ctx, child, "36m", &stats->txrates[9],
4457 	    "36 Mbit/s");
4458 	URTW_SYSCTL_STAT_ADD32(ctx, child, "48m", &stats->txrates[10],
4459 	    "48 Mbit/s");
4460 	URTW_SYSCTL_STAT_ADD32(ctx, child, "54m", &stats->txrates[11],
4461 	    "54 Mbit/s");
4462 #undef URTW_SYSCTL_STAT_ADD32
4463 }
4464 
4465 static device_method_t urtw_methods[] = {
4466 	DEVMETHOD(device_probe, urtw_match),
4467 	DEVMETHOD(device_attach, urtw_attach),
4468 	DEVMETHOD(device_detach, urtw_detach),
4469 	DEVMETHOD_END
4470 };
4471 static driver_t urtw_driver = {
4472 	.name = "urtw",
4473 	.methods = urtw_methods,
4474 	.size = sizeof(struct urtw_softc)
4475 };
4476 static devclass_t urtw_devclass;
4477 
4478 DRIVER_MODULE(urtw, uhub, urtw_driver, urtw_devclass, NULL, 0);
4479 MODULE_DEPEND(urtw, wlan, 1, 1, 1);
4480 MODULE_DEPEND(urtw, usb, 1, 1, 1);
4481 MODULE_VERSION(urtw, 1);
4482