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

📄 msapiinternal.h

📁 marvell交换芯片6095的所有驱动程序及测试例子
💻 H
📖 第 1 页 / 共 2 页
字号:
#include <Copyright.h>

/********************************************************************************
* msApiPrototype.h
*
* DESCRIPTION:
*       API Prototypes for QuarterDeck Device
*
* DEPENDENCIES:
*
* FILE REVISION NUMBER:
*
*******************************************************************************/

#ifndef __msApiInternal_h
#define __msApiInternal_h

#ifdef __cplusplus
extern "C" {
#endif

#define GT_LPORT_2_PORT(_lport)      (GT_U8)((_lport) & 0xff)
#define GT_PORT_2_LPORT(_port)       (GT_32)((_port) & 0xff)

/* The following macro converts a binary    */
/* value (of 1 bit) to a boolean one.       */
/* 0 --> GT_FALSE                           */
/* 1 --> GT_TRUE                            */
#define BIT_2_BOOL(binVal,boolVal)                                  \
            (boolVal) = (((binVal) == 0) ? GT_FALSE : GT_TRUE)

/* The following macro converts a boolean   */
/* value to a binary one (of 1 bit).        */
/* GT_FALSE --> 0                           */
/* GT_TRUE --> 1                            */
#define BOOL_2_BIT(boolVal,binVal)                                  \
            (binVal) = (((boolVal) == GT_TRUE) ? 1 : 0)

/* device name - devName */
#define DEV_88E6051                      0x0001    /* quarterdeck 6051      */
#define DEV_88E6052                      0x0002    /* quarterdeck 6052      */
#define DEV_88E6021                      0x0004    /* fullsail              */
#define DEV_88E6060                      0x0008    /* Gondola               */
#define DEV_88E6063                      0x0010    /* clippership 6063      */
#define DEV_FF_EG                        0x0020    /* FireFox-EG            */
#define DEV_FF_HG                        0x0040    /* FireFox-HG            */
#define DEV_FH_VPN                       0x0080    /* FireHawk-VPN          */
#define DEV_88E6083                      0x0100    /* Octane 6083           */
#define DEV_88E6181                      0x0200    /* Sapphire 88E6181      */
#define DEV_88E6183                      0x0400    /* Sapphire 88E6153,88E6183 */
#define DEV_88E6093	 	                    0x0800   /* 88E6093                  */
#define DEV_88E6092	 	                    0x1000   /* 88E6092                  */#define DEV_88E6095	 	                    0x2000   /* 88E6095                  */#define DEV_88E6182                      0x4000   /* Jade 88E6152, 88E6182 */
#define DEV_88E6185                      0x8000   /* Jade 88E6155, 88E6185 */

#define DEV_88E6095_FAMILY	( DEV_88E6092 | DEV_88E6095 )
#define DEV_88E6185_FAMILY	( DEV_88E6182 | DEV_88E6185 )
#define DEV_NEW_FEATURE_IN_REV (DEV_88E6095_FAMILY | DEV_88E6185_FAMILY)/* DEV_8PORT_SWITCH is used to access the given device's Register Map */#define DEV_8PORT_SWITCH	( DEV_88E6083 | DEV_88E6181 | DEV_88E6183 | 	\							  DEV_88E6093 | 								\							  DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )
#define DEV_PORT_SECURITY	( DEV_88E6083 | DEV_88E6183 | DEV_88E6093 | 	\							  DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_BROADCAST_INVALID	( DEV_88E6051 | DEV_88E6052 | DEV_FF_EG | DEV_FF_HG)

#define DEV_ATU_256_2048 		( DEV_88E6021 | DEV_88E6060 )
#define DEV_ATU_562_2048 		\
						( DEV_88E6052 | DEV_88E6063 | DEV_FF_HG | 	\						  DEV_FH_VPN | DEV_88E6083 )
#define DEV_ATU_8192	( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )

#define DEV_DBNUM_FULL 	\
						( DEV_88E6021 | DEV_88E6060 | DEV_88E6063 | 	\
						  DEV_FH_VPN |  DEV_88E6083 |					\						  DEV_88E6183 | DEV_88E6093 )
#define DEV_DBNUM_256 	( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )
#define DEV_STATIC_ADDR	\
						( DEV_88E6021 | DEV_FF_EG | DEV_FF_HG |			\
						  DEV_88E6052 | DEV_88E6063 | DEV_FH_VPN |		\
						  DEV_88E6083 |	DEV_88E6183 | DEV_88E6093 | 	\						  DEV_88E6095_FAMILY | DEV_88E6185_FAMILY)

#define DEV_TRAILER		\
						( DEV_88E6021 | DEV_FF_HG | DEV_88E6052 |  		\
						  DEV_88E6063 | DEV_FH_VPN | DEV_88E6083 )

#define DEV_TRAILER_P5		( DEV_FF_EG )
#define DEV_TRAILER_P4P5	( DEV_88E6060 )

#define DEV_HEADER		\
						( DEV_FF_HG | DEV_88E6063 | DEV_FH_VPN |	\						  DEV_88E6083 |	DEV_88E6183 | DEV_88E6093 | \						  DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )
#define DEV_HEADER_P5		( DEV_FF_EG )
#define DEV_HEADER_P4P5		( DEV_88E6060 )

/* DEV_QoS : Devices with multiple Queues for QoS Priority Support */#define DEV_QoS			\
						( DEV_88E6021 | DEV_FF_HG |	DEV_88E6051 | 		\						  DEV_88E6052 | DEV_88E6063 | DEV_FH_VPN |		\
						  DEV_88E6083 | DEV_88E6181 | DEV_88E6183 | 	\						  DEV_88E6093 | DEV_88E6095_FAMILY |			\						  DEV_88E6185_FAMILY )
#define DEV_TAGGING			DEV_QoS
#define DEV_EGRESS_DOUBLE_TAGGING	\						( DEV_QoS & ~(DEV_88E6051 | DEV_88E6092 | DEV_88E6182) )#define DEV_INGRESS_DOUBLE_TAGGING	\						( DEV_88E6181 | DEV_88E6183 | DEV_88E6093 | 	\						  DEV_88E6095 | DEV_88E6185 )#define DEV_PRIORITY_REMAPPING		\						( DEV_88E6181 | DEV_88E6183 | DEV_88E6093 | 	\						  DEV_88E6095 | DEV_88E6185 )#define DEV_802_1Q		( DEV_88E6021 | DEV_88E6063 | DEV_FH_VPN | 			\						  DEV_88E6083 | DEV_88E6183 | DEV_88E6093 | 		\						  DEV_88E6095 | DEV_88E6092 | DEV_88E6185_FAMILY )
#define DEV_802_1S		( DEV_88E6095 | DEV_88E6185 )#define DEV_802_1W		( DEV_88E6183 | DEV_88E6093 | DEV_88E6095 | DEV_88E6185 )#define DEV_RMON		( DEV_88E6021 | DEV_88E6063 | DEV_FH_VPN | 			\						  DEV_88E6083 | DEV_88E6183 | DEV_88E6093 | 		\						  DEV_88E6092 | DEV_88E6095 | DEV_88E6185_FAMILY ) 
#define DEV_RMON_TYPE_1	( DEV_88E6021 | DEV_88E6063 | DEV_FH_VPN | DEV_88E6083 ) #define DEV_RMON_TYPE_2 ( DEV_88E6183 )#define DEV_RMON_TYPE_3 ( DEV_88E6093 | DEV_88E6095 | DEV_88E6092 | 	\						  DEV_88E6185_FAMILY )#define DEV_IGMP_SNOOPING	\
						( DEV_88E6021 | DEV_88E6063 | DEV_FH_VPN |			\
						  DEV_88E6083 | DEV_88E6183 | DEV_88E6093 | 		\						  DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )

#define DEV_PORT_MONITORING	\
						( DEV_88E6060 | DEV_88E6063 | DEV_FH_VPN |			\
						  DEV_88E6083 | DEV_88E6183 | DEV_88E6093 | 		\						  DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )
#define DEV_ENABLE_MONITORING	\
						( DEV_88E6060 | DEV_88E6063 | DEV_FH_VPN |			\
						  DEV_88E6083 | DEV_88E6183 | DEV_88E6093 )

#define DEV_MC_RATE_PERCENT	\
						( DEV_88E6021 | DEV_88E6051 | DEV_88E6052 )

#define DEV_MC_RATE_KBPS	\
						( DEV_FF_HG | DEV_88E6063 | DEV_FH_VPN |			\
						  DEV_88E6083 )

#define DEV_INGRESS_RATE_KBPS	\
						( DEV_FF_HG | DEV_88E6063 | DEV_FH_VPN |			\
						  DEV_88E6083 | DEV_88E6181 | DEV_88E6183 | 		\						  DEV_88E6093 | DEV_88E6095_FAMILY | DEV_88E6185_FAMILY)

#define DEV_EGRESS_RATE_KBPS	\
						( DEV_FF_HG | DEV_88E6063 | DEV_FH_VPN |			\
						  DEV_88E6083 | DEV_88E6181 | DEV_88E6183 | 		\						  DEV_88E6093 | DEV_88E6095 | DEV_88E6185 )
#define DEV_MII_DUPLEX_CONFIG	\
						( DEV_88E6021 | DEV_88E6063 | DEV_FH_VPN |			\
						  DEV_88E6083 )

#define DEV_QD_PLUS 	\
					( DEV_88E6021 | DEV_FF_EG | DEV_FF_HG |					\
					  DEV_88E6060 | DEV_88E6063 | DEV_FH_VPN |				\
					  DEV_88E6083 | DEV_88E6181 | DEV_88E6183 | 			\					  DEV_88E6093 | 										\					  DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )
#define DEV_FASTETH_SWITCH	\					( DEV_88E6051 | DEV_88E6052 | DEV_88E6021 | 		\					  DEV_FF_EG | DEV_FF_HG | DEV_88E6060 | 			\
					  DEV_88E6063 | DEV_FH_VPN | DEV_88E6083 )
#define DEV_EXTERNAL_PHY	\					( DEV_88E6181 | DEV_88E6183 | DEV_88E6093 |			\					  DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_EXTERNAL_PHY_ONLY	( DEV_88E6181 | DEV_88E6183 | DEV_88E6185_FAMILY )#define DEV_FC_WITH_VALUE	( DEV_88E6093 | DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_CORE_TAG		( DEV_88E6093 | DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_PCS_LINK		( DEV_88E6093 | DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_MGMII_STATUS	( DEV_88E6093 | DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_88E6183_FAMILY		( DEV_88E6183 | DEV_88E6185_FAMILY )#define DEV_88E6093_FAMILY		( DEV_88E6093 | DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_UNMANAGED_SWITCH	( DEV_88E6181 )#define DEV_GIGABIT_SWITCH		\					( DEV_88E6181 | DEV_88E6183 | DEV_88E6093 | 	\					  DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_GIGABIT_MANAGED_SWITCH	\					( DEV_88E6183 | DEV_88E6093 | \					  DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_CROSS_CHIP_VLAN		\					( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_TRUNK	( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_FRAME_SIZE_1632		\					( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_FLOW_CTRL_DELAY		\					( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_ENHANCED_CPU_PORT	\					( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )/* supports Reserved Multicast, etc */#define DEV_ENHANCED_MULTICAST	( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_ARP_SUPPORT		( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_MARVELL_TAG_FLOW_CTRL	( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_USE_DOUBLE_TAG_DATA		( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_MARVELL_TAG_LOOP_BLOCK	( DEV_88E6095_FAMILY | DEV_88E6185_FAMILY )#define DEV_PRIORITY_OVERRIDE	\					( DEV_88E6183 | DEV_88E6093 | DEV_88E6095 | 	\					  DEV_88E6185 )#define DEV_STACKING	\					( DEV_88E6095 | DEV_88E6185 )#define DEV_8_TRUNKING	( DEV_88E6092 | DEV_88E6182 )#define IS_IN_DEV_GROUP(dev,_group) (dev->devName & (_group))/* need to check port number(_hwPort) later */
#define IS_VALID_API_CALL(dev,_hwPort, _devName)	    	\
	(!(dev->devName & (_devName)) ? GT_NOT_SUPPORTED : GT_OK)
#define DOES_DEVPORT_SUPPORT_PCS(dev, _hwPort)			\	(!(dev->devName & DEV_GIGABIT_SWITCH) || \	(!(dev->devName & DEV_EXTERNAL_PHY_ONLY) && (((_hwPort) < 8) || ((_hwPort) > 10)))	\	? 0 : 1)#define IS_CONFIGURABLE_PHY(dev,_hwPort)	(dev->maxPhyNum > (_hwPort))
typedef struct _EXTRA_OP_DATA{	GT_U32 moveFrom;	GT_U32 moveTo;	GT_U32 intCause;	GT_U32 reserved;} GT_EXTRA_OP_DATA;
/*******************************************************************************
* gvtuGetViolation
*
* DESCRIPTION:
*       Get VTU Violation data
*
* INPUTS:
*       None.
*
* OUTPUTS:
*       vtuIntStatus - interrupt cause, source portID, and vid.
*
* RETURNS:
*       GT_OK           - on success
*       GT_FAIL         - on error
*       GT_NOT_SUPPORT  - if current device does not support this feature.
*
* COMMENTS:
*		This is an internal function. No user should call this function.
*
* GalTis:
*
*******************************************************************************/
GT_STATUS gvtuGetViolation
(
    IN GT_QD_DEV*       dev,
    OUT GT_VTU_INT_STATUS *vtuIntStatus
);

/*******************************************************************************
* gvtuGetViolation2
*
* DESCRIPTION:
*       Get VTU Violation data (for Gigabit Device)
*
* INPUTS:
*       None.
*
* OUTPUTS:
*       vtuIntStatus - interrupt cause, source portID, and vid.
*
* RETURNS:
*       GT_OK           - on success
*       GT_FAIL         - on error
*       GT_NOT_SUPPORT  - if current device does not support this feature.
*
* COMMENTS:
*		This is an internal function. No user should call this function.
*
* GalTis:
*
*******************************************************************************/
GT_STATUS gvtuGetViolation2
(
    IN GT_QD_DEV*       dev,
    OUT GT_VTU_INT_STATUS *vtuIntStatus
);
/*******************************************************************************
* gatuGetViolation
*
* DESCRIPTION:
*       Get ATU Violation data
*
* INPUTS:
*       None.
*

⌨️ 快捷键说明

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