1203134Sthompsa/*	$OpenBSD: rt2860reg.h,v 1.19 2009/05/18 19:25:07 damien Exp $	*/
2203134Sthompsa
3203134Sthompsa/*-
4203134Sthompsa * Copyright (c) 2007
5203134Sthompsa *	Damien Bergamini <damien.bergamini@free.fr>
6203134Sthompsa *
7203134Sthompsa * Permission to use, copy, modify, and distribute this software for any
8203134Sthompsa * purpose with or without fee is hereby granted, provided that the above
9203134Sthompsa * copyright notice and this permission notice appear in all copies.
10203134Sthompsa *
11203134Sthompsa * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
12203134Sthompsa * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
13203134Sthompsa * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
14203134Sthompsa * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15203134Sthompsa * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16203134Sthompsa * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17203134Sthompsa * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18203134Sthompsa *
19203134Sthompsa * $FreeBSD: stable/11/sys/dev/usb/wlan/if_runreg.h 343976 2019-02-10 21:00:02Z avos $
20203134Sthompsa */
21203134Sthompsa
22203134Sthompsa#ifndef _IF_RUNREG_H_
23203134Sthompsa#define	_IF_RUNREG_H_
24203134Sthompsa
25259546Skevlo#define	RT2860_CONFIG_NO		1
26259546Skevlo#define	RT2860_IFACE_INDEX		0
27203134Sthompsa
28259546Skevlo#define	RT3070_OPT_14			0x0114
29203134Sthompsa
30203134Sthompsa/* SCH/DMA registers */
31259546Skevlo#define	RT2860_INT_STATUS		0x0200
32259546Skevlo#define	RT2860_INT_MASK			0x0204
33259546Skevlo#define	RT2860_WPDMA_GLO_CFG		0x0208
34259546Skevlo#define	RT2860_WPDMA_RST_IDX		0x020c
35259546Skevlo#define	RT2860_DELAY_INT_CFG		0x0210
36259546Skevlo#define	RT2860_WMM_AIFSN_CFG		0x0214
37259546Skevlo#define	RT2860_WMM_CWMIN_CFG		0x0218
38259546Skevlo#define	RT2860_WMM_CWMAX_CFG		0x021c
39259546Skevlo#define	RT2860_WMM_TXOP0_CFG		0x0220
40259546Skevlo#define	RT2860_WMM_TXOP1_CFG		0x0224
41259546Skevlo#define	RT2860_GPIO_CTRL		0x0228
42259546Skevlo#define	RT2860_MCU_CMD_REG		0x022c
43259546Skevlo#define	RT2860_TX_BASE_PTR(qid)		(0x0230 + (qid) * 16)
44259546Skevlo#define	RT2860_TX_MAX_CNT(qid)		(0x0234 + (qid) * 16)
45259546Skevlo#define	RT2860_TX_CTX_IDX(qid)		(0x0238 + (qid) * 16)
46259546Skevlo#define	RT2860_TX_DTX_IDX(qid)		(0x023c + (qid) * 16)
47259546Skevlo#define	RT2860_RX_BASE_PTR		0x0290
48259546Skevlo#define	RT2860_RX_MAX_CNT		0x0294
49259546Skevlo#define	RT2860_RX_CALC_IDX		0x0298
50259546Skevlo#define	RT2860_FS_DRX_IDX		0x029c
51259546Skevlo#define	RT2860_USB_DMA_CFG		0x02a0	/* RT2870 only */
52259546Skevlo#define	RT2860_US_CYC_CNT		0x02a4
53203134Sthompsa
54203134Sthompsa/* PBF registers */
55259546Skevlo#define	RT2860_SYS_CTRL			0x0400
56259546Skevlo#define	RT2860_HOST_CMD			0x0404
57259546Skevlo#define	RT2860_PBF_CFG			0x0408
58259546Skevlo#define	RT2860_MAX_PCNT			0x040c
59259546Skevlo#define	RT2860_BUF_CTRL			0x0410
60259546Skevlo#define	RT2860_MCU_INT_STA		0x0414
61259546Skevlo#define	RT2860_MCU_INT_ENA		0x0418
62259546Skevlo#define	RT2860_TXQ_IO(qid)		(0x041c + (qid) * 4)
63259546Skevlo#define	RT2860_RX0Q_IO			0x0424
64259546Skevlo#define	RT2860_BCN_OFFSET0		0x042c
65259546Skevlo#define	RT2860_BCN_OFFSET1		0x0430
66259546Skevlo#define	RT2860_TXRXQ_STA		0x0434
67259546Skevlo#define	RT2860_TXRXQ_PCNT		0x0438
68259546Skevlo#define	RT2860_PBF_DBG			0x043c
69259546Skevlo#define	RT2860_CAP_CTRL			0x0440
70203134Sthompsa
71203134Sthompsa/* RT3070 registers */
72259546Skevlo#define	RT3070_RF_CSR_CFG		0x0500
73259546Skevlo#define	RT3070_EFUSE_CTRL		0x0580
74259546Skevlo#define	RT3070_EFUSE_DATA0		0x0590
75259546Skevlo#define	RT3070_EFUSE_DATA1		0x0594
76259546Skevlo#define	RT3070_EFUSE_DATA2		0x0598
77259546Skevlo#define	RT3070_EFUSE_DATA3		0x059c
78259546Skevlo#define	RT3070_LDO_CFG0			0x05d4
79259546Skevlo#define	RT3070_GPIO_SWITCH		0x05dc
80203134Sthompsa
81259032Skevlo/* RT5592 registers */
82259546Skevlo#define	RT5592_DEBUG_INDEX		0x05e8
83259032Skevlo
84203134Sthompsa/* MAC registers */
85259546Skevlo#define	RT2860_ASIC_VER_ID		0x1000
86259546Skevlo#define	RT2860_MAC_SYS_CTRL		0x1004
87259546Skevlo#define	RT2860_MAC_ADDR_DW0		0x1008
88259546Skevlo#define	RT2860_MAC_ADDR_DW1		0x100c
89259546Skevlo#define	RT2860_MAC_BSSID_DW0		0x1010
90259546Skevlo#define	RT2860_MAC_BSSID_DW1		0x1014
91259546Skevlo#define	RT2860_MAX_LEN_CFG		0x1018
92259546Skevlo#define	RT2860_BBP_CSR_CFG		0x101c
93259546Skevlo#define	RT2860_RF_CSR_CFG0		0x1020
94259546Skevlo#define	RT2860_RF_CSR_CFG1		0x1024
95259546Skevlo#define	RT2860_RF_CSR_CFG2		0x1028
96259546Skevlo#define	RT2860_LED_CFG			0x102c
97203134Sthompsa
98203134Sthompsa/* undocumented registers */
99259546Skevlo#define	RT2860_DEBUG			0x10f4
100203134Sthompsa
101203134Sthompsa/* MAC Timing control registers */
102259546Skevlo#define	RT2860_XIFS_TIME_CFG		0x1100
103259546Skevlo#define	RT2860_BKOFF_SLOT_CFG		0x1104
104259546Skevlo#define	RT2860_NAV_TIME_CFG		0x1108
105259546Skevlo#define	RT2860_CH_TIME_CFG		0x110c
106259546Skevlo#define	RT2860_PBF_LIFE_TIMER		0x1110
107259546Skevlo#define	RT2860_BCN_TIME_CFG		0x1114
108259546Skevlo#define	RT2860_TBTT_SYNC_CFG		0x1118
109259546Skevlo#define	RT2860_TSF_TIMER_DW0		0x111c
110259546Skevlo#define	RT2860_TSF_TIMER_DW1		0x1120
111259546Skevlo#define	RT2860_TBTT_TIMER		0x1124
112259546Skevlo#define	RT2860_INT_TIMER_CFG		0x1128
113259546Skevlo#define	RT2860_INT_TIMER_EN		0x112c
114259546Skevlo#define	RT2860_CH_IDLE_TIME		0x1130
115203134Sthompsa
116203134Sthompsa/* MAC Power Save configuration registers */
117259546Skevlo#define	RT2860_MAC_STATUS_REG		0x1200
118259546Skevlo#define	RT2860_PWR_PIN_CFG		0x1204
119259546Skevlo#define	RT2860_AUTO_WAKEUP_CFG		0x1208
120203134Sthompsa
121203134Sthompsa/* MAC TX configuration registers */
122259546Skevlo#define	RT2860_EDCA_AC_CFG(aci)		(0x1300 + (aci) * 4)
123259546Skevlo#define	RT2860_EDCA_TID_AC_MAP		0x1310
124259546Skevlo#define	RT2860_TX_PWR_CFG(ridx)		(0x1314 + (ridx) * 4)
125259546Skevlo#define	RT2860_TX_PIN_CFG		0x1328
126259546Skevlo#define	RT2860_TX_BAND_CFG		0x132c
127259546Skevlo#define	RT2860_TX_SW_CFG0		0x1330
128259546Skevlo#define	RT2860_TX_SW_CFG1		0x1334
129259546Skevlo#define	RT2860_TX_SW_CFG2		0x1338
130259546Skevlo#define	RT2860_TXOP_THRES_CFG		0x133c
131259546Skevlo#define	RT2860_TXOP_CTRL_CFG		0x1340
132259546Skevlo#define	RT2860_TX_RTS_CFG		0x1344
133259546Skevlo#define	RT2860_TX_TIMEOUT_CFG		0x1348
134259546Skevlo#define	RT2860_TX_RTY_CFG		0x134c
135259546Skevlo#define	RT2860_TX_LINK_CFG		0x1350
136259546Skevlo#define	RT2860_HT_FBK_CFG0		0x1354
137259546Skevlo#define	RT2860_HT_FBK_CFG1		0x1358
138259546Skevlo#define	RT2860_LG_FBK_CFG0		0x135c
139259546Skevlo#define	RT2860_LG_FBK_CFG1		0x1360
140259546Skevlo#define	RT2860_CCK_PROT_CFG		0x1364
141259546Skevlo#define	RT2860_OFDM_PROT_CFG		0x1368
142259546Skevlo#define	RT2860_MM20_PROT_CFG		0x136c
143259546Skevlo#define	RT2860_MM40_PROT_CFG		0x1370
144259546Skevlo#define	RT2860_GF20_PROT_CFG		0x1374
145259546Skevlo#define	RT2860_GF40_PROT_CFG		0x1378
146259546Skevlo#define	RT2860_EXP_CTS_TIME		0x137c
147259546Skevlo#define	RT2860_EXP_ACK_TIME		0x1380
148203134Sthompsa
149203134Sthompsa/* MAC RX configuration registers */
150259546Skevlo#define	RT2860_RX_FILTR_CFG		0x1400
151259546Skevlo#define	RT2860_AUTO_RSP_CFG		0x1404
152259546Skevlo#define	RT2860_LEGACY_BASIC_RATE	0x1408
153259546Skevlo#define	RT2860_HT_BASIC_RATE		0x140c
154259546Skevlo#define	RT2860_HT_CTRL_CFG		0x1410
155259546Skevlo#define	RT2860_SIFS_COST_CFG		0x1414
156259546Skevlo#define	RT2860_RX_PARSER_CFG		0x1418
157203134Sthompsa
158203134Sthompsa/* MAC Security configuration registers */
159259546Skevlo#define	RT2860_TX_SEC_CNT0		0x1500
160259546Skevlo#define	RT2860_RX_SEC_CNT0		0x1504
161259546Skevlo#define	RT2860_CCMP_FC_MUTE		0x1508
162203134Sthompsa
163203134Sthompsa/* MAC HCCA/PSMP configuration registers */
164259546Skevlo#define	RT2860_TXOP_HLDR_ADDR0		0x1600
165259546Skevlo#define	RT2860_TXOP_HLDR_ADDR1		0x1604
166259546Skevlo#define	RT2860_TXOP_HLDR_ET		0x1608
167259546Skevlo#define	RT2860_QOS_CFPOLL_RA_DW0	0x160c
168259546Skevlo#define	RT2860_QOS_CFPOLL_A1_DW1	0x1610
169259546Skevlo#define	RT2860_QOS_CFPOLL_QC		0x1614
170203134Sthompsa
171203134Sthompsa/* MAC Statistics Counters */
172259546Skevlo#define	RT2860_RX_STA_CNT0		0x1700
173259546Skevlo#define	RT2860_RX_STA_CNT1		0x1704
174259546Skevlo#define	RT2860_RX_STA_CNT2		0x1708
175259546Skevlo#define	RT2860_TX_STA_CNT0		0x170c
176259546Skevlo#define	RT2860_TX_STA_CNT1		0x1710
177259546Skevlo#define	RT2860_TX_STA_CNT2		0x1714
178259546Skevlo#define	RT2860_TX_STAT_FIFO		0x1718
179203134Sthompsa
180203134Sthompsa/* RX WCID search table */
181259546Skevlo#define	RT2860_WCID_ENTRY(wcid)		(0x1800 + (wcid) * 8)
182203134Sthompsa
183259546Skevlo#define	RT2860_FW_BASE			0x2000
184259546Skevlo#define	RT2870_FW_BASE			0x3000
185203134Sthompsa
186203134Sthompsa/* Pair-wise key table */
187259546Skevlo#define	RT2860_PKEY(wcid)		(0x4000 + (wcid) * 32)
188203134Sthompsa
189203134Sthompsa/* IV/EIV table */
190259546Skevlo#define	RT2860_IVEIV(wcid)		(0x6000 + (wcid) * 8)
191203134Sthompsa
192203134Sthompsa/* WCID attribute table */
193259546Skevlo#define	RT2860_WCID_ATTR(wcid)		(0x6800 + (wcid) * 4)
194203134Sthompsa
195203134Sthompsa/* Shared Key Table */
196259546Skevlo#define	RT2860_SKEY(vap, kidx)		(0x6c00 + (vap) * 128 + (kidx) * 32)
197203134Sthompsa
198203134Sthompsa/* Shared Key Mode */
199259546Skevlo#define	RT2860_SKEY_MODE_0_7		0x7000
200259546Skevlo#define	RT2860_SKEY_MODE_8_15		0x7004
201259546Skevlo#define	RT2860_SKEY_MODE_16_23		0x7008
202259546Skevlo#define	RT2860_SKEY_MODE_24_31		0x700c
203203134Sthompsa
204203134Sthompsa/* Shared Memory between MCU and host */
205259546Skevlo#define	RT2860_H2M_MAILBOX		0x7010
206259546Skevlo#define	RT2860_H2M_MAILBOX_CID		0x7014
207259546Skevlo#define	RT2860_H2M_MAILBOX_STATUS	0x701c
208259546Skevlo#define	RT2860_H2M_INTSRC		0x7024
209259546Skevlo#define	RT2860_H2M_BBPAGENT		0x7028
210259546Skevlo#define	RT2860_BCN_BASE(vap)		(0x7800 + (vap) * 512)
211203134Sthompsa
212203134Sthompsa
213203134Sthompsa/* possible flags for register RT2860_PCI_EECTRL */
214259546Skevlo#define	RT2860_C	(1 << 0)
215259546Skevlo#define	RT2860_S	(1 << 1)
216259546Skevlo#define	RT2860_D	(1 << 2)
217259546Skevlo#define	RT2860_SHIFT_D	2
218259546Skevlo#define	RT2860_Q	(1 << 3)
219259546Skevlo#define	RT2860_SHIFT_Q	3
220203134Sthompsa
221203134Sthompsa/* possible flags for registers INT_STATUS/INT_MASK */
222259546Skevlo#define	RT2860_TX_COHERENT	(1 << 17)
223259546Skevlo#define	RT2860_RX_COHERENT	(1 << 16)
224259546Skevlo#define	RT2860_MAC_INT_4	(1 << 15)
225259546Skevlo#define	RT2860_MAC_INT_3	(1 << 14)
226259546Skevlo#define	RT2860_MAC_INT_2	(1 << 13)
227259546Skevlo#define	RT2860_MAC_INT_1	(1 << 12)
228259546Skevlo#define	RT2860_MAC_INT_0	(1 << 11)
229259546Skevlo#define	RT2860_TX_RX_COHERENT	(1 << 10)
230259546Skevlo#define	RT2860_MCU_CMD_INT	(1 <<  9)
231259546Skevlo#define	RT2860_TX_DONE_INT5	(1 <<  8)
232259546Skevlo#define	RT2860_TX_DONE_INT4	(1 <<  7)
233259546Skevlo#define	RT2860_TX_DONE_INT3	(1 <<  6)
234259546Skevlo#define	RT2860_TX_DONE_INT2	(1 <<  5)
235259546Skevlo#define	RT2860_TX_DONE_INT1	(1 <<  4)
236259546Skevlo#define	RT2860_TX_DONE_INT0	(1 <<  3)
237259546Skevlo#define	RT2860_RX_DONE_INT	(1 <<  2)
238259546Skevlo#define	RT2860_TX_DLY_INT	(1 <<  1)
239259546Skevlo#define	RT2860_RX_DLY_INT	(1 <<  0)
240203134Sthompsa
241203134Sthompsa/* possible flags for register WPDMA_GLO_CFG */
242259546Skevlo#define	RT2860_HDR_SEG_LEN_SHIFT	8
243259546Skevlo#define	RT2860_BIG_ENDIAN		(1 << 7)
244259546Skevlo#define	RT2860_TX_WB_DDONE		(1 << 6)
245259546Skevlo#define	RT2860_WPDMA_BT_SIZE_SHIFT	4
246259546Skevlo#define	RT2860_WPDMA_BT_SIZE16		0
247259546Skevlo#define	RT2860_WPDMA_BT_SIZE32		1
248259546Skevlo#define	RT2860_WPDMA_BT_SIZE64		2
249259546Skevlo#define	RT2860_WPDMA_BT_SIZE128		3
250259546Skevlo#define	RT2860_RX_DMA_BUSY		(1 << 3)
251259546Skevlo#define	RT2860_RX_DMA_EN		(1 << 2)
252259546Skevlo#define	RT2860_TX_DMA_BUSY		(1 << 1)
253259546Skevlo#define	RT2860_TX_DMA_EN		(1 << 0)
254203134Sthompsa
255203134Sthompsa/* possible flags for register DELAY_INT_CFG */
256259546Skevlo#define	RT2860_TXDLY_INT_EN		(1U << 31)
257259546Skevlo#define	RT2860_TXMAX_PINT_SHIFT		24
258259546Skevlo#define	RT2860_TXMAX_PTIME_SHIFT	16
259259546Skevlo#define	RT2860_RXDLY_INT_EN		(1 << 15)
260259546Skevlo#define	RT2860_RXMAX_PINT_SHIFT		8
261259546Skevlo#define	RT2860_RXMAX_PTIME_SHIFT	0
262203134Sthompsa
263203134Sthompsa/* possible flags for register GPIO_CTRL */
264259546Skevlo#define	RT2860_GPIO_D_SHIFT	8
265259546Skevlo#define	RT2860_GPIO_O_SHIFT	0
266203134Sthompsa
267203134Sthompsa/* possible flags for register USB_DMA_CFG */
268259546Skevlo#define	RT2860_USB_TX_BUSY		(1U << 31)
269259546Skevlo#define	RT2860_USB_RX_BUSY		(1 << 30)
270259546Skevlo#define	RT2860_USB_EPOUT_VLD_SHIFT	24
271259546Skevlo#define	RT2860_USB_TX_EN		(1 << 23)
272259546Skevlo#define	RT2860_USB_RX_EN		(1 << 22)
273259546Skevlo#define	RT2860_USB_RX_AGG_EN		(1 << 21)
274259546Skevlo#define	RT2860_USB_TXOP_HALT		(1 << 20)
275259546Skevlo#define	RT2860_USB_TX_CLEAR		(1 << 19)
276259546Skevlo#define	RT2860_USB_PHY_WD_EN		(1 << 16)
277259546Skevlo#define	RT2860_USB_RX_AGG_LMT(x)	((x) << 8)	/* in unit of 1KB */
278259546Skevlo#define	RT2860_USB_RX_AGG_TO(x)		((x) & 0xff)	/* in unit of 33ns */
279203134Sthompsa
280203134Sthompsa/* possible flags for register US_CYC_CNT */
281259546Skevlo#define	RT2860_TEST_EN		(1 << 24)
282259546Skevlo#define	RT2860_TEST_SEL_SHIFT	16
283259546Skevlo#define	RT2860_BT_MODE_EN	(1 <<  8)
284259546Skevlo#define	RT2860_US_CYC_CNT_SHIFT	0
285203134Sthompsa
286203134Sthompsa/* possible flags for register SYS_CTRL */
287259546Skevlo#define	RT2860_HST_PM_SEL	(1 << 16)
288259546Skevlo#define	RT2860_CAP_MODE		(1 << 14)
289259546Skevlo#define	RT2860_PME_OEN		(1 << 13)
290259546Skevlo#define	RT2860_CLKSELECT	(1 << 12)
291259546Skevlo#define	RT2860_PBF_CLK_EN	(1 << 11)
292259546Skevlo#define	RT2860_MAC_CLK_EN	(1 << 10)
293259546Skevlo#define	RT2860_DMA_CLK_EN	(1 <<  9)
294259546Skevlo#define	RT2860_MCU_READY	(1 <<  7)
295259546Skevlo#define	RT2860_ASY_RESET	(1 <<  4)
296259546Skevlo#define	RT2860_PBF_RESET	(1 <<  3)
297259546Skevlo#define	RT2860_MAC_RESET	(1 <<  2)
298259546Skevlo#define	RT2860_DMA_RESET	(1 <<  1)
299259546Skevlo#define	RT2860_MCU_RESET	(1 <<  0)
300203134Sthompsa
301203134Sthompsa/* possible values for register HOST_CMD */
302259546Skevlo#define	RT2860_MCU_CMD_SLEEP	0x30
303259546Skevlo#define	RT2860_MCU_CMD_WAKEUP	0x31
304259546Skevlo#define	RT2860_MCU_CMD_LEDS	0x50
305259546Skevlo#define	RT2860_MCU_CMD_LED_RSSI	0x51
306259546Skevlo#define	RT2860_MCU_CMD_LED1	0x52
307259546Skevlo#define	RT2860_MCU_CMD_LED2	0x53
308259546Skevlo#define	RT2860_MCU_CMD_LED3	0x54
309259546Skevlo#define	RT2860_MCU_CMD_RFRESET	0x72
310259546Skevlo#define	RT2860_MCU_CMD_ANTSEL	0x73
311259546Skevlo#define	RT2860_MCU_CMD_BBP	0x80
312259546Skevlo#define	RT2860_MCU_CMD_PSLEVEL	0x83
313203134Sthompsa
314203134Sthompsa/* possible flags for register PBF_CFG */
315259546Skevlo#define	RT2860_TX1Q_NUM_SHIFT	21
316259546Skevlo#define	RT2860_TX2Q_NUM_SHIFT	16
317259546Skevlo#define	RT2860_NULL0_MODE	(1 << 15)
318259546Skevlo#define	RT2860_NULL1_MODE	(1 << 14)
319259546Skevlo#define	RT2860_RX_DROP_MODE	(1 << 13)
320259546Skevlo#define	RT2860_TX0Q_MANUAL	(1 << 12)
321259546Skevlo#define	RT2860_TX1Q_MANUAL	(1 << 11)
322259546Skevlo#define	RT2860_TX2Q_MANUAL	(1 << 10)
323259546Skevlo#define	RT2860_RX0Q_MANUAL	(1 <<  9)
324259546Skevlo#define	RT2860_HCCA_EN		(1 <<  8)
325259546Skevlo#define	RT2860_TX0Q_EN		(1 <<  4)
326259546Skevlo#define	RT2860_TX1Q_EN		(1 <<  3)
327259546Skevlo#define	RT2860_TX2Q_EN		(1 <<  2)
328259546Skevlo#define	RT2860_RX0Q_EN		(1 <<  1)
329203134Sthompsa
330203134Sthompsa/* possible flags for register BUF_CTRL */
331259546Skevlo#define	RT2860_WRITE_TXQ(qid)	(1 << (11 - (qid)))
332259546Skevlo#define	RT2860_NULL0_KICK	(1 << 7)
333259546Skevlo#define	RT2860_NULL1_KICK	(1 << 6)
334259546Skevlo#define	RT2860_BUF_RESET	(1 << 5)
335259546Skevlo#define	RT2860_READ_TXQ(qid)	(1 << (3 - (qid))
336259546Skevlo#define	RT2860_READ_RX0Q	(1 << 0)
337203134Sthompsa
338203134Sthompsa/* possible flags for registers MCU_INT_STA/MCU_INT_ENA */
339259546Skevlo#define	RT2860_MCU_MAC_INT_8	(1 << 24)
340259546Skevlo#define	RT2860_MCU_MAC_INT_7	(1 << 23)
341259546Skevlo#define	RT2860_MCU_MAC_INT_6	(1 << 22)
342259546Skevlo#define	RT2860_MCU_MAC_INT_4	(1 << 20)
343259546Skevlo#define	RT2860_MCU_MAC_INT_3	(1 << 19)
344259546Skevlo#define	RT2860_MCU_MAC_INT_2	(1 << 18)
345259546Skevlo#define	RT2860_MCU_MAC_INT_1	(1 << 17)
346259546Skevlo#define	RT2860_MCU_MAC_INT_0	(1 << 16)
347259546Skevlo#define	RT2860_DTX0_INT		(1 << 11)
348259546Skevlo#define	RT2860_DTX1_INT		(1 << 10)
349259546Skevlo#define	RT2860_DTX2_INT		(1 <<  9)
350259546Skevlo#define	RT2860_DRX0_INT		(1 <<  8)
351259546Skevlo#define	RT2860_HCMD_INT		(1 <<  7)
352259546Skevlo#define	RT2860_N0TX_INT		(1 <<  6)
353259546Skevlo#define	RT2860_N1TX_INT		(1 <<  5)
354259546Skevlo#define	RT2860_BCNTX_INT	(1 <<  4)
355259546Skevlo#define	RT2860_MTX0_INT		(1 <<  3)
356259546Skevlo#define	RT2860_MTX1_INT		(1 <<  2)
357259546Skevlo#define	RT2860_MTX2_INT		(1 <<  1)
358259546Skevlo#define	RT2860_MRX0_INT		(1 <<  0)
359203134Sthompsa
360203134Sthompsa/* possible flags for register TXRXQ_PCNT */
361259546Skevlo#define	RT2860_RX0Q_PCNT_MASK	0xff000000
362259546Skevlo#define	RT2860_TX2Q_PCNT_MASK	0x00ff0000
363259546Skevlo#define	RT2860_TX1Q_PCNT_MASK	0x0000ff00
364259546Skevlo#define	RT2860_TX0Q_PCNT_MASK	0x000000ff
365203134Sthompsa
366203134Sthompsa/* possible flags for register CAP_CTRL */
367259546Skevlo#define	RT2860_CAP_ADC_FEQ		(1U << 31)
368259546Skevlo#define	RT2860_CAP_START		(1 << 30)
369259546Skevlo#define	RT2860_MAN_TRIG			(1 << 29)
370259546Skevlo#define	RT2860_TRIG_OFFSET_SHIFT	16
371259546Skevlo#define	RT2860_START_ADDR_SHIFT		0
372203134Sthompsa
373203134Sthompsa/* possible flags for register RF_CSR_CFG */
374259546Skevlo#define	RT3070_RF_KICK		(1 << 17)
375259546Skevlo#define	RT3070_RF_WRITE		(1 << 16)
376203134Sthompsa
377203134Sthompsa/* possible flags for register EFUSE_CTRL */
378259546Skevlo#define	RT3070_SEL_EFUSE	(1U << 31)
379259546Skevlo#define	RT3070_EFSROM_KICK	(1 << 30)
380259546Skevlo#define	RT3070_EFSROM_AIN_MASK	0x03ff0000
381259546Skevlo#define	RT3070_EFSROM_AIN_SHIFT	16
382259546Skevlo#define	RT3070_EFSROM_MODE_MASK	0x000000c0
383259546Skevlo#define	RT3070_EFUSE_AOUT_MASK	0x0000003f
384203134Sthompsa
385259032Skevlo/* possible flag for register DEBUG_INDEX */
386259546Skevlo#define	RT5592_SEL_XTAL		(1U << 31)
387259032Skevlo
388203134Sthompsa/* possible flags for register MAC_SYS_CTRL */
389259546Skevlo#define	RT2860_RX_TS_EN		(1 << 7)
390259546Skevlo#define	RT2860_WLAN_HALT_EN	(1 << 6)
391259546Skevlo#define	RT2860_PBF_LOOP_EN	(1 << 5)
392259546Skevlo#define	RT2860_CONT_TX_TEST	(1 << 4)
393259546Skevlo#define	RT2860_MAC_RX_EN	(1 << 3)
394259546Skevlo#define	RT2860_MAC_TX_EN	(1 << 2)
395259546Skevlo#define	RT2860_BBP_HRST		(1 << 1)
396259546Skevlo#define	RT2860_MAC_SRST		(1 << 0)
397203134Sthompsa
398203134Sthompsa/* possible flags for register MAC_BSSID_DW1 */
399259546Skevlo#define	RT2860_MULTI_BCN_NUM_SHIFT	18
400259546Skevlo#define	RT2860_MULTI_BSSID_MODE_SHIFT	16
401203134Sthompsa
402203134Sthompsa/* possible flags for register MAX_LEN_CFG */
403259546Skevlo#define	RT2860_MIN_MPDU_LEN_SHIFT	16
404259546Skevlo#define	RT2860_MAX_PSDU_LEN_SHIFT	12
405259546Skevlo#define	RT2860_MAX_PSDU_LEN8K		0
406259546Skevlo#define	RT2860_MAX_PSDU_LEN16K		1
407259546Skevlo#define	RT2860_MAX_PSDU_LEN32K		2
408259546Skevlo#define	RT2860_MAX_PSDU_LEN64K		3
409259546Skevlo#define	RT2860_MAX_MPDU_LEN_SHIFT	0
410203134Sthompsa
411203134Sthompsa/* possible flags for registers BBP_CSR_CFG/H2M_BBPAGENT */
412259546Skevlo#define	RT2860_BBP_RW_PARALLEL		(1 << 19)
413259546Skevlo#define	RT2860_BBP_PAR_DUR_112_5	(1 << 18)
414259546Skevlo#define	RT2860_BBP_CSR_KICK		(1 << 17)
415259546Skevlo#define	RT2860_BBP_CSR_READ		(1 << 16)
416259546Skevlo#define	RT2860_BBP_ADDR_SHIFT		8
417259546Skevlo#define	RT2860_BBP_DATA_SHIFT		0
418203134Sthompsa
419203134Sthompsa/* possible flags for register RF_CSR_CFG0 */
420259546Skevlo#define	RT2860_RF_REG_CTRL		(1U << 31)
421259546Skevlo#define	RT2860_RF_LE_SEL1		(1 << 30)
422259546Skevlo#define	RT2860_RF_LE_STBY		(1 << 29)
423259546Skevlo#define	RT2860_RF_REG_WIDTH_SHIFT	24
424259546Skevlo#define	RT2860_RF_REG_0_SHIFT		0
425203134Sthompsa
426203134Sthompsa/* possible flags for register RF_CSR_CFG1 */
427259546Skevlo#define	RT2860_RF_DUR_5		(1 << 24)
428259546Skevlo#define	RT2860_RF_REG_1_SHIFT	0
429203134Sthompsa
430203134Sthompsa/* possible flags for register LED_CFG */
431259546Skevlo#define	RT2860_LED_POL			(1 << 30)
432259546Skevlo#define	RT2860_Y_LED_MODE_SHIFT		28
433259546Skevlo#define	RT2860_G_LED_MODE_SHIFT		26
434259546Skevlo#define	RT2860_R_LED_MODE_SHIFT		24
435259546Skevlo#define	RT2860_LED_MODE_OFF		0
436259546Skevlo#define	RT2860_LED_MODE_BLINK_TX	1
437259546Skevlo#define	RT2860_LED_MODE_SLOW_BLINK	2
438259546Skevlo#define	RT2860_LED_MODE_ON		3
439259546Skevlo#define	RT2860_SLOW_BLK_TIME_SHIFT	16
440259546Skevlo#define	RT2860_LED_OFF_TIME_SHIFT	8
441259546Skevlo#define	RT2860_LED_ON_TIME_SHIFT	0
442203134Sthompsa
443203134Sthompsa/* possible flags for register XIFS_TIME_CFG */
444259546Skevlo#define	RT2860_BB_RXEND_EN		(1 << 29)
445259546Skevlo#define	RT2860_EIFS_TIME_SHIFT		20
446259546Skevlo#define	RT2860_OFDM_XIFS_TIME_SHIFT	16
447259546Skevlo#define	RT2860_OFDM_SIFS_TIME_SHIFT	8
448259546Skevlo#define	RT2860_CCK_SIFS_TIME_SHIFT	0
449203134Sthompsa
450203134Sthompsa/* possible flags for register BKOFF_SLOT_CFG */
451259546Skevlo#define	RT2860_CC_DELAY_TIME_SHIFT	8
452259546Skevlo#define	RT2860_SLOT_TIME		0
453203134Sthompsa
454203134Sthompsa/* possible flags for register NAV_TIME_CFG */
455259546Skevlo#define	RT2860_NAV_UPD			(1U << 31)
456259546Skevlo#define	RT2860_NAV_UPD_VAL_SHIFT	16
457259546Skevlo#define	RT2860_NAV_CLR_EN		(1 << 15)
458259546Skevlo#define	RT2860_NAV_TIMER_SHIFT		0
459203134Sthompsa
460203134Sthompsa/* possible flags for register CH_TIME_CFG */
461259546Skevlo#define	RT2860_EIFS_AS_CH_BUSY	(1 << 4)
462259546Skevlo#define	RT2860_NAV_AS_CH_BUSY	(1 << 3)
463259546Skevlo#define	RT2860_RX_AS_CH_BUSY	(1 << 2)
464259546Skevlo#define	RT2860_TX_AS_CH_BUSY	(1 << 1)
465259546Skevlo#define	RT2860_CH_STA_TIMER_EN	(1 << 0)
466203134Sthompsa
467203134Sthompsa/* possible values for register BCN_TIME_CFG */
468259546Skevlo#define	RT2860_TSF_INS_COMP_SHIFT	24
469259546Skevlo#define	RT2860_BCN_TX_EN		(1 << 20)
470259546Skevlo#define	RT2860_TBTT_TIMER_EN		(1 << 19)
471259546Skevlo#define	RT2860_TSF_SYNC_MODE_SHIFT	17
472259546Skevlo#define	RT2860_TSF_SYNC_MODE_DIS	0
473259546Skevlo#define	RT2860_TSF_SYNC_MODE_STA	1
474259546Skevlo#define	RT2860_TSF_SYNC_MODE_IBSS	2
475259546Skevlo#define	RT2860_TSF_SYNC_MODE_HOSTAP	3
476259546Skevlo#define	RT2860_TSF_TIMER_EN		(1 << 16)
477259546Skevlo#define	RT2860_BCN_INTVAL_SHIFT		0
478203134Sthompsa
479203134Sthompsa/* possible flags for register TBTT_SYNC_CFG */
480259546Skevlo#define	RT2860_BCN_CWMIN_SHIFT		20
481259546Skevlo#define	RT2860_BCN_AIFSN_SHIFT		16
482259546Skevlo#define	RT2860_BCN_EXP_WIN_SHIFT	8
483259546Skevlo#define	RT2860_TBTT_ADJUST_SHIFT	0
484203134Sthompsa
485203134Sthompsa/* possible flags for register INT_TIMER_CFG */
486259546Skevlo#define	RT2860_GP_TIMER_SHIFT		16
487259546Skevlo#define	RT2860_PRE_TBTT_TIMER_SHIFT	0
488203134Sthompsa
489203134Sthompsa/* possible flags for register INT_TIMER_EN */
490259546Skevlo#define	RT2860_GP_TIMER_EN	(1 << 1)
491259546Skevlo#define	RT2860_PRE_TBTT_INT_EN	(1 << 0)
492203134Sthompsa
493203134Sthompsa/* possible flags for register MAC_STATUS_REG */
494259546Skevlo#define	RT2860_RX_STATUS_BUSY	(1 << 1)
495259546Skevlo#define	RT2860_TX_STATUS_BUSY	(1 << 0)
496203134Sthompsa
497203134Sthompsa/* possible flags for register PWR_PIN_CFG */
498259546Skevlo#define	RT2860_IO_ADDA_PD	(1 << 3)
499259546Skevlo#define	RT2860_IO_PLL_PD	(1 << 2)
500259546Skevlo#define	RT2860_IO_RA_PE		(1 << 1)
501259546Skevlo#define	RT2860_IO_RF_PE		(1 << 0)
502203134Sthompsa
503203134Sthompsa/* possible flags for register AUTO_WAKEUP_CFG */
504259546Skevlo#define	RT2860_AUTO_WAKEUP_EN		(1 << 15)
505259546Skevlo#define	RT2860_SLEEP_TBTT_NUM_SHIFT	8
506259546Skevlo#define	RT2860_WAKEUP_LEAD_TIME_SHIFT	0
507203134Sthompsa
508203134Sthompsa/* possible flags for register TX_PIN_CFG */
509259546Skevlo#define	RT2860_TRSW_POL		(1 << 19)
510259546Skevlo#define	RT2860_TRSW_EN		(1 << 18)
511259546Skevlo#define	RT2860_RFTR_POL		(1 << 17)
512259546Skevlo#define	RT2860_RFTR_EN		(1 << 16)
513259546Skevlo#define	RT2860_LNA_PE_G1_POL	(1 << 15)
514259546Skevlo#define	RT2860_LNA_PE_A1_POL	(1 << 14)
515259546Skevlo#define	RT2860_LNA_PE_G0_POL	(1 << 13)
516259546Skevlo#define	RT2860_LNA_PE_A0_POL	(1 << 12)
517259546Skevlo#define	RT2860_LNA_PE_G1_EN	(1 << 11)
518259546Skevlo#define	RT2860_LNA_PE_A1_EN	(1 << 10)
519259546Skevlo#define	RT2860_LNA_PE1_EN	(RT2860_LNA_PE_A1_EN | RT2860_LNA_PE_G1_EN)
520259546Skevlo#define	RT2860_LNA_PE_G0_EN	(1 <<  9)
521259546Skevlo#define	RT2860_LNA_PE_A0_EN	(1 <<  8)
522259546Skevlo#define	RT2860_LNA_PE0_EN	(RT2860_LNA_PE_A0_EN | RT2860_LNA_PE_G0_EN)
523259546Skevlo#define	RT2860_PA_PE_G1_POL	(1 <<  7)
524259546Skevlo#define	RT2860_PA_PE_A1_POL	(1 <<  6)
525259546Skevlo#define	RT2860_PA_PE_G0_POL	(1 <<  5)
526259546Skevlo#define	RT2860_PA_PE_A0_POL	(1 <<  4)
527259546Skevlo#define	RT2860_PA_PE_G1_EN	(1 <<  3)
528259546Skevlo#define	RT2860_PA_PE_A1_EN	(1 <<  2)
529259546Skevlo#define	RT2860_PA_PE_G0_EN	(1 <<  1)
530259546Skevlo#define	RT2860_PA_PE_A0_EN	(1 <<  0)
531203134Sthompsa
532203134Sthompsa/* possible flags for register TX_BAND_CFG */
533259546Skevlo#define	RT2860_5G_BAND_SEL_N	(1 << 2)
534259546Skevlo#define	RT2860_5G_BAND_SEL_P	(1 << 1)
535259546Skevlo#define	RT2860_TX_BAND_SEL	(1 << 0)
536203134Sthompsa
537203134Sthompsa/* possible flags for register TX_SW_CFG0 */
538259546Skevlo#define	RT2860_DLY_RFTR_EN_SHIFT	24
539259546Skevlo#define	RT2860_DLY_TRSW_EN_SHIFT	16
540259546Skevlo#define	RT2860_DLY_PAPE_EN_SHIFT	8
541259546Skevlo#define	RT2860_DLY_TXPE_EN_SHIFT	0
542203134Sthompsa
543203134Sthompsa/* possible flags for register TX_SW_CFG1 */
544259546Skevlo#define	RT2860_DLY_RFTR_DIS_SHIFT	16
545259546Skevlo#define	RT2860_DLY_TRSW_DIS_SHIFT	8
546259546Skevlo#define	RT2860_DLY_PAPE_DIS SHIFT	0
547203134Sthompsa
548203134Sthompsa/* possible flags for register TX_SW_CFG2 */
549259546Skevlo#define	RT2860_DLY_LNA_EN_SHIFT		24
550259546Skevlo#define	RT2860_DLY_LNA_DIS_SHIFT	16
551259546Skevlo#define	RT2860_DLY_DAC_EN_SHIFT		8
552259546Skevlo#define	RT2860_DLY_DAC_DIS_SHIFT	0
553203134Sthompsa
554203134Sthompsa/* possible flags for register TXOP_THRES_CFG */
555259546Skevlo#define	RT2860_TXOP_REM_THRES_SHIFT	24
556259546Skevlo#define	RT2860_CF_END_THRES_SHIFT	16
557259546Skevlo#define	RT2860_RDG_IN_THRES		8
558259546Skevlo#define	RT2860_RDG_OUT_THRES		0
559203134Sthompsa
560203134Sthompsa/* possible flags for register TXOP_CTRL_CFG */
561259546Skevlo#define	RT2860_EXT_CW_MIN_SHIFT		16
562259546Skevlo#define	RT2860_EXT_CCA_DLY_SHIFT	8
563259546Skevlo#define	RT2860_EXT_CCA_EN		(1 << 7)
564259546Skevlo#define	RT2860_LSIG_TXOP_EN		(1 << 6)
565259546Skevlo#define	RT2860_TXOP_TRUN_EN_MIMOPS	(1 << 4)
566259546Skevlo#define	RT2860_TXOP_TRUN_EN_TXOP	(1 << 3)
567259546Skevlo#define	RT2860_TXOP_TRUN_EN_RATE	(1 << 2)
568259546Skevlo#define	RT2860_TXOP_TRUN_EN_AC		(1 << 1)
569259546Skevlo#define	RT2860_TXOP_TRUN_EN_TIMEOUT	(1 << 0)
570203134Sthompsa
571203134Sthompsa/* possible flags for register TX_RTS_CFG */
572259546Skevlo#define	RT2860_RTS_FBK_EN		(1 << 24)
573259546Skevlo#define	RT2860_RTS_THRES_SHIFT		8
574259546Skevlo#define	RT2860_RTS_RTY_LIMIT_SHIFT	0
575203134Sthompsa
576203134Sthompsa/* possible flags for register TX_TIMEOUT_CFG */
577259546Skevlo#define	RT2860_TXOP_TIMEOUT_SHIFT	16
578259546Skevlo#define	RT2860_RX_ACK_TIMEOUT_SHIFT	8
579259546Skevlo#define	RT2860_MPDU_LIFE_TIME_SHIFT	4
580203134Sthompsa
581203134Sthompsa/* possible flags for register TX_RTY_CFG */
582259546Skevlo#define	RT2860_TX_AUTOFB_EN		(1 << 30)
583259546Skevlo#define	RT2860_AGG_RTY_MODE_TIMER	(1 << 29)
584259546Skevlo#define	RT2860_NAG_RTY_MODE_TIMER	(1 << 28)
585259546Skevlo#define	RT2860_LONG_RTY_THRES_SHIFT	16
586259546Skevlo#define	RT2860_LONG_RTY_LIMIT_SHIFT	8
587259546Skevlo#define	RT2860_SHORT_RTY_LIMIT_SHIFT	0
588203134Sthompsa
589203134Sthompsa/* possible flags for register TX_LINK_CFG */
590259546Skevlo#define	RT2860_REMOTE_MFS_SHIFT		24
591259546Skevlo#define	RT2860_REMOTE_MFB_SHIFT		16
592259546Skevlo#define	RT2860_TX_CFACK_EN		(1 << 12)
593259546Skevlo#define	RT2860_TX_RDG_EN		(1 << 11)
594259546Skevlo#define	RT2860_TX_MRQ_EN		(1 << 10)
595259546Skevlo#define	RT2860_REMOTE_UMFS_EN		(1 <<  9)
596259546Skevlo#define	RT2860_TX_MFB_EN		(1 <<  8)
597259546Skevlo#define	RT2860_REMOTE_MFB_LT_SHIFT	0
598203134Sthompsa
599203134Sthompsa/* possible flags for registers *_PROT_CFG */
600259546Skevlo#define	RT2860_RTSTH_EN			(1 << 26)
601259546Skevlo#define	RT2860_TXOP_ALLOW_GF40		(1 << 25)
602259546Skevlo#define	RT2860_TXOP_ALLOW_GF20		(1 << 24)
603259546Skevlo#define	RT2860_TXOP_ALLOW_MM40		(1 << 23)
604259546Skevlo#define	RT2860_TXOP_ALLOW_MM20		(1 << 22)
605259546Skevlo#define	RT2860_TXOP_ALLOW_OFDM		(1 << 21)
606259546Skevlo#define	RT2860_TXOP_ALLOW_CCK		(1 << 20)
607259546Skevlo#define	RT2860_TXOP_ALLOW_ALL		(0x3f << 20)
608259546Skevlo#define	RT2860_PROT_NAV_SHORT		(1 << 18)
609259546Skevlo#define	RT2860_PROT_NAV_LONG		(2 << 18)
610259546Skevlo#define	RT2860_PROT_CTRL_RTS_CTS	(1 << 16)
611259546Skevlo#define	RT2860_PROT_CTRL_CTS		(2 << 16)
612203134Sthompsa
613203134Sthompsa/* possible flags for registers EXP_{CTS,ACK}_TIME */
614259546Skevlo#define	RT2860_EXP_OFDM_TIME_SHIFT	16
615259546Skevlo#define	RT2860_EXP_CCK_TIME_SHIFT	0
616203134Sthompsa
617203134Sthompsa/* possible flags for register RX_FILTR_CFG */
618259546Skevlo#define	RT2860_DROP_CTRL_RSV	(1 << 16)
619259546Skevlo#define	RT2860_DROP_BAR		(1 << 15)
620259546Skevlo#define	RT2860_DROP_BA		(1 << 14)
621259546Skevlo#define	RT2860_DROP_PSPOLL	(1 << 13)
622259546Skevlo#define	RT2860_DROP_RTS		(1 << 12)
623259546Skevlo#define	RT2860_DROP_CTS		(1 << 11)
624259546Skevlo#define	RT2860_DROP_ACK		(1 << 10)
625259546Skevlo#define	RT2860_DROP_CFEND	(1 <<  9)
626259546Skevlo#define	RT2860_DROP_CFACK	(1 <<  8)
627259546Skevlo#define	RT2860_DROP_DUPL	(1 <<  7)
628259546Skevlo#define	RT2860_DROP_BC		(1 <<  6)
629259546Skevlo#define	RT2860_DROP_MC		(1 <<  5)
630259546Skevlo#define	RT2860_DROP_VER_ERR	(1 <<  4)
631259546Skevlo#define	RT2860_DROP_NOT_MYBSS	(1 <<  3)
632259546Skevlo#define	RT2860_DROP_UC_NOME	(1 <<  2)
633259546Skevlo#define	RT2860_DROP_PHY_ERR	(1 <<  1)
634259546Skevlo#define	RT2860_DROP_CRC_ERR	(1 <<  0)
635203134Sthompsa
636203134Sthompsa/* possible flags for register AUTO_RSP_CFG */
637259546Skevlo#define	RT2860_CTRL_PWR_BIT	(1 << 7)
638259546Skevlo#define	RT2860_BAC_ACK_POLICY	(1 << 6)
639259546Skevlo#define	RT2860_CCK_SHORT_EN	(1 << 4)
640259546Skevlo#define	RT2860_CTS_40M_REF_EN	(1 << 3)
641259546Skevlo#define	RT2860_CTS_40M_MODE_EN	(1 << 2)
642259546Skevlo#define	RT2860_BAC_ACKPOLICY_EN	(1 << 1)
643259546Skevlo#define	RT2860_AUTO_RSP_EN	(1 << 0)
644203134Sthompsa
645203134Sthompsa/* possible flags for register SIFS_COST_CFG */
646259546Skevlo#define	RT2860_OFDM_SIFS_COST_SHIFT	8
647259546Skevlo#define	RT2860_CCK_SIFS_COST_SHIFT	0
648203134Sthompsa
649203134Sthompsa/* possible flags for register TXOP_HLDR_ET */
650259546Skevlo#define	RT2860_TXOP_ETM1_EN		(1 << 25)
651259546Skevlo#define	RT2860_TXOP_ETM0_EN		(1 << 24)
652259546Skevlo#define	RT2860_TXOP_ETM_THRES_SHIFT	16
653259546Skevlo#define	RT2860_TXOP_ETO_EN		(1 <<  8)
654259546Skevlo#define	RT2860_TXOP_ETO_THRES_SHIFT	1
655259546Skevlo#define	RT2860_PER_RX_RST_EN		(1 <<  0)
656203134Sthompsa
657203134Sthompsa/* possible flags for register TX_STAT_FIFO */
658259546Skevlo#define	RT2860_TXQ_MCS_SHIFT	16
659259546Skevlo#define	RT2860_TXQ_WCID_SHIFT	8
660259546Skevlo#define	RT2860_TXQ_ACKREQ	(1 << 7)
661259546Skevlo#define	RT2860_TXQ_AGG		(1 << 6)
662259546Skevlo#define	RT2860_TXQ_OK		(1 << 5)
663259546Skevlo#define	RT2860_TXQ_PID_SHIFT	1
664259546Skevlo#define	RT2860_TXQ_VLD		(1 << 0)
665203134Sthompsa
666203134Sthompsa/* possible flags for register WCID_ATTR */
667259546Skevlo#define	RT2860_MODE_NOSEC	0
668259546Skevlo#define	RT2860_MODE_WEP40	1
669259546Skevlo#define	RT2860_MODE_WEP104	2
670259546Skevlo#define	RT2860_MODE_TKIP	3
671259546Skevlo#define	RT2860_MODE_AES_CCMP	4
672259546Skevlo#define	RT2860_MODE_CKIP40	5
673259546Skevlo#define	RT2860_MODE_CKIP104	6
674259546Skevlo#define	RT2860_MODE_CKIP128	7
675259546Skevlo#define	RT2860_RX_PKEY_EN	(1 << 0)
676203134Sthompsa
677203134Sthompsa/* possible flags for register H2M_MAILBOX */
678259546Skevlo#define	RT2860_H2M_BUSY		(1 << 24)
679259546Skevlo#define	RT2860_TOKEN_NO_INTR	0xff
680203134Sthompsa
681203134Sthompsa/* possible flags for MCU command RT2860_MCU_CMD_LEDS */
682259546Skevlo#define	RT2860_LED_RADIO	(1 << 13)
683259546Skevlo#define	RT2860_LED_LINK_2GHZ	(1 << 14)
684259546Skevlo#define	RT2860_LED_LINK_5GHZ	(1 << 15)
685203134Sthompsa
686203134Sthompsa/* possible flags for RT3020 RF register 1 */
687259546Skevlo#define	RT3070_RF_BLOCK	(1 << 0)
688259546Skevlo#define	RT3070_PLL_PD	(1 << 1)
689259546Skevlo#define	RT3070_RX0_PD	(1 << 2)
690259546Skevlo#define	RT3070_TX0_PD	(1 << 3)
691259546Skevlo#define	RT3070_RX1_PD	(1 << 4)
692259546Skevlo#define	RT3070_TX1_PD	(1 << 5)
693260219Skevlo#define	RT3070_RX2_PD	(1 << 6)
694260219Skevlo#define	RT3070_TX2_PD	(1 << 7)
695203134Sthompsa
696203134Sthompsa/* possible flags for RT3020 RF register 15 */
697259546Skevlo#define	RT3070_TX_LO2	(1 << 3)
698203134Sthompsa
699203134Sthompsa/* possible flags for RT3020 RF register 17 */
700259546Skevlo#define	RT3070_TX_LO1	(1 << 3)
701203134Sthompsa
702203134Sthompsa/* possible flags for RT3020 RF register 20 */
703259546Skevlo#define	RT3070_RX_LO1	(1 << 3)
704203134Sthompsa
705203134Sthompsa/* possible flags for RT3020 RF register 21 */
706259546Skevlo#define	RT3070_RX_LO2	(1 << 3)
707203134Sthompsa
708260219Skevlo/* possible flags for RT3053 RF register 18 */
709260219Skevlo#define	RT3593_AUTOTUNE_BYPASS	(1 << 6)
710260219Skevlo
711260219Skevlo/* possible flags for RT3053 RF register 50 */
712260219Skevlo#define	RT3593_TX_LO2	(1 << 4)
713260219Skevlo
714260219Skevlo/* possible flags for RT3053 RF register 51 */
715260219Skevlo#define	RT3593_TX_LO1	(1 << 4)
716260219Skevlo
717259031Skevlo/* Possible flags for RT5390 RF register 2. */
718259031Skevlo#define	RT5390_RESCAL	(1 << 7)
719259031Skevlo
720257955Skevlo/* Possible flags for RT5390 RF register 3. */
721257955Skevlo#define	RT5390_VCOCAL	(1 << 7)
722203134Sthompsa
723257955Skevlo/* Possible flags for RT5390 RF register 38. */
724257955Skevlo#define	RT5390_RX_LO1	(1 << 5)
725257955Skevlo
726257955Skevlo/* Possible flags for RT5390 RF register 39. */
727257955Skevlo#define	RT5390_RX_LO2	(1 << 7)
728257955Skevlo
729259031Skevlo/* Possible flags for RT5390 BBP register 4. */
730259031Skevlo#define	RT5390_MAC_IF_CTRL	(1 << 6)
731259031Skevlo
732259031Skevlo/* Possible flags for RT5390 BBP register 105. */
733259031Skevlo#define	RT5390_MLD			(1 << 2)
734259031Skevlo#define	RT5390_EN_SIG_MODULATION	(1 << 3)
735259031Skevlo
736203134Sthompsa/* RT2860 TX descriptor */
737203134Sthompsastruct rt2860_txd {
738203134Sthompsa	uint32_t	sdp0;		/* Segment Data Pointer 0 */
739203134Sthompsa	uint16_t	sdl1;		/* Segment Data Length 1 */
740259546Skevlo#define	RT2860_TX_BURST	(1 << 15)
741259546Skevlo#define	RT2860_TX_LS1	(1 << 14)	/* SDP1 is the last segment */
742203134Sthompsa
743203134Sthompsa	uint16_t	sdl0;		/* Segment Data Length 0 */
744259546Skevlo#define	RT2860_TX_DDONE	(1 << 15)
745259546Skevlo#define	RT2860_TX_LS0	(1 << 14)	/* SDP0 is the last segment */
746203134Sthompsa
747203134Sthompsa	uint32_t	sdp1;		/* Segment Data Pointer 1 */
748203134Sthompsa	uint8_t		reserved[3];
749203134Sthompsa	uint8_t		flags;
750259546Skevlo#define	RT2860_TX_QSEL_SHIFT	1
751259546Skevlo#define	RT2860_TX_QSEL_MGMT	(0 << 1)
752259546Skevlo#define	RT2860_TX_QSEL_HCCA	(1 << 1)
753259546Skevlo#define	RT2860_TX_QSEL_EDCA	(2 << 1)
754259546Skevlo#define	RT2860_TX_WIV		(1 << 0)
755203134Sthompsa} __packed;
756203134Sthompsa
757203134Sthompsa/* RT2870 TX descriptor */
758203134Sthompsastruct rt2870_txd {
759203134Sthompsa	uint16_t	len;
760203134Sthompsa	uint8_t		pad;
761203134Sthompsa	uint8_t		flags;
762203134Sthompsa} __packed;
763203134Sthompsa
764203134Sthompsa/* TX Wireless Information */
765203134Sthompsastruct rt2860_txwi {
766203134Sthompsa	uint8_t		flags;
767259546Skevlo#define	RT2860_TX_MPDU_DSITY_SHIFT	5
768259546Skevlo#define	RT2860_TX_AMPDU			(1 << 4)
769259546Skevlo#define	RT2860_TX_TS			(1 << 3)
770259546Skevlo#define	RT2860_TX_CFACK			(1 << 2)
771259546Skevlo#define	RT2860_TX_MMPS			(1 << 1)
772259546Skevlo#define	RT2860_TX_FRAG			(1 << 0)
773203134Sthompsa
774203134Sthompsa	uint8_t		txop;
775259546Skevlo#define	RT2860_TX_TXOP_HT	0
776259546Skevlo#define	RT2860_TX_TXOP_PIFS	1
777259546Skevlo#define	RT2860_TX_TXOP_SIFS	2
778259546Skevlo#define	RT2860_TX_TXOP_BACKOFF	3
779203134Sthompsa
780203134Sthompsa	uint16_t	phy;
781259546Skevlo#define	RT2860_PHY_MODE		0xc000
782259546Skevlo#define	RT2860_PHY_CCK		(0 << 14)
783259546Skevlo#define	RT2860_PHY_OFDM		(1 << 14)
784259546Skevlo#define	RT2860_PHY_HT		(2 << 14)
785259546Skevlo#define	RT2860_PHY_HT_GF	(3 << 14)
786259546Skevlo#define	RT2860_PHY_SGI		(1 << 8)
787259546Skevlo#define	RT2860_PHY_BW40		(1 << 7)
788259546Skevlo#define	RT2860_PHY_MCS		0x7f
789259546Skevlo#define	RT2860_PHY_SHPRE	(1 << 3)
790203134Sthompsa
791203134Sthompsa	uint8_t		xflags;
792259546Skevlo#define	RT2860_TX_BAWINSIZE_SHIFT	2
793259546Skevlo#define	RT2860_TX_NSEQ			(1 << 1)
794259546Skevlo#define	RT2860_TX_ACK			(1 << 0)
795203134Sthompsa
796203134Sthompsa	uint8_t		wcid;	/* Wireless Client ID */
797203134Sthompsa	uint16_t	len;
798259546Skevlo#define	RT2860_TX_PID_SHIFT	12
799203134Sthompsa
800203134Sthompsa	uint32_t	iv;
801203134Sthompsa	uint32_t	eiv;
802203134Sthompsa} __packed;
803203134Sthompsa
804203134Sthompsa/* RT2860 RX descriptor */
805203134Sthompsastruct rt2860_rxd {
806203134Sthompsa	uint32_t	sdp0;
807203134Sthompsa	uint16_t	sdl1;	/* unused */
808203134Sthompsa	uint16_t	sdl0;
809259546Skevlo#define	RT2860_RX_DDONE	(1 << 15)
810259546Skevlo#define	RT2860_RX_LS0	(1 << 14)
811203134Sthompsa
812203134Sthompsa	uint32_t	sdp1;	/* unused */
813203134Sthompsa	uint32_t	flags;
814259546Skevlo#define	RT2860_RX_DEC		(1 << 16)
815259546Skevlo#define	RT2860_RX_AMPDU		(1 << 15)
816259546Skevlo#define	RT2860_RX_L2PAD		(1 << 14)
817259546Skevlo#define	RT2860_RX_RSSI		(1 << 13)
818259546Skevlo#define	RT2860_RX_HTC		(1 << 12)
819259546Skevlo#define	RT2860_RX_AMSDU		(1 << 11)
820259546Skevlo#define	RT2860_RX_MICERR	(1 << 10)
821259546Skevlo#define	RT2860_RX_ICVERR	(1 <<  9)
822259546Skevlo#define	RT2860_RX_CRCERR	(1 <<  8)
823259546Skevlo#define	RT2860_RX_MYBSS		(1 <<  7)
824259546Skevlo#define	RT2860_RX_BC		(1 <<  6)
825259546Skevlo#define	RT2860_RX_MC		(1 <<  5)
826259546Skevlo#define	RT2860_RX_UC2ME		(1 <<  4)
827259546Skevlo#define	RT2860_RX_FRAG		(1 <<  3)
828259546Skevlo#define	RT2860_RX_NULL		(1 <<  2)
829259546Skevlo#define	RT2860_RX_DATA		(1 <<  1)
830259546Skevlo#define	RT2860_RX_BA		(1 <<  0)
831203134Sthompsa} __packed;
832203134Sthompsa
833203134Sthompsa/* RT2870 RX descriptor */
834203134Sthompsastruct rt2870_rxd {
835203134Sthompsa	/* single 32-bit field */
836203134Sthompsa	uint32_t	flags;
837203134Sthompsa} __packed;
838203134Sthompsa
839203134Sthompsa/* RX Wireless Information */
840203134Sthompsastruct rt2860_rxwi {
841203134Sthompsa	uint8_t		wcid;
842203134Sthompsa	uint8_t		keyidx;
843259546Skevlo#define	RT2860_RX_UDF_SHIFT	5
844259546Skevlo#define	RT2860_RX_BSS_IDX_SHIFT	2
845203134Sthompsa
846203134Sthompsa	uint16_t	len;
847259546Skevlo#define	RT2860_RX_TID_SHIFT	12
848203134Sthompsa
849203134Sthompsa	uint16_t	seq;
850203134Sthompsa	uint16_t	phy;
851203134Sthompsa	uint8_t		rssi[3];
852203134Sthompsa	uint8_t		reserved1;
853203134Sthompsa	uint8_t		snr[2];
854203134Sthompsa	uint16_t	reserved2;
855203134Sthompsa} __packed;
856203134Sthompsa
857259546Skevlo#define	RT2860_RF_2820	0x0001	/* 2T3R */
858259546Skevlo#define	RT2860_RF_2850	0x0002	/* dual-band 2T3R */
859259546Skevlo#define	RT2860_RF_2720	0x0003	/* 1T2R */
860259546Skevlo#define	RT2860_RF_2750	0x0004	/* dual-band 1T2R */
861259546Skevlo#define	RT3070_RF_3020	0x0005	/* 1T1R */
862259546Skevlo#define	RT3070_RF_2020	0x0006	/* b/g */
863259546Skevlo#define	RT3070_RF_3021	0x0007	/* 1T2R */
864259546Skevlo#define	RT3070_RF_3022	0x0008	/* 2T2R */
865259546Skevlo#define	RT3070_RF_3052	0x0009	/* dual-band 2T2R */
866260219Skevlo#define	RT3593_RF_3053	0x000d	/* dual-band 3T3R */
867259546Skevlo#define	RT5592_RF_5592	0x000f	/* dual-band 2T2R */
868259546Skevlo#define	RT5390_RF_5370	0x5370	/* 1T1R */
869259546Skevlo#define	RT5390_RF_5372	0x5372	/* 2T2R */
870203134Sthompsa
871203134Sthompsa/* USB commands for RT2870 only */
872259546Skevlo#define	RT2870_RESET		1
873259546Skevlo#define	RT2870_WRITE_2		2
874259546Skevlo#define	RT2870_WRITE_REGION_1	6
875259546Skevlo#define	RT2870_READ_REGION_1	7
876259546Skevlo#define	RT2870_EEPROM_READ	9
877203134Sthompsa
878259546Skevlo#define	RT2860_EEPROM_DELAY	1	/* minimum hold time (microsecond) */
879203134Sthompsa
880259546Skevlo#define	RT2860_EEPROM_VERSION		0x01
881259546Skevlo#define	RT2860_EEPROM_MAC01		0x02
882259546Skevlo#define	RT2860_EEPROM_MAC23		0x03
883259546Skevlo#define	RT2860_EEPROM_MAC45		0x04
884259546Skevlo#define	RT2860_EEPROM_PCIE_PSLEVEL	0x11
885259546Skevlo#define	RT2860_EEPROM_REV		0x12
886259546Skevlo#define	RT2860_EEPROM_ANTENNA		0x1a
887259546Skevlo#define	RT2860_EEPROM_CONFIG		0x1b
888259546Skevlo#define	RT2860_EEPROM_COUNTRY		0x1c
889259546Skevlo#define	RT2860_EEPROM_FREQ_LEDS		0x1d
890259546Skevlo#define	RT2860_EEPROM_LED1		0x1e
891259546Skevlo#define	RT2860_EEPROM_LED2		0x1f
892259546Skevlo#define	RT2860_EEPROM_LED3		0x20
893259546Skevlo#define	RT2860_EEPROM_LNA		0x22
894259546Skevlo#define	RT2860_EEPROM_RSSI1_2GHZ	0x23
895259546Skevlo#define	RT2860_EEPROM_RSSI2_2GHZ	0x24
896259546Skevlo#define	RT2860_EEPROM_RSSI1_5GHZ	0x25
897259546Skevlo#define	RT2860_EEPROM_RSSI2_5GHZ	0x26
898259546Skevlo#define	RT2860_EEPROM_DELTAPWR		0x28
899259546Skevlo#define	RT2860_EEPROM_PWR2GHZ_BASE1	0x29
900259546Skevlo#define	RT2860_EEPROM_PWR2GHZ_BASE2	0x30
901259546Skevlo#define	RT2860_EEPROM_TSSI1_2GHZ	0x37
902259546Skevlo#define	RT2860_EEPROM_TSSI2_2GHZ	0x38
903259546Skevlo#define	RT2860_EEPROM_TSSI3_2GHZ	0x39
904259546Skevlo#define	RT2860_EEPROM_TSSI4_2GHZ	0x3a
905259546Skevlo#define	RT2860_EEPROM_TSSI5_2GHZ	0x3b
906259546Skevlo#define	RT2860_EEPROM_PWR5GHZ_BASE1	0x3c
907259546Skevlo#define	RT2860_EEPROM_PWR5GHZ_BASE2	0x53
908259546Skevlo#define	RT2860_EEPROM_TSSI1_5GHZ	0x6a
909259546Skevlo#define	RT2860_EEPROM_TSSI2_5GHZ	0x6b
910259546Skevlo#define	RT2860_EEPROM_TSSI3_5GHZ	0x6c
911259546Skevlo#define	RT2860_EEPROM_TSSI4_5GHZ	0x6d
912259546Skevlo#define	RT2860_EEPROM_TSSI5_5GHZ	0x6e
913259546Skevlo#define	RT2860_EEPROM_RPWR		0x6f
914259546Skevlo#define	RT2860_EEPROM_BBP_BASE		0x78
915259546Skevlo#define	RT3071_EEPROM_RF_BASE		0x82
916203134Sthompsa
917260219Skevlo/* EEPROM registers for RT3593. */
918260219Skevlo#define	RT3593_EEPROM_FREQ_LEDS		0x21
919260219Skevlo#define	RT3593_EEPROM_FREQ		0x22
920260219Skevlo#define	RT3593_EEPROM_LED1		0x22
921260219Skevlo#define	RT3593_EEPROM_LED2		0x23
922260219Skevlo#define	RT3593_EEPROM_LED3		0x24
923260219Skevlo#define	RT3593_EEPROM_LNA		0x26
924260219Skevlo#define	RT3593_EEPROM_LNA_5GHZ		0x27
925260219Skevlo#define	RT3593_EEPROM_RSSI1_2GHZ	0x28
926260219Skevlo#define	RT3593_EEPROM_RSSI2_2GHZ	0x29
927260219Skevlo#define	RT3593_EEPROM_RSSI1_5GHZ	0x2a
928260219Skevlo#define	RT3593_EEPROM_RSSI2_5GHZ	0x2b
929260219Skevlo#define	RT3593_EEPROM_PWR2GHZ_BASE1	0x30
930260219Skevlo#define	RT3593_EEPROM_PWR2GHZ_BASE2	0x37
931260219Skevlo#define	RT3593_EEPROM_PWR2GHZ_BASE3	0x3e
932260219Skevlo#define	RT3593_EEPROM_PWR5GHZ_BASE1	0x4b
933260219Skevlo#define	RT3593_EEPROM_PWR5GHZ_BASE2	0x65
934260219Skevlo#define	RT3593_EEPROM_PWR5GHZ_BASE3	0x7f
935260219Skevlo
936259544Skevlo/*
937259544Skevlo * EEPROM IQ calibration.
938259544Skevlo */
939259544Skevlo#define	RT5390_EEPROM_IQ_GAIN_CAL_TX0_2GHZ			0x130
940259544Skevlo#define	RT5390_EEPROM_IQ_PHASE_CAL_TX0_2GHZ			0x131
941259544Skevlo#define	RT5390_EEPROM_IQ_GAIN_CAL_TX1_2GHZ			0x133
942259544Skevlo#define	RT5390_EEPROM_IQ_PHASE_CAL_TX1_2GHZ			0x134
943259544Skevlo#define	RT5390_EEPROM_RF_IQ_COMPENSATION_CTL			0x13c
944259544Skevlo#define	RT5390_EEPROM_RF_IQ_IMBALANCE_COMPENSATION_CTL		0x13d
945259546Skevlo#define	RT5390_EEPROM_IQ_GAIN_CAL_TX0_CH36_TO_CH64_5GHZ		0x144
946259546Skevlo#define	RT5390_EEPROM_IQ_PHASE_CAL_TX0_CH36_TO_CH64_5GHZ	0x145
947259546Skevlo#define	RT5390_EEPROM_IQ_GAIN_CAL_TX0_CH100_TO_CH138_5GHZ	0x146
948259546Skevlo#define	RT5390_EEPROM_IQ_PHASE_CAL_TX0_CH100_TO_CH138_5GHZ	0x147
949259546Skevlo#define	RT5390_EEPROM_IQ_GAIN_CAL_TX0_CH140_TO_CH165_5GHZ	0x148
950259546Skevlo#define	RT5390_EEPROM_IQ_PHASE_CAL_TX0_CH140_TO_CH165_5GHZ	0x149
951259546Skevlo#define	RT5390_EEPROM_IQ_GAIN_CAL_TX1_CH36_TO_CH64_5GHZ		0x14a
952259546Skevlo#define	RT5390_EEPROM_IQ_PHASE_CAL_TX1_CH36_TO_CH64_5GHZ	0x14b
953259546Skevlo#define	RT5390_EEPROM_IQ_GAIN_CAL_TX1_CH100_TO_CH138_5GHZ	0x14c
954259546Skevlo#define	RT5390_EEPROM_IQ_PHASE_CAL_TX1_CH100_TO_CH138_5GHZ	0x14d
955259546Skevlo#define	RT5390_EEPROM_IQ_GAIN_CAL_TX1_CH140_TO_CH165_5GHZ	0x14e
956259546Skevlo#define	RT5390_EEPROM_IQ_PHASE_CAL_TX1_CH140_TO_CH165_5GHZ	0x14f
957259544Skevlo
958259546Skevlo#define	RT2860_RIDX_CCK1	 0
959259546Skevlo#define	RT2860_RIDX_CCK11	 3
960259546Skevlo#define	RT2860_RIDX_OFDM6	 4
961259546Skevlo#define	RT2860_RIDX_MAX		12
962203134Sthompsa
963203134Sthompsa/*
964203134Sthompsa * EEPROM access macro.
965203134Sthompsa */
966203134Sthompsa#define RT2860_EEPROM_CTL(sc, val) do {					\
967203134Sthompsa	RAL_WRITE((sc), RT2860_PCI_EECTRL, (val));			\
968203134Sthompsa	RAL_BARRIER_READ_WRITE((sc));					\
969203134Sthompsa	DELAY(RT2860_EEPROM_DELAY);					\
970203134Sthompsa} while (/* CONSTCOND */0)
971203134Sthompsa
972203134Sthompsa/*
973203134Sthompsa * Default values for MAC registers; values taken from the reference driver.
974203134Sthompsa */
975259546Skevlo#define	RT2870_DEF_MAC					\
976203134Sthompsa	{ RT2860_BCN_OFFSET0,		0xf8f0e8e0 },	\
977257411Skevlo	{ RT2860_BCN_OFFSET1,		0x6f77d0c8 },	\
978203134Sthompsa	{ RT2860_LEGACY_BASIC_RATE,	0x0000013f },	\
979203134Sthompsa	{ RT2860_HT_BASIC_RATE,		0x00008003 },	\
980203134Sthompsa	{ RT2860_MAC_SYS_CTRL,		0x00000000 },	\
981203134Sthompsa	{ RT2860_BKOFF_SLOT_CFG,	0x00000209 },	\
982203134Sthompsa	{ RT2860_TX_SW_CFG0,		0x00000000 },	\
983203134Sthompsa	{ RT2860_TX_SW_CFG1,		0x00080606 },	\
984203134Sthompsa	{ RT2860_TX_LINK_CFG,		0x00001020 },	\
985203134Sthompsa	{ RT2860_TX_TIMEOUT_CFG,	0x000a2090 },	\
986257411Skevlo	{ RT2860_MAX_LEN_CFG,		0x00001f00 },	\
987203134Sthompsa	{ RT2860_LED_CFG,		0x7f031e46 },	\
988203134Sthompsa	{ RT2860_WMM_AIFSN_CFG,		0x00002273 },	\
989203134Sthompsa	{ RT2860_WMM_CWMIN_CFG,		0x00002344 },	\
990203134Sthompsa	{ RT2860_WMM_CWMAX_CFG,		0x000034aa },	\
991203134Sthompsa	{ RT2860_MAX_PCNT,		0x1f3fbf9f },	\
992203134Sthompsa	{ RT2860_TX_RTY_CFG,		0x47d01f0f },	\
993203134Sthompsa	{ RT2860_AUTO_RSP_CFG,		0x00000013 },	\
994203134Sthompsa	{ RT2860_CCK_PROT_CFG,		0x05740003 },	\
995203134Sthompsa	{ RT2860_OFDM_PROT_CFG,		0x05740003 },	\
996203134Sthompsa	{ RT2860_PBF_CFG,		0x00f40006 },	\
997203134Sthompsa	{ RT2860_WPDMA_GLO_CFG,		0x00000030 },	\
998203134Sthompsa	{ RT2860_GF20_PROT_CFG,		0x01744004 },	\
999203134Sthompsa	{ RT2860_GF40_PROT_CFG,		0x03f44084 },	\
1000203134Sthompsa	{ RT2860_MM20_PROT_CFG,		0x01744004 },	\
1001203134Sthompsa	{ RT2860_MM40_PROT_CFG,		0x03f44084 },	\
1002203134Sthompsa	{ RT2860_TXOP_CTRL_CFG,		0x0000583f },	\
1003203134Sthompsa	{ RT2860_TXOP_HLDR_ET,		0x00000002 },	\
1004203134Sthompsa	{ RT2860_TX_RTS_CFG,		0x00092b20 },	\
1005203134Sthompsa	{ RT2860_EXP_ACK_TIME,		0x002400ca },	\
1006203134Sthompsa	{ RT2860_XIFS_TIME_CFG,		0x33a41010 },	\
1007203134Sthompsa	{ RT2860_PWR_PIN_CFG,		0x00000003 }
1008203134Sthompsa
1009203134Sthompsa/*
1010203134Sthompsa * Default values for BBP registers; values taken from the reference driver.
1011203134Sthompsa */
1012259546Skevlo#define	RT2860_DEF_BBP	\
1013203134Sthompsa	{  65, 0x2c },	\
1014203134Sthompsa	{  66, 0x38 },	\
1015257410Skevlo	{  68, 0x0b },	\
1016203134Sthompsa	{  69, 0x12 },	\
1017203134Sthompsa	{  70, 0x0a },	\
1018203134Sthompsa	{  73, 0x10 },	\
1019203134Sthompsa	{  81, 0x37 },	\
1020203134Sthompsa	{  82, 0x62 },	\
1021203134Sthompsa	{  83, 0x6a },	\
1022203134Sthompsa	{  84, 0x99 },	\
1023203134Sthompsa	{  86, 0x00 },	\
1024203134Sthompsa	{  91, 0x04 },	\
1025203134Sthompsa	{  92, 0x00 },	\
1026203134Sthompsa	{ 103, 0x00 },	\
1027205042Sthompsa	{ 105, 0x05 },	\
1028205042Sthompsa	{ 106, 0x35 }
1029203134Sthompsa
1030259546Skevlo#define	RT5390_DEF_BBP	\
1031257955Skevlo	{  31, 0x08 },	\
1032257955Skevlo	{  65, 0x2c },	\
1033257955Skevlo	{  66, 0x38 },	\
1034257955Skevlo	{  68, 0x0b },	\
1035257955Skevlo	{  69, 0x0d },	\
1036257955Skevlo	{  70, 0x06 },	\
1037257955Skevlo	{  73, 0x13 },	\
1038257955Skevlo	{  75, 0x46 },	\
1039257955Skevlo	{  76, 0x28 },	\
1040257955Skevlo	{  77, 0x59 },	\
1041257955Skevlo	{  81, 0x37 },	\
1042257955Skevlo	{  82, 0x62 },	\
1043257955Skevlo	{  83, 0x7a },	\
1044257955Skevlo	{  84, 0x9a },	\
1045257955Skevlo	{  86, 0x38 },	\
1046257955Skevlo	{  91, 0x04 },	\
1047257955Skevlo	{  92, 0x02 },	\
1048257955Skevlo	{ 103, 0xc0 },	\
1049257955Skevlo	{ 104, 0x92 },	\
1050257955Skevlo	{ 105, 0x3c },	\
1051257955Skevlo	{ 106, 0x03 },	\
1052257955Skevlo	{ 128, 0x12 }
1053257955Skevlo
1054259546Skevlo#define	RT5592_DEF_BBP	\
1055259032Skevlo	{  20, 0x06 },	\
1056259032Skevlo	{  31, 0x08 },	\
1057259032Skevlo	{  65, 0x2c },	\
1058259032Skevlo	{  66, 0x38 },	\
1059259032Skevlo	{  68, 0xdd },	\
1060259032Skevlo	{  69, 0x1a },	\
1061259032Skevlo	{  70, 0x05 },	\
1062259032Skevlo	{  73, 0x13 },	\
1063259032Skevlo	{  74, 0x0f },	\
1064259032Skevlo	{  75, 0x4f },	\
1065259032Skevlo	{  76, 0x28 },	\
1066259032Skevlo	{  77, 0x59 },	\
1067259032Skevlo	{  81, 0x37 },	\
1068259032Skevlo	{  82, 0x62 },	\
1069259032Skevlo	{  83, 0x6a },	\
1070259032Skevlo	{  84, 0x9a },	\
1071259032Skevlo	{  86, 0x38 },	\
1072259032Skevlo	{  88, 0x90 },	\
1073259032Skevlo	{  91, 0x04 },	\
1074259032Skevlo	{  92, 0x02 },	\
1075259032Skevlo	{  95, 0x9a },	\
1076259032Skevlo	{  98, 0x12 },	\
1077259032Skevlo	{ 103, 0xc0 },	\
1078259032Skevlo	{ 104, 0x92 },	\
1079259032Skevlo	{ 105, 0x3c },	\
1080259032Skevlo	{ 106, 0x35 },	\
1081259032Skevlo	{ 128, 0x12 },	\
1082259032Skevlo	{ 134, 0xd0 },	\
1083259032Skevlo	{ 135, 0xf6 },	\
1084259032Skevlo	{ 137, 0x0f }
1085259032Skevlo
1086203134Sthompsa/*
1087300748Savos * Channel map for run(4) driver; taken from the table below.
1088300748Savos */
1089300748Savosstatic const uint8_t run_chan_5ghz[] =
1090300748Savos	{ 36, 38, 40, 44, 46, 48, 52, 54, 56, 60, 62, 64, 100, 102, 104,
1091300748Savos	  108, 110, 112, 116, 118, 120, 124, 126, 128, 132, 134, 136, 140,
1092300748Savos	  149, 151, 153, 157, 159, 161, 165, 167, 169, 171, 173,
1093300748Savos	  184, 188, 192, 196, 208, 212, 216 };
1094300748Savos
1095300748Savos/*
1096203134Sthompsa * Default settings for RF registers; values derived from the reference driver.
1097203134Sthompsa */
1098259546Skevlo#define	RT2860_RF2850							\
1099257955Skevlo	{   1, 0x98402ecc, 0x984c0786, 0x9816b455, 0x9800510b },	\
1100257955Skevlo	{   2, 0x98402ecc, 0x984c0786, 0x98168a55, 0x9800519f },	\
1101257955Skevlo	{   3, 0x98402ecc, 0x984c078a, 0x98168a55, 0x9800518b },	\
1102257955Skevlo	{   4, 0x98402ecc, 0x984c078a, 0x98168a55, 0x9800519f },	\
1103257955Skevlo	{   5, 0x98402ecc, 0x984c078e, 0x98168a55, 0x9800518b },	\
1104257955Skevlo	{   6, 0x98402ecc, 0x984c078e, 0x98168a55, 0x9800519f },	\
1105257955Skevlo	{   7, 0x98402ecc, 0x984c0792, 0x98168a55, 0x9800518b },	\
1106257955Skevlo	{   8, 0x98402ecc, 0x984c0792, 0x98168a55, 0x9800519f },	\
1107257955Skevlo	{   9, 0x98402ecc, 0x984c0796, 0x98168a55, 0x9800518b },	\
1108257955Skevlo	{  10, 0x98402ecc, 0x984c0796, 0x98168a55, 0x9800519f },	\
1109257955Skevlo	{  11, 0x98402ecc, 0x984c079a, 0x98168a55, 0x9800518b },	\
1110257955Skevlo	{  12, 0x98402ecc, 0x984c079a, 0x98168a55, 0x9800519f },	\
1111257955Skevlo	{  13, 0x98402ecc, 0x984c079e, 0x98168a55, 0x9800518b },	\
1112257955Skevlo	{  14, 0x98402ecc, 0x984c07a2, 0x98168a55, 0x98005193 },	\
1113257955Skevlo	{  36, 0x98402ecc, 0x984c099a, 0x98158a55, 0x980ed1a3 },	\
1114257955Skevlo	{  38, 0x98402ecc, 0x984c099e, 0x98158a55, 0x980ed193 },	\
1115257955Skevlo	{  40, 0x98402ec8, 0x984c0682, 0x98158a55, 0x980ed183 },	\
1116257955Skevlo	{  44, 0x98402ec8, 0x984c0682, 0x98158a55, 0x980ed1a3 },	\
1117257955Skevlo	{  46, 0x98402ec8, 0x984c0686, 0x98158a55, 0x980ed18b },	\
1118257955Skevlo	{  48, 0x98402ec8, 0x984c0686, 0x98158a55, 0x980ed19b },	\
1119257955Skevlo	{  52, 0x98402ec8, 0x984c068a, 0x98158a55, 0x980ed193 },	\
1120257955Skevlo	{  54, 0x98402ec8, 0x984c068a, 0x98158a55, 0x980ed1a3 },	\
1121257955Skevlo	{  56, 0x98402ec8, 0x984c068e, 0x98158a55, 0x980ed18b },	\
1122257955Skevlo	{  60, 0x98402ec8, 0x984c0692, 0x98158a55, 0x980ed183 },	\
1123257955Skevlo	{  62, 0x98402ec8, 0x984c0692, 0x98158a55, 0x980ed193 },	\
1124257955Skevlo	{  64, 0x98402ec8, 0x984c0692, 0x98158a55, 0x980ed1a3 },	\
1125257955Skevlo	{ 100, 0x98402ec8, 0x984c06b2, 0x98178a55, 0x980ed783 },	\
1126257955Skevlo	{ 102, 0x98402ec8, 0x985c06b2, 0x98578a55, 0x980ed793 },	\
1127257955Skevlo	{ 104, 0x98402ec8, 0x985c06b2, 0x98578a55, 0x980ed1a3 },	\
1128257955Skevlo	{ 108, 0x98402ecc, 0x985c0a32, 0x98578a55, 0x980ed193 },	\
1129257955Skevlo	{ 110, 0x98402ecc, 0x984c0a36, 0x98178a55, 0x980ed183 },	\
1130257955Skevlo	{ 112, 0x98402ecc, 0x984c0a36, 0x98178a55, 0x980ed19b },	\
1131257955Skevlo	{ 116, 0x98402ecc, 0x984c0a3a, 0x98178a55, 0x980ed1a3 },	\
1132257955Skevlo	{ 118, 0x98402ecc, 0x984c0a3e, 0x98178a55, 0x980ed193 },	\
1133257955Skevlo	{ 120, 0x98402ec4, 0x984c0382, 0x98178a55, 0x980ed183 },	\
1134257955Skevlo	{ 124, 0x98402ec4, 0x984c0382, 0x98178a55, 0x980ed193 },	\
1135257955Skevlo	{ 126, 0x98402ec4, 0x984c0382, 0x98178a55, 0x980ed15b },	\
1136257955Skevlo	{ 128, 0x98402ec4, 0x984c0382, 0x98178a55, 0x980ed1a3 },	\
1137257955Skevlo	{ 132, 0x98402ec4, 0x984c0386, 0x98178a55, 0x980ed18b },	\
1138257955Skevlo	{ 134, 0x98402ec4, 0x984c0386, 0x98178a55, 0x980ed193 },	\
1139257955Skevlo	{ 136, 0x98402ec4, 0x984c0386, 0x98178a55, 0x980ed19b },	\
1140257955Skevlo	{ 140, 0x98402ec4, 0x984c038a, 0x98178a55, 0x980ed183 },	\
1141257955Skevlo	{ 149, 0x98402ec4, 0x984c038a, 0x98178a55, 0x980ed1a7 },	\
1142257955Skevlo	{ 151, 0x98402ec4, 0x984c038e, 0x98178a55, 0x980ed187 },	\
1143257955Skevlo	{ 153, 0x98402ec4, 0x984c038e, 0x98178a55, 0x980ed18f },	\
1144257955Skevlo	{ 157, 0x98402ec4, 0x984c038e, 0x98178a55, 0x980ed19f },	\
1145257955Skevlo	{ 159, 0x98402ec4, 0x984c038e, 0x98178a55, 0x980ed1a7 },	\
1146257955Skevlo	{ 161, 0x98402ec4, 0x984c0392, 0x98178a55, 0x980ed187 },	\
1147257955Skevlo	{ 165, 0x98402ec4, 0x984c0392, 0x98178a55, 0x980ed197 },	\
1148257955Skevlo	{ 167, 0x98402ec4, 0x984c03d2, 0x98179855, 0x9815531f },	\
1149257955Skevlo	{ 169, 0x98402ec4, 0x984c03d2, 0x98179855, 0x98155327 },	\
1150257955Skevlo	{ 171, 0x98402ec4, 0x984c03d6, 0x98179855, 0x98155307 },	\
1151257955Skevlo	{ 173, 0x98402ec4, 0x984c03d6, 0x98179855, 0x9815530f },	\
1152257955Skevlo	{ 184, 0x95002ccc, 0x9500491e, 0x9509be55, 0x950c0a0b },	\
1153257955Skevlo	{ 188, 0x95002ccc, 0x95004922, 0x9509be55, 0x950c0a13 },	\
1154257955Skevlo	{ 192, 0x95002ccc, 0x95004926, 0x9509be55, 0x950c0a1b },	\
1155257955Skevlo	{ 196, 0x95002ccc, 0x9500492a, 0x9509be55, 0x950c0a23 },	\
1156257955Skevlo	{ 208, 0x95002ccc, 0x9500493a, 0x9509be55, 0x950c0a13 },	\
1157257955Skevlo	{ 212, 0x95002ccc, 0x9500493e, 0x9509be55, 0x950c0a1b },	\
1158257955Skevlo	{ 216, 0x95002ccc, 0x95004982, 0x9509be55, 0x950c0a23 }
1159203134Sthompsa
1160259546Skevlo#define	RT3070_RF3052		\
1161205042Sthompsa	{ 0xf1, 2,  2 },	\
1162205042Sthompsa	{ 0xf1, 2,  7 },	\
1163205042Sthompsa	{ 0xf2, 2,  2 },	\
1164205042Sthompsa	{ 0xf2, 2,  7 },	\
1165205042Sthompsa	{ 0xf3, 2,  2 },	\
1166205042Sthompsa	{ 0xf3, 2,  7 },	\
1167205042Sthompsa	{ 0xf4, 2,  2 },	\
1168205042Sthompsa	{ 0xf4, 2,  7 },	\
1169205042Sthompsa	{ 0xf5, 2,  2 },	\
1170205042Sthompsa	{ 0xf5, 2,  7 },	\
1171205042Sthompsa	{ 0xf6, 2,  2 },	\
1172205042Sthompsa	{ 0xf6, 2,  7 },	\
1173205042Sthompsa	{ 0xf7, 2,  2 },	\
1174205042Sthompsa	{ 0xf8, 2,  4 },	\
1175205042Sthompsa	{ 0x56, 0,  4 },	\
1176205042Sthompsa	{ 0x56, 0,  6 },	\
1177205042Sthompsa	{ 0x56, 0,  8 },	\
1178205042Sthompsa	{ 0x57, 0,  0 },	\
1179205042Sthompsa	{ 0x57, 0,  2 },	\
1180205042Sthompsa	{ 0x57, 0,  4 },	\
1181205042Sthompsa	{ 0x57, 0,  8 },	\
1182205042Sthompsa	{ 0x57, 0, 10 },	\
1183205042Sthompsa	{ 0x58, 0,  0 },	\
1184205042Sthompsa	{ 0x58, 0,  4 },	\
1185205042Sthompsa	{ 0x58, 0,  6 },	\
1186205042Sthompsa	{ 0x58, 0,  8 },	\
1187205042Sthompsa	{ 0x5b, 0,  8 },	\
1188205042Sthompsa	{ 0x5b, 0, 10 },	\
1189205042Sthompsa	{ 0x5c, 0,  0 },	\
1190205042Sthompsa	{ 0x5c, 0,  4 },	\
1191205042Sthompsa	{ 0x5c, 0,  6 },	\
1192205042Sthompsa	{ 0x5c, 0,  8 },	\
1193205042Sthompsa	{ 0x5d, 0,  0 },	\
1194205042Sthompsa	{ 0x5d, 0,  2 },	\
1195205042Sthompsa	{ 0x5d, 0,  4 },	\
1196205042Sthompsa	{ 0x5d, 0,  8 },	\
1197205042Sthompsa	{ 0x5d, 0, 10 },	\
1198205042Sthompsa	{ 0x5e, 0,  0 },	\
1199205042Sthompsa	{ 0x5e, 0,  4 },	\
1200205042Sthompsa	{ 0x5e, 0,  6 },	\
1201205042Sthompsa	{ 0x5e, 0,  8 },	\
1202205042Sthompsa	{ 0x5f, 0,  0 },	\
1203205042Sthompsa	{ 0x5f, 0,  9 },	\
1204205042Sthompsa	{ 0x5f, 0, 11 },	\
1205205042Sthompsa	{ 0x60, 0,  1 },	\
1206205042Sthompsa	{ 0x60, 0,  5 },	\
1207205042Sthompsa	{ 0x60, 0,  7 },	\
1208205042Sthompsa	{ 0x60, 0,  9 },	\
1209205042Sthompsa	{ 0x61, 0,  1 },	\
1210205042Sthompsa	{ 0x61, 0,  3 },	\
1211205042Sthompsa	{ 0x61, 0,  5 },	\
1212205042Sthompsa	{ 0x61, 0,  7 },	\
1213205042Sthompsa	{ 0x61, 0,  9 }
1214205042Sthompsa
1215259546Skevlo#define	RT5592_RF5592_20MHZ	\
1216259032Skevlo	{ 0x1e2,  4, 10, 3 },	\
1217259032Skevlo	{ 0x1e3,  4, 10, 3 },	\
1218259032Skevlo	{ 0x1e4,  4, 10, 3 },	\
1219259032Skevlo	{ 0x1e5,  4, 10, 3 },	\
1220259032Skevlo	{ 0x1e6,  4, 10, 3 },	\
1221259032Skevlo	{ 0x1e7,  4, 10, 3 },	\
1222259032Skevlo	{ 0x1e8,  4, 10, 3 },	\
1223259032Skevlo	{ 0x1e9,  4, 10, 3 },	\
1224259032Skevlo	{ 0x1ea,  4, 10, 3 },	\
1225259032Skevlo	{ 0x1eb,  4, 10, 3 },	\
1226259032Skevlo	{ 0x1ec,  4, 10, 3 },	\
1227259032Skevlo	{ 0x1ed,  4, 10, 3 },	\
1228259032Skevlo	{ 0x1ee,  4, 10, 3 },	\
1229259032Skevlo	{ 0x1f0,  8, 10, 3 },	\
1230259032Skevlo	{  0xac,  8, 12, 1 },	\
1231259032Skevlo	{  0xad,  0, 12, 1 },	\
1232259032Skevlo	{  0xad,  4, 12, 1 },	\
1233259032Skevlo	{  0xae,  0, 12, 1 },	\
1234259032Skevlo	{  0xae,  4, 12, 1 },	\
1235259032Skevlo	{  0xae,  8, 12, 1 },	\
1236259032Skevlo	{  0xaf,  4, 12, 1 },	\
1237259032Skevlo	{  0xaf,  8, 12, 1 },	\
1238259032Skevlo	{  0xb0,  0, 12, 1 },	\
1239259032Skevlo	{  0xb0,  8, 12, 1 },	\
1240259032Skevlo	{  0xb1,  0, 12, 1 },	\
1241259032Skevlo	{  0xb1,  4, 12, 1 },	\
1242259032Skevlo	{  0xb7,  4, 12, 1 },	\
1243259032Skevlo	{  0xb7,  8, 12, 1 },	\
1244259032Skevlo	{  0xb8,  0, 12, 1 },	\
1245259032Skevlo	{  0xb8,  8, 12, 1 },	\
1246259032Skevlo	{  0xb9,  0, 12, 1 },	\
1247259032Skevlo	{  0xb9,  4, 12, 1 },	\
1248259032Skevlo	{  0xba,  0, 12, 1 },	\
1249259032Skevlo	{  0xba,  4, 12, 1 },	\
1250259032Skevlo	{  0xba,  8, 12, 1 },	\
1251259032Skevlo	{  0xbb,  4, 12, 1 },	\
1252259032Skevlo	{  0xbb,  8, 12, 1 },	\
1253259032Skevlo	{  0xbc,  0, 12, 1 },	\
1254259032Skevlo	{  0xbc,  8, 12, 1 },	\
1255259032Skevlo	{  0xbd,  0, 12, 1 },	\
1256259032Skevlo	{  0xbd,  4, 12, 1 },	\
1257259032Skevlo	{  0xbe,  0, 12, 1 },	\
1258259032Skevlo	{  0xbf,  6, 12, 1 },	\
1259259032Skevlo	{  0xbf, 10, 12, 1 },	\
1260259032Skevlo	{  0xc0,  2, 12, 1 },	\
1261259032Skevlo	{  0xc0, 10, 12, 1 },	\
1262259032Skevlo	{  0xc1,  2, 12, 1 },	\
1263259032Skevlo	{  0xc1,  6, 12, 1 },	\
1264259032Skevlo	{  0xc2,  2, 12, 1 },	\
1265259032Skevlo	{  0xa4,  0, 12, 1 },	\
1266259032Skevlo	{  0xa4,  4, 12, 1 },	\
1267259032Skevlo	{  0xa5,  8, 12, 1 },	\
1268259032Skevlo	{  0xa6,  0, 12, 1 }
1269259032Skevlo
1270259546Skevlo#define	RT5592_RF5592_40MHZ	\
1271259032Skevlo	{ 0xf1,  2, 10, 3 },	\
1272259032Skevlo	{ 0xf1,  7, 10, 3 },	\
1273259032Skevlo	{ 0xf2,  2, 10, 3 },	\
1274259032Skevlo	{ 0xf2,  7, 10, 3 },	\
1275259032Skevlo	{ 0xf3,  2, 10, 3 },	\
1276259032Skevlo	{ 0xf3,  7, 10, 3 },	\
1277259032Skevlo	{ 0xf4,  2, 10, 3 },	\
1278259032Skevlo	{ 0xf4,  7, 10, 3 },	\
1279259032Skevlo	{ 0xf5,  2, 10, 3 },	\
1280259032Skevlo	{ 0xf5,  7, 10, 3 },	\
1281259032Skevlo	{ 0xf6,  2, 10, 3 },	\
1282259032Skevlo	{ 0xf6,  7, 10, 3 },	\
1283259032Skevlo	{ 0xf7,  2, 10, 3 },	\
1284259032Skevlo	{ 0xf8,  4, 10, 3 },	\
1285259032Skevlo	{ 0x56,  4, 12, 1 },	\
1286259032Skevlo	{ 0x56,  6, 12, 1 },	\
1287259032Skevlo	{ 0x56,  8, 12, 1 },	\
1288259032Skevlo	{ 0x57,  0, 12, 1 },	\
1289259032Skevlo	{ 0x57,  2, 12, 1 },	\
1290259032Skevlo	{ 0x57,  4, 12, 1 },	\
1291259032Skevlo	{ 0x57,  8, 12, 1 },	\
1292259032Skevlo	{ 0x57, 10, 12, 1 },	\
1293259032Skevlo	{ 0x58,  0, 12, 1 },	\
1294259032Skevlo	{ 0x58,  4, 12, 1 },	\
1295259032Skevlo	{ 0x58,  6, 12, 1 },	\
1296259032Skevlo	{ 0x58,  8, 12, 1 },	\
1297259032Skevlo	{ 0x5b,  8, 12, 1 },	\
1298259032Skevlo	{ 0x5b, 10, 12, 1 },	\
1299259032Skevlo	{ 0x5c,  0, 12, 1 },	\
1300259032Skevlo	{ 0x5c,  4, 12, 1 },	\
1301259032Skevlo	{ 0x5c,  6, 12, 1 },	\
1302259032Skevlo	{ 0x5c,  8, 12, 1 },	\
1303259032Skevlo	{ 0x5d,  0, 12, 1 },	\
1304259032Skevlo	{ 0x5d,  2, 12, 1 },	\
1305259032Skevlo	{ 0x5d,  4, 12, 1 },	\
1306259032Skevlo	{ 0x5d,  8, 12, 1 },	\
1307259032Skevlo	{ 0x5d, 10, 12, 1 },	\
1308259032Skevlo	{ 0x5e,  0, 12, 1 },	\
1309259032Skevlo	{ 0x5e,  4, 12, 1 },	\
1310259032Skevlo	{ 0x5e,  6, 12, 1 },	\
1311259032Skevlo	{ 0x5e,  8, 12, 1 },	\
1312259032Skevlo	{ 0x5f,  0, 12, 1 },	\
1313259032Skevlo	{ 0x5f,  9, 12, 1 },	\
1314259032Skevlo	{ 0x5f, 11, 12, 1 },	\
1315259032Skevlo	{ 0x60,  1, 12, 1 },	\
1316259032Skevlo	{ 0x60,  5, 12, 1 },	\
1317259032Skevlo	{ 0x60,  7, 12, 1 },	\
1318259032Skevlo	{ 0x60,  9, 12, 1 },	\
1319259032Skevlo	{ 0x61,  1, 12, 1 },	\
1320259032Skevlo	{ 0x52,  0, 12, 1 },	\
1321259032Skevlo	{ 0x52,  4, 12, 1 },	\
1322259032Skevlo	{ 0x52,  8, 12, 1 },	\
1323259032Skevlo	{ 0x53,  0, 12, 1 }
1324259032Skevlo
1325259546Skevlo#define	RT3070_DEF_RF	\
1326203134Sthompsa	{  4, 0x40 },	\
1327203134Sthompsa	{  5, 0x03 },	\
1328203134Sthompsa	{  6, 0x02 },	\
1329256718Skevlo	{  7, 0x60 },	\
1330203134Sthompsa	{  9, 0x0f },	\
1331203134Sthompsa	{ 10, 0x41 },	\
1332203134Sthompsa	{ 11, 0x21 },	\
1333203134Sthompsa	{ 12, 0x7b },	\
1334203134Sthompsa	{ 14, 0x90 },	\
1335203134Sthompsa	{ 15, 0x58 },	\
1336203134Sthompsa	{ 16, 0xb3 },	\
1337203134Sthompsa	{ 17, 0x92 },	\
1338203134Sthompsa	{ 18, 0x2c },	\
1339203134Sthompsa	{ 19, 0x02 },	\
1340203134Sthompsa	{ 20, 0xba },	\
1341203134Sthompsa	{ 21, 0xdb },	\
1342203134Sthompsa	{ 24, 0x16 },	\
1343256718Skevlo	{ 25, 0x03 },	\
1344203134Sthompsa	{ 29, 0x1f }
1345203134Sthompsa
1346259546Skevlo#define	RT3572_DEF_RF	\
1347205042Sthompsa	{  0, 0x70 },	\
1348205042Sthompsa	{  1, 0x81 },	\
1349205042Sthompsa	{  2, 0xf1 },	\
1350205042Sthompsa	{  3, 0x02 },	\
1351205042Sthompsa	{  4, 0x4c },	\
1352205042Sthompsa	{  5, 0x05 },	\
1353205042Sthompsa	{  6, 0x4a },	\
1354205042Sthompsa	{  7, 0xd8 },	\
1355205042Sthompsa	{  9, 0xc3 },	\
1356205042Sthompsa	{ 10, 0xf1 },	\
1357205042Sthompsa	{ 11, 0xb9 },	\
1358205042Sthompsa	{ 12, 0x70 },	\
1359205042Sthompsa	{ 13, 0x65 },	\
1360205042Sthompsa	{ 14, 0xa0 },	\
1361205042Sthompsa	{ 15, 0x53 },	\
1362205042Sthompsa	{ 16, 0x4c },	\
1363205042Sthompsa	{ 17, 0x23 },	\
1364205042Sthompsa	{ 18, 0xac },	\
1365205042Sthompsa	{ 19, 0x93 },	\
1366205042Sthompsa	{ 20, 0xb3 },	\
1367205042Sthompsa	{ 21, 0xd0 },	\
1368205042Sthompsa	{ 22, 0x00 },  	\
1369205042Sthompsa	{ 23, 0x3c },	\
1370205042Sthompsa	{ 24, 0x16 },	\
1371205042Sthompsa	{ 25, 0x15 },	\
1372205042Sthompsa	{ 26, 0x85 },	\
1373205042Sthompsa	{ 27, 0x00 },	\
1374205042Sthompsa	{ 28, 0x00 },	\
1375205042Sthompsa	{ 29, 0x9b },	\
1376205042Sthompsa	{ 30, 0x09 },	\
1377205042Sthompsa	{ 31, 0x10 }
1378205042Sthompsa
1379260219Skevlo#define	RT3593_DEF_RF	\
1380260219Skevlo	{  1, 0x03 },	\
1381260219Skevlo	{  3, 0x80 },	\
1382260219Skevlo	{  5, 0x00 },	\
1383260219Skevlo	{  6, 0x40 },	\
1384260219Skevlo	{  8, 0xf1 },	\
1385260219Skevlo	{  9, 0x02 },	\
1386260219Skevlo	{ 10, 0xd3 },	\
1387260219Skevlo	{ 11, 0x40 },	\
1388260219Skevlo	{ 12, 0x4e },	\
1389260219Skevlo	{ 13, 0x12 },	\
1390260219Skevlo	{ 18, 0x40 },	\
1391260219Skevlo	{ 22, 0x20 },	\
1392260219Skevlo	{ 30, 0x10 },	\
1393260219Skevlo	{ 31, 0x80 },	\
1394260219Skevlo	{ 32, 0x78 },	\
1395260219Skevlo	{ 33, 0x3b },	\
1396260219Skevlo	{ 34, 0x3c },	\
1397260219Skevlo	{ 35, 0xe0 },	\
1398260219Skevlo	{ 38, 0x86 },	\
1399260219Skevlo	{ 39, 0x23 },	\
1400260219Skevlo	{ 44, 0xd3 },	\
1401260219Skevlo	{ 45, 0xbb },	\
1402260219Skevlo	{ 46, 0x60 },	\
1403260219Skevlo	{ 49, 0x81 },	\
1404260219Skevlo	{ 50, 0x86 },	\
1405260219Skevlo	{ 51, 0x75 },	\
1406260219Skevlo	{ 52, 0x45 },	\
1407260219Skevlo	{ 53, 0x18 },	\
1408260219Skevlo	{ 54, 0x18 },	\
1409260219Skevlo	{ 55, 0x18 },	\
1410260219Skevlo	{ 56, 0xdb },	\
1411260219Skevlo	{ 57, 0x6e }
1412260219Skevlo
1413259546Skevlo#define	RT5390_DEF_RF	\
1414257955Skevlo	{  1, 0x0f },	\
1415257955Skevlo	{  2, 0x80 },	\
1416257955Skevlo	{  3, 0x88 },	\
1417257955Skevlo	{  5, 0x10 },	\
1418257955Skevlo	{  6, 0xa0 },	\
1419257955Skevlo	{  7, 0x00 },	\
1420257955Skevlo	{ 10, 0x53 },	\
1421257955Skevlo	{ 11, 0x4a },	\
1422257955Skevlo	{ 12, 0x46 },	\
1423257955Skevlo	{ 13, 0x9f },	\
1424257955Skevlo	{ 14, 0x00 },	\
1425257955Skevlo	{ 15, 0x00 },	\
1426257955Skevlo	{ 16, 0x00 },	\
1427257955Skevlo	{ 18, 0x03 },	\
1428257955Skevlo	{ 19, 0x00 },	\
1429257955Skevlo	{ 20, 0x00 },	\
1430257955Skevlo	{ 21, 0x00 },	\
1431257955Skevlo	{ 22, 0x20 },  	\
1432257955Skevlo	{ 23, 0x00 },	\
1433257955Skevlo	{ 24, 0x00 },	\
1434257955Skevlo	{ 25, 0xc0 },	\
1435257955Skevlo	{ 26, 0x00 },	\
1436257955Skevlo	{ 27, 0x09 },	\
1437257955Skevlo	{ 28, 0x00 },	\
1438257955Skevlo	{ 29, 0x10 },	\
1439257955Skevlo	{ 30, 0x10 },	\
1440257955Skevlo	{ 31, 0x80 },	\
1441257955Skevlo	{ 32, 0x80 },	\
1442257955Skevlo	{ 33, 0x00 },	\
1443257955Skevlo	{ 34, 0x07 },	\
1444257955Skevlo	{ 35, 0x12 },	\
1445257955Skevlo	{ 36, 0x00 },	\
1446257955Skevlo	{ 37, 0x08 },	\
1447257955Skevlo	{ 38, 0x85 },	\
1448257955Skevlo	{ 39, 0x1b },	\
1449257955Skevlo	{ 40, 0x0b },	\
1450257955Skevlo	{ 41, 0xbb },	\
1451257955Skevlo	{ 42, 0xd2 },	\
1452257955Skevlo	{ 43, 0x9a },	\
1453257955Skevlo	{ 44, 0x0e },	\
1454257955Skevlo	{ 45, 0xa2 },	\
1455257955Skevlo	{ 46, 0x7b },	\
1456257955Skevlo	{ 47, 0x00 },	\
1457257955Skevlo	{ 48, 0x10 },	\
1458257955Skevlo	{ 49, 0x94 },	\
1459257955Skevlo	{ 52, 0x38 },	\
1460257955Skevlo	{ 53, 0x84 },	\
1461257955Skevlo	{ 54, 0x78 },	\
1462257955Skevlo	{ 55, 0x44 },	\
1463257955Skevlo	{ 56, 0x22 },	\
1464257955Skevlo	{ 57, 0x80 },	\
1465257955Skevlo	{ 58, 0x7f },	\
1466257955Skevlo	{ 59, 0x8f },	\
1467257955Skevlo	{ 60, 0x45 },	\
1468257955Skevlo	{ 61, 0xdd },	\
1469257955Skevlo	{ 62, 0x00 },	\
1470257955Skevlo	{ 63, 0x00 }
1471218676Shselasky
1472259546Skevlo#define	RT5392_DEF_RF	\
1473257955Skevlo	{  1, 0x17 },	\
1474257955Skevlo	{  3, 0x88 },	\
1475257955Skevlo	{  5, 0x10 },	\
1476257955Skevlo	{  6, 0xe0 },	\
1477257955Skevlo	{  7, 0x00 },	\
1478257955Skevlo	{ 10, 0x53 },	\
1479257955Skevlo	{ 11, 0x4a },	\
1480257955Skevlo	{ 12, 0x46 },	\
1481257955Skevlo	{ 13, 0x9f },	\
1482257955Skevlo	{ 14, 0x00 },	\
1483257955Skevlo	{ 15, 0x00 },	\
1484257955Skevlo	{ 16, 0x00 },	\
1485257955Skevlo	{ 18, 0x03 },	\
1486257955Skevlo	{ 19, 0x4d },	\
1487257955Skevlo	{ 20, 0x00 },	\
1488257955Skevlo	{ 21, 0x8d },	\
1489257955Skevlo	{ 22, 0x20 },  	\
1490257955Skevlo	{ 23, 0x0b },	\
1491257955Skevlo	{ 24, 0x44 },	\
1492257955Skevlo	{ 25, 0x80 },	\
1493257955Skevlo	{ 26, 0x82 },	\
1494257955Skevlo	{ 27, 0x09 },	\
1495257955Skevlo	{ 28, 0x00 },	\
1496257955Skevlo	{ 29, 0x10 },	\
1497257955Skevlo	{ 30, 0x10 },	\
1498257955Skevlo	{ 31, 0x80 },	\
1499257955Skevlo	{ 32, 0x20 },	\
1500257955Skevlo	{ 33, 0xc0 },	\
1501257955Skevlo	{ 34, 0x07 },	\
1502257955Skevlo	{ 35, 0x12 },	\
1503257955Skevlo	{ 36, 0x00 },	\
1504257955Skevlo	{ 37, 0x08 },	\
1505257955Skevlo	{ 38, 0x89 },	\
1506257955Skevlo	{ 39, 0x1b },	\
1507257955Skevlo	{ 40, 0x0f },	\
1508257955Skevlo	{ 41, 0xbb },	\
1509257955Skevlo	{ 42, 0xd5 },	\
1510257955Skevlo	{ 43, 0x9b },	\
1511257955Skevlo	{ 44, 0x0e },	\
1512257955Skevlo	{ 45, 0xa2 },	\
1513257955Skevlo	{ 46, 0x73 },	\
1514257955Skevlo	{ 47, 0x0c },	\
1515257955Skevlo	{ 48, 0x10 },	\
1516257955Skevlo	{ 49, 0x94 },	\
1517257955Skevlo	{ 50, 0x94 },	\
1518257955Skevlo	{ 51, 0x3a },	\
1519257955Skevlo	{ 52, 0x48 },	\
1520257955Skevlo	{ 53, 0x44 },	\
1521257955Skevlo	{ 54, 0x38 },	\
1522257955Skevlo	{ 55, 0x43 },	\
1523257955Skevlo	{ 56, 0xa1 },	\
1524257955Skevlo	{ 57, 0x00 },	\
1525257955Skevlo	{ 58, 0x39 },	\
1526257955Skevlo	{ 59, 0x07 },	\
1527257955Skevlo	{ 60, 0x45 },	\
1528257955Skevlo	{ 61, 0x91 },	\
1529257955Skevlo	{ 62, 0x39 },	\
1530257955Skevlo	{ 63, 0x07 }
1531257955Skevlo
1532259546Skevlo#define	RT5592_DEF_RF	\
1533259032Skevlo	{  1, 0x3f },	\
1534259032Skevlo	{  3, 0x08 },	\
1535259032Skevlo	{  5, 0x10 },	\
1536259032Skevlo	{  6, 0xe4 },	\
1537259032Skevlo	{  7, 0x00 },	\
1538259032Skevlo	{ 14, 0x00 },	\
1539259032Skevlo	{ 15, 0x00 },	\
1540259032Skevlo	{ 16, 0x00 },	\
1541259032Skevlo	{ 18, 0x03 },	\
1542259032Skevlo	{ 19, 0x4d },	\
1543259032Skevlo	{ 20, 0x10 },	\
1544259032Skevlo	{ 21, 0x8d },	\
1545259032Skevlo	{ 26, 0x82 },	\
1546259032Skevlo	{ 28, 0x00 },	\
1547259032Skevlo	{ 29, 0x10 },	\
1548259032Skevlo	{ 33, 0xc0 },	\
1549259032Skevlo	{ 34, 0x07 },	\
1550259032Skevlo	{ 35, 0x12 },	\
1551259032Skevlo	{ 47, 0x0c },	\
1552259032Skevlo	{ 53, 0x22 },	\
1553259032Skevlo	{ 63, 0x07 }
1554259032Skevlo
1555259546Skevlo#define	RT5592_2GHZ_DEF_RF	\
1556259032Skevlo	{ 10, 0x90 },		\
1557259032Skevlo	{ 11, 0x4a },		\
1558259032Skevlo	{ 12, 0x52 },		\
1559259032Skevlo	{ 13, 0x42 },		\
1560259032Skevlo	{ 22, 0x40 },		\
1561259032Skevlo	{ 24, 0x4a },		\
1562259032Skevlo	{ 25, 0x80 },		\
1563259032Skevlo	{ 27, 0x42 },		\
1564259032Skevlo	{ 36, 0x80 },		\
1565259032Skevlo	{ 37, 0x08 },		\
1566259032Skevlo	{ 38, 0x89 },		\
1567259032Skevlo	{ 39, 0x1b },		\
1568259032Skevlo	{ 40, 0x0d },		\
1569259032Skevlo	{ 41, 0x9b },		\
1570259032Skevlo	{ 42, 0xd5 },		\
1571259032Skevlo	{ 43, 0x72 },		\
1572259032Skevlo	{ 44, 0x0e },		\
1573259032Skevlo	{ 45, 0xa2 },		\
1574259032Skevlo	{ 46, 0x6b },		\
1575259032Skevlo	{ 48, 0x10 },		\
1576259032Skevlo	{ 51, 0x3e },		\
1577259032Skevlo	{ 52, 0x48 },		\
1578259032Skevlo	{ 54, 0x38 },		\
1579259032Skevlo	{ 56, 0xa1 },		\
1580259032Skevlo	{ 57, 0x00 },		\
1581259032Skevlo	{ 58, 0x39 },		\
1582259032Skevlo	{ 60, 0x45 },		\
1583259032Skevlo	{ 61, 0x91 },		\
1584259032Skevlo	{ 62, 0x39 }
1585259032Skevlo
1586259546Skevlo#define	RT5592_5GHZ_DEF_RF	\
1587259032Skevlo	{ 10, 0x97 },		\
1588259032Skevlo	{ 11, 0x40 },		\
1589259032Skevlo	{ 25, 0xbf },		\
1590259032Skevlo	{ 27, 0x42 },		\
1591259032Skevlo	{ 36, 0x00 },		\
1592259032Skevlo	{ 37, 0x04 },		\
1593259032Skevlo	{ 38, 0x85 },		\
1594259032Skevlo	{ 40, 0x42 },		\
1595259032Skevlo	{ 41, 0xbb },		\
1596259032Skevlo	{ 42, 0xd7 },		\
1597259032Skevlo	{ 45, 0x41 },		\
1598259032Skevlo	{ 48, 0x00 },		\
1599259032Skevlo	{ 57, 0x77 },		\
1600259032Skevlo	{ 60, 0x05 },		\
1601259032Skevlo	{ 61, 0x01 }
1602259032Skevlo
1603259546Skevlo#define	RT5592_CHAN_5GHZ	\
1604259032Skevlo	{  36,  64, 12, 0x2e },	\
1605259032Skevlo	{ 100, 165, 12, 0x0e },	\
1606259032Skevlo	{  36,  64, 13, 0x22 },	\
1607259032Skevlo	{ 100, 165, 13, 0x42 },	\
1608259032Skevlo	{  36,  64, 22, 0x60 },	\
1609259032Skevlo	{ 100, 165, 22, 0x40 },	\
1610259032Skevlo	{  36,  64, 23, 0x7f },	\
1611259032Skevlo	{ 100, 153, 23, 0x3c },	\
1612259032Skevlo	{ 155, 165, 23, 0x38 },	\
1613259032Skevlo	{  36,  50, 24, 0x09 },	\
1614259032Skevlo	{  52,  64, 24, 0x07 },	\
1615259032Skevlo	{ 100, 153, 24, 0x06 },	\
1616259032Skevlo	{ 155, 165, 24, 0x05 },	\
1617259032Skevlo	{  36,  64, 39, 0x1c },	\
1618259032Skevlo	{ 100, 138, 39, 0x1a },	\
1619259032Skevlo	{ 140, 165, 39, 0x18 },	\
1620259032Skevlo	{  36,  64, 43, 0x5b },	\
1621259032Skevlo	{ 100, 138, 43, 0x3b },	\
1622259032Skevlo	{ 140, 165, 43, 0x1b },	\
1623259032Skevlo	{  36,  64, 44, 0x40 },	\
1624259032Skevlo	{ 100, 138, 44, 0x20 },	\
1625259032Skevlo	{ 140, 165, 44, 0x10 },	\
1626259032Skevlo	{  36,  64, 46, 0x00 },	\
1627259032Skevlo	{ 100, 138, 46, 0x18 },	\
1628259032Skevlo	{ 140, 165, 46, 0x08 },	\
1629259032Skevlo	{  36,  64, 51, 0xfe },	\
1630259032Skevlo	{ 100, 124, 51, 0xfc },	\
1631259032Skevlo	{ 126, 165, 51, 0xec },	\
1632259032Skevlo	{  36,  64, 52, 0x0c },	\
1633259032Skevlo	{ 100, 138, 52, 0x06 },	\
1634259032Skevlo	{ 140, 165, 52, 0x06 },	\
1635259032Skevlo	{  36,  64, 54, 0xf8 },	\
1636259032Skevlo	{ 100, 165, 54, 0xeb },	\
1637259032Skevlo	{ 36,   50, 55, 0x06 },	\
1638259032Skevlo	{ 52,   64, 55, 0x04 },	\
1639259032Skevlo	{ 100, 138, 55, 0x01 },	\
1640259032Skevlo	{ 140, 165, 55, 0x00 },	\
1641259032Skevlo	{  36,  50, 56, 0xd3 },	\
1642259032Skevlo	{  52, 128, 56, 0xbb },	\
1643259032Skevlo	{ 130, 165, 56, 0xab },	\
1644259032Skevlo	{  36,  64, 58, 0x15 },	\
1645259032Skevlo	{ 100, 116, 58, 0x1d },	\
1646259032Skevlo	{ 118, 165, 58, 0x15 },	\
1647259032Skevlo	{  36,  64, 59, 0x7f },	\
1648259032Skevlo	{ 100, 138, 59, 0x3f },	\
1649259032Skevlo	{ 140, 165, 59, 0x7c },	\
1650259032Skevlo	{  36,  64, 62, 0x15 },	\
1651259032Skevlo	{ 100, 116, 62, 0x1d },	\
1652259032Skevlo	{ 118, 165, 62, 0x15 }
1653259032Skevlo
1654218676Shselaskyunion run_stats {
1655218676Shselasky	uint32_t	raw;
1656218676Shselasky	struct {
1657218676Shselasky		uint16_t	fail;
1658218676Shselasky		uint16_t	pad;
1659218676Shselasky	} error;
1660218676Shselasky	struct {
1661218676Shselasky		uint16_t	success;
1662218676Shselasky		uint16_t	retry;
1663218676Shselasky	} tx;
1664218676Shselasky} __aligned(4);
1665218676Shselasky
1666203134Sthompsa#endif	/* _IF_RUNREG_H_ */
1667