#ifndef BCM_PHS_DEFINES_H #define BCM_PHS_DEFINES_H #define PHS_INVALID_TABLE_INDEX 0xffffffff #define PHS_MEM_TAG "_SHP" /* PHS Defines */ #define STATUS_PHS_COMPRESSED 0xa1 #define STATUS_PHS_NOCOMPRESSION 0xa2 #define APPLY_PHS 1 #define MAX_NO_BIT 7 #define ZERO_PHSI 0 #define VERIFY 0 #define SIZE_MULTIPLE_32 4 #define UNCOMPRESSED_PACKET 0 #define DYNAMIC 0 #define SUPPRESS 0x80 #define NO_CLASSIFIER_MATCH 0 #define SEND_PACKET_UNCOMPRESSED 0 #define PHSI_IS_ZERO 0 #define PHSI_LEN 1 #define ERROR_LEN 0 #define PHS_BUFFER_SIZE 1532 #define MAX_PHSRULE_PER_SF 20 #define MAX_SERVICEFLOWS 17 /* PHS Error Defines */ #define PHS_SUCCESS 0 #define ERR_PHS_INVALID_DEVICE_EXETENSION 0x800 #define ERR_PHS_INVALID_PHS_RULE 0x801 #define ERR_PHS_RULE_ALREADY_EXISTS 0x802 #define ERR_SF_MATCH_FAIL 0x803 #define ERR_INVALID_CLASSIFIERTABLE_FOR_SF 0x804 #define ERR_SFTABLE_FULL 0x805 #define ERR_CLSASSIFIER_TABLE_FULL 0x806 #define ERR_PHSRULE_MEMALLOC_FAIL 0x807 #define ERR_CLSID_MATCH_FAIL 0x808 #define ERR_PHSRULE_MATCH_FAIL 0x809 struct bcm_phs_rule { u8 u8PHSI; u8 u8PHSFLength; u8 u8PHSF[MAX_PHS_LENGTHS]; u8 u8PHSMLength; u8 u8PHSM[MAX_PHS_LENGTHS]; u8 u8PHSS; u8 u8PHSV; u8 u8RefCnt; u8 bUnclassifiedPHSRule; u8 u8Reserved[3]; long PHSModifiedBytes; unsigned long PHSModifiedNumPackets; unsigned long PHSErrorNumPackets; }; enum bcm_phs_classifier_context { eActiveClassifierRuleContext, eOldClassifierRuleContext }; struct bcm_phs_classifier_entry { u8 bUsed; u16 uiClassifierRuleId; u8 u8PHSI; struct bcm_phs_rule *pstPhsRule; u8 bUnclassifiedPHSRule; }; struct bcm_phs_classifier_table { u16 uiTotalClassifiers; struct bcm_phs_classifier_entry stActivePhsRulesList[MAX_PHSRULE_PER_SF]; struct bcm_phs_classifier_entry stOldPhsRulesList[MAX_PHSRULE_PER_SF]; u16 uiOldestPhsRuleIndex; }; struct bcm_phs_entry { u8 bUsed; u16 uiVcid; struct bcm_phs_classifier_table *pstClassifierTable; }; struct bcm_phs_table { u16 uiTotalServiceFlows; struct bcm_phs_entry stSFList[MAX_SERVICEFLOWS]; }; struct bcm_phs_extension { /* PHS Specific data */ struct bcm_phs_table *pstServiceFlowPhsRulesTable; void *CompressedTxBuffer; void *UnCompressedRxBuffer; }; #endif