Linux-2.6.33.2/drivers/staging/otus/80211core/struct.h

/*
 * Copyright (c) 2007-2008 Atheros Communications Inc.
 *
 * Permission to use, copy, modify, and/or distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 *
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 */

#ifndef _STRUCT_H
#define _STRUCT_H

#include "../oal_marc.h"

#define ZM_SW_LOOP_BACK                     0 /* 1=>enable, 0=>disable */
#define ZM_PCI_LOOP_BACK                    0 /* 1=>enable, 0=>disable */
#define ZM_PROTOCOL_RESPONSE_SIMULATION     0

#define ZM_RX_FRAME_SIZE               1600

extern const u8_t zg11bRateTbl[4];
extern const u8_t zg11gRateTbl[8];

#define ZM_DRIVER_CORE_MAJOR_VERSION        1
#define ZM_DRIVER_CORE_MINOR_VERSION        1
#define ZM_DRIVER_CORE_BRANCH_MAJOR_VERSION 3
#define ZM_DRIVER_CORE_BRANCH_MINOR_VERSION 39

#ifndef ZM_VTXQ_SIZE
#define ZM_VTXQ_SIZE                        1024 //2^N
#endif

#define ZM_VTXQ_SIZE_MASK                   (ZM_VTXQ_SIZE-1)
#define ZM_VMMQ_SIZE                        8 //2^N
#define ZM_VMMQ_SIZE_MASK                   (ZM_VMMQ_SIZE-1)

#include "cagg.h"

#define ZM_AGG_POOL_SIZE                    20
#define ZM_RATE_TABLE_SIZE                  32

#define ZM_MAX_BUF_DISCRETE_NUMBER          5









/**********************************************************************************/
/* IBSS macros                                                     */
/**********************************************************************************/
#define ZM_IBSS_PEER_ALIVE_COUNTER     4

/**********************************************************************************/
/* BIT mapping related macros                                                     */
/**********************************************************************************/

#define ZM_BIT_0       0x1
#define ZM_BIT_1       0x2
#define ZM_BIT_2       0x4
#define ZM_BIT_3       0x8
#define ZM_BIT_4       0x10
#define ZM_BIT_5       0x20
#define ZM_BIT_6       0x40
#define ZM_BIT_7       0x80
#define ZM_BIT_8       0x100
#define ZM_BIT_9       0x200
#define ZM_BIT_10      0x400
#define ZM_BIT_11      0x800
#define ZM_BIT_12      0x1000
#define ZM_BIT_13      0x2000
#define ZM_BIT_14      0x4000
#define ZM_BIT_15      0x8000
#define ZM_BIT_16      0x10000
#define ZM_BIT_17      0x20000
#define ZM_BIT_18      0x40000
#define ZM_BIT_19      0x80000
#define ZM_BIT_20      0x100000
#define ZM_BIT_21      0x200000
#define ZM_BIT_22      0x400000
#define ZM_BIT_23      0x800000
#define ZM_BIT_24      0x1000000
#define ZM_BIT_25      0x2000000
#define ZM_BIT_26      0x4000000
#define ZM_BIT_27      0x8000000
#define ZM_BIT_28      0x10000000
#define ZM_BIT_29      0x20000000   //WPA support
#define ZM_BIT_30      0x40000000
#define ZM_BIT_31      0x80000000


/**********************************************************************************/
/* MAC address related macros                                                     */
/**********************************************************************************/
#define ZM_MAC_BYTE_TO_WORD(macb, macw)   macw[0] = macb[0] + (macb[1] << 8); \
                                          macw[1] = macb[2] + (macb[3] << 8); \
                                          macw[2] = macb[4] + (macb[5] << 8);

#define ZM_MAC_WORD_TO_BYTE(macw, macb)   macb[0] = (u8_t) (macw[0] & 0xff); \
                                          macb[1] = (u8_t) (macw[0] >> 8);   \
                                          macb[2] = (u8_t) (macw[1] & 0xff); \
                                          macb[3] = (u8_t) (macw[1] >> 8);   \
                                          macb[4] = (u8_t) (macw[2] & 0xff); \
                                          macb[5] = (u8_t) (macw[2] >> 8);

#define ZM_MAC_0(macw)   ((u8_t)(macw[0] & 0xff))
#define ZM_MAC_1(macw)   ((u8_t)(macw[0] >> 8))
#define ZM_MAC_2(macw)   ((u8_t)(macw[1] & 0xff))
#define ZM_MAC_3(macw)   ((u8_t)(macw[1] >> 8))
#define ZM_MAC_4(macw)   ((u8_t)(macw[2] & 0xff))
#define ZM_MAC_5(macw)   ((u8_t)(macw[2] >> 8))

#define ZM_IS_MULTICAST_OR_BROADCAST(mac) (mac[0] & 0x01)
#define ZM_IS_MULTICAST(mac) ((mac[0] & 0x01) && (((u8_t)mac[0]) != 0xFF))

#define ZM_MAC_EQUAL(mac1, mac2)   ((mac1[0]==mac2[0])&&(mac1[1]==mac2[1])&&(mac1[2]==mac2[2]))
#define ZM_MAC_NOT_EQUAL(mac1, mac2)   ((mac1[0]!=mac2[0])||(mac1[1]!=mac2[1])||(mac1[2]!=mac2[2]))
/**********************************************************************************/
/* MAC address related mac'ros (end)                                               */
/**********************************************************************************/
#define ZM_BYTE_TO_WORD(A, B)   ((A<<8)+B)
#define ZM_ROL32( A, n ) \
        ( ((A) << (n)) | ( ((A)>>(32-(n)))  & ( (1UL << (n)) - 1 ) ) )
#define ZM_ROR32( A, n ) ZM_ROL32( (A), 32-(n) )
#define ZM_LO8(v16)  ((u8_t)((v16) & 0xFF))
#define ZM_HI8(v16)  ((u8_t)(((v16)>>8)&0xFF))

#ifdef ZM_ENABLE_BUFFER_TRACE
extern void zfwBufTrace(zdev_t* dev, zbuf_t *buf, u8_t *functionName);
#define ZM_BUFFER_TRACE(dev, buf)       zfwBufTrace(dev, buf, __func__);
#else
#define ZM_BUFFER_TRACE(dev, buf)
#endif

/* notification events to heart beat function */
#define ZM_BSSID_LIST_SCAN         0x01

/* CAM mode */
#define ZM_CAM_AP                       0x1
#define ZM_CAM_STA                      0x2
#define ZM_CAM_HOST                     0x4

/* finite state machine for adapter */
#define ZM_STA_STATE_DISCONNECT           1
#define ZM_STA_STATE_CONNECTING           2
#define ZM_STA_STATE_CONNECTED            3

/* Event definitions for  finite state machine */
#define ZM_EVENT_TIMEOUT_SCAN             0x0000
#define ZM_EVENT_TIMEOUT_BG_SCAN          0x0001
#define ZN_EVENT_TIMEOUT_RECONNECT        0x0002
#define ZM_EVENT_TIMEOUT_INIT_SCAN        0x0003
#define ZM_EVENT_TIMEOUT_AUTH             0x0004
#define ZM_EVENT_TIMEOUT_ASSO             0x0005
#define ZM_EVENT_TIMEOUT_AUTO_SCAN        0x0006
#define ZM_EVENT_TIMEOUT_MIC_FAIL         0x0007
#define ZM_EVENT_TIMEOUT_CHECK_AP         0x0008
#define ZM_EVENT_CONNECT                  0x0009
#define ZM_EVENT_INIT_SCAN                0x000a
#define ZM_EVENT_SCAN                     0x000b
#define ZM_EVENT_BG_SCAN                  0x000c
#define ZM_EVENT_DISCONNECT               0x000d
#define ZM_EVENT_WPA_MIC_FAIL             0x000e
#define ZM_EVENT_AP_ALIVE                 0x000f
#define ZM_EVENT_CHANGE_TO_AP             0x0010
#define ZM_EVENT_CHANGE_TO_STA            0x0011
#define ZM_EVENT_IDLE                     0x0012
#define ZM_EVENT_AUTH                     0x0013
#define ZM_EVENT_ASSO_RSP                 0x0014
#define ZM_EVENT_WPA_PK_OK                0x0015
#define ZM_EVENT_WPA_GK_OK                0x0016
#define ZM_EVENT_RCV_BEACON               0x0017
#define ZM_EVENT_RCV_PROBE_RSP            0x0018
#define ZM_EVENT_SEND_DATA                0x0019
#define ZM_EVENT_AUTO_SCAN                0x001a
#define ZM_EVENT_MIC_FAIL1                0x001d
#define ZM_EVENT_MIC_FAIL2                0x001e
#define ZM_EVENT_IBSS_MONITOR             0x001f
#define ZM_EVENT_IN_SCAN                  0x0020
#define ZM_EVENT_CM_TIMER                 0x0021
#define ZM_EVENT_CM_DISCONNECT            0x0022
#define ZM_EVENT_CM_BLOCK_TIMER           0x0023
#define ZM_EVENT_TIMEOUT_ADDBA            0x0024
#define ZM_EVENT_TIMEOUT_PERFORMANCE      0x0025
#define ZM_EVENT_SKIP_COUNTERMEASURE	  0x0026
#define ZM_EVENT_NONE                     0xffff

/* Actions after call finite state machine */
#define ZM_ACTION_NONE                    0x0000
#define ZM_ACTION_QUEUE_DATA              0x0001
#define ZM_ACTION_DROP_DATA               0x0002

/* Timers for finite state machine */
#define ZM_TICK_ZERO                      0
#define ZM_TICK_INIT_SCAN_END             8
#define ZM_TICK_NEXT_BG_SCAN              50
#define ZM_TICK_BG_SCAN_END               8
#define ZM_TICK_AUTH_TIMEOUT              4
#define ZM_TICK_ASSO_TIMEOUT              4
#define ZM_TICK_AUTO_SCAN                 300
#define ZM_TICK_MIC_FAIL_TIMEOUT          6000
#define ZM_TICK_CHECK_AP1                 150
#define ZM_TICK_CHECK_AP2                 350
#define ZM_TICK_CHECK_AP3                 250
#define ZM_TICK_IBSS_MONITOR              160
#define ZM_TICK_IN_SCAN                   4
#define ZM_TICK_CM_TIMEOUT                6000
#define ZM_TICK_CM_DISCONNECT             200
#define ZM_TICK_CM_BLOCK_TIMEOUT          6000

/* Fix bug#33338 Counter Measure Issur */
#ifdef NDIS_CM_FOR_XP
#define ZM_TICK_CM_TIMEOUT_OFFSET        2160
#define ZM_TICK_CM_DISCONNECT_OFFSET     72
#define ZM_TICK_CM_BLOCK_TIMEOUT_OFFSET  2160
#else
#define ZM_TICK_CM_TIMEOUT_OFFSET        0
#define ZM_TICK_CM_DISCONNECT_OFFSET     0
#define ZM_TICK_CM_BLOCK_TIMEOUT_OFFSET  0
#endif

#define ZM_TIME_ACTIVE_SCAN               30 //ms
#define ZM_TIME_PASSIVE_SCAN              110 //ms

/* finite state machine for BSS connect */
#define ZM_STA_CONN_STATE_NONE            0
#define ZM_STA_CONN_STATE_AUTH_OPEN       1
#define ZM_STA_CONN_STATE_AUTH_SHARE_1    2
#define ZM_STA_CONN_STATE_AUTH_SHARE_2    3
#define ZM_STA_CONN_STATE_ASSOCIATE       4
#define ZM_STA_CONN_STATE_SSID_NOT_FOUND  5
#define ZM_STA_CONN_STATE_AUTH_COMPLETED  6

/* finite state machine for WPA handshaking */
#define ZM_STA_WPA_STATE_INIT             0
#define ZM_STA_WPA_STATE_PK_OK            1
#define ZM_STA_WPA_STATE_GK_OK            2

/* various timers */
#define ZM_INTERVAL_CONNECT_TIMEOUT          20   /* 200 milisecond */

/* IBSS definitions */
#define ZM_IBSS_PARTNER_LOST                 0
#define ZM_IBSS_PARTNER_ALIVE                1
#define ZM_IBSS_PARTNER_CHECK                2

#define ZM_BCMC_ARRAY_SIZE                  16 /* Must be 2^N */
#define ZM_UNI_ARRAY_SIZE                   16 /* Must be 2^N */

#define ZM_MAX_DEFRAG_ENTRIES               4  /* 2^N */
#define ZM_DEFRAG_AGING_TIME_SEC            5  /* 5 seconds */

#define ZM_MAX_WPAIE_SIZE                   128
/* WEP related definitions */
#define ZM_USER_KEY_DEFAULT                 64
#define ZM_USER_KEY_PK                      0                /* Pairwise Key */
#define ZM_USER_KEY_GK                      1                /* Group Key */
/* AP WLAN Type */
#define ZM_WLAN_TYPE_PURE_B                 2
#define ZM_WLAN_TYPE_PURE_G                 1
#define ZM_WLAN_TYPE_MIXED                  0

/* HAL State */
#define ZM_HAL_STATE_INIT                   0
#define ZM_HAL_STATE_RUNNING                1

/* AP Capability */
#define ZM_All11N_AP                        0x01
#define ZM_XR_AP                            0x02
#define ZM_SuperG_AP                        0x04

/* MPDU Density */
#define ZM_MPDU_DENSITY_NONE                0
#define ZM_MPDU_DENSITY_1_8US               1
#define ZM_MPDU_DENSITY_1_4US               2
#define ZM_MPDU_DENSITY_1_2US               3
#define ZM_MPDU_DENSITY_1US                 4
#define ZM_MPDU_DENSITY_2US                 5
#define ZM_MPDU_DENSITY_4US                 6
#define ZM_MPDU_DENSITY_8US                 7

/* Software Encryption */
#define ZM_SW_TKIP_ENCRY_EN                0x01
#define ZM_SW_TKIP_DECRY_EN                0x02
#define ZM_SW_WEP_ENCRY_EN                 0x04
#define ZM_SW_WEP_DECRY_EN                 0x08

/* Default Support Rate */
#define ZM_DEFAULT_SUPPORT_RATE_ZERO       0x0
#define ZM_DEFAULT_SUPPORT_RATE_DISCONNECT 0x1
#define ZM_DEFAULT_SUPPORT_RATE_IBSS_B     0x2
#define ZM_DEFAULT_SUPPORT_RATE_IBSS_AG    0x3

/* security related definitions */
struct zsTkipSeed
{
    u8_t   tk[32];     /* key */
    u8_t   ta[6];
    u16_t  ttak[5];
    u16_t  ppk[6];
    u16_t  iv16,iv16tmp;
    u32_t  iv32,iv32tmp;
};

struct zsMicVar
{
    u32_t  k0, k1;        // Key
    u32_t  left, right;   // Current state
    u32_t  m;             // Message accumulator (single word)
    u16_t  nBytes;        // # bytes in M
};

struct zsDefragEntry
{
    u8_t    fragCount;
    u8_t    addr[6];
    u16_t   seqNum;
    zbuf_t* fragment[8];
    u32_t   tick;
};

struct zsDefragList
{
    struct zsDefragEntry   defragEntry[ZM_MAX_DEFRAG_ENTRIES];
    u8_t                   replaceNum;
};

#define ZM_MAX_OPPOSITE_COUNT      16
#define ZM_MAX_TX_SAMPLES          15
#define ZM_TX_RATE_DOWN_CRITERIA   80
#define ZM_TX_RATE_UP_CRITERIA    200


#define ZM_MAX_PROBE_HIDDEN_SSID_SIZE 2
struct zsSsidList
{
    u8_t            ssid[32];
    u8_t            ssidLen;
};

struct zsWrapperSetting
{
    u8_t            bDesiredBssid;
    u8_t            desiredBssid[6];
    u16_t           bssid[3];
    u8_t            ssid[32];
    u8_t            ssidLen;
    u8_t            authMode;
    u8_t            wepStatus;
    u8_t            encryMode;
    u8_t            wlanMode;
    u16_t           frequency;
    u16_t           beaconInterval;
    u8_t            dtim;
    u8_t            preambleType;
    u16_t           atimWindow;

    struct zsSsidList probingSsidList[ZM_MAX_PROBE_HIDDEN_SSID_SIZE];

    u8_t            dropUnencryptedPkts;
    u8_t            ibssJoinOnly;
    u32_t           adhocMode;
    u8_t            countryIsoName[4];
    u16_t           autoSetFrequency;

    /* AP */
    u8_t            bRateBasic;
    u8_t            gRateBasic;
    u32_t           nRateBasic;
    u8_t            bgMode;

    /* Common */
    u8_t            staWmeEnabled;
    u8_t            staWmeQosInfo;
    u8_t            apWmeEnabled;


    /* rate information: added in the future */
};

struct zsWrapperFeatureCtrl
{
    u8_t           bIbssGMode;
};

#define  ZM_MAX_PS_STA            16
#define  ZM_PS_QUEUE_SIZE         32

struct zsStaPSEntity
{
    u8_t           bUsed;
    u8_t           macAddr[6];
    u8_t           bDataQueued;
};

struct zsStaPSList
{
    u8_t           count;
    struct zsStaPSEntity    entity[ZM_MAX_PS_STA];
};

#define ZM_MAX_TIMER_COUNT   32

/* double linked list */
struct zsTimerEntry
{
    u16_t   event;
    u32_t   timer;
    struct zsTimerEntry *pre;
    struct zsTimerEntry *next;
};

struct zsTimerList
{
    u8_t   freeCount;
    struct zsTimerEntry list[ZM_MAX_TIMER_COUNT];
    struct zsTimerEntry *head;
    struct zsTimerEntry *tail;
};

/* Multicast list */
#define ZM_MAX_MULTICAST_LIST_SIZE     64

struct zsMulticastAddr
{
    u8_t addr[6];
};

struct zsMulticastList
{
    u8_t   size;
    struct zsMulticastAddr macAddr[ZM_MAX_MULTICAST_LIST_SIZE];
};

enum ieee80211_cwm_mode {
    CWM_MODE20,
    CWM_MODE2040,
    CWM_MODE40,
    CWM_MODEMAX

};

enum ieee80211_cwm_extprotspacing {
    CWM_EXTPROTSPACING20,
    CWM_EXTPROTSPACING25,
    CWM_EXTPROTSPACINGMAX
};

enum ieee80211_cwm_width {
    CWM_WIDTH20,
    CWM_WIDTH40
};

enum ieee80211_cwm_extprotmode {
    CWM_EXTPROTNONE,  /* no protection */
    CWM_EXTPROTCTSONLY,   /* CTS to self */
    CWM_EXTPROTRTSCTS,    /* RTS-CTS */
    CWM_EXTPROTMAX
};

struct ieee80211_cwm {

    /* Configuration */
    enum ieee80211_cwm_mode         cw_mode;            /* CWM mode */
    u8_t                            cw_extoffset;       /* CWM Extension Channel Offset */
    enum ieee80211_cwm_extprotmode  cw_extprotmode;     /* CWM Extension Channel Protection Mode */
    enum ieee80211_cwm_extprotspacing cw_extprotspacing;/* CWM Extension Channel Protection Spacing */
    u32_t                           cw_enable;          /* CWM State Machine Enabled */
    u32_t                           cw_extbusythreshold;/* CWM Extension Channel Busy Threshold */

    /* State */
    enum ieee80211_cwm_width        cw_width;           /* CWM channel width */
};


/* AP : STA database structure */
struct zsStaTable
{
    u32_t time;     /* tick time */
    //u32_t phyCtrl;   /* Tx PHY CTRL */
    u16_t addr[3];  /* STA MAC address */
    u16_t state;    /* aut/asoc */
    //u16_t retry;    /* Retry count */
    struct zsRcCell rcCell;

    u8_t valid;     /* Valid flag : 1=>valid */
    u8_t psMode;    /* STA power saving mode */
    u8_t staType;   /* 0=>11b, 1=>11g, 2=>11n */
    u8_t qosType;   /* 0=>Legacy, 1=>WME */
    u8_t qosInfo;   /* WME QoS info */
    u8_t vap;       /* Virtual AP ID */
    u8_t encryMode; /* Encryption type for this STA */
    u8_t keyIdx;
    struct zsMicVar     txMicKey;
    struct zsMicVar     rxMicKey;
    u16_t iv16;
    u32_t iv32;
#ifdef ZM_ENABLE_CENC
    /* CENC */
    u8_t cencKeyIdx;
    u32_t txiv[4];
    u32_t rxiv[4];
#endif //ZM_ENABLE_CENC
};

struct zdStructWds
{
    u8_t    wdsBitmap;                      /* Set bit-N to 1 to enable WDS */
    u8_t    encryMode[ZM_MAX_WDS_SUPPORT];  /* WDS encryption mode */
    u16_t   macAddr[ZM_MAX_WDS_SUPPORT][3]; /* WDS neighbor MAC address */
};

    // htcapinfo 16bits
#define HTCAP_AdvCodingCap          0x0001
#define HTCAP_SupChannelWidthSet    0x0002
#define HTCAP_DynamicSMPS           0x0004
#define HTCAP_SMEnabled             0x000C
#define HTCAP_GreenField            0x0010
#define HTCAP_ShortGIfor20MHz       0x0020
#define HTCAP_ShortGIfor40MHz       0x0040
#define HTCAP_TxSTBC                0x0080
#define HTCAP_RxOneStream           0x0100
#define HTCAP_RxTwoStream           0x0200
#define HTCAP_RxThreeStream         0x0300
#define HTCAP_DelayedBlockACK       0x0400
#define HTCAP_MaxAMSDULength        0x0800
#define HTCAP_DSSSandCCKin40MHz     0x1000
#define HTCAP_PSMPSup               0x2000
#define HTCAP_STBCControlFrameSup   0x4000
#define HTCAP_LSIGTXOPProtectionSUP 0x8000
    // Ampdu HT Parameter Info 8bits
#define HTCAP_MaxRxAMPDU0           0x00
#define HTCAP_MaxRxAMPDU1           0x01
#define HTCAP_MaxRxAMPDU2           0x02
#define HTCAP_MaxRxAMPDU3           0x03
    // PCO 8bits
#define HTCAP_PCO                   0x01
#define HTCAP_TransmissionTime1     0x02
#define HTCAP_TransmissionTime2     0x04
#define HTCAP_TransmissionTime3     0x06
    // MCS FeedBack 8bits
#define HTCAP_PlusHTCSupport        0x04
#define HTCAP_RDResponder           0x08
    // TX Beamforming 0 8bits
#define HTCAP_TxBFCapable           0x01
#define HTCAP_RxStaggeredSoundCap   0x02
#define HTCAP_TxStaggeredSoundCap   0x04
#define HTCAP_RxZLFCapable          0x08
#define HTCAP_TxZLFCapable          0x10
#define HTCAP_ImplicitTxBFCapable   0x20
    // Tx Beamforming 1 8bits
#define HTCAP_ExplicitCSITxBFCap    0x01
#define HTCAP_ExpUncompSteerMatrCap 0x02
    // Antenna Selection Capabilities 8bits
#define HTCAP_AntennaSelectionCap       0x01
#define HTCAP_ExplicitCSITxASCap        0x02
#define HTCAP_AntennaIndFeeTxASCap      0x04
#define HTCAP_ExplicitCSIFeedbackCap    0x08
#define HTCAP_AntennaIndFeedbackCap     0x10
#define HTCAP_RxASCap                   0x20
#define HTCAP_TxSoundPPDUsCap           0x40



struct zsHTCapability
{
    u8_t ElementID;
    u8_t Length;
    // HT Capability Info
    u16_t HtCapInfo;
    u8_t AMPDUParam;
    u8_t MCSSet[16];    //16 bytes
    // Extended HT Capability Info
    u8_t PCO;
    u8_t MCSFeedBack;

    u8_t TxBFCap[4];
    u8_t AselCap;
};

union zuHTCapability
{
    struct zsHTCapability Data;
    u8_t Byte[28];
};

    //channelinfo 8bits
#define ExtHtCap_ExtChannelOffsetAbove  0x01
#define ExtHtCap_ExtChannelOffsetBelow  0x03
#define ExtHtCap_RecomTxWidthSet        0x04
#define ExtHtCap_RIFSMode               0x08
#define ExtHtCap_ControlAccessOnly      0x10
    //operatinginfo 16bits
#define ExtHtCap_NonGFDevicePresent     0x0004
    //beaconinfo 16bits
#define ExtHtCap_DualBeacon             0x0040
#define ExtHtCap_DualSTBCProtection     0x0080
#define ExtHtCap_SecondaryBeacon        0x0100
#define ExtHtCap_LSIGTXOPProtectFullSup 0x0200
#define ExtHtCap_PCOActive              0x0400
#define ExtHtCap_PCOPhase               0x0800


struct zsExtHTCapability
{
    u8_t    ElementID;
    u8_t    Length;
    u8_t    ControlChannel;
    u8_t    ChannelInfo;
    u16_t   OperatingInfo;
    u16_t   BeaconInfo;
    // Supported MCS Set
    u8_t    MCSSet[16];
};

union zuExtHTCapability
{
    struct zsExtHTCapability Data;
    u8_t Byte[24];
};

struct InformationElementSta {
    struct zsHTCapability       HtCap;
    struct zsExtHTCapability    HtInfo;
};

struct InformationElementAp {
    struct zsHTCapability       HtCap;
};

#define ZM_MAX_FREQ_REQ_QUEUE  32
typedef void (*zfpFreqChangeCompleteCb)(zdev_t* dev);

struct zsWlanDevFreqControl
{
    u16_t                     freqReqQueue[ZM_MAX_FREQ_REQ_QUEUE];
    u8_t                     freqReqBw40[ZM_MAX_FREQ_REQ_QUEUE];
    u8_t                     freqReqExtOffset[ZM_MAX_FREQ_REQ_QUEUE];
    zfpFreqChangeCompleteCb   freqChangeCompCb[ZM_MAX_FREQ_REQ_QUEUE];
    u8_t                      freqReqQueueHead;
    u8_t                      freqReqQueueTail;
};

struct zsWlanDevAp
{
    u16_t   protectedObss;    /* protected overlap BSS */
    u16_t   staAgingTimeSec;  /* in second, STA will be deathed if it does not */
                              /* active for this long time                     */
    u16_t   staProbingTimeSec;/* in second, STA will be probed if it does not  */
                              /* active for this long time                     */
    u8_t    authSharing;      /* authentication on going*/
    u8_t    bStaAssociated;   /* 11b STA associated */
    u8_t    gStaAssociated;   /* 11g STA associated */
    u8_t    nStaAssociated;   /* 11n STA associated */
    u16_t   protectionMode;   /* AP protection mode flag */
    u16_t   staPowerSaving;   /* Set associated power saving STA count */



    zbuf_t*  uniArray[ZM_UNI_ARRAY_SIZE]; /* array to store unicast frames */
    u16_t   uniHead;
    u16_t   uniTail;

    /* HT Capability Info */
    union zuHTCapability HTCap; //CWYang(+)

    /* Extended HT Capability Info */
    union zuExtHTCapability ExtHTCap; //CWYang(+)

    /* STA table */
    struct zsStaTable staTable[ZM_MAX_STA_SUPPORT];

    /* WDS */
    struct zdStructWds wds;
    /* WPA */
    u8_t wpaIe[ZM_MAX_AP_SUPPORT][ZM_MAX_WPAIE_SIZE];
    u8_t wpaLen[ZM_MAX_AP_SUPPORT];
    u8_t stawpaIe[ZM_MAX_AP_SUPPORT][ZM_MAX_WPAIE_SIZE];
    u8_t stawpaLen[ZM_MAX_AP_SUPPORT];
    u8_t wpaSupport[ZM_MAX_AP_SUPPORT];

    //struct zsTkipSeed   bcSeed;
    u8_t bcKeyIndex[ZM_MAX_AP_SUPPORT];
    u8_t bcHalKeyIdx[ZM_MAX_AP_SUPPORT];
    struct zsMicVar     bcMicKey[ZM_MAX_AP_SUPPORT];
    u16_t iv16[ZM_MAX_AP_SUPPORT];
    u32_t iv32[ZM_MAX_AP_SUPPORT];

#ifdef ZM_ENABLE_CENC
    /* CENC */
    u32_t txiv[ZM_MAX_AP_SUPPORT][4];
#endif //ZM_ENABLE_CENC

    /* Virtual AP */
    u8_t    beaconCounter;
    u8_t    vapNumber;
    u8_t    apBitmap;                         /* Set bit-N to 1 to enable VAP */
    u8_t    hideSsid[ZM_MAX_AP_SUPPORT];
    u8_t    authAlgo[ZM_MAX_AP_SUPPORT];
    u8_t    ssid[ZM_MAX_AP_SUPPORT][32];      /* SSID */
    u8_t    ssidLen[ZM_MAX_AP_SUPPORT];       /* SSID length */
    u8_t    encryMode[ZM_MAX_AP_SUPPORT];
    u8_t    wepStatus[ZM_MAX_AP_SUPPORT];
    u16_t   capab[ZM_MAX_AP_SUPPORT];         /* Capability */
    u8_t    timBcmcBit[ZM_MAX_AP_SUPPORT];    /* BMCM bit of TIM */
    u8_t    wlanType[ZM_MAX_AP_SUPPORT];

    /* Array to store BC or MC frames */
    zbuf_t*  bcmcArray[ZM_MAX_AP_SUPPORT][ZM_BCMC_ARRAY_SIZE];
    u16_t   bcmcHead[ZM_MAX_AP_SUPPORT];
    u16_t   bcmcTail[ZM_MAX_AP_SUPPORT];

    u8_t                    qosMode;                          /* 1=>WME */
    u8_t                    uapsdEnabled;
    struct zsQueue*         uapsdQ;

    u8_t                    challengeText[128];

    struct InformationElementAp ie[ZM_MAX_STA_SUPPORT];


};

#define ZM_MAX_BLOCKING_AP_LIST_SIZE    4 /* 2^N */
struct zsBlockingAp
{
    u8_t addr[6];
    u8_t weight;
};

#define ZM_SCAN_MGR_SCAN_NONE           0
#define ZM_SCAN_MGR_SCAN_INTERNAL       1
#define ZM_SCAN_MGR_SCAN_EXTERNAL       2

struct zsWlanDevStaScanMgr
{
    u8_t                    scanReqs[2];
    u8_t                    currScanType;
    u8_t                    scanStartDelay;
};

#define ZM_PS_MSG_STATE_ACTIVE          0
#define ZM_PS_MSG_STATE_SLEEP           1
#define ZM_PS_MSG_STATE_T1              2
#define ZM_PS_MSG_STATE_T2              3
#define ZM_PS_MSG_STATE_S1              4

#define ZM_PS_MAX_SLEEP_PERIODS         3       // The number of beacon periods

struct zsWlanDevStaPSMgr
{
    u8_t                    state;
    u8_t                    isSleepAllowed;
    u8_t                    maxSleepPeriods;
    u8_t                    ticks;
    u32_t                   lastTxUnicastFrm;
    u32_t                   lastTxMulticastFrm;
    u32_t                   lastTxBroadcastFrm;
    u8_t                    tempWakeUp; /*enable when wake up but still in ps mode */
    u16_t                   sleepAllowedtick;
};

struct zsWlanDevSta
{
    u32_t                   beaconTxCnt;  /* Transmitted beacon counter (in IBSS) */
    u8_t                    txBeaconInd;  /* In IBSS mode, true means that we just transmit a beacon during
                                             last beacon period.
                                           */
    u16_t                   beaconCnt;    /* receive beacon count, will be perodically reset */
    u16_t                   bssid[3];     /* BSSID of connected AP */
    u8_t                    ssid[32];     /* SSID */
    u8_t                    ssidLen;      /* SSID length */
    u8_t                    mTxRate;      /* Tx rate for multicast */
    u8_t                    uTxRate;      /* Tx rate for unicast */
    u8_t                    mmTxRate;     /* Tx rate for management frame */
    u8_t                    bChannelScan;
    u8_t                    bScheduleScan;

    u8_t                    InternalScanReq;
    u16_t                   activescanTickPerChannel;
    u16_t                   passiveScanTickPerChannel;
    u16_t                   scanFrequency;
    u32_t                   connPowerInHalfDbm;

    u16_t                   currentFrequency;
    u16_t                   currentBw40;
    u16_t                   currentExtOffset;

    u8_t                    bPassiveScan;

    struct zsBlockingAp     blockingApList[ZM_MAX_BLOCKING_AP_LIST_SIZE];

    //struct zsBssInfo        bssInfoPool[ZM_MAX_BSS];
    struct zsBssInfo*       bssInfoArray[ZM_MAX_BSS];
    struct zsBssList        bssList;
    u8_t                    bssInfoArrayHead;
    u8_t                    bssInfoArrayTail;
    u8_t                    bssInfoFreeCount;

    u8_t                    authMode;
    u8_t                    currentAuthMode;
    u8_t                    wepStatus;
    u8_t                    encryMode;
    u8_t                    keyId;
#ifdef ZM_ENABLE_IBSS_WPA2PSK
    u8_t                    ibssWpa2Psk;
#endif
#ifdef ZM_ENABLE_CENC
    u8_t                    cencKeyId; //CENC
#endif //ZM_ENABLE_CENC
    u8_t                    dropUnencryptedPkts;
    u8_t                    ibssJoinOnly;
    u8_t                    adapterState;
    u8_t                    oldAdapterState;
    u8_t                    connectState;
    u8_t                    connectRetry;
    u8_t                    wpaState;
    u8_t                    wpaIe[ZM_MAX_IE_SIZE + 2];
    u8_t                    rsnIe[ZM_MAX_IE_SIZE + 2];
    u8_t                    challengeText[255+2];
    u8_t                    capability[2];
    //u8_t                    connectingHiddenAP;
    //u8_t                    scanWithSSID;
    u16_t                   aid;
    u32_t                   mgtFrameCount;
    u8_t                    bProtectionMode;
	u32_t					NonNAPcount;
	u8_t					RTSInAGGMode;
    u32_t                   connectTimer;
    u16_t                   atimWindow;
    u8_t                    desiredBssid[6];
    u8_t                    bDesiredBssid;
    struct zsTkipSeed       txSeed;
    struct zsTkipSeed       rxSeed[4];
    struct zsMicVar         txMicKey;
    struct zsMicVar         rxMicKey[4];
    u16_t                   iv16;
    u32_t                   iv32;
    struct zsOppositeInfo   oppositeInfo[ZM_MAX_OPPOSITE_COUNT];
    u8_t                    oppositeCount;
    u8_t                    bssNotFoundCount;     /* sitesurvey for search desired ISBB threshold */
    u16_t                   rxBeaconCount;
    u8_t                    beaconMissState;
    u32_t                   rxBeaconTotal;
    u8_t                    bIsSharedKey;
    u8_t                    connectTimeoutCount;

    u8_t                    recvAtim;

    /* ScanMgr Control block */
    struct zsWlanDevStaScanMgr scanMgr;
    struct zsWlanDevStaPSMgr   psMgr;

    // The callback would be called if receiving an unencrypted packets but
    // the station is in encrypted mode. The wrapper could decide whether
    // to drop the packet by its OS setting.
    zfpStaRxSecurityCheckCb pStaRxSecurityCheckCb;

    /* WME */
    u8_t                    apWmeCapability; //bit-0 => a WME AP
                                             //bit-7 => a UAPSD AP
    u8_t                    wmeParameterSetCount;

    u8_t                    wmeEnabled;
    #define ZM_STA_WME_ENABLE_BIT       0x1
    #define ZM_STA_UAPSD_ENABLE_BIT     0x2
    u8_t                    wmeQosInfo;

    u8_t                    wmeConnected;
    u8_t                    qosInfo;
    struct zsQueue*         uapsdQ;

    /* countermeasures */
    u8_t                    cmMicFailureCount;
    u8_t                    cmDisallowSsidLength;
    u8_t                    cmDisallowSsid[32];

    /* power-saving mode */
    u8_t                    powerSaveMode;
    zbuf_t*                 staPSDataQueue[ZM_PS_QUEUE_SIZE];
    u8_t                    staPSDataCount;

    /* IBSS power-saving mode */
    /* record the STA which has entered the PS mode */
    struct zsStaPSList      staPSList;
    /* queue the data of the PS STAs */
    zbuf_t*                  ibssPSDataQueue[ZM_PS_QUEUE_SIZE];
    u8_t                    ibssPSDataCount;
    u8_t                    ibssPrevPSDataCount;
    u8_t                    bIbssPSEnable;
    /* BIT_15: ON/OFF, BIT_0~14: Atim Timer */
    u16_t                   ibssAtimTimer;

    /* WPA2 */
    struct zsPmkidInfo      pmkidInfo;

    /* Multicast list related objects */
    struct zsMulticastList  multicastList;

    /* XP packet filter feature : */
    /* 1=>enable: All multicast address packets, not just the ones enumerated in the multicast address list. */
    /* 0=>disable */
    u8_t                    bAllMulticast;

    /* reassociation flag */
    u8_t                    connectByReasso;
    u8_t                    failCntOfReasso;

	/* for HT configure control setting */
    u8_t                    preambleTypeHT;  /* HT: 0 Mixed mode    1 Green field */
	u8_t                    htCtrlBandwidth;
	u8_t                    htCtrlSTBC;
	u8_t                    htCtrlSG;
    u8_t                    defaultTA;

    u8_t                    connection_11b;

    u8_t                    EnableHT;
    u8_t                    SG40;
    u8_t                    HT2040;
    /* for WPA setting */
    u8_t                    wpaSupport;
    u8_t                    wpaLen;

    /* IBSS related objects */
    u8_t                    ibssDelayedInd;
    struct zsPartnerNotifyEvent ibssDelayedIndEvent;
    u8_t                    ibssPartnerStatus;

    u8_t                    bAutoReconnect;

    u8_t                    flagFreqChanging;
    u8_t                    flagKeyChanging;
    struct zsBssInfo        ibssBssDesc;
    u8_t                    ibssBssIsCreator;
    u16_t                   ibssReceiveBeaconCount;
    u8_t                    ibssSiteSurveyStatus;

    u8_t                    disableProbingWithSsid;
#ifdef ZM_ENABLE_CENC
    /* CENC */
    u8_t                    cencIe[ZM_MAX_IE_SIZE + 2];
#endif //ZM_ENABLE_CENC
    u32_t txiv[4];  //Tx PN Sequence
    u32_t rxiv[4];  //Rx PN Sequence
    u32_t rxivGK[4];//Broadcast Rx PN Sequence
    u8_t  wepKey[4][32];    // For Software WEP
	u8_t  SWEncryMode[4];

    /* 802.11d */
    u8_t b802_11D;

    /* 802.11h */
    u8_t TPCEnable;
    u8_t DFSEnable;
    u8_t DFSDisableTx;

    /* Owl AP */
    u8_t athOwlAp;

    /* Enable BA response in driver */
    u8_t enableDrvBA;

    /* HT Capability Info */
    union zuHTCapability HTCap; //CWYang(+)

    /* Extended HT Capability Info */
    union zuExtHTCapability ExtHTCap; //CWYang(+)

    struct InformationElementSta   ie;

#define ZM_CACHED_FRAMEBODY_SIZE   200
    u8_t                    asocReqFrameBody[ZM_CACHED_FRAMEBODY_SIZE];
    u16_t                   asocReqFrameBodySize;
    u8_t                    asocRspFrameBody[ZM_CACHED_FRAMEBODY_SIZE];
    u16_t                   asocRspFrameBodySize;
    u8_t                    beaconFrameBody[ZM_CACHED_FRAMEBODY_SIZE];
    u16_t                   beaconFrameBodySize;

    u8_t                    ac0PriorityHigherThanAc2;
    u8_t                    SWEncryptEnable;

    u8_t                    leapEnabled;

    u32_t                    TotalNumberOfReceivePackets;
    u32_t                    TotalNumberOfReceiveBytes;
    u32_t                    avgSizeOfReceivePackets;

    u32_t                    ReceivedPacketRateCounter;
    u32_t                    ReceivedPktRatePerSecond;

    /* #2 Record the sequence number to determine whether the unicast frame is separated by RIFS or not */
#define    ZM_RIFS_STATE_DETECTING    0
#define    ZM_RIFS_STATE_DETECTED     1
#define    ZM_RIFS_TIMER_TIMEOUT      4480          // <Driver time>4480ms <Real time>7s
    u8_t                    rifsState;
    u8_t                    rifsLikeFrameCnt;
    u16_t                   rifsLikeFrameSequence[3];
    u32_t                   rifsTimer;
    u32_t                   rifsCount;

    /* RX filter desired by upper layers.  Note this contains some bits which must be filtered
       by sw since the hw supports only a subset of possible filter actions.= */
    u32_t  osRxFilter;

    u8_t   bSafeMode;

    u32_t  ibssAdditionalIESize;
    u8_t   ibssAdditionalIE[256];
}; //struct zsWlanDevSta

#define ZM_CMD_QUEUE_SIZE                   256  //Roger Check, test 64 when ready

#define ZM_OID_READ                         1
#define ZM_OID_WRITE                        2
#define ZM_OID_INTERNAL_WRITE               3
#define ZM_CMD_SET_FREQUENCY                4
#define ZM_CMD_SET_KEY                      5
#define ZM_CWM_READ                         6
#define ZM_MAC_READ                         7
#define ZM_ANI_READ                         8
#define ZM_EEPROM_READ                      9
#define ZM_EEPROM_WRITE                     0x0A
#define ZM_OID_CHAN							0x30
#define ZM_OID_SYNTH						0x32
#define ZM_OID_TALLY						0x81
#define ZM_OID_TALLY_APD					0x82

#define ZM_OID_DKTX_STATUS                  0x92
#define ZM_OID_FLASH_CHKSUM                 0xD0
#define ZM_OID_FLASH_READ                   0xD1
#define ZM_OID_FLASH_PROGRAM                0xD2
#define ZM_OID_FW_DL_INIT                   0xD3

/* Driver to Firmware OID */
#define ZM_CMD_ECHO         0x80
#define ZM_CMD_TALLY        0x81
#define ZM_CMD_TALLY_APD    0x82
#define ZM_CMD_CONFIG       0x83
#define ZM_CMD_RREG         0x00
#define ZM_CMD_WREG         0x01
#define ZM_CMD_RMEM         0x02
#define ZM_CMD_WMEM         0x03
#define ZM_CMD_BITAND       0x04
#define ZM_CMD_BITOR        0x05
#define ZM_CMD_EKEY         0x28
#define ZM_CMD_DKEY         0x29
#define ZM_CMD_FREQUENCY    0x30
#define ZM_CMD_RF_INIT      0x31
#define ZM_CMD_SYNTH        0x32
#define ZM_CMD_FREQ_STRAT   0x33
#define ZM_CMD_RESET        0x90
#define ZM_CMD_DKRESET      0x91
#define ZM_CMD_DKTX_STATUS  0x92
#define ZM_CMD_FDC          0xA0
#define ZM_CMD_WREEPROM     0xB0
#define ZM_CMD_WFLASH       0xB0
#define ZM_CMD_FLASH_ERASE  0xB1
#define ZM_CMD_FLASH_PROG   0xB2
#define ZM_CMD_FLASH_CHKSUM 0xB3
#define ZM_CMD_FLASH_READ   0xB4
#define ZM_CMD_FW_DL_INIT   0xB5
#define ZM_CMD_MEM_WREEPROM 0xBB


/* duplicate filter table column */
#define ZM_FILTER_TABLE_COL                 2 /* 2^n */
/* duplicate filter table Row */
#define ZM_FILTER_TABLE_ROW                 8 /* 2^n */

/* duplicate filter table structure */
struct zsRxFilter
{
    u16_t addr[3];
    u16_t seq;
    u8_t up;
};

struct zsWlanDev
{
    /* AP global variables */
    struct zsWlanDevAp ap;
    /* STA global variables */
    struct zsWlanDevSta sta;
    /* save wrapper setting */
    struct zsWrapperSetting ws;
    /* features determined by wrapper (vendor) */
    struct zsWrapperFeatureCtrl wfc;
    /* Traffic Monitor tally */
    struct zsTrafTally trafTally;
    /* Communication tally */
    struct zsCommTally commTally;
    /* Duplicate frame filter table */
    struct zsRxFilter rxFilterTbl[ZM_FILTER_TABLE_COL][ZM_FILTER_TABLE_ROW];
    /* Regulatory table */
    struct zsRegulationTable  regulationTable;

    /* */
    struct zsWlanDevFreqControl freqCtrl;

    enum devState state;

    u8_t  halState;
    u8_t  wlanMode;         /* AP/INFRASTRUCTURE/IBSS/PSEUDO */
    u16_t macAddr[3];       /* MAC address */
    u16_t beaconInterval;   /* beacon Interval */
    u8_t dtim;              /* DTIM period */
    u8_t            CurrentDtimCount;
    u8_t  preambleType;
    u8_t  preambleTypeInUsed;
    u8_t  maxTxPower2;	    /* 2.4 GHz Max Tx power (Unit: 0.5 dBm) */
    u8_t  maxTxPower5;	    /* 5 GHz Max Tx power (Unit: 0.5 dBm) */
    u8_t  connectMode;
    u32_t supportMode;

    u8_t bRate;             /* 11b Support Rate bit map */
    u8_t bRateBasic;        /* 11b Basic Rate bit map */
    u8_t gRate;             /* 11g Support Rate bit map */
    u8_t gRateBasic;        /* 11g Basic Rate bit map */
    /* channel index point to the item in regulation table */
    u8_t channelIndex;

    /* channel management */
    u8_t    BandWidth40;
    u8_t    ExtOffset;      //1 above, 3 below, 0 not present
    u16_t   frequency;      /* operation frequency */

    u8_t erpElement;        /* ERP information element data */

    u8_t disableSelfCts;    /* set to 1 to disable Self-CTS */
    u8_t bgMode;

	/* private test flag */
    u32_t enableProtectionMode;   /* force enable/disable self cts */
	u32_t checksumTest;     /* OTUS checksum test 1=>zero checksum 0=>normal */
	u32_t rxPacketDump;     /* rx packet dump */

    u8_t enableAggregation; /* force enable/disable A-MSPU */
    u8_t enableWDS;         /* force enable/disable WDS testing */
	u8_t enableTxPathMode;  /* OTUS special testing mode 1=>diable, 0=>enable: ZM_SYSTEM_TEST_MODE */
    u8_t enableHALDbgInfo;  /*  */

    u32_t forceTxTPC;       /* force tx packet send TPC */

    u16_t seq[4];
    u16_t mmseq;

    /* driver core time tick */
    u32_t tick;
    u16_t tickIbssSendBeacon;
    u16_t tickIbssReceiveBeacon;

    /* RTS threshold */
    u16_t rtsThreshold;

    /* fragmentation threshold,  256 <= value <= 2346, 0=disabled */
    u16_t fragThreshold;

    /* Tx Rate */
    u16_t txMCS;
    u16_t txMT;
    u32_t CurrentTxRateKbps; //CWYang(+)
    /* Rx Rate */
    u32_t CurrentRxRateKbps; //Janet(+)
    u8_t CurrentRxRateUpdated;
    u8_t modulationType;
    u8_t rxInfo;
    u16_t rateField;

    /* timer related objects */
    struct zsTimerList  timerList;
    u8_t                bTimerReady;

    /* for defragmentation */
    struct zsDefragList defragTable;

    /* Data struct for Interface Dependent Layer */
    //struct zsIdlStruct idlStruct;

    /* Signal Strength/Quality Related Parameters */
    u8_t SignalStrength; //CWYang(+)
    u8_t SignalQuality;  //CWYang(+)



    /* QoS */
    zbuf_t* vtxq[4][ZM_VTXQ_SIZE];
    u16_t vtxqHead[4];
    u16_t vtxqTail[4];
    u16_t qosDropIpFrag[4];

    /* Management Tx queue */
    zbuf_t* vmmq[ZM_VMMQ_SIZE];
    u16_t vmmqHead;
    u16_t vmmqTail;

    u8_t                vtxqPushing;

    /*
     * add by honda
     * 1. Aggregate queues
     * 2. STA's associated information and queue number
     * 3. rx aggregation re-ordering queue
     */
    struct aggQueue    *aggQPool[ZM_AGG_POOL_SIZE];
    u8_t                aggInitiated;
    u8_t                addbaComplete;
    u8_t                addbaCount;
    u8_t                aggState;
    u8_t                destLock;
    struct aggSta       aggSta[ZM_MAX_STA_SUPPORT];
    struct agg_tid_rx  *tid_rx[ZM_AGG_POOL_SIZE];
    struct aggTally     agg_tal;
    struct destQ        destQ;
    struct baw_enabler *baw_enabler;
    struct ieee80211_cwm    cwm;
    u16_t               reorder;
    u16_t               seq_debug;
    /* rate control */
    u32_t txMPDU[ZM_RATE_TABLE_SIZE];
    u32_t txFail[ZM_RATE_TABLE_SIZE];
    u32_t PER[ZM_RATE_TABLE_SIZE];
    u16_t probeCount;
    u16_t probeSuccessCount;
    u16_t probeInterval;
    u16_t success_probing;
    /*
     * end of add by honda
     */

    /* airopeek sniffer mode for upper sw */
    u32_t               swSniffer;   /* window: airoPeek */
    u32_t               XLinkMode;

    /* MDK mode */
    /* init by 0=>normal driver 1=>MDK driver */
    u32_t               modeMDKEnable;

    u32_t               heartBeatNotification;

    /* pointer for HAL Plus private memory */
    void* hpPrivate;

    /* for WPA setting */
    //u8_t                    wpaSupport[ZM_MAX_AP_SUPPORT];
    //u8_t                    wpaLen[ZM_MAX_AP_SUPPORT];
    //u8_t                    wpaIe[ZM_MAX_AP_SUPPORT][ZM_MAX_IE_SIZE];

    struct zsLedStruct      ledStruct;

    /* ani flag */
    u8_t aniEnable;
    u16_t txq_threshold;

	//Skip Mic Error Check
	u8_t	TKIP_Group_KeyChanging;

	u8_t    dynamicSIFSEnable;

	u8_t    queueFlushed;

    u16_t (*zfcbAuthNotify)(zdev_t* dev, u16_t* macAddr);
    u16_t (*zfcbAsocNotify)(zdev_t* dev, u16_t* macAddr, u8_t* body, u16_t bodySize, u16_t port);
    u16_t (*zfcbDisAsocNotify)(zdev_t* dev, u8_t* macAddr, u16_t port);
    u16_t (*zfcbApConnectNotify)(zdev_t* dev, u8_t* macAddr, u16_t port);
    void (*zfcbConnectNotify)(zdev_t* dev, u16_t status, u16_t* bssid);
    void (*zfcbScanNotify)(zdev_t* dev, struct zsScanResult* result);
    void (*zfcbMicFailureNotify)(zdev_t* dev, u16_t* addr, u16_t status);
    void (*zfcbApMicFailureNotify)(zdev_t* dev, u8_t* addr, zbuf_t* buf);
    void (*zfcbIbssPartnerNotify)(zdev_t* dev, u16_t status, struct zsPartnerNotifyEvent *event);
    void (*zfcbMacAddressNotify)(zdev_t* dev, u8_t* addr);
    void (*zfcbSendCompleteIndication)(zdev_t* dev, zbuf_t* buf);
    void (*zfcbRecvEth)(zdev_t* dev, zbuf_t* buf, u16_t port);
    void (*zfcbRecv80211)(zdev_t* dev, zbuf_t* buf, struct zsAdditionInfo* addInfo);
    void (*zfcbRestoreBufData)(zdev_t* dev, zbuf_t* buf);
#ifdef ZM_ENABLE_CENC
    u16_t (*zfcbCencAsocNotify)(zdev_t* dev, u16_t* macAddr, u8_t* body,
            u16_t bodySize, u16_t port);
#endif //ZM_ENABLE_CENC
    u8_t (*zfcbClassifyTxPacket)(zdev_t* dev, zbuf_t* buf);
    void (*zfcbHwWatchDogNotify)(zdev_t* dev);
};


struct zsWlanKey
{
    u8_t key;
};


/* These macros are defined here for backward compatibility */
/* Please leave them alone */
/* For Tx packet allocated in upper layer layer */
#define zmw_tx_buf_readb(dev, buf, offset) zmw_buf_readb(dev, buf, offset)
#define zmw_tx_buf_readh(dev, buf, offset) zmw_buf_readh(dev, buf, offset)
#define zmw_tx_buf_writeb(dev, buf, offset, value) zmw_buf_writeb(dev, buf, offset, value)
#define zmw_tx_buf_writeh(dev, buf, offset, value) zmw_buf_writeh(dev, buf, offset, value)

/* For Rx packet allocated in driver */
#define zmw_rx_buf_readb(dev, buf, offset) zmw_buf_readb(dev, buf, offset)
#define zmw_rx_buf_readh(dev, buf, offset) zmw_buf_readh(dev, buf, offset)
#define zmw_rx_buf_writeb(dev, buf, offset, value) zmw_buf_writeb(dev, buf, offset, value)
#define zmw_rx_buf_writeh(dev, buf, offset, value) zmw_buf_writeh(dev, buf, offset, value)

#endif /* #ifndef _STRUCT_H */