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