📄 rt61pci.h
字号:
/* 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 + -