blob: e1efe10930f01c37759472ed562ca5b9ab8a8d5f [file] [log] [blame]
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001/*
Krishna Kumaar Natarajan4e9cf392015-11-20 13:35:05 -08002 * Copyright (c) 2011-2016 The Linux Foundation. All rights reserved.
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003 *
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 * This file was originally distributed by Qualcomm Atheros, Inc.
24 * under proprietary terms before Copyright ownership was assigned
25 * to the Linux Foundation.
26 */
27
28/*
29 *
30 * This file lim_global.h contains the definitions exported by
31 * LIM module.
32 * Author: Chandra Modumudi
33 * Date: 02/11/02
34 * History:-
35 * Date Modified by Modification Information
36 * --------------------------------------------------------------------
37 *
38 */
39#ifndef __LIM_GLOBAL_H
40#define __LIM_GLOBAL_H
41
42#include "wni_api.h"
43#include "sir_api.h"
44#include "sir_mac_prot_def.h"
45#include "sir_mac_prop_exts.h"
46#include "sir_common.h"
47#include "sir_debug.h"
48#include "wni_cfg.h"
49#include "csr_api.h"
50#include "sap_api.h"
51#include "dot11f.h"
52#include "wma_if.h"
53
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080054/* Sending Disassociate frames threshold */
55#define LIM_SEND_DISASSOC_FRAME_THRESHOLD 2
56#define LIM_HASH_MISS_TIMER_MS 10000
57
58/* Deferred Message Queue Length */
59#define MAX_DEFERRED_QUEUE_LEN 80
60
61/* Maximum number of PS - TIM's to be sent with out wakeup from STA */
62#define LIM_TIM_WAIT_COUNT_FACTOR 5
63
64/*
65 * Use this count if (LIM_TIM_WAIT_FACTOR * ListenInterval)
66 * is less than LIM_MIN_TIM_WAIT_CNT
67 */
68#define LIM_MIN_TIM_WAIT_COUNT 50
69
70#define GET_TIM_WAIT_COUNT(LIntrvl) \
71 ((LIntrvl * LIM_TIM_WAIT_COUNT_FACTOR) > LIM_MIN_TIM_WAIT_COUNT ? \
72 (LIntrvl * LIM_TIM_WAIT_COUNT_FACTOR) : LIM_MIN_TIM_WAIT_COUNT)
73
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080074#define LIM_MAX_CSA_IE_UPDATES (5)
75
76/* enums exported by LIM are as follows */
77
78/*System role definition */
79typedef enum eLimSystemRole {
80 eLIM_UNKNOWN_ROLE,
81 eLIM_AP_ROLE,
82 eLIM_STA_IN_IBSS_ROLE,
83 eLIM_STA_ROLE,
84 eLIM_BT_AMP_STA_ROLE,
85 eLIM_BT_AMP_AP_ROLE,
86 eLIM_P2P_DEVICE_ROLE,
87 eLIM_P2P_DEVICE_GO,
88 eLIM_P2P_DEVICE_CLIENT
89} tLimSystemRole;
90
91/*
92 * SME state definition accessible across all Sirius modules.
93 * AP only states are LIM_SME_CHANNEL_SCAN_STATE &
94 * LIM_SME_NORMAL_CHANNEL_SCAN_STATE.
95 * Note that these states may also be present in STA
96 * side too when DFS support is present for a STA in IBSS mode.
97 */
98typedef enum eLimSmeStates {
99 eLIM_SME_OFFLINE_STATE,
100 eLIM_SME_IDLE_STATE,
101 eLIM_SME_SUSPEND_STATE,
102 eLIM_SME_WT_SCAN_STATE,
103 eLIM_SME_WT_JOIN_STATE,
104 eLIM_SME_WT_AUTH_STATE,
105 eLIM_SME_WT_ASSOC_STATE,
106 eLIM_SME_WT_REASSOC_STATE,
107 eLIM_SME_WT_REASSOC_LINK_FAIL_STATE,
108 eLIM_SME_JOIN_FAILURE_STATE,
109 eLIM_SME_ASSOCIATED_STATE,
110 eLIM_SME_REASSOCIATED_STATE,
111 eLIM_SME_LINK_EST_STATE,
112 eLIM_SME_LINK_EST_WT_SCAN_STATE,
113 eLIM_SME_WT_PRE_AUTH_STATE,
114 eLIM_SME_WT_DISASSOC_STATE,
115 eLIM_SME_WT_DEAUTH_STATE,
116 eLIM_SME_WT_START_BSS_STATE,
117 eLIM_SME_WT_STOP_BSS_STATE,
118 eLIM_SME_NORMAL_STATE,
119 eLIM_SME_CHANNEL_SCAN_STATE,
120 eLIM_SME_NORMAL_CHANNEL_SCAN_STATE
121} tLimSmeStates;
122
123/*
124 * MLM state definition.
125 * While these states are present on AP too when it is
126 * STA mode, per-STA MLM state exclusive to AP is:
127 * eLIM_MLM_WT_AUTH_FRAME3.
128 */
129typedef enum eLimMlmStates {
130 eLIM_MLM_OFFLINE_STATE,
131 eLIM_MLM_IDLE_STATE,
132 eLIM_MLM_WT_PROBE_RESP_STATE,
133 eLIM_MLM_PASSIVE_SCAN_STATE,
134 eLIM_MLM_WT_JOIN_BEACON_STATE,
135 eLIM_MLM_JOINED_STATE,
136 eLIM_MLM_BSS_STARTED_STATE,
137 eLIM_MLM_WT_AUTH_FRAME2_STATE,
138 eLIM_MLM_WT_AUTH_FRAME3_STATE,
139 eLIM_MLM_WT_AUTH_FRAME4_STATE,
140 eLIM_MLM_AUTH_RSP_TIMEOUT_STATE,
141 eLIM_MLM_AUTHENTICATED_STATE,
142 eLIM_MLM_WT_ASSOC_RSP_STATE,
143 eLIM_MLM_WT_REASSOC_RSP_STATE,
144 eLIM_MLM_ASSOCIATED_STATE,
145 eLIM_MLM_REASSOCIATED_STATE,
146 eLIM_MLM_LINK_ESTABLISHED_STATE,
147 eLIM_MLM_WT_ASSOC_CNF_STATE,
148 eLIM_MLM_LEARN_STATE,
149 eLIM_MLM_WT_ADD_BSS_RSP_STATE,
150 eLIM_MLM_WT_DEL_BSS_RSP_STATE,
151 eLIM_MLM_WT_ADD_BSS_RSP_ASSOC_STATE,
152 eLIM_MLM_WT_ADD_BSS_RSP_REASSOC_STATE,
153 eLIM_MLM_WT_ADD_BSS_RSP_PREASSOC_STATE,
154 eLIM_MLM_WT_ADD_STA_RSP_STATE,
155 eLIM_MLM_WT_DEL_STA_RSP_STATE,
156 /*
157 * MLM goes to this state when LIM initiates DELETE_STA
158 * as processing of Assoc req because the entry already exists.
159 * LIM comes out of this state when DELETE_STA response from
160 * HAL is received. LIM needs to maintain this state so that ADD_STA
161 * can be issued while processing DELETE_STA response from HAL.
162 */
163 eLIM_MLM_WT_ASSOC_DEL_STA_RSP_STATE,
164 eLIM_MLM_WT_SET_BSS_KEY_STATE,
165 eLIM_MLM_WT_SET_STA_KEY_STATE,
166 eLIM_MLM_WT_SET_STA_BCASTKEY_STATE,
167 eLIM_MLM_WT_SET_MIMOPS_STATE,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800168 eLIM_MLM_WT_ADD_BSS_RSP_FT_REASSOC_STATE,
169 eLIM_MLM_WT_FT_REASSOC_RSP_STATE,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800170 eLIM_MLM_P2P_LISTEN_STATE,
171} tLimMlmStates;
172
173/* 11h channel quiet states */
174
175/*
176 * This enum indicates in which state the device is in
177 * when it receives quiet element in beacon or probe-response.
178 * The default quiet state of the device is always INIT
179 * eLIM_QUIET_BEGIN - When Quiet period is started
180 * eLIM_QUIET_CHANGED - When Quiet period is updated
181 * eLIM_QUIET_RUNNING - Between two successive Quiet updates
182 * eLIM_QUIET_END - When quiet period ends
183 */
184typedef enum eLimQuietStates {
185 eLIM_QUIET_INIT,
186 eLIM_QUIET_BEGIN,
187 eLIM_QUIET_CHANGED,
188 eLIM_QUIET_RUNNING,
189 eLIM_QUIET_END
190} tLimQuietStates;
191
192/* 11h channel switch states */
193
194/*
195 * This enum indicates in which state the channel-swith
196 * is presently operating.
197 * eLIM_11H_CHANSW_INIT - Default state
198 * eLIM_11H_CHANSW_RUNNING - When channel switch is running
199 * eLIM_11H_CHANSW_END - After channel switch is complete
200 */
201typedef enum eLimDot11hChanSwStates {
202 eLIM_11H_CHANSW_INIT,
203 eLIM_11H_CHANSW_RUNNING,
204 eLIM_11H_CHANSW_END
205} tLimDot11hChanSwStates;
206
207
208/* WLAN_SUSPEND_LINK Related */
209typedef void (*SUSPEND_RESUME_LINK_CALLBACK)(tpAniSirGlobal pMac,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530210 QDF_STATUS status,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800211 uint32_t *data);
212
213/* LIM to HAL SCAN Management Message Interface states */
214typedef enum eLimHalScanState {
215 eLIM_HAL_IDLE_SCAN_STATE,
216 eLIM_HAL_INIT_SCAN_WAIT_STATE,
217 eLIM_HAL_START_SCAN_WAIT_STATE,
218 eLIM_HAL_END_SCAN_WAIT_STATE,
219 eLIM_HAL_FINISH_SCAN_WAIT_STATE,
220 eLIM_HAL_INIT_LEARN_WAIT_STATE,
221 eLIM_HAL_START_LEARN_WAIT_STATE,
222 eLIM_HAL_END_LEARN_WAIT_STATE,
223 eLIM_HAL_FINISH_LEARN_WAIT_STATE,
224 eLIM_HAL_SCANNING_STATE,
225/* WLAN_SUSPEND_LINK Related */
226 eLIM_HAL_SUSPEND_LINK_WAIT_STATE,
227 eLIM_HAL_SUSPEND_LINK_STATE,
228 eLIM_HAL_RESUME_LINK_WAIT_STATE,
229/* end WLAN_SUSPEND_LINK Related */
230} tLimLimHalScanState;
231
232/* MLM Req/Cnf structure definitions */
233typedef struct sLimMlmAuthReq {
234 tSirMacAddr peerMacAddr;
235 tAniAuthType authType;
236 uint32_t authFailureTimeout;
237 uint8_t sessionId;
238} tLimMlmAuthReq, *tpLimMlmAuthReq;
239
240typedef struct sLimMlmJoinReq {
241 uint32_t joinFailureTimeout;
242 tSirMacRateSet operationalRateSet;
243 uint8_t sessionId;
244 tSirBssDescription bssDescription;
245} tLimMlmJoinReq, *tpLimMlmJoinReq;
246
247typedef struct sLimMlmScanReq {
248 tSirBssType bssType;
249 tSirMacAddr bssId;
250 tSirMacSSid ssId[SIR_SCAN_MAX_NUM_SSID];
251 tSirScanType scanType;
252 uint32_t minChannelTime;
253 uint32_t maxChannelTime;
254 uint32_t dot11mode;
255 /* Number of SSIDs to scan(send Probe request) */
256 uint8_t numSsid;
257
258 bool p2pSearch;
259 uint16_t uIEFieldLen;
260 uint16_t uIEFieldOffset;
261
262 uint8_t sessionId;
263 /* channelList MUST be the last field of this structure */
264 tSirChannelList channelList;
265 /*-----------------------------
266 tLimMlmScanReq....
267 -----------------------------
268 uIEFiledLen
269 -----------------------------
270 uIEFiledOffset ----+
271 ----------------------------- |
272 channelList.numChannels |
273 ----------------------------- |
274 ... variable size up to |
275 channelNumber[numChannels-1] |
276 This can be zero, if |
277 numChannel is zero. |
278 ----------------------------- <--+
279 ... variable size uIEFiled
280 up to uIEFieldLen (can be 0)
281 -----------------------------*/
282} tLimMlmScanReq, *tpLimMlmScanReq;
283
284typedef struct tLimScanResultNode tLimScanResultNode;
285struct tLimScanResultNode {
286 tLimScanResultNode *next;
287 tSirBssDescription bssDescription;
288};
289
290#ifdef FEATURE_OEM_DATA_SUPPORT
291
292#ifndef OEM_DATA_REQ_SIZE
293#define OEM_DATA_REQ_SIZE 280
294#endif
295#ifndef OEM_DATA_RSP_SIZE
296#define OEM_DATA_RSP_SIZE 1724
297#endif
298
299/* OEM Data related structure definitions */
300typedef struct sLimMlmOemDataReq {
Anurag Chouhan6d760662016-02-20 16:05:43 +0530301 struct qdf_mac_addr selfMacAddr;
Krishna Kumaar Natarajan9ac8efd2015-11-20 13:40:24 -0800302 uint8_t data_len;
303 uint8_t *data;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800304} tLimMlmOemDataReq, *tpLimMlmOemDataReq;
305
306typedef struct sLimMlmOemDataRsp {
Krishna Kumaar Natarajan4e9cf392015-11-20 13:35:05 -0800307 bool target_rsp;
Krishna Kumaar Natarajan608291e2015-12-14 18:17:27 -0800308 uint32_t rsp_len;
309 uint8_t *oem_data_rsp;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800310} tLimMlmOemDataRsp, *tpLimMlmOemDataRsp;
311#endif
312
313/* Pre-authentication structure definition */
314typedef struct tLimPreAuthNode {
315 struct tLimPreAuthNode *next;
316 tSirMacAddr peerMacAddr;
317 tAniAuthType authType;
318 tLimMlmStates mlmState;
319 uint8_t authNodeIdx;
320 uint8_t challengeText[SIR_MAC_AUTH_CHALLENGE_LENGTH];
321 uint8_t fTimerStarted:1;
322 uint8_t fSeen:1;
323 uint8_t fFree:1;
324 uint8_t rsvd:5;
325 TX_TIMER timer;
326 uint16_t seq_num;
Anurag Chouhan6d760662016-02-20 16:05:43 +0530327 unsigned long timestamp;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800328} tLimPreAuthNode, *tpLimPreAuthNode;
329
330/* Pre-authentication table definition */
331typedef struct tLimPreAuthTable {
332 uint32_t numEntry;
Naveen Rawate6ddcaa2016-02-05 16:50:18 -0800333 tLimPreAuthNode **pTable;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800334} tLimPreAuthTable, *tpLimPreAuthTable;
335
336/* / Per STA context structure definition */
337typedef struct sLimMlmStaContext {
338 tLimMlmStates mlmState;
339 tAniAuthType authType;
340 uint16_t listenInterval;
341 tSirMacCapabilityInfo capabilityInfo;
342 tSirMacPropRateSet propRateSet;
343 tSirMacReasonCodes disassocReason;
344 uint16_t cleanupTrigger;
345
346 tSirResultCodes resultCode;
347 uint16_t protStatusCode;
348
349 uint8_t subType:1; /* Indicates ASSOC (0) or REASSOC (1) */
350 uint8_t updateContext:1;
351 uint8_t schClean:1;
352 /* 802.11n HT Capability in Station: Enabled 1 or DIsabled 0 */
353 uint8_t htCapability:1;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800354 uint8_t vhtCapability:1;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800355} tLimMlmStaContext, *tpLimMlmStaContext;
356
357/* Structure definition to hold deferred messages queue parameters */
358typedef struct sLimDeferredMsgQParams {
359 tSirMsgQ deferredQueue[MAX_DEFERRED_QUEUE_LEN];
360 uint16_t size;
361 uint16_t read;
362 uint16_t write;
363} tLimDeferredMsgQParams, *tpLimDeferredMsgQParams;
364
365typedef struct sCfgProtection {
366 uint32_t overlapFromlla:1;
367 uint32_t overlapFromllb:1;
368 uint32_t overlapFromllg:1;
369 uint32_t overlapHt20:1;
370 uint32_t overlapNonGf:1;
371 uint32_t overlapLsigTxop:1;
372 uint32_t overlapRifs:1;
373 uint32_t overlapOBSS:1; /* added for obss */
374 uint32_t fromlla:1;
375 uint32_t fromllb:1;
376 uint32_t fromllg:1;
377 uint32_t ht20:1;
378 uint32_t nonGf:1;
379 uint32_t lsigTxop:1;
380 uint32_t rifs:1;
381 uint32_t obss:1; /* added for Obss */
382} tCfgProtection, *tpCfgProtection;
383
384typedef enum eLimProtStaCacheType {
385 eLIM_PROT_STA_CACHE_TYPE_INVALID,
386 eLIM_PROT_STA_CACHE_TYPE_llB,
387 eLIM_PROT_STA_CACHE_TYPE_llG,
388 eLIM_PROT_STA_CACHE_TYPE_HT20
389} tLimProtStaCacheType;
390
391typedef struct sCacheParams {
392 uint8_t active;
393 tSirMacAddr addr;
394 tLimProtStaCacheType protStaCacheType;
395
396} tCacheParams, *tpCacheParams;
397
398#define LIM_PROT_STA_OVERLAP_CACHE_SIZE HAL_NUM_ASSOC_STA
399#define LIM_PROT_STA_CACHE_SIZE HAL_NUM_ASSOC_STA
400
401typedef struct sLimProtStaParams {
402 uint8_t numSta;
403 uint8_t protectionEnabled;
404} tLimProtStaParams, *tpLimProtStaParams;
405
406typedef struct sLimNoShortParams {
407 uint8_t numNonShortPreambleSta;
408 tCacheParams staNoShortCache[LIM_PROT_STA_CACHE_SIZE];
409} tLimNoShortParams, *tpLimNoShortParams;
410
411typedef struct sLimNoShortSlotParams {
412 uint8_t numNonShortSlotSta;
413 tCacheParams staNoShortSlotCache[LIM_PROT_STA_CACHE_SIZE];
414} tLimNoShortSlotParams, *tpLimNoShortSlotParams;
415
416typedef struct tLimIbssPeerNode tLimIbssPeerNode;
417struct tLimIbssPeerNode {
418 tLimIbssPeerNode *next;
419 tSirMacAddr peerMacAddr;
420 uint8_t extendedRatesPresent:1;
421 uint8_t edcaPresent:1;
422 uint8_t wmeEdcaPresent:1;
423 uint8_t wmeInfoPresent:1;
424 uint8_t htCapable:1;
425 uint8_t vhtCapable:1;
426 uint8_t rsvd:2;
427 uint8_t htSecondaryChannelOffset;
428 tSirMacCapabilityInfo capabilityInfo;
429 tSirMacRateSet supportedRates;
430 tSirMacRateSet extendedRates;
431 uint8_t supportedMCSSet[SIZE_OF_SUPPORTED_MCS_SET];
432 tSirMacEdcaParamSetIE edcaParams;
433 uint8_t erpIePresent;
434
435 /* HT Capabilities of IBSS Peer */
436 uint8_t htGreenfield;
437 uint8_t htShortGI40Mhz;
438 uint8_t htShortGI20Mhz;
439
440 /* DSSS/CCK at 40 MHz: Enabled 1 or Disabled */
441 uint8_t htDsssCckRate40MHzSupport;
442
443 /* MIMO Power Save */
444 tSirMacHTMIMOPowerSaveState htMIMOPSState;
445
446 /* */
447 /* A-MPDU Density */
448 /* 000 - No restriction */
449 /* 001 - 1/8 usec */
450 /* 010 - 1/4 usec */
451 /* 011 - 1/2 usec */
452 /* 100 - 1 usec */
453 /* 101 - 2 usec */
454 /* 110 - 4 usec */
455 /* 111 - 8 usec */
456 /* */
457 uint8_t htAMpduDensity;
458
459 /* Maximum Rx A-MPDU factor */
460 uint8_t htMaxRxAMpduFactor;
461
462 /* Set to 0 for 3839 octets */
463 /* Set to 1 for 7935 octets */
464 uint8_t htMaxAmsduLength;
465
466 /* */
467 /* Recommended Tx Width Set */
468 /* 0 - use 20 MHz channel (control channel) */
469 /* 1 - use 40 Mhz channel */
470 /* */
471 uint8_t htSupportedChannelWidthSet;
472
473 uint8_t htLdpcCapable;
474
475 uint8_t beaconHBCount;
476 uint8_t heartbeatFailure;
477
478 uint8_t *beacon; /* Hold beacon to be sent to HDD/CSR */
479 uint16_t beaconLen;
480
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800481 tDot11fIEVHTCaps VHTCaps;
482 uint8_t vhtSupportedChannelWidthSet;
483 uint8_t vhtBeamFormerCapable;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800484 /*
485 * Peer Atim Info
486 */
487 uint8_t atimIePresent;
488 uint32_t peerAtimWindowLength;
489};
490
491/* Enums used for channel switching. */
492typedef enum eLimChannelSwitchState {
493 eLIM_CHANNEL_SWITCH_IDLE,
494 eLIM_CHANNEL_SWITCH_PRIMARY_ONLY,
495 eLIM_CHANNEL_SWITCH_PRIMARY_AND_SECONDARY
496} tLimChannelSwitchState;
497
498/* Channel Switch Info */
499typedef struct sLimChannelSwitchInfo {
500 tLimChannelSwitchState state;
501 uint8_t primaryChannel;
502 uint8_t ch_center_freq_seg0;
503 uint8_t ch_center_freq_seg1;
Kiran Kumar Lokere999e58c2016-01-07 02:18:39 -0800504 uint8_t sec_ch_offset;
Kiran Kumar Lokere13644672016-02-29 15:40:10 -0800505 enum phy_ch_width ch_width;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800506 int8_t switchCount;
507 uint32_t switchTimeoutValue;
508 uint8_t switchMode;
509} tLimChannelSwitchInfo, *tpLimChannelSwitchInfo;
510
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800511typedef struct sLimOperatingModeInfo {
512 uint8_t present;
513 uint8_t chanWidth:2;
514 uint8_t reserved:2;
515 uint8_t rxNSS:3;
516 uint8_t rxNSSType:1;
517} tLimOperatingModeInfo, *tpLimOperatingModeInfo;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800518
519typedef struct sLimWiderBWChannelSwitch {
520 uint8_t newChanWidth;
521 uint8_t newCenterChanFreq0;
522 uint8_t newCenterChanFreq1;
523} tLimWiderBWChannelSwitchInfo, *tpLimWiderBWChannelSwitchInfo;
524
525/* Enums used when stopping the Tx. */
526typedef enum eLimQuietTxMode {
527 /* Stop/resume transmission of all stations,Uses the global flag */
528 eLIM_TX_ALL = 0,
529 /*
530 * Stops/resumes the transmission of specific stations identified
531 * by staId.
532 */
533 eLIM_TX_STA,
534 /* Stops/resumes the transmission of all the packets in BSS */
535 eLIM_TX_BSS,
536 /*
537 * Stops/resumes the transmission of all packets except beacons in BSS
538 * This is used when radar is detected in the current operating channel.
539 * Beacon has to be sent to notify the stations associated about the
540 * scheduled channel switch
541 */
542 eLIM_TX_BSS_BUT_BEACON
543} tLimQuietTxMode;
544
545typedef enum eLimControlTx {
546 eLIM_RESUME_TX = 0,
547 eLIM_STOP_TX
548} tLimControlTx;
549
550/* -------------------------------------------------------------------- */
551
552typedef struct sLimTspecInfo {
553 /* 0==free, else used */
554 uint8_t inuse;
555 /* index in list */
556 uint8_t idx;
557 tSirMacAddr staAddr;
558 uint16_t assocId;
559 tSirMacTspecIE tspec;
560 /* number of Tclas elements */
561 uint8_t numTclas;
562 tSirTclasInfo tclasInfo[SIR_MAC_TCLASIE_MAXNUM];
563 uint8_t tclasProc;
564 /* tclassProc is valid only if this is set to 1. */
565 uint8_t tclasProcPresent:1;
Anurag Chouhan6d760662016-02-20 16:05:43 +0530566} qdf_packed tLimTspecInfo, *tpLimTspecInfo;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800567
568typedef struct sLimAdmitPolicyInfo {
569 /* admit control policy type */
570 uint8_t type;
571 /* oversubscription factor : 0 means nothing is allowed */
572 uint8_t bw_factor;
573 /* valid only when 'type' is set BW_FACTOR */
574} tLimAdmitPolicyInfo, *tpLimAdmitPolicyInfo;
575
576typedef enum eLimWscEnrollState {
577 eLIM_WSC_ENROLL_NOOP,
578 eLIM_WSC_ENROLL_BEGIN,
579 eLIM_WSC_ENROLL_IN_PROGRESS,
580 eLIM_WSC_ENROLL_END
581} tLimWscEnrollState;
582
583#define WSC_PASSWD_ID_PUSH_BUTTON (0x0004)
584
585typedef struct sLimWscIeInfo {
586 bool apSetupLocked;
587 bool selectedRegistrar;
588 uint16_t selectedRegistrarConfigMethods;
589 tLimWscEnrollState wscEnrollmentState;
590 tLimWscEnrollState probeRespWscEnrollmentState;
591 uint8_t reqType;
592 uint8_t respType;
593} tLimWscIeInfo, *tpLimWscIeInfo;
594
595/* maximum number of tspec's supported */
596#define LIM_NUM_TSPEC_MAX 15
597
598/* structure to hold all 11h specific data */
599typedef struct sLimSpecMgmtInfo {
600 tLimQuietStates quietState;
601 uint32_t quietCount;
602 /* This is in units of system TICKS */
603 uint32_t quietDuration;
604 /* This is in units of TU, for over the air transmission */
605 uint32_t quietDuration_TU;
606 /* After this timeout, actual quiet starts */
607 uint32_t quietTimeoutValue;
608 /* Used on AP, if quiet is enabled during learning */
609 bool fQuietEnabled;
610 tLimDot11hChanSwStates dot11hChanSwState;
611 /* Radar detected in cur oper chan on AP */
612 bool fRadarDetCurOperChan;
613 /* Whether radar interrupt has been configured */
614 bool fRadarIntrConfigured;
615} tLimSpecMgmtInfo, *tpLimSpecMgmtInfo;
616
617#ifdef FEATURE_WLAN_TDLS
618/*
619 * Peer info needed for TDLS setup..
620 */
621typedef struct tLimTDLSPeerSta {
622 struct tLimTDLSPeerSta *next;
623 uint8_t dialog;
624 tSirMacAddr peerMac;
625 tSirMacCapabilityInfo capabilityInfo;
626 tSirMacRateSet supportedRates;
627 tSirMacRateSet extendedRates;
628 tSirMacQosCapabilityStaIE qosCaps;
629 tSirMacEdcaParamSetIE edcaParams;
630 uint8_t mcsSet[SIZE_OF_SUPPORTED_MCS_SET];
631 uint8_t tdls_bIsResponder;
632 /* HT Capabilties */
633 tDot11fIEHTCaps tdlsPeerHTCaps;
634 tDot11fIEExtCap tdlsPeerExtCaps;
635 uint8_t tdls_flags;
636 uint8_t tdls_link_state;
637 uint8_t tdls_prev_link_state;
638 uint8_t tdls_sessionId;
639 uint8_t ExtRatesPresent;
640 TX_TIMER gLimTdlsLinkSetupRspTimeoutTimer;
641 TX_TIMER gLimTdlsLinkSetupCnfTimeoutTimer;
642} tLimTdlsLinkSetupPeer, *tpLimTdlsLinkSetupPeer;
643
644typedef struct tLimTdlsLinkSetupInfo {
645 tLimTdlsLinkSetupPeer *tdlsLinkSetupList;
646 uint8_t num_tdls_peers;
647 uint8_t tdls_flags;
648 uint8_t tdls_state;
649 uint8_t tdls_prev_state;
650} tLimTdlsLinkSetupInfo, *tpLimTdlsLinkSetupInfo;
651
652typedef enum tdlsLinkMode {
653 TDLS_LINK_MODE_BG,
654 TDLS_LINK_MODE_N,
655 TDLS_LINK_MODE_AC,
656 TDLS_LINK_MODE_NONE
657} eLimTdlsLinkMode;
658#endif /* FEATURE_WLAN_TDLS */
659
660#endif