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