⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rt61pci.h

📁 linux内核源码
💻 H
📖 第 1 页 / 共 3 页
字号:
/*	Copyright (C) 2004 - 2007 rt2x00 SourceForge Project	<http://rt2x00.serialmonkey.com>	This program is free software; you can redistribute it and/or modify	it under the terms of the GNU General Public License as published by	the Free Software Foundation; either version 2 of the License, or	(at your option) any later version.	This program is distributed in the hope that it will be useful,	but WITHOUT ANY WARRANTY; without even the implied warranty of	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the	GNU General Public License for more details.	You should have received a copy of the GNU General Public License	along with this program; if not, write to the	Free Software Foundation, Inc.,	59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *//*	Module: rt61pci	Abstract: Data structures and registers for the rt61pci module.	Supported chipsets: RT2561, RT2561s, RT2661. */#ifndef RT61PCI_H#define RT61PCI_H/* * RF chip defines. */#define RF5225				0x0001#define RF5325				0x0002#define RF2527				0x0003#define RF2529				0x0004/* * Signal information. * Defaul offset is required for RSSI <-> dBm conversion. */#define MAX_SIGNAL			100#define MAX_RX_SSI			-1#define DEFAULT_RSSI_OFFSET		120/* * Register layout information. */#define CSR_REG_BASE			0x3000#define CSR_REG_SIZE			0x04b0#define EEPROM_BASE			0x0000#define EEPROM_SIZE			0x0100#define BBP_SIZE			0x0080#define RF_SIZE				0x0014/* * PCI registers. *//* * PCI Configuration Header */#define PCI_CONFIG_HEADER_VENDOR	0x0000#define PCI_CONFIG_HEADER_DEVICE	0x0002/* * HOST_CMD_CSR: For HOST to interrupt embedded processor */#define HOST_CMD_CSR			0x0008#define HOST_CMD_CSR_HOST_COMMAND	FIELD32(0x0000007f)#define HOST_CMD_CSR_INTERRUPT_MCU	FIELD32(0x00000080)/* * MCU_CNTL_CSR * SELECT_BANK: Select 8051 program bank. * RESET: Enable 8051 reset state. * READY: Ready state for 8051. */#define MCU_CNTL_CSR			0x000c#define MCU_CNTL_CSR_SELECT_BANK	FIELD32(0x00000001)#define MCU_CNTL_CSR_RESET		FIELD32(0x00000002)#define MCU_CNTL_CSR_READY		FIELD32(0x00000004)/* * SOFT_RESET_CSR */#define SOFT_RESET_CSR			0x0010/* * MCU_INT_SOURCE_CSR: MCU interrupt source/mask register. */#define MCU_INT_SOURCE_CSR		0x0014#define MCU_INT_SOURCE_CSR_0		FIELD32(0x00000001)#define MCU_INT_SOURCE_CSR_1		FIELD32(0x00000002)#define MCU_INT_SOURCE_CSR_2		FIELD32(0x00000004)#define MCU_INT_SOURCE_CSR_3		FIELD32(0x00000008)#define MCU_INT_SOURCE_CSR_4		FIELD32(0x00000010)#define MCU_INT_SOURCE_CSR_5		FIELD32(0x00000020)#define MCU_INT_SOURCE_CSR_6		FIELD32(0x00000040)#define MCU_INT_SOURCE_CSR_7		FIELD32(0x00000080)#define MCU_INT_SOURCE_CSR_TWAKEUP	FIELD32(0x00000100)#define MCU_INT_SOURCE_CSR_TBTT_EXPIRE	FIELD32(0x00000200)/* * MCU_INT_MASK_CSR: MCU interrupt source/mask register. */#define MCU_INT_MASK_CSR		0x0018#define MCU_INT_MASK_CSR_0		FIELD32(0x00000001)#define MCU_INT_MASK_CSR_1		FIELD32(0x00000002)#define MCU_INT_MASK_CSR_2		FIELD32(0x00000004)#define MCU_INT_MASK_CSR_3		FIELD32(0x00000008)#define MCU_INT_MASK_CSR_4		FIELD32(0x00000010)#define MCU_INT_MASK_CSR_5		FIELD32(0x00000020)#define MCU_INT_MASK_CSR_6		FIELD32(0x00000040)#define MCU_INT_MASK_CSR_7		FIELD32(0x00000080)#define MCU_INT_MASK_CSR_TWAKEUP	FIELD32(0x00000100)#define MCU_INT_MASK_CSR_TBTT_EXPIRE	FIELD32(0x00000200)/* * PCI_USEC_CSR */#define PCI_USEC_CSR			0x001c/* * Security key table memory. * 16 entries 32-byte for shared key table * 64 entries 32-byte for pairwise key table * 64 entries 8-byte for pairwise ta key table */#define SHARED_KEY_TABLE_BASE		0x1000#define PAIRWISE_KEY_TABLE_BASE		0x1200#define PAIRWISE_TA_TABLE_BASE		0x1a00struct hw_key_entry {	u8 key[16];	u8 tx_mic[8];	u8 rx_mic[8];} __attribute__ ((packed));struct hw_pairwise_ta_entry {	u8 address[6];	u8 reserved[2];} __attribute__ ((packed));/* * Other on-chip shared memory space. */#define HW_CIS_BASE			0x2000#define HW_NULL_BASE			0x2b00/* * Since NULL frame won't be that long (256 byte), * We steal 16 tail bytes to save debugging settings. */#define HW_DEBUG_SETTING_BASE		0x2bf0/* * On-chip BEACON frame space. */#define HW_BEACON_BASE0			0x2c00#define HW_BEACON_BASE1			0x2d00#define HW_BEACON_BASE2			0x2e00#define HW_BEACON_BASE3			0x2f00#define HW_BEACON_OFFSET		0x0100/* * HOST-MCU shared memory. *//* * H2M_MAILBOX_CSR: Host-to-MCU Mailbox. */#define H2M_MAILBOX_CSR			0x2100#define H2M_MAILBOX_CSR_ARG0		FIELD32(0x000000ff)#define H2M_MAILBOX_CSR_ARG1		FIELD32(0x0000ff00)#define H2M_MAILBOX_CSR_CMD_TOKEN	FIELD32(0x00ff0000)#define H2M_MAILBOX_CSR_OWNER		FIELD32(0xff000000)/* * MCU_LEDCS: LED control for MCU Mailbox. */#define MCU_LEDCS_LED_MODE		FIELD16(0x001f)#define MCU_LEDCS_RADIO_STATUS		FIELD16(0x0020)#define MCU_LEDCS_LINK_BG_STATUS	FIELD16(0x0040)#define MCU_LEDCS_LINK_A_STATUS		FIELD16(0x0080)#define MCU_LEDCS_POLARITY_GPIO_0	FIELD16(0x0100)#define MCU_LEDCS_POLARITY_GPIO_1	FIELD16(0x0200)#define MCU_LEDCS_POLARITY_GPIO_2	FIELD16(0x0400)#define MCU_LEDCS_POLARITY_GPIO_3	FIELD16(0x0800)#define MCU_LEDCS_POLARITY_GPIO_4	FIELD16(0x1000)#define MCU_LEDCS_POLARITY_ACT		FIELD16(0x2000)#define MCU_LEDCS_POLARITY_READY_BG	FIELD16(0x4000)#define MCU_LEDCS_POLARITY_READY_A	FIELD16(0x8000)/* * M2H_CMD_DONE_CSR. */#define M2H_CMD_DONE_CSR		0x2104/* * MCU_TXOP_ARRAY_BASE. */#define MCU_TXOP_ARRAY_BASE		0x2110/* * MAC Control/Status Registers(CSR). * Some values are set in TU, whereas 1 TU == 1024 us. *//* * MAC_CSR0: ASIC revision number. */#define MAC_CSR0			0x3000/* * MAC_CSR1: System control register. * SOFT_RESET: Software reset bit, 1: reset, 0: normal. * BBP_RESET: Hardware reset BBP. * HOST_READY: Host is ready after initialization, 1: ready. */#define MAC_CSR1			0x3004#define MAC_CSR1_SOFT_RESET		FIELD32(0x00000001)#define MAC_CSR1_BBP_RESET		FIELD32(0x00000002)#define MAC_CSR1_HOST_READY		FIELD32(0x00000004)/* * MAC_CSR2: STA MAC register 0. */#define MAC_CSR2			0x3008#define MAC_CSR2_BYTE0			FIELD32(0x000000ff)#define MAC_CSR2_BYTE1			FIELD32(0x0000ff00)#define MAC_CSR2_BYTE2			FIELD32(0x00ff0000)#define MAC_CSR2_BYTE3			FIELD32(0xff000000)/* * MAC_CSR3: STA MAC register 1. */#define MAC_CSR3			0x300c#define MAC_CSR3_BYTE4			FIELD32(0x000000ff)#define MAC_CSR3_BYTE5			FIELD32(0x0000ff00)#define MAC_CSR3_UNICAST_TO_ME_MASK	FIELD32(0x00ff0000)/* * MAC_CSR4: BSSID register 0. */#define MAC_CSR4			0x3010#define MAC_CSR4_BYTE0			FIELD32(0x000000ff)#define MAC_CSR4_BYTE1			FIELD32(0x0000ff00)#define MAC_CSR4_BYTE2			FIELD32(0x00ff0000)#define MAC_CSR4_BYTE3			FIELD32(0xff000000)/* * MAC_CSR5: BSSID register 1. * BSS_ID_MASK: 3: one BSSID, 0: 4 BSSID, 2 or 1: 2 BSSID. */#define MAC_CSR5			0x3014#define MAC_CSR5_BYTE4			FIELD32(0x000000ff)#define MAC_CSR5_BYTE5			FIELD32(0x0000ff00)#define MAC_CSR5_BSS_ID_MASK		FIELD32(0x00ff0000)/* * MAC_CSR6: Maximum frame length register. */#define MAC_CSR6			0x3018#define MAC_CSR6_MAX_FRAME_UNIT		FIELD32(0x00000fff)/* * MAC_CSR7: Reserved */#define MAC_CSR7			0x301c/* * MAC_CSR8: SIFS/EIFS register. * All units are in US. */#define MAC_CSR8			0x3020#define MAC_CSR8_SIFS			FIELD32(0x000000ff)#define MAC_CSR8_SIFS_AFTER_RX_OFDM	FIELD32(0x0000ff00)#define MAC_CSR8_EIFS			FIELD32(0xffff0000)/* * MAC_CSR9: Back-Off control register. * SLOT_TIME: Slot time, default is 20us for 802.11BG. * CWMIN: Bit for Cwmin. default Cwmin is 31 (2^5 - 1). * CWMAX: Bit for Cwmax, default Cwmax is 1023 (2^10 - 1). * CW_SELECT: 1: CWmin/Cwmax select from register, 0:select from TxD. */#define MAC_CSR9			0x3024#define MAC_CSR9_SLOT_TIME		FIELD32(0x000000ff)#define MAC_CSR9_CWMIN			FIELD32(0x00000f00)#define MAC_CSR9_CWMAX			FIELD32(0x0000f000)#define MAC_CSR9_CW_SELECT		FIELD32(0x00010000)/* * MAC_CSR10: Power state configuration. */#define MAC_CSR10			0x3028/* * MAC_CSR11: Power saving transition time register. * DELAY_AFTER_TBCN: Delay after Tbcn expired in units of TU. * TBCN_BEFORE_WAKEUP: Number of beacon before wakeup. * WAKEUP_LATENCY: In unit of TU. */#define MAC_CSR11			0x302c#define MAC_CSR11_DELAY_AFTER_TBCN	FIELD32(0x000000ff)#define MAC_CSR11_TBCN_BEFORE_WAKEUP	FIELD32(0x00007f00)#define MAC_CSR11_AUTOWAKE		FIELD32(0x00008000)#define MAC_CSR11_WAKEUP_LATENCY	FIELD32(0x000f0000)/* * MAC_CSR12: Manual power control / status register (merge CSR20 & PWRCSR1). * CURRENT_STATE: 0:sleep, 1:awake. * FORCE_WAKEUP: This has higher priority than PUT_TO_SLEEP. * BBP_CURRENT_STATE: 0: BBP sleep, 1: BBP awake. */#define MAC_CSR12			0x3030#define MAC_CSR12_CURRENT_STATE		FIELD32(0x00000001)#define MAC_CSR12_PUT_TO_SLEEP		FIELD32(0x00000002)#define MAC_CSR12_FORCE_WAKEUP		FIELD32(0x00000004)#define MAC_CSR12_BBP_CURRENT_STATE	FIELD32(0x00000008)/* * MAC_CSR13: GPIO. */#define MAC_CSR13			0x3034#define MAC_CSR13_BIT0			FIELD32(0x00000001)#define MAC_CSR13_BIT1			FIELD32(0x00000002)#define MAC_CSR13_BIT2			FIELD32(0x00000004)#define MAC_CSR13_BIT3			FIELD32(0x00000008)#define MAC_CSR13_BIT4			FIELD32(0x00000010)#define MAC_CSR13_BIT5			FIELD32(0x00000020)#define MAC_CSR13_BIT6			FIELD32(0x00000040)#define MAC_CSR13_BIT7			FIELD32(0x00000080)#define MAC_CSR13_BIT8			FIELD32(0x00000100)#define MAC_CSR13_BIT9			FIELD32(0x00000200)#define MAC_CSR13_BIT10			FIELD32(0x00000400)#define MAC_CSR13_BIT11			FIELD32(0x00000800)#define MAC_CSR13_BIT12			FIELD32(0x00001000)/* * MAC_CSR14: LED control register. * ON_PERIOD: On period, default 70ms. * OFF_PERIOD: Off period, default 30ms. * HW_LED: HW TX activity, 1: normal OFF, 0: normal ON. * SW_LED: s/w LED, 1: ON, 0: OFF. * HW_LED_POLARITY: 0: active low, 1: active high. */#define MAC_CSR14			0x3038#define MAC_CSR14_ON_PERIOD		FIELD32(0x000000ff)#define MAC_CSR14_OFF_PERIOD		FIELD32(0x0000ff00)#define MAC_CSR14_HW_LED		FIELD32(0x00010000)#define MAC_CSR14_SW_LED		FIELD32(0x00020000)#define MAC_CSR14_HW_LED_POLARITY	FIELD32(0x00040000)#define MAC_CSR14_SW_LED2		FIELD32(0x00080000)/* * MAC_CSR15: NAV control. */#define MAC_CSR15			0x303c/* * TXRX control registers. * Some values are set in TU, whereas 1 TU == 1024 us. *//* * TXRX_CSR0: TX/RX configuration register. * TSF_OFFSET: Default is 24. * AUTO_TX_SEQ: 1: ASIC auto replace sequence nr in outgoing frame. * DISABLE_RX: Disable Rx engine. * DROP_CRC: Drop CRC error. * DROP_PHYSICAL: Drop physical error. * DROP_CONTROL: Drop control frame. * DROP_NOT_TO_ME: Drop not to me unicast frame. * DROP_TO_DS: Drop fram ToDs bit is true. * DROP_VERSION_ERROR: Drop version error frame. * DROP_MULTICAST: Drop multicast frames. * DROP_BORADCAST: Drop broadcast frames. * ROP_ACK_CTS: Drop received ACK and CTS. */#define TXRX_CSR0			0x3040#define TXRX_CSR0_RX_ACK_TIMEOUT	FIELD32(0x000001ff)#define TXRX_CSR0_TSF_OFFSET		FIELD32(0x00007e00)#define TXRX_CSR0_AUTO_TX_SEQ		FIELD32(0x00008000)#define TXRX_CSR0_DISABLE_RX		FIELD32(0x00010000)#define TXRX_CSR0_DROP_CRC		FIELD32(0x00020000)#define TXRX_CSR0_DROP_PHYSICAL		FIELD32(0x00040000)#define TXRX_CSR0_DROP_CONTROL		FIELD32(0x00080000)#define TXRX_CSR0_DROP_NOT_TO_ME	FIELD32(0x00100000)#define TXRX_CSR0_DROP_TO_DS		FIELD32(0x00200000)#define TXRX_CSR0_DROP_VERSION_ERROR	FIELD32(0x00400000)#define TXRX_CSR0_DROP_MULTICAST	FIELD32(0x00800000)#define TXRX_CSR0_DROP_BORADCAST	FIELD32(0x01000000)#define TXRX_CSR0_DROP_ACK_CTS		FIELD32(0x02000000)#define TXRX_CSR0_TX_WITHOUT_WAITING	FIELD32(0x04000000)/* * TXRX_CSR1 */#define TXRX_CSR1			0x3044#define TXRX_CSR1_BBP_ID0		FIELD32(0x0000007f)#define TXRX_CSR1_BBP_ID0_VALID		FIELD32(0x00000080)#define TXRX_CSR1_BBP_ID1		FIELD32(0x00007f00)#define TXRX_CSR1_BBP_ID1_VALID		FIELD32(0x00008000)#define TXRX_CSR1_BBP_ID2		FIELD32(0x007f0000)#define TXRX_CSR1_BBP_ID2_VALID		FIELD32(0x00800000)#define TXRX_CSR1_BBP_ID3		FIELD32(0x7f000000)#define TXRX_CSR1_BBP_ID3_VALID		FIELD32(0x80000000)/* * TXRX_CSR2 */#define TXRX_CSR2			0x3048#define TXRX_CSR2_BBP_ID0		FIELD32(0x0000007f)#define TXRX_CSR2_BBP_ID0_VALID		FIELD32(0x00000080)#define TXRX_CSR2_BBP_ID1		FIELD32(0x00007f00)#define TXRX_CSR2_BBP_ID1_VALID		FIELD32(0x00008000)#define TXRX_CSR2_BBP_ID2		FIELD32(0x007f0000)#define TXRX_CSR2_BBP_ID2_VALID		FIELD32(0x00800000)#define TXRX_CSR2_BBP_ID3		FIELD32(0x7f000000)#define TXRX_CSR2_BBP_ID3_VALID		FIELD32(0x80000000)/* * TXRX_CSR3 */#define TXRX_CSR3			0x304c#define TXRX_CSR3_BBP_ID0		FIELD32(0x0000007f)#define TXRX_CSR3_BBP_ID0_VALID		FIELD32(0x00000080)#define TXRX_CSR3_BBP_ID1		FIELD32(0x00007f00)#define TXRX_CSR3_BBP_ID1_VALID		FIELD32(0x00008000)#define TXRX_CSR3_BBP_ID2		FIELD32(0x007f0000)#define TXRX_CSR3_BBP_ID2_VALID		FIELD32(0x00800000)#define TXRX_CSR3_BBP_ID3		FIELD32(0x7f000000)#define TXRX_CSR3_BBP_ID3_VALID		FIELD32(0x80000000)/* * TXRX_CSR4: Auto-Responder/Tx-retry register. * AUTORESPOND_PREAMBLE: 0:long, 1:short preamble. * OFDM_TX_RATE_DOWN: 1:enable. * OFDM_TX_RATE_STEP: 0:1-step, 1: 2-step, 2:3-step, 3:4-step. * OFDM_TX_FALLBACK_CCK: 0: Fallback to OFDM 6M only, 1: Fallback to CCK 1M,2M. */#define TXRX_CSR4			0x3050#define TXRX_CSR4_TX_ACK_TIMEOUT	FIELD32(0x000000ff)#define TXRX_CSR4_CNTL_ACK_POLICY	FIELD32(0x00000700)#define TXRX_CSR4_ACK_CTS_PSM		FIELD32(0x00010000)#define TXRX_CSR4_AUTORESPOND_ENABLE	FIELD32(0x00020000)#define TXRX_CSR4_AUTORESPOND_PREAMBLE	FIELD32(0x00040000)#define TXRX_CSR4_OFDM_TX_RATE_DOWN	FIELD32(0x00080000)#define TXRX_CSR4_OFDM_TX_RATE_STEP	FIELD32(0x00300000)#define TXRX_CSR4_OFDM_TX_FALLBACK_CCK	FIELD32(0x00400000)#define TXRX_CSR4_LONG_RETRY_LIMIT	FIELD32(0x0f000000)#define TXRX_CSR4_SHORT_RETRY_LIMIT	FIELD32(0xf0000000)/* * TXRX_CSR5 */#define TXRX_CSR5			0x3054/* * TXRX_CSR6: ACK/CTS payload consumed time */#define TXRX_CSR6			0x3058/* * TXRX_CSR7: OFDM ACK/CTS payload consumed time for 6/9/12/18 mbps. */#define TXRX_CSR7			0x305c#define TXRX_CSR7_ACK_CTS_6MBS		FIELD32(0x000000ff)#define TXRX_CSR7_ACK_CTS_9MBS		FIELD32(0x0000ff00)#define TXRX_CSR7_ACK_CTS_12MBS		FIELD32(0x00ff0000)#define TXRX_CSR7_ACK_CTS_18MBS		FIELD32(0xff000000)/* * TXRX_CSR8: OFDM ACK/CTS payload consumed time for 24/36/48/54 mbps. */#define TXRX_CSR8			0x3060#define TXRX_CSR8_ACK_CTS_24MBS		FIELD32(0x000000ff)#define TXRX_CSR8_ACK_CTS_36MBS		FIELD32(0x0000ff00)#define TXRX_CSR8_ACK_CTS_48MBS		FIELD32(0x00ff0000)#define TXRX_CSR8_ACK_CTS_54MBS		FIELD32(0xff000000)/* * TXRX_CSR9: Synchronization control register. * BEACON_INTERVAL: In unit of 1/16 TU.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -