📄 macreg.h
字号:
/******************* (c) Marvell Semiconductor, Inc., 2001 ********************
*
* $HEADER&
*
* Purpose:
* This file contains CF MAC registers definition
*
* Notes:
*
*****************************************************************************/
#ifndef __MACREG_H_ /* filename in CAPS */
#define __MACREG_H_
/*
===============================================================================
PUBLIC DEFINITIONS
===============================================================================
*/
//
// NDIS version
//
#define MRVDRV_NDIS_MAJOR_VERSION 0x5
#ifdef MRVL_WINXP_NDIS51
#define MRVDRV_NDIS_MINOR_VERSION 0x1
#else
#define MRVDRV_NDIS_MINOR_VERSION 0x0
#endif
#define MRVDRV_DRIVER_VERSION ((MRVDRV_NDIS_MAJOR_VERSION*0x100) + MRVDRV_NDIS_MINOR_VERSION)
//
// Product name
//
#ifdef CF_DRIVER
#define VENDORDESCRIPTOR "Marvell W8100 802.11 CompactFlash CARD NIC"
#else
#define VENDORDESCRIPTOR "Marvell W8100 802.11 SDIO CARD NIC"
#endif // CF_DRIVER
#ifdef CF_DRIVER
#define MRVL_8100_COMPACTFLASH_VER_ID 0x02
// define CF MAC device ID
#define MRVL_8300_PCMCIA_DEVICE_ID 0x03
// define CF MAC I/P window size
#define CFMACREG_IO_LENGTH 0x50
// Host Control Registers (HCR) Offset
//
#define CFMACREG_HCR_HOST_STATUS 0x00000000
#define CFMACREG_HCR_CARD_INT_CAUSE 0x00000002
#define CFMACREG_HCR_HOST_INT_MASK 0x00000004
#define CFMACREG_HCR_READ_BASE_LOW 0x00000008
#define CFMACREG_HCR_READ_BASE_HIGH 0x0000000A
#define CFMACREG_HCR_WRITE_BASE_LOW 0x0000000C
#define CFMACREG_HCR_WRITE_BASE_HIGH 0x0000000E
#define CFMACREG_HCR_IO_READ_PORT 0x00000010
#define CFMACREG_HCR_IO_CMD_READ_PORT 0x00000012
#define CFMACREG_HCR_IO_WRITE_LEN 0x00000014
#define CFMACREG_HCR_IO_WRITE_PORT 0x00000016
#define CFMACREG_HCR_IO_CMD_WRITE_LEN 0x00000018
#define CFMACREG_HCR_IO_CMD_WRITE_PORT 0x0000001A
#define CFMACREG_HCR_SCRATCH_PORT 0x0000003F
#define CFMACREG_HCR_CIS_ADDR_PORT 0x00000046
#define CFMACREG_HCR_CIS_DATA_PORT 0x00000048
#define CFMACREG_HCR_IO_GBUS_REG_READ 0x0000004C
#define CFMACREG_HCR_IO_GBUS_REG_WRITE 0x0000004E
// Card Control Registers (CCR) Offset
//
#define CFMACREG_CCR_PRODUCT_ID 0x0000001C
#define CFMACREG_CCR_CARD_STATUS 0x00000020
#define CFMACREG_CCR_HOST_INT_CAUSE 0x00000022
#define CFMACREG_CCR_IO_READ_LEN 0x00000024
#define CFMACREG_CCR_SQ_READ_BASE_LOW 0x00000028
#define CFMACREG_CCR_SQ_READ_BASE_HIGH 0x0000002A
#define CFMACREG_CCR_SQ_WRITE_BASE_LOW 0x0000002C
#define CFMACREG_CCR_SQ_WRITE_BASE_HIGH 0x0000002E
#define CFMACREG_CCR_IO_CMD_READ_LEN 0x00000030
#define CFMACREG_CCR_SQ_CMD_READ_BASE_LOW 0x00000034
#define CFMACREG_CCR_SQ_CMD_READ_BASE_HIGH 0x00000036
#define CFMACREG_CCR_SQ_CMD_WRITE_BASE_LOW 0x00000038
#define CFMACREG_CCR_SQ_CMD_WRITE_BASE_HIGH 0x0000003A
#define CFMACREG_CCR_CFG_REG_BASE_ADR 0x0000003C
#define CFMACREG_CCR_CARD_CFG 0x0000003E
#define CFMACREG_CCR_SCRATCH_PORT 0x0000003F
#define CFMACREG_CCR_TX_FRAME_SEQ_NUM 0x00000040
#define CFMACREG_CCR_TX_FRAME_STATUS 0x00000042
#define CFMACREG_CCR_CARD_INT_MASK 0x00000044
#define CFMACREG_CCR_CIS_ADR_PORT 0x00000046
#define CFMACREG_CCR_CIS_DATA_PORT 0x00000048
// Bit definition for CFMACREG_HCR_HOST_STATUS (Host Status)
#define CFMACREG_HCR_HS_TxDnLdOvr B_BIT_0
#define CFMACREG_HCR_HS_RxUpLdOvr B_BIT_1
#define CFMACREG_HCR_HS_CmdDnLdOvr B_BIT_2
#define CFMACREG_HCR_HS_PwrDown B_BIT_3
#define CFMACREG_HCR_HS_HstEvent B_BIT_4
#define CFMACREG_HCR_HS_FlushDataFifo B_BIT_5
#define CFMACREG_HCR_HS_MASK 0x3F
// Bit definition for CFMACREG_HCR_CARD_INT_CAUSE (Card Interrupt Cause)
#define CFMACREG_HCR_CIC_TxDnLdOvr W_BIT_0
#define CFMACREG_HCR_CIC_RxUpLdOvr W_BIT_1
#define CFMACREG_HCR_CIC_CmdDnLdOvr W_BIT_2
#define CFMACREG_HCR_CIC_PwrDown W_BIT_3
#define CFMACREG_HCR_CIC_HstEvent W_BIT_4
#define CFMACREG_HCR_CIC_MASK 0x001F
// Bit definition for CFMACREG_HCR_HOST_INT_MASK (Host Interrupt Mask)
#define CFMACREG_HCR_HIM_TxDnLdRdy W_BIT_0
#define CFMACREG_HCR_HIM_RxUpLdRdy W_BIT_1
#define CFMACREG_HCR_HIM_CmdDnLdRdy W_BIT_2
#define CFMACREG_HCR_HIM_CmdRspRdy W_BIT_3
#define CFMACREG_HCR_HIM_CardEvent W_BIT_4
#define CFMACREG_HCR_HIM_MASK 0x001F
// Bit definition for CFMACREG_CCR_CARD_STATUS (Card Status)
#define CFMACREG_CCR_CS_TxDnLdRdy W_BIT_0
#define CFMACREG_CCR_CS_RxUpLdRdy W_BIT_1
#define CFMACREG_CCR_CS_CmdDnLdRdy W_BIT_2
#define CFMACREG_CCR_CS_CmdRspRdy W_BIT_3
#define CFMACREG_CCR_CS_CardEvent W_BIT_4
#define CFMACREG_CCR_CS_PwrDwn W_BIT_8
#define CFMACREG_CCR_CS_MACErr W_BIT_9
#define CFMACREG_CCR_CS_802_11LnkUp W_BIT_10
#define CFMACREG_CCR_CS_10btLnkUp W_BIT_11
#define CFMACREG_CCR_CS_100btLnkUp W_BIT_12
#define CFMACREG_CCR_CS_LnkStsChg W_BIT_13
#define CFMACREG_CCR_CS_TxFrmStsChg W_BIT_14
#define CFMACREG_CCR_CS_ReadCISRdy W_BIT_15
#define CFMACREG_CCR_CS_MASK 0xFF1F
#define CFMACREG_CCR_CS_STATUS_MASK 0x7f00
// Bit definition for CFMACREG_CCR_HOST_INT_CAUSE (Host Interrupt Cause)
#define CFMACREG_CCR_HIC_TxDnLdRdy W_BIT_0
#define CFMACREG_CCR_HIC_RxUpLdRdy W_BIT_1
#define CFMACREG_CCR_HIC_CmdDnLdRdy W_BIT_2
#define CFMACREG_CCR_HIC_CmdRspRdy W_BIT_3
#define CFMACREG_CCR_HIC_CardEvent W_BIT_4
#define CFMACREG_CCR_HIC_MASK 0x001F
// Bit definition for CFMACREG_CCR_TX_FRAME_STATUS (Tx Frame Status)
#define CFMACREG_CCR_TFS_SqDmaOvr W_BIT_0
#define CFMACREG_CCR_TFS_TxFrmSent W_BIT_1
#define CFMACREG_CCR_TFS_RtyLmtExcd W_BIT_2
#define CFMACREG_CCR_TFS_TimeOut W_BIT_3
#define CFMACREG_CCR_TFS_MASK 0x000F
// Frame status also returns link speed in bits 4 through 7. They will be filled
// in by FW to correspond with the link speed but in a different translation.
// Once shifted down to low order nibble, this is the translation.
#define FRAME_STATUS_LINK_SPEED_0mbps 0 // MRVDRV_LINK_SPEED_0mbps
#define FRAME_STATUS_LINK_SPEED_1mbps 1 // MRVDRV_LINK_SPEED_1mbps
#define FRAME_STATUS_LINK_SPEED_2mbps 2 // MRVDRV_LINK_SPEED_2mbps
#define FRAME_STATUS_LINK_SPEED_5dot5mbps 3 // MRVDRV_LINK_SPEED_5dot5mbps
#define FRAME_STATUS_LINK_SPEED_10mbps 4 // MRVDRV_LINK_SPEED_10mbps
#define FRAME_STATUS_LINK_SPEED_11mbps 5 // MRVDRV_LINK_SPEED_11mbps
#define FRAME_STATUS_LINK_SPEED_22mbps 6 // MRVDRV_LINK_SPEED_22mbps
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -