xref: /freebsd/sys/dev/usb/wlan/if_run.c (revision 19261079b74319502c6ffa1249920079f0f69a72)
1 /*-
2  * Copyright (c) 2008,2010 Damien Bergamini <damien.bergamini@free.fr>
3  * ported to FreeBSD by Akinori Furukoshi <moonlightakkiy@yahoo.ca>
4  * USB Consulting, Hans Petter Selasky <hselasky@freebsd.org>
5  * Copyright (c) 2013-2014 Kevin Lo
6  *
7  * Permission to use, copy, modify, and distribute this software for any
8  * purpose with or without fee is hereby granted, provided that the above
9  * copyright notice and this permission notice appear in all copies.
10  *
11  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
12  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
13  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
14  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18  */
19 
20 #include <sys/cdefs.h>
21 __FBSDID("$FreeBSD$");
22 
23 /*-
24  * Ralink Technology RT2700U/RT2800U/RT3000U/RT3900E chipset driver.
25  * http://www.ralinktech.com/
26  */
27 
28 #include "opt_wlan.h"
29 
30 #include <sys/param.h>
31 #include <sys/eventhandler.h>
32 #include <sys/sockio.h>
33 #include <sys/sysctl.h>
34 #include <sys/lock.h>
35 #include <sys/mutex.h>
36 #include <sys/mbuf.h>
37 #include <sys/kernel.h>
38 #include <sys/socket.h>
39 #include <sys/systm.h>
40 #include <sys/malloc.h>
41 #include <sys/module.h>
42 #include <sys/bus.h>
43 #include <sys/endian.h>
44 #include <sys/linker.h>
45 #include <sys/firmware.h>
46 #include <sys/kdb.h>
47 
48 #include <net/bpf.h>
49 #include <net/if.h>
50 #include <net/if_var.h>
51 #include <net/if_arp.h>
52 #include <net/ethernet.h>
53 #include <net/if_dl.h>
54 #include <net/if_media.h>
55 #include <net/if_types.h>
56 
57 #include <netinet/in.h>
58 #include <netinet/in_systm.h>
59 #include <netinet/in_var.h>
60 #include <netinet/if_ether.h>
61 #include <netinet/ip.h>
62 
63 #include <net80211/ieee80211_var.h>
64 #include <net80211/ieee80211_regdomain.h>
65 #include <net80211/ieee80211_radiotap.h>
66 #include <net80211/ieee80211_ratectl.h>
67 #ifdef	IEEE80211_SUPPORT_SUPERG
68 #include <net80211/ieee80211_superg.h>
69 #endif
70 
71 #include <dev/usb/usb.h>
72 #include <dev/usb/usbdi.h>
73 #include "usbdevs.h"
74 
75 #define	USB_DEBUG_VAR	run_debug
76 #include <dev/usb/usb_debug.h>
77 #include <dev/usb/usb_msctest.h>
78 
79 #include <dev/usb/wlan/if_runreg.h>
80 #include <dev/usb/wlan/if_runvar.h>
81 
82 #ifdef	USB_DEBUG
83 #define	RUN_DEBUG
84 #endif
85 
86 #ifdef	RUN_DEBUG
87 int run_debug = 0;
88 static SYSCTL_NODE(_hw_usb, OID_AUTO, run, CTLFLAG_RW | CTLFLAG_MPSAFE, 0,
89     "USB run");
90 SYSCTL_INT(_hw_usb_run, OID_AUTO, debug, CTLFLAG_RWTUN, &run_debug, 0,
91     "run debug level");
92 
93 enum {
94 	RUN_DEBUG_XMIT		= 0x00000001,	/* basic xmit operation */
95 	RUN_DEBUG_XMIT_DESC	= 0x00000002,	/* xmit descriptors */
96 	RUN_DEBUG_RECV		= 0x00000004,	/* basic recv operation */
97 	RUN_DEBUG_RECV_DESC	= 0x00000008,	/* recv descriptors */
98 	RUN_DEBUG_STATE		= 0x00000010,	/* 802.11 state transitions */
99 	RUN_DEBUG_RATE		= 0x00000020,	/* rate adaptation */
100 	RUN_DEBUG_USB		= 0x00000040,	/* usb requests */
101 	RUN_DEBUG_FIRMWARE	= 0x00000080,	/* firmware(9) loading debug */
102 	RUN_DEBUG_BEACON	= 0x00000100,	/* beacon handling */
103 	RUN_DEBUG_INTR		= 0x00000200,	/* ISR */
104 	RUN_DEBUG_TEMP		= 0x00000400,	/* temperature calibration */
105 	RUN_DEBUG_ROM		= 0x00000800,	/* various ROM info */
106 	RUN_DEBUG_KEY		= 0x00001000,	/* crypto keys management */
107 	RUN_DEBUG_TXPWR		= 0x00002000,	/* dump Tx power values */
108 	RUN_DEBUG_RSSI		= 0x00004000,	/* dump RSSI lookups */
109 	RUN_DEBUG_RESET		= 0x00008000,	/* initialization progress */
110 	RUN_DEBUG_CALIB		= 0x00010000,	/* calibration progress */
111 	RUN_DEBUG_CMD		= 0x00020000,	/* command queue */
112 	RUN_DEBUG_ANY		= 0xffffffff
113 };
114 
115 #define RUN_DPRINTF(_sc, _m, ...) do {			\
116 	if (run_debug & (_m))				\
117 		device_printf((_sc)->sc_dev, __VA_ARGS__);	\
118 } while(0)
119 #else
120 #define RUN_DPRINTF(_sc, _m, ...)	do { (void) _sc; } while (0)
121 #endif
122 
123 #define	IEEE80211_HAS_ADDR4(wh)	IEEE80211_IS_DSTODS(wh)
124 
125 /*
126  * Because of LOR in run_key_delete(), use atomic instead.
127  * '& RUN_CMDQ_MASQ' is to loop cmdq[].
128  */
129 #define	RUN_CMDQ_GET(c)	(atomic_fetchadd_32((c), 1) & RUN_CMDQ_MASQ)
130 
131 static const STRUCT_USB_HOST_ID run_devs[] = {
132 #define	RUN_DEV(v,p)	{ USB_VP(USB_VENDOR_##v, USB_PRODUCT_##v##_##p) }
133 #define	RUN_DEV_EJECT(v,p)	\
134 	{ USB_VPI(USB_VENDOR_##v, USB_PRODUCT_##v##_##p, RUN_EJECT) }
135 #define	RUN_EJECT	1
136     RUN_DEV(ABOCOM,		RT2770),
137     RUN_DEV(ABOCOM,		RT2870),
138     RUN_DEV(ABOCOM,		RT3070),
139     RUN_DEV(ABOCOM,		RT3071),
140     RUN_DEV(ABOCOM,		RT3072),
141     RUN_DEV(ABOCOM2,		RT2870_1),
142     RUN_DEV(ACCTON,		RT2770),
143     RUN_DEV(ACCTON,		RT2870_1),
144     RUN_DEV(ACCTON,		RT2870_2),
145     RUN_DEV(ACCTON,		RT2870_3),
146     RUN_DEV(ACCTON,		RT2870_4),
147     RUN_DEV(ACCTON,		RT2870_5),
148     RUN_DEV(ACCTON,		RT3070),
149     RUN_DEV(ACCTON,		RT3070_1),
150     RUN_DEV(ACCTON,		RT3070_2),
151     RUN_DEV(ACCTON,		RT3070_3),
152     RUN_DEV(ACCTON,		RT3070_4),
153     RUN_DEV(ACCTON,		RT3070_5),
154     RUN_DEV(AIRTIES,		RT3070),
155     RUN_DEV(ALLWIN,		RT2070),
156     RUN_DEV(ALLWIN,		RT2770),
157     RUN_DEV(ALLWIN,		RT2870),
158     RUN_DEV(ALLWIN,		RT3070),
159     RUN_DEV(ALLWIN,		RT3071),
160     RUN_DEV(ALLWIN,		RT3072),
161     RUN_DEV(ALLWIN,		RT3572),
162     RUN_DEV(AMIGO,		RT2870_1),
163     RUN_DEV(AMIGO,		RT2870_2),
164     RUN_DEV(AMIT,		CGWLUSB2GNR),
165     RUN_DEV(AMIT,		RT2870_1),
166     RUN_DEV(AMIT2,		RT2870),
167     RUN_DEV(ASUS,		RT2870_1),
168     RUN_DEV(ASUS,		RT2870_2),
169     RUN_DEV(ASUS,		RT2870_3),
170     RUN_DEV(ASUS,		RT2870_4),
171     RUN_DEV(ASUS,		RT2870_5),
172     RUN_DEV(ASUS,		USBN13),
173     RUN_DEV(ASUS,		RT3070_1),
174     RUN_DEV(ASUS,		USBN66),
175     RUN_DEV(ASUS,		USB_N53),
176     RUN_DEV(ASUS,		USBN14),
177     RUN_DEV(ASUS2,		USBN11),
178     RUN_DEV(AZUREWAVE,		RT2870_1),
179     RUN_DEV(AZUREWAVE,		RT2870_2),
180     RUN_DEV(AZUREWAVE,		RT3070_1),
181     RUN_DEV(AZUREWAVE,		RT3070_2),
182     RUN_DEV(AZUREWAVE,		RT3070_3),
183     RUN_DEV(BELKIN,		F9L1103),
184     RUN_DEV(BELKIN,		F5D8053V3),
185     RUN_DEV(BELKIN,		F5D8055),
186     RUN_DEV(BELKIN,		F5D8055V2),
187     RUN_DEV(BELKIN,		F6D4050V1),
188     RUN_DEV(BELKIN,		F6D4050V2),
189     RUN_DEV(BELKIN,		RT2870_1),
190     RUN_DEV(BELKIN,		RT2870_2),
191     RUN_DEV(CISCOLINKSYS,	AE1000),
192     RUN_DEV(CISCOLINKSYS2,	RT3070),
193     RUN_DEV(CISCOLINKSYS3,	RT3070),
194     RUN_DEV(CONCEPTRONIC2,	RT2870_1),
195     RUN_DEV(CONCEPTRONIC2,	RT2870_2),
196     RUN_DEV(CONCEPTRONIC2,	RT2870_3),
197     RUN_DEV(CONCEPTRONIC2,	RT2870_4),
198     RUN_DEV(CONCEPTRONIC2,	RT2870_5),
199     RUN_DEV(CONCEPTRONIC2,	RT2870_6),
200     RUN_DEV(CONCEPTRONIC2,	RT2870_7),
201     RUN_DEV(CONCEPTRONIC2,	RT2870_8),
202     RUN_DEV(CONCEPTRONIC2,	RT3070_1),
203     RUN_DEV(CONCEPTRONIC2,	RT3070_2),
204     RUN_DEV(CONCEPTRONIC2,	VIGORN61),
205     RUN_DEV(COREGA,		CGWLUSB300GNM),
206     RUN_DEV(COREGA,		RT2870_1),
207     RUN_DEV(COREGA,		RT2870_2),
208     RUN_DEV(COREGA,		RT2870_3),
209     RUN_DEV(COREGA,		RT3070),
210     RUN_DEV(CYBERTAN,		RT2870),
211     RUN_DEV(DLINK,		RT2870),
212     RUN_DEV(DLINK,		RT3072),
213     RUN_DEV(DLINK,		DWA125A3),
214     RUN_DEV(DLINK,		DWA127),
215     RUN_DEV(DLINK,		DWA140B3),
216     RUN_DEV(DLINK,		DWA160B2),
217     RUN_DEV(DLINK,		DWA140D1),
218     RUN_DEV(DLINK,		DWA130F1),
219     RUN_DEV(DLINK,		DWA162),
220     RUN_DEV(DLINK2,		DWA130),
221     RUN_DEV(DLINK2,		RT2870_1),
222     RUN_DEV(DLINK2,		RT2870_2),
223     RUN_DEV(DLINK2,		RT3070_1),
224     RUN_DEV(DLINK2,		RT3070_2),
225     RUN_DEV(DLINK2,		RT3070_3),
226     RUN_DEV(DLINK2,		RT3070_4),
227     RUN_DEV(DLINK2,		RT3070_5),
228     RUN_DEV(DLINK2,		RT3072),
229     RUN_DEV(DLINK2,		RT3072_1),
230     RUN_DEV(EDIMAX,		EW7717),
231     RUN_DEV(EDIMAX,		EW7718),
232     RUN_DEV(EDIMAX,		EW7733UND),
233     RUN_DEV(EDIMAX,		RT2870_1),
234     RUN_DEV(ENCORE,		RT3070_1),
235     RUN_DEV(ENCORE,		RT3070_2),
236     RUN_DEV(ENCORE,		RT3070_3),
237     RUN_DEV(GIGABYTE,		GNWB31N),
238     RUN_DEV(GIGABYTE,		GNWB32L),
239     RUN_DEV(GIGABYTE,		RT2870_1),
240     RUN_DEV(GIGASET,		RT3070_1),
241     RUN_DEV(GIGASET,		RT3070_2),
242     RUN_DEV(GUILLEMOT,		HWNU300),
243     RUN_DEV(HAWKING,		HWUN2),
244     RUN_DEV(HAWKING,		RT2870_1),
245     RUN_DEV(HAWKING,		RT2870_2),
246     RUN_DEV(HAWKING,		RT3070),
247     RUN_DEV(IODATA,		RT3072_1),
248     RUN_DEV(IODATA,		RT3072_2),
249     RUN_DEV(IODATA,		RT3072_3),
250     RUN_DEV(IODATA,		RT3072_4),
251     RUN_DEV(LINKSYS4,		RT3070),
252     RUN_DEV(LINKSYS4,		WUSB100),
253     RUN_DEV(LINKSYS4,		WUSB54GCV3),
254     RUN_DEV(LINKSYS4,		WUSB600N),
255     RUN_DEV(LINKSYS4,		WUSB600NV2),
256     RUN_DEV(LOGITEC,		RT2870_1),
257     RUN_DEV(LOGITEC,		RT2870_2),
258     RUN_DEV(LOGITEC,		RT2870_3),
259     RUN_DEV(LOGITEC,		LANW300NU2),
260     RUN_DEV(LOGITEC,		LANW150NU2),
261     RUN_DEV(LOGITEC,		LANW300NU2S),
262     RUN_DEV(MELCO,		WLIUCG300HP),
263     RUN_DEV(MELCO,		RT2870_2),
264     RUN_DEV(MELCO,		WLIUCAG300N),
265     RUN_DEV(MELCO,		WLIUCG300N),
266     RUN_DEV(MELCO,		WLIUCG301N),
267     RUN_DEV(MELCO,		WLIUCGN),
268     RUN_DEV(MELCO,		WLIUCGNM),
269     RUN_DEV(MELCO,		WLIUCG300HPV1),
270     RUN_DEV(MELCO,		WLIUCGNM2),
271     RUN_DEV(MOTOROLA4,		RT2770),
272     RUN_DEV(MOTOROLA4,		RT3070),
273     RUN_DEV(MSI,		RT3070_1),
274     RUN_DEV(MSI,		RT3070_2),
275     RUN_DEV(MSI,		RT3070_3),
276     RUN_DEV(MSI,		RT3070_4),
277     RUN_DEV(MSI,		RT3070_5),
278     RUN_DEV(MSI,		RT3070_6),
279     RUN_DEV(MSI,		RT3070_7),
280     RUN_DEV(MSI,		RT3070_8),
281     RUN_DEV(MSI,		RT3070_9),
282     RUN_DEV(MSI,		RT3070_10),
283     RUN_DEV(MSI,		RT3070_11),
284     RUN_DEV(NETGEAR,		WNDA4100),
285     RUN_DEV(OVISLINK,		RT3072),
286     RUN_DEV(PARA,		RT3070),
287     RUN_DEV(PEGATRON,		RT2870),
288     RUN_DEV(PEGATRON,		RT3070),
289     RUN_DEV(PEGATRON,		RT3070_2),
290     RUN_DEV(PEGATRON,		RT3070_3),
291     RUN_DEV(PHILIPS,		RT2870),
292     RUN_DEV(PLANEX2,		GWUS300MINIS),
293     RUN_DEV(PLANEX2,		GWUSMICRON),
294     RUN_DEV(PLANEX2,		RT2870),
295     RUN_DEV(PLANEX2,		RT3070),
296     RUN_DEV(QCOM,		RT2870),
297     RUN_DEV(QUANTA,		RT3070),
298     RUN_DEV(RALINK,		RT2070),
299     RUN_DEV(RALINK,		RT2770),
300     RUN_DEV(RALINK,		RT2870),
301     RUN_DEV(RALINK,		RT3070),
302     RUN_DEV(RALINK,		RT3071),
303     RUN_DEV(RALINK,		RT3072),
304     RUN_DEV(RALINK,		RT3370),
305     RUN_DEV(RALINK,		RT3572),
306     RUN_DEV(RALINK,		RT3573),
307     RUN_DEV(RALINK,		RT5370),
308     RUN_DEV(RALINK,		RT5372),
309     RUN_DEV(RALINK,		RT5572),
310     RUN_DEV(RALINK,		RT8070),
311     RUN_DEV(SAMSUNG,		WIS09ABGN),
312     RUN_DEV(SAMSUNG2,		RT2870_1),
313     RUN_DEV(SENAO,		RT2870_1),
314     RUN_DEV(SENAO,		RT2870_2),
315     RUN_DEV(SENAO,		RT2870_3),
316     RUN_DEV(SENAO,		RT2870_4),
317     RUN_DEV(SENAO,		RT3070),
318     RUN_DEV(SENAO,		RT3071),
319     RUN_DEV(SENAO,		RT3072_1),
320     RUN_DEV(SENAO,		RT3072_2),
321     RUN_DEV(SENAO,		RT3072_3),
322     RUN_DEV(SENAO,		RT3072_4),
323     RUN_DEV(SENAO,		RT3072_5),
324     RUN_DEV(SITECOMEU,		RT2770),
325     RUN_DEV(SITECOMEU,		RT2870_1),
326     RUN_DEV(SITECOMEU,		RT2870_2),
327     RUN_DEV(SITECOMEU,		RT2870_3),
328     RUN_DEV(SITECOMEU,		RT2870_4),
329     RUN_DEV(SITECOMEU,		RT3070),
330     RUN_DEV(SITECOMEU,		RT3070_2),
331     RUN_DEV(SITECOMEU,		RT3070_3),
332     RUN_DEV(SITECOMEU,		RT3070_4),
333     RUN_DEV(SITECOMEU,		RT3071),
334     RUN_DEV(SITECOMEU,		RT3072_1),
335     RUN_DEV(SITECOMEU,		RT3072_2),
336     RUN_DEV(SITECOMEU,		RT3072_3),
337     RUN_DEV(SITECOMEU,		RT3072_4),
338     RUN_DEV(SITECOMEU,		RT3072_5),
339     RUN_DEV(SITECOMEU,		RT3072_6),
340     RUN_DEV(SITECOMEU,		WL608),
341     RUN_DEV(SPARKLAN,		RT2870_1),
342     RUN_DEV(SPARKLAN,		RT3070),
343     RUN_DEV(SWEEX2,		LW153),
344     RUN_DEV(SWEEX2,		LW303),
345     RUN_DEV(SWEEX2,		LW313),
346     RUN_DEV(TOSHIBA,		RT3070),
347     RUN_DEV(UMEDIA,		RT2870_1),
348     RUN_DEV(ZCOM,		RT2870_1),
349     RUN_DEV(ZCOM,		RT2870_2),
350     RUN_DEV(ZINWELL,		RT2870_1),
351     RUN_DEV(ZINWELL,		RT2870_2),
352     RUN_DEV(ZINWELL,		RT3070),
353     RUN_DEV(ZINWELL,		RT3072_1),
354     RUN_DEV(ZINWELL,		RT3072_2),
355     RUN_DEV(ZYXEL,		RT2870_1),
356     RUN_DEV(ZYXEL,		RT2870_2),
357     RUN_DEV(ZYXEL,		RT3070),
358     RUN_DEV_EJECT(ZYXEL,	NWD2705),
359     RUN_DEV_EJECT(RALINK,	RT_STOR),
360 #undef RUN_DEV_EJECT
361 #undef RUN_DEV
362 };
363 
364 static device_probe_t	run_match;
365 static device_attach_t	run_attach;
366 static device_detach_t	run_detach;
367 
368 static usb_callback_t	run_bulk_rx_callback;
369 static usb_callback_t	run_bulk_tx_callback0;
370 static usb_callback_t	run_bulk_tx_callback1;
371 static usb_callback_t	run_bulk_tx_callback2;
372 static usb_callback_t	run_bulk_tx_callback3;
373 static usb_callback_t	run_bulk_tx_callback4;
374 static usb_callback_t	run_bulk_tx_callback5;
375 
376 static void	run_autoinst(void *, struct usb_device *,
377 		    struct usb_attach_arg *);
378 static int	run_driver_loaded(struct module *, int, void *);
379 static void	run_bulk_tx_callbackN(struct usb_xfer *xfer,
380 		    usb_error_t error, u_int index);
381 static struct ieee80211vap *run_vap_create(struct ieee80211com *,
382 		    const char [IFNAMSIZ], int, enum ieee80211_opmode, int,
383 		    const uint8_t [IEEE80211_ADDR_LEN],
384 		    const uint8_t [IEEE80211_ADDR_LEN]);
385 static void	run_vap_delete(struct ieee80211vap *);
386 static void	run_cmdq_cb(void *, int);
387 static void	run_setup_tx_list(struct run_softc *,
388 		    struct run_endpoint_queue *);
389 static void	run_unsetup_tx_list(struct run_softc *,
390 		    struct run_endpoint_queue *);
391 static int	run_load_microcode(struct run_softc *);
392 static int	run_reset(struct run_softc *);
393 static usb_error_t run_do_request(struct run_softc *,
394 		    struct usb_device_request *, void *);
395 static int	run_read(struct run_softc *, uint16_t, uint32_t *);
396 static int	run_read_region_1(struct run_softc *, uint16_t, uint8_t *, int);
397 static int	run_write_2(struct run_softc *, uint16_t, uint16_t);
398 static int	run_write(struct run_softc *, uint16_t, uint32_t);
399 static int	run_write_region_1(struct run_softc *, uint16_t,
400 		    const uint8_t *, int);
401 static int	run_set_region_4(struct run_softc *, uint16_t, uint32_t, int);
402 static int	run_efuse_read(struct run_softc *, uint16_t, uint16_t *, int);
403 static int	run_efuse_read_2(struct run_softc *, uint16_t, uint16_t *);
404 static int	run_eeprom_read_2(struct run_softc *, uint16_t, uint16_t *);
405 static int	run_rt2870_rf_write(struct run_softc *, uint32_t);
406 static int	run_rt3070_rf_read(struct run_softc *, uint8_t, uint8_t *);
407 static int	run_rt3070_rf_write(struct run_softc *, uint8_t, uint8_t);
408 static int	run_bbp_read(struct run_softc *, uint8_t, uint8_t *);
409 static int	run_bbp_write(struct run_softc *, uint8_t, uint8_t);
410 static int	run_mcu_cmd(struct run_softc *, uint8_t, uint16_t);
411 static const char *run_get_rf(uint16_t);
412 static void	run_rt3593_get_txpower(struct run_softc *);
413 static void	run_get_txpower(struct run_softc *);
414 static int	run_read_eeprom(struct run_softc *);
415 static struct ieee80211_node *run_node_alloc(struct ieee80211vap *,
416 			    const uint8_t mac[IEEE80211_ADDR_LEN]);
417 static int	run_media_change(struct ifnet *);
418 static int	run_newstate(struct ieee80211vap *, enum ieee80211_state, int);
419 static int	run_wme_update(struct ieee80211com *);
420 static void	run_key_set_cb(void *);
421 static int	run_key_set(struct ieee80211vap *, struct ieee80211_key *);
422 static void	run_key_delete_cb(void *);
423 static int	run_key_delete(struct ieee80211vap *, struct ieee80211_key *);
424 static void	run_ratectl_to(void *);
425 static void	run_ratectl_cb(void *, int);
426 static void	run_drain_fifo(void *);
427 static void	run_iter_func(void *, struct ieee80211_node *);
428 static void	run_newassoc_cb(void *);
429 static void	run_newassoc(struct ieee80211_node *, int);
430 static void	run_recv_mgmt(struct ieee80211_node *, struct mbuf *, int,
431 		    const struct ieee80211_rx_stats *, int, int);
432 static void	run_rx_frame(struct run_softc *, struct mbuf *, uint32_t);
433 static void	run_tx_free(struct run_endpoint_queue *pq,
434 		    struct run_tx_data *, int);
435 static void	run_set_tx_desc(struct run_softc *, struct run_tx_data *);
436 static int	run_tx(struct run_softc *, struct mbuf *,
437 		    struct ieee80211_node *);
438 static int	run_tx_mgt(struct run_softc *, struct mbuf *,
439 		    struct ieee80211_node *);
440 static int	run_sendprot(struct run_softc *, const struct mbuf *,
441 		    struct ieee80211_node *, int, int);
442 static int	run_tx_param(struct run_softc *, struct mbuf *,
443 		    struct ieee80211_node *,
444 		    const struct ieee80211_bpf_params *);
445 static int	run_raw_xmit(struct ieee80211_node *, struct mbuf *,
446 		    const struct ieee80211_bpf_params *);
447 static int	run_transmit(struct ieee80211com *, struct mbuf *);
448 static void	run_start(struct run_softc *);
449 static void	run_parent(struct ieee80211com *);
450 static void	run_iq_calib(struct run_softc *, u_int);
451 static void	run_set_agc(struct run_softc *, uint8_t);
452 static void	run_select_chan_group(struct run_softc *, int);
453 static void	run_set_rx_antenna(struct run_softc *, int);
454 static void	run_rt2870_set_chan(struct run_softc *, u_int);
455 static void	run_rt3070_set_chan(struct run_softc *, u_int);
456 static void	run_rt3572_set_chan(struct run_softc *, u_int);
457 static void	run_rt3593_set_chan(struct run_softc *, u_int);
458 static void	run_rt5390_set_chan(struct run_softc *, u_int);
459 static void	run_rt5592_set_chan(struct run_softc *, u_int);
460 static int	run_set_chan(struct run_softc *, struct ieee80211_channel *);
461 static void	run_set_channel(struct ieee80211com *);
462 static void	run_getradiocaps(struct ieee80211com *, int, int *,
463 		    struct ieee80211_channel[]);
464 static void	run_scan_start(struct ieee80211com *);
465 static void	run_scan_end(struct ieee80211com *);
466 static void	run_update_beacon(struct ieee80211vap *, int);
467 static void	run_update_beacon_cb(void *);
468 static void	run_updateprot(struct ieee80211com *);
469 static void	run_updateprot_cb(void *);
470 static void	run_usb_timeout_cb(void *);
471 static void	run_reset_livelock(struct run_softc *);
472 static void	run_enable_tsf_sync(struct run_softc *);
473 static void	run_enable_tsf(struct run_softc *);
474 static void	run_disable_tsf(struct run_softc *);
475 static void	run_get_tsf(struct run_softc *, uint64_t *);
476 static void	run_enable_mrr(struct run_softc *);
477 static void	run_set_txpreamble(struct run_softc *);
478 static void	run_set_basicrates(struct run_softc *);
479 static void	run_set_leds(struct run_softc *, uint16_t);
480 static void	run_set_bssid(struct run_softc *, const uint8_t *);
481 static void	run_set_macaddr(struct run_softc *, const uint8_t *);
482 static void	run_updateslot(struct ieee80211com *);
483 static void	run_updateslot_cb(void *);
484 static void	run_update_mcast(struct ieee80211com *);
485 static int8_t	run_rssi2dbm(struct run_softc *, uint8_t, uint8_t);
486 static void	run_update_promisc_locked(struct run_softc *);
487 static void	run_update_promisc(struct ieee80211com *);
488 static void	run_rt5390_bbp_init(struct run_softc *);
489 static int	run_bbp_init(struct run_softc *);
490 static int	run_rt3070_rf_init(struct run_softc *);
491 static void	run_rt3593_rf_init(struct run_softc *);
492 static void	run_rt5390_rf_init(struct run_softc *);
493 static int	run_rt3070_filter_calib(struct run_softc *, uint8_t, uint8_t,
494 		    uint8_t *);
495 static void	run_rt3070_rf_setup(struct run_softc *);
496 static void	run_rt3593_rf_setup(struct run_softc *);
497 static void	run_rt5390_rf_setup(struct run_softc *);
498 static int	run_txrx_enable(struct run_softc *);
499 static void	run_adjust_freq_offset(struct run_softc *);
500 static void	run_init_locked(struct run_softc *);
501 static void	run_stop(void *);
502 static void	run_delay(struct run_softc *, u_int);
503 static void	run_update_chw(struct ieee80211com *ic);
504 static int	run_ampdu_enable(struct ieee80211_node *ni,
505 		    struct ieee80211_tx_ampdu *tap);
506 
507 static eventhandler_tag run_etag;
508 
509 static const struct rt2860_rate {
510 	uint8_t		rate;
511 	uint8_t		mcs;
512 	enum		ieee80211_phytype phy;
513 	uint8_t		ctl_ridx;
514 	uint16_t	sp_ack_dur;
515 	uint16_t	lp_ack_dur;
516 } rt2860_rates[] = {
517 	/* CCK rates (11b) */
518 	{   2, 0, IEEE80211_T_DS,   0, 314, 314 },
519 	{   4, 1, IEEE80211_T_DS,   1, 258, 162 },
520 	{  11, 2, IEEE80211_T_DS,   2, 223, 127 },
521 	{  22, 3, IEEE80211_T_DS,   3, 213, 117 },
522 
523 	/* OFDM rates (11a / 11g) */
524 	{  12, 0, IEEE80211_T_OFDM, 4,  60,  60 },
525 	{  18, 1, IEEE80211_T_OFDM, 4,  52,  52 },
526 	{  24, 2, IEEE80211_T_OFDM, 6,  48,  48 },
527 	{  36, 3, IEEE80211_T_OFDM, 6,  44,  44 },
528 	{  48, 4, IEEE80211_T_OFDM, 8,  44,  44 },
529 	{  72, 5, IEEE80211_T_OFDM, 8,  40,  40 },
530 	{  96, 6, IEEE80211_T_OFDM, 8,  40,  40 },
531 	{ 108, 7, IEEE80211_T_OFDM, 8,  40,  40 },
532 
533 	/* MCS - single stream */
534 	{  0x80, 0, IEEE80211_T_HT, 4, 60, 60 },
535 	{  0x81, 1, IEEE80211_T_HT, 4, 60, 60 },
536 	{  0x82, 2, IEEE80211_T_HT, 4, 60, 60 },
537 	{  0x83, 3, IEEE80211_T_HT, 4, 60, 60 },
538 	{  0x84, 4, IEEE80211_T_HT, 4, 60, 60 },
539 	{  0x85, 5, IEEE80211_T_HT, 4, 60, 60 },
540 	{  0x86, 6, IEEE80211_T_HT, 4, 60, 60 },
541 	{  0x87, 7, IEEE80211_T_HT, 4, 60, 60 },
542 
543 	/* MCS - 2 streams */
544 	{  0x88, 8, IEEE80211_T_HT, 4, 60, 60 },
545 	{  0x89, 9, IEEE80211_T_HT, 4, 60, 60 },
546 	{  0x8a, 10, IEEE80211_T_HT, 4, 60, 60 },
547 	{  0x8b, 11, IEEE80211_T_HT, 4, 60, 60 },
548 	{  0x8c, 12, IEEE80211_T_HT, 4, 60, 60 },
549 	{  0x8d, 13, IEEE80211_T_HT, 4, 60, 60 },
550 	{  0x8e, 14, IEEE80211_T_HT, 4, 60, 60 },
551 	{  0x8f, 15, IEEE80211_T_HT, 4, 60, 60 },
552 
553 	/* MCS - 3 streams */
554 	{  0x90, 16, IEEE80211_T_HT, 4, 60, 60 },
555 	{  0x91, 17, IEEE80211_T_HT, 4, 60, 60 },
556 	{  0x92, 18, IEEE80211_T_HT, 4, 60, 60 },
557 	{  0x93, 19, IEEE80211_T_HT, 4, 60, 60 },
558 	{  0x94, 20, IEEE80211_T_HT, 4, 60, 60 },
559 	{  0x95, 21, IEEE80211_T_HT, 4, 60, 60 },
560 	{  0x96, 22, IEEE80211_T_HT, 4, 60, 60 },
561 	{  0x97, 23, IEEE80211_T_HT, 4, 60, 60 },
562 };
563 
564 /* These are indexes into the above rt2860_rates[] array */
565 #define	RT2860_RIDX_CCK1		0
566 #define	RT2860_RIDX_CCK11		3
567 #define	RT2860_RIDX_OFDM6		4
568 #define	RT2860_RIDX_MCS0		12
569 #define	RT2860_RIDX_MAX			36
570 
571 static const struct {
572 	uint16_t	reg;
573 	uint32_t	val;
574 } rt2870_def_mac[] = {
575 	RT2870_DEF_MAC
576 };
577 
578 static const struct {
579 	uint8_t	reg;
580 	uint8_t	val;
581 } rt2860_def_bbp[] = {
582 	RT2860_DEF_BBP
583 },rt5390_def_bbp[] = {
584 	RT5390_DEF_BBP
585 },rt5592_def_bbp[] = {
586 	RT5592_DEF_BBP
587 };
588 
589 /*
590  * Default values for BBP register R196 for RT5592.
591  */
592 static const uint8_t rt5592_bbp_r196[] = {
593 	0xe0, 0x1f, 0x38, 0x32, 0x08, 0x28, 0x19, 0x0a, 0xff, 0x00,
594 	0x16, 0x10, 0x10, 0x0b, 0x36, 0x2c, 0x26, 0x24, 0x42, 0x36,
595 	0x30, 0x2d, 0x4c, 0x46, 0x3d, 0x40, 0x3e, 0x42, 0x3d, 0x40,
596 	0x3c, 0x34, 0x2c, 0x2f, 0x3c, 0x35, 0x2e, 0x2a, 0x49, 0x41,
597 	0x36, 0x31, 0x30, 0x30, 0x0e, 0x0d, 0x28, 0x21, 0x1c, 0x16,
598 	0x50, 0x4a, 0x43, 0x40, 0x10, 0x10, 0x10, 0x10, 0x00, 0x00,
599 	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
600 	0x00, 0x00, 0x7d, 0x14, 0x32, 0x2c, 0x36, 0x4c, 0x43, 0x2c,
601 	0x2e, 0x36, 0x30, 0x6e
602 };
603 
604 static const struct rfprog {
605 	uint8_t		chan;
606 	uint32_t	r1, r2, r3, r4;
607 } rt2860_rf2850[] = {
608 	RT2860_RF2850
609 };
610 
611 struct {
612 	uint8_t	n, r, k;
613 } rt3070_freqs[] = {
614 	RT3070_RF3052
615 };
616 
617 static const struct rt5592_freqs {
618 	uint16_t	n;
619 	uint8_t		k, m, r;
620 } rt5592_freqs_20mhz[] = {
621 	RT5592_RF5592_20MHZ
622 },rt5592_freqs_40mhz[] = {
623 	RT5592_RF5592_40MHZ
624 };
625 
626 static const struct {
627 	uint8_t	reg;
628 	uint8_t	val;
629 } rt3070_def_rf[] = {
630 	RT3070_DEF_RF
631 },rt3572_def_rf[] = {
632 	RT3572_DEF_RF
633 },rt3593_def_rf[] = {
634 	RT3593_DEF_RF
635 },rt5390_def_rf[] = {
636 	RT5390_DEF_RF
637 },rt5392_def_rf[] = {
638 	RT5392_DEF_RF
639 },rt5592_def_rf[] = {
640 	RT5592_DEF_RF
641 },rt5592_2ghz_def_rf[] = {
642 	RT5592_2GHZ_DEF_RF
643 },rt5592_5ghz_def_rf[] = {
644 	RT5592_5GHZ_DEF_RF
645 };
646 
647 static const struct {
648 	u_int	firstchan;
649 	u_int	lastchan;
650 	uint8_t	reg;
651 	uint8_t	val;
652 } rt5592_chan_5ghz[] = {
653 	RT5592_CHAN_5GHZ
654 };
655 
656 static const struct usb_config run_config[RUN_N_XFER] = {
657     [RUN_BULK_TX_BE] = {
658 	.type = UE_BULK,
659 	.endpoint = UE_ADDR_ANY,
660 	.ep_index = 0,
661 	.direction = UE_DIR_OUT,
662 	.bufsize = RUN_MAX_TXSZ,
663 	.flags = {.pipe_bof = 1,.force_short_xfer = 1,},
664 	.callback = run_bulk_tx_callback0,
665 	.timeout = 5000,	/* ms */
666     },
667     [RUN_BULK_TX_BK] = {
668 	.type = UE_BULK,
669 	.endpoint = UE_ADDR_ANY,
670 	.direction = UE_DIR_OUT,
671 	.ep_index = 1,
672 	.bufsize = RUN_MAX_TXSZ,
673 	.flags = {.pipe_bof = 1,.force_short_xfer = 1,},
674 	.callback = run_bulk_tx_callback1,
675 	.timeout = 5000,	/* ms */
676     },
677     [RUN_BULK_TX_VI] = {
678 	.type = UE_BULK,
679 	.endpoint = UE_ADDR_ANY,
680 	.direction = UE_DIR_OUT,
681 	.ep_index = 2,
682 	.bufsize = RUN_MAX_TXSZ,
683 	.flags = {.pipe_bof = 1,.force_short_xfer = 1,},
684 	.callback = run_bulk_tx_callback2,
685 	.timeout = 5000,	/* ms */
686     },
687     [RUN_BULK_TX_VO] = {
688 	.type = UE_BULK,
689 	.endpoint = UE_ADDR_ANY,
690 	.direction = UE_DIR_OUT,
691 	.ep_index = 3,
692 	.bufsize = RUN_MAX_TXSZ,
693 	.flags = {.pipe_bof = 1,.force_short_xfer = 1,},
694 	.callback = run_bulk_tx_callback3,
695 	.timeout = 5000,	/* ms */
696     },
697     [RUN_BULK_TX_HCCA] = {
698 	.type = UE_BULK,
699 	.endpoint = UE_ADDR_ANY,
700 	.direction = UE_DIR_OUT,
701 	.ep_index = 4,
702 	.bufsize = RUN_MAX_TXSZ,
703 	.flags = {.pipe_bof = 1,.force_short_xfer = 1,.no_pipe_ok = 1,},
704 	.callback = run_bulk_tx_callback4,
705 	.timeout = 5000,	/* ms */
706     },
707     [RUN_BULK_TX_PRIO] = {
708 	.type = UE_BULK,
709 	.endpoint = UE_ADDR_ANY,
710 	.direction = UE_DIR_OUT,
711 	.ep_index = 5,
712 	.bufsize = RUN_MAX_TXSZ,
713 	.flags = {.pipe_bof = 1,.force_short_xfer = 1,.no_pipe_ok = 1,},
714 	.callback = run_bulk_tx_callback5,
715 	.timeout = 5000,	/* ms */
716     },
717     [RUN_BULK_RX] = {
718 	.type = UE_BULK,
719 	.endpoint = UE_ADDR_ANY,
720 	.direction = UE_DIR_IN,
721 	.bufsize = RUN_MAX_RXSZ,
722 	.flags = {.pipe_bof = 1,.short_xfer_ok = 1,},
723 	.callback = run_bulk_rx_callback,
724     }
725 };
726 
727 static void
728 run_autoinst(void *arg, struct usb_device *udev,
729     struct usb_attach_arg *uaa)
730 {
731 	struct usb_interface *iface;
732 	struct usb_interface_descriptor *id;
733 
734 	if (uaa->dev_state != UAA_DEV_READY)
735 		return;
736 
737 	iface = usbd_get_iface(udev, 0);
738 	if (iface == NULL)
739 		return;
740 	id = iface->idesc;
741 	if (id == NULL || id->bInterfaceClass != UICLASS_MASS)
742 		return;
743 	if (usbd_lookup_id_by_uaa(run_devs, sizeof(run_devs), uaa))
744 		return;
745 
746 	if (usb_msc_eject(udev, 0, MSC_EJECT_STOPUNIT) == 0)
747 		uaa->dev_state = UAA_DEV_EJECTING;
748 }
749 
750 static int
751 run_driver_loaded(struct module *mod, int what, void *arg)
752 {
753 	switch (what) {
754 	case MOD_LOAD:
755 		run_etag = EVENTHANDLER_REGISTER(usb_dev_configured,
756 		    run_autoinst, NULL, EVENTHANDLER_PRI_ANY);
757 		break;
758 	case MOD_UNLOAD:
759 		EVENTHANDLER_DEREGISTER(usb_dev_configured, run_etag);
760 		break;
761 	default:
762 		return (EOPNOTSUPP);
763 	}
764 	return (0);
765 }
766 
767 static int
768 run_match(device_t self)
769 {
770 	struct usb_attach_arg *uaa = device_get_ivars(self);
771 
772 	if (uaa->usb_mode != USB_MODE_HOST)
773 		return (ENXIO);
774 	if (uaa->info.bConfigIndex != 0)
775 		return (ENXIO);
776 	if (uaa->info.bIfaceIndex != RT2860_IFACE_INDEX)
777 		return (ENXIO);
778 
779 	return (usbd_lookup_id_by_uaa(run_devs, sizeof(run_devs), uaa));
780 }
781 
782 static int
783 run_attach(device_t self)
784 {
785 	struct run_softc *sc = device_get_softc(self);
786 	struct usb_attach_arg *uaa = device_get_ivars(self);
787 	struct ieee80211com *ic = &sc->sc_ic;
788 	uint32_t ver;
789 	uint8_t iface_index;
790 	int ntries, error;
791 
792 	device_set_usb_desc(self);
793 	sc->sc_udev = uaa->device;
794 	sc->sc_dev = self;
795 	if (USB_GET_DRIVER_INFO(uaa) != RUN_EJECT)
796 		sc->sc_flags |= RUN_FLAG_FWLOAD_NEEDED;
797 
798 	mtx_init(&sc->sc_mtx, device_get_nameunit(sc->sc_dev),
799 	    MTX_NETWORK_LOCK, MTX_DEF);
800 	mbufq_init(&sc->sc_snd, ifqmaxlen);
801 
802 	iface_index = RT2860_IFACE_INDEX;
803 
804 	error = usbd_transfer_setup(uaa->device, &iface_index,
805 	    sc->sc_xfer, run_config, RUN_N_XFER, sc, &sc->sc_mtx);
806 	if (error) {
807 		device_printf(self, "could not allocate USB transfers, "
808 		    "err=%s\n", usbd_errstr(error));
809 		goto detach;
810 	}
811 
812 	RUN_LOCK(sc);
813 
814 	/* wait for the chip to settle */
815 	for (ntries = 0; ntries < 100; ntries++) {
816 		if (run_read(sc, RT2860_ASIC_VER_ID, &ver) != 0) {
817 			RUN_UNLOCK(sc);
818 			goto detach;
819 		}
820 		if (ver != 0 && ver != 0xffffffff)
821 			break;
822 		run_delay(sc, 10);
823 	}
824 	if (ntries == 100) {
825 		device_printf(sc->sc_dev,
826 		    "timeout waiting for NIC to initialize\n");
827 		RUN_UNLOCK(sc);
828 		goto detach;
829 	}
830 	sc->mac_ver = ver >> 16;
831 	sc->mac_rev = ver & 0xffff;
832 
833 	/* retrieve RF rev. no and various other things from EEPROM */
834 	run_read_eeprom(sc);
835 
836 	device_printf(sc->sc_dev,
837 	    "MAC/BBP RT%04X (rev 0x%04X), RF %s (MIMO %dT%dR), address %s\n",
838 	    sc->mac_ver, sc->mac_rev, run_get_rf(sc->rf_rev),
839 	    sc->ntxchains, sc->nrxchains, ether_sprintf(ic->ic_macaddr));
840 
841 	RUN_UNLOCK(sc);
842 
843 	ic->ic_softc = sc;
844 	ic->ic_name = device_get_nameunit(self);
845 	ic->ic_phytype = IEEE80211_T_OFDM;	/* not only, but not used */
846 	ic->ic_opmode = IEEE80211_M_STA;	/* default to BSS mode */
847 
848 	/* set device capabilities */
849 	ic->ic_caps =
850 	    IEEE80211_C_STA |		/* station mode supported */
851 	    IEEE80211_C_MONITOR |	/* monitor mode supported */
852 	    IEEE80211_C_IBSS |
853 	    IEEE80211_C_HOSTAP |
854 	    IEEE80211_C_WDS |		/* 4-address traffic works */
855 	    IEEE80211_C_MBSS |
856 	    IEEE80211_C_SHPREAMBLE |	/* short preamble supported */
857 	    IEEE80211_C_SHSLOT |	/* short slot time supported */
858 	    IEEE80211_C_SWAMSDUTX |	/* Do software A-MSDU TX */
859 	    IEEE80211_C_FF | 		/* Atheros fast-frames */
860 	    IEEE80211_C_WME |		/* WME */
861 	    IEEE80211_C_WPA;		/* WPA1|WPA2(RSN) */
862 
863 	/*
864 	 * RF2020 is not an 11n device.
865 	 */
866 	if (sc->rf_rev != RT3070_RF_2020) {
867 		device_printf(sc->sc_dev, "[HT] Enabling 802.11n\n");
868 		ic->ic_htcaps =
869 			    IEEE80211_HTC_HT |
870 			    IEEE80211_HTC_AMPDU |
871 			    IEEE80211_HTC_AMSDU |
872 			    IEEE80211_HTCAP_MAXAMSDU_3839 |
873 			    IEEE80211_HTCAP_SMPS_OFF;
874 
875 		ic->ic_rxstream = sc->nrxchains;
876 		ic->ic_txstream = sc->ntxchains;
877 	}
878 
879 	ic->ic_cryptocaps =
880 	    IEEE80211_CRYPTO_WEP |
881 	    IEEE80211_CRYPTO_AES_CCM |
882 	    IEEE80211_CRYPTO_TKIPMIC |
883 	    IEEE80211_CRYPTO_TKIP;
884 
885 	ic->ic_flags |= IEEE80211_F_DATAPAD;
886 	ic->ic_flags_ext |= IEEE80211_FEXT_SWBMISS;
887 
888 	run_getradiocaps(ic, IEEE80211_CHAN_MAX, &ic->ic_nchans,
889 	    ic->ic_channels);
890 
891 	ieee80211_ifattach(ic);
892 
893 	ic->ic_scan_start = run_scan_start;
894 	ic->ic_scan_end = run_scan_end;
895 	ic->ic_set_channel = run_set_channel;
896 	ic->ic_getradiocaps = run_getradiocaps;
897 	ic->ic_node_alloc = run_node_alloc;
898 	ic->ic_newassoc = run_newassoc;
899 	ic->ic_updateslot = run_updateslot;
900 	ic->ic_update_mcast = run_update_mcast;
901 	ic->ic_wme.wme_update = run_wme_update;
902 	ic->ic_raw_xmit = run_raw_xmit;
903 	ic->ic_update_promisc = run_update_promisc;
904 	ic->ic_vap_create = run_vap_create;
905 	ic->ic_vap_delete = run_vap_delete;
906 	ic->ic_transmit = run_transmit;
907 	ic->ic_parent = run_parent;
908 	ic->ic_update_chw = run_update_chw;
909 	ic->ic_ampdu_enable = run_ampdu_enable;
910 
911 	ieee80211_radiotap_attach(ic,
912 	    &sc->sc_txtap.wt_ihdr, sizeof(sc->sc_txtap),
913 		RUN_TX_RADIOTAP_PRESENT,
914 	    &sc->sc_rxtap.wr_ihdr, sizeof(sc->sc_rxtap),
915 		RUN_RX_RADIOTAP_PRESENT);
916 
917 	TASK_INIT(&sc->cmdq_task, 0, run_cmdq_cb, sc);
918 	TASK_INIT(&sc->ratectl_task, 0, run_ratectl_cb, sc);
919 	usb_callout_init_mtx(&sc->ratectl_ch, &sc->sc_mtx, 0);
920 
921 	if (bootverbose)
922 		ieee80211_announce(ic);
923 
924 	return (0);
925 
926 detach:
927 	run_detach(self);
928 	return (ENXIO);
929 }
930 
931 static void
932 run_drain_mbufq(struct run_softc *sc)
933 {
934 	struct mbuf *m;
935 	struct ieee80211_node *ni;
936 
937 	RUN_LOCK_ASSERT(sc, MA_OWNED);
938 	while ((m = mbufq_dequeue(&sc->sc_snd)) != NULL) {
939 		ni = (struct ieee80211_node *)m->m_pkthdr.rcvif;
940 		m->m_pkthdr.rcvif = NULL;
941 		ieee80211_free_node(ni);
942 		m_freem(m);
943 	}
944 }
945 
946 static int
947 run_detach(device_t self)
948 {
949 	struct run_softc *sc = device_get_softc(self);
950 	struct ieee80211com *ic = &sc->sc_ic;
951 	int i;
952 
953 	RUN_LOCK(sc);
954 	sc->sc_detached = 1;
955 	RUN_UNLOCK(sc);
956 
957 	/* stop all USB transfers */
958 	usbd_transfer_unsetup(sc->sc_xfer, RUN_N_XFER);
959 
960 	RUN_LOCK(sc);
961 	sc->ratectl_run = RUN_RATECTL_OFF;
962 	sc->cmdq_run = sc->cmdq_key_set = RUN_CMDQ_ABORT;
963 
964 	/* free TX list, if any */
965 	for (i = 0; i != RUN_EP_QUEUES; i++)
966 		run_unsetup_tx_list(sc, &sc->sc_epq[i]);
967 
968 	/* Free TX queue */
969 	run_drain_mbufq(sc);
970 	RUN_UNLOCK(sc);
971 
972 	if (sc->sc_ic.ic_softc == sc) {
973 		/* drain tasks */
974 		usb_callout_drain(&sc->ratectl_ch);
975 		ieee80211_draintask(ic, &sc->cmdq_task);
976 		ieee80211_draintask(ic, &sc->ratectl_task);
977 		ieee80211_ifdetach(ic);
978 	}
979 
980 	mtx_destroy(&sc->sc_mtx);
981 
982 	return (0);
983 }
984 
985 static struct ieee80211vap *
986 run_vap_create(struct ieee80211com *ic, const char name[IFNAMSIZ], int unit,
987     enum ieee80211_opmode opmode, int flags,
988     const uint8_t bssid[IEEE80211_ADDR_LEN],
989     const uint8_t mac[IEEE80211_ADDR_LEN])
990 {
991 	struct run_softc *sc = ic->ic_softc;
992 	struct run_vap *rvp;
993 	struct ieee80211vap *vap;
994 	int i;
995 
996 	if (sc->rvp_cnt >= RUN_VAP_MAX) {
997 		device_printf(sc->sc_dev, "number of VAPs maxed out\n");
998 		return (NULL);
999 	}
1000 
1001 	switch (opmode) {
1002 	case IEEE80211_M_STA:
1003 		/* enable s/w bmiss handling for sta mode */
1004 		flags |= IEEE80211_CLONE_NOBEACONS;
1005 		/* fall though */
1006 	case IEEE80211_M_IBSS:
1007 	case IEEE80211_M_MONITOR:
1008 	case IEEE80211_M_HOSTAP:
1009 	case IEEE80211_M_MBSS:
1010 		/* other than WDS vaps, only one at a time */
1011 		if (!TAILQ_EMPTY(&ic->ic_vaps))
1012 			return (NULL);
1013 		break;
1014 	case IEEE80211_M_WDS:
1015 		TAILQ_FOREACH(vap, &ic->ic_vaps, iv_next){
1016 			if(vap->iv_opmode != IEEE80211_M_HOSTAP)
1017 				continue;
1018 			/* WDS vap's always share the local mac address. */
1019 			flags &= ~IEEE80211_CLONE_BSSID;
1020 			break;
1021 		}
1022 		if (vap == NULL) {
1023 			device_printf(sc->sc_dev,
1024 			    "wds only supported in ap mode\n");
1025 			return (NULL);
1026 		}
1027 		break;
1028 	default:
1029 		device_printf(sc->sc_dev, "unknown opmode %d\n", opmode);
1030 		return (NULL);
1031 	}
1032 
1033 	rvp = malloc(sizeof(struct run_vap), M_80211_VAP, M_WAITOK | M_ZERO);
1034 	vap = &rvp->vap;
1035 
1036 	if (ieee80211_vap_setup(ic, vap, name, unit, opmode, flags,
1037 	    bssid) != 0) {
1038 		/* out of memory */
1039 		free(rvp, M_80211_VAP);
1040 		return (NULL);
1041 	}
1042 
1043 	vap->iv_update_beacon = run_update_beacon;
1044 	vap->iv_max_aid = RT2870_WCID_MAX;
1045 
1046 	/*
1047 	 * The linux rt2800 driver limits 1 stream devices to a 32KB
1048 	 * RX AMPDU.
1049 	 */
1050 	if (ic->ic_rxstream > 1)
1051 		vap->iv_ampdu_rxmax = IEEE80211_HTCAP_MAXRXAMPDU_64K;
1052 	else
1053 		vap->iv_ampdu_rxmax = IEEE80211_HTCAP_MAXRXAMPDU_32K;
1054 	vap->iv_ampdu_density = IEEE80211_HTCAP_MPDUDENSITY_2; /* 2uS */
1055 
1056 	/*
1057 	 * To delete the right key from h/w, we need wcid.
1058 	 * Luckily, there is unused space in ieee80211_key{}, wk_pad,
1059 	 * and matching wcid will be written into there. So, cast
1060 	 * some spells to remove 'const' from ieee80211_key{}
1061 	 */
1062 	vap->iv_key_delete = (void *)run_key_delete;
1063 	vap->iv_key_set = (void *)run_key_set;
1064 
1065 	/* override state transition machine */
1066 	rvp->newstate = vap->iv_newstate;
1067 	vap->iv_newstate = run_newstate;
1068 	if (opmode == IEEE80211_M_IBSS) {
1069 		rvp->recv_mgmt = vap->iv_recv_mgmt;
1070 		vap->iv_recv_mgmt = run_recv_mgmt;
1071 	}
1072 
1073 	ieee80211_ratectl_init(vap);
1074 	ieee80211_ratectl_setinterval(vap, 1000 /* 1 sec */);
1075 
1076 	/* complete setup */
1077 	ieee80211_vap_attach(vap, run_media_change, ieee80211_media_status,
1078 	    mac);
1079 
1080 	/* make sure id is always unique */
1081 	for (i = 0; i < RUN_VAP_MAX; i++) {
1082 		if((sc->rvp_bmap & 1 << i) == 0){
1083 			sc->rvp_bmap |= 1 << i;
1084 			rvp->rvp_id = i;
1085 			break;
1086 		}
1087 	}
1088 	if (sc->rvp_cnt++ == 0)
1089 		ic->ic_opmode = opmode;
1090 
1091 	if (opmode == IEEE80211_M_HOSTAP)
1092 		sc->cmdq_run = RUN_CMDQ_GO;
1093 
1094 	RUN_DPRINTF(sc, RUN_DEBUG_STATE, "rvp_id=%d bmap=%x rvp_cnt=%d\n",
1095 	    rvp->rvp_id, sc->rvp_bmap, sc->rvp_cnt);
1096 
1097 	return (vap);
1098 }
1099 
1100 static void
1101 run_vap_delete(struct ieee80211vap *vap)
1102 {
1103 	struct run_vap *rvp = RUN_VAP(vap);
1104 	struct ieee80211com *ic;
1105 	struct run_softc *sc;
1106 	uint8_t rvp_id;
1107 
1108 	if (vap == NULL)
1109 		return;
1110 
1111 	ic = vap->iv_ic;
1112 	sc = ic->ic_softc;
1113 
1114 	RUN_LOCK(sc);
1115 
1116 	m_freem(rvp->beacon_mbuf);
1117 	rvp->beacon_mbuf = NULL;
1118 
1119 	rvp_id = rvp->rvp_id;
1120 	sc->ratectl_run &= ~(1 << rvp_id);
1121 	sc->rvp_bmap &= ~(1 << rvp_id);
1122 	run_set_region_4(sc, RT2860_SKEY(rvp_id, 0), 0, 128);
1123 	run_set_region_4(sc, RT2860_BCN_BASE(rvp_id), 0, 512);
1124 	--sc->rvp_cnt;
1125 
1126 	RUN_DPRINTF(sc, RUN_DEBUG_STATE,
1127 	    "vap=%p rvp_id=%d bmap=%x rvp_cnt=%d\n",
1128 	    vap, rvp_id, sc->rvp_bmap, sc->rvp_cnt);
1129 
1130 	RUN_UNLOCK(sc);
1131 
1132 	ieee80211_ratectl_deinit(vap);
1133 	ieee80211_vap_detach(vap);
1134 	free(rvp, M_80211_VAP);
1135 }
1136 
1137 /*
1138  * There are numbers of functions need to be called in context thread.
1139  * Rather than creating taskqueue event for each of those functions,
1140  * here is all-for-one taskqueue callback function. This function
1141  * guarantees deferred functions are executed in the same order they
1142  * were enqueued.
1143  * '& RUN_CMDQ_MASQ' is to loop cmdq[].
1144  */
1145 static void
1146 run_cmdq_cb(void *arg, int pending)
1147 {
1148 	struct run_softc *sc = arg;
1149 	uint8_t i;
1150 
1151 	/* call cmdq[].func locked */
1152 	RUN_LOCK(sc);
1153 	for (i = sc->cmdq_exec; sc->cmdq[i].func && pending;
1154 	    i = sc->cmdq_exec, pending--) {
1155 		RUN_DPRINTF(sc, RUN_DEBUG_CMD, "cmdq_exec=%d pending=%d\n",
1156 		    i, pending);
1157 		if (sc->cmdq_run == RUN_CMDQ_GO) {
1158 			/*
1159 			 * If arg0 is NULL, callback func needs more
1160 			 * than one arg. So, pass ptr to cmdq struct.
1161 			 */
1162 			if (sc->cmdq[i].arg0)
1163 				sc->cmdq[i].func(sc->cmdq[i].arg0);
1164 			else
1165 				sc->cmdq[i].func(&sc->cmdq[i]);
1166 		}
1167 		sc->cmdq[i].arg0 = NULL;
1168 		sc->cmdq[i].func = NULL;
1169 		sc->cmdq_exec++;
1170 		sc->cmdq_exec &= RUN_CMDQ_MASQ;
1171 	}
1172 	RUN_UNLOCK(sc);
1173 }
1174 
1175 static void
1176 run_setup_tx_list(struct run_softc *sc, struct run_endpoint_queue *pq)
1177 {
1178 	struct run_tx_data *data;
1179 
1180 	memset(pq, 0, sizeof(*pq));
1181 
1182 	STAILQ_INIT(&pq->tx_qh);
1183 	STAILQ_INIT(&pq->tx_fh);
1184 
1185 	for (data = &pq->tx_data[0];
1186 	    data < &pq->tx_data[RUN_TX_RING_COUNT]; data++) {
1187 		data->sc = sc;
1188 		STAILQ_INSERT_TAIL(&pq->tx_fh, data, next);
1189 	}
1190 	pq->tx_nfree = RUN_TX_RING_COUNT;
1191 }
1192 
1193 static void
1194 run_unsetup_tx_list(struct run_softc *sc, struct run_endpoint_queue *pq)
1195 {
1196 	struct run_tx_data *data;
1197 
1198 	/* make sure any subsequent use of the queues will fail */
1199 	pq->tx_nfree = 0;
1200 	STAILQ_INIT(&pq->tx_fh);
1201 	STAILQ_INIT(&pq->tx_qh);
1202 
1203 	/* free up all node references and mbufs */
1204 	for (data = &pq->tx_data[0];
1205 	    data < &pq->tx_data[RUN_TX_RING_COUNT]; data++) {
1206 		if (data->m != NULL) {
1207 			m_freem(data->m);
1208 			data->m = NULL;
1209 		}
1210 		if (data->ni != NULL) {
1211 			ieee80211_free_node(data->ni);
1212 			data->ni = NULL;
1213 		}
1214 	}
1215 }
1216 
1217 static int
1218 run_load_microcode(struct run_softc *sc)
1219 {
1220 	usb_device_request_t req;
1221 	const struct firmware *fw;
1222 	const u_char *base;
1223 	uint32_t tmp;
1224 	int ntries, error;
1225 	const uint64_t *temp;
1226 	uint64_t bytes;
1227 
1228 	RUN_UNLOCK(sc);
1229 	fw = firmware_get("runfw");
1230 	RUN_LOCK(sc);
1231 	if (fw == NULL) {
1232 		device_printf(sc->sc_dev,
1233 		    "failed loadfirmware of file %s\n", "runfw");
1234 		return ENOENT;
1235 	}
1236 
1237 	if (fw->datasize != 8192) {
1238 		device_printf(sc->sc_dev,
1239 		    "invalid firmware size (should be 8KB)\n");
1240 		error = EINVAL;
1241 		goto fail;
1242 	}
1243 
1244 	/*
1245 	 * RT3071/RT3072 use a different firmware
1246 	 * run-rt2870 (8KB) contains both,
1247 	 * first half (4KB) is for rt2870,
1248 	 * last half is for rt3071.
1249 	 */
1250 	base = fw->data;
1251 	if ((sc->mac_ver) != 0x2860 &&
1252 	    (sc->mac_ver) != 0x2872 &&
1253 	    (sc->mac_ver) != 0x3070) {
1254 		base += 4096;
1255 	}
1256 
1257 	/* cheap sanity check */
1258 	temp = fw->data;
1259 	bytes = *temp;
1260 	if (bytes != be64toh(0xffffff0210280210ULL)) {
1261 		device_printf(sc->sc_dev, "firmware checksum failed\n");
1262 		error = EINVAL;
1263 		goto fail;
1264 	}
1265 
1266 	/* write microcode image */
1267 	if (sc->sc_flags & RUN_FLAG_FWLOAD_NEEDED) {
1268 		run_write_region_1(sc, RT2870_FW_BASE, base, 4096);
1269 		run_write(sc, RT2860_H2M_MAILBOX_CID, 0xffffffff);
1270 		run_write(sc, RT2860_H2M_MAILBOX_STATUS, 0xffffffff);
1271 	}
1272 
1273 	req.bmRequestType = UT_WRITE_VENDOR_DEVICE;
1274 	req.bRequest = RT2870_RESET;
1275 	USETW(req.wValue, 8);
1276 	USETW(req.wIndex, 0);
1277 	USETW(req.wLength, 0);
1278 	if ((error = usbd_do_request(sc->sc_udev, &sc->sc_mtx, &req, NULL))
1279 	    != 0) {
1280 		device_printf(sc->sc_dev, "firmware reset failed\n");
1281 		goto fail;
1282 	}
1283 
1284 	run_delay(sc, 10);
1285 
1286 	run_write(sc, RT2860_H2M_BBPAGENT, 0);
1287 	run_write(sc, RT2860_H2M_MAILBOX, 0);
1288 	run_write(sc, RT2860_H2M_INTSRC, 0);
1289 	if ((error = run_mcu_cmd(sc, RT2860_MCU_CMD_RFRESET, 0)) != 0)
1290 		goto fail;
1291 
1292 	/* wait until microcontroller is ready */
1293 	for (ntries = 0; ntries < 1000; ntries++) {
1294 		if ((error = run_read(sc, RT2860_SYS_CTRL, &tmp)) != 0)
1295 			goto fail;
1296 		if (tmp & RT2860_MCU_READY)
1297 			break;
1298 		run_delay(sc, 10);
1299 	}
1300 	if (ntries == 1000) {
1301 		device_printf(sc->sc_dev,
1302 		    "timeout waiting for MCU to initialize\n");
1303 		error = ETIMEDOUT;
1304 		goto fail;
1305 	}
1306 	device_printf(sc->sc_dev, "firmware %s ver. %u.%u loaded\n",
1307 	    (base == fw->data) ? "RT2870" : "RT3071",
1308 	    *(base + 4092), *(base + 4093));
1309 
1310 fail:
1311 	firmware_put(fw, FIRMWARE_UNLOAD);
1312 	return (error);
1313 }
1314 
1315 static int
1316 run_reset(struct run_softc *sc)
1317 {
1318 	usb_device_request_t req;
1319 
1320 	req.bmRequestType = UT_WRITE_VENDOR_DEVICE;
1321 	req.bRequest = RT2870_RESET;
1322 	USETW(req.wValue, 1);
1323 	USETW(req.wIndex, 0);
1324 	USETW(req.wLength, 0);
1325 	return (usbd_do_request(sc->sc_udev, &sc->sc_mtx, &req, NULL));
1326 }
1327 
1328 static usb_error_t
1329 run_do_request(struct run_softc *sc,
1330     struct usb_device_request *req, void *data)
1331 {
1332 	usb_error_t err;
1333 	int ntries = 10;
1334 
1335 	RUN_LOCK_ASSERT(sc, MA_OWNED);
1336 
1337 	while (ntries--) {
1338 		err = usbd_do_request_flags(sc->sc_udev, &sc->sc_mtx,
1339 		    req, data, 0, NULL, 250 /* ms */);
1340 		if (err == 0)
1341 			break;
1342 		RUN_DPRINTF(sc, RUN_DEBUG_USB,
1343 		    "Control request failed, %s (retrying)\n",
1344 		    usbd_errstr(err));
1345 		run_delay(sc, 10);
1346 	}
1347 	return (err);
1348 }
1349 
1350 static int
1351 run_read(struct run_softc *sc, uint16_t reg, uint32_t *val)
1352 {
1353 	uint32_t tmp;
1354 	int error;
1355 
1356 	error = run_read_region_1(sc, reg, (uint8_t *)&tmp, sizeof tmp);
1357 	if (error == 0)
1358 		*val = le32toh(tmp);
1359 	else
1360 		*val = 0xffffffff;
1361 	return (error);
1362 }
1363 
1364 static int
1365 run_read_region_1(struct run_softc *sc, uint16_t reg, uint8_t *buf, int len)
1366 {
1367 	usb_device_request_t req;
1368 
1369 	req.bmRequestType = UT_READ_VENDOR_DEVICE;
1370 	req.bRequest = RT2870_READ_REGION_1;
1371 	USETW(req.wValue, 0);
1372 	USETW(req.wIndex, reg);
1373 	USETW(req.wLength, len);
1374 
1375 	return (run_do_request(sc, &req, buf));
1376 }
1377 
1378 static int
1379 run_write_2(struct run_softc *sc, uint16_t reg, uint16_t val)
1380 {
1381 	usb_device_request_t req;
1382 
1383 	req.bmRequestType = UT_WRITE_VENDOR_DEVICE;
1384 	req.bRequest = RT2870_WRITE_2;
1385 	USETW(req.wValue, val);
1386 	USETW(req.wIndex, reg);
1387 	USETW(req.wLength, 0);
1388 
1389 	return (run_do_request(sc, &req, NULL));
1390 }
1391 
1392 static int
1393 run_write(struct run_softc *sc, uint16_t reg, uint32_t val)
1394 {
1395 	int error;
1396 
1397 	if ((error = run_write_2(sc, reg, val & 0xffff)) == 0)
1398 		error = run_write_2(sc, reg + 2, val >> 16);
1399 	return (error);
1400 }
1401 
1402 static int
1403 run_write_region_1(struct run_softc *sc, uint16_t reg, const uint8_t *buf,
1404     int len)
1405 {
1406 #if 1
1407 	int i, error = 0;
1408 	/*
1409 	 * NB: the WRITE_REGION_1 command is not stable on RT2860.
1410 	 * We thus issue multiple WRITE_2 commands instead.
1411 	 */
1412 	KASSERT((len & 1) == 0, ("run_write_region_1: Data too long.\n"));
1413 	for (i = 0; i < len && error == 0; i += 2)
1414 		error = run_write_2(sc, reg + i, buf[i] | buf[i + 1] << 8);
1415 	return (error);
1416 #else
1417 	usb_device_request_t req;
1418 	int error = 0;
1419 
1420 	/*
1421 	 * NOTE: It appears the WRITE_REGION_1 command cannot be
1422 	 * passed a huge amount of data, which will crash the
1423 	 * firmware. Limit amount of data passed to 64-bytes at a
1424 	 * time.
1425 	 */
1426 	while (len > 0) {
1427 		int delta = 64;
1428 		if (delta > len)
1429 			delta = len;
1430 
1431 		req.bmRequestType = UT_WRITE_VENDOR_DEVICE;
1432 		req.bRequest = RT2870_WRITE_REGION_1;
1433 		USETW(req.wValue, 0);
1434 		USETW(req.wIndex, reg);
1435 		USETW(req.wLength, delta);
1436 		error = run_do_request(sc, &req, __DECONST(uint8_t *, buf));
1437 		if (error != 0)
1438 			break;
1439 		reg += delta;
1440 		buf += delta;
1441 		len -= delta;
1442 	}
1443 	return (error);
1444 #endif
1445 }
1446 
1447 static int
1448 run_set_region_4(struct run_softc *sc, uint16_t reg, uint32_t val, int len)
1449 {
1450 	int i, error = 0;
1451 
1452 	KASSERT((len & 3) == 0, ("run_set_region_4: Invalid data length.\n"));
1453 	for (i = 0; i < len && error == 0; i += 4)
1454 		error = run_write(sc, reg + i, val);
1455 	return (error);
1456 }
1457 
1458 static int
1459 run_efuse_read(struct run_softc *sc, uint16_t addr, uint16_t *val, int count)
1460 {
1461 	uint32_t tmp;
1462 	uint16_t reg;
1463 	int error, ntries;
1464 
1465 	if ((error = run_read(sc, RT3070_EFUSE_CTRL, &tmp)) != 0)
1466 		return (error);
1467 
1468 	if (count == 2)
1469 		addr *= 2;
1470 	/*-
1471 	 * Read one 16-byte block into registers EFUSE_DATA[0-3]:
1472 	 * DATA0: F E D C
1473 	 * DATA1: B A 9 8
1474 	 * DATA2: 7 6 5 4
1475 	 * DATA3: 3 2 1 0
1476 	 */
1477 	tmp &= ~(RT3070_EFSROM_MODE_MASK | RT3070_EFSROM_AIN_MASK);
1478 	tmp |= (addr & ~0xf) << RT3070_EFSROM_AIN_SHIFT | RT3070_EFSROM_KICK;
1479 	run_write(sc, RT3070_EFUSE_CTRL, tmp);
1480 	for (ntries = 0; ntries < 100; ntries++) {
1481 		if ((error = run_read(sc, RT3070_EFUSE_CTRL, &tmp)) != 0)
1482 			return (error);
1483 		if (!(tmp & RT3070_EFSROM_KICK))
1484 			break;
1485 		run_delay(sc, 2);
1486 	}
1487 	if (ntries == 100)
1488 		return (ETIMEDOUT);
1489 
1490 	if ((tmp & RT3070_EFUSE_AOUT_MASK) == RT3070_EFUSE_AOUT_MASK) {
1491 		*val = 0xffff;	/* address not found */
1492 		return (0);
1493 	}
1494 	/* determine to which 32-bit register our 16-bit word belongs */
1495 	reg = RT3070_EFUSE_DATA3 - (addr & 0xc);
1496 	if ((error = run_read(sc, reg, &tmp)) != 0)
1497 		return (error);
1498 
1499 	tmp >>= (8 * (addr & 0x3));
1500 	*val = (addr & 1) ? tmp >> 16 : tmp & 0xffff;
1501 
1502 	return (0);
1503 }
1504 
1505 /* Read 16-bit from eFUSE ROM for RT3xxx. */
1506 static int
1507 run_efuse_read_2(struct run_softc *sc, uint16_t addr, uint16_t *val)
1508 {
1509 	return (run_efuse_read(sc, addr, val, 2));
1510 }
1511 
1512 static int
1513 run_eeprom_read_2(struct run_softc *sc, uint16_t addr, uint16_t *val)
1514 {
1515 	usb_device_request_t req;
1516 	uint16_t tmp;
1517 	int error;
1518 
1519 	addr *= 2;
1520 	req.bmRequestType = UT_READ_VENDOR_DEVICE;
1521 	req.bRequest = RT2870_EEPROM_READ;
1522 	USETW(req.wValue, 0);
1523 	USETW(req.wIndex, addr);
1524 	USETW(req.wLength, sizeof(tmp));
1525 
1526 	error = usbd_do_request(sc->sc_udev, &sc->sc_mtx, &req, &tmp);
1527 	if (error == 0)
1528 		*val = le16toh(tmp);
1529 	else
1530 		*val = 0xffff;
1531 	return (error);
1532 }
1533 
1534 static __inline int
1535 run_srom_read(struct run_softc *sc, uint16_t addr, uint16_t *val)
1536 {
1537 	/* either eFUSE ROM or EEPROM */
1538 	return sc->sc_srom_read(sc, addr, val);
1539 }
1540 
1541 static int
1542 run_rt2870_rf_write(struct run_softc *sc, uint32_t val)
1543 {
1544 	uint32_t tmp;
1545 	int error, ntries;
1546 
1547 	for (ntries = 0; ntries < 10; ntries++) {
1548 		if ((error = run_read(sc, RT2860_RF_CSR_CFG0, &tmp)) != 0)
1549 			return (error);
1550 		if (!(tmp & RT2860_RF_REG_CTRL))
1551 			break;
1552 	}
1553 	if (ntries == 10)
1554 		return (ETIMEDOUT);
1555 
1556 	return (run_write(sc, RT2860_RF_CSR_CFG0, val));
1557 }
1558 
1559 static int
1560 run_rt3070_rf_read(struct run_softc *sc, uint8_t reg, uint8_t *val)
1561 {
1562 	uint32_t tmp;
1563 	int error, ntries;
1564 
1565 	for (ntries = 0; ntries < 100; ntries++) {
1566 		if ((error = run_read(sc, RT3070_RF_CSR_CFG, &tmp)) != 0)
1567 			return (error);
1568 		if (!(tmp & RT3070_RF_KICK))
1569 			break;
1570 	}
1571 	if (ntries == 100)
1572 		return (ETIMEDOUT);
1573 
1574 	tmp = RT3070_RF_KICK | reg << 8;
1575 	if ((error = run_write(sc, RT3070_RF_CSR_CFG, tmp)) != 0)
1576 		return (error);
1577 
1578 	for (ntries = 0; ntries < 100; ntries++) {
1579 		if ((error = run_read(sc, RT3070_RF_CSR_CFG, &tmp)) != 0)
1580 			return (error);
1581 		if (!(tmp & RT3070_RF_KICK))
1582 			break;
1583 	}
1584 	if (ntries == 100)
1585 		return (ETIMEDOUT);
1586 
1587 	*val = tmp & 0xff;
1588 	return (0);
1589 }
1590 
1591 static int
1592 run_rt3070_rf_write(struct run_softc *sc, uint8_t reg, uint8_t val)
1593 {
1594 	uint32_t tmp;
1595 	int error, ntries;
1596 
1597 	for (ntries = 0; ntries < 10; ntries++) {
1598 		if ((error = run_read(sc, RT3070_RF_CSR_CFG, &tmp)) != 0)
1599 			return (error);
1600 		if (!(tmp & RT3070_RF_KICK))
1601 			break;
1602 	}
1603 	if (ntries == 10)
1604 		return (ETIMEDOUT);
1605 
1606 	tmp = RT3070_RF_WRITE | RT3070_RF_KICK | reg << 8 | val;
1607 	return (run_write(sc, RT3070_RF_CSR_CFG, tmp));
1608 }
1609 
1610 static int
1611 run_bbp_read(struct run_softc *sc, uint8_t reg, uint8_t *val)
1612 {
1613 	uint32_t tmp;
1614 	int ntries, error;
1615 
1616 	for (ntries = 0; ntries < 10; ntries++) {
1617 		if ((error = run_read(sc, RT2860_BBP_CSR_CFG, &tmp)) != 0)
1618 			return (error);
1619 		if (!(tmp & RT2860_BBP_CSR_KICK))
1620 			break;
1621 	}
1622 	if (ntries == 10)
1623 		return (ETIMEDOUT);
1624 
1625 	tmp = RT2860_BBP_CSR_READ | RT2860_BBP_CSR_KICK | reg << 8;
1626 	if ((error = run_write(sc, RT2860_BBP_CSR_CFG, tmp)) != 0)
1627 		return (error);
1628 
1629 	for (ntries = 0; ntries < 10; ntries++) {
1630 		if ((error = run_read(sc, RT2860_BBP_CSR_CFG, &tmp)) != 0)
1631 			return (error);
1632 		if (!(tmp & RT2860_BBP_CSR_KICK))
1633 			break;
1634 	}
1635 	if (ntries == 10)
1636 		return (ETIMEDOUT);
1637 
1638 	*val = tmp & 0xff;
1639 	return (0);
1640 }
1641 
1642 static int
1643 run_bbp_write(struct run_softc *sc, uint8_t reg, uint8_t val)
1644 {
1645 	uint32_t tmp;
1646 	int ntries, error;
1647 
1648 	for (ntries = 0; ntries < 10; ntries++) {
1649 		if ((error = run_read(sc, RT2860_BBP_CSR_CFG, &tmp)) != 0)
1650 			return (error);
1651 		if (!(tmp & RT2860_BBP_CSR_KICK))
1652 			break;
1653 	}
1654 	if (ntries == 10)
1655 		return (ETIMEDOUT);
1656 
1657 	tmp = RT2860_BBP_CSR_KICK | reg << 8 | val;
1658 	return (run_write(sc, RT2860_BBP_CSR_CFG, tmp));
1659 }
1660 
1661 /*
1662  * Send a command to the 8051 microcontroller unit.
1663  */
1664 static int
1665 run_mcu_cmd(struct run_softc *sc, uint8_t cmd, uint16_t arg)
1666 {
1667 	uint32_t tmp;
1668 	int error, ntries;
1669 
1670 	for (ntries = 0; ntries < 100; ntries++) {
1671 		if ((error = run_read(sc, RT2860_H2M_MAILBOX, &tmp)) != 0)
1672 			return error;
1673 		if (!(tmp & RT2860_H2M_BUSY))
1674 			break;
1675 	}
1676 	if (ntries == 100)
1677 		return ETIMEDOUT;
1678 
1679 	tmp = RT2860_H2M_BUSY | RT2860_TOKEN_NO_INTR << 16 | arg;
1680 	if ((error = run_write(sc, RT2860_H2M_MAILBOX, tmp)) == 0)
1681 		error = run_write(sc, RT2860_HOST_CMD, cmd);
1682 	return (error);
1683 }
1684 
1685 /*
1686  * Add `delta' (signed) to each 4-bit sub-word of a 32-bit word.
1687  * Used to adjust per-rate Tx power registers.
1688  */
1689 static __inline uint32_t
1690 b4inc(uint32_t b32, int8_t delta)
1691 {
1692 	int8_t i, b4;
1693 
1694 	for (i = 0; i < 8; i++) {
1695 		b4 = b32 & 0xf;
1696 		b4 += delta;
1697 		if (b4 < 0)
1698 			b4 = 0;
1699 		else if (b4 > 0xf)
1700 			b4 = 0xf;
1701 		b32 = b32 >> 4 | b4 << 28;
1702 	}
1703 	return (b32);
1704 }
1705 
1706 static const char *
1707 run_get_rf(uint16_t rev)
1708 {
1709 	switch (rev) {
1710 	case RT2860_RF_2820:	return "RT2820";
1711 	case RT2860_RF_2850:	return "RT2850";
1712 	case RT2860_RF_2720:	return "RT2720";
1713 	case RT2860_RF_2750:	return "RT2750";
1714 	case RT3070_RF_3020:	return "RT3020";
1715 	case RT3070_RF_2020:	return "RT2020";
1716 	case RT3070_RF_3021:	return "RT3021";
1717 	case RT3070_RF_3022:	return "RT3022";
1718 	case RT3070_RF_3052:	return "RT3052";
1719 	case RT3593_RF_3053:	return "RT3053";
1720 	case RT5592_RF_5592:	return "RT5592";
1721 	case RT5390_RF_5370:	return "RT5370";
1722 	case RT5390_RF_5372:	return "RT5372";
1723 	}
1724 	return ("unknown");
1725 }
1726 
1727 static void
1728 run_rt3593_get_txpower(struct run_softc *sc)
1729 {
1730 	uint16_t addr, val;
1731 	int i;
1732 
1733 	/* Read power settings for 2GHz channels. */
1734 	for (i = 0; i < 14; i += 2) {
1735 		addr = (sc->ntxchains == 3) ? RT3593_EEPROM_PWR2GHZ_BASE1 :
1736 		    RT2860_EEPROM_PWR2GHZ_BASE1;
1737 		run_srom_read(sc, addr + i / 2, &val);
1738 		sc->txpow1[i + 0] = (int8_t)(val & 0xff);
1739 		sc->txpow1[i + 1] = (int8_t)(val >> 8);
1740 
1741 		addr = (sc->ntxchains == 3) ? RT3593_EEPROM_PWR2GHZ_BASE2 :
1742 		    RT2860_EEPROM_PWR2GHZ_BASE2;
1743 		run_srom_read(sc, addr + i / 2, &val);
1744 		sc->txpow2[i + 0] = (int8_t)(val & 0xff);
1745 		sc->txpow2[i + 1] = (int8_t)(val >> 8);
1746 
1747 		if (sc->ntxchains == 3) {
1748 			run_srom_read(sc, RT3593_EEPROM_PWR2GHZ_BASE3 + i / 2,
1749 			    &val);
1750 			sc->txpow3[i + 0] = (int8_t)(val & 0xff);
1751 			sc->txpow3[i + 1] = (int8_t)(val >> 8);
1752 		}
1753 	}
1754 	/* Fix broken Tx power entries. */
1755 	for (i = 0; i < 14; i++) {
1756 		if (sc->txpow1[i] > 31)
1757 			sc->txpow1[i] = 5;
1758 		if (sc->txpow2[i] > 31)
1759 			sc->txpow2[i] = 5;
1760 		if (sc->ntxchains == 3) {
1761 			if (sc->txpow3[i] > 31)
1762 				sc->txpow3[i] = 5;
1763 		}
1764 	}
1765 	/* Read power settings for 5GHz channels. */
1766 	for (i = 0; i < 40; i += 2) {
1767 		run_srom_read(sc, RT3593_EEPROM_PWR5GHZ_BASE1 + i / 2, &val);
1768 		sc->txpow1[i + 14] = (int8_t)(val & 0xff);
1769 		sc->txpow1[i + 15] = (int8_t)(val >> 8);
1770 
1771 		run_srom_read(sc, RT3593_EEPROM_PWR5GHZ_BASE2 + i / 2, &val);
1772 		sc->txpow2[i + 14] = (int8_t)(val & 0xff);
1773 		sc->txpow2[i + 15] = (int8_t)(val >> 8);
1774 
1775 		if (sc->ntxchains == 3) {
1776 			run_srom_read(sc, RT3593_EEPROM_PWR5GHZ_BASE3 + i / 2,
1777 			    &val);
1778 			sc->txpow3[i + 14] = (int8_t)(val & 0xff);
1779 			sc->txpow3[i + 15] = (int8_t)(val >> 8);
1780 		}
1781 	}
1782 }
1783 
1784 static void
1785 run_get_txpower(struct run_softc *sc)
1786 {
1787 	uint16_t val;
1788 	int i;
1789 
1790 	/* Read power settings for 2GHz channels. */
1791 	for (i = 0; i < 14; i += 2) {
1792 		run_srom_read(sc, RT2860_EEPROM_PWR2GHZ_BASE1 + i / 2, &val);
1793 		sc->txpow1[i + 0] = (int8_t)(val & 0xff);
1794 		sc->txpow1[i + 1] = (int8_t)(val >> 8);
1795 
1796 		if (sc->mac_ver != 0x5390) {
1797 			run_srom_read(sc,
1798 			    RT2860_EEPROM_PWR2GHZ_BASE2 + i / 2, &val);
1799 			sc->txpow2[i + 0] = (int8_t)(val & 0xff);
1800 			sc->txpow2[i + 1] = (int8_t)(val >> 8);
1801 		}
1802 	}
1803 	/* Fix broken Tx power entries. */
1804 	for (i = 0; i < 14; i++) {
1805 		if (sc->mac_ver >= 0x5390) {
1806 			if (sc->txpow1[i] < 0 || sc->txpow1[i] > 39)
1807 				sc->txpow1[i] = 5;
1808 		} else {
1809 			if (sc->txpow1[i] < 0 || sc->txpow1[i] > 31)
1810 				sc->txpow1[i] = 5;
1811 		}
1812 		if (sc->mac_ver > 0x5390) {
1813 			if (sc->txpow2[i] < 0 || sc->txpow2[i] > 39)
1814 				sc->txpow2[i] = 5;
1815 		} else if (sc->mac_ver < 0x5390) {
1816 			if (sc->txpow2[i] < 0 || sc->txpow2[i] > 31)
1817 				sc->txpow2[i] = 5;
1818 		}
1819 		RUN_DPRINTF(sc, RUN_DEBUG_TXPWR,
1820 		    "chan %d: power1=%d, power2=%d\n",
1821 		    rt2860_rf2850[i].chan, sc->txpow1[i], sc->txpow2[i]);
1822 	}
1823 	/* Read power settings for 5GHz channels. */
1824 	for (i = 0; i < 40; i += 2) {
1825 		run_srom_read(sc, RT2860_EEPROM_PWR5GHZ_BASE1 + i / 2, &val);
1826 		sc->txpow1[i + 14] = (int8_t)(val & 0xff);
1827 		sc->txpow1[i + 15] = (int8_t)(val >> 8);
1828 
1829 		run_srom_read(sc, RT2860_EEPROM_PWR5GHZ_BASE2 + i / 2, &val);
1830 		sc->txpow2[i + 14] = (int8_t)(val & 0xff);
1831 		sc->txpow2[i + 15] = (int8_t)(val >> 8);
1832 	}
1833 	/* Fix broken Tx power entries. */
1834 	for (i = 0; i < 40; i++ ) {
1835 		if (sc->mac_ver != 0x5592) {
1836 			if (sc->txpow1[14 + i] < -7 || sc->txpow1[14 + i] > 15)
1837 				sc->txpow1[14 + i] = 5;
1838 			if (sc->txpow2[14 + i] < -7 || sc->txpow2[14 + i] > 15)
1839 				sc->txpow2[14 + i] = 5;
1840 		}
1841 		RUN_DPRINTF(sc, RUN_DEBUG_TXPWR,
1842 		    "chan %d: power1=%d, power2=%d\n",
1843 		    rt2860_rf2850[14 + i].chan, sc->txpow1[14 + i],
1844 		    sc->txpow2[14 + i]);
1845 	}
1846 }
1847 
1848 static int
1849 run_read_eeprom(struct run_softc *sc)
1850 {
1851 	struct ieee80211com *ic = &sc->sc_ic;
1852 	int8_t delta_2ghz, delta_5ghz;
1853 	uint32_t tmp;
1854 	uint16_t val;
1855 	int ridx, ant, i;
1856 
1857 	/* check whether the ROM is eFUSE ROM or EEPROM */
1858 	sc->sc_srom_read = run_eeprom_read_2;
1859 	if (sc->mac_ver >= 0x3070) {
1860 		run_read(sc, RT3070_EFUSE_CTRL, &tmp);
1861 		RUN_DPRINTF(sc, RUN_DEBUG_ROM, "EFUSE_CTRL=0x%08x\n", tmp);
1862 		if ((tmp & RT3070_SEL_EFUSE) || sc->mac_ver == 0x3593)
1863 			sc->sc_srom_read = run_efuse_read_2;
1864 	}
1865 
1866 	/* read ROM version */
1867 	run_srom_read(sc, RT2860_EEPROM_VERSION, &val);
1868 	RUN_DPRINTF(sc, RUN_DEBUG_ROM,
1869 	    "EEPROM rev=%d, FAE=%d\n", val >> 8, val & 0xff);
1870 
1871 	/* read MAC address */
1872 	run_srom_read(sc, RT2860_EEPROM_MAC01, &val);
1873 	ic->ic_macaddr[0] = val & 0xff;
1874 	ic->ic_macaddr[1] = val >> 8;
1875 	run_srom_read(sc, RT2860_EEPROM_MAC23, &val);
1876 	ic->ic_macaddr[2] = val & 0xff;
1877 	ic->ic_macaddr[3] = val >> 8;
1878 	run_srom_read(sc, RT2860_EEPROM_MAC45, &val);
1879 	ic->ic_macaddr[4] = val & 0xff;
1880 	ic->ic_macaddr[5] = val >> 8;
1881 
1882 	if (sc->mac_ver < 0x3593) {
1883 		/* read vender BBP settings */
1884 		for (i = 0; i < 10; i++) {
1885 			run_srom_read(sc, RT2860_EEPROM_BBP_BASE + i, &val);
1886 			sc->bbp[i].val = val & 0xff;
1887 			sc->bbp[i].reg = val >> 8;
1888 			RUN_DPRINTF(sc, RUN_DEBUG_ROM,
1889 			    "BBP%d=0x%02x\n", sc->bbp[i].reg, sc->bbp[i].val);
1890 		}
1891 		if (sc->mac_ver >= 0x3071) {
1892 			/* read vendor RF settings */
1893 			for (i = 0; i < 10; i++) {
1894 				run_srom_read(sc, RT3071_EEPROM_RF_BASE + i,
1895 				   &val);
1896 				sc->rf[i].val = val & 0xff;
1897 				sc->rf[i].reg = val >> 8;
1898 				RUN_DPRINTF(sc, RUN_DEBUG_ROM, "RF%d=0x%02x\n",
1899 				    sc->rf[i].reg, sc->rf[i].val);
1900 			}
1901 		}
1902 	}
1903 
1904 	/* read RF frequency offset from EEPROM */
1905 	run_srom_read(sc, (sc->mac_ver != 0x3593) ? RT2860_EEPROM_FREQ_LEDS :
1906 	    RT3593_EEPROM_FREQ, &val);
1907 	sc->freq = ((val & 0xff) != 0xff) ? val & 0xff : 0;
1908 	RUN_DPRINTF(sc, RUN_DEBUG_ROM, "EEPROM freq offset %d\n",
1909 	    sc->freq & 0xff);
1910 
1911 	run_srom_read(sc, (sc->mac_ver != 0x3593) ? RT2860_EEPROM_FREQ_LEDS :
1912 	    RT3593_EEPROM_FREQ_LEDS, &val);
1913 	if (val >> 8 != 0xff) {
1914 		/* read LEDs operating mode */
1915 		sc->leds = val >> 8;
1916 		run_srom_read(sc, (sc->mac_ver != 0x3593) ? RT2860_EEPROM_LED1 :
1917 		    RT3593_EEPROM_LED1, &sc->led[0]);
1918 		run_srom_read(sc, (sc->mac_ver != 0x3593) ? RT2860_EEPROM_LED2 :
1919 		    RT3593_EEPROM_LED2, &sc->led[1]);
1920 		run_srom_read(sc, (sc->mac_ver != 0x3593) ? RT2860_EEPROM_LED3 :
1921 		    RT3593_EEPROM_LED3, &sc->led[2]);
1922 	} else {
1923 		/* broken EEPROM, use default settings */
1924 		sc->leds = 0x01;
1925 		sc->led[0] = 0x5555;
1926 		sc->led[1] = 0x2221;
1927 		sc->led[2] = 0x5627;	/* differs from RT2860 */
1928 	}
1929 	RUN_DPRINTF(sc, RUN_DEBUG_ROM,
1930 	    "EEPROM LED mode=0x%02x, LEDs=0x%04x/0x%04x/0x%04x\n",
1931 	    sc->leds, sc->led[0], sc->led[1], sc->led[2]);
1932 
1933 	/* read RF information */
1934 	if (sc->mac_ver == 0x5390 || sc->mac_ver ==0x5392)
1935 		run_srom_read(sc, 0x00, &val);
1936 	else
1937 		run_srom_read(sc, RT2860_EEPROM_ANTENNA, &val);
1938 
1939 	if (val == 0xffff) {
1940 		device_printf(sc->sc_dev,
1941 		    "invalid EEPROM antenna info, using default\n");
1942 		if (sc->mac_ver == 0x3572) {
1943 			/* default to RF3052 2T2R */
1944 			sc->rf_rev = RT3070_RF_3052;
1945 			sc->ntxchains = 2;
1946 			sc->nrxchains = 2;
1947 		} else if (sc->mac_ver >= 0x3070) {
1948 			/* default to RF3020 1T1R */
1949 			sc->rf_rev = RT3070_RF_3020;
1950 			sc->ntxchains = 1;
1951 			sc->nrxchains = 1;
1952 		} else {
1953 			/* default to RF2820 1T2R */
1954 			sc->rf_rev = RT2860_RF_2820;
1955 			sc->ntxchains = 1;
1956 			sc->nrxchains = 2;
1957 		}
1958 	} else {
1959 		if (sc->mac_ver == 0x5390 || sc->mac_ver ==0x5392) {
1960 			sc->rf_rev = val;
1961 			run_srom_read(sc, RT2860_EEPROM_ANTENNA, &val);
1962 		} else
1963 			sc->rf_rev = (val >> 8) & 0xf;
1964 		sc->ntxchains = (val >> 4) & 0xf;
1965 		sc->nrxchains = val & 0xf;
1966 	}
1967 	RUN_DPRINTF(sc, RUN_DEBUG_ROM, "EEPROM RF rev=0x%04x chains=%dT%dR\n",
1968 	    sc->rf_rev, sc->ntxchains, sc->nrxchains);
1969 
1970 	/* check if RF supports automatic Tx access gain control */
1971 	run_srom_read(sc, RT2860_EEPROM_CONFIG, &val);
1972 	RUN_DPRINTF(sc, RUN_DEBUG_ROM, "EEPROM CFG 0x%04x\n", val);
1973 	/* check if driver should patch the DAC issue */
1974 	if ((val >> 8) != 0xff)
1975 		sc->patch_dac = (val >> 15) & 1;
1976 	if ((val & 0xff) != 0xff) {
1977 		sc->ext_5ghz_lna = (val >> 3) & 1;
1978 		sc->ext_2ghz_lna = (val >> 2) & 1;
1979 		/* check if RF supports automatic Tx access gain control */
1980 		sc->calib_2ghz = sc->calib_5ghz = (val >> 1) & 1;
1981 		/* check if we have a hardware radio switch */
1982 		sc->rfswitch = val & 1;
1983 	}
1984 
1985 	/* Read Tx power settings. */
1986 	if (sc->mac_ver == 0x3593)
1987 		run_rt3593_get_txpower(sc);
1988 	else
1989 		run_get_txpower(sc);
1990 
1991 	/* read Tx power compensation for each Tx rate */
1992 	run_srom_read(sc, RT2860_EEPROM_DELTAPWR, &val);
1993 	delta_2ghz = delta_5ghz = 0;
1994 	if ((val & 0xff) != 0xff && (val & 0x80)) {
1995 		delta_2ghz = val & 0xf;
1996 		if (!(val & 0x40))	/* negative number */
1997 			delta_2ghz = -delta_2ghz;
1998 	}
1999 	val >>= 8;
2000 	if ((val & 0xff) != 0xff && (val & 0x80)) {
2001 		delta_5ghz = val & 0xf;
2002 		if (!(val & 0x40))	/* negative number */
2003 			delta_5ghz = -delta_5ghz;
2004 	}
2005 	RUN_DPRINTF(sc, RUN_DEBUG_ROM | RUN_DEBUG_TXPWR,
2006 	    "power compensation=%d (2GHz), %d (5GHz)\n", delta_2ghz, delta_5ghz);
2007 
2008 	for (ridx = 0; ridx < 5; ridx++) {
2009 		uint32_t reg;
2010 
2011 		run_srom_read(sc, RT2860_EEPROM_RPWR + ridx * 2, &val);
2012 		reg = val;
2013 		run_srom_read(sc, RT2860_EEPROM_RPWR + ridx * 2 + 1, &val);
2014 		reg |= (uint32_t)val << 16;
2015 
2016 		sc->txpow20mhz[ridx] = reg;
2017 		sc->txpow40mhz_2ghz[ridx] = b4inc(reg, delta_2ghz);
2018 		sc->txpow40mhz_5ghz[ridx] = b4inc(reg, delta_5ghz);
2019 
2020 		RUN_DPRINTF(sc, RUN_DEBUG_ROM | RUN_DEBUG_TXPWR,
2021 		    "ridx %d: power 20MHz=0x%08x, 40MHz/2GHz=0x%08x, "
2022 		    "40MHz/5GHz=0x%08x\n", ridx, sc->txpow20mhz[ridx],
2023 		    sc->txpow40mhz_2ghz[ridx], sc->txpow40mhz_5ghz[ridx]);
2024 	}
2025 
2026 	/* Read RSSI offsets and LNA gains from EEPROM. */
2027 	run_srom_read(sc, (sc->mac_ver != 0x3593) ? RT2860_EEPROM_RSSI1_2GHZ :
2028 	    RT3593_EEPROM_RSSI1_2GHZ, &val);
2029 	sc->rssi_2ghz[0] = val & 0xff;	/* Ant A */
2030 	sc->rssi_2ghz[1] = val >> 8;	/* Ant B */
2031 	run_srom_read(sc, (sc->mac_ver != 0x3593) ? RT2860_EEPROM_RSSI2_2GHZ :
2032 	    RT3593_EEPROM_RSSI2_2GHZ, &val);
2033 	if (sc->mac_ver >= 0x3070) {
2034 		if (sc->mac_ver == 0x3593) {
2035 			sc->txmixgain_2ghz = 0;
2036 			sc->rssi_2ghz[2] = val & 0xff;	/* Ant C */
2037 		} else {
2038 			/*
2039 			 * On RT3070 chips (limited to 2 Rx chains), this ROM
2040 			 * field contains the Tx mixer gain for the 2GHz band.
2041 			 */
2042 			if ((val & 0xff) != 0xff)
2043 				sc->txmixgain_2ghz = val & 0x7;
2044 		}
2045 		RUN_DPRINTF(sc, RUN_DEBUG_ROM, "tx mixer gain=%u (2GHz)\n",
2046 		    sc->txmixgain_2ghz);
2047 	} else
2048 		sc->rssi_2ghz[2] = val & 0xff;	/* Ant C */
2049 	if (sc->mac_ver == 0x3593)
2050 		run_srom_read(sc, RT3593_EEPROM_LNA_5GHZ, &val);
2051 	sc->lna[2] = val >> 8;		/* channel group 2 */
2052 
2053 	run_srom_read(sc, (sc->mac_ver != 0x3593) ? RT2860_EEPROM_RSSI1_5GHZ :
2054 	    RT3593_EEPROM_RSSI1_5GHZ, &val);
2055 	sc->rssi_5ghz[0] = val & 0xff;	/* Ant A */
2056 	sc->rssi_5ghz[1] = val >> 8;	/* Ant B */
2057 	run_srom_read(sc, (sc->mac_ver != 0x3593) ? RT2860_EEPROM_RSSI2_5GHZ :
2058 	    RT3593_EEPROM_RSSI2_5GHZ, &val);
2059 	if (sc->mac_ver == 0x3572) {
2060 		/*
2061 		 * On RT3572 chips (limited to 2 Rx chains), this ROM
2062 		 * field contains the Tx mixer gain for the 5GHz band.
2063 		 */
2064 		if ((val & 0xff) != 0xff)
2065 			sc->txmixgain_5ghz = val & 0x7;
2066 		RUN_DPRINTF(sc, RUN_DEBUG_ROM, "tx mixer gain=%u (5GHz)\n",
2067 		    sc->txmixgain_5ghz);
2068 	} else
2069 		sc->rssi_5ghz[2] = val & 0xff;	/* Ant C */
2070 	if (sc->mac_ver == 0x3593) {
2071 		sc->txmixgain_5ghz = 0;
2072 		run_srom_read(sc, RT3593_EEPROM_LNA_5GHZ, &val);
2073 	}
2074 	sc->lna[3] = val >> 8;		/* channel group 3 */
2075 
2076 	run_srom_read(sc, (sc->mac_ver != 0x3593) ? RT2860_EEPROM_LNA :
2077 	    RT3593_EEPROM_LNA, &val);
2078 	sc->lna[0] = val & 0xff;	/* channel group 0 */
2079 	sc->lna[1] = val >> 8;		/* channel group 1 */
2080 
2081 	/* fix broken 5GHz LNA entries */
2082 	if (sc->lna[2] == 0 || sc->lna[2] == 0xff) {
2083 		RUN_DPRINTF(sc, RUN_DEBUG_ROM,
2084 		    "invalid LNA for channel group %d\n", 2);
2085 		sc->lna[2] = sc->lna[1];
2086 	}
2087 	if (sc->lna[3] == 0 || sc->lna[3] == 0xff) {
2088 		RUN_DPRINTF(sc, RUN_DEBUG_ROM,
2089 		    "invalid LNA for channel group %d\n", 3);
2090 		sc->lna[3] = sc->lna[1];
2091 	}
2092 
2093 	/* fix broken RSSI offset entries */
2094 	for (ant = 0; ant < 3; ant++) {
2095 		if (sc->rssi_2ghz[ant] < -10 || sc->rssi_2ghz[ant] > 10) {
2096 			RUN_DPRINTF(sc, RUN_DEBUG_ROM | RUN_DEBUG_RSSI,
2097 			    "invalid RSSI%d offset: %d (2GHz)\n",
2098 			    ant + 1, sc->rssi_2ghz[ant]);
2099 			sc->rssi_2ghz[ant] = 0;
2100 		}
2101 		if (sc->rssi_5ghz[ant] < -10 || sc->rssi_5ghz[ant] > 10) {
2102 			RUN_DPRINTF(sc, RUN_DEBUG_ROM | RUN_DEBUG_RSSI,
2103 			    "invalid RSSI%d offset: %d (5GHz)\n",
2104 			    ant + 1, sc->rssi_5ghz[ant]);
2105 			sc->rssi_5ghz[ant] = 0;
2106 		}
2107 	}
2108 	return (0);
2109 }
2110 
2111 static struct ieee80211_node *
2112 run_node_alloc(struct ieee80211vap *vap, const uint8_t mac[IEEE80211_ADDR_LEN])
2113 {
2114 	return malloc(sizeof (struct run_node), M_80211_NODE,
2115 	    M_NOWAIT | M_ZERO);
2116 }
2117 
2118 static int
2119 run_media_change(struct ifnet *ifp)
2120 {
2121 	struct ieee80211vap *vap = ifp->if_softc;
2122 	struct ieee80211com *ic = vap->iv_ic;
2123 	const struct ieee80211_txparam *tp;
2124 	struct run_softc *sc = ic->ic_softc;
2125 	uint8_t rate, ridx;
2126 	int error;
2127 
2128 	RUN_LOCK(sc);
2129 
2130 	error = ieee80211_media_change(ifp);
2131 	if (error != 0) {
2132 		RUN_UNLOCK(sc);
2133 		return (error);
2134 	}
2135 
2136 	tp = &vap->iv_txparms[ieee80211_chan2mode(ic->ic_curchan)];
2137 	if (tp->ucastrate != IEEE80211_FIXED_RATE_NONE) {
2138 		struct ieee80211_node *ni;
2139 		struct run_node	*rn;
2140 
2141 		/* XXX TODO: methodize with MCS rates */
2142 		rate = ic->ic_sup_rates[ic->ic_curmode].
2143 		    rs_rates[tp->ucastrate] & IEEE80211_RATE_VAL;
2144 		for (ridx = 0; ridx < RT2860_RIDX_MAX; ridx++)
2145 			if (rt2860_rates[ridx].rate == rate)
2146 				break;
2147 
2148 		ni = ieee80211_ref_node(vap->iv_bss);
2149 		rn = RUN_NODE(ni);
2150 		rn->fix_ridx = ridx;
2151 		RUN_DPRINTF(sc, RUN_DEBUG_RATE, "rate=%d, fix_ridx=%d\n",
2152 		    rate, rn->fix_ridx);
2153 		ieee80211_free_node(ni);
2154 	}
2155 
2156 #if 0
2157 	if ((ifp->if_flags & IFF_UP) &&
2158 	    (ifp->if_drv_flags &  RUN_RUNNING)){
2159 		run_init_locked(sc);
2160 	}
2161 #endif
2162 
2163 	RUN_UNLOCK(sc);
2164 
2165 	return (0);
2166 }
2167 
2168 static int
2169 run_newstate(struct ieee80211vap *vap, enum ieee80211_state nstate, int arg)
2170 {
2171 	const struct ieee80211_txparam *tp;
2172 	struct ieee80211com *ic = vap->iv_ic;
2173 	struct run_softc *sc = ic->ic_softc;
2174 	struct run_vap *rvp = RUN_VAP(vap);
2175 	enum ieee80211_state ostate;
2176 	uint32_t sta[3];
2177 	uint8_t ratectl;
2178 	uint8_t restart_ratectl = 0;
2179 	uint8_t bid = 1 << rvp->rvp_id;
2180 
2181 	ostate = vap->iv_state;
2182 	RUN_DPRINTF(sc, RUN_DEBUG_STATE, "%s -> %s\n",
2183 		ieee80211_state_name[ostate],
2184 		ieee80211_state_name[nstate]);
2185 
2186 	IEEE80211_UNLOCK(ic);
2187 	RUN_LOCK(sc);
2188 
2189 	ratectl = sc->ratectl_run; /* remember current state */
2190 	sc->ratectl_run = RUN_RATECTL_OFF;
2191 	usb_callout_stop(&sc->ratectl_ch);
2192 
2193 	if (ostate == IEEE80211_S_RUN) {
2194 		/* turn link LED off */
2195 		run_set_leds(sc, RT2860_LED_RADIO);
2196 	}
2197 
2198 	switch (nstate) {
2199 	case IEEE80211_S_INIT:
2200 		restart_ratectl = 1;
2201 
2202 		if (ostate != IEEE80211_S_RUN)
2203 			break;
2204 
2205 		ratectl &= ~bid;
2206 		sc->runbmap &= ~bid;
2207 
2208 		/* abort TSF synchronization if there is no vap running */
2209 		if (--sc->running == 0)
2210 			run_disable_tsf(sc);
2211 		break;
2212 
2213 	case IEEE80211_S_RUN:
2214 		if (!(sc->runbmap & bid)) {
2215 			if(sc->running++)
2216 				restart_ratectl = 1;
2217 			sc->runbmap |= bid;
2218 		}
2219 
2220 		m_freem(rvp->beacon_mbuf);
2221 		rvp->beacon_mbuf = NULL;
2222 
2223 		switch (vap->iv_opmode) {
2224 		case IEEE80211_M_HOSTAP:
2225 		case IEEE80211_M_MBSS:
2226 			sc->ap_running |= bid;
2227 			ic->ic_opmode = vap->iv_opmode;
2228 			run_update_beacon_cb(vap);
2229 			break;
2230 		case IEEE80211_M_IBSS:
2231 			sc->adhoc_running |= bid;
2232 			if (!sc->ap_running)
2233 				ic->ic_opmode = vap->iv_opmode;
2234 			run_update_beacon_cb(vap);
2235 			break;
2236 		case IEEE80211_M_STA:
2237 			sc->sta_running |= bid;
2238 			if (!sc->ap_running && !sc->adhoc_running)
2239 				ic->ic_opmode = vap->iv_opmode;
2240 
2241 			/* read statistic counters (clear on read) */
2242 			run_read_region_1(sc, RT2860_TX_STA_CNT0,
2243 			    (uint8_t *)sta, sizeof sta);
2244 
2245 			break;
2246 		default:
2247 			ic->ic_opmode = vap->iv_opmode;
2248 			break;
2249 		}
2250 
2251 		if (vap->iv_opmode != IEEE80211_M_MONITOR) {
2252 			struct ieee80211_node *ni;
2253 
2254 			if (ic->ic_bsschan == IEEE80211_CHAN_ANYC) {
2255 				RUN_UNLOCK(sc);
2256 				IEEE80211_LOCK(ic);
2257 				return (-1);
2258 			}
2259 			run_updateslot(ic);
2260 			run_enable_mrr(sc);
2261 			run_set_txpreamble(sc);
2262 			run_set_basicrates(sc);
2263 			ni = ieee80211_ref_node(vap->iv_bss);
2264 			IEEE80211_ADDR_COPY(sc->sc_bssid, ni->ni_bssid);
2265 			run_set_bssid(sc, sc->sc_bssid);
2266 			ieee80211_free_node(ni);
2267 			run_enable_tsf_sync(sc);
2268 
2269 			/* enable automatic rate adaptation */
2270 			tp = &vap->iv_txparms[ieee80211_chan2mode(ic->ic_curchan)];
2271 			if (tp->ucastrate == IEEE80211_FIXED_RATE_NONE)
2272 				ratectl |= bid;
2273 		} else
2274 			run_enable_tsf(sc);
2275 
2276 		/* turn link LED on */
2277 		run_set_leds(sc, RT2860_LED_RADIO |
2278 		    (IEEE80211_IS_CHAN_2GHZ(ic->ic_curchan) ?
2279 		     RT2860_LED_LINK_2GHZ : RT2860_LED_LINK_5GHZ));
2280 
2281 		break;
2282 	default:
2283 		RUN_DPRINTF(sc, RUN_DEBUG_STATE, "undefined state\n");
2284 		break;
2285 	}
2286 
2287 	/* restart amrr for running VAPs */
2288 	if ((sc->ratectl_run = ratectl) && restart_ratectl)
2289 		usb_callout_reset(&sc->ratectl_ch, hz, run_ratectl_to, sc);
2290 
2291 	RUN_UNLOCK(sc);
2292 	IEEE80211_LOCK(ic);
2293 
2294 	return(rvp->newstate(vap, nstate, arg));
2295 }
2296 
2297 static int
2298 run_wme_update(struct ieee80211com *ic)
2299 {
2300 	struct chanAccParams chp;
2301 	struct run_softc *sc = ic->ic_softc;
2302 	const struct wmeParams *ac;
2303 	int aci, error = 0;
2304 
2305 	ieee80211_wme_ic_getparams(ic, &chp);
2306 	ac = chp.cap_wmeParams;
2307 
2308 	/* update MAC TX configuration registers */
2309 	RUN_LOCK(sc);
2310 	for (aci = 0; aci < WME_NUM_AC; aci++) {
2311 		error = run_write(sc, RT2860_EDCA_AC_CFG(aci),
2312 		    ac[aci].wmep_logcwmax << 16 |
2313 		    ac[aci].wmep_logcwmin << 12 |
2314 		    ac[aci].wmep_aifsn    <<  8 |
2315 		    ac[aci].wmep_txopLimit);
2316 		if (error) goto err;
2317 	}
2318 
2319 	/* update SCH/DMA registers too */
2320 	error = run_write(sc, RT2860_WMM_AIFSN_CFG,
2321 	    ac[WME_AC_VO].wmep_aifsn  << 12 |
2322 	    ac[WME_AC_VI].wmep_aifsn  <<  8 |
2323 	    ac[WME_AC_BK].wmep_aifsn  <<  4 |
2324 	    ac[WME_AC_BE].wmep_aifsn);
2325 	if (error) goto err;
2326 	error = run_write(sc, RT2860_WMM_CWMIN_CFG,
2327 	    ac[WME_AC_VO].wmep_logcwmin << 12 |
2328 	    ac[WME_AC_VI].wmep_logcwmin <<  8 |
2329 	    ac[WME_AC_BK].wmep_logcwmin <<  4 |
2330 	    ac[WME_AC_BE].wmep_logcwmin);
2331 	if (error) goto err;
2332 	error = run_write(sc, RT2860_WMM_CWMAX_CFG,
2333 	    ac[WME_AC_VO].wmep_logcwmax << 12 |
2334 	    ac[WME_AC_VI].wmep_logcwmax <<  8 |
2335 	    ac[WME_AC_BK].wmep_logcwmax <<  4 |
2336 	    ac[WME_AC_BE].wmep_logcwmax);
2337 	if (error) goto err;
2338 	error = run_write(sc, RT2860_WMM_TXOP0_CFG,
2339 	    ac[WME_AC_BK].wmep_txopLimit << 16 |
2340 	    ac[WME_AC_BE].wmep_txopLimit);
2341 	if (error) goto err;
2342 	error = run_write(sc, RT2860_WMM_TXOP1_CFG,
2343 	    ac[WME_AC_VO].wmep_txopLimit << 16 |
2344 	    ac[WME_AC_VI].wmep_txopLimit);
2345 
2346 err:
2347 	RUN_UNLOCK(sc);
2348 	if (error)
2349 		RUN_DPRINTF(sc, RUN_DEBUG_USB, "WME update failed\n");
2350 
2351 	return (error);
2352 }
2353 
2354 static void
2355 run_key_set_cb(void *arg)
2356 {
2357 	struct run_cmdq *cmdq = arg;
2358 	struct ieee80211vap *vap = cmdq->arg1;
2359 	struct ieee80211_key *k = cmdq->k;
2360 	struct ieee80211com *ic = vap->iv_ic;
2361 	struct run_softc *sc = ic->ic_softc;
2362 	struct ieee80211_node *ni;
2363 	u_int cipher = k->wk_cipher->ic_cipher;
2364 	uint32_t attr;
2365 	uint16_t base, associd;
2366 	uint8_t mode, wcid, iv[8];
2367 
2368 	RUN_LOCK_ASSERT(sc, MA_OWNED);
2369 
2370 	if (vap->iv_opmode == IEEE80211_M_HOSTAP)
2371 		ni = ieee80211_find_vap_node(&ic->ic_sta, vap, cmdq->mac);
2372 	else
2373 		ni = vap->iv_bss;
2374 	associd = (ni != NULL) ? ni->ni_associd : 0;
2375 
2376 	/* map net80211 cipher to RT2860 security mode */
2377 	switch (cipher) {
2378 	case IEEE80211_CIPHER_WEP:
2379 		if(k->wk_keylen < 8)
2380 			mode = RT2860_MODE_WEP40;
2381 		else
2382 			mode = RT2860_MODE_WEP104;
2383 		break;
2384 	case IEEE80211_CIPHER_TKIP:
2385 		mode = RT2860_MODE_TKIP;
2386 		break;
2387 	case IEEE80211_CIPHER_AES_CCM:
2388 		mode = RT2860_MODE_AES_CCMP;
2389 		break;
2390 	default:
2391 		RUN_DPRINTF(sc, RUN_DEBUG_KEY, "undefined case\n");
2392 		return;
2393 	}
2394 
2395 	RUN_DPRINTF(sc, RUN_DEBUG_KEY,
2396 	    "associd=%x, keyix=%d, mode=%x, type=%s, tx=%s, rx=%s\n",
2397 	    associd, k->wk_keyix, mode,
2398 	    (k->wk_flags & IEEE80211_KEY_GROUP) ? "group" : "pairwise",
2399 	    (k->wk_flags & IEEE80211_KEY_XMIT) ? "on" : "off",
2400 	    (k->wk_flags & IEEE80211_KEY_RECV) ? "on" : "off");
2401 
2402 	if (k->wk_flags & IEEE80211_KEY_GROUP) {
2403 		wcid = 0;	/* NB: update WCID0 for group keys */
2404 		base = RT2860_SKEY(RUN_VAP(vap)->rvp_id, k->wk_keyix);
2405 	} else {
2406 		wcid = (vap->iv_opmode == IEEE80211_M_STA) ?
2407 		    1 : RUN_AID2WCID(associd);
2408 		base = RT2860_PKEY(wcid);
2409 	}
2410 
2411 	if (cipher == IEEE80211_CIPHER_TKIP) {
2412 		if(run_write_region_1(sc, base, k->wk_key, 16))
2413 			return;
2414 		if(run_write_region_1(sc, base + 16, &k->wk_key[16], 8))	/* wk_txmic */
2415 			return;
2416 		if(run_write_region_1(sc, base + 24, &k->wk_key[24], 8))	/* wk_rxmic */
2417 			return;
2418 	} else {
2419 		/* roundup len to 16-bit: XXX fix write_region_1() instead */
2420 		if(run_write_region_1(sc, base, k->wk_key, (k->wk_keylen + 1) & ~1))
2421 			return;
2422 	}
2423 
2424 	if (!(k->wk_flags & IEEE80211_KEY_GROUP) ||
2425 	    (k->wk_flags & (IEEE80211_KEY_XMIT | IEEE80211_KEY_RECV))) {
2426 		/* set initial packet number in IV+EIV */
2427 		if (cipher == IEEE80211_CIPHER_WEP) {
2428 			memset(iv, 0, sizeof iv);
2429 			iv[3] = vap->iv_def_txkey << 6;
2430 		} else {
2431 			if (cipher == IEEE80211_CIPHER_TKIP) {
2432 				iv[0] = k->wk_keytsc >> 8;
2433 				iv[1] = (iv[0] | 0x20) & 0x7f;
2434 				iv[2] = k->wk_keytsc;
2435 			} else /* CCMP */ {
2436 				iv[0] = k->wk_keytsc;
2437 				iv[1] = k->wk_keytsc >> 8;
2438 				iv[2] = 0;
2439 			}
2440 			iv[3] = k->wk_keyix << 6 | IEEE80211_WEP_EXTIV;
2441 			iv[4] = k->wk_keytsc >> 16;
2442 			iv[5] = k->wk_keytsc >> 24;
2443 			iv[6] = k->wk_keytsc >> 32;
2444 			iv[7] = k->wk_keytsc >> 40;
2445 		}
2446 		if (run_write_region_1(sc, RT2860_IVEIV(wcid), iv, 8))
2447 			return;
2448 	}
2449 
2450 	if (k->wk_flags & IEEE80211_KEY_GROUP) {
2451 		/* install group key */
2452 		if (run_read(sc, RT2860_SKEY_MODE_0_7, &attr))
2453 			return;
2454 		attr &= ~(0xf << (k->wk_keyix * 4));
2455 		attr |= mode << (k->wk_keyix * 4);
2456 		if (run_write(sc, RT2860_SKEY_MODE_0_7, attr))
2457 			return;
2458 	} else {
2459 		/* install pairwise key */
2460 		if (run_read(sc, RT2860_WCID_ATTR(wcid), &attr))
2461 			return;
2462 		attr = (attr & ~0xf) | (mode << 1) | RT2860_RX_PKEY_EN;
2463 		if (run_write(sc, RT2860_WCID_ATTR(wcid), attr))
2464 			return;
2465 	}
2466 
2467 	/* TODO create a pass-thru key entry? */
2468 
2469 	/* need wcid to delete the right key later */
2470 	k->wk_pad = wcid;
2471 }
2472 
2473 /*
2474  * Don't have to be deferred, but in order to keep order of
2475  * execution, i.e. with run_key_delete(), defer this and let
2476  * run_cmdq_cb() maintain the order.
2477  *
2478  * return 0 on error
2479  */
2480 static int
2481 run_key_set(struct ieee80211vap *vap, struct ieee80211_key *k)
2482 {
2483 	struct ieee80211com *ic = vap->iv_ic;
2484 	struct run_softc *sc = ic->ic_softc;
2485 	uint32_t i;
2486 
2487 	i = RUN_CMDQ_GET(&sc->cmdq_store);
2488 	RUN_DPRINTF(sc, RUN_DEBUG_KEY, "cmdq_store=%d\n", i);
2489 	sc->cmdq[i].func = run_key_set_cb;
2490 	sc->cmdq[i].arg0 = NULL;
2491 	sc->cmdq[i].arg1 = vap;
2492 	sc->cmdq[i].k = k;
2493 	IEEE80211_ADDR_COPY(sc->cmdq[i].mac, k->wk_macaddr);
2494 	ieee80211_runtask(ic, &sc->cmdq_task);
2495 
2496 	/*
2497 	 * To make sure key will be set when hostapd
2498 	 * calls iv_key_set() before if_init().
2499 	 */
2500 	if (vap->iv_opmode == IEEE80211_M_HOSTAP) {
2501 		RUN_LOCK(sc);
2502 		sc->cmdq_key_set = RUN_CMDQ_GO;
2503 		RUN_UNLOCK(sc);
2504 	}
2505 
2506 	return (1);
2507 }
2508 
2509 /*
2510  * If wlan is destroyed without being brought down i.e. without
2511  * wlan down or wpa_cli terminate, this function is called after
2512  * vap is gone. Don't refer it.
2513  */
2514 static void
2515 run_key_delete_cb(void *arg)
2516 {
2517 	struct run_cmdq *cmdq = arg;
2518 	struct run_softc *sc = cmdq->arg1;
2519 	struct ieee80211_key *k = &cmdq->key;
2520 	uint32_t attr;
2521 	uint8_t wcid;
2522 
2523 	RUN_LOCK_ASSERT(sc, MA_OWNED);
2524 
2525 	if (k->wk_flags & IEEE80211_KEY_GROUP) {
2526 		/* remove group key */
2527 		RUN_DPRINTF(sc, RUN_DEBUG_KEY, "removing group key\n");
2528 		run_read(sc, RT2860_SKEY_MODE_0_7, &attr);
2529 		attr &= ~(0xf << (k->wk_keyix * 4));
2530 		run_write(sc, RT2860_SKEY_MODE_0_7, attr);
2531 	} else {
2532 		/* remove pairwise key */
2533 		RUN_DPRINTF(sc, RUN_DEBUG_KEY,
2534 		    "removing key for wcid %x\n", k->wk_pad);
2535 		/* matching wcid was written to wk_pad in run_key_set() */
2536 		wcid = k->wk_pad;
2537 		run_read(sc, RT2860_WCID_ATTR(wcid), &attr);
2538 		attr &= ~0xf;
2539 		run_write(sc, RT2860_WCID_ATTR(wcid), attr);
2540 		run_set_region_4(sc, RT2860_WCID_ENTRY(wcid), 0, 8);
2541 	}
2542 
2543 	k->wk_pad = 0;
2544 }
2545 
2546 /*
2547  * return 0 on error
2548  */
2549 static int
2550 run_key_delete(struct ieee80211vap *vap, struct ieee80211_key *k)
2551 {
2552 	struct ieee80211com *ic = vap->iv_ic;
2553 	struct run_softc *sc = ic->ic_softc;
2554 	struct ieee80211_key *k0;
2555 	uint32_t i;
2556 
2557 	/*
2558 	 * When called back, key might be gone. So, make a copy
2559 	 * of some values need to delete keys before deferring.
2560 	 * But, because of LOR with node lock, cannot use lock here.
2561 	 * So, use atomic instead.
2562 	 */
2563 	i = RUN_CMDQ_GET(&sc->cmdq_store);
2564 	RUN_DPRINTF(sc, RUN_DEBUG_KEY, "cmdq_store=%d\n", i);
2565 	sc->cmdq[i].func = run_key_delete_cb;
2566 	sc->cmdq[i].arg0 = NULL;
2567 	sc->cmdq[i].arg1 = sc;
2568 	k0 = &sc->cmdq[i].key;
2569 	k0->wk_flags = k->wk_flags;
2570 	k0->wk_keyix = k->wk_keyix;
2571 	/* matching wcid was written to wk_pad in run_key_set() */
2572 	k0->wk_pad = k->wk_pad;
2573 	ieee80211_runtask(ic, &sc->cmdq_task);
2574 	return (1);	/* return fake success */
2575 
2576 }
2577 
2578 static void
2579 run_ratectl_to(void *arg)
2580 {
2581 	struct run_softc *sc = arg;
2582 
2583 	/* do it in a process context, so it can go sleep */
2584 	ieee80211_runtask(&sc->sc_ic, &sc->ratectl_task);
2585 	/* next timeout will be rescheduled in the callback task */
2586 }
2587 
2588 /* ARGSUSED */
2589 static void
2590 run_ratectl_cb(void *arg, int pending)
2591 {
2592 	struct run_softc *sc = arg;
2593 	struct ieee80211com *ic = &sc->sc_ic;
2594 	struct ieee80211vap *vap = TAILQ_FIRST(&ic->ic_vaps);
2595 
2596 	if (vap == NULL)
2597 		return;
2598 
2599 	if (sc->rvp_cnt > 1 || vap->iv_opmode != IEEE80211_M_STA) {
2600 		/*
2601 		 * run_reset_livelock() doesn't do anything with AMRR,
2602 		 * but Ralink wants us to call it every 1 sec. So, we
2603 		 * piggyback here rather than creating another callout.
2604 		 * Livelock may occur only in HOSTAP or IBSS mode
2605 		 * (when h/w is sending beacons).
2606 		 */
2607 		RUN_LOCK(sc);
2608 		run_reset_livelock(sc);
2609 		/* just in case, there are some stats to drain */
2610 		run_drain_fifo(sc);
2611 		RUN_UNLOCK(sc);
2612 	}
2613 
2614 	ieee80211_iterate_nodes(&ic->ic_sta, run_iter_func, sc);
2615 
2616 	RUN_LOCK(sc);
2617 	if(sc->ratectl_run != RUN_RATECTL_OFF)
2618 		usb_callout_reset(&sc->ratectl_ch, hz, run_ratectl_to, sc);
2619 	RUN_UNLOCK(sc);
2620 }
2621 
2622 static void
2623 run_drain_fifo(void *arg)
2624 {
2625 	struct run_softc *sc = arg;
2626 	uint32_t stat;
2627 	uint16_t (*wstat)[3];
2628 	uint8_t wcid, mcs, pid;
2629 	int8_t retry;
2630 
2631 	RUN_LOCK_ASSERT(sc, MA_OWNED);
2632 
2633 	for (;;) {
2634 		/* drain Tx status FIFO (maxsize = 16) */
2635 		run_read(sc, RT2860_TX_STAT_FIFO, &stat);
2636 		RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "tx stat 0x%08x\n", stat);
2637 		if (!(stat & RT2860_TXQ_VLD))
2638 			break;
2639 
2640 		wcid = (stat >> RT2860_TXQ_WCID_SHIFT) & 0xff;
2641 
2642 		/* if no ACK was requested, no feedback is available */
2643 		if (!(stat & RT2860_TXQ_ACKREQ) || wcid > RT2870_WCID_MAX ||
2644 		    wcid == 0)
2645 			continue;
2646 
2647 		/*
2648 		 * Even though each stat is Tx-complete-status like format,
2649 		 * the device can poll stats. Because there is no guarantee
2650 		 * that the referring node is still around when read the stats.
2651 		 * So that, if we use ieee80211_ratectl_tx_update(), we will
2652 		 * have hard time not to refer already freed node.
2653 		 *
2654 		 * To eliminate such page faults, we poll stats in softc.
2655 		 * Then, update the rates later with ieee80211_ratectl_tx_update().
2656 		 */
2657 		wstat = &(sc->wcid_stats[wcid]);
2658 		(*wstat)[RUN_TXCNT]++;
2659 		if (stat & RT2860_TXQ_OK)
2660 			(*wstat)[RUN_SUCCESS]++;
2661 		else
2662 			counter_u64_add(sc->sc_ic.ic_oerrors, 1);
2663 		/*
2664 		 * Check if there were retries, ie if the Tx success rate is
2665 		 * different from the requested rate. Note that it works only
2666 		 * because we do not allow rate fallback from OFDM to CCK.
2667 		 */
2668 		mcs = (stat >> RT2860_TXQ_MCS_SHIFT) & 0x7f;
2669 		pid = (stat >> RT2860_TXQ_PID_SHIFT) & 0xf;
2670 		if ((retry = pid -1 - mcs) > 0) {
2671 			(*wstat)[RUN_TXCNT] += retry;
2672 			(*wstat)[RUN_RETRY] += retry;
2673 		}
2674 	}
2675 	RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "count=%d\n", sc->fifo_cnt);
2676 
2677 	sc->fifo_cnt = 0;
2678 }
2679 
2680 static void
2681 run_iter_func(void *arg, struct ieee80211_node *ni)
2682 {
2683 	struct run_softc *sc = arg;
2684 	struct ieee80211_ratectl_tx_stats *txs = &sc->sc_txs;
2685 	struct ieee80211vap *vap = ni->ni_vap;
2686 	struct run_node *rn = RUN_NODE(ni);
2687 	union run_stats sta[2];
2688 	uint16_t (*wstat)[3];
2689 	int error, ridx;
2690 
2691 	RUN_LOCK(sc);
2692 
2693 	/* Check for special case */
2694 	if (sc->rvp_cnt <= 1 && vap->iv_opmode == IEEE80211_M_STA &&
2695 	    ni != vap->iv_bss)
2696 		goto fail;
2697 
2698 	txs->flags = IEEE80211_RATECTL_TX_STATS_NODE |
2699 		     IEEE80211_RATECTL_TX_STATS_RETRIES;
2700 	txs->ni = ni;
2701 	if (sc->rvp_cnt <= 1 && (vap->iv_opmode == IEEE80211_M_IBSS ||
2702 	    vap->iv_opmode == IEEE80211_M_STA)) {
2703 		/* read statistic counters (clear on read) and update AMRR state */
2704 		error = run_read_region_1(sc, RT2860_TX_STA_CNT0, (uint8_t *)sta,
2705 		    sizeof sta);
2706 		if (error != 0)
2707 			goto fail;
2708 
2709 		/* count failed TX as errors */
2710 		if_inc_counter(vap->iv_ifp, IFCOUNTER_OERRORS,
2711 		    le16toh(sta[0].error.fail));
2712 
2713 		txs->nretries = le16toh(sta[1].tx.retry);
2714 		txs->nsuccess = le16toh(sta[1].tx.success);
2715 		/* nretries??? */
2716 		txs->nframes = txs->nretries + txs->nsuccess +
2717 		    le16toh(sta[0].error.fail);
2718 
2719 		RUN_DPRINTF(sc, RUN_DEBUG_RATE,
2720 		    "retrycnt=%d success=%d failcnt=%d\n",
2721 		    txs->nretries, txs->nsuccess, le16toh(sta[0].error.fail));
2722 	} else {
2723 		wstat = &(sc->wcid_stats[RUN_AID2WCID(ni->ni_associd)]);
2724 
2725 		if (wstat == &(sc->wcid_stats[0]) ||
2726 		    wstat > &(sc->wcid_stats[RT2870_WCID_MAX]))
2727 			goto fail;
2728 
2729 		txs->nretries = (*wstat)[RUN_RETRY];
2730 		txs->nsuccess = (*wstat)[RUN_SUCCESS];
2731 		txs->nframes = (*wstat)[RUN_TXCNT];
2732 		RUN_DPRINTF(sc, RUN_DEBUG_RATE,
2733 		    "retrycnt=%d txcnt=%d success=%d\n",
2734 		    txs->nretries, txs->nframes, txs->nsuccess);
2735 
2736 		memset(wstat, 0, sizeof(*wstat));
2737 	}
2738 
2739 	ieee80211_ratectl_tx_update(vap, txs);
2740 	ieee80211_ratectl_rate(ni, NULL, 0);
2741 	/* XXX TODO: methodize with MCS rates */
2742 	for (ridx = 0; ridx < RT2860_RIDX_MAX; ridx++)
2743 		if (rt2860_rates[ridx].rate == ni->ni_txrate)
2744 			break;
2745 	rn->amrr_ridx = ridx;
2746 
2747 fail:
2748 	RUN_UNLOCK(sc);
2749 
2750 	RUN_DPRINTF(sc, RUN_DEBUG_RATE, "rate=%d, ridx=%d\n", ni->ni_txrate, rn->amrr_ridx);
2751 }
2752 
2753 static void
2754 run_newassoc_cb(void *arg)
2755 {
2756 	struct run_cmdq *cmdq = arg;
2757 	struct ieee80211_node *ni = cmdq->arg1;
2758 	struct run_softc *sc = ni->ni_vap->iv_ic->ic_softc;
2759 	uint8_t wcid = cmdq->wcid;
2760 
2761 	RUN_LOCK_ASSERT(sc, MA_OWNED);
2762 
2763 	run_write_region_1(sc, RT2860_WCID_ENTRY(wcid),
2764 	    ni->ni_macaddr, IEEE80211_ADDR_LEN);
2765 
2766 	memset(&(sc->wcid_stats[wcid]), 0, sizeof(sc->wcid_stats[wcid]));
2767 }
2768 
2769 static void
2770 run_newassoc(struct ieee80211_node *ni, int isnew)
2771 {
2772 	struct run_node *rn = RUN_NODE(ni);
2773 	struct ieee80211vap *vap = ni->ni_vap;
2774 	struct ieee80211com *ic = vap->iv_ic;
2775 	struct run_softc *sc = ic->ic_softc;
2776 	uint8_t rate;
2777 	uint8_t ridx;
2778 	uint8_t wcid;
2779 
2780 	wcid = (vap->iv_opmode == IEEE80211_M_STA) ?
2781 	    1 : RUN_AID2WCID(ni->ni_associd);
2782 
2783 	if (wcid > RT2870_WCID_MAX) {
2784 		device_printf(sc->sc_dev, "wcid=%d out of range\n", wcid);
2785 		return;
2786 	}
2787 
2788 	/* only interested in true associations */
2789 	if (isnew && ni->ni_associd != 0) {
2790 		/*
2791 		 * This function could is called though timeout function.
2792 		 * Need to defer.
2793 		 */
2794 		uint32_t cnt = RUN_CMDQ_GET(&sc->cmdq_store);
2795 		RUN_DPRINTF(sc, RUN_DEBUG_STATE, "cmdq_store=%d\n", cnt);
2796 		sc->cmdq[cnt].func = run_newassoc_cb;
2797 		sc->cmdq[cnt].arg0 = NULL;
2798 		sc->cmdq[cnt].arg1 = ni;
2799 		sc->cmdq[cnt].wcid = wcid;
2800 		ieee80211_runtask(ic, &sc->cmdq_task);
2801 	}
2802 
2803 	RUN_DPRINTF(sc, RUN_DEBUG_STATE,
2804 	    "new assoc isnew=%d associd=%x addr=%s\n",
2805 	    isnew, ni->ni_associd, ether_sprintf(ni->ni_macaddr));
2806 
2807 	rate = vap->iv_txparms[ieee80211_chan2mode(ic->ic_curchan)].mgmtrate;
2808 	/* XXX TODO: methodize with MCS rates */
2809 	for (ridx = 0; ridx < RT2860_RIDX_MAX; ridx++)
2810 		if (rt2860_rates[ridx].rate == rate)
2811 			break;
2812 	rn->mgt_ridx = ridx;
2813 	RUN_DPRINTF(sc, RUN_DEBUG_STATE | RUN_DEBUG_RATE,
2814 	    "rate=%d, mgmt_ridx=%d\n", rate, rn->mgt_ridx);
2815 
2816 	RUN_LOCK(sc);
2817 	if(sc->ratectl_run != RUN_RATECTL_OFF)
2818 		usb_callout_reset(&sc->ratectl_ch, hz, run_ratectl_to, sc);
2819 	RUN_UNLOCK(sc);
2820 }
2821 
2822 /*
2823  * Return the Rx chain with the highest RSSI for a given frame.
2824  */
2825 static __inline uint8_t
2826 run_maxrssi_chain(struct run_softc *sc, const struct rt2860_rxwi *rxwi)
2827 {
2828 	uint8_t rxchain = 0;
2829 
2830 	if (sc->nrxchains > 1) {
2831 		if (rxwi->rssi[1] > rxwi->rssi[rxchain])
2832 			rxchain = 1;
2833 		if (sc->nrxchains > 2)
2834 			if (rxwi->rssi[2] > rxwi->rssi[rxchain])
2835 				rxchain = 2;
2836 	}
2837 	return (rxchain);
2838 }
2839 
2840 static void
2841 run_recv_mgmt(struct ieee80211_node *ni, struct mbuf *m, int subtype,
2842     const struct ieee80211_rx_stats *rxs, int rssi, int nf)
2843 {
2844 	struct ieee80211vap *vap = ni->ni_vap;
2845 	struct run_softc *sc = vap->iv_ic->ic_softc;
2846 	struct run_vap *rvp = RUN_VAP(vap);
2847 	uint64_t ni_tstamp, rx_tstamp;
2848 
2849 	rvp->recv_mgmt(ni, m, subtype, rxs, rssi, nf);
2850 
2851 	if (vap->iv_state == IEEE80211_S_RUN &&
2852 	    (subtype == IEEE80211_FC0_SUBTYPE_BEACON ||
2853 	    subtype == IEEE80211_FC0_SUBTYPE_PROBE_RESP)) {
2854 		ni_tstamp = le64toh(ni->ni_tstamp.tsf);
2855 		RUN_LOCK(sc);
2856 		run_get_tsf(sc, &rx_tstamp);
2857 		RUN_UNLOCK(sc);
2858 		rx_tstamp = le64toh(rx_tstamp);
2859 
2860 		if (ni_tstamp >= rx_tstamp) {
2861 			RUN_DPRINTF(sc, RUN_DEBUG_RECV | RUN_DEBUG_BEACON,
2862 			    "ibss merge, tsf %ju tstamp %ju\n",
2863 			    (uintmax_t)rx_tstamp, (uintmax_t)ni_tstamp);
2864 			(void) ieee80211_ibss_merge(ni);
2865 		}
2866 	}
2867 }
2868 
2869 static void
2870 run_rx_frame(struct run_softc *sc, struct mbuf *m, uint32_t dmalen)
2871 {
2872 	struct ieee80211com *ic = &sc->sc_ic;
2873 	struct ieee80211_frame *wh;
2874 	struct ieee80211_node *ni;
2875 	struct epoch_tracker et;
2876 	struct rt2870_rxd *rxd;
2877 	struct rt2860_rxwi *rxwi;
2878 	uint32_t flags;
2879 	uint16_t len, rxwisize;
2880 	uint8_t ant, rssi;
2881 	int8_t nf;
2882 
2883 	rxwisize = sizeof(struct rt2860_rxwi);
2884 	if (sc->mac_ver == 0x5592)
2885 		rxwisize += sizeof(uint64_t);
2886 	else if (sc->mac_ver == 0x3593)
2887 		rxwisize += sizeof(uint32_t);
2888 
2889 	if (__predict_false(dmalen <
2890 	    rxwisize + sizeof(struct ieee80211_frame_ack))) {
2891 		RUN_DPRINTF(sc, RUN_DEBUG_RECV,
2892 		    "payload is too short: dma length %u < %zu\n",
2893 		    dmalen, rxwisize + sizeof(struct ieee80211_frame_ack));
2894 		goto fail;
2895 	}
2896 
2897 	rxwi = mtod(m, struct rt2860_rxwi *);
2898 	len = le16toh(rxwi->len) & 0xfff;
2899 
2900 	if (__predict_false(len > dmalen - rxwisize)) {
2901 		RUN_DPRINTF(sc, RUN_DEBUG_RECV,
2902 		    "bad RXWI length %u > %u\n", len, dmalen);
2903 		goto fail;
2904 	}
2905 
2906 	/* Rx descriptor is located at the end */
2907 	rxd = (struct rt2870_rxd *)(mtod(m, caddr_t) + dmalen);
2908 	flags = le32toh(rxd->flags);
2909 
2910 	if (__predict_false(flags & (RT2860_RX_CRCERR | RT2860_RX_ICVERR))) {
2911 		RUN_DPRINTF(sc, RUN_DEBUG_RECV, "%s error.\n",
2912 		    (flags & RT2860_RX_CRCERR)?"CRC":"ICV");
2913 		goto fail;
2914 	}
2915 
2916 	if (flags & RT2860_RX_L2PAD) {
2917 		RUN_DPRINTF(sc, RUN_DEBUG_RECV,
2918 		    "received RT2860_RX_L2PAD frame\n");
2919 		len += 2;
2920 	}
2921 
2922 	m->m_data += rxwisize;
2923 	m->m_pkthdr.len = m->m_len = len;
2924 
2925 	wh = mtod(m, struct ieee80211_frame *);
2926 
2927 	if ((wh->i_fc[1] & IEEE80211_FC1_PROTECTED) != 0 &&
2928 	    (flags & RT2860_RX_DEC) != 0) {
2929 		wh->i_fc[1] &= ~IEEE80211_FC1_PROTECTED;
2930 		m->m_flags |= M_WEP;
2931 	}
2932 
2933 	if (len >= sizeof(struct ieee80211_frame_min)) {
2934 		ni = ieee80211_find_rxnode(ic,
2935 		    mtod(m, struct ieee80211_frame_min *));
2936 	} else
2937 		ni = NULL;
2938 
2939 	if(ni && ni->ni_flags & IEEE80211_NODE_HT) {
2940 		m->m_flags |= M_AMPDU;
2941 	}
2942 
2943 	if (__predict_false(flags & RT2860_RX_MICERR)) {
2944 		/* report MIC failures to net80211 for TKIP */
2945 		if (ni != NULL)
2946 			ieee80211_notify_michael_failure(ni->ni_vap, wh,
2947 			    rxwi->keyidx);
2948 		RUN_DPRINTF(sc, RUN_DEBUG_RECV,
2949 		    "MIC error. Someone is lying.\n");
2950 		goto fail;
2951 	}
2952 
2953 	ant = run_maxrssi_chain(sc, rxwi);
2954 	rssi = rxwi->rssi[ant];
2955 	nf = run_rssi2dbm(sc, rssi, ant);
2956 
2957 	if (__predict_false(ieee80211_radiotap_active(ic))) {
2958 		struct run_rx_radiotap_header *tap = &sc->sc_rxtap;
2959 		uint16_t phy;
2960 
2961 		tap->wr_flags = 0;
2962 		if (flags & RT2860_RX_L2PAD)
2963 			tap->wr_flags |= IEEE80211_RADIOTAP_F_DATAPAD;
2964 		tap->wr_antsignal = rssi;
2965 		tap->wr_antenna = ant;
2966 		tap->wr_dbm_antsignal = run_rssi2dbm(sc, rssi, ant);
2967 		tap->wr_rate = 2;	/* in case it can't be found below */
2968 		RUN_LOCK(sc);
2969 		run_get_tsf(sc, &tap->wr_tsf);
2970 		RUN_UNLOCK(sc);
2971 		phy = le16toh(rxwi->phy);
2972 		switch (phy & RT2860_PHY_MODE) {
2973 		case RT2860_PHY_CCK:
2974 			switch ((phy & RT2860_PHY_MCS) & ~RT2860_PHY_SHPRE) {
2975 			case 0:	tap->wr_rate =   2; break;
2976 			case 1:	tap->wr_rate =   4; break;
2977 			case 2:	tap->wr_rate =  11; break;
2978 			case 3:	tap->wr_rate =  22; break;
2979 			}
2980 			if (phy & RT2860_PHY_SHPRE)
2981 				tap->wr_flags |= IEEE80211_RADIOTAP_F_SHORTPRE;
2982 			break;
2983 		case RT2860_PHY_OFDM:
2984 			switch (phy & RT2860_PHY_MCS) {
2985 			case 0:	tap->wr_rate =  12; break;
2986 			case 1:	tap->wr_rate =  18; break;
2987 			case 2:	tap->wr_rate =  24; break;
2988 			case 3:	tap->wr_rate =  36; break;
2989 			case 4:	tap->wr_rate =  48; break;
2990 			case 5:	tap->wr_rate =  72; break;
2991 			case 6:	tap->wr_rate =  96; break;
2992 			case 7:	tap->wr_rate = 108; break;
2993 			}
2994 			break;
2995 		}
2996 	}
2997 
2998 	NET_EPOCH_ENTER(et);
2999 	if (ni != NULL) {
3000 		(void)ieee80211_input(ni, m, rssi, nf);
3001 		ieee80211_free_node(ni);
3002 	} else {
3003 		(void)ieee80211_input_all(ic, m, rssi, nf);
3004 	}
3005 	NET_EPOCH_EXIT(et);
3006 
3007 	return;
3008 
3009 fail:
3010 	m_freem(m);
3011 	counter_u64_add(ic->ic_ierrors, 1);
3012 }
3013 
3014 static void
3015 run_bulk_rx_callback(struct usb_xfer *xfer, usb_error_t error)
3016 {
3017 	struct run_softc *sc = usbd_xfer_softc(xfer);
3018 	struct ieee80211com *ic = &sc->sc_ic;
3019 	struct mbuf *m = NULL;
3020 	struct mbuf *m0;
3021 	uint32_t dmalen, mbuf_len;
3022 	uint16_t rxwisize;
3023 	int xferlen;
3024 
3025 	rxwisize = sizeof(struct rt2860_rxwi);
3026 	if (sc->mac_ver == 0x5592)
3027 		rxwisize += sizeof(uint64_t);
3028 	else if (sc->mac_ver == 0x3593)
3029 		rxwisize += sizeof(uint32_t);
3030 
3031 	usbd_xfer_status(xfer, &xferlen, NULL, NULL, NULL);
3032 
3033 	switch (USB_GET_STATE(xfer)) {
3034 	case USB_ST_TRANSFERRED:
3035 
3036 		RUN_DPRINTF(sc, RUN_DEBUG_RECV,
3037 		    "rx done, actlen=%d\n", xferlen);
3038 
3039 		if (xferlen < (int)(sizeof(uint32_t) + rxwisize +
3040 		    sizeof(struct rt2870_rxd))) {
3041 			RUN_DPRINTF(sc, RUN_DEBUG_RECV_DESC | RUN_DEBUG_USB,
3042 			    "xfer too short %d\n", xferlen);
3043 			goto tr_setup;
3044 		}
3045 
3046 		m = sc->rx_m;
3047 		sc->rx_m = NULL;
3048 
3049 		/* FALLTHROUGH */
3050 	case USB_ST_SETUP:
3051 tr_setup:
3052 		if (sc->rx_m == NULL) {
3053 			sc->rx_m = m_getjcl(M_NOWAIT, MT_DATA, M_PKTHDR,
3054 			    RUN_MAX_RXSZ);
3055 		}
3056 		if (sc->rx_m == NULL) {
3057 			RUN_DPRINTF(sc, RUN_DEBUG_RECV |
3058 			    RUN_DEBUG_RECV_DESC | RUN_DEBUG_USB,
3059 			    "could not allocate mbuf - idle with stall\n");
3060 			counter_u64_add(ic->ic_ierrors, 1);
3061 			usbd_xfer_set_stall(xfer);
3062 			usbd_xfer_set_frames(xfer, 0);
3063 		} else {
3064 			/*
3065 			 * Directly loading a mbuf cluster into DMA to
3066 			 * save some data copying. This works because
3067 			 * there is only one cluster.
3068 			 */
3069 			usbd_xfer_set_frame_data(xfer, 0,
3070 			    mtod(sc->rx_m, caddr_t), RUN_MAX_RXSZ);
3071 			usbd_xfer_set_frames(xfer, 1);
3072 		}
3073 		usbd_transfer_submit(xfer);
3074 		break;
3075 
3076 	default:	/* Error */
3077 		if (error != USB_ERR_CANCELLED) {
3078 			/* try to clear stall first */
3079 			usbd_xfer_set_stall(xfer);
3080 			if (error == USB_ERR_TIMEOUT)
3081 				device_printf(sc->sc_dev, "device timeout\n");
3082 			counter_u64_add(ic->ic_ierrors, 1);
3083 			goto tr_setup;
3084 		}
3085 		if (sc->rx_m != NULL) {
3086 			m_freem(sc->rx_m);
3087 			sc->rx_m = NULL;
3088 		}
3089 		break;
3090 	}
3091 
3092 	if (m == NULL)
3093 		return;
3094 
3095 	/* inputting all the frames must be last */
3096 
3097 	RUN_UNLOCK(sc);
3098 
3099 	m->m_pkthdr.len = m->m_len = xferlen;
3100 
3101 	/* HW can aggregate multiple 802.11 frames in a single USB xfer */
3102 	for(;;) {
3103 		dmalen = le32toh(*mtod(m, uint32_t *)) & 0xffff;
3104 
3105 		if ((dmalen >= (uint32_t)-8) || (dmalen == 0) ||
3106 		    ((dmalen & 3) != 0)) {
3107 			RUN_DPRINTF(sc, RUN_DEBUG_RECV_DESC | RUN_DEBUG_USB,
3108 			    "bad DMA length %u\n", dmalen);
3109 			break;
3110 		}
3111 		if ((dmalen + 8) > (uint32_t)xferlen) {
3112 			RUN_DPRINTF(sc, RUN_DEBUG_RECV_DESC | RUN_DEBUG_USB,
3113 			    "bad DMA length %u > %d\n",
3114 			dmalen + 8, xferlen);
3115 			break;
3116 		}
3117 
3118 		/* If it is the last one or a single frame, we won't copy. */
3119 		if ((xferlen -= dmalen + 8) <= 8) {
3120 			/* trim 32-bit DMA-len header */
3121 			m->m_data += 4;
3122 			m->m_pkthdr.len = m->m_len -= 4;
3123 			run_rx_frame(sc, m, dmalen);
3124 			m = NULL;	/* don't free source buffer */
3125 			break;
3126 		}
3127 
3128 		mbuf_len = dmalen + sizeof(struct rt2870_rxd);
3129 		if (__predict_false(mbuf_len > MCLBYTES)) {
3130 			RUN_DPRINTF(sc, RUN_DEBUG_RECV_DESC | RUN_DEBUG_USB,
3131 			    "payload is too big: mbuf_len %u\n", mbuf_len);
3132 			counter_u64_add(ic->ic_ierrors, 1);
3133 			break;
3134 		}
3135 
3136 		/* copy aggregated frames to another mbuf */
3137 		m0 = m_getcl(M_NOWAIT, MT_DATA, M_PKTHDR);
3138 		if (__predict_false(m0 == NULL)) {
3139 			RUN_DPRINTF(sc, RUN_DEBUG_RECV_DESC,
3140 			    "could not allocate mbuf\n");
3141 			counter_u64_add(ic->ic_ierrors, 1);
3142 			break;
3143 		}
3144 		m_copydata(m, 4 /* skip 32-bit DMA-len header */,
3145 		    mbuf_len, mtod(m0, caddr_t));
3146 		m0->m_pkthdr.len = m0->m_len = mbuf_len;
3147 		run_rx_frame(sc, m0, dmalen);
3148 
3149 		/* update data ptr */
3150 		m->m_data += mbuf_len + 4;
3151 		m->m_pkthdr.len = m->m_len -= mbuf_len + 4;
3152 	}
3153 
3154 	/* make sure we free the source buffer, if any */
3155 	m_freem(m);
3156 
3157 #ifdef	IEEE80211_SUPPORT_SUPERG
3158 	ieee80211_ff_age_all(ic, 100);
3159 #endif
3160 	RUN_LOCK(sc);
3161 }
3162 
3163 static void
3164 run_tx_free(struct run_endpoint_queue *pq,
3165     struct run_tx_data *data, int txerr)
3166 {
3167 
3168 	ieee80211_tx_complete(data->ni, data->m, txerr);
3169 
3170 	data->m = NULL;
3171 	data->ni = NULL;
3172 
3173 	STAILQ_INSERT_TAIL(&pq->tx_fh, data, next);
3174 	pq->tx_nfree++;
3175 }
3176 
3177 static void
3178 run_bulk_tx_callbackN(struct usb_xfer *xfer, usb_error_t error, u_int index)
3179 {
3180 	struct run_softc *sc = usbd_xfer_softc(xfer);
3181 	struct ieee80211com *ic = &sc->sc_ic;
3182 	struct run_tx_data *data;
3183 	struct ieee80211vap *vap = NULL;
3184 	struct usb_page_cache *pc;
3185 	struct run_endpoint_queue *pq = &sc->sc_epq[index];
3186 	struct mbuf *m;
3187 	usb_frlength_t size;
3188 	int actlen;
3189 	int sumlen;
3190 
3191 	usbd_xfer_status(xfer, &actlen, &sumlen, NULL, NULL);
3192 
3193 	switch (USB_GET_STATE(xfer)) {
3194 	case USB_ST_TRANSFERRED:
3195 		RUN_DPRINTF(sc, RUN_DEBUG_XMIT | RUN_DEBUG_USB,
3196 		    "transfer complete: %d bytes @ index %d\n", actlen, index);
3197 
3198 		data = usbd_xfer_get_priv(xfer);
3199 		run_tx_free(pq, data, 0);
3200 		usbd_xfer_set_priv(xfer, NULL);
3201 
3202 		/* FALLTHROUGH */
3203 	case USB_ST_SETUP:
3204 tr_setup:
3205 		data = STAILQ_FIRST(&pq->tx_qh);
3206 		if (data == NULL)
3207 			break;
3208 
3209 		STAILQ_REMOVE_HEAD(&pq->tx_qh, next);
3210 
3211 		m = data->m;
3212 		size = (sc->mac_ver == 0x5592) ?
3213 		    sizeof(data->desc) + sizeof(uint32_t) : sizeof(data->desc);
3214 		if ((m->m_pkthdr.len +
3215 		    size + 3 + 8) > RUN_MAX_TXSZ) {
3216 			RUN_DPRINTF(sc, RUN_DEBUG_XMIT_DESC | RUN_DEBUG_USB,
3217 			    "data overflow, %u bytes\n", m->m_pkthdr.len);
3218 			run_tx_free(pq, data, 1);
3219 			goto tr_setup;
3220 		}
3221 
3222 		pc = usbd_xfer_get_frame(xfer, 0);
3223 		usbd_copy_in(pc, 0, &data->desc, size);
3224 		usbd_m_copy_in(pc, size, m, 0, m->m_pkthdr.len);
3225 		size += m->m_pkthdr.len;
3226 		/*
3227 		 * Align end on a 4-byte boundary, pad 8 bytes (CRC +
3228 		 * 4-byte padding), and be sure to zero those trailing
3229 		 * bytes:
3230 		 */
3231 		usbd_frame_zero(pc, size, ((-size) & 3) + 8);
3232 		size += ((-size) & 3) + 8;
3233 
3234 		vap = data->ni->ni_vap;
3235 		if (ieee80211_radiotap_active_vap(vap)) {
3236 			const struct ieee80211_frame *wh;
3237 			struct run_tx_radiotap_header *tap = &sc->sc_txtap;
3238 			struct rt2860_txwi *txwi =
3239 			    (struct rt2860_txwi *)(&data->desc + sizeof(struct rt2870_txd));
3240 			int has_l2pad;
3241 
3242 			wh = mtod(m, struct ieee80211_frame *);
3243 			has_l2pad = IEEE80211_HAS_ADDR4(wh) !=
3244 			    IEEE80211_QOS_HAS_SEQ(wh);
3245 
3246 			tap->wt_flags = 0;
3247 			tap->wt_rate = rt2860_rates[data->ridx].rate;
3248 			tap->wt_hwqueue = index;
3249 			if (le16toh(txwi->phy) & RT2860_PHY_SHPRE)
3250 				tap->wt_flags |= IEEE80211_RADIOTAP_F_SHORTPRE;
3251 			if (has_l2pad)
3252 				tap->wt_flags |= IEEE80211_RADIOTAP_F_DATAPAD;
3253 
3254 			ieee80211_radiotap_tx(vap, m);
3255 		}
3256 
3257 		RUN_DPRINTF(sc, RUN_DEBUG_XMIT | RUN_DEBUG_USB,
3258 		    "sending frame len=%u/%u @ index %d\n",
3259 		    m->m_pkthdr.len, size, index);
3260 
3261 		usbd_xfer_set_frame_len(xfer, 0, size);
3262 		usbd_xfer_set_priv(xfer, data);
3263 		usbd_transfer_submit(xfer);
3264 		run_start(sc);
3265 
3266 		break;
3267 
3268 	default:
3269 		RUN_DPRINTF(sc, RUN_DEBUG_XMIT | RUN_DEBUG_USB,
3270 		    "USB transfer error, %s\n", usbd_errstr(error));
3271 
3272 		data = usbd_xfer_get_priv(xfer);
3273 
3274 		if (data != NULL) {
3275 			if(data->ni != NULL)
3276 				vap = data->ni->ni_vap;
3277 			run_tx_free(pq, data, error);
3278 			usbd_xfer_set_priv(xfer, NULL);
3279 		}
3280 
3281 		if (vap == NULL)
3282 			vap = TAILQ_FIRST(&ic->ic_vaps);
3283 
3284 		if (error != USB_ERR_CANCELLED) {
3285 			if (error == USB_ERR_TIMEOUT) {
3286 				device_printf(sc->sc_dev, "device timeout\n");
3287 				uint32_t i = RUN_CMDQ_GET(&sc->cmdq_store);
3288 				RUN_DPRINTF(sc, RUN_DEBUG_XMIT | RUN_DEBUG_USB,
3289 				    "cmdq_store=%d\n", i);
3290 				sc->cmdq[i].func = run_usb_timeout_cb;
3291 				sc->cmdq[i].arg0 = vap;
3292 				ieee80211_runtask(ic, &sc->cmdq_task);
3293 			}
3294 
3295 			/*
3296 			 * Try to clear stall first, also if other
3297 			 * errors occur, hence clearing stall
3298 			 * introduces a 50 ms delay:
3299 			 */
3300 			usbd_xfer_set_stall(xfer);
3301 			goto tr_setup;
3302 		}
3303 		break;
3304 	}
3305 #ifdef	IEEE80211_SUPPORT_SUPERG
3306 	/* XXX TODO: make this deferred rather than unlock/relock */
3307 	/* XXX TODO: should only do the QoS AC this belongs to */
3308 	if (pq->tx_nfree >= RUN_TX_RING_COUNT) {
3309 		RUN_UNLOCK(sc);
3310 		ieee80211_ff_flush_all(ic);
3311 		RUN_LOCK(sc);
3312 	}
3313 #endif
3314 }
3315 
3316 static void
3317 run_bulk_tx_callback0(struct usb_xfer *xfer, usb_error_t error)
3318 {
3319 	run_bulk_tx_callbackN(xfer, error, 0);
3320 }
3321 
3322 static void
3323 run_bulk_tx_callback1(struct usb_xfer *xfer, usb_error_t error)
3324 {
3325 	run_bulk_tx_callbackN(xfer, error, 1);
3326 }
3327 
3328 static void
3329 run_bulk_tx_callback2(struct usb_xfer *xfer, usb_error_t error)
3330 {
3331 	run_bulk_tx_callbackN(xfer, error, 2);
3332 }
3333 
3334 static void
3335 run_bulk_tx_callback3(struct usb_xfer *xfer, usb_error_t error)
3336 {
3337 	run_bulk_tx_callbackN(xfer, error, 3);
3338 }
3339 
3340 static void
3341 run_bulk_tx_callback4(struct usb_xfer *xfer, usb_error_t error)
3342 {
3343 	run_bulk_tx_callbackN(xfer, error, 4);
3344 }
3345 
3346 static void
3347 run_bulk_tx_callback5(struct usb_xfer *xfer, usb_error_t error)
3348 {
3349 	run_bulk_tx_callbackN(xfer, error, 5);
3350 }
3351 
3352 static void
3353 run_set_tx_desc(struct run_softc *sc, struct run_tx_data *data)
3354 {
3355 	struct mbuf *m = data->m;
3356 	struct ieee80211com *ic = &sc->sc_ic;
3357 	struct ieee80211vap *vap = data->ni->ni_vap;
3358 	struct ieee80211_frame *wh;
3359 	struct rt2870_txd *txd;
3360 	struct rt2860_txwi *txwi;
3361 	uint16_t xferlen, txwisize;
3362 	uint16_t mcs;
3363 	uint8_t ridx = data->ridx;
3364 	uint8_t pad;
3365 
3366 	/* get MCS code from rate index */
3367 	mcs = rt2860_rates[ridx].mcs;
3368 
3369 	txwisize = (sc->mac_ver == 0x5592) ?
3370 	    sizeof(*txwi) + sizeof(uint32_t) : sizeof(*txwi);
3371 	xferlen = txwisize + m->m_pkthdr.len;
3372 
3373 	/* roundup to 32-bit alignment */
3374 	xferlen = (xferlen + 3) & ~3;
3375 
3376 	txd = (struct rt2870_txd *)&data->desc;
3377 	txd->len = htole16(xferlen);
3378 
3379 	wh = mtod(m, struct ieee80211_frame *);
3380 
3381 	/*
3382 	 * Ether both are true or both are false, the header
3383 	 * are nicely aligned to 32-bit. So, no L2 padding.
3384 	 */
3385 	if(IEEE80211_HAS_ADDR4(wh) == IEEE80211_QOS_HAS_SEQ(wh))
3386 		pad = 0;
3387 	else
3388 		pad = 2;
3389 
3390 	/* setup TX Wireless Information */
3391 	txwi = (struct rt2860_txwi *)(txd + 1);
3392 	txwi->len = htole16(m->m_pkthdr.len - pad);
3393 	if (rt2860_rates[ridx].phy == IEEE80211_T_DS) {
3394 		mcs |= RT2860_PHY_CCK;
3395 		if (ridx != RT2860_RIDX_CCK1 &&
3396 		    (ic->ic_flags & IEEE80211_F_SHPREAMBLE))
3397 			mcs |= RT2860_PHY_SHPRE;
3398 	} else if (rt2860_rates[ridx].phy == IEEE80211_T_OFDM) {
3399 		mcs |= RT2860_PHY_OFDM;
3400 	} else if (rt2860_rates[ridx].phy == IEEE80211_T_HT) {
3401 		/* XXX TODO: [adrian] set short preamble for MCS? */
3402 		mcs |= RT2860_PHY_HT_MIX; /* Mixed, not greenfield */
3403 	}
3404 	txwi->phy = htole16(mcs);
3405 
3406 	/* check if RTS/CTS or CTS-to-self protection is required */
3407 	if (!IEEE80211_IS_MULTICAST(wh->i_addr1) &&
3408 	    ((m->m_pkthdr.len + IEEE80211_CRC_LEN > vap->iv_rtsthreshold) ||
3409 	     ((ic->ic_flags & IEEE80211_F_USEPROT) &&
3410 	      rt2860_rates[ridx].phy == IEEE80211_T_OFDM) ||
3411 	     ((ic->ic_htprotmode == IEEE80211_PROT_RTSCTS) &&
3412 	      rt2860_rates[ridx].phy == IEEE80211_T_HT)))
3413 		txwi->txop |= RT2860_TX_TXOP_HT;
3414 	else
3415 		txwi->txop |= RT2860_TX_TXOP_BACKOFF;
3416 
3417 	if (vap->iv_opmode != IEEE80211_M_STA && !IEEE80211_QOS_HAS_SEQ(wh))
3418 		txwi->xflags |= RT2860_TX_NSEQ;
3419 }
3420 
3421 /* This function must be called locked */
3422 static int
3423 run_tx(struct run_softc *sc, struct mbuf *m, struct ieee80211_node *ni)
3424 {
3425 	struct ieee80211com *ic = &sc->sc_ic;
3426 	struct ieee80211vap *vap = ni->ni_vap;
3427 	struct ieee80211_frame *wh;
3428 	const struct ieee80211_txparam *tp = ni->ni_txparms;
3429 	struct run_node *rn = RUN_NODE(ni);
3430 	struct run_tx_data *data;
3431 	struct rt2870_txd *txd;
3432 	struct rt2860_txwi *txwi;
3433 	uint16_t qos;
3434 	uint16_t dur;
3435 	uint16_t qid;
3436 	uint8_t type;
3437 	uint8_t tid;
3438 	uint8_t ridx;
3439 	uint8_t ctl_ridx;
3440 	uint8_t qflags;
3441 	uint8_t xflags = 0;
3442 	int hasqos;
3443 
3444 	RUN_LOCK_ASSERT(sc, MA_OWNED);
3445 
3446 	wh = mtod(m, struct ieee80211_frame *);
3447 
3448 	type = wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK;
3449 
3450 	/*
3451 	 * There are 7 bulk endpoints: 1 for RX
3452 	 * and 6 for TX (4 EDCAs + HCCA + Prio).
3453 	 * Update 03-14-2009:  some devices like the Planex GW-US300MiniS
3454 	 * seem to have only 4 TX bulk endpoints (Fukaumi Naoki).
3455 	 */
3456 	if ((hasqos = IEEE80211_QOS_HAS_SEQ(wh))) {
3457 		uint8_t *frm;
3458 
3459 		frm = ieee80211_getqos(wh);
3460 		qos = le16toh(*(const uint16_t *)frm);
3461 		tid = qos & IEEE80211_QOS_TID;
3462 		qid = TID_TO_WME_AC(tid);
3463 	} else {
3464 		qos = 0;
3465 		tid = 0;
3466 		qid = WME_AC_BE;
3467 	}
3468 	qflags = (qid < 4) ? RT2860_TX_QSEL_EDCA : RT2860_TX_QSEL_HCCA;
3469 
3470 	RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "qos %d\tqid %d\ttid %d\tqflags %x\n",
3471 	    qos, qid, tid, qflags);
3472 
3473 	/* pickup a rate index */
3474 	if (IEEE80211_IS_MULTICAST(wh->i_addr1) ||
3475 	    type != IEEE80211_FC0_TYPE_DATA || m->m_flags & M_EAPOL) {
3476 		/* XXX TODO: methodize for 11n; use MCS0 for 11NA/11NG */
3477 		ridx = (ic->ic_curmode == IEEE80211_MODE_11A || ic->ic_curmode == IEEE80211_MODE_11NA) ?
3478 		    RT2860_RIDX_OFDM6 : RT2860_RIDX_CCK1;
3479 		ctl_ridx = rt2860_rates[ridx].ctl_ridx;
3480 	} else {
3481 		if (tp->ucastrate != IEEE80211_FIXED_RATE_NONE)
3482 			ridx = rn->fix_ridx;
3483 		else
3484 			ridx = rn->amrr_ridx;
3485 		ctl_ridx = rt2860_rates[ridx].ctl_ridx;
3486 	}
3487 
3488 	if (!IEEE80211_IS_MULTICAST(wh->i_addr1) &&
3489 	    (!hasqos || (qos & IEEE80211_QOS_ACKPOLICY) !=
3490 	     IEEE80211_QOS_ACKPOLICY_NOACK)) {
3491 		xflags |= RT2860_TX_ACK;
3492 		if (ic->ic_flags & IEEE80211_F_SHPREAMBLE)
3493 			dur = rt2860_rates[ctl_ridx].sp_ack_dur;
3494 		else
3495 			dur = rt2860_rates[ctl_ridx].lp_ack_dur;
3496 		USETW(wh->i_dur, dur);
3497 	}
3498 
3499 	/* reserve slots for mgmt packets, just in case */
3500 	if (sc->sc_epq[qid].tx_nfree < 3) {
3501 		RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "tx ring %d is full\n", qid);
3502 		return (-1);
3503 	}
3504 
3505 	data = STAILQ_FIRST(&sc->sc_epq[qid].tx_fh);
3506 	STAILQ_REMOVE_HEAD(&sc->sc_epq[qid].tx_fh, next);
3507 	sc->sc_epq[qid].tx_nfree--;
3508 
3509 	txd = (struct rt2870_txd *)&data->desc;
3510 	txd->flags = qflags;
3511 	txwi = (struct rt2860_txwi *)(txd + 1);
3512 	txwi->xflags = xflags;
3513 	if (IEEE80211_IS_MULTICAST(wh->i_addr1))
3514 		txwi->wcid = 0;
3515 	else
3516 		txwi->wcid = (vap->iv_opmode == IEEE80211_M_STA) ?
3517 		    1 : RUN_AID2WCID(ni->ni_associd);
3518 
3519 	/* clear leftover garbage bits */
3520 	txwi->flags = 0;
3521 	txwi->txop = 0;
3522 
3523 	data->m = m;
3524 	data->ni = ni;
3525 	data->ridx = ridx;
3526 
3527 	run_set_tx_desc(sc, data);
3528 
3529 	/*
3530 	 * The chip keeps track of 2 kind of Tx stats,
3531 	 *  * TX_STAT_FIFO, for per WCID stats, and
3532 	 *  * TX_STA_CNT0 for all-TX-in-one stats.
3533 	 *
3534 	 * To use FIFO stats, we need to store MCS into the driver-private
3535  	 * PacketID field. So that, we can tell whose stats when we read them.
3536  	 * We add 1 to the MCS because setting the PacketID field to 0 means
3537  	 * that we don't want feedback in TX_STAT_FIFO.
3538  	 * And, that's what we want for STA mode, since TX_STA_CNT0 does the job.
3539  	 *
3540  	 * FIFO stats doesn't count Tx with WCID 0xff, so we do this in run_tx().
3541  	 */
3542 	if (sc->rvp_cnt > 1 || vap->iv_opmode == IEEE80211_M_HOSTAP ||
3543 	    vap->iv_opmode == IEEE80211_M_MBSS) {
3544 		uint16_t pid = (rt2860_rates[ridx].mcs + 1) & 0xf;
3545 		txwi->len |= htole16(pid << RT2860_TX_PID_SHIFT);
3546 
3547 		/*
3548 		 * Unlike PCI based devices, we don't get any interrupt from
3549 		 * USB devices, so we simulate FIFO-is-full interrupt here.
3550 		 * Ralink recommends to drain FIFO stats every 100 ms, but 16 slots
3551 		 * quickly get fulled. To prevent overflow, increment a counter on
3552 		 * every FIFO stat request, so we know how many slots are left.
3553 		 * We do this only in HOSTAP or multiple vap mode since FIFO stats
3554 		 * are used only in those modes.
3555 		 * We just drain stats. AMRR gets updated every 1 sec by
3556 		 * run_ratectl_cb() via callout.
3557 		 * Call it early. Otherwise overflow.
3558 		 */
3559 		if (sc->fifo_cnt++ == 10) {
3560 			/*
3561 			 * With multiple vaps or if_bridge, if_start() is called
3562 			 * with a non-sleepable lock, tcpinp. So, need to defer.
3563 			 */
3564 			uint32_t i = RUN_CMDQ_GET(&sc->cmdq_store);
3565 			RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "cmdq_store=%d\n", i);
3566 			sc->cmdq[i].func = run_drain_fifo;
3567 			sc->cmdq[i].arg0 = sc;
3568 			ieee80211_runtask(ic, &sc->cmdq_task);
3569 		}
3570 	}
3571 
3572         STAILQ_INSERT_TAIL(&sc->sc_epq[qid].tx_qh, data, next);
3573 
3574 	usbd_transfer_start(sc->sc_xfer[qid]);
3575 
3576 	RUN_DPRINTF(sc, RUN_DEBUG_XMIT,
3577 	    "sending data frame len=%d rate=%d qid=%d\n",
3578 	    m->m_pkthdr.len + (int)(sizeof(struct rt2870_txd) +
3579 	    sizeof(struct rt2860_txwi)), rt2860_rates[ridx].rate, qid);
3580 
3581 	return (0);
3582 }
3583 
3584 static int
3585 run_tx_mgt(struct run_softc *sc, struct mbuf *m, struct ieee80211_node *ni)
3586 {
3587 	struct ieee80211com *ic = &sc->sc_ic;
3588 	struct run_node *rn = RUN_NODE(ni);
3589 	struct run_tx_data *data;
3590 	struct ieee80211_frame *wh;
3591 	struct rt2870_txd *txd;
3592 	struct rt2860_txwi *txwi;
3593 	uint16_t dur;
3594 	uint8_t ridx = rn->mgt_ridx;
3595 	uint8_t xflags = 0;
3596 	uint8_t wflags = 0;
3597 
3598 	RUN_LOCK_ASSERT(sc, MA_OWNED);
3599 
3600 	wh = mtod(m, struct ieee80211_frame *);
3601 
3602 	/* tell hardware to add timestamp for probe responses */
3603 	if ((wh->i_fc[0] &
3604 	    (IEEE80211_FC0_TYPE_MASK | IEEE80211_FC0_SUBTYPE_MASK)) ==
3605 	    (IEEE80211_FC0_TYPE_MGT | IEEE80211_FC0_SUBTYPE_PROBE_RESP))
3606 		wflags |= RT2860_TX_TS;
3607 	else if (!IEEE80211_IS_MULTICAST(wh->i_addr1)) {
3608 		xflags |= RT2860_TX_ACK;
3609 
3610 		dur = ieee80211_ack_duration(ic->ic_rt, rt2860_rates[ridx].rate,
3611 		    ic->ic_flags & IEEE80211_F_SHPREAMBLE);
3612 		USETW(wh->i_dur, dur);
3613 	}
3614 
3615 	if (sc->sc_epq[0].tx_nfree == 0)
3616 		/* let caller free mbuf */
3617 		return (EIO);
3618 	data = STAILQ_FIRST(&sc->sc_epq[0].tx_fh);
3619 	STAILQ_REMOVE_HEAD(&sc->sc_epq[0].tx_fh, next);
3620 	sc->sc_epq[0].tx_nfree--;
3621 
3622 	txd = (struct rt2870_txd *)&data->desc;
3623 	txd->flags = RT2860_TX_QSEL_EDCA;
3624 	txwi = (struct rt2860_txwi *)(txd + 1);
3625 	txwi->wcid = 0xff;
3626 	txwi->flags = wflags;
3627 	txwi->xflags = xflags;
3628 	txwi->txop = 0;	/* clear leftover garbage bits */
3629 
3630 	data->m = m;
3631 	data->ni = ni;
3632 	data->ridx = ridx;
3633 
3634 	run_set_tx_desc(sc, data);
3635 
3636 	RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "sending mgt frame len=%d rate=%d\n",
3637 	    m->m_pkthdr.len + (int)(sizeof(struct rt2870_txd) +
3638 	    sizeof(struct rt2860_txwi)), rt2860_rates[ridx].rate);
3639 
3640 	STAILQ_INSERT_TAIL(&sc->sc_epq[0].tx_qh, data, next);
3641 
3642 	usbd_transfer_start(sc->sc_xfer[0]);
3643 
3644 	return (0);
3645 }
3646 
3647 static int
3648 run_sendprot(struct run_softc *sc,
3649     const struct mbuf *m, struct ieee80211_node *ni, int prot, int rate)
3650 {
3651 	struct ieee80211com *ic = ni->ni_ic;
3652 	struct run_tx_data *data;
3653 	struct rt2870_txd *txd;
3654 	struct rt2860_txwi *txwi;
3655 	struct mbuf *mprot;
3656 	int ridx;
3657 	int protrate;
3658 	uint8_t wflags = 0;
3659 	uint8_t xflags = 0;
3660 
3661 	RUN_LOCK_ASSERT(sc, MA_OWNED);
3662 
3663 	/* check that there are free slots before allocating the mbuf */
3664 	if (sc->sc_epq[0].tx_nfree == 0)
3665 		/* let caller free mbuf */
3666 		return (ENOBUFS);
3667 
3668 	mprot = ieee80211_alloc_prot(ni, m, rate, prot);
3669 	if (mprot == NULL) {
3670 		if_inc_counter(ni->ni_vap->iv_ifp, IFCOUNTER_OERRORS, 1);
3671 		RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "could not allocate mbuf\n");
3672 		return (ENOBUFS);
3673 	}
3674 
3675 	protrate = ieee80211_ctl_rate(ic->ic_rt, rate);
3676 	wflags = RT2860_TX_FRAG;
3677 	xflags = 0;
3678 	if (prot == IEEE80211_PROT_RTSCTS)
3679 		xflags |= RT2860_TX_ACK;
3680 
3681         data = STAILQ_FIRST(&sc->sc_epq[0].tx_fh);
3682         STAILQ_REMOVE_HEAD(&sc->sc_epq[0].tx_fh, next);
3683         sc->sc_epq[0].tx_nfree--;
3684 
3685 	txd = (struct rt2870_txd *)&data->desc;
3686 	txd->flags = RT2860_TX_QSEL_EDCA;
3687 	txwi = (struct rt2860_txwi *)(txd + 1);
3688 	txwi->wcid = 0xff;
3689 	txwi->flags = wflags;
3690 	txwi->xflags = xflags;
3691 	txwi->txop = 0;	/* clear leftover garbage bits */
3692 
3693 	data->m = mprot;
3694 	data->ni = ieee80211_ref_node(ni);
3695 
3696 	/* XXX TODO: methodize with MCS rates */
3697 	for (ridx = 0; ridx < RT2860_RIDX_MAX; ridx++)
3698 		if (rt2860_rates[ridx].rate == protrate)
3699 			break;
3700 	data->ridx = ridx;
3701 
3702 	run_set_tx_desc(sc, data);
3703 
3704         RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "sending prot len=%u rate=%u\n",
3705             m->m_pkthdr.len, rate);
3706 
3707         STAILQ_INSERT_TAIL(&sc->sc_epq[0].tx_qh, data, next);
3708 
3709 	usbd_transfer_start(sc->sc_xfer[0]);
3710 
3711 	return (0);
3712 }
3713 
3714 static int
3715 run_tx_param(struct run_softc *sc, struct mbuf *m, struct ieee80211_node *ni,
3716     const struct ieee80211_bpf_params *params)
3717 {
3718 	struct ieee80211com *ic = ni->ni_ic;
3719 	struct run_tx_data *data;
3720 	struct rt2870_txd *txd;
3721 	struct rt2860_txwi *txwi;
3722 	uint8_t ridx;
3723 	uint8_t rate;
3724 	uint8_t opflags = 0;
3725 	uint8_t xflags = 0;
3726 	int error;
3727 
3728 	RUN_LOCK_ASSERT(sc, MA_OWNED);
3729 
3730 	KASSERT(params != NULL, ("no raw xmit params"));
3731 
3732 	rate = params->ibp_rate0;
3733 	if (!ieee80211_isratevalid(ic->ic_rt, rate)) {
3734 		/* let caller free mbuf */
3735 		return (EINVAL);
3736 	}
3737 
3738 	if ((params->ibp_flags & IEEE80211_BPF_NOACK) == 0)
3739 		xflags |= RT2860_TX_ACK;
3740 	if (params->ibp_flags & (IEEE80211_BPF_RTS|IEEE80211_BPF_CTS)) {
3741 		error = run_sendprot(sc, m, ni,
3742 		    params->ibp_flags & IEEE80211_BPF_RTS ?
3743 			IEEE80211_PROT_RTSCTS : IEEE80211_PROT_CTSONLY,
3744 		    rate);
3745 		if (error) {
3746 			/* let caller free mbuf */
3747 			return error;
3748 		}
3749 		opflags |= /*XXX RT2573_TX_LONG_RETRY |*/ RT2860_TX_TXOP_SIFS;
3750 	}
3751 
3752 	if (sc->sc_epq[0].tx_nfree == 0) {
3753 		/* let caller free mbuf */
3754 		RUN_DPRINTF(sc, RUN_DEBUG_XMIT,
3755 		    "sending raw frame, but tx ring is full\n");
3756 		return (EIO);
3757 	}
3758         data = STAILQ_FIRST(&sc->sc_epq[0].tx_fh);
3759         STAILQ_REMOVE_HEAD(&sc->sc_epq[0].tx_fh, next);
3760         sc->sc_epq[0].tx_nfree--;
3761 
3762 	txd = (struct rt2870_txd *)&data->desc;
3763 	txd->flags = RT2860_TX_QSEL_EDCA;
3764 	txwi = (struct rt2860_txwi *)(txd + 1);
3765 	txwi->wcid = 0xff;
3766 	txwi->xflags = xflags;
3767 	txwi->txop = opflags;
3768 	txwi->flags = 0;	/* clear leftover garbage bits */
3769 
3770         data->m = m;
3771         data->ni = ni;
3772 	/* XXX TODO: methodize with MCS rates */
3773 	for (ridx = 0; ridx < RT2860_RIDX_MAX; ridx++)
3774 		if (rt2860_rates[ridx].rate == rate)
3775 			break;
3776 	data->ridx = ridx;
3777 
3778         run_set_tx_desc(sc, data);
3779 
3780         RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "sending raw frame len=%u rate=%u\n",
3781             m->m_pkthdr.len, rate);
3782 
3783         STAILQ_INSERT_TAIL(&sc->sc_epq[0].tx_qh, data, next);
3784 
3785 	usbd_transfer_start(sc->sc_xfer[0]);
3786 
3787         return (0);
3788 }
3789 
3790 static int
3791 run_raw_xmit(struct ieee80211_node *ni, struct mbuf *m,
3792     const struct ieee80211_bpf_params *params)
3793 {
3794 	struct run_softc *sc = ni->ni_ic->ic_softc;
3795 	int error = 0;
3796 
3797 	RUN_LOCK(sc);
3798 
3799 	/* prevent management frames from being sent if we're not ready */
3800 	if (!(sc->sc_flags & RUN_RUNNING)) {
3801 		error = ENETDOWN;
3802 		goto done;
3803 	}
3804 
3805 	if (params == NULL) {
3806 		/* tx mgt packet */
3807 		if ((error = run_tx_mgt(sc, m, ni)) != 0) {
3808 			RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "mgt tx failed\n");
3809 			goto done;
3810 		}
3811 	} else {
3812 		/* tx raw packet with param */
3813 		if ((error = run_tx_param(sc, m, ni, params)) != 0) {
3814 			RUN_DPRINTF(sc, RUN_DEBUG_XMIT, "tx with param failed\n");
3815 			goto done;
3816 		}
3817 	}
3818 
3819 done:
3820 	RUN_UNLOCK(sc);
3821 
3822 	if (error != 0) {
3823 		if(m != NULL)
3824 			m_freem(m);
3825 	}
3826 
3827 	return (error);
3828 }
3829 
3830 static int
3831 run_transmit(struct ieee80211com *ic, struct mbuf *m)
3832 {
3833 	struct run_softc *sc = ic->ic_softc;
3834 	int error;
3835 
3836 	RUN_LOCK(sc);
3837 	if ((sc->sc_flags & RUN_RUNNING) == 0) {
3838 		RUN_UNLOCK(sc);
3839 		return (ENXIO);
3840 	}
3841 	error = mbufq_enqueue(&sc->sc_snd, m);
3842 	if (error) {
3843 		RUN_UNLOCK(sc);
3844 		return (error);
3845 	}
3846 	run_start(sc);
3847 	RUN_UNLOCK(sc);
3848 
3849 	return (0);
3850 }
3851 
3852 static void
3853 run_start(struct run_softc *sc)
3854 {
3855 	struct ieee80211_node *ni;
3856 	struct mbuf *m;
3857 
3858 	RUN_LOCK_ASSERT(sc, MA_OWNED);
3859 
3860 	if ((sc->sc_flags & RUN_RUNNING) == 0)
3861 		return;
3862 
3863 	while ((m = mbufq_dequeue(&sc->sc_snd)) != NULL) {
3864 		ni = (struct ieee80211_node *)m->m_pkthdr.rcvif;
3865 		if (run_tx(sc, m, ni) != 0) {
3866 			mbufq_prepend(&sc->sc_snd, m);
3867 			break;
3868 		}
3869 	}
3870 }
3871 
3872 static void
3873 run_parent(struct ieee80211com *ic)
3874 {
3875 	struct run_softc *sc = ic->ic_softc;
3876 	int startall = 0;
3877 
3878 	RUN_LOCK(sc);
3879 	if (sc->sc_detached) {
3880 		RUN_UNLOCK(sc);
3881 		return;
3882 	}
3883 
3884 	if (ic->ic_nrunning > 0) {
3885 		if (!(sc->sc_flags & RUN_RUNNING)) {
3886 			startall = 1;
3887 			run_init_locked(sc);
3888 		} else
3889 			run_update_promisc_locked(sc);
3890 	} else if ((sc->sc_flags & RUN_RUNNING) && sc->rvp_cnt <= 1)
3891 		run_stop(sc);
3892 	RUN_UNLOCK(sc);
3893 	if (startall)
3894 		ieee80211_start_all(ic);
3895 }
3896 
3897 static void
3898 run_iq_calib(struct run_softc *sc, u_int chan)
3899 {
3900 	uint16_t val;
3901 
3902 	/* Tx0 IQ gain. */
3903 	run_bbp_write(sc, 158, 0x2c);
3904 	if (chan <= 14)
3905 		run_efuse_read(sc, RT5390_EEPROM_IQ_GAIN_CAL_TX0_2GHZ, &val, 1);
3906 	else if (chan <= 64) {
3907 		run_efuse_read(sc,
3908 		    RT5390_EEPROM_IQ_GAIN_CAL_TX0_CH36_TO_CH64_5GHZ,
3909 		    &val, 1);
3910 	} else if (chan <= 138) {
3911 		run_efuse_read(sc,
3912 		    RT5390_EEPROM_IQ_GAIN_CAL_TX0_CH100_TO_CH138_5GHZ,
3913 		    &val, 1);
3914 	} else if (chan <= 165) {
3915 		run_efuse_read(sc,
3916 	    RT5390_EEPROM_IQ_GAIN_CAL_TX0_CH140_TO_CH165_5GHZ,
3917 		    &val, 1);
3918 	} else
3919 		val = 0;
3920 	run_bbp_write(sc, 159, val);
3921 
3922 	/* Tx0 IQ phase. */
3923 	run_bbp_write(sc, 158, 0x2d);
3924 	if (chan <= 14) {
3925 		run_efuse_read(sc, RT5390_EEPROM_IQ_PHASE_CAL_TX0_2GHZ,
3926 		    &val, 1);
3927 	} else if (chan <= 64) {
3928 		run_efuse_read(sc,
3929 		    RT5390_EEPROM_IQ_PHASE_CAL_TX0_CH36_TO_CH64_5GHZ,
3930 		    &val, 1);
3931 	} else if (chan <= 138) {
3932 		run_efuse_read(sc,
3933 		    RT5390_EEPROM_IQ_PHASE_CAL_TX0_CH100_TO_CH138_5GHZ,
3934 		    &val, 1);
3935 	} else if (chan <= 165) {
3936 		run_efuse_read(sc,
3937 		    RT5390_EEPROM_IQ_PHASE_CAL_TX0_CH140_TO_CH165_5GHZ,
3938 		    &val, 1);
3939 	} else
3940 		val = 0;
3941 	run_bbp_write(sc, 159, val);
3942 
3943 	/* Tx1 IQ gain. */
3944 	run_bbp_write(sc, 158, 0x4a);
3945 	if (chan <= 14) {
3946 		run_efuse_read(sc, RT5390_EEPROM_IQ_GAIN_CAL_TX1_2GHZ,
3947 		    &val, 1);
3948 	} else if (chan <= 64) {
3949 		run_efuse_read(sc,
3950 		    RT5390_EEPROM_IQ_GAIN_CAL_TX1_CH36_TO_CH64_5GHZ,
3951 		    &val, 1);
3952 	} else if (chan <= 138) {
3953 		run_efuse_read(sc,
3954 		    RT5390_EEPROM_IQ_GAIN_CAL_TX1_CH100_TO_CH138_5GHZ,
3955 		    &val, 1);
3956 	} else if (chan <= 165) {
3957 		run_efuse_read(sc,
3958 		    RT5390_EEPROM_IQ_GAIN_CAL_TX1_CH140_TO_CH165_5GHZ,
3959 		    &val, 1);
3960 	} else
3961 		val = 0;
3962 	run_bbp_write(sc, 159, val);
3963 
3964 	/* Tx1 IQ phase. */
3965 	run_bbp_write(sc, 158, 0x4b);
3966 	if (chan <= 14) {
3967 		run_efuse_read(sc, RT5390_EEPROM_IQ_PHASE_CAL_TX1_2GHZ,
3968 		    &val, 1);
3969 	} else if (chan <= 64) {
3970 		run_efuse_read(sc,
3971 		    RT5390_EEPROM_IQ_PHASE_CAL_TX1_CH36_TO_CH64_5GHZ,
3972 		    &val, 1);
3973 	} else if (chan <= 138) {
3974 		run_efuse_read(sc,
3975 		    RT5390_EEPROM_IQ_PHASE_CAL_TX1_CH100_TO_CH138_5GHZ,
3976 		    &val, 1);
3977 	} else if (chan <= 165) {
3978 		run_efuse_read(sc,
3979 		    RT5390_EEPROM_IQ_PHASE_CAL_TX1_CH140_TO_CH165_5GHZ,
3980 		    &val, 1);
3981 	} else
3982 		val = 0;
3983 	run_bbp_write(sc, 159, val);
3984 
3985 	/* RF IQ compensation control. */
3986 	run_bbp_write(sc, 158, 0x04);
3987 	run_efuse_read(sc, RT5390_EEPROM_RF_IQ_COMPENSATION_CTL,
3988 	    &val, 1);
3989 	run_bbp_write(sc, 159, val);
3990 
3991 	/* RF IQ imbalance compensation control. */
3992 	run_bbp_write(sc, 158, 0x03);
3993 	run_efuse_read(sc,
3994 	    RT5390_EEPROM_RF_IQ_IMBALANCE_COMPENSATION_CTL, &val, 1);
3995 	run_bbp_write(sc, 159, val);
3996 }
3997 
3998 static void
3999 run_set_agc(struct run_softc *sc, uint8_t agc)
4000 {
4001 	uint8_t bbp;
4002 
4003 	if (sc->mac_ver == 0x3572) {
4004 		run_bbp_read(sc, 27, &bbp);
4005 		bbp &= ~(0x3 << 5);
4006 		run_bbp_write(sc, 27, bbp | 0 << 5);	/* select Rx0 */
4007 		run_bbp_write(sc, 66, agc);
4008 		run_bbp_write(sc, 27, bbp | 1 << 5);	/* select Rx1 */
4009 		run_bbp_write(sc, 66, agc);
4010 	} else
4011 		run_bbp_write(sc, 66, agc);
4012 }
4013 
4014 static void
4015 run_select_chan_group(struct run_softc *sc, int group)
4016 {
4017 	uint32_t tmp;
4018 	uint8_t agc;
4019 
4020 	run_bbp_write(sc, 62, 0x37 - sc->lna[group]);
4021 	run_bbp_write(sc, 63, 0x37 - sc->lna[group]);
4022 	run_bbp_write(sc, 64, 0x37 - sc->lna[group]);
4023 	if (sc->mac_ver < 0x3572)
4024 		run_bbp_write(sc, 86, 0x00);
4025 
4026 	if (sc->mac_ver == 0x3593) {
4027 		run_bbp_write(sc, 77, 0x98);
4028 		run_bbp_write(sc, 83, (group == 0) ? 0x8a : 0x9a);
4029 	}
4030 
4031 	if (group == 0) {
4032 		if (sc->ext_2ghz_lna) {
4033 			if (sc->mac_ver >= 0x5390)
4034 				run_bbp_write(sc, 75, 0x52);
4035 			else {
4036 				run_bbp_write(sc, 82, 0x62);
4037 				run_bbp_write(sc, 75, 0x46);
4038 			}
4039 		} else {
4040 			if (sc->mac_ver == 0x5592) {
4041 				run_bbp_write(sc, 79, 0x1c);
4042 				run_bbp_write(sc, 80, 0x0e);
4043 				run_bbp_write(sc, 81, 0x3a);
4044 				run_bbp_write(sc, 82, 0x62);
4045 
4046 				run_bbp_write(sc, 195, 0x80);
4047 				run_bbp_write(sc, 196, 0xe0);
4048 				run_bbp_write(sc, 195, 0x81);
4049 				run_bbp_write(sc, 196, 0x1f);
4050 				run_bbp_write(sc, 195, 0x82);
4051 				run_bbp_write(sc, 196, 0x38);
4052 				run_bbp_write(sc, 195, 0x83);
4053 				run_bbp_write(sc, 196, 0x32);
4054 				run_bbp_write(sc, 195, 0x85);
4055 				run_bbp_write(sc, 196, 0x28);
4056 				run_bbp_write(sc, 195, 0x86);
4057 				run_bbp_write(sc, 196, 0x19);
4058 			} else if (sc->mac_ver >= 0x5390)
4059 				run_bbp_write(sc, 75, 0x50);
4060 			else {
4061 				run_bbp_write(sc, 82,
4062 				    (sc->mac_ver == 0x3593) ? 0x62 : 0x84);
4063 				run_bbp_write(sc, 75, 0x50);
4064 			}
4065 		}
4066 	} else {
4067 		if (sc->mac_ver == 0x5592) {
4068 			run_bbp_write(sc, 79, 0x18);
4069 			run_bbp_write(sc, 80, 0x08);
4070 			run_bbp_write(sc, 81, 0x38);
4071 			run_bbp_write(sc, 82, 0x92);
4072 
4073 			run_bbp_write(sc, 195, 0x80);
4074 			run_bbp_write(sc, 196, 0xf0);
4075 			run_bbp_write(sc, 195, 0x81);
4076 			run_bbp_write(sc, 196, 0x1e);
4077 			run_bbp_write(sc, 195, 0x82);
4078 			run_bbp_write(sc, 196, 0x28);
4079 			run_bbp_write(sc, 195, 0x83);
4080 			run_bbp_write(sc, 196, 0x20);
4081 			run_bbp_write(sc, 195, 0x85);
4082 			run_bbp_write(sc, 196, 0x7f);
4083 			run_bbp_write(sc, 195, 0x86);
4084 			run_bbp_write(sc, 196, 0x7f);
4085 		} else if (sc->mac_ver == 0x3572)
4086 			run_bbp_write(sc, 82, 0x94);
4087 		else
4088 			run_bbp_write(sc, 82,
4089 			    (sc->mac_ver == 0x3593) ? 0x82 : 0xf2);
4090 		if (sc->ext_5ghz_lna)
4091 			run_bbp_write(sc, 75, 0x46);
4092 		else
4093 			run_bbp_write(sc, 75, 0x50);
4094 	}
4095 
4096 	run_read(sc, RT2860_TX_BAND_CFG, &tmp);
4097 	tmp &= ~(RT2860_5G_BAND_SEL_N | RT2860_5G_BAND_SEL_P);
4098 	tmp |= (group == 0) ? RT2860_5G_BAND_SEL_N : RT2860_5G_BAND_SEL_P;
4099 	run_write(sc, RT2860_TX_BAND_CFG, tmp);
4100 
4101 	/* enable appropriate Power Amplifiers and Low Noise Amplifiers */
4102 	tmp = RT2860_RFTR_EN | RT2860_TRSW_EN | RT2860_LNA_PE0_EN;
4103 	if (sc->mac_ver == 0x3593)
4104 		tmp |= 1 << 29 | 1 << 28;
4105 	if (sc->nrxchains > 1)
4106 		tmp |= RT2860_LNA_PE1_EN;
4107 	if (group == 0) {	/* 2GHz */
4108 		tmp |= RT2860_PA_PE_G0_EN;
4109 		if (sc->ntxchains > 1)
4110 			tmp |= RT2860_PA_PE_G1_EN;
4111 		if (sc->mac_ver == 0x3593) {
4112 			if (sc->ntxchains > 2)
4113 				tmp |= 1 << 25;
4114 		}
4115 	} else {		/* 5GHz */
4116 		tmp |= RT2860_PA_PE_A0_EN;
4117 		if (sc->ntxchains > 1)
4118 			tmp |= RT2860_PA_PE_A1_EN;
4119 	}
4120 	if (sc->mac_ver == 0x3572) {
4121 		run_rt3070_rf_write(sc, 8, 0x00);
4122 		run_write(sc, RT2860_TX_PIN_CFG, tmp);
4123 		run_rt3070_rf_write(sc, 8, 0x80);
4124 	} else
4125 		run_write(sc, RT2860_TX_PIN_CFG, tmp);
4126 
4127 	if (sc->mac_ver == 0x5592) {
4128 		run_bbp_write(sc, 195, 0x8d);
4129 		run_bbp_write(sc, 196, 0x1a);
4130 	}
4131 
4132 	if (sc->mac_ver == 0x3593) {
4133 		run_read(sc, RT2860_GPIO_CTRL, &tmp);
4134 		tmp &= ~0x01010000;
4135 		if (group == 0)
4136 			tmp |= 0x00010000;
4137 		tmp = (tmp & ~0x00009090) | 0x00000090;
4138 		run_write(sc, RT2860_GPIO_CTRL, tmp);
4139 	}
4140 
4141 	/* set initial AGC value */
4142 	if (group == 0) {	/* 2GHz band */
4143 		if (sc->mac_ver >= 0x3070)
4144 			agc = 0x1c + sc->lna[0] * 2;
4145 		else
4146 			agc = 0x2e + sc->lna[0];
4147 	} else {		/* 5GHz band */
4148 		if (sc->mac_ver == 0x5592)
4149 			agc = 0x24 + sc->lna[group] * 2;
4150 		else if (sc->mac_ver == 0x3572 || sc->mac_ver == 0x3593)
4151 			agc = 0x22 + (sc->lna[group] * 5) / 3;
4152 		else
4153 			agc = 0x32 + (sc->lna[group] * 5) / 3;
4154 	}
4155 	run_set_agc(sc, agc);
4156 }
4157 
4158 static void
4159 run_rt2870_set_chan(struct run_softc *sc, u_int chan)
4160 {
4161 	const struct rfprog *rfprog = rt2860_rf2850;
4162 	uint32_t r2, r3, r4;
4163 	int8_t txpow1, txpow2;
4164 	int i;
4165 
4166 	/* find the settings for this channel (we know it exists) */
4167 	for (i = 0; rfprog[i].chan != chan; i++);
4168 
4169 	r2 = rfprog[i].r2;
4170 	if (sc->ntxchains == 1)
4171 		r2 |= 1 << 14;		/* 1T: disable Tx chain 2 */
4172 	if (sc->nrxchains == 1)
4173 		r2 |= 1 << 17 | 1 << 6;	/* 1R: disable Rx chains 2 & 3 */
4174 	else if (sc->nrxchains == 2)
4175 		r2 |= 1 << 6;		/* 2R: disable Rx chain 3 */
4176 
4177 	/* use Tx power values from EEPROM */
4178 	txpow1 = sc->txpow1[i];
4179 	txpow2 = sc->txpow2[i];
4180 
4181 	/* Initialize RF R3 and R4. */
4182 	r3 = rfprog[i].r3 & 0xffffc1ff;
4183 	r4 = (rfprog[i].r4 & ~(0x001f87c0)) | (sc->freq << 15);
4184 	if (chan > 14) {
4185 		if (txpow1 >= 0) {
4186 			txpow1 = (txpow1 > 0xf) ? (0xf) : (txpow1);
4187 			r3 |= (txpow1 << 10) | (1 << 9);
4188 		} else {
4189 			txpow1 += 7;
4190 
4191 			/* txpow1 is not possible larger than 15. */
4192 			r3 |= (txpow1 << 10);
4193 		}
4194 		if (txpow2 >= 0) {
4195 			txpow2 = (txpow2 > 0xf) ? (0xf) : (txpow2);
4196 			r4 |= (txpow2 << 7) | (1 << 6);
4197 		} else {
4198 			txpow2 += 7;
4199 			r4 |= (txpow2 << 7);
4200 		}
4201 	} else {
4202 		/* Set Tx0 power. */
4203 		r3 |= (txpow1 << 9);
4204 
4205 		/* Set frequency offset and Tx1 power. */
4206 		r4 |= (txpow2 << 6);
4207 	}
4208 
4209 	run_rt2870_rf_write(sc, rfprog[i].r1);
4210 	run_rt2870_rf_write(sc, r2);
4211 	run_rt2870_rf_write(sc, r3 & ~(1 << 2));
4212 	run_rt2870_rf_write(sc, r4);
4213 
4214 	run_delay(sc, 10);
4215 
4216 	run_rt2870_rf_write(sc, rfprog[i].r1);
4217 	run_rt2870_rf_write(sc, r2);
4218 	run_rt2870_rf_write(sc, r3 | (1 << 2));
4219 	run_rt2870_rf_write(sc, r4);
4220 
4221 	run_delay(sc, 10);
4222 
4223 	run_rt2870_rf_write(sc, rfprog[i].r1);
4224 	run_rt2870_rf_write(sc, r2);
4225 	run_rt2870_rf_write(sc, r3 & ~(1 << 2));
4226 	run_rt2870_rf_write(sc, r4);
4227 }
4228 
4229 static void
4230 run_rt3070_set_chan(struct run_softc *sc, u_int chan)
4231 {
4232 	int8_t txpow1, txpow2;
4233 	uint8_t rf;
4234 	int i;
4235 
4236 	/* find the settings for this channel (we know it exists) */
4237 	for (i = 0; rt2860_rf2850[i].chan != chan; i++);
4238 
4239 	/* use Tx power values from EEPROM */
4240 	txpow1 = sc->txpow1[i];
4241 	txpow2 = sc->txpow2[i];
4242 
4243 	run_rt3070_rf_write(sc, 2, rt3070_freqs[i].n);
4244 
4245 	/* RT3370/RT3390: RF R3 [7:4] is not reserved bits. */
4246 	run_rt3070_rf_read(sc, 3, &rf);
4247 	rf = (rf & ~0x0f) | rt3070_freqs[i].k;
4248 	run_rt3070_rf_write(sc, 3, rf);
4249 
4250 	run_rt3070_rf_read(sc, 6, &rf);
4251 	rf = (rf & ~0x03) | rt3070_freqs[i].r;
4252 	run_rt3070_rf_write(sc, 6, rf);
4253 
4254 	/* set Tx0 power */
4255 	run_rt3070_rf_read(sc, 12, &rf);
4256 	rf = (rf & ~0x1f) | txpow1;
4257 	run_rt3070_rf_write(sc, 12, rf);
4258 
4259 	/* set Tx1 power */
4260 	run_rt3070_rf_read(sc, 13, &rf);
4261 	rf = (rf & ~0x1f) | txpow2;
4262 	run_rt3070_rf_write(sc, 13, rf);
4263 
4264 	run_rt3070_rf_read(sc, 1, &rf);
4265 	rf &= ~0xfc;
4266 	if (sc->ntxchains == 1)
4267 		rf |= 1 << 7 | 1 << 5;	/* 1T: disable Tx chains 2 & 3 */
4268 	else if (sc->ntxchains == 2)
4269 		rf |= 1 << 7;		/* 2T: disable Tx chain 3 */
4270 	if (sc->nrxchains == 1)
4271 		rf |= 1 << 6 | 1 << 4;	/* 1R: disable Rx chains 2 & 3 */
4272 	else if (sc->nrxchains == 2)
4273 		rf |= 1 << 6;		/* 2R: disable Rx chain 3 */
4274 	run_rt3070_rf_write(sc, 1, rf);
4275 
4276 	/* set RF offset */
4277 	run_rt3070_rf_read(sc, 23, &rf);
4278 	rf = (rf & ~0x7f) | sc->freq;
4279 	run_rt3070_rf_write(sc, 23, rf);
4280 
4281 	/* program RF filter */
4282 	run_rt3070_rf_read(sc, 24, &rf);	/* Tx */
4283 	rf = (rf & ~0x3f) | sc->rf24_20mhz;
4284 	run_rt3070_rf_write(sc, 24, rf);
4285 	run_rt3070_rf_read(sc, 31, &rf);	/* Rx */
4286 	rf = (rf & ~0x3f) | sc->rf24_20mhz;
4287 	run_rt3070_rf_write(sc, 31, rf);
4288 
4289 	/* enable RF tuning */
4290 	run_rt3070_rf_read(sc, 7, &rf);
4291 	run_rt3070_rf_write(sc, 7, rf | 0x01);
4292 }
4293 
4294 static void
4295 run_rt3572_set_chan(struct run_softc *sc, u_int chan)
4296 {
4297 	int8_t txpow1, txpow2;
4298 	uint32_t tmp;
4299 	uint8_t rf;
4300 	int i;
4301 
4302 	/* find the settings for this channel (we know it exists) */
4303 	for (i = 0; rt2860_rf2850[i].chan != chan; i++);
4304 
4305 	/* use Tx power values from EEPROM */
4306 	txpow1 = sc->txpow1[i];
4307 	txpow2 = sc->txpow2[i];
4308 
4309 	if (chan <= 14) {
4310 		run_bbp_write(sc, 25, sc->bbp25);
4311 		run_bbp_write(sc, 26, sc->bbp26);
4312 	} else {
4313 		/* enable IQ phase correction */
4314 		run_bbp_write(sc, 25, 0x09);
4315 		run_bbp_write(sc, 26, 0xff);
4316 	}
4317 
4318 	run_rt3070_rf_write(sc, 2, rt3070_freqs[i].n);
4319 	run_rt3070_rf_write(sc, 3, rt3070_freqs[i].k);
4320 	run_rt3070_rf_read(sc, 6, &rf);
4321 	rf  = (rf & ~0x0f) | rt3070_freqs[i].r;
4322 	rf |= (chan <= 14) ? 0x08 : 0x04;
4323 	run_rt3070_rf_write(sc, 6, rf);
4324 
4325 	/* set PLL mode */
4326 	run_rt3070_rf_read(sc, 5, &rf);
4327 	rf &= ~(0x08 | 0x04);
4328 	rf |= (chan <= 14) ? 0x04 : 0x08;
4329 	run_rt3070_rf_write(sc, 5, rf);
4330 
4331 	/* set Tx power for chain 0 */
4332 	if (chan <= 14)
4333 		rf = 0x60 | txpow1;
4334 	else
4335 		rf = 0xe0 | (txpow1 & 0xc) << 1 | (txpow1 & 0x3);
4336 	run_rt3070_rf_write(sc, 12, rf);
4337 
4338 	/* set Tx power for chain 1 */
4339 	if (chan <= 14)
4340 		rf = 0x60 | txpow2;
4341 	else
4342 		rf = 0xe0 | (txpow2 & 0xc) << 1 | (txpow2 & 0x3);
4343 	run_rt3070_rf_write(sc, 13, rf);
4344 
4345 	/* set Tx/Rx streams */
4346 	run_rt3070_rf_read(sc, 1, &rf);
4347 	rf &= ~0xfc;
4348 	if (sc->ntxchains == 1)
4349 		rf |= 1 << 7 | 1 << 5;  /* 1T: disable Tx chains 2 & 3 */
4350 	else if (sc->ntxchains == 2)
4351 		rf |= 1 << 7;           /* 2T: disable Tx chain 3 */
4352 	if (sc->nrxchains == 1)
4353 		rf |= 1 << 6 | 1 << 4;  /* 1R: disable Rx chains 2 & 3 */
4354 	else if (sc->nrxchains == 2)
4355 		rf |= 1 << 6;           /* 2R: disable Rx chain 3 */
4356 	run_rt3070_rf_write(sc, 1, rf);
4357 
4358 	/* set RF offset */
4359 	run_rt3070_rf_read(sc, 23, &rf);
4360 	rf = (rf & ~0x7f) | sc->freq;
4361 	run_rt3070_rf_write(sc, 23, rf);
4362 
4363 	/* program RF filter */
4364 	rf = sc->rf24_20mhz;
4365 	run_rt3070_rf_write(sc, 24, rf);	/* Tx */
4366 	run_rt3070_rf_write(sc, 31, rf);	/* Rx */
4367 
4368 	/* enable RF tuning */
4369 	run_rt3070_rf_read(sc, 7, &rf);
4370 	rf = (chan <= 14) ? 0xd8 : ((rf & ~0xc8) | 0x14);
4371 	run_rt3070_rf_write(sc, 7, rf);
4372 
4373 	/* TSSI */
4374 	rf = (chan <= 14) ? 0xc3 : 0xc0;
4375 	run_rt3070_rf_write(sc, 9, rf);
4376 
4377 	/* set loop filter 1 */
4378 	run_rt3070_rf_write(sc, 10, 0xf1);
4379 	/* set loop filter 2 */
4380 	run_rt3070_rf_write(sc, 11, (chan <= 14) ? 0xb9 : 0x00);
4381 
4382 	/* set tx_mx2_ic */
4383 	run_rt3070_rf_write(sc, 15, (chan <= 14) ? 0x53 : 0x43);
4384 	/* set tx_mx1_ic */
4385 	if (chan <= 14)
4386 		rf = 0x48 | sc->txmixgain_2ghz;
4387 	else
4388 		rf = 0x78 | sc->txmixgain_5ghz;
4389 	run_rt3070_rf_write(sc, 16, rf);
4390 
4391 	/* set tx_lo1 */
4392 	run_rt3070_rf_write(sc, 17, 0x23);
4393 	/* set tx_lo2 */
4394 	if (chan <= 14)
4395 		rf = 0x93;
4396 	else if (chan <= 64)
4397 		rf = 0xb7;
4398 	else if (chan <= 128)
4399 		rf = 0x74;
4400 	else
4401 		rf = 0x72;
4402 	run_rt3070_rf_write(sc, 19, rf);
4403 
4404 	/* set rx_lo1 */
4405 	if (chan <= 14)
4406 		rf = 0xb3;
4407 	else if (chan <= 64)
4408 		rf = 0xf6;
4409 	else if (chan <= 128)
4410 		rf = 0xf4;
4411 	else
4412 		rf = 0xf3;
4413 	run_rt3070_rf_write(sc, 20, rf);
4414 
4415 	/* set pfd_delay */
4416 	if (chan <= 14)
4417 		rf = 0x15;
4418 	else if (chan <= 64)
4419 		rf = 0x3d;
4420 	else
4421 		rf = 0x01;
4422 	run_rt3070_rf_write(sc, 25, rf);
4423 
4424 	/* set rx_lo2 */
4425 	run_rt3070_rf_write(sc, 26, (chan <= 14) ? 0x85 : 0x87);
4426 	/* set ldo_rf_vc */
4427 	run_rt3070_rf_write(sc, 27, (chan <= 14) ? 0x00 : 0x01);
4428 	/* set drv_cc */
4429 	run_rt3070_rf_write(sc, 29, (chan <= 14) ? 0x9b : 0x9f);
4430 
4431 	run_read(sc, RT2860_GPIO_CTRL, &tmp);
4432 	tmp &= ~0x8080;
4433 	if (chan <= 14)
4434 		tmp |= 0x80;
4435 	run_write(sc, RT2860_GPIO_CTRL, tmp);
4436 
4437 	/* enable RF tuning */
4438 	run_rt3070_rf_read(sc, 7, &rf);
4439 	run_rt3070_rf_write(sc, 7, rf | 0x01);
4440 
4441 	run_delay(sc, 2);
4442 }
4443 
4444 static void
4445 run_rt3593_set_chan(struct run_softc *sc, u_int chan)
4446 {
4447 	int8_t txpow1, txpow2, txpow3;
4448 	uint8_t h20mhz, rf;
4449 	int i;
4450 
4451 	/* find the settings for this channel (we know it exists) */
4452 	for (i = 0; rt2860_rf2850[i].chan != chan; i++);
4453 
4454 	/* use Tx power values from EEPROM */
4455 	txpow1 = sc->txpow1[i];
4456 	txpow2 = sc->txpow2[i];
4457 	txpow3 = (sc->ntxchains == 3) ? sc->txpow3[i] : 0;
4458 
4459 	if (chan <= 14) {
4460 		run_bbp_write(sc, 25, sc->bbp25);
4461 		run_bbp_write(sc, 26, sc->bbp26);
4462 	} else {
4463 		/* Enable IQ phase correction. */
4464 		run_bbp_write(sc, 25, 0x09);
4465 		run_bbp_write(sc, 26, 0xff);
4466 	}
4467 
4468 	run_rt3070_rf_write(sc, 8, rt3070_freqs[i].n);
4469 	run_rt3070_rf_write(sc, 9, rt3070_freqs[i].k & 0x0f);
4470 	run_rt3070_rf_read(sc, 11, &rf);
4471 	rf = (rf & ~0x03) | (rt3070_freqs[i].r & 0x03);
4472 	run_rt3070_rf_write(sc, 11, rf);
4473 
4474 	/* Set pll_idoh. */
4475 	run_rt3070_rf_read(sc, 11, &rf);
4476 	rf &= ~0x4c;
4477 	rf |= (chan <= 14) ? 0x44 : 0x48;
4478 	run_rt3070_rf_write(sc, 11, rf);
4479 
4480 	if (chan <= 14)
4481 		rf = txpow1 & 0x1f;
4482 	else
4483 		rf = 0x40 | ((txpow1 & 0x18) << 1) | (txpow1 & 0x07);
4484 	run_rt3070_rf_write(sc, 53, rf);
4485 
4486 	if (chan <= 14)
4487 		rf = txpow2 & 0x1f;
4488 	else
4489 		rf = 0x40 | ((txpow2 & 0x18) << 1) | (txpow2 & 0x07);
4490 	run_rt3070_rf_write(sc, 55, rf);
4491 
4492 	if (chan <= 14)
4493 		rf = txpow3 & 0x1f;
4494 	else
4495 		rf = 0x40 | ((txpow3 & 0x18) << 1) | (txpow3 & 0x07);
4496 	run_rt3070_rf_write(sc, 54, rf);
4497 
4498 	rf = RT3070_RF_BLOCK | RT3070_PLL_PD;
4499 	if (sc->ntxchains == 3)
4500 		rf |= RT3070_TX0_PD | RT3070_TX1_PD | RT3070_TX2_PD;
4501 	else
4502 		rf |= RT3070_TX0_PD | RT3070_TX1_PD;
4503 	rf |= RT3070_RX0_PD | RT3070_RX1_PD | RT3070_RX2_PD;
4504 	run_rt3070_rf_write(sc, 1, rf);
4505 
4506 	run_adjust_freq_offset(sc);
4507 
4508 	run_rt3070_rf_write(sc, 31, (chan <= 14) ? 0xa0 : 0x80);
4509 
4510 	h20mhz = (sc->rf24_20mhz & 0x20) >> 5;
4511 	run_rt3070_rf_read(sc, 30, &rf);
4512 	rf = (rf & ~0x06) | (h20mhz << 1) | (h20mhz << 2);
4513 	run_rt3070_rf_write(sc, 30, rf);
4514 
4515 	run_rt3070_rf_read(sc, 36, &rf);
4516 	if (chan <= 14)
4517 		rf |= 0x80;
4518 	else
4519 		rf &= ~0x80;
4520 	run_rt3070_rf_write(sc, 36, rf);
4521 
4522 	/* Set vcolo_bs. */
4523 	run_rt3070_rf_write(sc, 34, (chan <= 14) ? 0x3c : 0x20);
4524 	/* Set pfd_delay. */
4525 	run_rt3070_rf_write(sc, 12, (chan <= 14) ? 0x1a : 0x12);
4526 
4527 	/* Set vco bias current control. */
4528 	run_rt3070_rf_read(sc, 6, &rf);
4529 	rf &= ~0xc0;
4530 	if (chan <= 14)
4531 		rf |= 0x40;
4532 	else if (chan <= 128)
4533 		rf |= 0x80;
4534 	else
4535 		rf |= 0x40;
4536 	run_rt3070_rf_write(sc, 6, rf);
4537 
4538 	run_rt3070_rf_read(sc, 30, &rf);
4539 	rf = (rf & ~0x18) | 0x10;
4540 	run_rt3070_rf_write(sc, 30, rf);
4541 
4542 	run_rt3070_rf_write(sc, 10, (chan <= 14) ? 0xd3 : 0xd8);
4543 	run_rt3070_rf_write(sc, 13, (chan <= 14) ? 0x12 : 0x23);
4544 
4545 	run_rt3070_rf_read(sc, 51, &rf);
4546 	rf = (rf & ~0x03) | 0x01;
4547 	run_rt3070_rf_write(sc, 51, rf);
4548 	/* Set tx_mx1_cc. */
4549 	run_rt3070_rf_read(sc, 51, &rf);
4550 	rf &= ~0x1c;
4551 	rf |= (chan <= 14) ? 0x14 : 0x10;
4552 	run_rt3070_rf_write(sc, 51, rf);
4553 	/* Set tx_mx1_ic. */
4554 	run_rt3070_rf_read(sc, 51, &rf);
4555 	rf &= ~0xe0;
4556 	rf |= (chan <= 14) ? 0x60 : 0x40;
4557 	run_rt3070_rf_write(sc, 51, rf);
4558 	/* Set tx_lo1_ic. */
4559 	run_rt3070_rf_read(sc, 49, &rf);
4560 	rf &= ~0x1c;
4561 	rf |= (chan <= 14) ? 0x0c : 0x08;
4562 	run_rt3070_rf_write(sc, 49, rf);
4563 	/* Set tx_lo1_en. */
4564 	run_rt3070_rf_read(sc, 50, &rf);
4565 	run_rt3070_rf_write(sc, 50, rf & ~0x20);
4566 	/* Set drv_cc. */
4567 	run_rt3070_rf_read(sc, 57, &rf);
4568 	rf &= ~0xfc;
4569 	rf |= (chan <= 14) ?  0x6c : 0x3c;
4570 	run_rt3070_rf_write(sc, 57, rf);
4571 	/* Set rx_mix1_ic, rxa_lnactr, lna_vc, lna_inbias_en and lna_en. */
4572 	run_rt3070_rf_write(sc, 44, (chan <= 14) ? 0x93 : 0x9b);
4573 	/* Set drv_gnd_a, tx_vga_cc_a and tx_mx2_gain. */
4574 	run_rt3070_rf_write(sc, 52, (chan <= 14) ? 0x45 : 0x05);
4575 	/* Enable VCO calibration. */
4576 	run_rt3070_rf_read(sc, 3, &rf);
4577 	rf &= ~RT5390_VCOCAL;
4578 	rf |= (chan <= 14) ? RT5390_VCOCAL : 0xbe;
4579 	run_rt3070_rf_write(sc, 3, rf);
4580 
4581 	if (chan <= 14)
4582 		rf = 0x23;
4583 	else if (chan <= 64)
4584 		rf = 0x36;
4585 	else if (chan <= 128)
4586 		rf = 0x32;
4587 	else
4588 		rf = 0x30;
4589 	run_rt3070_rf_write(sc, 39, rf);
4590 	if (chan <= 14)
4591 		rf = 0xbb;
4592 	else if (chan <= 64)
4593 		rf = 0xeb;
4594 	else if (chan <= 128)
4595 		rf = 0xb3;
4596 	else
4597 		rf = 0x9b;
4598 	run_rt3070_rf_write(sc, 45, rf);
4599 
4600 	/* Set FEQ/AEQ control. */
4601 	run_bbp_write(sc, 105, 0x34);
4602 }
4603 
4604 static void
4605 run_rt5390_set_chan(struct run_softc *sc, u_int chan)
4606 {
4607 	int8_t txpow1, txpow2;
4608 	uint8_t rf;
4609 	int i;
4610 
4611 	/* find the settings for this channel (we know it exists) */
4612 	for (i = 0; rt2860_rf2850[i].chan != chan; i++);
4613 
4614 	/* use Tx power values from EEPROM */
4615 	txpow1 = sc->txpow1[i];
4616 	txpow2 = sc->txpow2[i];
4617 
4618 	run_rt3070_rf_write(sc, 8, rt3070_freqs[i].n);
4619 	run_rt3070_rf_write(sc, 9, rt3070_freqs[i].k & 0x0f);
4620 	run_rt3070_rf_read(sc, 11, &rf);
4621 	rf = (rf & ~0x03) | (rt3070_freqs[i].r & 0x03);
4622 	run_rt3070_rf_write(sc, 11, rf);
4623 
4624 	run_rt3070_rf_read(sc, 49, &rf);
4625 	rf = (rf & ~0x3f) | (txpow1 & 0x3f);
4626 	/* The valid range of the RF R49 is 0x00 to 0x27. */
4627 	if ((rf & 0x3f) > 0x27)
4628 		rf = (rf & ~0x3f) | 0x27;
4629 	run_rt3070_rf_write(sc, 49, rf);
4630 
4631 	if (sc->mac_ver == 0x5392) {
4632 		run_rt3070_rf_read(sc, 50, &rf);
4633 		rf = (rf & ~0x3f) | (txpow2 & 0x3f);
4634 		/* The valid range of the RF R50 is 0x00 to 0x27. */
4635 		if ((rf & 0x3f) > 0x27)
4636 			rf = (rf & ~0x3f) | 0x27;
4637 		run_rt3070_rf_write(sc, 50, rf);
4638 	}
4639 
4640 	run_rt3070_rf_read(sc, 1, &rf);
4641 	rf |= RT3070_RF_BLOCK | RT3070_PLL_PD | RT3070_RX0_PD | RT3070_TX0_PD;
4642 	if (sc->mac_ver == 0x5392)
4643 		rf |= RT3070_RX1_PD | RT3070_TX1_PD;
4644 	run_rt3070_rf_write(sc, 1, rf);
4645 
4646 	if (sc->mac_ver != 0x5392) {
4647 		run_rt3070_rf_read(sc, 2, &rf);
4648 		rf |= 0x80;
4649 		run_rt3070_rf_write(sc, 2, rf);
4650 		run_delay(sc, 10);
4651 		rf &= 0x7f;
4652 		run_rt3070_rf_write(sc, 2, rf);
4653 	}
4654 
4655 	run_adjust_freq_offset(sc);
4656 
4657 	if (sc->mac_ver == 0x5392) {
4658 		/* Fix for RT5392C. */
4659 		if (sc->mac_rev >= 0x0223) {
4660 			if (chan <= 4)
4661 				rf = 0x0f;
4662 			else if (chan >= 5 && chan <= 7)
4663 				rf = 0x0e;
4664 			else
4665 				rf = 0x0d;
4666 			run_rt3070_rf_write(sc, 23, rf);
4667 
4668 			if (chan <= 4)
4669 				rf = 0x0c;
4670 			else if (chan == 5)
4671 				rf = 0x0b;
4672 			else if (chan >= 6 && chan <= 7)
4673 				rf = 0x0a;
4674 			else if (chan >= 8 && chan <= 10)
4675 				rf = 0x09;
4676 			else
4677 				rf = 0x08;
4678 			run_rt3070_rf_write(sc, 59, rf);
4679 		} else {
4680 			if (chan <= 11)
4681 				rf = 0x0f;
4682 			else
4683 				rf = 0x0b;
4684 			run_rt3070_rf_write(sc, 59, rf);
4685 		}
4686 	} else {
4687 		/* Fix for RT5390F. */
4688 		if (sc->mac_rev >= 0x0502) {
4689 			if (chan <= 11)
4690 				rf = 0x43;
4691 			else
4692 				rf = 0x23;
4693 			run_rt3070_rf_write(sc, 55, rf);
4694 
4695 			if (chan <= 11)
4696 				rf = 0x0f;
4697 			else if (chan == 12)
4698 				rf = 0x0d;
4699 			else
4700 				rf = 0x0b;
4701 			run_rt3070_rf_write(sc, 59, rf);
4702 		} else {
4703 			run_rt3070_rf_write(sc, 55, 0x44);
4704 			run_rt3070_rf_write(sc, 59, 0x8f);
4705 		}
4706 	}
4707 
4708 	/* Enable VCO calibration. */
4709 	run_rt3070_rf_read(sc, 3, &rf);
4710 	rf |= RT5390_VCOCAL;
4711 	run_rt3070_rf_write(sc, 3, rf);
4712 }
4713 
4714 static void
4715 run_rt5592_set_chan(struct run_softc *sc, u_int chan)
4716 {
4717 	const struct rt5592_freqs *freqs;
4718 	uint32_t tmp;
4719 	uint8_t reg, rf, txpow_bound;
4720 	int8_t txpow1, txpow2;
4721 	int i;
4722 
4723 	run_read(sc, RT5592_DEBUG_INDEX, &tmp);
4724 	freqs = (tmp & RT5592_SEL_XTAL) ?
4725 	    rt5592_freqs_40mhz : rt5592_freqs_20mhz;
4726 
4727 	/* find the settings for this channel (we know it exists) */
4728 	for (i = 0; rt2860_rf2850[i].chan != chan; i++, freqs++);
4729 
4730 	/* use Tx power values from EEPROM */
4731 	txpow1 = sc->txpow1[i];
4732 	txpow2 = sc->txpow2[i];
4733 
4734 	run_read(sc, RT3070_LDO_CFG0, &tmp);
4735 	tmp &= ~0x1c000000;
4736 	if (chan > 14)
4737 		tmp |= 0x14000000;
4738 	run_write(sc, RT3070_LDO_CFG0, tmp);
4739 
4740 	/* N setting. */
4741 	run_rt3070_rf_write(sc, 8, freqs->n & 0xff);
4742 	run_rt3070_rf_read(sc, 9, &rf);
4743 	rf &= ~(1 << 4);
4744 	rf |= ((freqs->n & 0x0100) >> 8) << 4;
4745 	run_rt3070_rf_write(sc, 9, rf);
4746 
4747 	/* K setting. */
4748 	run_rt3070_rf_read(sc, 9, &rf);
4749 	rf &= ~0x0f;
4750 	rf |= (freqs->k & 0x0f);
4751 	run_rt3070_rf_write(sc, 9, rf);
4752 
4753 	/* Mode setting. */
4754 	run_rt3070_rf_read(sc, 11, &rf);
4755 	rf &= ~0x0c;
4756 	rf |= ((freqs->m - 0x8) & 0x3) << 2;
4757 	run_rt3070_rf_write(sc, 11, rf);
4758 	run_rt3070_rf_read(sc, 9, &rf);
4759 	rf &= ~(1 << 7);
4760 	rf |= (((freqs->m - 0x8) & 0x4) >> 2) << 7;
4761 	run_rt3070_rf_write(sc, 9, rf);
4762 
4763 	/* R setting. */
4764 	run_rt3070_rf_read(sc, 11, &rf);
4765 	rf &= ~0x03;
4766 	rf |= (freqs->r - 0x1);
4767 	run_rt3070_rf_write(sc, 11, rf);
4768 
4769 	if (chan <= 14) {
4770 		/* Initialize RF registers for 2GHZ. */
4771 		for (i = 0; i < nitems(rt5592_2ghz_def_rf); i++) {
4772 			run_rt3070_rf_write(sc, rt5592_2ghz_def_rf[i].reg,
4773 			    rt5592_2ghz_def_rf[i].val);
4774 		}
4775 
4776 		rf = (chan <= 10) ? 0x07 : 0x06;
4777 		run_rt3070_rf_write(sc, 23, rf);
4778 		run_rt3070_rf_write(sc, 59, rf);
4779 
4780 		run_rt3070_rf_write(sc, 55, 0x43);
4781 
4782 		/*
4783 		 * RF R49/R50 Tx power ALC code.
4784 		 * G-band bit<7:6>=1:0, bit<5:0> range from 0x0 ~ 0x27.
4785 		 */
4786 		reg = 2;
4787 		txpow_bound = 0x27;
4788 	} else {
4789 		/* Initialize RF registers for 5GHZ. */
4790 		for (i = 0; i < nitems(rt5592_5ghz_def_rf); i++) {
4791 			run_rt3070_rf_write(sc, rt5592_5ghz_def_rf[i].reg,
4792 			    rt5592_5ghz_def_rf[i].val);
4793 		}
4794 		for (i = 0; i < nitems(rt5592_chan_5ghz); i++) {
4795 			if (chan >= rt5592_chan_5ghz[i].firstchan &&
4796 			    chan <= rt5592_chan_5ghz[i].lastchan) {
4797 				run_rt3070_rf_write(sc, rt5592_chan_5ghz[i].reg,
4798 				    rt5592_chan_5ghz[i].val);
4799 			}
4800 		}
4801 
4802 		/*
4803 		 * RF R49/R50 Tx power ALC code.
4804 		 * A-band bit<7:6>=1:1, bit<5:0> range from 0x0 ~ 0x2b.
4805 		 */
4806 		reg = 3;
4807 		txpow_bound = 0x2b;
4808 	}
4809 
4810 	/* RF R49 ch0 Tx power ALC code. */
4811 	run_rt3070_rf_read(sc, 49, &rf);
4812 	rf &= ~0xc0;
4813 	rf |= (reg << 6);
4814 	rf = (rf & ~0x3f) | (txpow1 & 0x3f);
4815 	if ((rf & 0x3f) > txpow_bound)
4816 		rf = (rf & ~0x3f) | txpow_bound;
4817 	run_rt3070_rf_write(sc, 49, rf);
4818 
4819 	/* RF R50 ch1 Tx power ALC code. */
4820 	run_rt3070_rf_read(sc, 50, &rf);
4821 	rf &= ~(1 << 7 | 1 << 6);
4822 	rf |= (reg << 6);
4823 	rf = (rf & ~0x3f) | (txpow2 & 0x3f);
4824 	if ((rf & 0x3f) > txpow_bound)
4825 		rf = (rf & ~0x3f) | txpow_bound;
4826 	run_rt3070_rf_write(sc, 50, rf);
4827 
4828 	/* Enable RF_BLOCK, PLL_PD, RX0_PD, and TX0_PD. */
4829 	run_rt3070_rf_read(sc, 1, &rf);
4830 	rf |= (RT3070_RF_BLOCK | RT3070_PLL_PD | RT3070_RX0_PD | RT3070_TX0_PD);
4831 	if (sc->ntxchains > 1)
4832 		rf |= RT3070_TX1_PD;
4833 	if (sc->nrxchains > 1)
4834 		rf |= RT3070_RX1_PD;
4835 	run_rt3070_rf_write(sc, 1, rf);
4836 
4837 	run_rt3070_rf_write(sc, 6, 0xe4);
4838 
4839 	run_rt3070_rf_write(sc, 30, 0x10);
4840 	run_rt3070_rf_write(sc, 31, 0x80);
4841 	run_rt3070_rf_write(sc, 32, 0x80);
4842 
4843 	run_adjust_freq_offset(sc);
4844 
4845 	/* Enable VCO calibration. */
4846 	run_rt3070_rf_read(sc, 3, &rf);
4847 	rf |= RT5390_VCOCAL;
4848 	run_rt3070_rf_write(sc, 3, rf);
4849 }
4850 
4851 static void
4852 run_set_rx_antenna(struct run_softc *sc, int aux)
4853 {
4854 	uint32_t tmp;
4855 	uint8_t bbp152;
4856 
4857 	if (aux) {
4858 		if (sc->rf_rev == RT5390_RF_5370) {
4859 			run_bbp_read(sc, 152, &bbp152);
4860 			run_bbp_write(sc, 152, bbp152 & ~0x80);
4861 		} else {
4862 			run_mcu_cmd(sc, RT2860_MCU_CMD_ANTSEL, 0);
4863 			run_read(sc, RT2860_GPIO_CTRL, &tmp);
4864 			run_write(sc, RT2860_GPIO_CTRL, (tmp & ~0x0808) | 0x08);
4865 		}
4866 	} else {
4867 		if (sc->rf_rev == RT5390_RF_5370) {
4868 			run_bbp_read(sc, 152, &bbp152);
4869 			run_bbp_write(sc, 152, bbp152 | 0x80);
4870 		} else {
4871 			run_mcu_cmd(sc, RT2860_MCU_CMD_ANTSEL, 1);
4872 			run_read(sc, RT2860_GPIO_CTRL, &tmp);
4873 			run_write(sc, RT2860_GPIO_CTRL, tmp & ~0x0808);
4874 		}
4875 	}
4876 }
4877 
4878 static int
4879 run_set_chan(struct run_softc *sc, struct ieee80211_channel *c)
4880 {
4881 	struct ieee80211com *ic = &sc->sc_ic;
4882 	u_int chan, group;
4883 
4884 	chan = ieee80211_chan2ieee(ic, c);
4885 	if (chan == 0 || chan == IEEE80211_CHAN_ANY)
4886 		return (EINVAL);
4887 
4888 	if (sc->mac_ver == 0x5592)
4889 		run_rt5592_set_chan(sc, chan);
4890 	else if (sc->mac_ver >= 0x5390)
4891 		run_rt5390_set_chan(sc, chan);
4892 	else if (sc->mac_ver == 0x3593)
4893 		run_rt3593_set_chan(sc, chan);
4894 	else if (sc->mac_ver == 0x3572)
4895 		run_rt3572_set_chan(sc, chan);
4896 	else if (sc->mac_ver >= 0x3070)
4897 		run_rt3070_set_chan(sc, chan);
4898 	else
4899 		run_rt2870_set_chan(sc, chan);
4900 
4901 	/* determine channel group */
4902 	if (chan <= 14)
4903 		group = 0;
4904 	else if (chan <= 64)
4905 		group = 1;
4906 	else if (chan <= 128)
4907 		group = 2;
4908 	else
4909 		group = 3;
4910 
4911 	/* XXX necessary only when group has changed! */
4912 	run_select_chan_group(sc, group);
4913 
4914 	run_delay(sc, 10);
4915 
4916 	/* Perform IQ calibration. */
4917 	if (sc->mac_ver >= 0x5392)
4918 		run_iq_calib(sc, chan);
4919 
4920 	return (0);
4921 }
4922 
4923 static void
4924 run_set_channel(struct ieee80211com *ic)
4925 {
4926 	struct run_softc *sc = ic->ic_softc;
4927 
4928 	RUN_LOCK(sc);
4929 	run_set_chan(sc, ic->ic_curchan);
4930 	RUN_UNLOCK(sc);
4931 
4932 	return;
4933 }
4934 
4935 static void
4936 run_getradiocaps(struct ieee80211com *ic,
4937     int maxchans, int *nchans, struct ieee80211_channel chans[])
4938 {
4939 	struct run_softc *sc = ic->ic_softc;
4940 	uint8_t bands[IEEE80211_MODE_BYTES];
4941 
4942 	memset(bands, 0, sizeof(bands));
4943 	setbit(bands, IEEE80211_MODE_11B);
4944 	setbit(bands, IEEE80211_MODE_11G);
4945 	if (sc->rf_rev != RT3070_RF_2020)
4946 		setbit(bands, IEEE80211_MODE_11NG);
4947 
4948 	/* Note: for now, only support HT20 channels */
4949 	ieee80211_add_channels_default_2ghz(chans, maxchans, nchans, bands, 0);
4950 
4951 	if (sc->rf_rev == RT2860_RF_2750 || sc->rf_rev == RT2860_RF_2850 ||
4952 	    sc->rf_rev == RT3070_RF_3052 || sc->rf_rev == RT3593_RF_3053 ||
4953 	    sc->rf_rev == RT5592_RF_5592) {
4954 		setbit(bands, IEEE80211_MODE_11A);
4955 		if (sc->rf_rev != RT3070_RF_2020)
4956 			setbit(bands, IEEE80211_MODE_11NA);
4957 		/* Note: for now, only support HT20 channels */
4958 		ieee80211_add_channel_list_5ghz(chans, maxchans, nchans,
4959 		    run_chan_5ghz, nitems(run_chan_5ghz), bands, 0);
4960 	}
4961 }
4962 
4963 static void
4964 run_scan_start(struct ieee80211com *ic)
4965 {
4966 	struct run_softc *sc = ic->ic_softc;
4967 
4968 	RUN_LOCK(sc);
4969 
4970 	/* abort TSF synchronization */
4971 	run_disable_tsf(sc);
4972 	run_set_bssid(sc, ieee80211broadcastaddr);
4973 
4974 	RUN_UNLOCK(sc);
4975 
4976 	return;
4977 }
4978 
4979 static void
4980 run_scan_end(struct ieee80211com *ic)
4981 {
4982 	struct run_softc *sc = ic->ic_softc;
4983 
4984 	RUN_LOCK(sc);
4985 
4986 	run_enable_tsf_sync(sc);
4987 	run_set_bssid(sc, sc->sc_bssid);
4988 
4989 	RUN_UNLOCK(sc);
4990 
4991 	return;
4992 }
4993 
4994 /*
4995  * Could be called from ieee80211_node_timeout()
4996  * (non-sleepable thread)
4997  */
4998 static void
4999 run_update_beacon(struct ieee80211vap *vap, int item)
5000 {
5001 	struct ieee80211com *ic = vap->iv_ic;
5002 	struct ieee80211_beacon_offsets *bo = &vap->iv_bcn_off;
5003 	struct ieee80211_node *ni = vap->iv_bss;
5004 	struct run_softc *sc = ic->ic_softc;
5005 	struct run_vap *rvp = RUN_VAP(vap);
5006 	int mcast = 0;
5007 	uint32_t i;
5008 
5009 	switch (item) {
5010 	case IEEE80211_BEACON_ERP:
5011 		run_updateslot(ic);
5012 		break;
5013 	case IEEE80211_BEACON_HTINFO:
5014 		run_updateprot(ic);
5015 		break;
5016 	case IEEE80211_BEACON_TIM:
5017 		mcast = 1;	/*TODO*/
5018 		break;
5019 	default:
5020 		break;
5021 	}
5022 
5023 	setbit(bo->bo_flags, item);
5024 	if (rvp->beacon_mbuf == NULL) {
5025 		rvp->beacon_mbuf = ieee80211_beacon_alloc(ni);
5026 		if (rvp->beacon_mbuf == NULL)
5027 			return;
5028 	}
5029 	ieee80211_beacon_update(ni, rvp->beacon_mbuf, mcast);
5030 
5031 	i = RUN_CMDQ_GET(&sc->cmdq_store);
5032 	RUN_DPRINTF(sc, RUN_DEBUG_BEACON, "cmdq_store=%d\n", i);
5033 	sc->cmdq[i].func = run_update_beacon_cb;
5034 	sc->cmdq[i].arg0 = vap;
5035 	ieee80211_runtask(ic, &sc->cmdq_task);
5036 
5037 	return;
5038 }
5039 
5040 static void
5041 run_update_beacon_cb(void *arg)
5042 {
5043 	struct ieee80211vap *vap = arg;
5044 	struct ieee80211_node *ni = vap->iv_bss;
5045 	struct run_vap *rvp = RUN_VAP(vap);
5046 	struct ieee80211com *ic = vap->iv_ic;
5047 	struct run_softc *sc = ic->ic_softc;
5048 	struct rt2860_txwi txwi;
5049 	struct mbuf *m;
5050 	uint16_t txwisize;
5051 	uint8_t ridx;
5052 
5053 	if (ni->ni_chan == IEEE80211_CHAN_ANYC)
5054 		return;
5055 	if (ic->ic_bsschan == IEEE80211_CHAN_ANYC)
5056 		return;
5057 
5058 	/*
5059 	 * No need to call ieee80211_beacon_update(), run_update_beacon()
5060 	 * is taking care of appropriate calls.
5061 	 */
5062 	if (rvp->beacon_mbuf == NULL) {
5063 		rvp->beacon_mbuf = ieee80211_beacon_alloc(ni);
5064 		if (rvp->beacon_mbuf == NULL)
5065 			return;
5066 	}
5067 	m = rvp->beacon_mbuf;
5068 
5069 	memset(&txwi, 0, sizeof(txwi));
5070 	txwi.wcid = 0xff;
5071 	txwi.len = htole16(m->m_pkthdr.len);
5072 
5073 	/* send beacons at the lowest available rate */
5074 	ridx = (ic->ic_curmode == IEEE80211_MODE_11A) ?
5075 	    RT2860_RIDX_OFDM6 : RT2860_RIDX_CCK1;
5076 	txwi.phy = htole16(rt2860_rates[ridx].mcs);
5077 	if (rt2860_rates[ridx].phy == IEEE80211_T_OFDM)
5078 		txwi.phy |= htole16(RT2860_PHY_OFDM);
5079 	txwi.txop = RT2860_TX_TXOP_HT;
5080 	txwi.flags = RT2860_TX_TS;
5081 	txwi.xflags = RT2860_TX_NSEQ;
5082 
5083 	txwisize = (sc->mac_ver == 0x5592) ?
5084 	    sizeof(txwi) + sizeof(uint32_t) : sizeof(txwi);
5085 	run_write_region_1(sc, RT2860_BCN_BASE(rvp->rvp_id), (uint8_t *)&txwi,
5086 	    txwisize);
5087 	run_write_region_1(sc, RT2860_BCN_BASE(rvp->rvp_id) + txwisize,
5088 	    mtod(m, uint8_t *), (m->m_pkthdr.len + 1) & ~1);
5089 }
5090 
5091 static void
5092 run_updateprot(struct ieee80211com *ic)
5093 {
5094 	struct run_softc *sc = ic->ic_softc;
5095 	uint32_t i;
5096 
5097 	i = RUN_CMDQ_GET(&sc->cmdq_store);
5098 	RUN_DPRINTF(sc, RUN_DEBUG_BEACON, "cmdq_store=%d\n", i);
5099 	sc->cmdq[i].func = run_updateprot_cb;
5100 	sc->cmdq[i].arg0 = ic;
5101 	ieee80211_runtask(ic, &sc->cmdq_task);
5102 }
5103 
5104 static void
5105 run_updateprot_cb(void *arg)
5106 {
5107 	struct ieee80211com *ic = arg;
5108 	struct run_softc *sc = ic->ic_softc;
5109 	uint32_t tmp;
5110 
5111 	tmp = RT2860_RTSTH_EN | RT2860_PROT_NAV_SHORT | RT2860_TXOP_ALLOW_ALL;
5112 	/* setup protection frame rate (MCS code) */
5113 	tmp |= (ic->ic_curmode == IEEE80211_MODE_11A) ?
5114 	    rt2860_rates[RT2860_RIDX_OFDM6].mcs | RT2860_PHY_OFDM :
5115 	    rt2860_rates[RT2860_RIDX_CCK11].mcs;
5116 
5117 	/* CCK frames don't require protection */
5118 	run_write(sc, RT2860_CCK_PROT_CFG, tmp);
5119 	if (ic->ic_flags & IEEE80211_F_USEPROT) {
5120 		if (ic->ic_protmode == IEEE80211_PROT_RTSCTS)
5121 			tmp |= RT2860_PROT_CTRL_RTS_CTS;
5122 		else if (ic->ic_protmode == IEEE80211_PROT_CTSONLY)
5123 			tmp |= RT2860_PROT_CTRL_CTS;
5124 	}
5125 	run_write(sc, RT2860_OFDM_PROT_CFG, tmp);
5126 }
5127 
5128 static void
5129 run_usb_timeout_cb(void *arg)
5130 {
5131 	struct ieee80211vap *vap = arg;
5132 	struct run_softc *sc = vap->iv_ic->ic_softc;
5133 
5134 	RUN_LOCK_ASSERT(sc, MA_OWNED);
5135 
5136 	if(vap->iv_state == IEEE80211_S_RUN &&
5137 	    vap->iv_opmode != IEEE80211_M_STA)
5138 		run_reset_livelock(sc);
5139 	else if (vap->iv_state == IEEE80211_S_SCAN) {
5140 		RUN_DPRINTF(sc, RUN_DEBUG_USB | RUN_DEBUG_STATE,
5141 		    "timeout caused by scan\n");
5142 		/* cancel bgscan */
5143 		ieee80211_cancel_scan(vap);
5144 	} else
5145 		RUN_DPRINTF(sc, RUN_DEBUG_USB | RUN_DEBUG_STATE,
5146 		    "timeout by unknown cause\n");
5147 }
5148 
5149 static void
5150 run_reset_livelock(struct run_softc *sc)
5151 {
5152 	uint32_t tmp;
5153 
5154 	RUN_LOCK_ASSERT(sc, MA_OWNED);
5155 
5156 	/*
5157 	 * In IBSS or HostAP modes (when the hardware sends beacons), the MAC
5158 	 * can run into a livelock and start sending CTS-to-self frames like
5159 	 * crazy if protection is enabled.  Reset MAC/BBP for a while
5160 	 */
5161 	run_read(sc, RT2860_DEBUG, &tmp);
5162 	RUN_DPRINTF(sc, RUN_DEBUG_RESET, "debug reg %08x\n", tmp);
5163 	if ((tmp & (1 << 29)) && (tmp & (1 << 7 | 1 << 5))) {
5164 		RUN_DPRINTF(sc, RUN_DEBUG_RESET,
5165 		    "CTS-to-self livelock detected\n");
5166 		run_write(sc, RT2860_MAC_SYS_CTRL, RT2860_MAC_SRST);
5167 		run_delay(sc, 1);
5168 		run_write(sc, RT2860_MAC_SYS_CTRL,
5169 		    RT2860_MAC_RX_EN | RT2860_MAC_TX_EN);
5170 	}
5171 }
5172 
5173 static void
5174 run_update_promisc_locked(struct run_softc *sc)
5175 {
5176         uint32_t tmp;
5177 
5178 	run_read(sc, RT2860_RX_FILTR_CFG, &tmp);
5179 
5180 	tmp |= RT2860_DROP_UC_NOME;
5181         if (sc->sc_ic.ic_promisc > 0)
5182 		tmp &= ~RT2860_DROP_UC_NOME;
5183 
5184 	run_write(sc, RT2860_RX_FILTR_CFG, tmp);
5185 
5186         RUN_DPRINTF(sc, RUN_DEBUG_RECV, "%s promiscuous mode\n",
5187 	    (sc->sc_ic.ic_promisc > 0) ?  "entering" : "leaving");
5188 }
5189 
5190 static void
5191 run_update_promisc(struct ieee80211com *ic)
5192 {
5193 	struct run_softc *sc = ic->ic_softc;
5194 
5195 	if ((sc->sc_flags & RUN_RUNNING) == 0)
5196 		return;
5197 
5198 	RUN_LOCK(sc);
5199 	run_update_promisc_locked(sc);
5200 	RUN_UNLOCK(sc);
5201 }
5202 
5203 static void
5204 run_enable_tsf_sync(struct run_softc *sc)
5205 {
5206 	struct ieee80211com *ic = &sc->sc_ic;
5207 	struct ieee80211vap *vap = TAILQ_FIRST(&ic->ic_vaps);
5208 	uint32_t tmp;
5209 
5210 	RUN_DPRINTF(sc, RUN_DEBUG_BEACON, "rvp_id=%d ic_opmode=%d\n",
5211 	    RUN_VAP(vap)->rvp_id, ic->ic_opmode);
5212 
5213 	run_read(sc, RT2860_BCN_TIME_CFG, &tmp);
5214 	tmp &= ~0x1fffff;
5215 	tmp |= vap->iv_bss->ni_intval * 16;
5216 	tmp |= RT2860_TSF_TIMER_EN | RT2860_TBTT_TIMER_EN;
5217 
5218 	if (ic->ic_opmode == IEEE80211_M_STA) {
5219 		/*
5220 		 * Local TSF is always updated with remote TSF on beacon
5221 		 * reception.
5222 		 */
5223 		tmp |= 1 << RT2860_TSF_SYNC_MODE_SHIFT;
5224 	} else if (ic->ic_opmode == IEEE80211_M_IBSS) {
5225 	        tmp |= RT2860_BCN_TX_EN;
5226 	        /*
5227 	         * Local TSF is updated with remote TSF on beacon reception
5228 	         * only if the remote TSF is greater than local TSF.
5229 	         */
5230 	        tmp |= 2 << RT2860_TSF_SYNC_MODE_SHIFT;
5231 	} else if (ic->ic_opmode == IEEE80211_M_HOSTAP ||
5232 		    ic->ic_opmode == IEEE80211_M_MBSS) {
5233 	        tmp |= RT2860_BCN_TX_EN;
5234 	        /* SYNC with nobody */
5235 	        tmp |= 3 << RT2860_TSF_SYNC_MODE_SHIFT;
5236 	} else {
5237 		RUN_DPRINTF(sc, RUN_DEBUG_BEACON,
5238 		    "Enabling TSF failed. undefined opmode\n");
5239 		return;
5240 	}
5241 
5242 	run_write(sc, RT2860_BCN_TIME_CFG, tmp);
5243 }
5244 
5245 static void
5246 run_enable_tsf(struct run_softc *sc)
5247 {
5248 	uint32_t tmp;
5249 
5250 	if (run_read(sc, RT2860_BCN_TIME_CFG, &tmp) == 0) {
5251 		tmp &= ~(RT2860_BCN_TX_EN | RT2860_TBTT_TIMER_EN);
5252 		tmp |= RT2860_TSF_TIMER_EN;
5253 		run_write(sc, RT2860_BCN_TIME_CFG, tmp);
5254 	}
5255 }
5256 
5257 static void
5258 run_disable_tsf(struct run_softc *sc)
5259 {
5260 	uint32_t tmp;
5261 
5262 	if (run_read(sc, RT2860_BCN_TIME_CFG, &tmp) == 0) {
5263 		tmp &= ~(RT2860_BCN_TX_EN | RT2860_TSF_TIMER_EN |
5264 		    RT2860_TBTT_TIMER_EN);
5265 		run_write(sc, RT2860_BCN_TIME_CFG, tmp);
5266 	}
5267 }
5268 
5269 static void
5270 run_get_tsf(struct run_softc *sc, uint64_t *buf)
5271 {
5272 	run_read_region_1(sc, RT2860_TSF_TIMER_DW0, (uint8_t *)buf,
5273 	    sizeof(*buf));
5274 }
5275 
5276 static void
5277 run_enable_mrr(struct run_softc *sc)
5278 {
5279 #define	CCK(mcs)	(mcs)
5280 #define	OFDM(mcs)	(1 << 3 | (mcs))
5281 	run_write(sc, RT2860_LG_FBK_CFG0,
5282 	    OFDM(6) << 28 |	/* 54->48 */
5283 	    OFDM(5) << 24 |	/* 48->36 */
5284 	    OFDM(4) << 20 |	/* 36->24 */
5285 	    OFDM(3) << 16 |	/* 24->18 */
5286 	    OFDM(2) << 12 |	/* 18->12 */
5287 	    OFDM(1) <<  8 |	/* 12-> 9 */
5288 	    OFDM(0) <<  4 |	/*  9-> 6 */
5289 	    OFDM(0));		/*  6-> 6 */
5290 
5291 	run_write(sc, RT2860_LG_FBK_CFG1,
5292 	    CCK(2) << 12 |	/* 11->5.5 */
5293 	    CCK(1) <<  8 |	/* 5.5-> 2 */
5294 	    CCK(0) <<  4 |	/*   2-> 1 */
5295 	    CCK(0));		/*   1-> 1 */
5296 #undef OFDM
5297 #undef CCK
5298 }
5299 
5300 static void
5301 run_set_txpreamble(struct run_softc *sc)
5302 {
5303 	struct ieee80211com *ic = &sc->sc_ic;
5304 	uint32_t tmp;
5305 
5306 	run_read(sc, RT2860_AUTO_RSP_CFG, &tmp);
5307 	if (ic->ic_flags & IEEE80211_F_SHPREAMBLE)
5308 		tmp |= RT2860_CCK_SHORT_EN;
5309 	else
5310 		tmp &= ~RT2860_CCK_SHORT_EN;
5311 	run_write(sc, RT2860_AUTO_RSP_CFG, tmp);
5312 }
5313 
5314 static void
5315 run_set_basicrates(struct run_softc *sc)
5316 {
5317 	struct ieee80211com *ic = &sc->sc_ic;
5318 
5319 	/* set basic rates mask */
5320 	if (ic->ic_curmode == IEEE80211_MODE_11B)
5321 		run_write(sc, RT2860_LEGACY_BASIC_RATE, 0x003);
5322 	else if (ic->ic_curmode == IEEE80211_MODE_11A)
5323 		run_write(sc, RT2860_LEGACY_BASIC_RATE, 0x150);
5324 	else	/* 11g */
5325 		run_write(sc, RT2860_LEGACY_BASIC_RATE, 0x15f);
5326 }
5327 
5328 static void
5329 run_set_leds(struct run_softc *sc, uint16_t which)
5330 {
5331 	(void)run_mcu_cmd(sc, RT2860_MCU_CMD_LEDS,
5332 	    which | (sc->leds & 0x7f));
5333 }
5334 
5335 static void
5336 run_set_bssid(struct run_softc *sc, const uint8_t *bssid)
5337 {
5338 	run_write(sc, RT2860_MAC_BSSID_DW0,
5339 	    bssid[0] | bssid[1] << 8 | bssid[2] << 16 | bssid[3] << 24);
5340 	run_write(sc, RT2860_MAC_BSSID_DW1,
5341 	    bssid[4] | bssid[5] << 8);
5342 }
5343 
5344 static void
5345 run_set_macaddr(struct run_softc *sc, const uint8_t *addr)
5346 {
5347 	run_write(sc, RT2860_MAC_ADDR_DW0,
5348 	    addr[0] | addr[1] << 8 | addr[2] << 16 | addr[3] << 24);
5349 	run_write(sc, RT2860_MAC_ADDR_DW1,
5350 	    addr[4] | addr[5] << 8 | 0xff << 16);
5351 }
5352 
5353 static void
5354 run_updateslot(struct ieee80211com *ic)
5355 {
5356 	struct run_softc *sc = ic->ic_softc;
5357 	uint32_t i;
5358 
5359 	i = RUN_CMDQ_GET(&sc->cmdq_store);
5360 	RUN_DPRINTF(sc, RUN_DEBUG_BEACON, "cmdq_store=%d\n", i);
5361 	sc->cmdq[i].func = run_updateslot_cb;
5362 	sc->cmdq[i].arg0 = ic;
5363 	ieee80211_runtask(ic, &sc->cmdq_task);
5364 
5365 	return;
5366 }
5367 
5368 /* ARGSUSED */
5369 static void
5370 run_updateslot_cb(void *arg)
5371 {
5372 	struct ieee80211com *ic = arg;
5373 	struct run_softc *sc = ic->ic_softc;
5374 	uint32_t tmp;
5375 
5376 	run_read(sc, RT2860_BKOFF_SLOT_CFG, &tmp);
5377 	tmp &= ~0xff;
5378 	tmp |= IEEE80211_GET_SLOTTIME(ic);
5379 	run_write(sc, RT2860_BKOFF_SLOT_CFG, tmp);
5380 }
5381 
5382 static void
5383 run_update_mcast(struct ieee80211com *ic)
5384 {
5385 }
5386 
5387 static int8_t
5388 run_rssi2dbm(struct run_softc *sc, uint8_t rssi, uint8_t rxchain)
5389 {
5390 	struct ieee80211com *ic = &sc->sc_ic;
5391 	struct ieee80211_channel *c = ic->ic_curchan;
5392 	int delta;
5393 
5394 	if (IEEE80211_IS_CHAN_5GHZ(c)) {
5395 		u_int chan = ieee80211_chan2ieee(ic, c);
5396 		delta = sc->rssi_5ghz[rxchain];
5397 
5398 		/* determine channel group */
5399 		if (chan <= 64)
5400 			delta -= sc->lna[1];
5401 		else if (chan <= 128)
5402 			delta -= sc->lna[2];
5403 		else
5404 			delta -= sc->lna[3];
5405 	} else
5406 		delta = sc->rssi_2ghz[rxchain] - sc->lna[0];
5407 
5408 	return (-12 - delta - rssi);
5409 }
5410 
5411 static void
5412 run_rt5390_bbp_init(struct run_softc *sc)
5413 {
5414 	u_int i;
5415 	uint8_t bbp;
5416 
5417 	/* Apply maximum likelihood detection for 2 stream case. */
5418 	run_bbp_read(sc, 105, &bbp);
5419 	if (sc->nrxchains > 1)
5420 		run_bbp_write(sc, 105, bbp | RT5390_MLD);
5421 
5422 	/* Avoid data lost and CRC error. */
5423 	run_bbp_read(sc, 4, &bbp);
5424 	run_bbp_write(sc, 4, bbp | RT5390_MAC_IF_CTRL);
5425 
5426 	if (sc->mac_ver == 0x5592) {
5427 		for (i = 0; i < nitems(rt5592_def_bbp); i++) {
5428 			run_bbp_write(sc, rt5592_def_bbp[i].reg,
5429 			    rt5592_def_bbp[i].val);
5430 		}
5431 		for (i = 0; i < nitems(rt5592_bbp_r196); i++) {
5432 			run_bbp_write(sc, 195, i + 0x80);
5433 			run_bbp_write(sc, 196, rt5592_bbp_r196[i]);
5434 		}
5435 	} else {
5436 		for (i = 0; i < nitems(rt5390_def_bbp); i++) {
5437 			run_bbp_write(sc, rt5390_def_bbp[i].reg,
5438 			    rt5390_def_bbp[i].val);
5439 		}
5440 	}
5441 	if (sc->mac_ver == 0x5392) {
5442 		run_bbp_write(sc, 88, 0x90);
5443 		run_bbp_write(sc, 95, 0x9a);
5444 		run_bbp_write(sc, 98, 0x12);
5445 		run_bbp_write(sc, 106, 0x12);
5446 		run_bbp_write(sc, 134, 0xd0);
5447 		run_bbp_write(sc, 135, 0xf6);
5448 		run_bbp_write(sc, 148, 0x84);
5449 	}
5450 
5451 	run_bbp_read(sc, 152, &bbp);
5452 	run_bbp_write(sc, 152, bbp | 0x80);
5453 
5454 	/* Fix BBP254 for RT5592C. */
5455 	if (sc->mac_ver == 0x5592 && sc->mac_rev >= 0x0221) {
5456 		run_bbp_read(sc, 254, &bbp);
5457 		run_bbp_write(sc, 254, bbp | 0x80);
5458 	}
5459 
5460 	/* Disable hardware antenna diversity. */
5461 	if (sc->mac_ver == 0x5390)
5462 		run_bbp_write(sc, 154, 0);
5463 
5464 	/* Initialize Rx CCK/OFDM frequency offset report. */
5465 	run_bbp_write(sc, 142, 1);
5466 	run_bbp_write(sc, 143, 57);
5467 }
5468 
5469 static int
5470 run_bbp_init(struct run_softc *sc)
5471 {
5472 	int i, error, ntries;
5473 	uint8_t bbp0;
5474 
5475 	/* wait for BBP to wake up */
5476 	for (ntries = 0; ntries < 20; ntries++) {
5477 		if ((error = run_bbp_read(sc, 0, &bbp0)) != 0)
5478 			return error;
5479 		if (bbp0 != 0 && bbp0 != 0xff)
5480 			break;
5481 	}
5482 	if (ntries == 20)
5483 		return (ETIMEDOUT);
5484 
5485 	/* initialize BBP registers to default values */
5486 	if (sc->mac_ver >= 0x5390)
5487 		run_rt5390_bbp_init(sc);
5488 	else {
5489 		for (i = 0; i < nitems(rt2860_def_bbp); i++) {
5490 			run_bbp_write(sc, rt2860_def_bbp[i].reg,
5491 			    rt2860_def_bbp[i].val);
5492 		}
5493 	}
5494 
5495 	if (sc->mac_ver == 0x3593) {
5496 		run_bbp_write(sc, 79, 0x13);
5497 		run_bbp_write(sc, 80, 0x05);
5498 		run_bbp_write(sc, 81, 0x33);
5499 		run_bbp_write(sc, 86, 0x46);
5500 		run_bbp_write(sc, 137, 0x0f);
5501 	}
5502 
5503 	/* fix BBP84 for RT2860E */
5504 	if (sc->mac_ver == 0x2860 && sc->mac_rev != 0x0101)
5505 		run_bbp_write(sc, 84, 0x19);
5506 
5507 	if (sc->mac_ver >= 0x3070 && (sc->mac_ver != 0x3593 &&
5508 	    sc->mac_ver != 0x5592)) {
5509 		run_bbp_write(sc, 79, 0x13);
5510 		run_bbp_write(sc, 80, 0x05);
5511 		run_bbp_write(sc, 81, 0x33);
5512 	} else if (sc->mac_ver == 0x2860 && sc->mac_rev == 0x0100) {
5513 		run_bbp_write(sc, 69, 0x16);
5514 		run_bbp_write(sc, 73, 0x12);
5515 	}
5516 	return (0);
5517 }
5518 
5519 static int
5520 run_rt3070_rf_init(struct run_softc *sc)
5521 {
5522 	uint32_t tmp;
5523 	uint8_t bbp4, mingain, rf, target;
5524 	u_int i;
5525 
5526 	run_rt3070_rf_read(sc, 30, &rf);
5527 	/* toggle RF R30 bit 7 */
5528 	run_rt3070_rf_write(sc, 30, rf | 0x80);
5529 	run_delay(sc, 10);
5530 	run_rt3070_rf_write(sc, 30, rf & ~0x80);
5531 
5532 	/* initialize RF registers to default value */
5533 	if (sc->mac_ver == 0x3572) {
5534 		for (i = 0; i < nitems(rt3572_def_rf); i++) {
5535 			run_rt3070_rf_write(sc, rt3572_def_rf[i].reg,
5536 			    rt3572_def_rf[i].val);
5537 		}
5538 	} else {
5539 		for (i = 0; i < nitems(rt3070_def_rf); i++) {
5540 			run_rt3070_rf_write(sc, rt3070_def_rf[i].reg,
5541 			    rt3070_def_rf[i].val);
5542 		}
5543 	}
5544 
5545 	if (sc->mac_ver == 0x3070 && sc->mac_rev < 0x0201) {
5546 		/*
5547 		 * Change voltage from 1.2V to 1.35V for RT3070.
5548 		 * The DAC issue (RT3070_LDO_CFG0) has been fixed
5549 		 * in RT3070(F).
5550 		 */
5551 		run_read(sc, RT3070_LDO_CFG0, &tmp);
5552 		tmp = (tmp & ~0x0f000000) | 0x0d000000;
5553 		run_write(sc, RT3070_LDO_CFG0, tmp);
5554 
5555 	} else if (sc->mac_ver == 0x3071) {
5556 		run_rt3070_rf_read(sc, 6, &rf);
5557 		run_rt3070_rf_write(sc, 6, rf | 0x40);
5558 		run_rt3070_rf_write(sc, 31, 0x14);
5559 
5560 		run_read(sc, RT3070_LDO_CFG0, &tmp);
5561 		tmp &= ~0x1f000000;
5562 		if (sc->mac_rev < 0x0211)
5563 			tmp |= 0x0d000000;	/* 1.3V */
5564 		else
5565 			tmp |= 0x01000000;	/* 1.2V */
5566 		run_write(sc, RT3070_LDO_CFG0, tmp);
5567 
5568 		/* patch LNA_PE_G1 */
5569 		run_read(sc, RT3070_GPIO_SWITCH, &tmp);
5570 		run_write(sc, RT3070_GPIO_SWITCH, tmp & ~0x20);
5571 
5572 	} else if (sc->mac_ver == 0x3572) {
5573 		run_rt3070_rf_read(sc, 6, &rf);
5574 		run_rt3070_rf_write(sc, 6, rf | 0x40);
5575 
5576 		/* increase voltage from 1.2V to 1.35V */
5577 		run_read(sc, RT3070_LDO_CFG0, &tmp);
5578 		tmp = (tmp & ~0x1f000000) | 0x0d000000;
5579 		run_write(sc, RT3070_LDO_CFG0, tmp);
5580 
5581 		if (sc->mac_rev < 0x0211 || !sc->patch_dac) {
5582 			run_delay(sc, 1);	/* wait for 1msec */
5583 			/* decrease voltage back to 1.2V */
5584 			tmp = (tmp & ~0x1f000000) | 0x01000000;
5585 			run_write(sc, RT3070_LDO_CFG0, tmp);
5586 		}
5587 	}
5588 
5589 	/* select 20MHz bandwidth */
5590 	run_rt3070_rf_read(sc, 31, &rf);
5591 	run_rt3070_rf_write(sc, 31, rf & ~0x20);
5592 
5593 	/* calibrate filter for 20MHz bandwidth */
5594 	sc->rf24_20mhz = 0x1f;	/* default value */
5595 	target = (sc->mac_ver < 0x3071) ? 0x16 : 0x13;
5596 	run_rt3070_filter_calib(sc, 0x07, target, &sc->rf24_20mhz);
5597 
5598 	/* select 40MHz bandwidth */
5599 	run_bbp_read(sc, 4, &bbp4);
5600 	run_bbp_write(sc, 4, (bbp4 & ~0x18) | 0x10);
5601 	run_rt3070_rf_read(sc, 31, &rf);
5602 	run_rt3070_rf_write(sc, 31, rf | 0x20);
5603 
5604 	/* calibrate filter for 40MHz bandwidth */
5605 	sc->rf24_40mhz = 0x2f;	/* default value */
5606 	target = (sc->mac_ver < 0x3071) ? 0x19 : 0x15;
5607 	run_rt3070_filter_calib(sc, 0x27, target, &sc->rf24_40mhz);
5608 
5609 	/* go back to 20MHz bandwidth */
5610 	run_bbp_read(sc, 4, &bbp4);
5611 	run_bbp_write(sc, 4, bbp4 & ~0x18);
5612 
5613 	if (sc->mac_ver == 0x3572) {
5614 		/* save default BBP registers 25 and 26 values */
5615 		run_bbp_read(sc, 25, &sc->bbp25);
5616 		run_bbp_read(sc, 26, &sc->bbp26);
5617 	} else if (sc->mac_rev < 0x0201 || sc->mac_rev < 0x0211)
5618 		run_rt3070_rf_write(sc, 27, 0x03);
5619 
5620 	run_read(sc, RT3070_OPT_14, &tmp);
5621 	run_write(sc, RT3070_OPT_14, tmp | 1);
5622 
5623 	if (sc->mac_ver == 0x3070 || sc->mac_ver == 0x3071) {
5624 		run_rt3070_rf_read(sc, 17, &rf);
5625 		rf &= ~RT3070_TX_LO1;
5626 		if ((sc->mac_ver == 0x3070 ||
5627 		     (sc->mac_ver == 0x3071 && sc->mac_rev >= 0x0211)) &&
5628 		    !sc->ext_2ghz_lna)
5629 			rf |= 0x20;	/* fix for long range Rx issue */
5630 		mingain = (sc->mac_ver == 0x3070) ? 1 : 2;
5631 		if (sc->txmixgain_2ghz >= mingain)
5632 			rf = (rf & ~0x7) | sc->txmixgain_2ghz;
5633 		run_rt3070_rf_write(sc, 17, rf);
5634 	}
5635 
5636 	if (sc->mac_ver == 0x3071) {
5637 		run_rt3070_rf_read(sc, 1, &rf);
5638 		rf &= ~(RT3070_RX0_PD | RT3070_TX0_PD);
5639 		rf |= RT3070_RF_BLOCK | RT3070_RX1_PD | RT3070_TX1_PD;
5640 		run_rt3070_rf_write(sc, 1, rf);
5641 
5642 		run_rt3070_rf_read(sc, 15, &rf);
5643 		run_rt3070_rf_write(sc, 15, rf & ~RT3070_TX_LO2);
5644 
5645 		run_rt3070_rf_read(sc, 20, &rf);
5646 		run_rt3070_rf_write(sc, 20, rf & ~RT3070_RX_LO1);
5647 
5648 		run_rt3070_rf_read(sc, 21, &rf);
5649 		run_rt3070_rf_write(sc, 21, rf & ~RT3070_RX_LO2);
5650 	}
5651 
5652 	if (sc->mac_ver == 0x3070 || sc->mac_ver == 0x3071) {
5653 		/* fix Tx to Rx IQ glitch by raising RF voltage */
5654 		run_rt3070_rf_read(sc, 27, &rf);
5655 		rf &= ~0x77;
5656 		if (sc->mac_rev < 0x0211)
5657 			rf |= 0x03;
5658 		run_rt3070_rf_write(sc, 27, rf);
5659 	}
5660 	return (0);
5661 }
5662 
5663 static void
5664 run_rt3593_rf_init(struct run_softc *sc)
5665 {
5666 	uint32_t tmp;
5667 	uint8_t rf;
5668 	u_int i;
5669 
5670 	/* Disable the GPIO bits 4 and 7 for LNA PE control. */
5671 	run_read(sc, RT3070_GPIO_SWITCH, &tmp);
5672 	tmp &= ~(1 << 4 | 1 << 7);
5673 	run_write(sc, RT3070_GPIO_SWITCH, tmp);
5674 
5675 	/* Initialize RF registers to default value. */
5676 	for (i = 0; i < nitems(rt3593_def_rf); i++) {
5677 		run_rt3070_rf_write(sc, rt3593_def_rf[i].reg,
5678 		    rt3593_def_rf[i].val);
5679 	}
5680 
5681 	/* Toggle RF R2 to initiate calibration. */
5682 	run_rt3070_rf_write(sc, 2, RT5390_RESCAL);
5683 
5684 	/* Initialize RF frequency offset. */
5685 	run_adjust_freq_offset(sc);
5686 
5687 	run_rt3070_rf_read(sc, 18, &rf);
5688 	run_rt3070_rf_write(sc, 18, rf | RT3593_AUTOTUNE_BYPASS);
5689 
5690 	/*
5691 	 * Increase voltage from 1.2V to 1.35V, wait for 1 msec to
5692 	 * decrease voltage back to 1.2V.
5693 	 */
5694 	run_read(sc, RT3070_LDO_CFG0, &tmp);
5695 	tmp = (tmp & ~0x1f000000) | 0x0d000000;
5696 	run_write(sc, RT3070_LDO_CFG0, tmp);
5697 	run_delay(sc, 1);
5698 	tmp = (tmp & ~0x1f000000) | 0x01000000;
5699 	run_write(sc, RT3070_LDO_CFG0, tmp);
5700 
5701 	sc->rf24_20mhz = 0x1f;
5702 	sc->rf24_40mhz = 0x2f;
5703 
5704 	/* Save default BBP registers 25 and 26 values. */
5705 	run_bbp_read(sc, 25, &sc->bbp25);
5706 	run_bbp_read(sc, 26, &sc->bbp26);
5707 
5708 	run_read(sc, RT3070_OPT_14, &tmp);
5709 	run_write(sc, RT3070_OPT_14, tmp | 1);
5710 }
5711 
5712 static void
5713 run_rt5390_rf_init(struct run_softc *sc)
5714 {
5715 	uint32_t tmp;
5716 	uint8_t rf;
5717 	u_int i;
5718 
5719 	/* Toggle RF R2 to initiate calibration. */
5720 	if (sc->mac_ver == 0x5390) {
5721 		run_rt3070_rf_read(sc, 2, &rf);
5722 		run_rt3070_rf_write(sc, 2, rf | RT5390_RESCAL);
5723 		run_delay(sc, 10);
5724 		run_rt3070_rf_write(sc, 2, rf & ~RT5390_RESCAL);
5725 	} else {
5726 		run_rt3070_rf_write(sc, 2, RT5390_RESCAL);
5727 		run_delay(sc, 10);
5728 	}
5729 
5730 	/* Initialize RF registers to default value. */
5731 	if (sc->mac_ver == 0x5592) {
5732 		for (i = 0; i < nitems(rt5592_def_rf); i++) {
5733 			run_rt3070_rf_write(sc, rt5592_def_rf[i].reg,
5734 			    rt5592_def_rf[i].val);
5735 		}
5736 		/* Initialize RF frequency offset. */
5737 		run_adjust_freq_offset(sc);
5738 	} else if (sc->mac_ver == 0x5392) {
5739 		for (i = 0; i < nitems(rt5392_def_rf); i++) {
5740 			run_rt3070_rf_write(sc, rt5392_def_rf[i].reg,
5741 			    rt5392_def_rf[i].val);
5742 		}
5743 		if (sc->mac_rev >= 0x0223) {
5744 			run_rt3070_rf_write(sc, 23, 0x0f);
5745 			run_rt3070_rf_write(sc, 24, 0x3e);
5746 			run_rt3070_rf_write(sc, 51, 0x32);
5747 			run_rt3070_rf_write(sc, 53, 0x22);
5748 			run_rt3070_rf_write(sc, 56, 0xc1);
5749 			run_rt3070_rf_write(sc, 59, 0x0f);
5750 		}
5751 	} else {
5752 		for (i = 0; i < nitems(rt5390_def_rf); i++) {
5753 			run_rt3070_rf_write(sc, rt5390_def_rf[i].reg,
5754 			    rt5390_def_rf[i].val);
5755 		}
5756 		if (sc->mac_rev >= 0x0502) {
5757 			run_rt3070_rf_write(sc, 6, 0xe0);
5758 			run_rt3070_rf_write(sc, 25, 0x80);
5759 			run_rt3070_rf_write(sc, 46, 0x73);
5760 			run_rt3070_rf_write(sc, 53, 0x00);
5761 			run_rt3070_rf_write(sc, 56, 0x42);
5762 			run_rt3070_rf_write(sc, 61, 0xd1);
5763 		}
5764 	}
5765 
5766 	sc->rf24_20mhz = 0x1f;	/* default value */
5767 	sc->rf24_40mhz = (sc->mac_ver == 0x5592) ? 0 : 0x2f;
5768 
5769 	if (sc->mac_rev < 0x0211)
5770 		run_rt3070_rf_write(sc, 27, 0x3);
5771 
5772 	run_read(sc, RT3070_OPT_14, &tmp);
5773 	run_write(sc, RT3070_OPT_14, tmp | 1);
5774 }
5775 
5776 static int
5777 run_rt3070_filter_calib(struct run_softc *sc, uint8_t init, uint8_t target,
5778     uint8_t *val)
5779 {
5780 	uint8_t rf22, rf24;
5781 	uint8_t bbp55_pb, bbp55_sb, delta;
5782 	int ntries;
5783 
5784 	/* program filter */
5785 	run_rt3070_rf_read(sc, 24, &rf24);
5786 	rf24 = (rf24 & 0xc0) | init;	/* initial filter value */
5787 	run_rt3070_rf_write(sc, 24, rf24);
5788 
5789 	/* enable baseband loopback mode */
5790 	run_rt3070_rf_read(sc, 22, &rf22);
5791 	run_rt3070_rf_write(sc, 22, rf22 | 0x01);
5792 
5793 	/* set power and frequency of passband test tone */
5794 	run_bbp_write(sc, 24, 0x00);
5795 	for (ntries = 0; ntries < 100; ntries++) {
5796 		/* transmit test tone */
5797 		run_bbp_write(sc, 25, 0x90);
5798 		run_delay(sc, 10);
5799 		/* read received power */
5800 		run_bbp_read(sc, 55, &bbp55_pb);
5801 		if (bbp55_pb != 0)
5802 			break;
5803 	}
5804 	if (ntries == 100)
5805 		return (ETIMEDOUT);
5806 
5807 	/* set power and frequency of stopband test tone */
5808 	run_bbp_write(sc, 24, 0x06);
5809 	for (ntries = 0; ntries < 100; ntries++) {
5810 		/* transmit test tone */
5811 		run_bbp_write(sc, 25, 0x90);
5812 		run_delay(sc, 10);
5813 		/* read received power */
5814 		run_bbp_read(sc, 55, &bbp55_sb);
5815 
5816 		delta = bbp55_pb - bbp55_sb;
5817 		if (delta > target)
5818 			break;
5819 
5820 		/* reprogram filter */
5821 		rf24++;
5822 		run_rt3070_rf_write(sc, 24, rf24);
5823 	}
5824 	if (ntries < 100) {
5825 		if (rf24 != init)
5826 			rf24--;	/* backtrack */
5827 		*val = rf24;
5828 		run_rt3070_rf_write(sc, 24, rf24);
5829 	}
5830 
5831 	/* restore initial state */
5832 	run_bbp_write(sc, 24, 0x00);
5833 
5834 	/* disable baseband loopback mode */
5835 	run_rt3070_rf_read(sc, 22, &rf22);
5836 	run_rt3070_rf_write(sc, 22, rf22 & ~0x01);
5837 
5838 	return (0);
5839 }
5840 
5841 static void
5842 run_rt3070_rf_setup(struct run_softc *sc)
5843 {
5844 	uint8_t bbp, rf;
5845 	int i;
5846 
5847 	if (sc->mac_ver == 0x3572) {
5848 		/* enable DC filter */
5849 		if (sc->mac_rev >= 0x0201)
5850 			run_bbp_write(sc, 103, 0xc0);
5851 
5852 		run_bbp_read(sc, 138, &bbp);
5853 		if (sc->ntxchains == 1)
5854 			bbp |= 0x20;	/* turn off DAC1 */
5855 		if (sc->nrxchains == 1)
5856 			bbp &= ~0x02;	/* turn off ADC1 */
5857 		run_bbp_write(sc, 138, bbp);
5858 
5859 		if (sc->mac_rev >= 0x0211) {
5860 			/* improve power consumption */
5861 			run_bbp_read(sc, 31, &bbp);
5862 			run_bbp_write(sc, 31, bbp & ~0x03);
5863 		}
5864 
5865 		run_rt3070_rf_read(sc, 16, &rf);
5866 		rf = (rf & ~0x07) | sc->txmixgain_2ghz;
5867 		run_rt3070_rf_write(sc, 16, rf);
5868 
5869 	} else if (sc->mac_ver == 0x3071) {
5870 		if (sc->mac_rev >= 0x0211) {
5871 			/* enable DC filter */
5872 			run_bbp_write(sc, 103, 0xc0);
5873 
5874 			/* improve power consumption */
5875 			run_bbp_read(sc, 31, &bbp);
5876 			run_bbp_write(sc, 31, bbp & ~0x03);
5877 		}
5878 
5879 		run_bbp_read(sc, 138, &bbp);
5880 		if (sc->ntxchains == 1)
5881 			bbp |= 0x20;	/* turn off DAC1 */
5882 		if (sc->nrxchains == 1)
5883 			bbp &= ~0x02;	/* turn off ADC1 */
5884 		run_bbp_write(sc, 138, bbp);
5885 
5886 		run_write(sc, RT2860_TX_SW_CFG1, 0);
5887 		if (sc->mac_rev < 0x0211) {
5888 			run_write(sc, RT2860_TX_SW_CFG2,
5889 			    sc->patch_dac ? 0x2c : 0x0f);
5890 		} else
5891 			run_write(sc, RT2860_TX_SW_CFG2, 0);
5892 
5893 	} else if (sc->mac_ver == 0x3070) {
5894 		if (sc->mac_rev >= 0x0201) {
5895 			/* enable DC filter */
5896 			run_bbp_write(sc, 103, 0xc0);
5897 
5898 			/* improve power consumption */
5899 			run_bbp_read(sc, 31, &bbp);
5900 			run_bbp_write(sc, 31, bbp & ~0x03);
5901 		}
5902 
5903 		if (sc->mac_rev < 0x0201) {
5904 			run_write(sc, RT2860_TX_SW_CFG1, 0);
5905 			run_write(sc, RT2860_TX_SW_CFG2, 0x2c);
5906 		} else
5907 			run_write(sc, RT2860_TX_SW_CFG2, 0);
5908 	}
5909 
5910 	/* initialize RF registers from ROM for >=RT3071*/
5911 	if (sc->mac_ver >= 0x3071) {
5912 		for (i = 0; i < 10; i++) {
5913 			if (sc->rf[i].reg == 0 || sc->rf[i].reg == 0xff)
5914 				continue;
5915 			run_rt3070_rf_write(sc, sc->rf[i].reg, sc->rf[i].val);
5916 		}
5917 	}
5918 }
5919 
5920 static void
5921 run_rt3593_rf_setup(struct run_softc *sc)
5922 {
5923 	uint8_t bbp, rf;
5924 
5925 	if (sc->mac_rev >= 0x0211) {
5926 		/* Enable DC filter. */
5927 		run_bbp_write(sc, 103, 0xc0);
5928 	}
5929 	run_write(sc, RT2860_TX_SW_CFG1, 0);
5930 	if (sc->mac_rev < 0x0211) {
5931 		run_write(sc, RT2860_TX_SW_CFG2,
5932 		    sc->patch_dac ? 0x2c : 0x0f);
5933 	} else
5934 		run_write(sc, RT2860_TX_SW_CFG2, 0);
5935 
5936 	run_rt3070_rf_read(sc, 50, &rf);
5937 	run_rt3070_rf_write(sc, 50, rf & ~RT3593_TX_LO2);
5938 
5939 	run_rt3070_rf_read(sc, 51, &rf);
5940 	rf = (rf & ~(RT3593_TX_LO1 | 0x0c)) |
5941 	    ((sc->txmixgain_2ghz & 0x07) << 2);
5942 	run_rt3070_rf_write(sc, 51, rf);
5943 
5944 	run_rt3070_rf_read(sc, 38, &rf);
5945 	run_rt3070_rf_write(sc, 38, rf & ~RT5390_RX_LO1);
5946 
5947 	run_rt3070_rf_read(sc, 39, &rf);
5948 	run_rt3070_rf_write(sc, 39, rf & ~RT5390_RX_LO2);
5949 
5950 	run_rt3070_rf_read(sc, 1, &rf);
5951 	run_rt3070_rf_write(sc, 1, rf & ~(RT3070_RF_BLOCK | RT3070_PLL_PD));
5952 
5953 	run_rt3070_rf_read(sc, 30, &rf);
5954 	rf = (rf & ~0x18) | 0x10;
5955 	run_rt3070_rf_write(sc, 30, rf);
5956 
5957 	/* Apply maximum likelihood detection for 2 stream case. */
5958 	run_bbp_read(sc, 105, &bbp);
5959 	if (sc->nrxchains > 1)
5960 		run_bbp_write(sc, 105, bbp | RT5390_MLD);
5961 
5962 	/* Avoid data lost and CRC error. */
5963 	run_bbp_read(sc, 4, &bbp);
5964 	run_bbp_write(sc, 4, bbp | RT5390_MAC_IF_CTRL);
5965 
5966 	run_bbp_write(sc, 92, 0x02);
5967 	run_bbp_write(sc, 82, 0x82);
5968 	run_bbp_write(sc, 106, 0x05);
5969 	run_bbp_write(sc, 104, 0x92);
5970 	run_bbp_write(sc, 88, 0x90);
5971 	run_bbp_write(sc, 148, 0xc8);
5972 	run_bbp_write(sc, 47, 0x48);
5973 	run_bbp_write(sc, 120, 0x50);
5974 
5975 	run_bbp_write(sc, 163, 0x9d);
5976 
5977 	/* SNR mapping. */
5978 	run_bbp_write(sc, 142, 0x06);
5979 	run_bbp_write(sc, 143, 0xa0);
5980 	run_bbp_write(sc, 142, 0x07);
5981 	run_bbp_write(sc, 143, 0xa1);
5982 	run_bbp_write(sc, 142, 0x08);
5983 	run_bbp_write(sc, 143, 0xa2);
5984 
5985 	run_bbp_write(sc, 31, 0x08);
5986 	run_bbp_write(sc, 68, 0x0b);
5987 	run_bbp_write(sc, 105, 0x04);
5988 }
5989 
5990 static void
5991 run_rt5390_rf_setup(struct run_softc *sc)
5992 {
5993 	uint8_t bbp, rf;
5994 
5995 	if (sc->mac_rev >= 0x0211) {
5996 		/* Enable DC filter. */
5997 		run_bbp_write(sc, 103, 0xc0);
5998 
5999 		if (sc->mac_ver != 0x5592) {
6000 			/* Improve power consumption. */
6001 			run_bbp_read(sc, 31, &bbp);
6002 			run_bbp_write(sc, 31, bbp & ~0x03);
6003 		}
6004 	}
6005 
6006 	run_bbp_read(sc, 138, &bbp);
6007 	if (sc->ntxchains == 1)
6008 		bbp |= 0x20;	/* turn off DAC1 */
6009 	if (sc->nrxchains == 1)
6010 		bbp &= ~0x02;	/* turn off ADC1 */
6011 	run_bbp_write(sc, 138, bbp);
6012 
6013 	run_rt3070_rf_read(sc, 38, &rf);
6014 	run_rt3070_rf_write(sc, 38, rf & ~RT5390_RX_LO1);
6015 
6016 	run_rt3070_rf_read(sc, 39, &rf);
6017 	run_rt3070_rf_write(sc, 39, rf & ~RT5390_RX_LO2);
6018 
6019 	/* Avoid data lost and CRC error. */
6020 	run_bbp_read(sc, 4, &bbp);
6021 	run_bbp_write(sc, 4, bbp | RT5390_MAC_IF_CTRL);
6022 
6023 	run_rt3070_rf_read(sc, 30, &rf);
6024 	rf = (rf & ~0x18) | 0x10;
6025 	run_rt3070_rf_write(sc, 30, rf);
6026 
6027 	if (sc->mac_ver != 0x5592) {
6028 		run_write(sc, RT2860_TX_SW_CFG1, 0);
6029 		if (sc->mac_rev < 0x0211) {
6030 			run_write(sc, RT2860_TX_SW_CFG2,
6031 			    sc->patch_dac ? 0x2c : 0x0f);
6032 		} else
6033 			run_write(sc, RT2860_TX_SW_CFG2, 0);
6034 	}
6035 }
6036 
6037 static int
6038 run_txrx_enable(struct run_softc *sc)
6039 {
6040 	struct ieee80211com *ic = &sc->sc_ic;
6041 	uint32_t tmp;
6042 	int error, ntries;
6043 
6044 	run_write(sc, RT2860_MAC_SYS_CTRL, RT2860_MAC_TX_EN);
6045 	for (ntries = 0; ntries < 200; ntries++) {
6046 		if ((error = run_read(sc, RT2860_WPDMA_GLO_CFG, &tmp)) != 0)
6047 			return (error);
6048 		if ((tmp & (RT2860_TX_DMA_BUSY | RT2860_RX_DMA_BUSY)) == 0)
6049 			break;
6050 		run_delay(sc, 50);
6051 	}
6052 	if (ntries == 200)
6053 		return (ETIMEDOUT);
6054 
6055 	run_delay(sc, 50);
6056 
6057 	tmp |= RT2860_RX_DMA_EN | RT2860_TX_DMA_EN | RT2860_TX_WB_DDONE;
6058 	run_write(sc, RT2860_WPDMA_GLO_CFG, tmp);
6059 
6060 	/* enable Rx bulk aggregation (set timeout and limit) */
6061 	tmp = RT2860_USB_TX_EN | RT2860_USB_RX_EN | RT2860_USB_RX_AGG_EN |
6062 	    RT2860_USB_RX_AGG_TO(128) | RT2860_USB_RX_AGG_LMT(2);
6063 	run_write(sc, RT2860_USB_DMA_CFG, tmp);
6064 
6065 	/* set Rx filter */
6066 	tmp = RT2860_DROP_CRC_ERR | RT2860_DROP_PHY_ERR;
6067 	if (ic->ic_opmode != IEEE80211_M_MONITOR) {
6068 		tmp |= RT2860_DROP_UC_NOME | RT2860_DROP_DUPL |
6069 		    RT2860_DROP_CTS | RT2860_DROP_BA | RT2860_DROP_ACK |
6070 		    RT2860_DROP_VER_ERR | RT2860_DROP_CTRL_RSV |
6071 		    RT2860_DROP_CFACK | RT2860_DROP_CFEND;
6072 		if (ic->ic_opmode == IEEE80211_M_STA)
6073 			tmp |= RT2860_DROP_RTS | RT2860_DROP_PSPOLL;
6074 	}
6075 	run_write(sc, RT2860_RX_FILTR_CFG, tmp);
6076 
6077 	run_write(sc, RT2860_MAC_SYS_CTRL,
6078 	    RT2860_MAC_RX_EN | RT2860_MAC_TX_EN);
6079 
6080 	return (0);
6081 }
6082 
6083 static void
6084 run_adjust_freq_offset(struct run_softc *sc)
6085 {
6086 	uint8_t rf, tmp;
6087 
6088 	run_rt3070_rf_read(sc, 17, &rf);
6089 	tmp = rf;
6090 	rf = (rf & ~0x7f) | (sc->freq & 0x7f);
6091 	rf = MIN(rf, 0x5f);
6092 
6093 	if (tmp != rf)
6094 		run_mcu_cmd(sc, 0x74, (tmp << 8 ) | rf);
6095 }
6096 
6097 static void
6098 run_init_locked(struct run_softc *sc)
6099 {
6100 	struct ieee80211com *ic = &sc->sc_ic;
6101 	struct ieee80211vap *vap = TAILQ_FIRST(&ic->ic_vaps);
6102 	uint32_t tmp;
6103 	uint8_t bbp1, bbp3;
6104 	int i;
6105 	int ridx;
6106 	int ntries;
6107 
6108 	if (ic->ic_nrunning > 1)
6109 		return;
6110 
6111 	run_stop(sc);
6112 
6113 	if (run_load_microcode(sc) != 0) {
6114 		device_printf(sc->sc_dev, "could not load 8051 microcode\n");
6115 		goto fail;
6116 	}
6117 
6118 	for (ntries = 0; ntries < 100; ntries++) {
6119 		if (run_read(sc, RT2860_ASIC_VER_ID, &tmp) != 0)
6120 			goto fail;
6121 		if (tmp != 0 && tmp != 0xffffffff)
6122 			break;
6123 		run_delay(sc, 10);
6124 	}
6125 	if (ntries == 100)
6126 		goto fail;
6127 
6128 	for (i = 0; i != RUN_EP_QUEUES; i++)
6129 		run_setup_tx_list(sc, &sc->sc_epq[i]);
6130 
6131 	run_set_macaddr(sc, vap ? vap->iv_myaddr : ic->ic_macaddr);
6132 
6133 	for (ntries = 0; ntries < 100; ntries++) {
6134 		if (run_read(sc, RT2860_WPDMA_GLO_CFG, &tmp) != 0)
6135 			goto fail;
6136 		if ((tmp & (RT2860_TX_DMA_BUSY | RT2860_RX_DMA_BUSY)) == 0)
6137 			break;
6138 		run_delay(sc, 10);
6139 	}
6140 	if (ntries == 100) {
6141 		device_printf(sc->sc_dev, "timeout waiting for DMA engine\n");
6142 		goto fail;
6143 	}
6144 	tmp &= 0xff0;
6145 	tmp |= RT2860_TX_WB_DDONE;
6146 	run_write(sc, RT2860_WPDMA_GLO_CFG, tmp);
6147 
6148 	/* turn off PME_OEN to solve high-current issue */
6149 	run_read(sc, RT2860_SYS_CTRL, &tmp);
6150 	run_write(sc, RT2860_SYS_CTRL, tmp & ~RT2860_PME_OEN);
6151 
6152 	run_write(sc, RT2860_MAC_SYS_CTRL,
6153 	    RT2860_BBP_HRST | RT2860_MAC_SRST);
6154 	run_write(sc, RT2860_USB_DMA_CFG, 0);
6155 
6156 	if (run_reset(sc) != 0) {
6157 		device_printf(sc->sc_dev, "could not reset chipset\n");
6158 		goto fail;
6159 	}
6160 
6161 	run_write(sc, RT2860_MAC_SYS_CTRL, 0);
6162 
6163 	/* init Tx power for all Tx rates (from EEPROM) */
6164 	for (ridx = 0; ridx < 5; ridx++) {
6165 		if (sc->txpow20mhz[ridx] == 0xffffffff)
6166 			continue;
6167 		run_write(sc, RT2860_TX_PWR_CFG(ridx), sc->txpow20mhz[ridx]);
6168 	}
6169 
6170 	for (i = 0; i < nitems(rt2870_def_mac); i++)
6171 		run_write(sc, rt2870_def_mac[i].reg, rt2870_def_mac[i].val);
6172 	run_write(sc, RT2860_WMM_AIFSN_CFG, 0x00002273);
6173 	run_write(sc, RT2860_WMM_CWMIN_CFG, 0x00002344);
6174 	run_write(sc, RT2860_WMM_CWMAX_CFG, 0x000034aa);
6175 
6176 	if (sc->mac_ver >= 0x5390) {
6177 		run_write(sc, RT2860_TX_SW_CFG0,
6178 		    4 << RT2860_DLY_PAPE_EN_SHIFT | 4);
6179 		if (sc->mac_ver >= 0x5392) {
6180 			run_write(sc, RT2860_MAX_LEN_CFG, 0x00002fff);
6181 			if (sc->mac_ver == 0x5592) {
6182 				run_write(sc, RT2860_HT_FBK_CFG1, 0xedcba980);
6183 				run_write(sc, RT2860_TXOP_HLDR_ET, 0x00000082);
6184 			} else {
6185 				run_write(sc, RT2860_HT_FBK_CFG1, 0xedcb4980);
6186 				run_write(sc, RT2860_LG_FBK_CFG0, 0xedcba322);
6187 			}
6188 		}
6189 	} else if (sc->mac_ver == 0x3593) {
6190 		run_write(sc, RT2860_TX_SW_CFG0,
6191 		    4 << RT2860_DLY_PAPE_EN_SHIFT | 2);
6192 	} else if (sc->mac_ver >= 0x3070) {
6193 		/* set delay of PA_PE assertion to 1us (unit of 0.25us) */
6194 		run_write(sc, RT2860_TX_SW_CFG0,
6195 		    4 << RT2860_DLY_PAPE_EN_SHIFT);
6196 	}
6197 
6198 	/* wait while MAC is busy */
6199 	for (ntries = 0; ntries < 100; ntries++) {
6200 		if (run_read(sc, RT2860_MAC_STATUS_REG, &tmp) != 0)
6201 			goto fail;
6202 		if (!(tmp & (RT2860_RX_STATUS_BUSY | RT2860_TX_STATUS_BUSY)))
6203 			break;
6204 		run_delay(sc, 10);
6205 	}
6206 	if (ntries == 100)
6207 		goto fail;
6208 
6209 	/* clear Host to MCU mailbox */
6210 	run_write(sc, RT2860_H2M_BBPAGENT, 0);
6211 	run_write(sc, RT2860_H2M_MAILBOX, 0);
6212 	run_delay(sc, 10);
6213 
6214 	if (run_bbp_init(sc) != 0) {
6215 		device_printf(sc->sc_dev, "could not initialize BBP\n");
6216 		goto fail;
6217 	}
6218 
6219 	/* abort TSF synchronization */
6220 	run_disable_tsf(sc);
6221 
6222 	/* clear RX WCID search table */
6223 	run_set_region_4(sc, RT2860_WCID_ENTRY(0), 0, 512);
6224 	/* clear WCID attribute table */
6225 	run_set_region_4(sc, RT2860_WCID_ATTR(0), 0, 8 * 32);
6226 
6227 	/* hostapd sets a key before init. So, don't clear it. */
6228 	if (sc->cmdq_key_set != RUN_CMDQ_GO) {
6229 		/* clear shared key table */
6230 		run_set_region_4(sc, RT2860_SKEY(0, 0), 0, 8 * 32);
6231 		/* clear shared key mode */
6232 		run_set_region_4(sc, RT2860_SKEY_MODE_0_7, 0, 4);
6233 	}
6234 
6235 	run_read(sc, RT2860_US_CYC_CNT, &tmp);
6236 	tmp = (tmp & ~0xff) | 0x1e;
6237 	run_write(sc, RT2860_US_CYC_CNT, tmp);
6238 
6239 	if (sc->mac_rev != 0x0101)
6240 		run_write(sc, RT2860_TXOP_CTRL_CFG, 0x0000583f);
6241 
6242 	run_write(sc, RT2860_WMM_TXOP0_CFG, 0);
6243 	run_write(sc, RT2860_WMM_TXOP1_CFG, 48 << 16 | 96);
6244 
6245 	/* write vendor-specific BBP values (from EEPROM) */
6246 	if (sc->mac_ver < 0x3593) {
6247 		for (i = 0; i < 10; i++) {
6248 			if (sc->bbp[i].reg == 0 || sc->bbp[i].reg == 0xff)
6249 				continue;
6250 			run_bbp_write(sc, sc->bbp[i].reg, sc->bbp[i].val);
6251 		}
6252 	}
6253 
6254 	/* select Main antenna for 1T1R devices */
6255 	if (sc->rf_rev == RT3070_RF_3020 || sc->rf_rev == RT5390_RF_5370)
6256 		run_set_rx_antenna(sc, 0);
6257 
6258 	/* send LEDs operating mode to microcontroller */
6259 	(void)run_mcu_cmd(sc, RT2860_MCU_CMD_LED1, sc->led[0]);
6260 	(void)run_mcu_cmd(sc, RT2860_MCU_CMD_LED2, sc->led[1]);
6261 	(void)run_mcu_cmd(sc, RT2860_MCU_CMD_LED3, sc->led[2]);
6262 
6263 	if (sc->mac_ver >= 0x5390)
6264 		run_rt5390_rf_init(sc);
6265 	else if (sc->mac_ver == 0x3593)
6266 		run_rt3593_rf_init(sc);
6267 	else if (sc->mac_ver >= 0x3070)
6268 		run_rt3070_rf_init(sc);
6269 
6270 	/* disable non-existing Rx chains */
6271 	run_bbp_read(sc, 3, &bbp3);
6272 	bbp3 &= ~(1 << 3 | 1 << 4);
6273 	if (sc->nrxchains == 2)
6274 		bbp3 |= 1 << 3;
6275 	else if (sc->nrxchains == 3)
6276 		bbp3 |= 1 << 4;
6277 	run_bbp_write(sc, 3, bbp3);
6278 
6279 	/* disable non-existing Tx chains */
6280 	run_bbp_read(sc, 1, &bbp1);
6281 	if (sc->ntxchains == 1)
6282 		bbp1 &= ~(1 << 3 | 1 << 4);
6283 	run_bbp_write(sc, 1, bbp1);
6284 
6285 	if (sc->mac_ver >= 0x5390)
6286 		run_rt5390_rf_setup(sc);
6287 	else if (sc->mac_ver == 0x3593)
6288 		run_rt3593_rf_setup(sc);
6289 	else if (sc->mac_ver >= 0x3070)
6290 		run_rt3070_rf_setup(sc);
6291 
6292 	/* select default channel */
6293 	run_set_chan(sc, ic->ic_curchan);
6294 
6295 	/* setup initial protection mode */
6296 	run_updateprot_cb(ic);
6297 
6298 	/* turn radio LED on */
6299 	run_set_leds(sc, RT2860_LED_RADIO);
6300 
6301 	/* Set up AUTO_RSP_CFG register for auto response */
6302 	run_write(sc, RT2860_AUTO_RSP_CFG, RT2860_AUTO_RSP_EN |
6303 	    RT2860_BAC_ACKPOLICY_EN | RT2860_CTS_40M_MODE_EN);
6304 
6305 	sc->sc_flags |= RUN_RUNNING;
6306 	sc->cmdq_run = RUN_CMDQ_GO;
6307 
6308 	for (i = 0; i != RUN_N_XFER; i++)
6309 		usbd_xfer_set_stall(sc->sc_xfer[i]);
6310 
6311 	usbd_transfer_start(sc->sc_xfer[RUN_BULK_RX]);
6312 
6313 	if (run_txrx_enable(sc) != 0)
6314 		goto fail;
6315 
6316 	return;
6317 
6318 fail:
6319 	run_stop(sc);
6320 }
6321 
6322 static void
6323 run_stop(void *arg)
6324 {
6325 	struct run_softc *sc = (struct run_softc *)arg;
6326 	uint32_t tmp;
6327 	int i;
6328 	int ntries;
6329 
6330 	RUN_LOCK_ASSERT(sc, MA_OWNED);
6331 
6332 	if (sc->sc_flags & RUN_RUNNING)
6333 		run_set_leds(sc, 0);	/* turn all LEDs off */
6334 
6335 	sc->sc_flags &= ~RUN_RUNNING;
6336 
6337 	sc->ratectl_run = RUN_RATECTL_OFF;
6338 	sc->cmdq_run = sc->cmdq_key_set;
6339 
6340 	RUN_UNLOCK(sc);
6341 
6342 	for(i = 0; i < RUN_N_XFER; i++)
6343 		usbd_transfer_drain(sc->sc_xfer[i]);
6344 
6345 	RUN_LOCK(sc);
6346 
6347 	run_drain_mbufq(sc);
6348 
6349 	if (sc->rx_m != NULL) {
6350 		m_free(sc->rx_m);
6351 		sc->rx_m = NULL;
6352 	}
6353 
6354 	/* Disable Tx/Rx DMA. */
6355 	if (run_read(sc, RT2860_WPDMA_GLO_CFG, &tmp) != 0)
6356 		return;
6357 	tmp &= ~(RT2860_RX_DMA_EN | RT2860_TX_DMA_EN);
6358 	run_write(sc, RT2860_WPDMA_GLO_CFG, tmp);
6359 
6360 	for (ntries = 0; ntries < 100; ntries++) {
6361 		if (run_read(sc, RT2860_WPDMA_GLO_CFG, &tmp) != 0)
6362 			return;
6363 		if ((tmp & (RT2860_TX_DMA_BUSY | RT2860_RX_DMA_BUSY)) == 0)
6364 				break;
6365 		run_delay(sc, 10);
6366 	}
6367 	if (ntries == 100) {
6368 		device_printf(sc->sc_dev, "timeout waiting for DMA engine\n");
6369 		return;
6370 	}
6371 
6372 	/* disable Tx/Rx */
6373 	run_read(sc, RT2860_MAC_SYS_CTRL, &tmp);
6374 	tmp &= ~(RT2860_MAC_RX_EN | RT2860_MAC_TX_EN);
6375 	run_write(sc, RT2860_MAC_SYS_CTRL, tmp);
6376 
6377 	/* wait for pending Tx to complete */
6378 	for (ntries = 0; ntries < 100; ntries++) {
6379 		if (run_read(sc, RT2860_TXRXQ_PCNT, &tmp) != 0) {
6380 			RUN_DPRINTF(sc, RUN_DEBUG_XMIT | RUN_DEBUG_RESET,
6381 			    "Cannot read Tx queue count\n");
6382 			break;
6383 		}
6384 		if ((tmp & RT2860_TX2Q_PCNT_MASK) == 0) {
6385 			RUN_DPRINTF(sc, RUN_DEBUG_XMIT | RUN_DEBUG_RESET,
6386 			    "All Tx cleared\n");
6387 			break;
6388 		}
6389 		run_delay(sc, 10);
6390 	}
6391 	if (ntries >= 100)
6392 		RUN_DPRINTF(sc, RUN_DEBUG_XMIT | RUN_DEBUG_RESET,
6393 		    "There are still pending Tx\n");
6394 	run_delay(sc, 10);
6395 	run_write(sc, RT2860_USB_DMA_CFG, 0);
6396 
6397 	run_write(sc, RT2860_MAC_SYS_CTRL, RT2860_BBP_HRST | RT2860_MAC_SRST);
6398 	run_write(sc, RT2860_MAC_SYS_CTRL, 0);
6399 
6400 	for (i = 0; i != RUN_EP_QUEUES; i++)
6401 		run_unsetup_tx_list(sc, &sc->sc_epq[i]);
6402 }
6403 
6404 static void
6405 run_delay(struct run_softc *sc, u_int ms)
6406 {
6407 	usb_pause_mtx(mtx_owned(&sc->sc_mtx) ?
6408 	    &sc->sc_mtx : NULL, USB_MS_TO_TICKS(ms));
6409 }
6410 
6411 static void
6412 run_update_chw(struct ieee80211com *ic)
6413 {
6414 
6415 	printf("%s: TODO\n", __func__);
6416 }
6417 
6418 static int
6419 run_ampdu_enable(struct ieee80211_node *ni, struct ieee80211_tx_ampdu *tap)
6420 {
6421 
6422 	/* For now, no A-MPDU TX support in the driver */
6423 	return (0);
6424 }
6425 
6426 static device_method_t run_methods[] = {
6427 	/* Device interface */
6428 	DEVMETHOD(device_probe,		run_match),
6429 	DEVMETHOD(device_attach,	run_attach),
6430 	DEVMETHOD(device_detach,	run_detach),
6431 	DEVMETHOD_END
6432 };
6433 
6434 static driver_t run_driver = {
6435 	.name = "run",
6436 	.methods = run_methods,
6437 	.size = sizeof(struct run_softc)
6438 };
6439 
6440 static devclass_t run_devclass;
6441 
6442 DRIVER_MODULE(run, uhub, run_driver, run_devclass, run_driver_loaded, NULL);
6443 MODULE_DEPEND(run, wlan, 1, 1, 1);
6444 MODULE_DEPEND(run, usb, 1, 1, 1);
6445 MODULE_DEPEND(run, firmware, 1, 1, 1);
6446 MODULE_VERSION(run, 1);
6447 USB_PNP_HOST_INFO(run_devs);
6448