xref: /freebsd/sys/dev/ral/rt2560reg.h (revision 71625ec9ad2a9bc8c09784fbd23b759830e0ee5f)
19c6307b1SDamien Bergamini 
29c6307b1SDamien Bergamini /*-
39c6307b1SDamien Bergamini  * Copyright (c) 2005, 2006
49c6307b1SDamien Bergamini  *	Damien Bergamini <damien.bergamini@free.fr>
59c6307b1SDamien Bergamini  *
69c6307b1SDamien Bergamini  * Permission to use, copy, modify, and distribute this software for any
79c6307b1SDamien Bergamini  * purpose with or without fee is hereby granted, provided that the above
89c6307b1SDamien Bergamini  * copyright notice and this permission notice appear in all copies.
99c6307b1SDamien Bergamini  *
109c6307b1SDamien Bergamini  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
119c6307b1SDamien Bergamini  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
129c6307b1SDamien Bergamini  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
139c6307b1SDamien Bergamini  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
149c6307b1SDamien Bergamini  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
159c6307b1SDamien Bergamini  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
169c6307b1SDamien Bergamini  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
179c6307b1SDamien Bergamini  */
189c6307b1SDamien Bergamini 
1968e8e04eSSam Leffler #define RT2560_DEFAULT_RSSI_CORR	0x79
2068e8e04eSSam Leffler #define RT2560_NOISE_FLOOR		-95
2168e8e04eSSam Leffler 
229c6307b1SDamien Bergamini #define RT2560_TX_RING_COUNT		48
239c6307b1SDamien Bergamini #define RT2560_ATIM_RING_COUNT		4
249c6307b1SDamien Bergamini #define RT2560_PRIO_RING_COUNT		16
259c6307b1SDamien Bergamini #define RT2560_BEACON_RING_COUNT	1
269c6307b1SDamien Bergamini #define RT2560_RX_RING_COUNT		32
279c6307b1SDamien Bergamini 
289c6307b1SDamien Bergamini #define RT2560_TX_DESC_SIZE	(sizeof (struct rt2560_tx_desc))
299c6307b1SDamien Bergamini #define RT2560_RX_DESC_SIZE	(sizeof (struct rt2560_rx_desc))
309c6307b1SDamien Bergamini 
319c6307b1SDamien Bergamini #define RT2560_MAX_SCATTER	1
329c6307b1SDamien Bergamini 
339c6307b1SDamien Bergamini /*
349c6307b1SDamien Bergamini  * Control and status registers.
359c6307b1SDamien Bergamini  */
369c6307b1SDamien Bergamini #define RT2560_CSR0		0x0000	/* ASIC version number */
379c6307b1SDamien Bergamini #define RT2560_CSR1		0x0004	/* System control */
389c6307b1SDamien Bergamini #define RT2560_CSR3		0x000c	/* STA MAC address 0 */
399c6307b1SDamien Bergamini #define RT2560_CSR4		0x0010	/* STA MAC address 1 */
409c6307b1SDamien Bergamini #define RT2560_CSR5		0x0014	/* BSSID 0 */
419c6307b1SDamien Bergamini #define RT2560_CSR6		0x0018	/* BSSID 1 */
429c6307b1SDamien Bergamini #define RT2560_CSR7		0x001c	/* Interrupt source */
439c6307b1SDamien Bergamini #define RT2560_CSR8		0x0020	/* Interrupt mask */
449c6307b1SDamien Bergamini #define RT2560_CSR9		0x0024	/* Maximum frame length */
459c6307b1SDamien Bergamini #define RT2560_SECCSR0		0x0028	/* WEP control */
469c6307b1SDamien Bergamini #define RT2560_CSR11		0x002c	/* Back-off control */
479c6307b1SDamien Bergamini #define RT2560_CSR12		0x0030	/* Synchronization configuration 0 */
489c6307b1SDamien Bergamini #define RT2560_CSR13		0x0034	/* Synchronization configuration 1 */
499c6307b1SDamien Bergamini #define RT2560_CSR14		0x0038	/* Synchronization control */
509c6307b1SDamien Bergamini #define RT2560_CSR15		0x003c	/* Synchronization status */
519c6307b1SDamien Bergamini #define RT2560_CSR16		0x0040	/* TSF timer 0 */
529c6307b1SDamien Bergamini #define RT2560_CSR17		0x0044	/* TSF timer 1 */
539c6307b1SDamien Bergamini #define RT2560_CSR18		0x0048	/* IFS timer 0 */
549c6307b1SDamien Bergamini #define RT2560_CSR19		0x004c	/* IFS timer 1 */
559c6307b1SDamien Bergamini #define RT2560_CSR20		0x0050	/* WAKEUP timer */
569c6307b1SDamien Bergamini #define RT2560_CSR21		0x0054	/* EEPROM control */
579c6307b1SDamien Bergamini #define RT2560_CSR22		0x0058	/* CFP control */
589c6307b1SDamien Bergamini #define RT2560_TXCSR0		0x0060	/* TX control */
599c6307b1SDamien Bergamini #define RT2560_TXCSR1		0x0064	/* TX configuration */
609c6307b1SDamien Bergamini #define RT2560_TXCSR2		0x0068	/* TX descriptor configuration */
619c6307b1SDamien Bergamini #define RT2560_TXCSR3		0x006c	/* TX ring base address */
629c6307b1SDamien Bergamini #define RT2560_TXCSR4		0x0070	/* TX ATIM ring base address */
639c6307b1SDamien Bergamini #define RT2560_TXCSR5		0x0074	/* TX PRIO ring base address */
649c6307b1SDamien Bergamini #define RT2560_TXCSR6		0x0078	/* Beacon base address */
659c6307b1SDamien Bergamini #define RT2560_TXCSR7		0x007c	/* AutoResponder control */
669c6307b1SDamien Bergamini #define RT2560_RXCSR0		0x0080	/* RX control */
679c6307b1SDamien Bergamini #define RT2560_RXCSR1		0x0084	/* RX descriptor configuration */
689c6307b1SDamien Bergamini #define RT2560_RXCSR2		0x0088	/* RX ring base address */
699c6307b1SDamien Bergamini #define RT2560_PCICSR		0x008c	/* PCI control */
709c6307b1SDamien Bergamini #define RT2560_RXCSR3		0x0090	/* BBP ID 0 */
719c6307b1SDamien Bergamini #define RT2560_TXCSR9		0x0094	/* OFDM TX BBP */
729c6307b1SDamien Bergamini #define RT2560_ARSP_PLCP_0	0x0098	/* Auto Responder PLCP address */
739c6307b1SDamien Bergamini #define RT2560_ARSP_PLCP_1	0x009c	/* Auto Responder Basic Rate mask */
749c6307b1SDamien Bergamini #define RT2560_CNT0		0x00a0	/* FCS error counter */
759c6307b1SDamien Bergamini #define RT2560_CNT1		0x00ac	/* PLCP error counter */
769c6307b1SDamien Bergamini #define RT2560_CNT2		0x00b0	/* Long error counter */
779c6307b1SDamien Bergamini #define RT2560_CNT3		0x00b8	/* CCA false alarm counter */
789c6307b1SDamien Bergamini #define RT2560_CNT4		0x00bc	/* RX FIFO Overflow counter */
799c6307b1SDamien Bergamini #define RT2560_CNT5		0x00c0	/* Tx FIFO Underrun counter */
809c6307b1SDamien Bergamini #define RT2560_PWRCSR0		0x00c4	/* Power mode configuration */
819c6307b1SDamien Bergamini #define RT2560_PSCSR0		0x00c8	/* Power state transition time */
829c6307b1SDamien Bergamini #define RT2560_PSCSR1		0x00cc	/* Power state transition time */
839c6307b1SDamien Bergamini #define RT2560_PSCSR2		0x00d0	/* Power state transition time */
849c6307b1SDamien Bergamini #define RT2560_PSCSR3		0x00d4	/* Power state transition time */
859c6307b1SDamien Bergamini #define RT2560_PWRCSR1		0x00d8	/* Manual power control/status */
869c6307b1SDamien Bergamini #define RT2560_TIMECSR		0x00dc	/* Timer control */
879c6307b1SDamien Bergamini #define RT2560_MACCSR0		0x00e0	/* MAC configuration */
889c6307b1SDamien Bergamini #define RT2560_MACCSR1		0x00e4	/* MAC configuration */
899c6307b1SDamien Bergamini #define RT2560_RALINKCSR	0x00e8	/* Ralink RX auto-reset BBCR */
909c6307b1SDamien Bergamini #define RT2560_BCNCSR		0x00ec	/* Beacon interval control */
919c6307b1SDamien Bergamini #define RT2560_BBPCSR		0x00f0	/* BBP serial control */
929c6307b1SDamien Bergamini #define RT2560_RFCSR		0x00f4	/* RF serial control */
939c6307b1SDamien Bergamini #define RT2560_LEDCSR		0x00f8	/* LED control */
949c6307b1SDamien Bergamini #define RT2560_SECCSR3		0x00fc	/* XXX not documented */
959c6307b1SDamien Bergamini #define RT2560_DMACSR0		0x0100	/* Current RX ring address */
969c6307b1SDamien Bergamini #define RT2560_DMACSR1		0x0104	/* Current Tx ring address */
979c6307b1SDamien Bergamini #define RT2560_DMACSR2		0x0104	/* Current Priority ring address */
989c6307b1SDamien Bergamini #define RT2560_DMACSR3		0x0104	/* Current ATIM ring address */
999c6307b1SDamien Bergamini #define RT2560_TXACKCSR0	0x0110	/* XXX not documented */
1009c6307b1SDamien Bergamini #define RT2560_GPIOCSR		0x0120	/* */
1019c6307b1SDamien Bergamini #define RT2560_BBBPPCSR		0x0124	/* BBP Pin Control */
1029c6307b1SDamien Bergamini #define RT2560_FIFOCSR0		0x0128	/* TX FIFO pointer */
1039c6307b1SDamien Bergamini #define RT2560_FIFOCSR1		0x012c	/* RX FIFO pointer */
1049c6307b1SDamien Bergamini #define RT2560_BCNOCSR		0x0130	/* Beacon time offset */
1059c6307b1SDamien Bergamini #define RT2560_RLPWCSR		0x0134	/* RX_PE Low Width */
1069c6307b1SDamien Bergamini #define RT2560_TESTCSR		0x0138	/* Test Mode Select */
1079c6307b1SDamien Bergamini #define RT2560_PLCP1MCSR	0x013c	/* Signal/Service/Length of ACK @1M */
1089c6307b1SDamien Bergamini #define RT2560_PLCP2MCSR	0x0140	/* Signal/Service/Length of ACK @2M */
1099c6307b1SDamien Bergamini #define RT2560_PLCP5p5MCSR	0x0144	/* Signal/Service/Length of ACK @5.5M */
1109c6307b1SDamien Bergamini #define RT2560_PLCP11MCSR	0x0148	/* Signal/Service/Length of ACK @11M */
1119c6307b1SDamien Bergamini #define RT2560_ACKPCTCSR	0x014c	/* ACK/CTS padload consume time */
1129c6307b1SDamien Bergamini #define RT2560_ARTCSR1		0x0150	/* ACK/CTS padload consume time */
1139c6307b1SDamien Bergamini #define RT2560_ARTCSR2		0x0154	/* ACK/CTS padload consume time */
1149c6307b1SDamien Bergamini #define RT2560_SECCSR1		0x0158	/* WEP control */
1159c6307b1SDamien Bergamini #define RT2560_BBPCSR1		0x015c	/* BBP TX Configuration */
1169c6307b1SDamien Bergamini 
1179c6307b1SDamien Bergamini /* possible flags for register RXCSR0 */
1189c6307b1SDamien Bergamini #define RT2560_DISABLE_RX		(1 << 0)
1199c6307b1SDamien Bergamini #define RT2560_DROP_CRC_ERROR		(1 << 1)
1209c6307b1SDamien Bergamini #define RT2560_DROP_PHY_ERROR		(1 << 2)
1219c6307b1SDamien Bergamini #define RT2560_DROP_CTL			(1 << 3)
1229c6307b1SDamien Bergamini #define RT2560_DROP_NOT_TO_ME		(1 << 4)
1239c6307b1SDamien Bergamini #define RT2560_DROP_TODS		(1 << 5)
1249c6307b1SDamien Bergamini #define RT2560_DROP_VERSION_ERROR	(1 << 6)
1259c6307b1SDamien Bergamini 
1269c6307b1SDamien Bergamini /* possible flags for register CSR1 */
1279c6307b1SDamien Bergamini #define RT2560_RESET_ASIC	(1 << 0)
1289c6307b1SDamien Bergamini #define RT2560_RESET_BBP	(1 << 1)
1299c6307b1SDamien Bergamini #define RT2560_HOST_READY	(1 << 2)
1309c6307b1SDamien Bergamini 
1319c6307b1SDamien Bergamini /* possible flags for register CSR14 */
1329c6307b1SDamien Bergamini #define RT2560_ENABLE_TSF		(1 << 0)
1339c6307b1SDamien Bergamini #define RT2560_ENABLE_TSF_SYNC(x)	(((x) & 0x3) << 1)
1349c6307b1SDamien Bergamini #define RT2560_ENABLE_TBCN		(1 << 3)
1359c6307b1SDamien Bergamini #define RT2560_ENABLE_BEACON_GENERATOR	(1 << 6)
1369c6307b1SDamien Bergamini 
1379c6307b1SDamien Bergamini /* possible flags for register CSR21 */
1389c6307b1SDamien Bergamini #define RT2560_C	(1 << 1)
1399c6307b1SDamien Bergamini #define RT2560_S	(1 << 2)
1409c6307b1SDamien Bergamini #define RT2560_D	(1 << 3)
1419c6307b1SDamien Bergamini #define RT2560_Q	(1 << 4)
1429c6307b1SDamien Bergamini #define RT2560_93C46	(1 << 5)
1439c6307b1SDamien Bergamini 
1449c6307b1SDamien Bergamini #define RT2560_SHIFT_D	3
1459c6307b1SDamien Bergamini #define RT2560_SHIFT_Q	4
1469c6307b1SDamien Bergamini 
1479c6307b1SDamien Bergamini /* possible flags for register TXCSR0 */
1489c6307b1SDamien Bergamini #define RT2560_KICK_TX		(1 << 0)
1499c6307b1SDamien Bergamini #define RT2560_KICK_ATIM	(1 << 1)
1509c6307b1SDamien Bergamini #define RT2560_KICK_PRIO	(1 << 2)
1519c6307b1SDamien Bergamini #define RT2560_ABORT_TX		(1 << 3)
1529c6307b1SDamien Bergamini 
1539c6307b1SDamien Bergamini /* possible flags for register SECCSR0 */
1549c6307b1SDamien Bergamini #define RT2560_KICK_DECRYPT	(1 << 0)
1559c6307b1SDamien Bergamini 
1569c6307b1SDamien Bergamini /* possible flags for register SECCSR1 */
1579c6307b1SDamien Bergamini #define RT2560_KICK_ENCRYPT	(1 << 0)
1589c6307b1SDamien Bergamini 
1599c6307b1SDamien Bergamini /* possible flags for register CSR7 */
1609c6307b1SDamien Bergamini #define RT2560_BEACON_EXPIRE	0x00000001
1619c6307b1SDamien Bergamini #define RT2560_WAKEUP_EXPIRE	0x00000002
1629c6307b1SDamien Bergamini #define RT2560_ATIM_EXPIRE	0x00000004
1639c6307b1SDamien Bergamini #define RT2560_TX_DONE		0x00000008
1649c6307b1SDamien Bergamini #define RT2560_ATIM_DONE	0x00000010
1659c6307b1SDamien Bergamini #define RT2560_PRIO_DONE	0x00000020
1669c6307b1SDamien Bergamini #define RT2560_RX_DONE		0x00000040
1679c6307b1SDamien Bergamini #define RT2560_DECRYPTION_DONE	0x00000080
1689c6307b1SDamien Bergamini #define RT2560_ENCRYPTION_DONE	0x00000100
1699c6307b1SDamien Bergamini 
1709c6307b1SDamien Bergamini #define RT2560_INTR_MASK							\
1719c6307b1SDamien Bergamini 	(~(RT2560_BEACON_EXPIRE | RT2560_WAKEUP_EXPIRE | RT2560_TX_DONE |	\
1729c6307b1SDamien Bergamini 	   RT2560_PRIO_DONE | RT2560_RX_DONE | RT2560_DECRYPTION_DONE |		\
1739c6307b1SDamien Bergamini 	   RT2560_ENCRYPTION_DONE))
1749c6307b1SDamien Bergamini 
1759c6307b1SDamien Bergamini /* Tx descriptor */
1769c6307b1SDamien Bergamini struct rt2560_tx_desc {
1779c6307b1SDamien Bergamini 	uint32_t	flags;
1789c6307b1SDamien Bergamini #define RT2560_TX_BUSY			(1 << 0)
1799c6307b1SDamien Bergamini #define RT2560_TX_VALID			(1 << 1)
1809c6307b1SDamien Bergamini 
1819c6307b1SDamien Bergamini #define RT2560_TX_RESULT_MASK		0x0000001c
1829c6307b1SDamien Bergamini #define RT2560_TX_SUCCESS		(0 << 2)
1839c6307b1SDamien Bergamini #define RT2560_TX_SUCCESS_RETRY		(1 << 2)
1849c6307b1SDamien Bergamini #define RT2560_TX_FAIL_RETRY		(2 << 2)
1859c6307b1SDamien Bergamini #define RT2560_TX_FAIL_INVALID		(3 << 2)
1869c6307b1SDamien Bergamini #define RT2560_TX_FAIL_OTHER		(4 << 2)
1879c6307b1SDamien Bergamini 
1889c6307b1SDamien Bergamini #define RT2560_TX_MORE_FRAG		(1 << 8)
1899c6307b1SDamien Bergamini #define RT2560_TX_ACK			(1 << 9)
1909c6307b1SDamien Bergamini #define RT2560_TX_TIMESTAMP		(1 << 10)
1919c6307b1SDamien Bergamini #define RT2560_TX_OFDM			(1 << 11)
1929c6307b1SDamien Bergamini #define RT2560_TX_CIPHER_BUSY		(1 << 12)
1939c6307b1SDamien Bergamini 
1949c6307b1SDamien Bergamini #define RT2560_TX_IFS_MASK		0x00006000
1959c6307b1SDamien Bergamini #define RT2560_TX_IFS_BACKOFF		(0 << 13)
1969c6307b1SDamien Bergamini #define RT2560_TX_IFS_SIFS		(1 << 13)
1979c6307b1SDamien Bergamini #define RT2560_TX_IFS_NEWBACKOFF	(2 << 13)
1989c6307b1SDamien Bergamini #define RT2560_TX_IFS_NONE		(3 << 13)
1999c6307b1SDamien Bergamini 
2009c6307b1SDamien Bergamini #define RT2560_TX_LONG_RETRY		(1 << 15)
2019c6307b1SDamien Bergamini 
2029c6307b1SDamien Bergamini #define RT2560_TX_CIPHER_MASK		0xe0000000
2039c6307b1SDamien Bergamini #define RT2560_TX_CIPHER_NONE		(0 << 29)
2049c6307b1SDamien Bergamini #define RT2560_TX_CIPHER_WEP40		(1 << 29)
2059c6307b1SDamien Bergamini #define RT2560_TX_CIPHER_WEP104		(2 << 29)
2069c6307b1SDamien Bergamini #define RT2560_TX_CIPHER_TKIP		(3 << 29)
2079c6307b1SDamien Bergamini #define RT2560_TX_CIPHER_AES		(4 << 29)
2089c6307b1SDamien Bergamini 
209b032f27cSSam Leffler #define RT2560_TX_RETRYCNT(v)	(((v) >> 5) & 0x7)
210b032f27cSSam Leffler 
2119c6307b1SDamien Bergamini 	uint32_t	physaddr;
2129c6307b1SDamien Bergamini 	uint16_t	wme;
2139c6307b1SDamien Bergamini #define RT2560_LOGCWMAX(x)	(((x) & 0xf) << 12)
2149c6307b1SDamien Bergamini #define RT2560_LOGCWMIN(x)	(((x) & 0xf) << 8)
2159c6307b1SDamien Bergamini #define RT2560_AIFSN(x)		(((x) & 0x3) << 6)
2169c6307b1SDamien Bergamini #define RT2560_IVOFFSET(x)	(((x) & 0x3f))
2179c6307b1SDamien Bergamini 
2189c6307b1SDamien Bergamini 	uint16_t	reserved1;
2199c6307b1SDamien Bergamini 	uint8_t		plcp_signal;
2209c6307b1SDamien Bergamini 	uint8_t		plcp_service;
2219c6307b1SDamien Bergamini #define RT2560_PLCP_LENGEXT	0x80
2229c6307b1SDamien Bergamini 
2239c6307b1SDamien Bergamini 	uint8_t		plcp_length_lo;
2249c6307b1SDamien Bergamini 	uint8_t		plcp_length_hi;
2259c6307b1SDamien Bergamini 	uint32_t	iv;
2269c6307b1SDamien Bergamini 	uint32_t	eiv;
2279c6307b1SDamien Bergamini 	uint8_t		key[IEEE80211_KEYBUF_SIZE];
2289c6307b1SDamien Bergamini 	uint32_t	reserved2[2];
2299c6307b1SDamien Bergamini } __packed;
2309c6307b1SDamien Bergamini 
2319c6307b1SDamien Bergamini /* Rx descriptor */
2329c6307b1SDamien Bergamini struct rt2560_rx_desc {
2339c6307b1SDamien Bergamini 	uint32_t	flags;
2349c6307b1SDamien Bergamini #define RT2560_RX_BUSY		(1 << 0)
2359c6307b1SDamien Bergamini #define RT2560_RX_CRC_ERROR	(1 << 5)
2369c6307b1SDamien Bergamini #define RT2560_RX_OFDM		(1 << 6)
2379c6307b1SDamien Bergamini #define RT2560_RX_PHY_ERROR	(1 << 7)
2389c6307b1SDamien Bergamini #define RT2560_RX_CIPHER_BUSY	(1 << 8)
2399c6307b1SDamien Bergamini #define RT2560_RX_ICV_ERROR	(1 << 9)
2409c6307b1SDamien Bergamini 
2419c6307b1SDamien Bergamini #define RT2560_RX_CIPHER_MASK	0xe0000000
2429c6307b1SDamien Bergamini #define RT2560_RX_CIPHER_NONE	(0 << 29)
2439c6307b1SDamien Bergamini #define RT2560_RX_CIPHER_WEP40	(1 << 29)
2449c6307b1SDamien Bergamini #define RT2560_RX_CIPHER_WEP104	(2 << 29)
2459c6307b1SDamien Bergamini #define RT2560_RX_CIPHER_TKIP	(3 << 29)
2469c6307b1SDamien Bergamini #define RT2560_RX_CIPHER_AES	(4 << 29)
2479c6307b1SDamien Bergamini 
2489c6307b1SDamien Bergamini 	uint32_t	physaddr;
2499c6307b1SDamien Bergamini 	uint8_t		rate;
2509c6307b1SDamien Bergamini 	uint8_t		rssi;
2519c6307b1SDamien Bergamini 	uint8_t		ta[IEEE80211_ADDR_LEN];
2529c6307b1SDamien Bergamini 	uint32_t	iv;
2539c6307b1SDamien Bergamini 	uint32_t	eiv;
2549c6307b1SDamien Bergamini 	uint8_t		key[IEEE80211_KEYBUF_SIZE];
2559c6307b1SDamien Bergamini 	uint32_t	reserved[2];
2569c6307b1SDamien Bergamini } __packed;
2579c6307b1SDamien Bergamini 
2589c6307b1SDamien Bergamini #define RAL_RF1	0
2599c6307b1SDamien Bergamini #define RAL_RF2	2
2609c6307b1SDamien Bergamini #define RAL_RF3	1
2619c6307b1SDamien Bergamini #define RAL_RF4	3
2629c6307b1SDamien Bergamini 
2639c6307b1SDamien Bergamini #define RT2560_RF1_AUTOTUNE	0x08000
2649c6307b1SDamien Bergamini #define RT2560_RF3_AUTOTUNE	0x00040
2659c6307b1SDamien Bergamini 
2669c6307b1SDamien Bergamini #define RT2560_BBP_BUSY		(1 << 15)
2679c6307b1SDamien Bergamini #define RT2560_BBP_WRITE	(1 << 16)
2689c6307b1SDamien Bergamini #define RT2560_RF_20BIT		(20 << 24)
269*7a22215cSEitan Adler #define RT2560_RF_BUSY		(1U << 31)
2709c6307b1SDamien Bergamini 
2719c6307b1SDamien Bergamini #define RT2560_RF_2522	0x00
2729c6307b1SDamien Bergamini #define RT2560_RF_2523	0x01
2739c6307b1SDamien Bergamini #define RT2560_RF_2524	0x02
2749c6307b1SDamien Bergamini #define RT2560_RF_2525	0x03
2759c6307b1SDamien Bergamini #define RT2560_RF_2525E	0x04
2769c6307b1SDamien Bergamini #define RT2560_RF_2526	0x05
2779c6307b1SDamien Bergamini /* dual-band RF */
2789c6307b1SDamien Bergamini #define RT2560_RF_5222	0x10
2799c6307b1SDamien Bergamini 
2809c6307b1SDamien Bergamini #define RT2560_BBP_VERSION	0
2819c6307b1SDamien Bergamini #define RT2560_BBP_TX		2
2829c6307b1SDamien Bergamini #define RT2560_BBP_RX		14
2839c6307b1SDamien Bergamini 
2849c6307b1SDamien Bergamini #define RT2560_BBP_ANTA		0x00
2859c6307b1SDamien Bergamini #define RT2560_BBP_DIVERSITY	0x01
2869c6307b1SDamien Bergamini #define RT2560_BBP_ANTB		0x02
2879c6307b1SDamien Bergamini #define RT2560_BBP_ANTMASK	0x03
2889c6307b1SDamien Bergamini #define RT2560_BBP_FLIPIQ	0x04
2899c6307b1SDamien Bergamini 
2909c6307b1SDamien Bergamini #define RT2560_LED_MODE_DEFAULT		0
2919c6307b1SDamien Bergamini #define RT2560_LED_MODE_TXRX_ACTIVITY	1
2929c6307b1SDamien Bergamini #define RT2560_LED_MODE_SINGLE		2
2939c6307b1SDamien Bergamini #define RT2560_LED_MODE_ASUS		3
2949c6307b1SDamien Bergamini 
2959c6307b1SDamien Bergamini #define RT2560_JAPAN_FILTER	0x8
2969c6307b1SDamien Bergamini 
2979c6307b1SDamien Bergamini #define RT2560_EEPROM_DELAY	1	/* minimum hold time (microsecond) */
2989c6307b1SDamien Bergamini 
2999c6307b1SDamien Bergamini #define RT2560_EEPROM_CONFIG0	16
3009c6307b1SDamien Bergamini #define RT2560_EEPROM_BBP_BASE	19
3019c6307b1SDamien Bergamini #define RT2560_EEPROM_TXPOWER	35
30268e8e04eSSam Leffler #define RT2560_EEPROM_CALIBRATE	62
3039c6307b1SDamien Bergamini 
3049c6307b1SDamien Bergamini /*
3059c6307b1SDamien Bergamini  * control and status registers access macros
3069c6307b1SDamien Bergamini  */
3079c6307b1SDamien Bergamini #define RAL_READ(sc, reg)						\
3089c6307b1SDamien Bergamini 	bus_space_read_4((sc)->sc_st, (sc)->sc_sh, (reg))
3099c6307b1SDamien Bergamini 
3109c6307b1SDamien Bergamini #define RAL_WRITE(sc, reg, val)						\
3119c6307b1SDamien Bergamini 	bus_space_write_4((sc)->sc_st, (sc)->sc_sh, (reg), (val))
3129c6307b1SDamien Bergamini 
3139c6307b1SDamien Bergamini /*
3149c6307b1SDamien Bergamini  * EEPROM access macro
3159c6307b1SDamien Bergamini  */
3169c6307b1SDamien Bergamini #define RT2560_EEPROM_CTL(sc, val) do {					\
3179c6307b1SDamien Bergamini 	RAL_WRITE((sc), RT2560_CSR21, (val));				\
3189c6307b1SDamien Bergamini 	DELAY(RT2560_EEPROM_DELAY);					\
3199c6307b1SDamien Bergamini } while (/* CONSTCOND */0)
3209c6307b1SDamien Bergamini 
3219c6307b1SDamien Bergamini /*
3229c6307b1SDamien Bergamini  * Default values for MAC registers; values taken from the reference driver.
3239c6307b1SDamien Bergamini  */
3249c6307b1SDamien Bergamini #define RT2560_DEF_MAC				\
3259c6307b1SDamien Bergamini 	{ RT2560_PSCSR0,      0x00020002 },	\
3269c6307b1SDamien Bergamini 	{ RT2560_PSCSR1,      0x00000002 },	\
3279c6307b1SDamien Bergamini 	{ RT2560_PSCSR2,      0x00020002 },	\
3289c6307b1SDamien Bergamini 	{ RT2560_PSCSR3,      0x00000002 },	\
3299c6307b1SDamien Bergamini 	{ RT2560_TIMECSR,     0x00003f21 },	\
3309c6307b1SDamien Bergamini 	{ RT2560_CSR9,        0x00000780 },	\
3319c6307b1SDamien Bergamini 	{ RT2560_CSR11,       0x07041483 },	\
3329c6307b1SDamien Bergamini 	{ RT2560_CNT3,        0x00000000 },	\
3339c6307b1SDamien Bergamini 	{ RT2560_TXCSR1,      0x07614562 },	\
3349c6307b1SDamien Bergamini 	{ RT2560_ARSP_PLCP_0, 0x8c8d8b8a },	\
3359c6307b1SDamien Bergamini 	{ RT2560_ACKPCTCSR,   0x7038140a },	\
3364d494753SSepherosa Ziehau 	{ RT2560_ARTCSR1,     0x21212929 },	\
3374d494753SSepherosa Ziehau 	{ RT2560_ARTCSR2,     0x1d1d1d1d },	\
3389c6307b1SDamien Bergamini 	{ RT2560_RXCSR0,      0xffffffff },	\
3399c6307b1SDamien Bergamini 	{ RT2560_RXCSR3,      0xb3aab3af },	\
3409c6307b1SDamien Bergamini 	{ RT2560_PCICSR,      0x000003b8 },	\
3419c6307b1SDamien Bergamini 	{ RT2560_PWRCSR0,     0x3f3b3100 },	\
3429c6307b1SDamien Bergamini 	{ RT2560_GPIOCSR,     0x0000ff00 },	\
3439c6307b1SDamien Bergamini 	{ RT2560_TESTCSR,     0x000000f0 },	\
3449c6307b1SDamien Bergamini 	{ RT2560_PWRCSR1,     0x000001ff },	\
3459c6307b1SDamien Bergamini 	{ RT2560_MACCSR0,     0x00213223 },	\
3469c6307b1SDamien Bergamini 	{ RT2560_MACCSR1,     0x00235518 },	\
3479c6307b1SDamien Bergamini 	{ RT2560_RLPWCSR,     0x00000040 },	\
3489c6307b1SDamien Bergamini 	{ RT2560_RALINKCSR,   0x9a009a11 },	\
3499c6307b1SDamien Bergamini 	{ RT2560_CSR7,        0xffffffff },	\
3509c6307b1SDamien Bergamini 	{ RT2560_BBPCSR1,     0x82188200 },	\
3519c6307b1SDamien Bergamini 	{ RT2560_TXACKCSR0,   0x00000020 },	\
3529c6307b1SDamien Bergamini 	{ RT2560_SECCSR3,     0x0000e78f }
3539c6307b1SDamien Bergamini 
3549c6307b1SDamien Bergamini /*
3559c6307b1SDamien Bergamini  * Default values for BBP registers; values taken from the reference driver.
3569c6307b1SDamien Bergamini  */
3579c6307b1SDamien Bergamini #define RT2560_DEF_BBP	\
3589c6307b1SDamien Bergamini 	{  3, 0x02 },	\
3599c6307b1SDamien Bergamini 	{  4, 0x19 },	\
3609c6307b1SDamien Bergamini 	{ 14, 0x1c },	\
3619c6307b1SDamien Bergamini 	{ 15, 0x30 },	\
3629c6307b1SDamien Bergamini 	{ 16, 0xac },	\
3639c6307b1SDamien Bergamini 	{ 17, 0x48 },	\
3649c6307b1SDamien Bergamini 	{ 18, 0x18 },	\
3659c6307b1SDamien Bergamini 	{ 19, 0xff },	\
3669c6307b1SDamien Bergamini 	{ 20, 0x1e },	\
3679c6307b1SDamien Bergamini 	{ 21, 0x08 },	\
3689c6307b1SDamien Bergamini 	{ 22, 0x08 },	\
3699c6307b1SDamien Bergamini 	{ 23, 0x08 },	\
3709c6307b1SDamien Bergamini 	{ 24, 0x80 },	\
3719c6307b1SDamien Bergamini 	{ 25, 0x50 },	\
3729c6307b1SDamien Bergamini 	{ 26, 0x08 },	\
3739c6307b1SDamien Bergamini 	{ 27, 0x23 },	\
3749c6307b1SDamien Bergamini 	{ 30, 0x10 },	\
3759c6307b1SDamien Bergamini 	{ 31, 0x2b },	\
3769c6307b1SDamien Bergamini 	{ 32, 0xb9 },	\
3779c6307b1SDamien Bergamini 	{ 34, 0x12 },	\
3789c6307b1SDamien Bergamini 	{ 35, 0x50 },	\
3799c6307b1SDamien Bergamini 	{ 39, 0xc4 },	\
3809c6307b1SDamien Bergamini 	{ 40, 0x02 },	\
3819c6307b1SDamien Bergamini 	{ 41, 0x60 },	\
3829c6307b1SDamien Bergamini 	{ 53, 0x10 },	\
3839c6307b1SDamien Bergamini 	{ 54, 0x18 },	\
3849c6307b1SDamien Bergamini 	{ 56, 0x08 },	\
3859c6307b1SDamien Bergamini 	{ 57, 0x10 },	\
3869c6307b1SDamien Bergamini 	{ 58, 0x08 },	\
3879c6307b1SDamien Bergamini 	{ 61, 0x60 },	\
3889c6307b1SDamien Bergamini 	{ 62, 0x10 },	\
3899c6307b1SDamien Bergamini 	{ 75, 0xff }
3909c6307b1SDamien Bergamini 
3919c6307b1SDamien Bergamini /*
3929c6307b1SDamien Bergamini  * Default values for RF register R2 indexed by channel numbers; values taken
3939c6307b1SDamien Bergamini  * from the reference driver.
3949c6307b1SDamien Bergamini  */
3959c6307b1SDamien Bergamini #define RT2560_RF2522_R2						\
3969c6307b1SDamien Bergamini {									\
3979c6307b1SDamien Bergamini 	0x307f6, 0x307fb, 0x30800, 0x30805, 0x3080a, 0x3080f, 0x30814,	\
3989c6307b1SDamien Bergamini 	0x30819, 0x3081e, 0x30823, 0x30828, 0x3082d, 0x30832, 0x3083e	\
3999c6307b1SDamien Bergamini }
4009c6307b1SDamien Bergamini 
4019c6307b1SDamien Bergamini #define RT2560_RF2523_R2						\
4029c6307b1SDamien Bergamini {									\
4039c6307b1SDamien Bergamini 	0x00327, 0x00328, 0x00329, 0x0032a, 0x0032b, 0x0032c, 0x0032d,	\
4049c6307b1SDamien Bergamini 	0x0032e, 0x0032f, 0x00340, 0x00341, 0x00342, 0x00343, 0x00346	\
4059c6307b1SDamien Bergamini }
4069c6307b1SDamien Bergamini 
4079c6307b1SDamien Bergamini #define RT2560_RF2524_R2						\
4089c6307b1SDamien Bergamini {									\
4099c6307b1SDamien Bergamini 	0x00327, 0x00328, 0x00329, 0x0032a, 0x0032b, 0x0032c, 0x0032d,	\
4109c6307b1SDamien Bergamini 	0x0032e, 0x0032f, 0x00340, 0x00341, 0x00342, 0x00343, 0x00346	\
4119c6307b1SDamien Bergamini }
4129c6307b1SDamien Bergamini 
4139c6307b1SDamien Bergamini #define RT2560_RF2525_R2						\
4149c6307b1SDamien Bergamini {									\
4159c6307b1SDamien Bergamini 	0x20327, 0x20328, 0x20329, 0x2032a, 0x2032b, 0x2032c, 0x2032d,	\
4169c6307b1SDamien Bergamini 	0x2032e, 0x2032f, 0x20340, 0x20341, 0x20342, 0x20343, 0x20346	\
4179c6307b1SDamien Bergamini }
4189c6307b1SDamien Bergamini 
4199c6307b1SDamien Bergamini #define RT2560_RF2525_HI_R2						\
4209c6307b1SDamien Bergamini {									\
4219c6307b1SDamien Bergamini 	0x2032f, 0x20340, 0x20341, 0x20342, 0x20343, 0x20344, 0x20345,	\
4229c6307b1SDamien Bergamini 	0x20346, 0x20347, 0x20348, 0x20349, 0x2034a, 0x2034b, 0x2034e	\
4239c6307b1SDamien Bergamini }
4249c6307b1SDamien Bergamini 
4259c6307b1SDamien Bergamini #define RT2560_RF2525E_R2						\
4269c6307b1SDamien Bergamini {									\
4279c6307b1SDamien Bergamini 	0x2044d, 0x2044e, 0x2044f, 0x20460, 0x20461, 0x20462, 0x20463,	\
4289c6307b1SDamien Bergamini 	0x20464, 0x20465, 0x20466, 0x20467, 0x20468, 0x20469, 0x2046b	\
4299c6307b1SDamien Bergamini }
4309c6307b1SDamien Bergamini 
4319c6307b1SDamien Bergamini #define RT2560_RF2526_HI_R2						\
4329c6307b1SDamien Bergamini {									\
4339c6307b1SDamien Bergamini 	0x0022a, 0x0022b, 0x0022b, 0x0022c, 0x0022c, 0x0022d, 0x0022d,	\
4349c6307b1SDamien Bergamini 	0x0022e, 0x0022e, 0x0022f, 0x0022d, 0x00240, 0x00240, 0x00241	\
4359c6307b1SDamien Bergamini }
4369c6307b1SDamien Bergamini 
4379c6307b1SDamien Bergamini #define RT2560_RF2526_R2						\
4389c6307b1SDamien Bergamini {									\
4399c6307b1SDamien Bergamini 	0x00226, 0x00227, 0x00227, 0x00228, 0x00228, 0x00229, 0x00229,	\
4409c6307b1SDamien Bergamini 	0x0022a, 0x0022a, 0x0022b, 0x0022b, 0x0022c, 0x0022c, 0x0022d	\
4419c6307b1SDamien Bergamini }
4429c6307b1SDamien Bergamini 
4439c6307b1SDamien Bergamini /*
4449c6307b1SDamien Bergamini  * For dual-band RF, RF registers R1 and R4 also depend on channel number;
4459c6307b1SDamien Bergamini  * values taken from the reference driver.
4469c6307b1SDamien Bergamini  */
4479c6307b1SDamien Bergamini #define RT2560_RF5222				\
4489c6307b1SDamien Bergamini 	{   1, 0x08808, 0x0044d, 0x00282 },	\
4499c6307b1SDamien Bergamini 	{   2, 0x08808, 0x0044e, 0x00282 },	\
4509c6307b1SDamien Bergamini 	{   3, 0x08808, 0x0044f, 0x00282 },	\
4519c6307b1SDamien Bergamini 	{   4, 0x08808, 0x00460, 0x00282 },	\
4529c6307b1SDamien Bergamini 	{   5, 0x08808, 0x00461, 0x00282 },	\
4539c6307b1SDamien Bergamini 	{   6, 0x08808, 0x00462, 0x00282 },	\
4549c6307b1SDamien Bergamini 	{   7, 0x08808, 0x00463, 0x00282 },	\
4559c6307b1SDamien Bergamini 	{   8, 0x08808, 0x00464, 0x00282 },	\
4569c6307b1SDamien Bergamini 	{   9, 0x08808, 0x00465, 0x00282 },	\
4579c6307b1SDamien Bergamini 	{  10, 0x08808, 0x00466, 0x00282 },	\
4589c6307b1SDamien Bergamini 	{  11, 0x08808, 0x00467, 0x00282 },	\
4599c6307b1SDamien Bergamini 	{  12, 0x08808, 0x00468, 0x00282 },	\
4609c6307b1SDamien Bergamini 	{  13, 0x08808, 0x00469, 0x00282 },	\
4619c6307b1SDamien Bergamini 	{  14, 0x08808, 0x0046b, 0x00286 },	\
4629c6307b1SDamien Bergamini 						\
4639c6307b1SDamien Bergamini 	{  36, 0x08804, 0x06225, 0x00287 },	\
4649c6307b1SDamien Bergamini 	{  40, 0x08804, 0x06226, 0x00287 },	\
4659c6307b1SDamien Bergamini 	{  44, 0x08804, 0x06227, 0x00287 },	\
4669c6307b1SDamien Bergamini 	{  48, 0x08804, 0x06228, 0x00287 },	\
4679c6307b1SDamien Bergamini 	{  52, 0x08804, 0x06229, 0x00287 },	\
4689c6307b1SDamien Bergamini 	{  56, 0x08804, 0x0622a, 0x00287 },	\
4699c6307b1SDamien Bergamini 	{  60, 0x08804, 0x0622b, 0x00287 },	\
4709c6307b1SDamien Bergamini 	{  64, 0x08804, 0x0622c, 0x00287 },	\
4719c6307b1SDamien Bergamini 						\
4729c6307b1SDamien Bergamini 	{ 100, 0x08804, 0x02200, 0x00283 },	\
4739c6307b1SDamien Bergamini 	{ 104, 0x08804, 0x02201, 0x00283 },	\
4749c6307b1SDamien Bergamini 	{ 108, 0x08804, 0x02202, 0x00283 },	\
4759c6307b1SDamien Bergamini 	{ 112, 0x08804, 0x02203, 0x00283 },	\
4769c6307b1SDamien Bergamini 	{ 116, 0x08804, 0x02204, 0x00283 },	\
4779c6307b1SDamien Bergamini 	{ 120, 0x08804, 0x02205, 0x00283 },	\
4789c6307b1SDamien Bergamini 	{ 124, 0x08804, 0x02206, 0x00283 },	\
4799c6307b1SDamien Bergamini 	{ 128, 0x08804, 0x02207, 0x00283 },	\
4809c6307b1SDamien Bergamini 	{ 132, 0x08804, 0x02208, 0x00283 },	\
4819c6307b1SDamien Bergamini 	{ 136, 0x08804, 0x02209, 0x00283 },	\
4829c6307b1SDamien Bergamini 	{ 140, 0x08804, 0x0220a, 0x00283 },	\
4839c6307b1SDamien Bergamini 						\
4849c6307b1SDamien Bergamini 	{ 149, 0x08808, 0x02429, 0x00281 },	\
4859c6307b1SDamien Bergamini 	{ 153, 0x08808, 0x0242b, 0x00281 },	\
4869c6307b1SDamien Bergamini 	{ 157, 0x08808, 0x0242d, 0x00281 },	\
4879c6307b1SDamien Bergamini 	{ 161, 0x08808, 0x0242f, 0x00281 }
488