| /* |
| * Copyright (c) 2011-2017 The Linux Foundation. All rights reserved. |
| * |
| * Previously licensed under the ISC license by Qualcomm Atheros, 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. |
| */ |
| |
| /* |
| * This file was originally distributed by Qualcomm Atheros, Inc. |
| * under proprietary terms before Copyright ownership was assigned |
| * to the Linux Foundation. |
| */ |
| |
| /** |
| * \file csr_api.h |
| * |
| * Exports and types for the Common Scan and Roaming Module interfaces. |
| */ |
| |
| #ifndef CSRAPI_H__ |
| #define CSRAPI_H__ |
| |
| #include "sir_api.h" |
| #include "sir_mac_prot_def.h" |
| #include "csr_link_list.h" |
| |
| #define CSR_INVALID_SCANRESULT_HANDLE (NULL) |
| |
| typedef enum { |
| /* never used */ |
| eCSR_AUTH_TYPE_NONE, |
| /* MAC layer authentication types */ |
| eCSR_AUTH_TYPE_OPEN_SYSTEM, |
| eCSR_AUTH_TYPE_SHARED_KEY, |
| eCSR_AUTH_TYPE_AUTOSWITCH, |
| |
| /* Upper layer authentication types */ |
| eCSR_AUTH_TYPE_WPA, |
| eCSR_AUTH_TYPE_WPA_PSK, |
| eCSR_AUTH_TYPE_WPA_NONE, |
| |
| eCSR_AUTH_TYPE_RSN, |
| eCSR_AUTH_TYPE_RSN_PSK, |
| eCSR_AUTH_TYPE_FT_RSN, |
| eCSR_AUTH_TYPE_FT_RSN_PSK, |
| #ifdef FEATURE_WLAN_WAPI |
| eCSR_AUTH_TYPE_WAPI_WAI_CERTIFICATE, |
| eCSR_AUTH_TYPE_WAPI_WAI_PSK, |
| #endif /* FEATURE_WLAN_WAPI */ |
| eCSR_AUTH_TYPE_CCKM_WPA, |
| eCSR_AUTH_TYPE_CCKM_RSN, |
| eCSR_AUTH_TYPE_RSN_PSK_SHA256, |
| eCSR_AUTH_TYPE_RSN_8021X_SHA256, |
| eCSR_NUM_OF_SUPPORT_AUTH_TYPE, |
| eCSR_AUTH_TYPE_FAILED = 0xff, |
| eCSR_AUTH_TYPE_UNKNOWN = eCSR_AUTH_TYPE_FAILED, |
| |
| } eCsrAuthType; |
| |
| typedef enum { |
| eCSR_ENCRYPT_TYPE_NONE, |
| eCSR_ENCRYPT_TYPE_WEP40_STATICKEY, |
| eCSR_ENCRYPT_TYPE_WEP104_STATICKEY, |
| eCSR_ENCRYPT_TYPE_WEP40, |
| eCSR_ENCRYPT_TYPE_WEP104, |
| eCSR_ENCRYPT_TYPE_TKIP, |
| eCSR_ENCRYPT_TYPE_AES, |
| #ifdef FEATURE_WLAN_WAPI |
| /* WAPI */ |
| eCSR_ENCRYPT_TYPE_WPI, |
| #endif /* FEATURE_WLAN_WAPI */ |
| #ifdef FEATURE_WLAN_ESE |
| eCSR_ENCRYPT_TYPE_KRK, |
| #ifdef WLAN_FEATURE_ROAM_OFFLOAD |
| eCSR_ENCRYPT_TYPE_BTK, |
| #endif |
| #endif /* FEATURE_WLAN_ESE */ |
| #ifdef WLAN_FEATURE_11W |
| /* 11w BIP */ |
| eCSR_ENCRYPT_TYPE_AES_CMAC, |
| #endif |
| eCSR_ENCRYPT_TYPE_ANY, |
| eCSR_NUM_OF_ENCRYPT_TYPE = eCSR_ENCRYPT_TYPE_ANY, |
| |
| eCSR_ENCRYPT_TYPE_FAILED = 0xff, |
| eCSR_ENCRYPT_TYPE_UNKNOWN = eCSR_ENCRYPT_TYPE_FAILED, |
| |
| } eCsrEncryptionType; |
| |
| /*--------------------------------------------------------------------------- |
| Enumeration of the various Security types |
| ---------------------------------------------------------------------------*/ |
| typedef enum { |
| eCSR_SECURITY_TYPE_WPA, |
| eCSR_SECURITY_TYPE_RSN, |
| #ifdef FEATURE_WLAN_WAPI |
| eCSR_SECURITY_TYPE_WAPI, |
| #endif /* FEATURE_WLAN_WAPI */ |
| eCSR_SECURITY_TYPE_UNKNOWN, |
| |
| } eCsrSecurityType; |
| |
| typedef enum { |
| /* 11a/b/g only, no HT, no proprietary */ |
| eCSR_DOT11_MODE_abg = 0x0001, |
| eCSR_DOT11_MODE_11a = 0x0002, |
| eCSR_DOT11_MODE_11b = 0x0004, |
| eCSR_DOT11_MODE_11g = 0x0008, |
| eCSR_DOT11_MODE_11n = 0x0010, |
| eCSR_DOT11_MODE_11g_ONLY = 0x0020, |
| eCSR_DOT11_MODE_11n_ONLY = 0x0040, |
| eCSR_DOT11_MODE_11b_ONLY = 0x0080, |
| eCSR_DOT11_MODE_11ac = 0x0100, |
| eCSR_DOT11_MODE_11ac_ONLY = 0x0200, |
| /* |
| * This is for WIFI test. It is same as eWNIAPI_MAC_PROTOCOL_ALL |
| * except when it starts IBSS in 11B of 2.4GHz |
| * It is for CSR internal use |
| */ |
| eCSR_DOT11_MODE_AUTO = 0x0400, |
| eCSR_DOT11_MODE_11ax = 0x0800, |
| eCSR_DOT11_MODE_11ax_ONLY = 0x1000, |
| |
| /* specify the number of maximum bits for phyMode */ |
| eCSR_NUM_PHY_MODE = 16, |
| } eCsrPhyMode; |
| |
| /** |
| * enum eCsrRoamBssType - BSS type in CSR operations |
| * @eCSR_BSS_TYPE_INFRASTRUCTURE: Infrastructure station |
| * @eCSR_BSS_TYPE_INFRA_AP: SoftAP |
| * @eCSR_BSS_TYPE_IBSS: IBSS network we'll not start |
| * @eCSR_BSS_TYPE_START_IBSS: IBSS network we'll start if no partners found |
| * @eCSR_BSS_TYPE_NDI: NAN datapath interface |
| * @eCSR_BSS_TYPE_ANY: any BSS type (IBSS or Infrastructure) |
| */ |
| typedef enum { |
| eCSR_BSS_TYPE_INFRASTRUCTURE, |
| eCSR_BSS_TYPE_INFRA_AP, |
| eCSR_BSS_TYPE_IBSS, |
| eCSR_BSS_TYPE_START_IBSS, |
| eCSR_BSS_TYPE_NDI, |
| eCSR_BSS_TYPE_ANY, |
| } eCsrRoamBssType; |
| |
| typedef enum { |
| eCSR_SCAN_REQUEST_11D_SCAN = 1, |
| eCSR_SCAN_REQUEST_FULL_SCAN, |
| eCSR_SCAN_IDLE_MODE_SCAN, |
| eCSR_SCAN_HO_PROBE_SCAN, /* direct probe on entry from candidate list */ |
| eCSR_SCAN_P2P_DISCOVERY, |
| |
| eCSR_SCAN_SOFTAP_CHANNEL_RANGE, |
| eCSR_SCAN_P2P_FIND_PEER, |
| } eCsrRequestType; |
| |
| typedef enum { |
| eCSR_SCAN_RESULT_GET = 0, |
| eCSR_SCAN_RESULT_FLUSH = 1, /* to delete all cached scan results */ |
| } eCsrScanResultCmd; |
| |
| typedef enum { |
| eCSR_SCAN_SUCCESS, |
| eCSR_SCAN_FAILURE, |
| eCSR_SCAN_ABORT, |
| eCSR_SCAN_FOUND_PEER, |
| } eCsrScanStatus; |
| |
| /* |
| * Reason to abort the scan |
| * The reason can used later to decide whether to update the scan results |
| * to upper layer or not |
| */ |
| typedef enum { |
| eCSR_SCAN_ABORT_DEFAULT = 1, |
| eCSR_SCAN_ABORT_DUE_TO_BAND_CHANGE, /* Scan abort due to band change */ |
| eCSR_SCAN_ABORT_SSID_ONLY |
| } eCsrAbortReason; |
| |
| typedef enum { |
| eCSR_BW_20MHz_VAL = 20, |
| eCSR_BW_40MHz_VAL = 40, |
| eCSR_BW_80MHz_VAL = 80, |
| eCSR_BW_160MHz_VAL = 160 |
| } eCSR_BW_Val; |
| |
| typedef enum { |
| eCSR_INI_SINGLE_CHANNEL_CENTERED = 0, |
| eCSR_INI_DOUBLE_CHANNEL_HIGH_PRIMARY, |
| eCSR_INI_DOUBLE_CHANNEL_LOW_PRIMARY, |
| eCSR_INI_QUADRUPLE_CHANNEL_20MHZ_LOW_40MHZ_CENTERED, |
| eCSR_INI_QUADRUPLE_CHANNEL_20MHZ_CENTERED_40MHZ_CENTERED, |
| eCSR_INI_QUADRUPLE_CHANNEL_20MHZ_HIGH_40MHZ_CENTERED, |
| eCSR_INI_QUADRUPLE_CHANNEL_20MHZ_LOW_40MHZ_LOW, |
| eCSR_INI_QUADRUPLE_CHANNEL_20MHZ_HIGH_40MHZ_LOW, |
| eCSR_INI_QUADRUPLE_CHANNEL_20MHZ_LOW_40MHZ_HIGH, |
| eCSR_INI_QUADRUPLE_CHANNEL_20MHZ_HIGH_40MHZ_HIGH, |
| eCSR_INI_CHANNEL_BONDING_STATE_MAX |
| } eIniChanBondState; |
| |
| #define CSR_RSN_PMKID_SIZE 16 |
| #define CSR_MAX_PMKID_ALLOWED 32 |
| #define CSR_WEP40_KEY_LEN 5 |
| #define CSR_WEP104_KEY_LEN 13 |
| #define CSR_TKIP_KEY_LEN 32 |
| #define CSR_AES_KEY_LEN 16 |
| #define CSR_MAX_TX_POWER (WNI_CFG_CURRENT_TX_POWER_LEVEL_STAMAX) |
| #define CSR_MAX_RSC_LEN 16 |
| #ifdef FEATURE_WLAN_WAPI |
| #define CSR_WAPI_BKID_SIZE 16 |
| #define CSR_MAX_BKID_ALLOWED 16 |
| #define CSR_WAPI_KEY_LEN 32 |
| #define CSR_MAX_KEY_LEN (CSR_WAPI_KEY_LEN) /* longest one is for WAPI */ |
| #else |
| #define CSR_MAX_KEY_LEN (CSR_TKIP_KEY_LEN) /* longest one is for TKIP */ |
| #endif /* FEATURE_WLAN_WAPI */ |
| #ifdef FEATURE_WLAN_ESE |
| #define CSR_KRK_KEY_LEN 16 |
| #endif |
| |
| typedef struct tagCsrChannelInfo { |
| uint8_t numOfChannels; |
| uint8_t *ChannelList; /* it will be an array of channels */ |
| } tCsrChannelInfo, *tpCsrChannelInfo; |
| |
| typedef struct tagCsrSSIDInfo { |
| tSirMacSSid SSID; |
| bool handoffPermitted; |
| bool ssidHidden; |
| } tCsrSSIDInfo; |
| |
| typedef struct tagCsrSSIDs { |
| uint32_t numOfSSIDs; |
| tCsrSSIDInfo *SSIDList; /* To be allocated for array of SSIDs */ |
| } tCsrSSIDs; |
| |
| typedef struct tagCsrBSSIDs { |
| uint32_t numOfBSSIDs; |
| struct qdf_mac_addr *bssid; |
| } tCsrBSSIDs; |
| |
| typedef struct tagCsrStaParams { |
| uint16_t capability; |
| uint8_t extn_capability[SIR_MAC_MAX_EXTN_CAP]; |
| uint8_t supported_rates_len; |
| uint8_t supported_rates[SIR_MAC_MAX_SUPP_RATES]; |
| uint8_t htcap_present; |
| tSirHTCap HTCap; |
| uint8_t vhtcap_present; |
| tSirVHTCap VHTCap; |
| uint8_t uapsd_queues; |
| uint8_t max_sp; |
| uint8_t supported_channels_len; |
| uint8_t supported_channels[SIR_MAC_MAX_SUPP_CHANNELS]; |
| uint8_t supported_oper_classes_len; |
| uint8_t supported_oper_classes[CDS_MAX_SUPP_OPER_CLASSES]; |
| } tCsrStaParams; |
| |
| typedef struct tagCsrScanRequest { |
| tSirScanType scanType; |
| struct qdf_mac_addr bssid; |
| eCsrRoamBssType BSSType; |
| tCsrSSIDs SSIDs; |
| tCsrChannelInfo ChannelInfo; |
| uint32_t minChnTime; /* in units of milliseconds */ |
| uint32_t maxChnTime; /* in units of milliseconds */ |
| /* In units of milliseconds, ignored when not connected */ |
| uint32_t restTime; |
| /* In units of milliseconds, ignored when not connected */ |
| uint32_t min_rest_time; |
| /* In units of milliseconds, ignored when not connected */ |
| uint32_t idle_time; |
| uint32_t uIEFieldLen; |
| uint8_t *pIEField; |
| enum wmi_dwelltime_adaptive_mode scan_adaptive_dwell_mode; |
| eCsrRequestType requestType; /* 11d scan or full scan */ |
| bool p2pSearch; |
| bool skipDfsChnlInP2pSearch; |
| bool bcnRptReqScan; /* is Scan issued by Beacon Report Request */ |
| uint32_t scan_id; |
| uint32_t timestamp; |
| } tCsrScanRequest; |
| |
| typedef struct tagCsrScanResultInfo { |
| /* |
| * Carry the IEs for the current BSSDescription. |
| * A pointer to tDot11fBeaconIEs. Maybe NULL for start BSS. |
| */ |
| void *pvIes; |
| tAniSSID ssId; |
| unsigned long timer; /* timer is variable for hidden SSID timer */ |
| /* |
| * This member must be the last in the structure because the |
| * end of tSirBssDescription is an |
| * array with nonknown size at this time */ |
| tSirBssDescription BssDescriptor; |
| } tCsrScanResultInfo; |
| |
| typedef struct tagCsrEncryptionList { |
| |
| uint32_t numEntries; |
| eCsrEncryptionType encryptionType[eCSR_NUM_OF_ENCRYPT_TYPE]; |
| |
| } tCsrEncryptionList, *tpCsrEncryptionList; |
| |
| typedef struct tagCsrAuthList { |
| uint32_t numEntries; |
| eCsrAuthType authType[eCSR_NUM_OF_SUPPORT_AUTH_TYPE]; |
| } tCsrAuthList, *tpCsrAuthList; |
| |
| typedef struct tagCsrMobilityDomainInfo { |
| uint8_t mdiePresent; |
| uint16_t mobilityDomain; |
| } tCsrMobilityDomainInfo; |
| |
| #ifdef FEATURE_WLAN_ESE |
| typedef struct tagCsrEseCckmInfo { |
| uint32_t reassoc_req_num; |
| bool krk_plumbed; |
| uint8_t krk[SIR_KRK_KEY_LEN]; |
| #ifdef WLAN_FEATURE_ROAM_OFFLOAD |
| uint8_t btk[SIR_BTK_KEY_LEN]; |
| #endif |
| } tCsrEseCckmInfo; |
| |
| #define CSR_DOT11F_IE_RSN_MAX_LEN (114) |
| typedef struct tagCsrEseCckmIe { |
| uint8_t cckmIe[CSR_DOT11F_IE_RSN_MAX_LEN]; |
| uint8_t cckmIeLen; |
| } tCsrEseCckmIe; |
| #endif /* FEATURE_WLAN_ESE */ |
| |
| typedef struct sCsrChannel_ { |
| uint8_t numChannels; |
| uint8_t channelList[WNI_CFG_VALID_CHANNEL_LIST_LEN]; |
| } sCsrChannel; |
| |
| typedef struct tagCsrScanResultFilter { |
| tCsrBSSIDs BSSIDs; |
| tCsrSSIDs SSIDs; |
| tCsrChannelInfo ChannelInfo; |
| tCsrAuthList authType; |
| tCsrEncryptionList EncryptionType; |
| /* |
| * eCSR_ENCRYPT_TYPE_ANY cannot be set in multicast encryption type. |
| * If caller doesn't case, put all supported encryption types in here |
| */ |
| tCsrEncryptionList mcEncryptionType; |
| eCsrRoamBssType BSSType; |
| /* its a bit mask of all the needed phy mode defined in eCsrPhyMode */ |
| eCsrPhyMode phyMode; |
| /* |
| * If countryCode[0] is not 0, countryCode is checked |
| * independent of fCheckUnknownCountryCode |
| */ |
| uint8_t countryCode[WNI_CFG_COUNTRY_CODE_LEN]; |
| uint8_t uapsd_mask; |
| /* For WPS filtering if true => auth and ecryption should be ignored */ |
| bool bWPSAssociation; |
| bool bOSENAssociation; |
| /* |
| * For measurement reports --> if set, only SSID, |
| * BSSID and channel is considered for filtering. |
| */ |
| bool fMeasurement; |
| tCsrMobilityDomainInfo MDID; |
| bool p2pResult; |
| #ifdef WLAN_FEATURE_11W |
| /* Management Frame Protection */ |
| bool MFPEnabled; |
| uint8_t MFPRequired; |
| uint8_t MFPCapable; |
| #endif |
| /* The following flag is used to distinguish the |
| * roaming case while building the scan filter and |
| * applying it on to the scan results. This is mainly |
| * used to support whitelist ssid feature. |
| */ |
| uint8_t scan_filter_for_roam; |
| struct sCsrChannel_ pcl_channels; |
| struct qdf_mac_addr bssid_hint; |
| enum tQDF_ADAPTER_MODE csrPersona; |
| } tCsrScanResultFilter; |
| |
| typedef struct sCsrChnPower_ { |
| uint8_t firstChannel; |
| uint8_t numChannels; |
| uint8_t maxtxPower; |
| } sCsrChnPower; |
| |
| typedef struct tagCsr11dinfo { |
| sCsrChannel Channels; |
| uint8_t countryCode[WNI_CFG_COUNTRY_CODE_LEN + 1]; |
| /* max power channel list */ |
| sCsrChnPower ChnPower[WNI_CFG_VALID_CHANNEL_LIST_LEN]; |
| } tCsr11dinfo; |
| |
| typedef enum { |
| eCSR_ROAM_CANCELLED = 1, |
| /* it means error happens before assoc_start/roaming_start is called. */ |
| eCSR_ROAM_FAILED, |
| /* |
| * a CSR trigger roaming operation starts, |
| * callback may get a pointer to tCsrConnectedProfile |
| */ |
| eCSR_ROAM_ROAMING_START, |
| /* a CSR trigger roaming operation is completed */ |
| eCSR_ROAM_ROAMING_COMPLETION, |
| /* Connection completed status. */ |
| eCSR_ROAM_CONNECT_COMPLETION, |
| /* |
| * an association or start_IBSS operation starts, |
| * callback may get a pointer to tCsrRoamProfile and |
| * a pointer to tSirBssDescription |
| */ |
| eCSR_ROAM_ASSOCIATION_START, |
| /* |
| * a roaming operation is finish, see eCsrRoamResult for |
| * possible data passed back |
| */ |
| eCSR_ROAM_ASSOCIATION_COMPLETION, |
| eCSR_ROAM_DISASSOCIATED, |
| eCSR_ROAM_ASSOCIATION_FAILURE, |
| /* when callback with this flag. it gets a pointer to the BSS desc. */ |
| eCSR_ROAM_SHOULD_ROAM, |
| /* A new candidate for PMKID is found */ |
| eCSR_ROAM_SCAN_FOUND_NEW_BSS, |
| /* CSR is done lostlink roaming and still cannot reconnect */ |
| eCSR_ROAM_LOSTLINK, |
| /* a link lost is detected. CSR starts roaming. */ |
| eCSR_ROAM_LOSTLINK_DETECTED, |
| /* |
| * TKIP MIC error detected, callback gets a pointer |
| * to tpSirSmeMicFailureInd |
| */ |
| eCSR_ROAM_MIC_ERROR_IND, |
| /* IBSS indications. */ |
| eCSR_ROAM_IBSS_IND, |
| /* |
| * Update the connection status, useful for IBSS: new peer added, |
| * network is active etc. |
| */ |
| eCSR_ROAM_CONNECT_STATUS_UPDATE, |
| eCSR_ROAM_GEN_INFO, |
| eCSR_ROAM_SET_KEY_COMPLETE, |
| eCSR_ROAM_IBSS_LEAVE, /* IBSS indications. */ |
| /* BSS in SoftAP mode status indication */ |
| eCSR_ROAM_INFRA_IND, |
| eCSR_ROAM_WPS_PBC_PROBE_REQ_IND, |
| eCSR_ROAM_FT_RESPONSE, |
| eCSR_ROAM_FT_START, |
| eCSR_ROAM_REMAIN_CHAN_READY, |
| /* this mean error happens before assoc_start/roam_start is called. */ |
| eCSR_ROAM_SESSION_OPENED, |
| eCSR_ROAM_FT_REASSOC_FAILED, |
| eCSR_ROAM_PMK_NOTIFY, |
| /* |
| * Following 4 enums are used by FEATURE_WLAN_LFR_METRICS |
| * but they are needed for compilation even when |
| * FEATURE_WLAN_LFR_METRICS is not defined. |
| */ |
| eCSR_ROAM_PREAUTH_INIT_NOTIFY, |
| eCSR_ROAM_PREAUTH_STATUS_SUCCESS, |
| eCSR_ROAM_PREAUTH_STATUS_FAILURE, |
| eCSR_ROAM_HANDOVER_SUCCESS, |
| /* |
| * TDLS callback events |
| */ |
| eCSR_ROAM_TDLS_STATUS_UPDATE, |
| eCSR_ROAM_RESULT_MGMT_TX_COMPLETE_IND, |
| |
| /* Disaconnect all the clients */ |
| eCSR_ROAM_DISCONNECT_ALL_P2P_CLIENTS, |
| /* Stopbss triggered from SME due to different */ |
| eCSR_ROAM_SEND_P2P_STOP_BSS, |
| /* beacon interval */ |
| #ifdef WLAN_FEATURE_11W |
| eCSR_ROAM_UNPROT_MGMT_FRAME_IND, |
| #endif |
| |
| eCSR_ROAM_IBSS_PEER_INFO_COMPLETE, |
| |
| #ifdef FEATURE_WLAN_ESE |
| eCSR_ROAM_TSM_IE_IND, |
| eCSR_ROAM_CCKM_PREAUTH_NOTIFY, |
| eCSR_ROAM_ESE_ADJ_AP_REPORT_IND, |
| eCSR_ROAM_ESE_BCN_REPORT_IND, |
| #endif /* FEATURE_WLAN_ESE */ |
| |
| /* Radar indication from lower layers */ |
| eCSR_ROAM_DFS_RADAR_IND, |
| eCSR_ROAM_SET_CHANNEL_RSP, |
| |
| /* Channel sw update notification */ |
| eCSR_ROAM_DFS_CHAN_SW_NOTIFY, |
| eCSR_ROAM_EXT_CHG_CHNL_IND, |
| eCSR_ROAM_STA_CHANNEL_SWITCH, |
| eCSR_ROAM_NDP_STATUS_UPDATE, |
| eCSR_ROAM_UPDATE_SCAN_RESULT, |
| eCSR_ROAM_START, |
| eCSR_ROAM_ABORT, |
| eCSR_ROAM_NAPI_OFF, |
| eCSR_ROAM_CHANNEL_COMPLETE_IND, |
| } eRoamCmdStatus; |
| |
| /* comment inside indicates what roaming callback gets */ |
| typedef enum { |
| eCSR_ROAM_RESULT_NONE, |
| /* |
| * If roamStatus is eCSR_ROAM_ASSOCIATION_COMPLETION, |
| * tCsrRoamInfo's pBssDesc may pass back |
| */ |
| eCSR_ROAM_RESULT_FAILURE, |
| /* Pass back pointer to tCsrRoamInfo */ |
| eCSR_ROAM_RESULT_ASSOCIATED, |
| eCSR_ROAM_RESULT_NOT_ASSOCIATED, |
| eCSR_ROAM_RESULT_MIC_FAILURE, |
| eCSR_ROAM_RESULT_FORCED, |
| eCSR_ROAM_RESULT_DISASSOC_IND, |
| eCSR_ROAM_RESULT_DEAUTH_IND, |
| eCSR_ROAM_RESULT_CAP_CHANGED, |
| /* |
| * This means we starts an IBSS tCsrRoamInfo's |
| * pBssDesc may pass back |
| */ |
| eCSR_ROAM_RESULT_IBSS_STARTED, |
| eCSR_ROAM_RESULT_IBSS_START_FAILED, |
| eCSR_ROAM_RESULT_IBSS_JOIN_SUCCESS, |
| eCSR_ROAM_RESULT_IBSS_JOIN_FAILED, |
| eCSR_ROAM_RESULT_IBSS_CONNECT, |
| eCSR_ROAM_RESULT_IBSS_INACTIVE, |
| /* |
| * If roamStatus is eCSR_ROAM_ASSOCIATION_COMPLETION |
| * tCsrRoamInfo's pBssDesc may pass back and the peer's MAC address |
| * in peerMacOrBssid. If roamStatus is eCSR_ROAM_IBSS_IND, |
| * the peer's MAC address in peerMacOrBssid and a beacon frame |
| * of the IBSS in pbFrames |
| */ |
| eCSR_ROAM_RESULT_IBSS_NEW_PEER, |
| /* |
| * Peer departed from IBSS, Callback may get a pointer tSmeIbssPeerInd |
| * in pIbssPeerInd |
| */ |
| eCSR_ROAM_RESULT_IBSS_PEER_DEPARTED, |
| /* |
| * Coalescing in the IBSS network (joined an IBSS network) |
| * Callback pass a BSSID in peerMacOrBssid |
| */ |
| eCSR_ROAM_RESULT_IBSS_COALESCED, |
| /* |
| * If roamStatus is eCSR_ROAM_ROAMING_START, callback may get a pointer |
| * to tCsrConnectedProfile used to connect. |
| */ |
| eCSR_ROAM_RESULT_IBSS_STOP, |
| eCSR_ROAM_RESULT_LOSTLINK, |
| eCSR_ROAM_RESULT_MIC_ERROR_UNICAST, |
| eCSR_ROAM_RESULT_MIC_ERROR_GROUP, |
| eCSR_ROAM_RESULT_AUTHENTICATED, |
| eCSR_ROAM_RESULT_NEW_RSN_BSS, |
| #ifdef FEATURE_WLAN_WAPI |
| eCSR_ROAM_RESULT_NEW_WAPI_BSS, |
| #endif /* FEATURE_WLAN_WAPI */ |
| /* INFRA started successfully */ |
| eCSR_ROAM_RESULT_INFRA_STARTED, |
| /* INFRA start failed */ |
| eCSR_ROAM_RESULT_INFRA_START_FAILED, |
| /* INFRA stopped */ |
| eCSR_ROAM_RESULT_INFRA_STOPPED, |
| /* A station joining INFRA AP */ |
| eCSR_ROAM_RESULT_INFRA_ASSOCIATION_IND, |
| /* A station joined INFRA AP */ |
| eCSR_ROAM_RESULT_INFRA_ASSOCIATION_CNF, |
| /* INFRA disassociated */ |
| eCSR_ROAM_RESULT_INFRA_DISASSOCIATED, |
| eCSR_ROAM_RESULT_WPS_PBC_PROBE_REQ_IND, |
| eCSR_ROAM_RESULT_SEND_ACTION_FAIL, |
| /* peer rejected assoc because max assoc limit reached */ |
| eCSR_ROAM_RESULT_MAX_ASSOC_EXCEEDED, |
| /* Assoc rejected due to concurrent session running on a diff channel */ |
| eCSR_ROAM_RESULT_ASSOC_FAIL_CON_CHANNEL, |
| /* TDLS events */ |
| eCSR_ROAM_RESULT_ADD_TDLS_PEER, |
| eCSR_ROAM_RESULT_UPDATE_TDLS_PEER, |
| eCSR_ROAM_RESULT_DELETE_TDLS_PEER, |
| eCSR_ROAM_RESULT_TEARDOWN_TDLS_PEER_IND, |
| eCSR_ROAM_RESULT_DELETE_ALL_TDLS_PEER_IND, |
| eCSR_ROAM_RESULT_LINK_ESTABLISH_REQ_RSP, |
| eCSR_ROAM_RESULT_TDLS_SHOULD_DISCOVER, |
| eCSR_ROAM_RESULT_TDLS_SHOULD_TEARDOWN, |
| eCSR_ROAM_RESULT_TDLS_SHOULD_PEER_DISCONNECTED, |
| eCSR_ROAM_RESULT_TDLS_CONNECTION_TRACKER_NOTIFICATION, |
| |
| eCSR_ROAM_RESULT_IBSS_PEER_INFO_SUCCESS, |
| eCSR_ROAM_RESULT_IBSS_PEER_INFO_FAILED, |
| eCSR_ROAM_RESULT_DFS_RADAR_FOUND_IND, |
| eCSR_ROAM_RESULT_CHANNEL_CHANGE_SUCCESS, |
| eCSR_ROAM_RESULT_CHANNEL_CHANGE_FAILURE, |
| eCSR_ROAM_RESULT_DFS_CHANSW_UPDATE_SUCCESS, |
| eCSR_ROAM_EXT_CHG_CHNL_UPDATE_IND, |
| |
| eCSR_ROAM_RESULT_NDI_CREATE_RSP, |
| eCSR_ROAM_RESULT_NDI_DELETE_RSP, |
| eCSR_ROAM_RESULT_NDP_INITIATOR_RSP, |
| eCSR_ROAM_RESULT_NDP_NEW_PEER_IND, |
| eCSR_ROAM_RESULT_NDP_CONFIRM_IND, |
| eCSR_ROAM_RESULT_NDP_INDICATION, |
| eCSR_ROAM_RESULT_NDP_SCHED_UPDATE_RSP, |
| eCSR_ROAM_RESULT_NDP_RESPONDER_RSP, |
| eCSR_ROAM_RESULT_NDP_END_RSP, |
| eCSR_ROAM_RESULT_NDP_PEER_DEPARTED_IND, |
| eCSR_ROAM_RESULT_NDP_END_IND, |
| /* If Scan for SSID failed to found proper BSS */ |
| eCSR_ROAM_RESULT_SCAN_FOR_SSID_FAILURE, |
| } eCsrRoamResult; |
| |
| /*---------------------------------------------------------------------------- |
| List of link quality indications HDD can receive from SME |
| --------------------------------------------------------------------------*/ |
| typedef enum { |
| eCSR_ROAM_LINK_QUAL_MIN_IND = -1, |
| |
| eCSR_ROAM_LINK_QUAL_POOR_IND = 0, /* bad link */ |
| eCSR_ROAM_LINK_QUAL_GOOD_IND = 1, /* acceptable for voice */ |
| eCSR_ROAM_LINK_QUAL_VERY_GOOD_IND = 2, /* suitable for voice */ |
| eCSR_ROAM_LINK_QUAL_EXCELLENT_IND = 3, /* suitable for voice */ |
| |
| eCSR_ROAM_LINK_QUAL_MAX_IND /* invalid value */ |
| } eCsrRoamLinkQualityInd; |
| |
| typedef enum { |
| eCSR_DISCONNECT_REASON_UNSPECIFIED = 0, |
| eCSR_DISCONNECT_REASON_MIC_ERROR, |
| eCSR_DISCONNECT_REASON_DISASSOC, |
| eCSR_DISCONNECT_REASON_DEAUTH, |
| eCSR_DISCONNECT_REASON_HANDOFF, |
| eCSR_DISCONNECT_REASON_IBSS_JOIN_FAILURE, |
| eCSR_DISCONNECT_REASON_IBSS_LEAVE, |
| eCSR_DISCONNECT_REASON_STA_HAS_LEFT, |
| eCSR_DISCONNECT_REASON_NDI_DELETE, |
| eCSR_DISCONNECT_REASON_ROAM_HO_FAIL, |
| } eCsrRoamDisconnectReason; |
| |
| typedef enum { |
| /* Not associated in Infra or participating in an IBSS/Ad-hoc */ |
| eCSR_ASSOC_STATE_TYPE_NOT_CONNECTED, |
| /* Associated in an Infrastructure network. */ |
| eCSR_ASSOC_STATE_TYPE_INFRA_ASSOCIATED, |
| /* Participating in IBSS network though disconnection */ |
| eCSR_ASSOC_STATE_TYPE_IBSS_DISCONNECTED, |
| /* Participating in IBSS network with partner stations also present */ |
| eCSR_ASSOC_STATE_TYPE_IBSS_CONNECTED, |
| /* Participating in WDS network in AP/STA mode but not connected yet */ |
| eCSR_ASSOC_STATE_TYPE_WDS_DISCONNECTED, |
| /* Participating in a WDS network and connected peer to peer */ |
| eCSR_ASSOC_STATE_TYPE_WDS_CONNECTED, |
| /* Participating in a Infra network in AP not yet in connected state */ |
| eCSR_ASSOC_STATE_TYPE_INFRA_DISCONNECTED, |
| /* Participating in a Infra network and connected to a peer */ |
| eCSR_ASSOC_STATE_TYPE_INFRA_CONNECTED, |
| /* Disconnecting with AP or stop connecting process */ |
| eCSR_ASSOC_STATE_TYPE_INFRA_DISCONNECTING, |
| /* NAN Data interface not started */ |
| eCSR_CONNECT_STATE_TYPE_NDI_NOT_STARTED, |
| /* NAN Data inteface started */ |
| eCSR_CONNECT_STATE_TYPE_NDI_STARTED, |
| |
| } eCsrConnectState; |
| |
| /* |
| * This parameter is no longer supported in the Profile. |
| * Need to set this in the global properties for the adapter. |
| */ |
| typedef enum eCSR_MEDIUM_ACCESS { |
| eCSR_MEDIUM_ACCESS_AUTO = 0, |
| eCSR_MEDIUM_ACCESS_DCF, |
| eCSR_MEDIUM_ACCESS_eDCF, |
| eCSR_MEDIUM_ACCESS_HCF, |
| |
| eCSR_MEDIUM_ACCESS_WMM_eDCF_802dot1p, |
| eCSR_MEDIUM_ACCESS_WMM_eDCF_DSCP, |
| eCSR_MEDIUM_ACCESS_WMM_eDCF_NoClassify, |
| eCSR_MEDIUM_ACCESS_11e_eDCF = eCSR_MEDIUM_ACCESS_eDCF, |
| eCSR_MEDIUM_ACCESS_11e_HCF = eCSR_MEDIUM_ACCESS_HCF, |
| } eCsrMediaAccessType; |
| |
| typedef enum { |
| eCSR_TX_RATE_AUTO = 0, /* use rate adaption to determine Tx rate. */ |
| eCSR_TX_RATE_1Mbps = 0x00000001, |
| eCSR_TX_RATE_2Mbps = 0x00000002, |
| eCSR_TX_RATE_5_5Mbps = 0x00000004, |
| eCSR_TX_RATE_6Mbps = 0x00000008, |
| eCSR_TX_RATE_9Mbps = 0x00000010, |
| eCSR_TX_RATE_11Mbps = 0x00000020, |
| eCSR_TX_RATE_12Mbps = 0x00000040, |
| eCSR_TX_RATE_18Mbps = 0x00000080, |
| eCSR_TX_RATE_24Mbps = 0x00000100, |
| eCSR_TX_RATE_36Mbps = 0x00000200, |
| eCSR_TX_RATE_42Mbps = 0x00000400, |
| eCSR_TX_RATE_48Mbps = 0x00000800, |
| eCSR_TX_RATE_54Mbps = 0x00001000, |
| eCSR_TX_RATE_72Mbps = 0x00002000, |
| eCSR_TX_RATE_84Mbps = 0x00004000, |
| eCSR_TX_RATE_96Mbps = 0x00008000, |
| eCSR_TX_RATE_108Mbps = 0x00010000, |
| eCSR_TX_RATE_126Mbps = 0x00020000, |
| eCSR_TX_RATE_144Mbps = 0x00040000, |
| eCSR_TX_RATE_168Mbps = 0x00080000, |
| eCSR_TX_RATE_192Mbps = 0x00100000, |
| eCSR_TX_RATE_216Mbps = 0x00200000, |
| eCSR_TX_RATE_240Mbps = 0x00400000, |
| |
| } eCsrExposedTxRate; |
| |
| typedef enum { |
| eCSR_OPERATING_CHANNEL_ALL = 0, |
| eCSR_OPERATING_CHANNEL_AUTO = eCSR_OPERATING_CHANNEL_ALL, |
| eCSR_OPERATING_CHANNEL_ANY = eCSR_OPERATING_CHANNEL_ALL, |
| } eOperationChannel; |
| |
| typedef enum { |
| eCSR_DOT11_FRAG_THRESH_AUTO = -1, |
| eCSR_DOT11_FRAG_THRESH_MIN = 256, |
| eCSR_DOT11_FRAG_THRESH_MAX = 2346, |
| eCSR_DOT11_FRAG_THRESH_DEFAULT = 2000 |
| } eCsrDot11FragThresh; |
| |
| /* for channel bonding for ibss */ |
| typedef enum { |
| eCSR_CB_OFF = 0, |
| eCSR_CB_AUTO = 1, |
| eCSR_CB_DOWN = 2, |
| eCSR_CB_UP = 3, |
| } eCsrCBChoice; |
| |
| /* |
| * For channel bonding, the channel number gap is 4, either up or down. |
| * For both 11a and 11g mode. |
| */ |
| #define CSR_CB_CHANNEL_GAP 4 |
| #define CSR_CB_CENTER_CHANNEL_OFFSET 2 |
| |
| /* WEP keysize (in bits) */ |
| typedef enum { |
| /* 40 bit key + 24bit IV = 64bit WEP */ |
| eCSR_SECURITY_WEP_KEYSIZE_40 = 40, |
| /* 104bit key + 24bit IV = 128bit WEP */ |
| eCSR_SECURITY_WEP_KEYSIZE_104 = 104, |
| eCSR_SECURITY_WEP_KEYSIZE_MIN = eCSR_SECURITY_WEP_KEYSIZE_40, |
| eCSR_SECURITY_WEP_KEYSIZE_MAX = eCSR_SECURITY_WEP_KEYSIZE_104, |
| eCSR_SECURITY_WEP_KEYSIZE_MAX_BYTES = |
| (eCSR_SECURITY_WEP_KEYSIZE_MAX / 8), |
| } eCsrWEPKeySize; |
| |
| /* Possible values for the WEP static key ID */ |
| typedef enum { |
| |
| eCSR_SECURITY_WEP_STATIC_KEY_ID_MIN = 0, |
| eCSR_SECURITY_WEP_STATIC_KEY_ID_MAX = 3, |
| eCSR_SECURITY_WEP_STATIC_KEY_ID_DEFAULT = 0, |
| |
| eCSR_SECURITY_WEP_STATIC_KEY_ID_INVALID = -1, |
| |
| } eCsrWEPStaticKeyID; |
| |
| /* Two extra key indicies are used for the IGTK (which is used by BIP) */ |
| #define CSR_MAX_NUM_KEY (eCSR_SECURITY_WEP_STATIC_KEY_ID_MAX + 2 + 1) |
| |
| typedef enum { |
| eCSR_SECURITY_SET_KEY_ACTION_NO_CHANGE, |
| eCSR_SECURITY_SET_KEY_ACTION_SET_KEY, |
| eCSR_SECURITY_SET_KEY_ACTION_DELETE_KEY, |
| } eCsrSetKeyAction; |
| |
| typedef enum { |
| eCSR_BAND_ALL, |
| eCSR_BAND_24, |
| eCSR_BAND_5G, |
| eCSR_BAND_MAX, |
| } eCsrBand; |
| |
| typedef enum { |
| /* |
| * Roaming because HDD requested for reassoc by changing one of the |
| * fields in tCsrRoamModifyProfileFields. OR Roaming because SME |
| * requested for reassoc by changing one of the fields in |
| * tCsrRoamModifyProfileFields. |
| */ |
| eCsrRoamReasonStaCapabilityChanged, |
| /* |
| * Roaming because SME requested for reassoc to a different AP, |
| * as part of inter AP handoff. |
| */ |
| eCsrRoamReasonBetterAP, |
| /* |
| * Roaming because SME requested it as the link is lost - placeholder, |
| * will clean it up once handoff code gets in |
| */ |
| eCsrRoamReasonSmeIssuedForLostLink, |
| |
| } eCsrRoamReasonCodes; |
| |
| typedef enum { |
| eCsrRoamWmmAuto = 0, |
| eCsrRoamWmmQbssOnly = 1, |
| eCsrRoamWmmNoQos = 2, |
| |
| } eCsrRoamWmmUserModeType; |
| |
| typedef enum { |
| eCSR_REQUESTER_MIN = 0, |
| eCSR_DIAG, |
| eCSR_UMA_GAN, |
| eCSR_HDD |
| } eCsrStatsRequesterType; |
| |
| /** |
| * enum csr_hi_rssi_scan_id - Parameter ids for hi rssi scan feature |
| * |
| * @eCSR_HI_RSSI_SCAN_MAXCOUNT_ID: how many times scan can be performed |
| * @eCSR_HI_RSSI_SCAN_RSSI_DELTA_ID: rssi difference to trigger scan |
| * @eCSR_HI_RSSI_SCAN_DELAY_ID: delay in millseconds between scans |
| * @eCSR_HI_RSSI_SCAN_RSSI_UB_ID: rssi upper bound for scan trigger |
| */ |
| enum csr_hi_rssi_scan_id { |
| eCSR_HI_RSSI_SCAN_MAXCOUNT_ID, |
| eCSR_HI_RSSI_SCAN_RSSI_DELTA_ID, |
| eCSR_HI_RSSI_SCAN_DELAY_ID, |
| eCSR_HI_RSSI_SCAN_RSSI_UB_ID |
| }; |
| |
| typedef struct tagPmkidCandidateInfo { |
| struct qdf_mac_addr BSSID; |
| bool preAuthSupported; |
| } tPmkidCandidateInfo; |
| |
| typedef struct tagPmkidCacheInfo { |
| struct qdf_mac_addr BSSID; |
| uint8_t PMKID[CSR_RSN_PMKID_SIZE]; |
| } tPmkidCacheInfo; |
| |
| #ifdef FEATURE_WLAN_WAPI |
| typedef struct tagBkidCandidateInfo { |
| struct qdf_mac_addr BSSID; |
| bool preAuthSupported; |
| } tBkidCandidateInfo; |
| |
| typedef struct tagBkidCacheInfo { |
| struct qdf_mac_addr BSSID; |
| uint8_t BKID[CSR_WAPI_BKID_SIZE]; |
| } tBkidCacheInfo; |
| #endif /* FEATURE_WLAN_WAPI */ |
| |
| typedef struct tagCsrKeys { |
| /* Also use to indicate whether the key index is set */ |
| uint8_t KeyLength[CSR_MAX_NUM_KEY]; |
| uint8_t KeyMaterial[CSR_MAX_NUM_KEY][CSR_MAX_KEY_LEN]; |
| uint8_t defaultIndex; |
| } tCsrKeys; |
| |
| /* |
| * Following fields which're part of tCsrRoamConnectedProfile might need |
| * modification dynamically once STA is up & running & this'd trigger reassoc |
| */ |
| typedef struct tagCsrRoamModifyProfileFields { |
| /* |
| * during connect this specifies ACs U-APSD is to be setup |
| * for (Bit0:VO; Bit1:VI; Bit2:BK; Bit3:BE all other bits are ignored). |
| * During assoc response this COULD carry confirmation of what |
| * ACs U-APSD got setup for. Later if an APP looking for APSD, |
| * SME-QoS might need to modify this field |
| */ |
| uint8_t uapsd_mask; |
| /* HDD might ask to modify this field */ |
| uint16_t listen_interval; |
| } tCsrRoamModifyProfileFields; |
| |
| typedef struct tagCsrRoamProfile { |
| tCsrSSIDs SSIDs; |
| tCsrBSSIDs BSSIDs; |
| /* this is bit mask of all the needed phy mode defined in eCsrPhyMode */ |
| uint32_t phyMode; |
| eCsrRoamBssType BSSType; |
| tCsrAuthList AuthType; |
| eCsrAuthType negotiatedAuthType; |
| tCsrEncryptionList EncryptionType; |
| /* This field is for output only, not for input */ |
| eCsrEncryptionType negotiatedUCEncryptionType; |
| /* |
| * eCSR_ENCRYPT_TYPE_ANY cannot be set in multicast encryption type. |
| * If caller doesn't case, put all supported encryption types in here |
| */ |
| tCsrEncryptionList mcEncryptionType; |
| /* This field is for output only, not for input */ |
| eCsrEncryptionType negotiatedMCEncryptionType; |
| #ifdef WLAN_FEATURE_11W |
| /* Management Frame Protection */ |
| bool MFPEnabled; |
| uint8_t MFPRequired; |
| uint8_t MFPCapable; |
| #endif |
| tCsrKeys Keys; |
| eCsrCBChoice CBMode; |
| tCsrChannelInfo ChannelInfo; |
| uint8_t operationChannel; |
| struct ch_params_s ch_params; |
| /* If this is 0, SME will fill in for caller. */ |
| uint16_t beaconInterval; |
| /* |
| * during connect this specifies ACs U-APSD is to be setup |
| * for (Bit0:VO; Bit1:VI; Bit2:BK; Bit3:BE all other bits are ignored). |
| * During assoc resp this'd carry cnf of what ACs U-APSD got setup for |
| */ |
| uint8_t uapsd_mask; |
| uint32_t nWPAReqIELength; /* The byte count in the pWPAReqIE */ |
| uint8_t *pWPAReqIE; /* If not null,it's IE byte stream for WPA */ |
| uint32_t nRSNReqIELength; /* The byte count in the pRSNReqIE */ |
| uint8_t *pRSNReqIE; /* If not null,it's IE byte stream for RSN */ |
| #ifdef FEATURE_WLAN_WAPI |
| uint32_t nWAPIReqIELength;/* The byte count in the pWAPIReqIE */ |
| uint8_t *pWAPIReqIE; /* If not null,it's IE byte stream for WAPI */ |
| #endif /* FEATURE_WLAN_WAPI */ |
| |
| uint32_t nAddIEScanLength;/* pAddIE for scan (at the time of join) */ |
| /* |
| * If not null,it's the IE byte stream for additional IE, |
| * which can be WSC IE and/or P2P IE |
| */ |
| uint8_t *pAddIEScan; |
| uint32_t nAddIEAssocLength; /* The byte count in the pAddIE for assoc */ |
| /* |
| * If not null, it has the IE byte stream for additional IE, |
| * which can be WSC IE and/or P2P IE |
| */ |
| uint8_t *pAddIEAssoc; |
| /* it is ignored if [0] is 0. */ |
| uint8_t countryCode[WNI_CFG_COUNTRY_CODE_LEN]; |
| /* WPS Association if true => auth and ecryption should be ignored */ |
| bool bWPSAssociation; |
| bool bOSENAssociation; |
| uint32_t nWSCReqIELength; /* The byte count in the pWSCReqIE */ |
| uint8_t *pWSCReqIE; /* If not null,it's IE byte stream for WSC */ |
| uint8_t ieee80211d; |
| uint8_t privacy; |
| bool fwdWPSPBCProbeReq; |
| tAniAuthType csr80211AuthType; |
| uint32_t dtimPeriod; |
| bool ApUapsdEnable; |
| bool protEnabled; |
| bool obssProtEnabled; |
| uint16_t cfg_protection; |
| uint8_t wps_state; |
| tCsrMobilityDomainInfo MDID; |
| enum tQDF_ADAPTER_MODE csrPersona; |
| uint8_t disableDFSChSwitch; |
| /* addIe params */ |
| tSirAddIeParams addIeParams; |
| uint8_t sap_dot11mc; |
| uint8_t beacon_tx_rate; |
| tSirMacRateSet supported_rates; |
| tSirMacRateSet extended_rates; |
| struct qdf_mac_addr bssid_hint; |
| bool do_not_roam; |
| |
| } tCsrRoamProfile; |
| |
| #ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH |
| typedef struct tagCsrRoamHTProfile { |
| uint8_t phymode; |
| uint8_t htCapability; |
| uint8_t htSupportedChannelWidthSet; |
| uint8_t htRecommendedTxWidthSet; |
| ePhyChanBondState htSecondaryChannelOffset; |
| uint8_t vhtCapability; |
| uint8_t apCenterChan; |
| uint8_t apChanWidth; |
| } tCsrRoamHTProfile; |
| #endif |
| typedef struct tagCsrRoamConnectedProfile { |
| tSirMacSSid SSID; |
| bool handoffPermitted; |
| bool ssidHidden; |
| struct qdf_mac_addr bssid; |
| eCsrRoamBssType BSSType; |
| eCsrAuthType AuthType; |
| tCsrAuthList AuthInfo; |
| eCsrEncryptionType EncryptionType; |
| tCsrEncryptionList EncryptionInfo; |
| eCsrEncryptionType mcEncryptionType; |
| tCsrEncryptionList mcEncryptionInfo; |
| eCsrCBChoice CBMode; |
| uint8_t operationChannel; |
| uint32_t vht_channel_width; |
| uint16_t beaconInterval; |
| tCsrKeys Keys; |
| /* |
| * meaningless on connect. It's an OUT param from CSR's point of view |
| * During assoc response carries the ACM bit-mask i.e. what |
| * ACs have ACM=1 (if any),(Bit0:VO; Bit1:VI; Bit2:BK; Bit3:BE |
| * all other bits are ignored) |
| */ |
| uint8_t acm_mask; |
| tCsrRoamModifyProfileFields modifyProfileFields; |
| uint32_t nAddIEAssocLength; |
| /* |
| * If not null,it's IE byte stream for additional IE, |
| * which can be WSC IE and/or P2P IE |
| */ |
| uint8_t *pAddIEAssoc; |
| tSirBssDescription *pBssDesc; |
| bool qap; /* AP supports QoS */ |
| bool qosConnection; /* A connection is QoS enabled */ |
| tCsrMobilityDomainInfo MDID; |
| #ifdef FEATURE_WLAN_ESE |
| tCsrEseCckmInfo eseCckmInfo; |
| bool isESEAssoc; |
| #endif |
| uint32_t dot11Mode; |
| uint8_t proxyARPService; |
| #ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH |
| tCsrRoamHTProfile HTProfile; |
| #endif |
| #ifdef WLAN_FEATURE_11W |
| /* Management Frame Protection */ |
| bool MFPEnabled; |
| uint8_t MFPRequired; |
| uint8_t MFPCapable; |
| #endif |
| } tCsrRoamConnectedProfile; |
| |
| typedef struct tagCsr11rConfigParams { |
| bool IsFTResourceReqSupported; |
| } tCsr11rConfigParams; |
| |
| typedef struct tagCsrNeighborRoamConfigParams { |
| |
| uint32_t nNeighborScanTimerPeriod; |
| uint8_t nNeighborLookupRssiThreshold; |
| uint16_t nNeighborScanMinChanTime; |
| uint16_t nNeighborScanMaxChanTime; |
| sCsrChannel neighborScanChanList; |
| uint8_t nMaxNeighborRetries; |
| uint16_t nNeighborResultsRefreshPeriod; |
| uint16_t nEmptyScanRefreshPeriod; |
| uint8_t nOpportunisticThresholdDiff; |
| uint8_t nRoamRescanRssiDiff; |
| uint8_t nRoamBmissFirstBcnt; |
| uint8_t nRoamBmissFinalBcnt; |
| uint8_t nRoamBeaconRssiWeight; |
| uint8_t delay_before_vdev_stop; |
| uint32_t nhi_rssi_scan_max_count; |
| uint32_t nhi_rssi_scan_rssi_delta; |
| uint32_t nhi_rssi_scan_delay; |
| int32_t nhi_rssi_scan_rssi_ub; |
| } tCsrNeighborRoamConfigParams; |
| |
| /** |
| * enum sta_roam_policy_dfs_mode - state of DFS mode for STA ROME policy |
| * @CSR_STA_ROAM_POLICY_NONE: DFS mode attribute is not valid |
| * @CSR_STA_ROAM_POLICY_DFS_ENABLED: DFS mode is enabled |
| * @CSR_STA_ROAM_POLICY_DFS_DISABLED: DFS mode is disabled |
| * @CSR_STA_ROAM_POLICY_DFS_DEPRIORITIZE: Deprioritize DFS channels in scanning |
| */ |
| enum sta_roam_policy_dfs_mode { |
| CSR_STA_ROAM_POLICY_NONE, |
| CSR_STA_ROAM_POLICY_DFS_ENABLED, |
| CSR_STA_ROAM_POLICY_DFS_DISABLED, |
| CSR_STA_ROAM_POLICY_DFS_DEPRIORITIZE |
| }; |
| |
| /** |
| * struct csr_sta_roam_policy_params - sta roam policy params for station |
| * @dfs_mode: tell is DFS channels needs to be skipped while scanning |
| * @skip_unsafe_channels: tells if unsafe channels needs to be skip in scanning |
| * @sap_operating_band: Opearting band for SAP |
| */ |
| struct csr_sta_roam_policy_params { |
| enum sta_roam_policy_dfs_mode dfs_mode; |
| bool skip_unsafe_channels; |
| uint8_t sap_operating_band; |
| }; |
| |
| typedef struct tagCsrConfigParam { |
| uint32_t FragmentationThreshold; |
| /* keep this uint32_t. This gets converted to ePhyChannelBondState */ |
| uint32_t channelBondingMode24GHz; |
| uint32_t channelBondingMode5GHz; |
| eCsrPhyMode phyMode; |
| eCsrBand eBand; |
| uint32_t RTSThreshold; |
| uint32_t HeartbeatThresh50; |
| uint32_t HeartbeatThresh24; |
| eCsrCBChoice cbChoice; |
| eCsrBand bandCapability; /* indicate hw capability */ |
| uint16_t TxRate; |
| eCsrRoamWmmUserModeType WMMSupportMode; |
| bool Is11eSupportEnabled; |
| bool Is11dSupportEnabled; |
| bool Is11dSupportEnabledOriginal; |
| bool Is11hSupportEnabled; |
| bool shortSlotTime; |
| bool ProprietaryRatesEnabled; |
| uint8_t AdHocChannel24; |
| uint8_t AdHocChannel5G; |
| /* |
| * this number minus one is the number of times a scan doesn't find it |
| * before it is removed |
| */ |
| uint32_t nScanResultAgeCount; |
| /* to set the RSSI difference for each category */ |
| uint8_t bCatRssiOffset; |
| /* to set MCC Enable/Disable mode */ |
| uint8_t fEnableMCCMode; |
| bool mcc_rts_cts_prot_enable; |
| bool mcc_bcast_prob_resp_enable; |
| /* |
| * To allow MCC GO different B.I than STA's. |
| * NOTE: make sure if RIVA firmware can handle this combination before |
| * enabling this at the moment, this flag is provided only to pass |
| * Wi-Fi Cert. 5.1.12 |
| */ |
| uint8_t fAllowMCCGODiffBI; |
| tCsr11dinfo Csr11dinfo; |
| |
| /* Country Code Priority */ |
| bool fSupplicantCountryCodeHasPriority; |
| uint16_t vccRssiThreshold; |
| uint32_t vccUlMacLossThreshold; |
| uint32_t nPassiveMinChnTime; /* in units of milliseconds */ |
| uint32_t nPassiveMaxChnTime; /* in units of milliseconds */ |
| uint32_t nActiveMinChnTime; /* in units of milliseconds */ |
| uint32_t nActiveMaxChnTime; /* in units of milliseconds */ |
| uint32_t nInitialDwellTime; /* in units of milliseconds */ |
| bool initial_scan_no_dfs_chnl; |
| #ifdef WLAN_AP_STA_CONCURRENCY |
| uint32_t nPassiveMinChnTimeConc; /* in units of milliseconds */ |
| uint32_t nPassiveMaxChnTimeConc; /* in units of milliseconds */ |
| uint32_t nActiveMinChnTimeConc; /* in units of milliseconds */ |
| uint32_t nActiveMaxChnTimeConc; /* in units of milliseconds */ |
| uint32_t nRestTimeConc; /* in units of milliseconds */ |
| /* num of channels combined for STA in each split scan operation */ |
| uint8_t nNumStaChanCombinedConc; |
| /* number of channels combined for P2P in each split scan operation */ |
| uint8_t nNumP2PChanCombinedConc; |
| #endif |
| /*In units of milliseconds*/ |
| uint32_t min_rest_time_conc; |
| /*In units of milliseconds*/ |
| uint32_t idle_time_conc; |
| |
| /* |
| * in dBm, the maximum TX power The actual TX power is the lesser of |
| * this value and 11d. If 11d is disable, the lesser of this and |
| * default setting. |
| */ |
| uint8_t nTxPowerCap; |
| bool allow_tpc_from_ap; |
| /* stats request frequency from PE while in full power */ |
| uint32_t statsReqPeriodicity; |
| /* stats request frequency from PE while in power save */ |
| uint32_t statsReqPeriodicityInPS; |
| tCsr11rConfigParams csr11rConfig; |
| #ifdef FEATURE_WLAN_ESE |
| uint8_t isEseIniFeatureEnabled; |
| #endif |
| uint8_t isFastRoamIniFeatureEnabled; |
| uint8_t MAWCEnabled; |
| uint8_t isFastTransitionEnabled; |
| uint8_t RoamRssiDiff; |
| bool isWESModeEnabled; |
| tCsrNeighborRoamConfigParams neighborRoamConfig; |
| /* |
| * Instead of Reassoc, send ADDTS/DELTS even when ACM is off for that AC |
| * This is mandated by WMM-AC certification |
| */ |
| bool addTSWhenACMIsOff; |
| /* |
| * channelPowerInfoList24 has been seen corrupted. Set this flag to true |
| * trying to detect when it happens. Adding this into code because we |
| * can't reproduce it easily. We don't know when it happens. |
| */ |
| bool fValidateList; |
| /* |
| * Customer wants to start with an active scan based on the default |
| * country code. This optimization will minimize the driver load to |
| * association time. Based on this flag we will bypass the initial |
| * passive scan needed for 11d to determine the country code & domain |
| */ |
| bool fEnableBypass11d; |
| /* |
| * Customer wants to optimize the scan time. Avoiding scans(passive) |
| * on DFS channels while swipping through both bands can save some time |
| * (apprx 1.3 sec) |
| */ |
| uint8_t fEnableDFSChnlScan; |
| /* |
| * To enable/disable scanning 2.4Ghz channels twice on a single scan |
| * request from HDD |
| */ |
| bool fScanTwice; |
| uint32_t nVhtChannelWidth; |
| uint8_t enableTxBF; |
| uint8_t enable_txbf_sap_mode; |
| uint8_t enable2x2; |
| bool enableVhtFor24GHz; |
| bool vendor_vht_sap; |
| uint8_t enableMuBformee; |
| uint8_t enableVhtpAid; |
| uint8_t enableVhtGid; |
| uint8_t enableAmpduPs; |
| uint8_t enableHtSmps; |
| uint8_t htSmps; |
| bool send_smps_action; |
| bool ignore_peer_erp_info; |
| /* |
| * To enable/disable scanning only 2.4Ghz channels on first scan |
| */ |
| bool fFirstScanOnly2GChnl; |
| bool nRoamPrefer5GHz; |
| bool nRoamIntraBand; |
| uint8_t nProbes; |
| uint16_t nRoamScanHomeAwayTime; |
| |
| bool isRoamOffloadScanEnabled; |
| bool bFastRoamInConIniFeatureEnabled; |
| uint8_t scanCfgAgingTime; |
| uint8_t enableTxLdpc; |
| uint8_t enableRxLDPC; |
| uint8_t isAmsduSupportInAMPDU; |
| uint8_t nSelect5GHzMargin; |
| uint8_t isCoalesingInIBSSAllowed; |
| #ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH |
| uint8_t cc_switch_mode; |
| #endif |
| uint8_t allowDFSChannelRoam; |
| #ifdef WLAN_FEATURE_ROAM_OFFLOAD |
| bool isRoamOffloadEnabled; |
| #endif |
| bool obssEnabled; |
| uint8_t conc_custom_rule1; |
| uint8_t conc_custom_rule2; |
| uint8_t is_sta_connection_in_5gz_enabled; |
| bool sendDeauthBeforeCon; |
| |
| /* 802.11p enable */ |
| bool enable_dot11p; |
| uint8_t max_scan_count; |
| #ifdef FEATURE_WLAN_SCAN_PNO |
| bool pno_channel_prediction; |
| uint8_t top_k_num_of_channels; |
| uint8_t stationary_thresh; |
| enum wmi_dwelltime_adaptive_mode pnoscan_adaptive_dwell_mode; |
| uint32_t channel_prediction_full_scan; |
| #endif |
| bool early_stop_scan_enable; |
| int8_t early_stop_scan_min_threshold; |
| int8_t early_stop_scan_max_threshold; |
| int8_t first_scan_bucket_threshold; |
| bool pnoOffload; |
| uint8_t fEnableDebugLog; |
| uint8_t max_intf_count; |
| bool enable5gEBT; |
| bool enableSelfRecovery; |
| uint32_t f_sta_miracast_mcc_rest_time_val; |
| #ifdef FEATURE_AP_MCC_CH_AVOIDANCE |
| bool sap_channel_avoidance; |
| #endif /* FEATURE_AP_MCC_CH_AVOIDANCE */ |
| uint8_t f_prefer_non_dfs_on_radar; |
| bool is_ps_enabled; |
| uint32_t auto_bmps_timer_val; |
| uint32_t fine_time_meas_cap; |
| uint32_t dual_mac_feature_disable; |
| uint32_t roam_dense_traffic_thresh; |
| uint32_t roam_dense_rssi_thresh_offset; |
| uint32_t roam_dense_min_aps; |
| uint32_t obss_width_interval; |
| uint32_t obss_active_dwelltime; |
| uint32_t obss_passive_dwelltime; |
| bool ignore_peer_ht_opmode; |
| bool enable_edca_params; |
| uint32_t edca_vo_cwmin; |
| uint32_t edca_vi_cwmin; |
| uint32_t edca_bk_cwmin; |
| uint32_t edca_be_cwmin; |
| uint32_t edca_vo_cwmax; |
| uint32_t edca_vi_cwmax; |
| uint32_t edca_bk_cwmax; |
| uint32_t edca_be_cwmax; |
| uint32_t edca_vo_aifs; |
| uint32_t edca_vi_aifs; |
| uint32_t edca_bk_aifs; |
| uint32_t edca_be_aifs; |
| bool enable_fatal_event; |
| enum wmi_dwelltime_adaptive_mode scan_adaptive_dwell_mode; |
| enum wmi_dwelltime_adaptive_mode roamscan_adaptive_dwell_mode; |
| struct csr_sta_roam_policy_params sta_roam_policy_params; |
| uint32_t tx_aggregation_size; |
| uint32_t rx_aggregation_size; |
| struct wmi_per_roam_config per_roam_config; |
| bool enable_bcast_probe_rsp; |
| } tCsrConfigParam; |
| |
| /* Tush */ |
| typedef struct tagCsrUpdateConfigParam { |
| tCsr11dinfo Csr11dinfo; |
| } tCsrUpdateConfigParam; |
| #ifdef WLAN_FEATURE_ROAM_OFFLOAD |
| #define csr_roamIsRoamOffloadEnabled(pMac) \ |
| (pMac->roam.configParam.isRoamOffloadEnabled) |
| #define DEFAULT_REASSOC_FAILURE_TIMEOUT 1000 |
| #endif |
| |
| #ifdef WLAN_FEATURE_ROAM_OFFLOAD |
| /* connected but not authenticated */ |
| #define CSR_ROAM_AUTH_STATUS_CONNECTED 0x1 |
| /* connected and authenticated */ |
| #define CSR_ROAM_AUTH_STATUS_AUTHENTICATED 0x2 |
| #endif |
| |
| typedef struct tagCsrRoamInfo { |
| tCsrRoamProfile *pProfile; |
| tSirBssDescription *pBssDesc; |
| uint32_t nBeaconLength; |
| uint32_t nAssocReqLength; |
| uint32_t nAssocRspLength; |
| uint32_t nFrameLength; |
| uint8_t frameType; |
| /* |
| * Point to a buffer contain the beacon, assoc req, assoc rsp frame, |
| * in that order user needs to use nBeaconLength, nAssocReqLength, |
| * nAssocRspLength to desice where each frame starts and ends. |
| */ |
| uint8_t *pbFrames; |
| bool fReassocReq; /* set to true if for re-association */ |
| bool fReassocRsp; /* set to true if for re-association */ |
| struct qdf_mac_addr bssid; |
| /* |
| * Only valid in IBSS. this is the peers MAC address for |
| * eCSR_ROAM_RESULT_IBSS_NEW_PEER or PEER_DEPARTED |
| */ |
| struct qdf_mac_addr peerMac; |
| tSirResultCodes statusCode; |
| /* this'd be our own defined or sent from otherBSS(per 802.11spec) */ |
| uint32_t reasonCode; |
| uint8_t staId; /* Peer stationId when connected */ |
| /* |
| * The DPU signatures will be sent eventually to TL to help it |
| * determine the assoc to which a packet belongs to unicast DPU sign |
| */ |
| uint8_t ucastSig; |
| uint8_t bcastSig; /* Broadcast DPU signature */ |
| /* false means auth needed from supplicant. true means authenticated */ |
| bool fAuthRequired; |
| uint8_t sessionId; |
| uint8_t rsnIELen; |
| uint8_t *prsnIE; |
| uint8_t wapiIELen; |
| uint8_t *pwapiIE; |
| uint8_t addIELen; |
| uint8_t *paddIE; |
| union { |
| tSirMicFailureInfo *pMICFailureInfo; |
| tCsrRoamConnectedProfile *pConnectedProfile; |
| tSirWPSPBCProbeReq *pWPSPBCProbeReq; |
| } u; |
| bool wmmEnabledSta; /* set to true if WMM enabled STA */ |
| uint32_t dtimPeriod; |
| #ifdef FEATURE_WLAN_ESE |
| bool isESEAssoc; |
| tSirTsmIE tsmIe; |
| uint32_t timestamp[2]; |
| uint16_t tsmRoamDelay; |
| tSirEseBcnReportRsp *pEseBcnReportRsp; |
| #endif |
| void *pRemainCtx; |
| uint32_t roc_scan_id; |
| uint32_t rxChan; |
| #ifdef FEATURE_WLAN_TDLS |
| /* |
| * TDLS parameters to check whether TDLS |
| * and TDLS channel switch is allowed in the |
| * AP network |
| */ |
| uint8_t staType; |
| bool tdls_prohibited; /* per ExtCap in Assoc/Reassoc resp */ |
| bool tdls_chan_swit_prohibited; /* per ExtCap in Assoc/Reassoc resp */ |
| #endif |
| /* Required for indicating the frames to upper layer */ |
| uint32_t beaconLength; |
| uint8_t *beaconPtr; |
| uint32_t assocReqLength; |
| uint8_t *assocReqPtr; |
| int8_t rxRssi; |
| tSirSmeDfsEventInd dfs_event; |
| tSirChanChangeResponse *channelChangeRespEvent; |
| /* Timing and fine Timing measurement capability clubbed together */ |
| uint8_t timingMeasCap; |
| #ifdef WLAN_FEATURE_ROAM_OFFLOAD |
| uint8_t roamSynchInProgress; |
| uint8_t synchAuthStatus; |
| uint8_t kck[SIR_KCK_KEY_LEN]; |
| uint8_t kek[SIR_KEK_KEY_LEN]; |
| uint8_t replay_ctr[SIR_REPLAY_CTR_LEN]; |
| uint8_t subnet_change_status; |
| #endif |
| tSirSmeChanInfo chan_info; |
| uint8_t target_channel; |
| |
| #ifdef WLAN_FEATURE_NAN_DATAPATH |
| union { |
| struct sme_ndp_peer_ind ndp_peer_ind_params; |
| struct ndp_schedule_update_rsp ndp_sched_upd_rsp_params; |
| struct ndp_end_indication_event *ndp_end_ind_params; |
| struct ndp_end_rsp_event *ndp_end_rsp_params; |
| struct ndp_confirm_event ndp_confirm_params; |
| struct ndp_responder_rsp_event ndp_responder_rsp_params; |
| struct ndp_indication_event ndp_indication_params; |
| struct ndp_initiator_rsp ndp_init_rsp_params; |
| struct ndi_create_rsp ndi_create_params; |
| struct ndi_delete_rsp ndi_delete_params; |
| } ndp; |
| #endif |
| tDot11fIEHTCaps ht_caps; |
| tDot11fIEVHTCaps vht_caps; |
| tDot11fIEhs20vendor_ie hs20vendor_ie; |
| tDot11fIEVHTOperation vht_operation; |
| tDot11fIEHTInfo ht_operation; |
| bool reassoc; |
| } tCsrRoamInfo; |
| |
| typedef struct tagCsrFreqScanInfo { |
| uint32_t nStartFreq; /* in unit of MHz */ |
| uint32_t nEndFreq; /* in unit of MHz */ |
| tSirScanType scanType; |
| } tCsrFreqScanInfo; |
| |
| typedef struct sSirSmeAssocIndToUpperLayerCnf { |
| uint16_t messageType; /* eWNI_SME_ASSOC_CNF */ |
| uint16_t length; |
| uint8_t sessionId; |
| tSirResultCodes statusCode; |
| tSirMacAddr bssId; /* Self BSSID */ |
| tSirMacAddr peerMacAddr; |
| uint16_t aid; |
| tSirMacAddr alternateBssId; |
| uint8_t alternateChannelId; |
| uint8_t wmmEnabledSta; /* set to true if WMM enabled STA */ |
| tSirRSNie rsnIE; /* RSN IE received from peer */ |
| tSirWAPIie wapiIE; /* WAPI IE received from peer */ |
| tSirAddie addIE; /* this can be WSC and/or P2P IE */ |
| uint8_t reassocReq; /* set to true if reassoc */ |
| /* Timing and fine Timing measurement capability clubbed together */ |
| uint8_t timingMeasCap; |
| tSirSmeChanInfo chan_info; |
| uint8_t target_channel; |
| } tSirSmeAssocIndToUpperLayerCnf, *tpSirSmeAssocIndToUpperLayerCnf; |
| |
| typedef struct tagCsrSummaryStatsInfo { |
| uint32_t snr; |
| uint32_t rssi; |
| uint32_t retry_cnt[4]; |
| uint32_t multiple_retry_cnt[4]; |
| uint32_t tx_frm_cnt[4]; |
| /* uint32_t num_rx_frm_crc_err; same as rx_error_cnt */ |
| /* uint32_t num_rx_frm_crc_ok; same as rx_frm_cnt */ |
| uint32_t rx_frm_cnt; |
| uint32_t frm_dup_cnt; |
| uint32_t fail_cnt[4]; |
| uint32_t rts_fail_cnt; |
| uint32_t ack_fail_cnt; |
| uint32_t rts_succ_cnt; |
| uint32_t rx_discard_cnt; |
| uint32_t rx_error_cnt; |
| uint32_t tx_byte_cnt; |
| |
| } tCsrSummaryStatsInfo; |
| |
| typedef struct tagCsrGlobalClassAStatsInfo { |
| uint32_t rx_frag_cnt; |
| uint32_t promiscuous_rx_frag_cnt; |
| /* uint32_t rx_fcs_err; */ |
| uint32_t rx_input_sensitivity; |
| uint32_t max_pwr; |
| /* uint32_t default_pwr; */ |
| uint32_t sync_fail_cnt; |
| uint32_t tx_rate; |
| /* mcs index for HT20 and HT40 rates */ |
| uint32_t mcs_index; |
| /* to diff between HT20 & HT40 rates;short & long guard interval */ |
| uint32_t tx_rate_flags; |
| |
| } tCsrGlobalClassAStatsInfo; |
| |
| typedef struct tagCsrGlobalClassBStatsInfo { |
| uint32_t uc_rx_wep_unencrypted_frm_cnt; |
| uint32_t uc_rx_mic_fail_cnt; |
| uint32_t uc_tkip_icv_err; |
| uint32_t uc_aes_ccmp_format_err; |
| uint32_t uc_aes_ccmp_replay_cnt; |
| uint32_t uc_aes_ccmp_decrpt_err; |
| uint32_t uc_wep_undecryptable_cnt; |
| uint32_t uc_wep_icv_err; |
| uint32_t uc_rx_decrypt_succ_cnt; |
| uint32_t uc_rx_decrypt_fail_cnt; |
| uint32_t mcbc_rx_wep_unencrypted_frm_cnt; |
| uint32_t mcbc_rx_mic_fail_cnt; |
| uint32_t mcbc_tkip_icv_err; |
| uint32_t mcbc_aes_ccmp_format_err; |
| uint32_t mcbc_aes_ccmp_replay_cnt; |
| uint32_t mcbc_aes_ccmp_decrpt_err; |
| uint32_t mcbc_wep_undecryptable_cnt; |
| uint32_t mcbc_wep_icv_err; |
| uint32_t mcbc_rx_decrypt_succ_cnt; |
| uint32_t mcbc_rx_decrypt_fail_cnt; |
| |
| } tCsrGlobalClassBStatsInfo; |
| |
| typedef struct tagCsrGlobalClassCStatsInfo { |
| uint32_t rx_amsdu_cnt; |
| uint32_t rx_ampdu_cnt; |
| uint32_t tx_20_frm_cnt; |
| uint32_t rx_20_frm_cnt; |
| uint32_t rx_mpdu_in_ampdu_cnt; |
| uint32_t ampdu_delimiter_crc_err; |
| |
| } tCsrGlobalClassCStatsInfo; |
| |
| typedef struct tagCsrGlobalClassDStatsInfo { |
| uint32_t tx_uc_frm_cnt; |
| uint32_t tx_mc_frm_cnt; |
| uint32_t tx_bc_frm_cnt; |
| uint32_t rx_uc_frm_cnt; |
| uint32_t rx_mc_frm_cnt; |
| uint32_t rx_bc_frm_cnt; |
| uint32_t tx_uc_byte_cnt[4]; |
| uint32_t tx_mc_byte_cnt; |
| uint32_t tx_bc_byte_cnt; |
| uint32_t rx_uc_byte_cnt[4]; |
| uint32_t rx_mc_byte_cnt; |
| uint32_t rx_bc_byte_cnt; |
| uint32_t rx_byte_cnt; |
| uint32_t num_rx_bytes_crc_ok; |
| uint32_t rx_rate; |
| |
| } tCsrGlobalClassDStatsInfo; |
| |
| /** |
| * struct csr_per_chain_rssi_stats_info - stores chain rssi |
| * @rssi: array containing rssi for all chains |
| * @peer_mac_addr: peer mac address |
| */ |
| struct csr_per_chain_rssi_stats_info { |
| int8_t rssi[NUM_CHAINS_MAX]; |
| tSirMacAddr peer_mac_addr; |
| }; |
| |
| typedef struct tagCsrRoamSetKey { |
| eCsrEncryptionType encType; |
| tAniKeyDirection keyDirection; /* Tx, Rx or Tx-and-Rx */ |
| struct qdf_mac_addr peerMac; /* Peer MAC. ALL 1's for group key */ |
| uint8_t paeRole; /* 0 for supplicant */ |
| uint8_t keyId; /* Key index */ |
| uint16_t keyLength; /* Number of bytes containing the key in pKey */ |
| uint8_t Key[CSR_MAX_KEY_LEN]; |
| uint8_t keyRsc[CSR_MAX_RSC_LEN]; |
| } tCsrRoamSetKey; |
| |
| typedef struct tagCsrRoamRemoveKey { |
| eCsrEncryptionType encType; |
| struct qdf_mac_addr peerMac; /* Peer MAC. ALL 1's for group key */ |
| uint8_t keyId; /* key index */ |
| } tCsrRoamRemoveKey; |
| |
| #ifdef FEATURE_WLAN_TDLS |
| |
| typedef struct tagCsrLinkEstablishParams { |
| tSirMacAddr peerMac; |
| uint8_t uapsdQueues; |
| uint8_t maxSp; |
| uint8_t isBufSta; |
| uint8_t isOffChannelSupported; |
| uint8_t isResponder; |
| uint8_t supportedChannelsLen; |
| uint8_t supportedChannels[SIR_MAC_MAX_SUPP_CHANNELS]; |
| uint8_t supportedOperClassesLen; |
| uint8_t supportedOperClasses[CDS_MAX_SUPP_OPER_CLASSES]; |
| uint8_t qos; |
| } tCsrTdlsLinkEstablishParams; |
| |
| typedef struct tagCsrTdlsSendMgmt { |
| tSirMacAddr peerMac; |
| uint8_t frameType; |
| uint8_t dialog; |
| uint16_t statusCode; |
| uint8_t responder; |
| uint32_t peerCapability; |
| uint8_t *buf; |
| uint8_t len; |
| |
| } tCsrTdlsSendMgmt; |
| #endif |
| |
| typedef void *tScanResultHandle; |
| |
| typedef enum { |
| REASSOC = 0, |
| FASTREASSOC = 1, |
| CONNECT_CMD_USERSPACE = 2, |
| } handoff_src; |
| |
| typedef struct tagCsrHandoffRequest { |
| struct qdf_mac_addr bssid; |
| uint8_t channel; |
| uint8_t src; /* To check if its a REASSOC or a FASTREASSOC IOCTL */ |
| } tCsrHandoffRequest; |
| |
| #ifdef FEATURE_WLAN_ESE |
| typedef struct tagCsrEseBeaconReqParams { |
| uint16_t measurementToken; |
| uint8_t channel; |
| uint8_t scanMode; |
| uint16_t measurementDuration; |
| } tCsrEseBeaconReqParams, *tpCsrEseBeaconReqParams; |
| |
| typedef struct tagCsrEseBeaconReq { |
| uint8_t numBcnReqIe; |
| tCsrEseBeaconReqParams bcnReq[SIR_ESE_MAX_MEAS_IE_REQS]; |
| } tCsrEseBeaconReq, *tpCsrEseBeaconReq; |
| #endif /* FEATURE_WLAN_ESE */ |
| |
| struct tagCsrDelStaParams { |
| struct qdf_mac_addr peerMacAddr; |
| uint16_t reason_code; |
| uint8_t subtype; |
| }; |
| |
| /** |
| * struct wep_update_default_key_idx: wep default key index structure |
| * @session_id: session ID for the connection session |
| * @default_idx: default key index for wep |
| * |
| * structure includes sesssion id for connection and default key |
| * index used for wep |
| */ |
| struct wep_update_default_key_idx { |
| uint8_t session_id; |
| uint8_t default_idx; |
| }; |
| |
| /* |
| * NOTE: p2 is the second context pass in for the caller |
| * NOTE: what if callback is called before requester gets the scanId?? |
| */ |
| typedef QDF_STATUS (*csr_scan_completeCallback)(tHalHandle, void *p2, |
| uint8_t sessionId, |
| uint32_t scanID, |
| eCsrScanStatus status); |
| typedef QDF_STATUS (*csr_roam_completeCallback)(void *pContext, |
| tCsrRoamInfo * pParam, |
| uint32_t roamId, |
| eRoamCmdStatus roamStatus, |
| eCsrRoamResult roamResult); |
| typedef QDF_STATUS (*csr_roamSessionCloseCallback)(void *pContext); |
| |
| #define CSR_IS_START_IBSS(pProfile) (eCSR_BSS_TYPE_START_IBSS == \ |
| (pProfile)->BSSType) |
| #define CSR_IS_JOIN_TO_IBSS(pProfile) (eCSR_BSS_TYPE_IBSS == \ |
| (pProfile)->BSSType) |
| #define CSR_IS_IBSS(pProfile) (CSR_IS_START_IBSS(pProfile) || \ |
| CSR_IS_JOIN_TO_IBSS(pProfile)) |
| #define CSR_IS_INFRASTRUCTURE(pProfile) (eCSR_BSS_TYPE_INFRASTRUCTURE == \ |
| (pProfile)->BSSType) |
| #define CSR_IS_ANY_BSS_TYPE(pProfile) (eCSR_BSS_TYPE_ANY == \ |
| (pProfile)->BSSType) |
| #define CSR_IS_INFRA_AP(pProfile) (eCSR_BSS_TYPE_INFRA_AP == \ |
| (pProfile)->BSSType) |
| #ifdef WLAN_FEATURE_NAN_DATAPATH |
| #define CSR_IS_NDI(profile) (eCSR_BSS_TYPE_NDI == (profile)->BSSType) |
| #else |
| #define CSR_IS_NDI(profile) (false) |
| #endif |
| #define CSR_IS_CONN_INFRA_AP(pProfile) (eCSR_BSS_TYPE_INFRA_AP == \ |
| (pProfile)->BSSType) |
| #ifdef WLAN_FEATURE_NAN_DATAPATH |
| #define CSR_IS_CONN_NDI(profile) (eCSR_BSS_TYPE_NDI == (profile)->BSSType) |
| #else |
| #define CSR_IS_CONN_NDI(profile) (false) |
| #endif |
| |
| QDF_STATUS csr_set_channels(tHalHandle hHal, tCsrConfigParam *pParam); |
| |
| QDF_STATUS csr_set_reg_info(tHalHandle hHal, uint8_t *apCntryCode); |
| |
| /* enum to string conversion for debug output */ |
| const char *get_e_roam_cmd_status_str(eRoamCmdStatus val); |
| const char *get_e_csr_roam_result_str(eCsrRoamResult val); |
| QDF_STATUS csr_set_phy_mode(tHalHandle hHal, uint32_t phyMode, eCsrBand eBand, |
| bool *pfRestartNeeded); |
| typedef void (*csr_roamLinkQualityIndCallback) |
| (eCsrRoamLinkQualityInd ind, void *pContext); |
| typedef void (*tCsrStatsCallback)(void *stats, void *pContext); |
| typedef void (*tCsrRssiCallback)(int8_t rssi, uint32_t staId, void *pContext); |
| |
| #ifdef FEATURE_WLAN_ESE |
| typedef void (*tCsrTsmStatsCallback)(tAniTrafStrmMetrics tsmMetrics, |
| uint32_t staId, void *pContext); |
| #endif /* FEATURE_WLAN_ESE */ |
| typedef void (*tCsrSnrCallback)(int8_t snr, uint32_t staId, void *pContext); |
| #ifdef WLAN_FEATURE_HOST_ROAM |
| QDF_STATUS csr_roam_issue_ft_preauth_req(tHalHandle hHal, uint32_t sessionId, |
| tpSirBssDescription pBssDescription); |
| #else |
| static inline QDF_STATUS csr_roam_issue_ft_preauth_req(tHalHandle hHal, |
| uint32_t sessionId, tpSirBssDescription pBssDescription) |
| { |
| return QDF_STATUS_E_NOSUPPORT; |
| } |
| #endif |
| QDF_STATUS csr_set_band(tHalHandle hHal, uint8_t sessionId, eCsrBand eBand); |
| eCsrBand csr_get_current_band(tHalHandle hHal); |
| typedef void (*csr_readyToSuspendCallback)(void *pContext, bool suspended); |
| #ifdef WLAN_FEATURE_EXTWOW_SUPPORT |
| typedef void (*csr_readyToExtWoWCallback)(void *pContext, bool status); |
| #endif |
| #ifdef WLAN_FEATURE_ROAM_OFFLOAD |
| QDF_STATUS csr_roam_issue_ft_roam_offload_synch(tHalHandle hHal, |
| uint32_t sessionId, tSirBssDescription *pBssDescription); |
| #endif |
| typedef void (*tCsrLinkStatusCallback)(uint8_t status, void *pContext); |
| #ifdef FEATURE_WLAN_TDLS |
| void csr_roam_fill_tdls_info(tpAniSirGlobal mac_ctx, tCsrRoamInfo *roam_info, |
| tpSirSmeJoinRsp join_rsp); |
| #else |
| static inline void csr_roam_fill_tdls_info(tpAniSirGlobal mac_ctx, tCsrRoamInfo *roam_info, |
| tpSirSmeJoinRsp join_rsp) |
| {} |
| #endif |
| void csr_packetdump_timer_stop(void); |
| |
| #endif |