blob: a25788148f076f257768769c8dc7987246d26eae [file] [log] [blame]
Jeff Johnson295189b2012-06-20 16:38:30 -07001/*
Jeff Johnson32d95a32012-09-10 13:15:23 -07002 * Copyright (c) 2012, The Linux Foundation. All rights reserved.
Jeff Johnson295189b2012-06-20 16:38:30 -07003 *
4 * Previously licensed under the ISC license by Qualcomm Atheros, Inc.
5 *
6 *
7 * Permission to use, copy, modify, and/or distribute this software for
8 * any purpose with or without fee is hereby granted, provided that the
9 * above copyright notice and this permission notice appear in all
10 * copies.
11 *
12 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
13 * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
14 * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
15 * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
16 * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
17 * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
18 * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
19 * PERFORMANCE OF THIS SOFTWARE.
20 */
21
22/** ------------------------------------------------------------------------- *
23 ------------------------------------------------------------------------- *
24
25
26 \file csrInternal.h
27
28 Define internal data structure for MAC.
29
30 Copyright (C) 2006 Airgo Networks, Incorporated
31 ========================================================================== */
32#ifndef CSRINTERNAL_H__
33#define CSRINTERNAL_H__
34
35#if defined(VOSS_ENABLED)
36#include "vos_status.h"
37#include "vos_lock.h"
38#endif //#if defined(VOSS_ENABLED)
39
40#include "palTimer.h"
41#include "csrSupport.h"
42#include "vos_nvitem.h"
43#include "wlan_qct_tl.h"
44
45#ifdef WLAN_FEATURE_NEIGHBOR_ROAMING
46#include "csrNeighborRoam.h"
47#endif
48
49#define CSR_MAX_STA (HAL_NUM_STA)
50
51#define CSR_SME_SCAN_FLAGS_DELETE_CACHE 0x80
52
53#define CSR_TITAN_MAX_RATE_MIMO_CB 240
54#define CSR_TITAN_MAX_RATE_MIMO 126
55
56//define scan return criteria. LIM should use these define as well
57#define CSR_SCAN_RETURN_AFTER_ALL_CHANNELS ( 0 )
58#define CSR_SCAN_RETURN_AFTER_FIRST_MATCH ( 0x01 )
59#define CSR_SCAN_RETURN_AFTER_5_BAND_11d_FOUND ( 0x80 )
60#define CSR_SCAN_RETURN_AFTER_24_BAND_11d_FOUND ( 0x40 )
61#define CSR_SCAN_RETURN_AFTER_EITHER_BAND_11d_FOUND ( CSR_SCAN_RETURN_AFTER_5_BAND_11d_FOUND | CSR_SCAN_RETURN_AFTER_24_BAND_11d_FOUND )
62#define CSR_NUM_RSSI_CAT 5
63#define CSR_MAX_STATISTICS_REQ 10
64
65//Support for multiple session
66#define CSR_SESSION_ID_INVALID 0xFF // session ID invalid
67#define CSR_ROAM_SESSION_MAX 5 // No of sessions to be supported, and a
68 // session is for Infra, IBSS or BT-AMP
69
70#define CSR_IS_SESSION_VALID( pMac, sessionId ) ( ( (sessionId) < CSR_ROAM_SESSION_MAX ) \
71 && ( (pMac)->roam.roamSession[(sessionId)].sessionActive ) )
72#define CSR_GET_SESSION( pMac, sessionId ) \
73( \
74 (sessionId < CSR_ROAM_SESSION_MAX) ? \
75 (&(pMac)->roam.roamSession[(sessionId)]) :\
76 NULL \
77)
78
Madan Mohan Koyyalamudi470d2cf2012-09-28 14:43:44 -070079//Support for "Fast roaming" (i.e., CCX, LFR, or 802.11r.)
80#define CSR_BG_SCAN_OCCUPIED_CHANNEL_LIST_LEN 15
81#define CSR_BG_SCAN_VALID_CHANNEL_LIST_CHUNK_SIZE 3
82#define CSR_BG_SCAN_CHANNEL_LIST_LEN (CSR_BG_SCAN_OCCUPIED_CHANNEL_LIST_LEN + CSR_BG_SCAN_VALID_CHANNEL_LIST_CHUNK_SIZE)
83
Jeff Johnson295189b2012-06-20 16:38:30 -070084
85
86typedef enum
87{
88 //eCSR_CFG_DOT11_MODE_BEST = 0,
89 eCSR_CFG_DOT11_MODE_TAURUS = 0,
90 eCSR_CFG_DOT11_MODE_ABG,
91 eCSR_CFG_DOT11_MODE_11A,
92 eCSR_CFG_DOT11_MODE_11B,
93 eCSR_CFG_DOT11_MODE_11G,
94 eCSR_CFG_DOT11_MODE_11N,
95 eCSR_CFG_DOT11_MODE_POLARIS,
96 eCSR_CFG_DOT11_MODE_TITAN,
Jeff Johnsone7245742012-09-05 17:12:55 -070097#ifdef WLAN_FEATURE_11AC
98 eCSR_CFG_DOT11_MODE_11AC,
99#endif
Jeff Johnson295189b2012-06-20 16:38:30 -0700100#ifdef WLAN_SOFTAP_FEATURE
101 eCSR_CFG_DOT11_MODE_11G_ONLY,
102 eCSR_CFG_DOT11_MODE_11N_ONLY,
103#endif
Jeff Johnsone7245742012-09-05 17:12:55 -0700104#ifdef WLAN_FEATURE_11AC
105 eCSR_CFG_DOT11_MODE_11AC_ONLY,
106#endif
Jeff Johnson295189b2012-06-20 16:38:30 -0700107 //This value can never set to CFG. It is for CSR's internal use
108 eCSR_CFG_DOT11_MODE_AUTO,
109}eCsrCfgDot11Mode; //Used to determine what to set to the WNI_CFG_DOT11_MODE
110
111typedef enum etCsrRoamCommands
112{
113 eCsrRoamNoCommand,
114 eCsrRoamCommandScan,
115 eCsrRoamCommandRoam,
116 eCsrRoamCommandWmStatusChange,
117 eCsrRoamCommandSetKey,
118 eCsrRoamCommandRemoveKey,
119
120} eCsrRoamCommands;
121
122typedef enum
123{
124 eCsrScanOther = 1,
125 eCsrScanLostLink1,
126 eCsrScanLostLink2,
127 eCsrScanLostLink3,
128 eCsrScanLostLink4,
129 eCsrScan11d1, //First 11d scan
130 eCsrScan11d2, //First 11d scan has failed
131 eCsrScan11dDone, //11d scan succeeded, try the rest of the channel
132 eCsrScanUserRequest,
133 eCsrScanGetResult,
134 eCsrScanSetBGScanParam, //used for HO too - bg scan request in NT Handoff sub-state
135 eCsrScanForSsid,
136 eCsrScanForCapsChange,
137 eCsrScanBGScanAbort,
138 eCsrScanBGScanEnable,
139 eCsrScanIdleScan,
140 eCsrScanGetScanChnInfo, //To get the list of channels scanned
141
142 eCsrScanBgScan, // bg scan request in NRT & RT Handoff sub-states
143 eCsrScanProbeBss, // directed probe on an entry from the candidate list - HO
144 eCsrScanAbortBgScan, //aborting a BG scan (meaning the scan is triggered by LIM timer)
145 eCsrScanAbortNormalScan, //aborting a normal scan (the scan is trigger by eWNI_SME_SCAN_REQ)
146 eCsrScanP2PFindPeer
147}eCsrScanReason;
148
149typedef enum
150{
151 eCsrNoConnection, // Roaming because we have not established the initial connection.
152 eCsrCapsChange, // roaming because LIM reported a Capability change in the associated AP.
153 eCsrForcedDisassoc, // roaming becuase someone asked us to Disassoc and stay disassociated.
154 eCsrHddIssued, // roaming because an 802.11 request was issued to the driver.
155 eCsrLostLink1, // roaming because we lost link to an associated AP
156 eCsrLostLink2,
157 eCsrLostLink3,
158 eCsrForcedDisassocMICFailure, // roaming because we need to force a Disassoc due to MIC failure
159 eCsrHddIssuedReassocToSameAP,
160 eCsrSmeIssuedReassocToSameAP,
161 eCsrSmeIssuedReassocToDiffAP,
162 eCsrForcedDeauth, // roaming becuase someone asked us to deauth and stay disassociated.
163 eCsrSmeIssuedDisassocForHandoff, // will be issued by Handoff logic to disconect from current AP
164 eCsrSmeIssuedAssocToSimilarAP, // will be issued by Handoff logic to join a new AP with same profile
165 eCsrSmeIssuedIbssJoinFailure, // ibss join timer fired before any perr showed up, so shut down the network
166 eCsrForcedIbssLeave,
167 eCsrStopBss,
168 eCsrSmeIssuedFTReassoc,
169 eCsrForcedDisassocSta,
170 eCsrForcedDeauthSta,
Madan Mohan Koyyalamudi286b60e2012-10-11 12:59:07 -0700171 eCsrPerformPreauth,
Jeff Johnson295189b2012-06-20 16:38:30 -0700172
173}eCsrRoamReason;
174
175typedef enum
176{
177 eCSR_ROAM_SUBSTATE_NONE = 0,
178 eCSR_ROAM_SUBSTATE_START_BSS_REQ,
179 eCSR_ROAM_SUBSTATE_JOIN_REQ,
180 eCSR_ROAM_SUBSTATE_REASSOC_REQ,
181 eCSR_ROAM_SUBSTATE_DISASSOC_REQ,
182 eCSR_ROAM_SUBSTATE_STOP_BSS_REQ,
183 eCSR_ROAM_SUBSTATE_DISCONNECT_CONTINUE_ROAMING, //Continue the current roam command after disconnect
184 eCSR_ROAM_SUBSTATE_AUTH_REQ,
185 eCSR_ROAM_SUBSTATE_CONFIG,
186 eCSR_ROAM_SUBSTATE_DEAUTH_REQ,
187 eCSR_ROAM_SUBSTATE_DISASSOC_NOTHING_TO_JOIN,
188 eCSR_ROAM_SUBSTATE_DISASSOC_REASSOC_FAILURE,
189 eCSR_ROAM_SUBSTATE_DISASSOC_FORCED,
190 eCSR_ROAM_SUBSTATE_WAIT_FOR_KEY,
191 eCSR_ROAM_SUBSTATE_DISASSOC_HANDOFF,
192 eCSR_ROAM_SUBSTATE_JOINED_NO_TRAFFIC,
193 eCSR_ROAM_SUBSTATE_JOINED_NON_REALTIME_TRAFFIC,
194 eCSR_ROAM_SUBSTATE_JOINED_REALTIME_TRAFFIC,
195// max is 15 unless the bitfield is expanded...
196} eCsrRoamSubState;
197
198
199typedef enum
200{
201 eCSR_ROAMING_STATE_STOP = 0,
202 eCSR_ROAMING_STATE_IDLE,
203 eCSR_ROAMING_STATE_SCANNING,
204 eCSR_ROAMING_STATE_JOINING,
205 eCSR_ROAMING_STATE_JOINED,
206}eCsrRoamState;
207
208
209typedef enum
210{
211 eCsrContinueRoaming,
212 eCsrStopRoaming,
213 eCsrStartIbss,
214 eCsrStartIbssSameIbss,
215 eCsrReassocToSelfNoCapChange,
Jeff Johnsone7245742012-09-05 17:12:55 -0700216 eCsrStopRoamingDueToConcurrency,
Jeff Johnson295189b2012-06-20 16:38:30 -0700217
218}eCsrJoinState;
219
220typedef enum
221{
222 eCsrNotRoaming,
223 eCsrLostlinkRoamingDisassoc,
224 eCsrLostlinkRoamingDeauth,
225 eCsrDynamicRoaming,
226 eCsrReassocRoaming,
227}eCsrRoamingReason;
228
229typedef enum
230{
231 eCsrDisassociated,
232 eCsrDeauthenticated
233
234}eCsrRoamWmStatusChangeTypes;
235
236typedef enum
237{
238 eCsrSummaryStats = 0,
239 eCsrGlobalClassAStats,
240 eCsrGlobalClassBStats,
241 eCsrGlobalClassCStats,
242 eCsrGlobalClassDStats,
243 eCsrPerStaStats,
244 eCsrMaxStats
245}eCsrRoamStatsClassTypes;
246
247#ifdef FEATURE_WLAN_DIAG_SUPPORT
248typedef enum
249{
250 eCSR_WLAN_STATUS_CONNECT =0,
251 eCSR_WLAN_STATUS_DISCONNECT
252
253}eCsrDiagWlanStatusEventSubtype;
254
255typedef enum
256{
257 eCSR_REASON_UNSPECIFIED = 0,
258 eCSR_REASON_USER_REQUESTED,
259 eCSR_REASON_MIC_ERROR,
260 eCSR_REASON_DISASSOC,
261 eCSR_REASON_DEAUTH,
262 eCSR_REASON_HANDOFF,
263
264}eCsrDiagWlanStatusEventReason;
265
266typedef enum
267{
268 eCSR_WLAN_HANDOFF_EVENT =0,
269
270}eCsrDiagWlanHandoffEventSubtype;
271
272typedef enum
273{
274 eCSR_WLAN_VCC_EVENT =0,
275
276}eCsrDiagWlanVccEventSubtype;
277
278#endif //FEATURE_WLAN_DIAG_SUPPORT
279
280typedef struct tagCsrChannel
281{
282 tANI_U8 numChannels;
283 tANI_U8 channelList[WNI_CFG_VALID_CHANNEL_LIST_LEN];
284}tCsrChannel;
285
286typedef struct tagScanProfile
287{
288 tANI_U32 minChnTime;
289 tANI_U32 maxChnTime;
290 tANI_U32 restTime; //This is ignored if not associated
291 tANI_U32 numOfChannels;
292 tANI_U8 *pChannelList;
293 tSirScanType scanType; //active or passive
294 eCsrRoamBssType bssType; //BSS or IBSS
295 tANI_U8 ssid[WNI_CFG_SSID_LEN];
296 tANI_U8 bReturnAfter1stMatch;
297 tANI_U8 fUniqueResult;
298 tANI_U8 freshScan;
299 tCsrBssid bssid;
300}tScanProfile;
301
302typedef struct tagBssConfigParam
303{
304 eCsrMediaAccessType qosType;
305 tSirMacSSid SSID;
306 tANI_U32 uRTSThresh;
307 tANI_U32 uDeferThresh; //
308 eCsrCfgDot11Mode uCfgDot11Mode;
309 eCsrBand eBand;
310 tANI_U8 standardRate[CSR_DOT11_SUPPORTED_RATES_MAX];
311 tANI_U8 extendedRate[CSR_DOT11_EXTENDED_SUPPORTED_RATES_MAX];
312 eCsrExposedTxRate txRate;
313 tAniAuthType authType;
314 eCsrEncryptionType encType;
315 tANI_U32 uShortSlotTime;
316 tANI_U32 uHTSupport; //High throughput
317 tANI_U32 uPowerLimit;
318 tANI_U32 uHeartBeatThresh;
319 tANI_U32 uJoinTimeOut;
320 tSirMacCapabilityInfo BssCap;
321 tANI_BOOLEAN f11hSupport;
Jeff Johnsone7245742012-09-05 17:12:55 -0700322 ePhyChanBondState cbMode;
Jeff Johnson295189b2012-06-20 16:38:30 -0700323}tBssConfigParam;
324
325
326typedef struct tagCsrRoamStartBssParams
327{
328 tSirMacSSid ssId;
329 tCsrBssid bssid; //this is the BSSID for the party we want to join (only use for IBSS or WDS)
330 tSirNwType sirNwType;
Jeff Johnsone7245742012-09-05 17:12:55 -0700331 ePhyChanBondState cbMode;
Jeff Johnson295189b2012-06-20 16:38:30 -0700332 tSirMacRateSet operationalRateSet;
333 tSirMacRateSet extendedRateSet;
334 tANI_U8 operationChn;
335 eCsrCfgDot11Mode uCfgDot11Mode;
336#ifdef WLAN_SOFTAP_FEATURE
337 tANI_U8 privacy;
338 tANI_BOOLEAN fwdWPSPBCProbeReq;
339 tANI_BOOLEAN protEnabled;
340 tANI_BOOLEAN obssProtEnabled;
341 tAniAuthType authType;
342 tANI_U16 beaconInterval; //If this is 0, SME will fill in for caller.
343 tANI_U16 ht_protection;
344 tANI_U32 dtimPeriod;
345 tANI_U8 ApUapsdEnable;
346 tANI_U8 ssidHidden;
347 tANI_U8 wps_state;
348#endif
349 tVOS_CON_MODE bssPersona;
350 tANI_U16 nRSNIELength; //The byte count in the pRSNIE, if 0, pRSNIE is ignored.
351 tANI_U8 *pRSNIE; //If not null, it has the IE byte stream for RSN
352}tCsrRoamStartBssParams;
353
354
355typedef struct tagScanCmd
356{
357 tANI_U32 scanID;
358 csrScanCompleteCallback callback;
359 void *pContext;
360 eCsrScanReason reason;
361 eCsrRoamState lastRoamState[CSR_ROAM_SESSION_MAX];
362 tCsrRoamProfile *pToRoamProfile;
363 tANI_U32 roamId; //this is the ID related to the pToRoamProfile
364 union
365 {
366 tCsrScanRequest scanRequest;
367 tCsrBGScanRequest bgScanRequest;
368 }u;
369}tScanCmd;
370
371typedef struct tagRoamCmd
372{
373 tANI_U32 roamId;
374 eCsrRoamReason roamReason;
375 tCsrRoamProfile roamProfile;
376 tScanResultHandle hBSSList; //BSS list fits the profile
377 tListElem *pRoamBssEntry; //point to the current BSS in the list that is roaming. It starts from head to tail
378 tSirBssDescription *pLastRoamBss; //the last BSS we try and failed
379 tANI_BOOLEAN fReleaseBssList; //whether to free hBSSList
380 tANI_BOOLEAN fReleaseProfile; //whether to free roamProfile
381 tANI_BOOLEAN fReassoc; //whether this command is for reassociation
382 tANI_BOOLEAN fUpdateCurRoamProfile; //whether pMac->roam.pCurRoamProfile needs to be updated
383 //this is for CSR internal used only. And it should not be assigned when creating the command
384 //This causes the roam command not to do anything.
385 tANI_BOOLEAN fReassocToSelfNoCapChange;
386
387 tANI_BOOLEAN fStopWds;
388 tSirMacAddr peerMac;
389 tSirMacReasonCodes reason;
390}tRoamCmd;
391
392typedef struct tagSetKeyCmd
393{
394 tANI_U32 roamId;
395 eCsrEncryptionType encType;
396 eCsrAuthType authType;
397 tAniKeyDirection keyDirection; //Tx, Rx or Tx-and-Rx
398 tSirMacAddr peerMac; //Peer's MAC address. ALL 1's for group key
399 tANI_U8 paeRole; //0 for supplicant
400 tANI_U8 keyId; // Kye index
401 tANI_U8 keyLength; //Number of bytes containing the key in pKey
402 tANI_U8 Key[CSR_MAX_KEY_LEN];
403 tANI_U8 keyRsc[CSR_MAX_RSC_LEN];
404} tSetKeyCmd;
405
406typedef struct tahRemoveKeyCmd
407{
408 tANI_U32 roamId;
409 eCsrEncryptionType encType;
410 eCsrAuthType authType;
411 tSirMacAddr peerMac; //Peer's MAC address. ALL 1's for group key
412 tANI_U8 keyId; //key index
413} tRemoveKeyCmd;
414
415typedef struct tagWmStatusChangeCmd
416{
417 eCsrRoamWmStatusChangeTypes Type;
418 union
419 {
420 tSirSmeDeauthInd DeauthIndMsg;
421 tSirSmeDisassocInd DisassocIndMsg;
422 }u;
423
424}tWmStatusChangeCmd;
425
426typedef struct tagAddStaForSessionCmd
427{
428 //Session self mac addr
429 tSirMacAddr selfMacAddr;
430}tAddStaForSessionCmd;
431
432typedef struct tagDelStaForSessionCmd
433{
434 //Session self mac addr
435 tSirMacAddr selfMacAddr;
436 csrRoamSessionCloseCallback callback;
437 void *pContext;
438}tDelStaForSessionCmd;
439
440//This structure represents one scan request
441typedef struct tagCsrCmd
442{
443 tListElem Link;
444 eCsrRoamCommands command;
445 tANI_U8 sessionId; // Session ID for this command
446 union
447 {
448 tScanCmd scanCmd;
449 tRoamCmd roamCmd;
450 tWmStatusChangeCmd wmStatusChangeCmd;
451 tSetKeyCmd setKeyCmd;
452 tRemoveKeyCmd removeKeyCmd;
453 tAddStaForSessionCmd addStaSessionCmd;
454 tDelStaForSessionCmd delStaSessionCmd;
455 }u;
456}tCsrCmd;
457
458#ifdef WLAN_FEATURE_VOWIFI_11R
459typedef struct tagCsr11rConfig
460{
461 tANI_BOOLEAN IsFTResourceReqSupported;
462} tCsr11rConfig;
463#endif
464
465#ifdef WLAN_FEATURE_NEIGHBOR_ROAMING
466typedef struct tagCsrNeighborRoamConfig
467{
468 tANI_U32 nNeighborScanTimerPeriod;
469 tANI_U8 nNeighborLookupRssiThreshold;
470 tANI_U8 nNeighborReassocRssiThreshold;
471 tANI_U16 nNeighborScanMinChanTime;
472 tANI_U16 nNeighborScanMaxChanTime;
473 sCsrChannel neighborScanChanList;
474 tANI_U8 nMaxNeighborRetries;
475 tANI_U16 nNeighborResultsRefreshPeriod;
476}tCsrNeighborRoamConfig;
477#endif
478
479typedef struct tagCsrConfig
480{
481 tANI_U32 agingCount;
482 tANI_U32 FragmentationThreshold;
483 tANI_U32 channelBondingMode24GHz;
484 tANI_U32 channelBondingMode5GHz;
485 tANI_U32 RTSThreshold;
486 eCsrPhyMode phyMode;
487 eCsrCfgDot11Mode uCfgDot11Mode;
488 eCsrBand eBand;
489 tANI_U32 HeartbeatThresh50;
490 tANI_U32 HeartbeatThresh24;
491 tANI_U32 bgScanInterval;
492 eCsrCBChoice cbChoice;
493 eCsrBand bandCapability; //indicate hw capability
494 eCsrRoamWmmUserModeType WMMSupportMode;
495 tANI_BOOLEAN Is11eSupportEnabled;
496 tANI_BOOLEAN Is11dSupportEnabled;
497 tANI_BOOLEAN Is11dSupportEnabledOriginal;
498 tANI_BOOLEAN Is11hSupportEnabled;
499 tANI_BOOLEAN shortSlotTime;
500 tANI_BOOLEAN ProprietaryRatesEnabled;
501 tANI_BOOLEAN fenableMCCMode;
Mohit Khanna7ed53f02012-09-11 17:52:10 -0700502 tANI_BOOLEAN fAllowMCCGODiffBI;
Jeff Johnson295189b2012-06-20 16:38:30 -0700503 tANI_U16 TxRate;
504 tANI_U8 AdHocChannel24;
505 tANI_U8 AdHocChannel5G;
506 tANI_U32 impsSleepTime; //in units of microseconds
507 tANI_U32 scanAgeTimeNCNPS; //scan result aging time threshold when Not-Connect-No-Power-Save, in seconds
508 tANI_U32 scanAgeTimeNCPS; //scan result aging time threshold when Not-Connect-Power-Save, in seconds
509 tANI_U32 scanAgeTimeCNPS; //scan result aging time threshold when Connect-No-Power-Save, in seconds,
510 tANI_U32 scanAgeTimeCPS; //scan result aging time threshold when Connect-Power-Savein seconds
511 tANI_U32 BssPreferValue[CSR_NUM_RSSI_CAT]; //each RSSI category has one value
512 int RSSICat[CSR_NUM_RSSI_CAT];
513 tANI_U8 bCatRssiOffset; //to set the RSSI difference for each category
514 tANI_U32 nRoamingTime; //In seconds, CSR will try this long before gives up, 0 means no roaming
515 //Whether to limit the channels to the ones set in Csr11dInfo. If true, the opertaional
516 //channels are limited to the default channel list. It is an "AND" operation between the
517 //default channels and the channels in the 802.11d IE.
518 tANI_BOOLEAN fEnforce11dChannels;
519 //Country Code Priority
520 //0 = 802.11D > Configured Country > NV
521 //1 = Configured Country > 802.11D > NV
522 tANI_BOOLEAN fSupplicantCountryCodeHasPriority;
523 //When true, AP with unknown country code won't be see.
524 //"Unknown country code" means either Ap doesn't have 11d IE or we cannot
525 //find a domain for the country code in its 11d IE.
526 tANI_BOOLEAN fEnforceCountryCodeMatch;
527 //When true, only APs in the default domain can be seen. If the Ap has "unknown country
528 //code", or the doamin of the country code doesn't match the default domain, the Ap is
529 //not acceptable.
530 tANI_BOOLEAN fEnforceDefaultDomain;
531
532 tANI_U16 vccRssiThreshold;
533 tANI_U32 vccUlMacLossThreshold;
534
535 tANI_U32 nPassiveMinChnTime; //in units of milliseconds
536 tANI_U32 nPassiveMaxChnTime; //in units of milliseconds
537 tANI_U32 nActiveMinChnTime; //in units of milliseconds
538 tANI_U32 nActiveMaxChnTime; //in units of milliseconds
539
540 tANI_BOOLEAN IsIdleScanEnabled;
541 //in dBm, the maximum TX power
542 //The actual TX power is the lesser of this value and 11d.
543 //If 11d is disable, the lesser of this and default setting.
544 tANI_U8 nTxPowerCap;
545 tANI_U32 statsReqPeriodicity; //stats request frequency from PE while in full power
546 tANI_U32 statsReqPeriodicityInPS;//stats request frequency from PE while in power save
547#ifdef WLAN_SOFTAP_FEATURE
548 tANI_U32 dtimPeriod;
549 tANI_BOOLEAN ssidHidden;
550#endif
551
552#ifdef WLAN_FEATURE_VOWIFI_11R
553 tCsr11rConfig csr11rConfig;
554#endif
555
Jeff Johnson04dd8a82012-06-29 20:41:40 -0700556#ifdef FEATURE_WLAN_LFR
557 tANI_U8 isFastRoamIniFeatureEnabled;
558#endif
559
Jeff Johnson295189b2012-06-20 16:38:30 -0700560#ifdef FEATURE_WLAN_CCX
561 tANI_U8 isCcxIniFeatureEnabled;
562#endif
563
Jeff Johnson04dd8a82012-06-29 20:41:40 -0700564#if defined (WLAN_FEATURE_VOWIFI_11R) || defined (FEATURE_WLAN_CCX) || defined(FEATURE_WLAN_LFR)
Jeff Johnson295189b2012-06-20 16:38:30 -0700565 tANI_U8 isFastTransitionEnabled;
Jeff Johnson43971f52012-07-17 12:26:56 -0700566 tANI_U8 RoamRssiDiff;
Jeff Johnson295189b2012-06-20 16:38:30 -0700567#endif
568
569#ifdef WLAN_FEATURE_NEIGHBOR_ROAMING
570 tCsrNeighborRoamConfig neighborRoamConfig;
571#endif
572
573 /* Instead of Reassoc, send ADDTS/DELTS even when ACM is off for that AC
574 * This is mandated by WMM-AC certification */
575 tANI_BOOLEAN addTSWhenACMIsOff;
576
577 tANI_BOOLEAN fValidateList;
Madan Mohan Koyyalamudi96dd30d2012-10-05 17:24:51 -0700578 //Remove this code once SLM_Sessionization is supported
579 //BMPS_WORKAROUND_NOT_NEEDED
Jeff Johnsone7245742012-09-05 17:12:55 -0700580 tANI_BOOLEAN doBMPSWorkaround;
Jeff Johnson295189b2012-06-20 16:38:30 -0700581
582 //To enable/disable scanning 2.4Ghz channels twice on a single scan request from HDD
583 tANI_BOOLEAN fScanTwice;
Jeff Johnsone7245742012-09-05 17:12:55 -0700584#ifdef WLAN_FEATURE_11AC
585 tANI_U32 nVhtChannelWidth;
586#endif
Jeff Johnson295189b2012-06-20 16:38:30 -0700587
588}tCsrConfig;
589
590typedef struct tagCsrChannelPowerInfo
591{
592 tListElem link;
593 tANI_U8 firstChannel;
594 tANI_U8 numChannels;
595 tANI_U8 txPower;
596 tANI_U8 interChannelOffset;
597}tCsrChannelPowerInfo;
598
599typedef struct tagRoamJoinStatus
600{
601 tSirResultCodes statusCode;
602 //this is set to unspecified if statusCode indicates timeout. Or it is the failed reason from the other BSS(per 802.11 spec)
603 tANI_U32 reasonCode;
604}tCsrRoamJoinStatus;
605
606typedef struct tagCsrOsChannelMask
607{
608 tANI_U8 numChannels;
609 tANI_BOOLEAN scanEnabled[WNI_CFG_VALID_CHANNEL_LIST_LEN];
610 tANI_U8 channelList[WNI_CFG_VALID_CHANNEL_LIST_LEN];
611}tCsrOsChannelMask;
612
613
614typedef struct tagCsrScanStruct
615{
616 tScanProfile scanProfile;
617 tANI_U32 nextScanID;
Madan Mohan Koyyalamudica43cdf2012-09-24 13:15:49 -0700618 tDblLinkList scanResultList;
Jeff Johnson295189b2012-06-20 16:38:30 -0700619 tDblLinkList tempScanResults;
620 tANI_BOOLEAN fScanEnable;
621 tANI_BOOLEAN fFullScanIssued;
622 tPalTimerHandle hTimerGetResult;
623#ifdef WLAN_AP_STA_CONCURRENCY
624 tPalTimerHandle hTimerStaApConcTimer;
625#endif
626 tPalTimerHandle hTimerIdleScan;
627 tPalTimerHandle hTimerResultAging;
628 tPalTimerHandle hTimerBgScan;
629 //changes on every scan, it is used as a flag for whether 11d info is found on every scan
630 tANI_U8 channelOf11dInfo;
631 //changes on every scan, a flag to tell whether conflict 11d info found on each BSS
632 tANI_BOOLEAN fAmbiguous11dInfoFound;
633 //Tush: changes on every scan, a flag to tell whether the applied 11d info present in one of the scan results
634 tANI_BOOLEAN fCurrent11dInfoMatch;
635 tANI_BOOLEAN f11dInfoReset; //to indicate whether the 11d info in CFG is reset to default
636 tSirScanType curScanType;
637 tCsrChannel baseChannels; //This are all the supported channels AND(&) to the current eBand
638 tCsrChannel channels11d;
639 tChannelListWithPower defaultPowerTable[WNI_CFG_VALID_CHANNEL_LIST_LEN]; //From NV
640 tChannelListWithPower defaultPowerTable40MHz[WNI_CFG_VALID_CHANNEL_LIST_LEN]; //From NV
641 tANI_U32 numChannelsDefault; //total channels of NV
642 tCsrChannel base20MHzChannels; //The channel base to work on
643 tCsrChannel base40MHzChannels; //center channels for 40MHz channels
644 tDblLinkList channelPowerInfoList24;
645 tDblLinkList channelPowerInfoList5G;
646 tANI_U32 nLastAgeTimeOut;
647 tANI_U32 nAgingCountDown;
648 tANI_U8 countryCodeDefault[WNI_CFG_COUNTRY_CODE_LEN+1]; //The country code from NV
649 tANI_U8 countryCodeCurrent[WNI_CFG_COUNTRY_CODE_LEN+1];
650 tANI_U8 countryCode11d[WNI_CFG_COUNTRY_CODE_LEN+1];
651 v_REGDOMAIN_t domainIdDefault; //default regulatory domain
652 v_REGDOMAIN_t domainIdCurrent; //current regulatory domain
653 tANI_BOOLEAN f11dInfoApplied;
654 tANI_BOOLEAN fCancelIdleScan;
655#ifdef FEATURE_WLAN_WAPI
656// tANI_U16 NumBkidCandidate;
657// tBkidCandidateInfo BkidCandidateInfo[CSR_MAX_BKID_ALLOWED]; /* Move this as part of SessionEntry */
658#endif /* FEATURE_WLAN_WAPI */
659 tANI_U8 numBGScanChannel; //number of valid channels in the bgScanChannelList
660 tANI_U8 bgScanChannelList[WNI_CFG_BG_SCAN_CHANNEL_LIST_LEN];
661 //the ChannelInfo member is not used in this structure.
662 //numBGScanChannel and bgScanChannelList are used for the BG scan channel info
663 tCsrBGScanRequest bgScanParams;
664 tANI_BOOLEAN fRestartIdleScan;
665 tANI_U32 nIdleScanTimeGap; //the time since last trying to trigger idle scan
666 tCsrOsChannelMask osScanChannelMask;//keep a track of channels to be scnned while in traffic condition
667 tANI_U16 nBssLimit; //the maximum number of BSS in scan cache
668 /*channelPowerInfoList24 has been seen corrupted. Set this flag to true trying to
669 * detect when it happens. Adding this into code because we can't reproduce it easily.
670 * We don't know when it happens. */
671 tANI_BOOLEAN fValidateList;
672 /*Customer wants to start with an active scan based on the default country code.
673 * This optimization will minimize the driver load to association time.
674 * Based on this flag we will bypass the initial passive scan needed for 11d
675 * to determine the country code & domain */
676 tANI_BOOLEAN fEnableBypass11d;
677
678 /*Customer wants to optimize the scan time. Avoiding scans(passive) on DFS
679 * channels while swipping through both bands can save some time
680 * (apprx 1.3 sec) */
681 tANI_BOOLEAN fEnableDFSChnlScan;
682
Jeff Johnsone7245742012-09-05 17:12:55 -0700683 /*
684 * To enable/disable scanning only 2.4Ghz channels on first scan
685 */
686 tANI_BOOLEAN fFirstScanOnly2GChnl;
687
Jeff Johnson295189b2012-06-20 16:38:30 -0700688 tANI_BOOLEAN fDropScanCmd; //true means we don't accept scan commands
689
690#ifdef WLAN_AP_STA_CONCURRENCY
691 tDblLinkList scanCmdPendingList;
692#endif
Madan Mohan Koyyalamudi470d2cf2012-09-28 14:43:44 -0700693 tCsrChannel occupiedChannels; //This includes all channels on which candidate APs are found
Jeff Johnson295189b2012-06-20 16:38:30 -0700694}tCsrScanStruct;
695
696
697//Save the connected information. This structure + connectedProfile
698//should contain all information about the connection
699typedef struct tagRoamCsrConnectedInfo
700{
701 tANI_U32 nBeaconLength; //the length, in bytes, of the beacon frame, can be 0
702 tANI_U32 nAssocReqLength; //the length, in bytes, of the assoc req frame, can be 0
703 tANI_U32 nAssocRspLength; //The length, in bytes, of the assoc rsp frame, can be 0
704#ifdef WLAN_FEATURE_VOWIFI_11R
705 tANI_U32 nRICRspLength; //Length of the parsed RIC response IEs received in reassoc response
706#endif
707#ifdef FEATURE_WLAN_CCX
708 tANI_U32 nTspecIeLength;
709#endif
710 tANI_U8 *pbFrames; //Point to a buffer contain the beacon, assoc req, assoc rsp frame, in that order
711 //user needs to use nBeaconLength, nAssocReqLength, nAssocRspLength to desice where
712 //each frame starts and ends.
713 tANI_U8 staId;
714}tCsrRoamConnectedInfo;
715
716
717typedef struct tagCsrLinkQualityIndInfo
718{
719 csrRoamLinkQualityIndCallback callback;
720 void *context;
721}tCsrLinkQualityIndInfo;
722
723typedef struct tagCsrPeStatsReqInfo
724{
725 tListElem link; /* list links */
726 tANI_U32 statsMask;
727 tANI_U32 periodicity;
728 tANI_BOOLEAN rspPending;
729 vos_timer_t hPeStatsTimer;
730 tANI_BOOLEAN timerRunning;
731 tANI_U8 staId;
732 tANI_U8 numClient;
733 tpAniSirGlobal pMac;
734 /* To remember if the peStats timer is stopped successfully or not */
735 tANI_BOOLEAN timerStopFailed;
736
737}tCsrPeStatsReqInfo;
738
739typedef struct tagCsrStatsClientReqInfo
740{
741 tListElem link; /* list links */
742 eCsrStatsRequesterType requesterId;
743 tCsrStatsCallback callback;
744 tANI_U32 periodicity;
745 void *pContext;
746 tANI_U32 statsMask;
747 tCsrPeStatsReqInfo *pPeStaEntry;
748 tANI_U8 staId;
749 vos_timer_t timer;
750 tANI_BOOLEAN timerExpired;
751 tpAniSirGlobal pMac; // TODO: Confirm this change BTAMP
752}tCsrStatsClientReqInfo;
753
754typedef struct tagCsrTlStatsReqInfo
755{
756 tANI_U32 periodicity;
757 tANI_BOOLEAN timerRunning;
758 tPalTimerHandle hTlStatsTimer;
759 tANI_U8 numClient;
760}tCsrTlStatsReqInfo;
761
762typedef struct tagCsrRoamSession
763{
764 tANI_U8 sessionId; // Session ID
765 tANI_BOOLEAN sessionActive; // TRUE if it is used
766 tCsrBssid selfMacAddr; // For BT-AMP station, this serve as BSSID for self-BSS.
767 csrRoamCompleteCallback callback;
768 void *pContext;
769 eCsrConnectState connectState;
770 tCsrRoamConnectedProfile connectedProfile;
771 tCsrRoamConnectedInfo connectedInfo;
772 tCsrRoamProfile *pCurRoamProfile;
773 tSirBssDescription *pConnectBssDesc;
774 tANI_U16 NumPmkidCache;
775 tPmkidCacheInfo PmkidCacheInfo[CSR_MAX_PMKID_ALLOWED];
776 tANI_U8 cJoinAttemps;
777 //This may or may not have the up-to-date valid channel list
778 //It is used to get WNI_CFG_VALID_CHANNEL_LIST and not allocate memory all the time
779 tSirMacChanNum validChannelList[WNI_CFG_VALID_CHANNEL_LIST_LEN];
780 tANI_S32 sPendingCommands; //0 means CSR is ok to low power
781#ifdef FEATURE_WLAN_WAPI
782 tANI_U16 NumBkidCache;
783 tBkidCacheInfo BkidCacheInfo[CSR_MAX_BKID_ALLOWED];
784#endif /* FEATURE_WLAN_WAPI */
785 tANI_BOOLEAN fRoaming; //indicate whether CSR is roaming (either via lostlink or dynamic roaming)
786 //to remember some parameters needed for START_BSS.
787 //All member must be set every time we try to join or start an IBSS or BT-AMP
788 tCsrRoamStartBssParams bssParams;
789 tANI_U32 nWpaRsnReqIeLength; //the byte count of pWpaRsnIE;
790 tANI_U8 *pWpaRsnReqIE; //this contain the WPA/RSN IE in assoc request or the one sent in beacon (IBSS)
791 tANI_U32 nWpaRsnRspIeLength; //the byte count for pWpaRsnRspIE
792 tANI_U8 *pWpaRsnRspIE; //this contain the WPA/RSN IE in beacon/probe rsp
793#ifdef FEATURE_WLAN_WAPI
794 tANI_U32 nWapiReqIeLength; //the byte count of pWapiReqIE;
795 tANI_U8 *pWapiReqIE; //this contain the WAPI IE in assoc request or the one sent in beacon (IBSS)
796 tANI_U32 nWapiRspIeLength; //the byte count for pWapiRspIE
797 tANI_U8 *pWapiRspIE; //this contain the WAPI IE in beacon/probe rsp
798#endif /* FEATURE_WLAN_WAPI */
799 tANI_U32 nAddIEScanLength; //the byte count of pAddIeScanIE;
800 tANI_U8 *pAddIEScan; //this contains the additional IE in (unicast) probe request at the time of join
801 tANI_U32 nAddIEAssocLength; //the byte count for pAddIeAssocIE
802 tANI_U8 *pAddIEAssoc; //this contains the additional IE in (re) assoc request
803
804 tANI_TIMESTAMP roamingStartTime; //in units of 10ms
805 tCsrTimerInfo roamingTimerInfo;
806 eCsrRoamingReason roamingReason;
807 tANI_BOOLEAN fCancelRoaming;
808 tPalTimerHandle hTimerRoaming;
809 tPalTimerHandle hTimerIbssJoining;
810 tCsrTimerInfo ibssJoinTimerInfo;
811 tANI_BOOLEAN ibss_join_pending;
812 eCsrRoamResult roamResult; //the roamResult that is used when the roaming timer fires
813 tCsrRoamJoinStatus joinFailStatusCode; //This is the reason code for join(assoc) failure
814 //The status code returned from PE for deauth or disassoc (in case of lostlink), or our own dynamic roaming
815 tANI_U32 roamingStatusCode;
816 tANI_U16 NumPmkidCandidate;
817 tPmkidCandidateInfo PmkidCandidateInfo[CSR_MAX_PMKID_ALLOWED];
818 #ifdef FEATURE_WLAN_WAPI
819 tANI_U16 NumBkidCandidate;
820 tBkidCandidateInfo BkidCandidateInfo[CSR_MAX_BKID_ALLOWED];
821#endif
822 tANI_BOOLEAN fWMMConnection;
823#ifdef FEATURE_WLAN_BTAMP_UT_RF
824 //To retry a join later when it fails if so desired
825 tPalTimerHandle hTimerJoinRetry;
826 tCsrTimerInfo joinRetryTimerInfo;
827 tANI_U32 maxRetryCount;
828#endif
829#ifdef FEATURE_WLAN_CCX
830 tCsrCcxCckmInfo ccxCckmInfo;
831 tANI_BOOLEAN isPrevApInfoValid;
832 tSirMacSSid prevApSSID;
833 tCsrBssid prevApBssid;
834 tANI_U8 prevOpChannel;
835 tANI_U16 clientDissSecs;
836 tANI_U32 roamTS1;
837#endif
838 tANI_U8 bRefAssocStartCnt; //Tracking assoc start indication
839} tCsrRoamSession;
840
841typedef struct tagCsrRoamStruct
842{
843 tANI_U32 nextRoamId;
844 tDblLinkList roamCmdPendingList;
845 tDblLinkList channelList5G;
846 tDblLinkList channelList24;
847 tCsrConfig configParam;
848 tANI_U32 numChannelsEeprom; //total channels of eeprom
849 tCsrChannel base20MHzChannels; //The channel base to work on
850 tCsrChannel base40MHzChannels; //center channels for 40MHz channels
851 eCsrRoamState curState[CSR_ROAM_SESSION_MAX];
852 eCsrRoamSubState curSubState[CSR_ROAM_SESSION_MAX];
853 //This may or may not have the up-to-date valid channel list
854 //It is used to get WNI_CFG_VALID_CHANNEL_LIST and not allocate memory all the time
855 tSirMacChanNum validChannelList[WNI_CFG_VALID_CHANNEL_LIST_LEN];
856 tANI_U32 numValidChannels; //total number of channels in CFG
857
858 tANI_S32 sPendingCommands;
859 tChannelListWithPower *powerTableFromEeprom;
860 tChannelListWithPower *powerTableFromEeprom40MHz;
861 tPalTimerHandle hTimerWaitForKey; //To support timeout for WaitForKey state
862 tCsrSummaryStatsInfo summaryStatsInfo;
863 tCsrGlobalClassAStatsInfo classAStatsInfo;
864 tCsrGlobalClassBStatsInfo classBStatsInfo;
865 tCsrGlobalClassCStatsInfo classCStatsInfo;
866 tCsrGlobalClassDStatsInfo classDStatsInfo;
867 tCsrPerStaStatsInfo perStaStatsInfo[CSR_MAX_STA];
868 tDblLinkList statsClientReqList;
869 tDblLinkList peStatsReqList;
870 tCsrTlStatsReqInfo tlStatsReqInfo;
871 eCsrRoamLinkQualityInd vccLinkQuality;
872 tCsrLinkQualityIndInfo linkQualityIndInfo;
873 v_CONTEXT_t gVosContext; //used for interaction with TL
874 //To specify whether an association or a IBSS is WMM enabled
875 //This parameter is only valid during a join or start BSS command is being executed
876 //tANI_BOOLEAN fWMMConnection; /* Moving it to be part of roamsession */
877 v_U8_t ucACWeights[WLANTL_MAX_AC];
878 /* TODO : Upto here */
879 tCsrTimerInfo WaitForKeyTimerInfo;
880 tCsrRoamSession *roamSession;
881 tANI_U32 transactionId; // Current transaction ID for internal use.
882#ifdef WLAN_FEATURE_NEIGHBOR_ROAMING
883 tCsrNeighborRoamControlInfo neighborRoamInfo;
884#endif
Jeff Johnson04dd8a82012-06-29 20:41:40 -0700885#ifdef FEATURE_WLAN_LFR
886 tANI_U8 isFastRoamIniFeatureEnabled;
887#endif
Jeff Johnson295189b2012-06-20 16:38:30 -0700888#ifdef FEATURE_WLAN_CCX
889 tANI_U8 isCcxIniFeatureEnabled;
890#endif
Jeff Johnson43971f52012-07-17 12:26:56 -0700891#if defined (WLAN_FEATURE_VOWIFI_11R) || defined (FEATURE_WLAN_CCX) || defined(FEATURE_WLAN_LFR)
892 tANI_U8 RoamRssiDiff;
893#endif
Jeff Johnson295189b2012-06-20 16:38:30 -0700894}tCsrRoamStruct;
895
896
897#define GET_NEXT_ROAM_ID(pRoamStruct) (((pRoamStruct)->nextRoamId + 1 == 0) ? 1 : (pRoamStruct)->nextRoamId)
898#define CSR_IS_ROAM_STATE(pMac, state, sessionId) ( (state) == (pMac)->roam.curState[sessionId] )
899
900#define CSR_IS_ROAM_STOP(pMac, sessionId) CSR_IS_ROAM_STATE( (pMac), eCSR_ROAMING_STATE_STOP, sessionId )
901#define CSR_IS_ROAM_INIT(pMac, sessionId) CSR_IS_ROAM_STATE( (pMac), eCSR_ROAMING_STATE_INIT, sessionId )
902#define CSR_IS_ROAM_SCANNING(pMac, sessionId) CSR_IS_ROAM_STATE( pMac, eCSR_ROAMING_STATE_SCANNING, sessionId )
903#define CSR_IS_ROAM_JOINING(pMac, sessionId) CSR_IS_ROAM_STATE( pMac, eCSR_ROAMING_STATE_JOINING, sessionId )
904#define CSR_IS_ROAM_IDLE(pMac, sessionId) CSR_IS_ROAM_STATE( pMac, eCSR_ROAMING_STATE_IDLE, sessionId )
905#define CSR_IS_ROAM_JOINED(pMac, sessionId) CSR_IS_ROAM_STATE( pMac, eCSR_ROAMING_STATE_JOINED, sessionId )
906
907#define CSR_IS_ROAM_SUBSTATE(pMac, subState, sessionId) ((subState) == (pMac)->roam.curSubState[sessionId])
908#define CSR_IS_ROAM_SUBSTATE_JOIN_REQ(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_JOIN_REQ, sessionId)
909#define CSR_IS_ROAM_SUBSTATE_AUTH_REQ(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_AUTH_REQ, sessionId)
910#define CSR_IS_ROAM_SUBSTATE_REASSOC_REQ(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_REASSOC_REQ, sessionId)
911#define CSR_IS_ROAM_SUBSTATE_DISASSOC_REQ(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_DISASSOC_REQ, sessionId)
912#define CSR_IS_ROAM_SUBSTATE_DISASSOC_NO_JOIN(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_DISASSOC_NOTHING_TO_JOIN, sessionId)
913#define CSR_IS_ROAM_SUBSTATE_REASSOC_FAIL(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_DISASSOC_REASSOC_FAILURE, sessionId)
914#define CSR_IS_ROAM_SUBSTATE_DISASSOC_FORCED(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_DISASSOC_FORCED, sessionId)
915#define CSR_IS_ROAM_SUBSTATE_DEAUTH_REQ(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_DEAUTH_REQ, sessionId)
916#define CSR_IS_ROAM_SUBSTATE_START_BSS_REQ(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_START_BSS_REQ, sessionId)
917#define CSR_IS_ROAM_SUBSTATE_STOP_BSS_REQ(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_STOP_BSS_REQ, sessionId)
918#define CSR_IS_ROAM_SUBSTATE_DISCONNECT_CONTINUE(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_DISCONNECT_CONTINUE_ROAMING, sessionId)
919#define CSR_IS_ROAM_SUBSTATE_CONFIG(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_CONFIG, sessionId)
920#define CSR_IS_ROAM_SUBSTATE_WAITFORKEY(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_WAIT_FOR_KEY, sessionId)
921#define CSR_IS_ROAM_SUBSTATE_DISASSOC_HO(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_DISASSOC_HANDOFF, sessionId)
922#define CSR_IS_ROAM_SUBSTATE_HO_NT(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_JOINED_NO_TRAFFIC, sessionId)
923#define CSR_IS_ROAM_SUBSTATE_HO_NRT(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_JOINED_NON_REALTIME_TRAFFIC, sessionId)
924#define CSR_IS_ROAM_SUBSTATE_HO_RT(pMac, sessionId) CSR_IS_ROAM_SUBSTATE((pMac), eCSR_ROAM_SUBSTATE_JOINED_REALTIME_TRAFFIC, sessionId)
925
926#define CSR_IS_PHY_MODE_B_ONLY(pMac) \
927 ((eCSR_DOT11_MODE_11b == (pMac)->roam.configParam.phyMode) ||\
928 (eCSR_DOT11_MODE_11b_ONLY == (pMac)->roam.configParam.phyMode))
929
930#define CSR_IS_PHY_MODE_G_ONLY(pMac) \
931 (eCSR_DOT11_MODE_11g == (pMac)->roam.configParam.phyMode || eCSR_DOT11_MODE_11g_ONLY == (pMac)->roam.configParam.phyMode)
932
933#define CSR_IS_PHY_MODE_A_ONLY(pMac) \
934 ((eCSR_DOT11_MODE_11a == (pMac)->roam.configParam.phyMode) ||\
935 (eCSR_DOT11_MODE_11a_ONLY == (pMac)->roam.configParam.phyMode))
936
Jeff Johnsone7245742012-09-05 17:12:55 -0700937#ifdef WLAN_FEATURE_11AC
938#define CSR_IS_PHY_MODE_DUAL_BAND(phyMode) \
939 ((eCSR_DOT11_MODE_abg & (phyMode)) || (eCSR_DOT11_MODE_11n & (phyMode)) || \
940 (eCSR_DOT11_MODE_11ac & (phyMode)) || \
941 (eCSR_DOT11_MODE_TAURUS & (phyMode)) || \
942 (eCSR_DOT11_MODE_AUTO & (phyMode)))
943#else
Jeff Johnson295189b2012-06-20 16:38:30 -0700944#define CSR_IS_PHY_MODE_DUAL_BAND(phyMode) \
945 ((eCSR_DOT11_MODE_abg & (phyMode)) || (eCSR_DOT11_MODE_11n & (phyMode)) || \
946 (eCSR_DOT11_MODE_TAURUS & (phyMode)) || \
947 (eCSR_DOT11_MODE_AUTO & (phyMode)))
Jeff Johnsone7245742012-09-05 17:12:55 -0700948#endif
949
Jeff Johnson295189b2012-06-20 16:38:30 -0700950
951// this function returns TRUE if the NIC is operating exclusively in the 2.4 GHz band, meaning
952// it is NOT operating in the 5.0 GHz band.
953#define CSR_IS_24_BAND_ONLY(pMac) \
954 (eCSR_BAND_24 == (pMac)->roam.configParam.eBand)
955
956#define CSR_IS_5G_BAND_ONLY(pMac) \
957 (eCSR_BAND_5G == (pMac)->roam.configParam.eBand)
958
959#define CSR_IS_RADIO_DUAL_BAND(pMac) \
960 (eCSR_BAND_ALL == (pMac)->roam.configParam.bandCapability)
961
962#define CSR_IS_RADIO_BG_ONLY(pMac) \
963 (eCSR_BAND_24 == (pMac)->roam.configParam.bandCapability)
964
965// this function returns TRUE if the NIC is operating exclusively in the 5.0 GHz band, meaning
966// it is NOT operating in the 2.4 GHz band
967#define CSR_IS_RADIO_A_ONLY(pMac) \
968 (eCSR_BAND_5G == (pMac)->roam.configParam.bandCapability)
969
970// this function returns TRUE if the NIC is operating in both bands.
971#define CSR_IS_OPEARTING_DUAL_BAND(pMac) \
972 ((eCSR_BAND_ALL == (pMac)->roam.configParam.bandCapability) && (eCSR_BAND_ALL == (pMac)->roam.configParam.eBand))
973
974// this function returns TRUE if the NIC can operate in the 5.0 GHz band (could operate in the
975// 2.4 GHz band also).
976#define CSR_IS_OPERATING_A_BAND(pMac) \
977 (CSR_IS_OPEARTING_DUAL_BAND((pMac)) || CSR_IS_RADIO_A_ONLY((pMac)) || CSR_IS_5G_BAND_ONLY((pMac)))
978
979// this function returns TRUE if the NIC can operate in the 2.4 GHz band (could operate in the
980// 5.0 GHz band also).
981#define CSR_IS_OPERATING_BG_BAND(pMac) \
982 (CSR_IS_OPEARTING_DUAL_BAND((pMac)) || CSR_IS_RADIO_BG_ONLY((pMac)) || CSR_IS_24_BAND_ONLY((pMac)))
983
984#define CSR_IS_CHANNEL_5GHZ(chnNum) \
Jeff Johnsone7245742012-09-05 17:12:55 -0700985 (((chnNum) >= CSR_MIN_5GHz_CHANNEL_NUMBER) && ((chnNum) <= CSR_MAX_5GHz_CHANNEL_NUMBER))
Jeff Johnson295189b2012-06-20 16:38:30 -0700986
987#define CSR_IS_CHANNEL_24GHZ(chnNum) \
988 (((chnNum) > 0) && ((chnNum) <= CSR_MAX_24GHz_CHANNEL_NUMBER))
989
990#define CSR_IS_SAME_BAND_CHANNELS(ch1, ch2) (CSR_IS_CHANNEL_5GHZ(ch1) == CSR_IS_CHANNEL_5GHZ(ch2))
991
992
993#define CSR_IS_11D_INFO_FOUND(pMac) \
994 (0 != (pMac)->scan.channelOf11dInfo)
995// DEAUTHIND
996#define CSR_IS_ROAMING(pSession) ((CSR_IS_LOSTLINK_ROAMING((pSession)->roamingReason)) || \
997 (eCsrDynamicRoaming == (pSession)->roamingReason) || \
998 (eCsrReassocRoaming == (pSession)->roamingReason))
999
1000
1001#define CSR_IS_SET_KEY_COMMAND( pCommand ) ( eSmeCommandSetKey == (pCommand)->command )
1002
1003#define CSR_IS_ADDTS_WHEN_ACMOFF_SUPPORTED(pMac) (pMac->roam.configParam.addTSWhenACMIsOff)
1004// DEAUTHIND
1005#define CSR_IS_LOSTLINK_ROAMING(reason) ((eCsrLostlinkRoamingDisassoc == (reason)) || (eCsrLostlinkRoamingDeauth == (reason)))
1006
1007//Stop CSR from asking for IMPS, This function doesn't disable IMPS from CSR
1008void csrScanSuspendIMPS( tpAniSirGlobal pMac );
1009//Start CSR from asking for IMPS. This function doesn't trigger CSR to request entering IMPS
1010//because IMPS maybe disabled.
1011void csrScanResumeIMPS( tpAniSirGlobal pMac );
1012
1013eHalStatus csrInitGetChannels(tpAniSirGlobal pMac);
1014
1015eHalStatus csrSetModifyProfileFields(tpAniSirGlobal pMac, tANI_U32 sessionId,
1016 tCsrRoamModifyProfileFields *pModifyProfileFields);
1017/* ---------------------------------------------------------------------------
1018 \fn csrGetModifyProfileFields
1019 \brief HDD or SME - QOS calls this function to get the current values of
1020 connected profile fields changing which can cause reassoc.
1021 This function must be called after CFG is downloaded and STA is in connected
1022 state.
1023 \param pModifyProfileFields - pointer to the connected profile fields
1024 changing which can cause reassoc
1025
1026 \return eHalStatus
1027 -------------------------------------------------------------------------------*/
1028eHalStatus csrGetModifyProfileFields(tpAniSirGlobal pMac, tANI_U32 sessionId,
1029 tCsrRoamModifyProfileFields * pModifyProfileFields);
1030void csrSetGlobalCfgs( tpAniSirGlobal pMac );
1031void csrSetDefaultDot11Mode( tpAniSirGlobal pMac );
1032void csrScanSetChannelMask(tpAniSirGlobal pMac, tCsrChannelInfo *pChannelInfo);
1033tANI_BOOLEAN csrIsConnStateDisconnected(tpAniSirGlobal pMac, tANI_U32 sessionId);
1034tANI_BOOLEAN csrIsConnStateConnectedIbss( tpAniSirGlobal pMac, tANI_U32 sessionId );
1035tANI_BOOLEAN csrIsConnStateDisconnectedIbss( tpAniSirGlobal pMac, tANI_U32 sessionId );
1036tANI_BOOLEAN csrIsConnStateConnectedInfra( tpAniSirGlobal pMac, tANI_U32 sessionId );
1037tANI_BOOLEAN csrIsConnStateConnected( tpAniSirGlobal pMac, tANI_U32 sessionId );
1038tANI_BOOLEAN csrIsConnStateInfra( tpAniSirGlobal pMac, tANI_U32 sessionId );
1039tANI_BOOLEAN csrIsConnStateIbss( tpAniSirGlobal pMac, tANI_U32 sessionId );
1040tANI_BOOLEAN csrIsConnStateWds( tpAniSirGlobal pMac, tANI_U32 sessionId );
1041tANI_BOOLEAN csrIsConnStateConnectedWds( tpAniSirGlobal pMac, tANI_U32 sessionId );
1042tANI_BOOLEAN csrIsConnStateDisconnectedWds( tpAniSirGlobal pMac, tANI_U32 sessionId );
1043tANI_BOOLEAN csrIsAnySessionInConnectState( tpAniSirGlobal pMac );
1044tANI_BOOLEAN csrIsAllSessionDisconnected( tpAniSirGlobal pMac );
Madan Mohan Koyyalamudid3d22592012-09-24 14:01:29 -07001045tANI_BOOLEAN csrIsAnySessionConnected( tpAniSirGlobal pMac );
Jeff Johnson295189b2012-06-20 16:38:30 -07001046tANI_BOOLEAN csrIsInfraConnected( tpAniSirGlobal pMac );
1047tANI_BOOLEAN csrIsConcurrentInfraConnected( tpAniSirGlobal pMac );
Jeff Johnsone7245742012-09-05 17:12:55 -07001048tANI_BOOLEAN csrIsConcurrentSessionRunning( tpAniSirGlobal pMac );
Jeff Johnsone7245742012-09-05 17:12:55 -07001049tANI_BOOLEAN csrIsInfraApStarted( tpAniSirGlobal pMac );
Jeff Johnson295189b2012-06-20 16:38:30 -07001050tANI_BOOLEAN csrIsIBSSStarted( tpAniSirGlobal pMac );
1051tANI_BOOLEAN csrIsBTAMPStarted( tpAniSirGlobal pMac );
1052tANI_BOOLEAN csrIsBTAMP( tpAniSirGlobal pMac, tANI_U32 sessionId );
1053eHalStatus csrIsBTAMPAllowed( tpAniSirGlobal pMac, tANI_U32 chnId );
Jeff Johnsone7245742012-09-05 17:12:55 -07001054tANI_BOOLEAN csrIsValidMcConcurrentSession(tpAniSirGlobal pMac, tANI_U32 sessionId,
1055 tSirBssDescription *pBssDesc);
Jeff Johnson295189b2012-06-20 16:38:30 -07001056#ifdef WLAN_SOFTAP_FEATURE
1057tANI_BOOLEAN csrIsConnStateConnectedInfraAp( tpAniSirGlobal pMac, tANI_U32 sessionId );
1058#endif
1059/*----------------------------------------------------------------------------
1060 \fn csrRoamRegisterLinkQualityIndCallback
1061
1062 \brief
1063 a CSR function to allow HDD to register a callback handler with CSR for
1064 link quality indications.
1065
1066 Only one callback may be registered at any time.
1067 In order to deregister the callback, a NULL cback may be provided.
1068
1069 Registration happens in the task context of the caller.
1070
1071 \param callback - Call back being registered
1072 \param pContext - user data
1073
1074 DEPENDENCIES: After CSR open
1075
1076 \return eHalStatus
1077-----------------------------------------------------------------------------*/
1078eHalStatus csrRoamRegisterLinkQualityIndCallback(tpAniSirGlobal pMac,
1079 csrRoamLinkQualityIndCallback callback,
1080 void *pContext);
1081/* ---------------------------------------------------------------------------
1082 \fn csrGetStatistics
1083 \brief csr function that client calls to register a callback to get
1084 different PHY level statistics from CSR.
1085
1086 \param requesterId - different client requesting for statistics, HDD, UMA/GAN etc
1087 \param statsMask - The different category/categories of stats requester is looking for
1088 \param callback - SME sends back the requested stats using the callback
1089 \param periodicity - If requester needs periodic update, 0 means it's an one
1090 time request
1091 \param cache - If requester is happy with cached stats
1092 \param staId - The station ID for which the stats is requested for
1093 \param pContext - user context to be passed back along with the callback
1094
1095 \return eHalStatus
1096 ---------------------------------------------------------------------------*/
1097eHalStatus csrGetStatistics(tpAniSirGlobal pMac, eCsrStatsRequesterType requesterId,
1098 tANI_U32 statsMask,
1099 tCsrStatsCallback callback,
1100 tANI_U32 periodicity, tANI_BOOLEAN cache,
1101 tANI_U8 staId, void *pContext);
1102
1103
1104eHalStatus csrGetRssi(tpAniSirGlobal pMac,tCsrRssiCallback callback,tANI_U8 staId,tCsrBssid bssId,void * pContext,void * pVosContext);
1105eHalStatus csrRoamRegisterCallback(tpAniSirGlobal pMac, csrRoamCompleteCallback callback, void *pContext);
1106/* ---------------------------------------------------------------------------
1107 \fn csrGetConfigParam
1108 \brief HDD calls this function to get the global settings currently maintained by CSR.
1109 \param pParam - caller allocated memory
1110 \return eHalStatus
1111 -------------------------------------------------------------------------------*/
1112eHalStatus csrGetConfigParam(tpAniSirGlobal pMac, tCsrConfigParam *pParam);
1113
1114/* ---------------------------------------------------------------------------
1115 \fn csrMsgProcessor
1116 \brief HDD calls this function to change some global settings.
1117 caller must set the all fields or call csrGetConfigParam to prefill the fields.
1118 \param pParam - caller allocated memory
1119 \return eHalStatus
1120 -------------------------------------------------------------------------------*/
1121eHalStatus csrChangeDefaultConfigParam(tpAniSirGlobal pMac, tCsrConfigParam *pParam);
1122
1123
1124/* ---------------------------------------------------------------------------
1125 \fn csrMsgProcessor
1126 \brief HDD calls this function for the messages that are handled by CSR.
1127 \param pMsgBuf - a pointer to a buffer that maps to various structures base on the message type.
1128 The beginning of the buffer can always map to tSirSmeRsp.
1129 \return eHalStatus
1130 -------------------------------------------------------------------------------*/
1131eHalStatus csrMsgProcessor( tpAniSirGlobal pMac, void *pMsgBuf );
1132
1133/* ---------------------------------------------------------------------------
1134 \fn csrOpen
1135 \brief This function must be called before any API call to CSR.
1136 \return eHalStatus
1137 -------------------------------------------------------------------------------*/
1138eHalStatus csrOpen(tpAniSirGlobal pMac);
1139/* ---------------------------------------------------------------------------
1140 \fn csrClose
1141 \brief To close down CSR module. There should not be any API call into CSR after calling this function.
1142 \return eHalStatus
1143 -------------------------------------------------------------------------------*/
1144eHalStatus csrClose(tpAniSirGlobal pMac);
1145/* ---------------------------------------------------------------------------
1146 \fn csrStart
1147 \brief To start CSR.
1148 \return eHalStatus
1149 -------------------------------------------------------------------------------*/
1150eHalStatus csrStart(tpAniSirGlobal pMac);
1151/* ---------------------------------------------------------------------------
1152 \fn csrStop
1153 \brief To stop CSR. CSR still keeps its current setting.
1154 \return eHalStatus
1155 -------------------------------------------------------------------------------*/
1156eHalStatus csrStop(tpAniSirGlobal pMac);
1157/* ---------------------------------------------------------------------------
1158 \fn csrReady
1159 \brief To let CSR is ready to operate
1160 \return eHalStatus
1161 -------------------------------------------------------------------------------*/
1162eHalStatus csrReady(tpAniSirGlobal pMac);
1163
1164#ifdef FEATURE_WLAN_WAPI
1165eHalStatus csrRoamGetBKIDCache(tpAniSirGlobal pMac, tANI_U32 sessionId, tANI_U32 *pNum,
1166 tBkidCacheInfo *pBkidCache);
1167
1168
1169eHalStatus csrScanGetBKIDCandidateList(tpAniSirGlobal pMac, tANI_U32 sessionId,
1170 tBkidCandidateInfo *pBkidList, tANI_U32 *pNumItems );
1171tANI_U32 csrRoamGetNumBKIDCache(tpAniSirGlobal pMac, tANI_U32 sessionId);
1172eHalStatus csrRoamSetBKIDCache( tpAniSirGlobal pMac, tANI_U32 sessionId, tBkidCacheInfo *pBKIDCache,
1173 tANI_U32 numItems );
1174/* ---------------------------------------------------------------------------
1175 \fn csrRoamGetWapiReqIE
1176 \brief return the WAPI IE CSR passes to PE to JOIN request or START_BSS request
1177 \param pLen - caller allocated memory that has the length of pBuf as input. Upon returned, *pLen has the
1178 needed or IE length in pBuf.
1179 \param pBuf - Caller allocated memory that contain the IE field, if any, upon return
1180 \return eHalStatus - when fail, it usually means the buffer allocated is not big enough
1181 -------------------------------------------------------------------------------*/
1182eHalStatus csrRoamGetWapiReqIE(tpAniSirGlobal pMac, tANI_U32 sessionId, tANI_U32 *pLen, tANI_U8 *pBuf);
1183
1184/* ---------------------------------------------------------------------------
1185 \fn csrRoamGetWapiRspIE
1186 \brief return the WAPI IE from the beacon or probe rsp if connected
1187 \param pLen - caller allocated memory that has the length of pBuf as input. Upon returned, *pLen has the
1188 needed or IE length in pBuf.
1189 \param pBuf - Caller allocated memory that contain the IE field, if any, upon return
1190 \return eHalStatus - when fail, it usually means the buffer allocated is not big enough
1191 -------------------------------------------------------------------------------*/
1192eHalStatus csrRoamGetWapiRspIE(tpAniSirGlobal pMac, tANI_U32 sessionId, tANI_U32 *pLen, tANI_U8 *pBuf);
1193tANI_U8 csrConstructWapiIe( tpAniSirGlobal pMac, tANI_U32 sessionId, tCsrRoamProfile *pProfile,
1194 tSirBssDescription *pSirBssDesc, tDot11fBeaconIEs *pIes, tCsrWapiIe *pWapiIe );
1195#endif /* FEATURE_WLAN_WAPI */
1196
1197#ifdef WLAN_SOFTAP_FEATURE
1198eHalStatus csrRoamUpdateAPWPSIE( tpAniSirGlobal pMac, tANI_U32 sessionId, tSirAPWPSIEs *pAPWPSIES );
1199eHalStatus csrRoamUpdateWPARSNIEs( tpAniSirGlobal pMac, tANI_U32 sessionId, tSirRSNie * pAPSirRSNie);
1200#endif
1201void csrSetCfgPrivacy( tpAniSirGlobal pMac, tCsrRoamProfile *pProfile, tANI_BOOLEAN fPrivacy );
1202tANI_S8 csrGetInfraSessionId( tpAniSirGlobal pMac );
1203tANI_U8 csrGetInfraOperationChannel( tpAniSirGlobal pMac, tANI_U8 sessionId);
1204tANI_U8 csrGetConcurrentOperationChannel( tpAniSirGlobal pMac );
1205
1206eHalStatus csrRoamCopyConnectProfile(tpAniSirGlobal pMac, tANI_U32 sessionId,
1207 tCsrRoamConnectedProfile *pProfile);
1208tANI_BOOLEAN csrIsSetKeyAllowed(tpAniSirGlobal pMac, tANI_U32 sessionId);
1209
1210void csrSetOppositeBandChannelInfo( tpAniSirGlobal pMac );
1211void csrConstructCurrentValidChannelList( tpAniSirGlobal pMac, tDblLinkList *pChannelSetList,
1212 tANI_U8 *pChannelList, tANI_U8 bSize, tANI_U8 *pNumChannels );
1213
1214#endif
1215
1216#ifdef WLAN_FEATURE_VOWIFI_11R
1217//Returns whether the current association is a 11r assoc or not
1218tANI_BOOLEAN csrRoamIs11rAssoc(tpAniSirGlobal pMac);
1219#endif
1220
1221#ifdef FEATURE_WLAN_CCX
1222//Returns whether the current association is a CCX assoc or not
1223tANI_BOOLEAN csrRoamIsCCXAssoc(tpAniSirGlobal pMac);
1224#endif
1225
Madan Mohan Koyyalamudi96dd30d2012-10-05 17:24:51 -07001226//Remove this code once SLM_Sessionization is supported
1227//BMPS_WORKAROUND_NOT_NEEDED
Jeff Johnson295189b2012-06-20 16:38:30 -07001228void csrDisconnectAllActiveSessions(tpAniSirGlobal pMac);
Mohit Khanna349bc392012-09-11 17:24:52 -07001229
Jeff Johnson04dd8a82012-06-29 20:41:40 -07001230#ifdef FEATURE_WLAN_LFR
1231//Returns whether "Legacy Fast Roaming" is enabled...or not
1232tANI_BOOLEAN csrRoamIsFastRoamEnabled(tpAniSirGlobal pMac);
Madan Mohan Koyyalamudi470d2cf2012-09-28 14:43:44 -07001233tANI_BOOLEAN csrIsChannelPresentInList( tANI_U8 *pChannelList, int numChannels, tANI_U8 channel );
1234VOS_STATUS csrAddToChannelListFront( tANI_U8 *pChannelList, int numChannels, tANI_U8 channel );
1235tANI_BOOLEAN csrNeighborRoamIsSsidCandidateMatch( tpAniSirGlobal pMac, tDot11fBeaconIEs *pIes);
Jeff Johnson04dd8a82012-06-29 20:41:40 -07001236#endif
1237