| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321 |
- /*
- ** Id: //Department/DaVinci/BRANCHES/MT6620_WIFI_DRIVER_V2_3/include/nic/mt6630_reg.h#1
- */
- /*! \file "mt6630_reg.h"
- \brief The common register definition of MT6630
- N/A
- */
- /*
- ** Log: mt6630_reg.h
- **
- ** 07 23 2013 cp.wu
- ** [BORA00002227] [MT6630 Wi-Fi][Driver] Update for Makefile and HIFSYS modifications
- ** 1. build success for win32 port
- ** 2. add SDIO test read/write pattern for HQA tests (default off)
- **
- ** 03 18 2013 cp.wu
- ** [BORA00002227] [MT6630 Wi-Fi][Driver] Update for Makefile and HIFSYS modifications
- ** use RX default maximum length to 16 (max. 64)
- **
- ** 10 25 2012 cp.wu
- ** [BORA00002227] [MT6630 Wi-Fi][Driver] Update for Makefile and HIFSYS modifications
- ** sync with MT6630 HIFSYS update.
- **
- *
- */
- #ifndef _MT6630_REG_H
- #define _MT6630_REG_H
- /*******************************************************************************
- * C O M P I L E R F L A G S
- ********************************************************************************
- */
- /*******************************************************************************
- * E X T E R N A L R E F E R E N C E S
- ********************************************************************************
- */
- /*******************************************************************************
- * C O N S T A N T S
- ********************************************************************************
- */
- /*******************************************************************************
- * D A T A T Y P E S
- ********************************************************************************
- */
- /*******************************************************************************
- * P U B L I C D A T A
- ********************************************************************************
- */
- /*******************************************************************************
- * P R I V A T E D A T A
- ********************************************************************************
- */
- /*******************************************************************************
- * M A C R O S
- ********************************************************************************
- */
- /*******************************************************************************
- * F U N C T I O N D E C L A R A T I O N S
- ********************************************************************************
- */
- /*******************************************************************************
- * F U N C T I O N S
- ********************************************************************************
- */
- /* 1 MT6630 MCR Definition */
- /* 2 Host Interface */
- /* 4 CHIP ID Register */
- #define MCR_WCIR 0x0000
- /* 4 HIF Low Power Control Register */
- #define MCR_WHLPCR 0x0004
- /* 4 Control Status Register */
- #define MCR_WSDIOCSR 0x0008
- /* 4 HIF Control Register */
- #define MCR_WHCR 0x000C
- /* 4 HIF Interrupt Status Register */
- #define MCR_WHISR 0x0010
- /* 4 HIF Interrupt Enable Register */
- #define MCR_WHIER 0x0014
- /* 4 Abnormal Status Register */
- #define MCR_WASR 0x0020
- /* 4 WLAN Software Interrupt Control Register */
- #define MCR_WSICR 0x0024
- /* 4 WLAN TX Data Register 1 */
- #define MCR_WTDR1 0x0034
- /* 4 WLAN RX Data Register 0 */
- #define MCR_WRDR0 0x0050
- /* 4 WLAN RX Data Register 1 */
- #define MCR_WRDR1 0x0054
- /* 4 Host to Device Send Mailbox 0 Register */
- #define MCR_H2DSM0R 0x0070
- /* 4 Host to Device Send Mailbox 1 Register */
- #define MCR_H2DSM1R 0x0074
- /* 4 Device to Host Receive Mailbox 0 Register */
- #define MCR_D2HRM0R 0x0078
- /* 4 Device to Host Receive Mailbox 1 Register */
- #define MCR_D2HRM1R 0x007c
- /* 4 WLAN RX Packet Length Register */
- #define MCR_WRPLR 0x0090
- /* 4 Test Mode Data Port */
- #define MCR_WTMDR 0x00b0
- /* 4 Test Mode Control Register */
- #define MCR_WTMCR 0x00b4
- /* 4 Test Mode Data Pattern Control Register #0 */
- #define MCR_WTMDPCR0 0x00b8
- /* 4 Test Mode Data Pattern Control Register #1 */
- #define MCR_WTMDPCR1 0x00bc
- /* 4 WLAN Packet Length Report Control Register */
- #define MCR_WPLRCR 0x00d4
- /* 4 WLAN Snapshot Register */
- #define MCR_WSR 0x00D8
- /* 4 Clock Pad Macro IO Control Register */
- #define MCR_CLKIOCR 0x0100
- /* 4 Command Pad Macro IO Control Register */
- #define MCR_CMDIOCR 0x0104
- /* 4 Data 0 Pad Macro IO Control Register */
- #define MCR_DAT0IOCR 0x0108
- /* 4 Data 1 Pad Macro IO Control Register */
- #define MCR_DAT1IOCR 0x010C
- /* 4 Data 2 Pad Macro IO Control Register */
- #define MCR_DAT2IOCR 0x0110
- /* 4 Data 3 Pad Macro IO Control Register */
- #define MCR_DAT3IOCR 0x0114
- /* 4 Clock Pad Macro Delay Chain Control Register */
- #define MCR_CLKDLYCR 0x0118
- /* 4 Command Pad Macro Delay Chain Control Register */
- #define MCR_CMDDLYCR 0x011C
- /* 4 SDIO Output Data Delay Chain Control Register */
- #define MCR_ODATDLYCR 0x0120
- /* 4 SDIO Input Data Delay Chain Control Register 1 */
- #define MCR_IDATDLYCR1 0x0124
- /* 4 SDIO Input Data Delay Chain Control Register 2 */
- #define MCR_IDATDLYCR2 0x0128
- /* 4 SDIO Input Data Latch Time Control Register */
- #define MCR_ILCHCR 0x012C
- /* 4 WLAN TXQ Count Register 0 */
- #define MCR_WTQCR0 0x0130
- /* 4 WLAN TXQ Count Register 1 */
- #define MCR_WTQCR1 0x0134
- /* 4 WLAN TXQ Count Register 2 */
- #define MCR_WTQCR2 0x0138
- /* 4 WLAN TXQ Count Register 3 */
- #define MCR_WTQCR3 0x013C
- /* 4 WLAN TXQ Count Register 4 */
- #define MCR_WTQCR4 0x0140
- /* 4 WLAN TXQ Count Register 5 */
- #define MCR_WTQCR5 0x0144
- /* 4 WLAN TXQ Count Register 6 */
- #define MCR_WTQCR6 0x0148
- /* 4 WLAN TXQ Count Register 7 */
- #define MCR_WTQCR7 0x014C
- /* #if CFG_SDIO_INTR_ENHANCE */
- typedef struct _ENHANCE_MODE_DATA_STRUCT_T {
- UINT_32 u4WHISR;
- union {
- struct {
- UINT_16 u2TQ0Cnt;
- UINT_16 u2TQ1Cnt;
- UINT_16 u2TQ2Cnt;
- UINT_16 u2TQ3Cnt;
- UINT_16 u2TQ4Cnt;
- UINT_16 u2TQ5Cnt;
- UINT_16 u2TQ6Cnt;
- UINT_16 u2TQ7Cnt;
- UINT_16 u2TQ8Cnt;
- UINT_16 u2TQ9Cnt;
- UINT_16 u2TQ10Cnt;
- UINT_16 u2TQ11Cnt;
- UINT_16 u2TQ12Cnt;
- UINT_16 u2TQ13Cnt;
- UINT_16 u2TQ14Cnt;
- UINT_16 u2TQ15Cnt;
- } u;
- UINT_32 au4WTSR[8];
- } rTxInfo;
- union {
- struct {
- UINT_16 u2NumValidRx0Len;
- UINT_16 u2NumValidRx1Len;
- UINT_16 au2Rx0Len[16];
- UINT_16 au2Rx1Len[16];
- } u;
- UINT_32 au4RxStatusRaw[17];
- } rRxInfo;
- UINT_32 u4RcvMailbox0;
- UINT_32 u4RcvMailbox1;
- } ENHANCE_MODE_DATA_STRUCT_T, *P_ENHANCE_MODE_DATA_STRUCT_T;
- /* #endif *//* ENHANCE_MODE_DATA_STRUCT_T */
- /* 2 Definition in each register */
- /* 3 WCIR 0x0000 */
- #define WCIR_WLAN_READY BIT(21)
- #define WCIR_POR_INDICATOR BIT(20)
- #define WCIR_REVISION_ID BITS(16, 19)
- #define WCIR_CHIP_ID BITS(0, 15)
- #define MTK_CHIP_REV 0x00006630
- #define MTK_CHIP_MP_REVERSION_ID 0x0
- /* 3 WHLPCR 0x0004 */
- #define WHLPCR_FW_OWN_REQ_CLR BIT(9)
- #define WHLPCR_FW_OWN_REQ_SET BIT(8)
- #define WHLPCR_IS_DRIVER_OWN BIT(8)
- #define WHLPCR_INT_EN_CLR BIT(1)
- #define WHLPCR_INT_EN_SET BIT(0)
- /* 3 WSDIOCSR 0x0008 */
- #define WSDIOCSR_DB_CMD7_RESELECT_DIS BIT(4)
- #define WSDIOCSR_DB_WR_BUSY_EN BIT(3)
- #define WSDIOCSR_DB_RD_BUSY_EN BIT(2)
- #define WSDIOCSR_SDIO_INT_CTL BIT(1)
- #define WSDIOCSR_SDIO_RE_INIT_EN BIT(0)
- /* 3 WHCR 0x000C */
- #define WHCR_RX_ENHANCE_MODE_EN BIT(16)
- #define WHCR_MAX_HIF_RX_LEN_NUM BITS(8, 13)
- #define WHCR_RPT_OWN_RX_PACKET_LEN BIT(3)
- #define WHCR_RECV_MAILBOX_RD_CLR_EN BIT(2)
- #define WHCR_W_INT_CLR_CTRL BIT(1)
- #define WHCR_MCU_DBG_EN BIT(0)
- #define WHCR_OFFSET_MAX_HIF_RX_LEN_NUM 8
- /* 3 WHISR 0x0010 */
- #define WHISR_D2H_SW_INT BITS(8, 31)
- #define WHISR_D2H_SW_ASSERT_INFO_INT BIT(31)
- #define WHISR_FW_OWN_BACK_INT BIT(7)
- #define WHISR_ABNORMAL_INT BIT(6)
- #define WHISR_RX1_DONE_INT BIT(2)
- #define WHISR_RX0_DONE_INT BIT(1)
- #define WHISR_TX_DONE_INT BIT(0)
- /* 3 WHIER 0x0014 */
- #define WHIER_D2H_SW_INT BITS(8, 31)
- #define WHIER_FW_OWN_BACK_INT_EN BIT(7)
- #define WHIER_ABNORMAL_INT_EN BIT(6)
- #define WHIER_RX1_DONE_INT_EN BIT(2)
- #define WHIER_RX0_DONE_INT_EN BIT(1)
- #define WHIER_TX_DONE_INT_EN BIT(0)
- #define WHIER_DEFAULT (WHIER_RX0_DONE_INT_EN | \
- WHIER_RX1_DONE_INT_EN | \
- WHIER_TX_DONE_INT_EN | \
- WHIER_ABNORMAL_INT_EN | \
- WHIER_D2H_SW_INT \
- )
- /* 3 WASR 0x0020 */
- #define WASR_FW_OWN_INVALID_ACCESS BIT(16)
- #define WASR_RX1_UNDER_FLOW BIT(9)
- #define WASR_RX0_UNDER_FLOW BIT(8)
- #define WASR_TX1_OVER_FLOW BIT(1)
- /* 3 WSICR 0x0024 */
- #define WSICR_H2D_SW_INT_SET BITS(16, 31)
- /* 3 WRPLR 0x0090 */
- #define WRPLR_RX1_PACKET_LENGTH BITS(16, 31)
- #define WRPLR_RX0_PACKET_LENGTH BITS(0, 15)
- /* 3 WTMCR 0x00b4 */
- #define WMTCR_TEST_MODE_FW_OWN BIT(24)
- #define WMTCR_PRBS_INIT_VAL BITS(16, 23)
- #define WMTCR_TEST_MODE_STATUS BIT(8)
- #define WMTCR_TEST_MODE_SELECT BITS(0, 1)
- #endif /* _MT6628_REG_H */
|