blob: 194af13edd0fd8bca1a147ebd8c9df19fff6fece [file] [log] [blame]
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001/*
Prashanth Bhatta9e143052015-12-04 11:56:47 -08002 * Copyright (c) 2012-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 * DOC: wlan_hdd_cfg.c
30 *
31 * WLAN Host Device Driver configuration interface implementation
32 */
33
34/* Include Files */
35
36#include <linux/firmware.h>
37#include <linux/string.h>
38#include <wlan_hdd_includes.h>
39#include <wlan_hdd_main.h>
40#include <wlan_hdd_assoc.h>
41#include <wlan_hdd_cfg.h>
42#include <linux/string.h>
43#include <cdf_types.h>
44#include <csr_api.h>
45#include <wlan_hdd_misc.h>
46#include <wlan_hdd_napi.h>
47
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080048static void
49cb_notify_set_roam_prefer5_g_hz(hdd_context_t *pHddCtx, unsigned long notifyId)
50{
51 sme_update_roam_prefer5_g_hz(pHddCtx->hHal,
52 pHddCtx->config->nRoamPrefer5GHz);
53}
54
55static void
56cb_notify_set_roam_rssi_diff(hdd_context_t *pHddCtx, unsigned long notifyId)
57{
58 sme_update_roam_rssi_diff(pHddCtx->hHal,
59 0, pHddCtx->config->RoamRssiDiff);
60}
61
62static void
63cb_notify_set_fast_transition_enabled(hdd_context_t *pHddCtx,
64 unsigned long notifyId)
65{
66 sme_update_fast_transition_enabled(pHddCtx->hHal,
67 pHddCtx->config->
68 isFastTransitionEnabled);
69}
70
71static void
72cb_notify_set_roam_intra_band(hdd_context_t *pHddCtx, unsigned long notifyId)
73{
74 sme_set_roam_intra_band(pHddCtx->hHal, pHddCtx->config->nRoamIntraBand);
75}
76
77static void cb_notify_set_wes_mode(hdd_context_t *pHddCtx, unsigned long notifyId)
78{
79 /* At the point this routine is called, the value in the hdd config
80 table has already been updated */
81 sme_update_wes_mode(pHddCtx->hHal, pHddCtx->config->isWESModeEnabled, 0);
82}
83
84static void
85cb_notify_set_roam_scan_n_probes(hdd_context_t *pHddCtx, unsigned long notifyId)
86{
87 sme_update_roam_scan_n_probes(pHddCtx->hHal, 0, pHddCtx->config->nProbes);
88}
89
90static void
91cb_notify_set_roam_scan_home_away_time(hdd_context_t *pHddCtx, unsigned long notifyId)
92{
93 sme_update_roam_scan_home_away_time(pHddCtx->hHal, 0,
94 pHddCtx->config->nRoamScanHomeAwayTime,
95 true);
96}
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080097
98#ifdef FEATURE_WLAN_OKC
99static void
100cb_notify_set_okc_feature_enabled(hdd_context_t *pHddCtx, unsigned long notifyId)
101{
102 /* At the point this routine is called, the value in the hdd config
103 table has already been updated */
104}
105#endif
106
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800107static void
108notify_is_fast_roam_ini_feature_enabled(hdd_context_t *pHddCtx,
109 unsigned long notifyId)
110{
111 /* At the point this routine is called, the value in the hdd config
112 table has already been updated */
113 sme_update_is_fast_roam_ini_feature_enabled(pHddCtx->hHal, 0,
114 pHddCtx->config->
115 isFastRoamIniFeatureEnabled);
116}
117
118static void
119notify_is_mawc_ini_feature_enabled(hdd_context_t *pHddCtx, unsigned long notifyId)
120{
121 /* At the point this routine is called, the value in the hdd config
122 table has already been updated */
123 sme_update_is_mawc_ini_feature_enabled(pHddCtx->hHal,
124 pHddCtx->config->MAWCEnabled);
125}
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800126
127#ifdef FEATURE_WLAN_ESE
128static void
129cb_notify_set_ese_feature_enabled(hdd_context_t *pHddCtx, unsigned long notifyId)
130{
131 /* At the point this routine is called, the value in the hdd config
132 table has already been updated */
133 sme_update_is_ese_feature_enabled(pHddCtx->hHal, 0,
134 pHddCtx->config->isEseIniFeatureEnabled);
135}
136#endif
137
138static void
139cb_notify_set_fw_rssi_monitoring(hdd_context_t *pHddCtx, unsigned long notifyId)
140{
141 /* At the point this routine is called, the value in the hdd config
142 table has already been updated */
143 sme_update_config_fw_rssi_monitoring(pHddCtx->hHal,
144 pHddCtx->config->
145 fEnableFwRssiMonitoring);
146}
147
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800148static void cb_notify_set_opportunistic_scan_threshold_diff(hdd_context_t *pHddCtx,
149 unsigned long notifyId)
150{
151 /* At the point this routine is called, the value in the hdd config
152 table has already been updated */
153 sme_set_roam_opportunistic_scan_threshold_diff(pHddCtx->hHal, 0,
154 pHddCtx->config->
155 nOpportunisticThresholdDiff);
156}
157
158static void cb_notify_set_roam_rescan_rssi_diff(hdd_context_t *pHddCtx,
159 unsigned long notifyId)
160{
161 /* At the point this routine is called, the value in the hdd config
162 table has already been updated */
163 sme_set_roam_rescan_rssi_diff(pHddCtx->hHal,
164 0, pHddCtx->config->nRoamRescanRssiDiff);
165}
166
167static void
168cb_notify_set_neighbor_lookup_rssi_threshold(hdd_context_t *pHddCtx,
169 unsigned long notifyId)
170{
171 /* At the point this routine is called, the value in the hdd config
172 table has already been updated */
173 sme_set_neighbor_lookup_rssi_threshold(pHddCtx->hHal, 0,
174 pHddCtx->config->
175 nNeighborLookupRssiThreshold);
176}
177
178static void
179cb_notify_set_delay_before_vdev_stop(hdd_context_t *hdd_ctx,
180 unsigned long notify_id)
181{
182 /*
183 * At the point this routine is called, the value in the cfg_ini
184 * table has already been updated
185 */
186 sme_set_delay_before_vdev_stop(hdd_ctx->hHal, 0,
187 hdd_ctx->config->delay_before_vdev_stop);
188}
189
190static void
191cb_notify_set_neighbor_scan_period(hdd_context_t *pHddCtx, unsigned long notifyId)
192{
193 /* At the point this routine is called, the value in the hdd config
194 table has already been updated */
195 sme_set_neighbor_scan_period(pHddCtx->hHal, 0,
196 pHddCtx->config->nNeighborScanPeriod);
197}
198
199static void
200cb_notify_set_neighbor_results_refresh_period(hdd_context_t *pHddCtx,
201 unsigned long notifyId)
202{
203 /* At the point this routine is called, the value in the hdd config
204 table has already been updated */
205 sme_set_neighbor_scan_refresh_period(pHddCtx->hHal, 0,
206 pHddCtx->config->
207 nNeighborResultsRefreshPeriod);
208}
209
210static void
211cb_notify_set_empty_scan_refresh_period(hdd_context_t *pHddCtx,
212 unsigned long notifyId)
213{
214 /* At the point this routine is called, the value in the hdd config
215 table has already been updated */
216 sme_update_empty_scan_refresh_period(pHddCtx->hHal, 0,
217 pHddCtx->config->
218 nEmptyScanRefreshPeriod);
219}
220
221static void
222cb_notify_set_neighbor_scan_min_chan_time(hdd_context_t *pHddCtx,
223 unsigned long notifyId)
224{
225 /* At the point this routine is called, the value in the hdd config
226 table has already been updated */
227 sme_set_neighbor_scan_min_chan_time(pHddCtx->hHal,
228 pHddCtx->config->
229 nNeighborScanMinChanTime, 0);
230}
231
232static void
233cb_notify_set_neighbor_scan_max_chan_time(hdd_context_t *pHddCtx,
234 unsigned long notifyId)
235{
236 sme_set_neighbor_scan_max_chan_time(pHddCtx->hHal, 0,
237 pHddCtx->config->
238 nNeighborScanMaxChanTime);
239}
240
241static void cb_notify_set_roam_bmiss_first_bcnt(hdd_context_t *pHddCtx,
242 unsigned long notifyId)
243{
244 /* At the point this routine is called, the value in the hdd config
245 table has already been updated */
246 sme_set_roam_bmiss_first_bcnt(pHddCtx->hHal,
247 0, pHddCtx->config->nRoamBmissFirstBcnt);
248}
249
250static void cb_notify_set_roam_bmiss_final_bcnt(hdd_context_t *pHddCtx,
251 unsigned long notifyId)
252{
253 sme_set_roam_bmiss_final_bcnt(pHddCtx->hHal, 0,
254 pHddCtx->config->nRoamBmissFinalBcnt);
255}
256
257static void cb_notify_set_roam_beacon_rssi_weight(hdd_context_t *pHddCtx,
258 unsigned long notifyId)
259{
260 sme_set_roam_beacon_rssi_weight(pHddCtx->hHal, 0,
261 pHddCtx->config->nRoamBeaconRssiWeight);
262}
263
264static void
265cb_notify_set_dfs_scan_mode(hdd_context_t *pHddCtx, unsigned long notifyId)
266{
267 /* At the point this routine is called, the value in the hdd config
268 table has already been updated */
269 sme_update_dfs_scan_mode(pHddCtx->hHal, 0,
270 pHddCtx->config->allowDFSChannelRoam);
271}
272
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800273static void cb_notify_set_enable_ssr(hdd_context_t *pHddCtx,
274 unsigned long notifyId)
275{
276 sme_update_enable_ssr(pHddCtx->hHal, pHddCtx->config->enableSSR);
277}
278
279static void cb_notify_set_g_sap_preferred_chan_location(hdd_context_t *pHddCtx,
280 unsigned long notifyId)
281{
282 wlansap_set_dfs_preferred_channel_location(pHddCtx->hHal,
283 pHddCtx->config->
284 gSapPreferredChanLocation);
285}
286static void ch_notify_set_g_disable_dfs_japan_w53(hdd_context_t *pHddCtx,
287 unsigned long notifyId)
288{
289 wlansap_set_dfs_restrict_japan_w53(pHddCtx->hHal,
290 pHddCtx->config->
291 gDisableDfsJapanW53);
292}
293static void
294cb_notify_update_roam_scan_offload_enabled(hdd_context_t *pHddCtx,
295 unsigned long notifyId)
296{
297 sme_update_roam_scan_offload_enabled(pHddCtx->hHal,
298 pHddCtx->config->
299 isRoamOffloadScanEnabled);
300 if (0 == pHddCtx->config->isRoamOffloadScanEnabled) {
301 pHddCtx->config->bFastRoamInConIniFeatureEnabled = 0;
302 sme_update_enable_fast_roam_in_concurrency(pHddCtx->hHal,
303 pHddCtx->config->
304 bFastRoamInConIniFeatureEnabled);
305 }
306}
307
308static void
309cb_notify_set_enable_fast_roam_in_concurrency(hdd_context_t *pHddCtx,
310 unsigned long notifyId)
311{
312 sme_update_enable_fast_roam_in_concurrency(pHddCtx->hHal,
313 pHddCtx->config->
314 bFastRoamInConIniFeatureEnabled);
315}
316
317/**
318 * cb_notify_set_roam_scan_hi_rssi_scan_params() - configure hi rssi
319 * scan params from cfg to sme.
320 * @hdd_ctx: HDD context data structure
321 * @notify_id: Identifies 1 of the 4 parameters to be modified
322 *
323 * Picks up the value from hdd configuration and passes it to SME.
324 * Return: void
325 */
326
327static void
328cb_notify_set_roam_scan_hi_rssi_scan_params(hdd_context_t *hdd_ctx,
329 unsigned long notify_id)
330{
331 int32_t val;
332
333 if (wlan_hdd_validate_context(hdd_ctx)) {
334 hddLog(LOGE, FL("HDD context is invalid"));
335 return;
336 }
337
338 switch (notify_id) {
339 case eCSR_HI_RSSI_SCAN_MAXCOUNT_ID:
340 val = hdd_ctx->config->nhi_rssi_scan_max_count;
341 break;
342
343 case eCSR_HI_RSSI_SCAN_RSSI_DELTA_ID:
344 val = hdd_ctx->config->nhi_rssi_scan_rssi_delta;
345 break;
346
347 case eCSR_HI_RSSI_SCAN_DELAY_ID:
348 val = hdd_ctx->config->nhi_rssi_scan_delay;
349 break;
350
351 case eCSR_HI_RSSI_SCAN_RSSI_UB_ID:
352 val = hdd_ctx->config->nhi_rssi_scan_rssi_ub;
353 break;
354
355 default:
356 return;
357 }
358
359 sme_update_roam_scan_hi_rssi_scan_params(hdd_ctx->hHal, 0,
360 notify_id, val);
361}
362
363
364REG_TABLE_ENTRY g_registry_table[] = {
365 REG_VARIABLE(CFG_RTS_THRESHOLD_NAME, WLAN_PARAM_Integer,
366 struct hdd_config, RTSThreshold,
367 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
368 CFG_RTS_THRESHOLD_DEFAULT,
369 CFG_RTS_THRESHOLD_MIN,
370 CFG_RTS_THRESHOLD_MAX),
371
372 REG_VARIABLE(CFG_FRAG_THRESHOLD_NAME, WLAN_PARAM_Integer,
373 struct hdd_config, FragmentationThreshold,
374 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
375 CFG_FRAG_THRESHOLD_DEFAULT,
376 CFG_FRAG_THRESHOLD_MIN,
377 CFG_FRAG_THRESHOLD_MAX),
378
379 REG_VARIABLE(CFG_OPERATING_CHANNEL_NAME, WLAN_PARAM_Integer,
380 struct hdd_config, OperatingChannel,
381 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
382 CFG_OPERATING_CHANNEL_DEFAULT,
383 CFG_OPERATING_CHANNEL_MIN,
384 CFG_OPERATING_CHANNEL_MAX),
385
386 REG_VARIABLE(CFG_SHORT_SLOT_TIME_ENABLED_NAME, WLAN_PARAM_Integer,
387 struct hdd_config, ShortSlotTimeEnabled,
388 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
389 CFG_SHORT_SLOT_TIME_ENABLED_DEFAULT,
390 CFG_SHORT_SLOT_TIME_ENABLED_MIN,
391 CFG_SHORT_SLOT_TIME_ENABLED_MAX),
392
393 REG_VARIABLE(CFG_11D_SUPPORT_ENABLED_NAME, WLAN_PARAM_Integer,
394 struct hdd_config, Is11dSupportEnabled,
395 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
396 CFG_11D_SUPPORT_ENABLED_DEFAULT,
397 CFG_11D_SUPPORT_ENABLED_MIN,
398 CFG_11D_SUPPORT_ENABLED_MAX),
399
400 REG_VARIABLE(CFG_11H_SUPPORT_ENABLED_NAME, WLAN_PARAM_Integer,
401 struct hdd_config, Is11hSupportEnabled,
402 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
403 CFG_11H_SUPPORT_ENABLED_DEFAULT,
404 CFG_11H_SUPPORT_ENABLED_MIN,
405 CFG_11H_SUPPORT_ENABLED_MAX),
406
407 REG_VARIABLE(CFG_COUNTRY_CODE_PRIORITY_NAME, WLAN_PARAM_Integer,
408 struct hdd_config, fSupplicantCountryCodeHasPriority,
409 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
410 CFG_COUNTRY_CODE_PRIORITY_DEFAULT,
411 CFG_COUNTRY_CODE_PRIORITY_MIN,
412 CFG_COUNTRY_CODE_PRIORITY_MAX),
413
414 REG_VARIABLE(CFG_HEARTBEAT_THRESH_24_NAME, WLAN_PARAM_Integer,
415 struct hdd_config, HeartbeatThresh24,
416 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
417 CFG_HEARTBEAT_THRESH_24_DEFAULT,
418 CFG_HEARTBEAT_THRESH_24_MIN,
419 CFG_HEARTBEAT_THRESH_24_MAX),
420
421 REG_VARIABLE_STRING(CFG_POWER_USAGE_NAME, WLAN_PARAM_String,
422 struct hdd_config, PowerUsageControl,
423 VAR_FLAGS_OPTIONAL,
424 (void *)CFG_POWER_USAGE_DEFAULT),
425
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800426 REG_VARIABLE(CFG_ENABLE_IMPS_NAME, WLAN_PARAM_Integer,
427 struct hdd_config, fIsImpsEnabled,
428 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
429 CFG_ENABLE_IMPS_DEFAULT,
430 CFG_ENABLE_IMPS_MIN,
431 CFG_ENABLE_IMPS_MAX),
432
433 REG_VARIABLE(CFG_ENABLE_PS_NAME, WLAN_PARAM_Integer,
434 struct hdd_config, is_ps_enabled,
435 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
436 CFG_ENABLE_PS_DEFAULT,
437 CFG_ENABLE_PS_MIN,
438 CFG_ENABLE_PS_MAX),
439
440 REG_VARIABLE(CFG_BMPS_MINIMUM_LI_NAME, WLAN_PARAM_Integer,
441 struct hdd_config, nBmpsMinListenInterval,
442 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
443 CFG_BMPS_MINIMUM_LI_DEFAULT,
444 CFG_BMPS_MINIMUM_LI_MIN,
445 CFG_BMPS_MINIMUM_LI_MAX),
446
447 REG_VARIABLE(CFG_BMPS_MAXIMUM_LI_NAME, WLAN_PARAM_Integer,
448 struct hdd_config, nBmpsMaxListenInterval,
449 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
450 CFG_BMPS_MAXIMUM_LI_DEFAULT,
451 CFG_BMPS_MAXIMUM_LI_MIN,
452 CFG_BMPS_MAXIMUM_LI_MAX),
453
454 REG_VARIABLE(CFG_BMPS_MODERATE_LI_NAME, WLAN_PARAM_Integer,
455 struct hdd_config, nBmpsModListenInterval,
456 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
457 CFG_BMPS_MODERATE_LI_DEFAULT,
458 CFG_BMPS_MODERATE_LI_MIN,
459 CFG_BMPS_MODERATE_LI_MAX),
460
461 REG_VARIABLE(CFG_DOT11_MODE_NAME, WLAN_PARAM_Integer,
462 struct hdd_config, dot11Mode,
463 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
464 CFG_DOT11_MODE_DEFAULT,
465 CFG_DOT11_MODE_MIN,
466 CFG_DOT11_MODE_MAX),
467
468 REG_VARIABLE(CFG_CHANNEL_BONDING_MODE_24GHZ_NAME, WLAN_PARAM_Integer,
469 struct hdd_config, nChannelBondingMode24GHz,
470 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
471 CFG_CHANNEL_BONDING_MODE_DEFAULT,
472 CFG_CHANNEL_BONDING_MODE_MIN,
473 CFG_CHANNEL_BONDING_MODE_MAX),
474
475 REG_VARIABLE(CFG_CHANNEL_BONDING_MODE_5GHZ_NAME, WLAN_PARAM_Integer,
476 struct hdd_config, nChannelBondingMode5GHz,
477 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
478 CFG_CHANNEL_BONDING_MODE_DEFAULT,
479 CFG_CHANNEL_BONDING_MODE_MIN,
480 CFG_CHANNEL_BONDING_MODE_MAX),
481
482 REG_VARIABLE(CFG_MAX_RX_AMPDU_FACTOR_NAME, WLAN_PARAM_Integer,
483 struct hdd_config, MaxRxAmpduFactor,
484 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
485 CFG_MAX_RX_AMPDU_FACTOR_DEFAULT,
486 CFG_MAX_RX_AMPDU_FACTOR_MIN,
487 CFG_MAX_RX_AMPDU_FACTOR_MAX),
488
Krishna Kumaar Natarajan22b59a72015-11-23 18:54:58 -0800489 REG_VARIABLE(CFG_HT_MPDU_DENSITY_NAME, WLAN_PARAM_Integer,
490 struct hdd_config, ht_mpdu_density,
491 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK ,
492 CFG_HT_MPDU_DENSITY_DEFAULT,
493 CFG_HT_MPDU_DENSITY_MIN,
494 CFG_HT_MPDU_DENSITY_MAX),
495
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800496 REG_VARIABLE(CFG_FIXED_RATE_NAME, WLAN_PARAM_Integer,
497 struct hdd_config, TxRate,
498 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
499 CFG_FIXED_RATE_DEFAULT,
500 CFG_FIXED_RATE_MIN,
501 CFG_FIXED_RATE_MAX),
502
503 REG_VARIABLE(CFG_SHORT_GI_20MHZ_NAME, WLAN_PARAM_Integer,
504 struct hdd_config, ShortGI20MhzEnable,
505 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
506 CFG_SHORT_GI_20MHZ_DEFAULT,
507 CFG_SHORT_GI_20MHZ_MIN,
508 CFG_SHORT_GI_20MHZ_MAX),
509
510 REG_VARIABLE(CFG_SCAN_RESULT_AGE_COUNT_NAME, WLAN_PARAM_Integer,
511 struct hdd_config, ScanResultAgeCount,
512 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
513 CFG_SCAN_RESULT_AGE_COUNT_DEFAULT,
514 CFG_SCAN_RESULT_AGE_COUNT_MIN,
515 CFG_SCAN_RESULT_AGE_COUNT_MAX),
516
517 REG_VARIABLE(CFG_SCAN_RESULT_AGE_TIME_NCNPS_NAME, WLAN_PARAM_Integer,
518 struct hdd_config, nScanAgeTimeNCNPS,
519 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
520 CFG_SCAN_RESULT_AGE_TIME_NCNPS_DEFAULT,
521 CFG_SCAN_RESULT_AGE_TIME_NCNPS_MIN,
522 CFG_SCAN_RESULT_AGE_TIME_NCNPS_MAX),
523
524 REG_VARIABLE(CFG_SCAN_RESULT_AGE_TIME_NCPS_NAME, WLAN_PARAM_Integer,
525 struct hdd_config, nScanAgeTimeNCPS,
526 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
527 CFG_SCAN_RESULT_AGE_TIME_NCPS_DEFAULT,
528 CFG_SCAN_RESULT_AGE_TIME_NCPS_MIN,
529 CFG_SCAN_RESULT_AGE_TIME_NCPS_MAX),
530
531 REG_VARIABLE(CFG_SCAN_RESULT_AGE_TIME_CNPS_NAME, WLAN_PARAM_Integer,
532 struct hdd_config, nScanAgeTimeCNPS,
533 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
534 CFG_SCAN_RESULT_AGE_TIME_CNPS_DEFAULT,
535 CFG_SCAN_RESULT_AGE_TIME_CNPS_MIN,
536 CFG_SCAN_RESULT_AGE_TIME_CNPS_MAX),
537
538 REG_VARIABLE(CFG_SCAN_RESULT_AGE_TIME_CPS_NAME, WLAN_PARAM_Integer,
539 struct hdd_config, nScanAgeTimeCPS,
540 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
541 CFG_SCAN_RESULT_AGE_TIME_CPS_DEFAULT,
542 CFG_SCAN_RESULT_AGE_TIME_CPS_MIN,
543 CFG_SCAN_RESULT_AGE_TIME_CPS_MAX),
544
545 REG_VARIABLE(CFG_RSSI_CATEGORY_GAP_NAME, WLAN_PARAM_Integer,
546 struct hdd_config, nRssiCatGap,
547 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
548 CFG_RSSI_CATEGORY_GAP_DEFAULT,
549 CFG_RSSI_CATEGORY_GAP_MIN,
550 CFG_RSSI_CATEGORY_GAP_MAX),
551
552 REG_VARIABLE(CFG_SHORT_PREAMBLE_NAME, WLAN_PARAM_Integer,
553 struct hdd_config, fIsShortPreamble,
554 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
555 CFG_SHORT_PREAMBLE_DEFAULT,
556 CFG_SHORT_PREAMBLE_MIN,
557 CFG_SHORT_PREAMBLE_MAX),
558
559 REG_VARIABLE_STRING(CFG_IBSS_BSSID_NAME, WLAN_PARAM_MacAddr,
560 struct hdd_config, IbssBssid,
561 VAR_FLAGS_OPTIONAL,
562 (void *)CFG_IBSS_BSSID_DEFAULT),
563
564 REG_VARIABLE_STRING(CFG_INTF0_MAC_ADDR_NAME, WLAN_PARAM_MacAddr,
565 struct hdd_config, intfMacAddr[0],
566 VAR_FLAGS_OPTIONAL,
567 (void *)CFG_INTF0_MAC_ADDR_DEFAULT),
568
569 REG_VARIABLE_STRING(CFG_INTF1_MAC_ADDR_NAME, WLAN_PARAM_MacAddr,
570 struct hdd_config, intfMacAddr[1],
571 VAR_FLAGS_OPTIONAL,
572 (void *)CFG_INTF1_MAC_ADDR_DEFAULT),
573
574 REG_VARIABLE_STRING(CFG_INTF2_MAC_ADDR_NAME, WLAN_PARAM_MacAddr,
575 struct hdd_config, intfMacAddr[2],
576 VAR_FLAGS_OPTIONAL,
577 (void *)CFG_INTF2_MAC_ADDR_DEFAULT),
578
579 REG_VARIABLE_STRING(CFG_INTF3_MAC_ADDR_NAME, WLAN_PARAM_MacAddr,
580 struct hdd_config, intfMacAddr[3],
581 VAR_FLAGS_OPTIONAL,
582 (void *)CFG_INTF3_MAC_ADDR_DEFAULT),
583
584 REG_VARIABLE(CFG_AP_QOS_UAPSD_MODE_NAME, WLAN_PARAM_Integer,
585 struct hdd_config, apUapsdEnabled,
586 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
587 CFG_AP_QOS_UAPSD_MODE_DEFAULT,
588 CFG_AP_QOS_UAPSD_MODE_MIN,
589 CFG_AP_QOS_UAPSD_MODE_MAX),
590
591
592 REG_VARIABLE(CFG_AP_ENABLE_RANDOM_BSSID_NAME, WLAN_PARAM_Integer,
593 struct hdd_config, apRandomBssidEnabled,
594 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
595 CFG_AP_ENABLE_RANDOM_BSSID_DEFAULT,
596 CFG_AP_ENABLE_RANDOM_BSSID_MIN,
597 CFG_AP_ENABLE_RANDOM_BSSID_MAX),
598
599 REG_VARIABLE(CFG_AP_ENABLE_PROTECTION_MODE_NAME, WLAN_PARAM_Integer,
600 struct hdd_config, apProtEnabled,
601 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
602 CFG_AP_ENABLE_PROTECTION_MODE_DEFAULT,
603 CFG_AP_ENABLE_PROTECTION_MODE_MIN,
604 CFG_AP_ENABLE_PROTECTION_MODE_MAX),
605
606 REG_VARIABLE(CFG_AP_PROTECTION_MODE_NAME, WLAN_PARAM_HexInteger,
607 struct hdd_config, apProtection,
608 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
609 CFG_AP_PROTECTION_MODE_DEFAULT,
610 CFG_AP_PROTECTION_MODE_MIN,
611 CFG_AP_PROTECTION_MODE_MAX),
612
613 REG_VARIABLE(CFG_AP_OBSS_PROTECTION_MODE_NAME, WLAN_PARAM_Integer,
614 struct hdd_config, apOBSSProtEnabled,
615 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
616 CFG_AP_OBSS_PROTECTION_MODE_DEFAULT,
617 CFG_AP_OBSS_PROTECTION_MODE_MIN,
618 CFG_AP_OBSS_PROTECTION_MODE_MAX),
619
620 REG_VARIABLE(CFG_AP_STA_SECURITY_SEPERATION_NAME, WLAN_PARAM_Integer,
621 struct hdd_config, apDisableIntraBssFwd,
622 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
623 CFG_AP_STA_SECURITY_SEPERATION_DEFAULT,
624 CFG_AP_STA_SECURITY_SEPERATION_MIN,
625 CFG_AP_STA_SECURITY_SEPERATION_MAX),
626
627 REG_VARIABLE(CFG_ENABLE_LTE_COEX, WLAN_PARAM_Integer,
628 struct hdd_config, enableLTECoex,
629 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
630 CFG_ENABLE_LTE_COEX_DEFAULT,
631 CFG_ENABLE_LTE_COEX_MIN,
632 CFG_ENABLE_LTE_COEX_MAX),
633 REG_VARIABLE(CFG_FORCE_SAP_ACS, WLAN_PARAM_Integer,
634 struct hdd_config, force_sap_acs,
635 VAR_FLAGS_DYNAMIC_CFG |
636 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
637 CFG_FORCE_SAP_ACS_DEFAULT,
638 CFG_FORCE_SAP_ACS_MIN,
639 CFG_FORCE_SAP_ACS_MAX),
640
641 REG_VARIABLE(CFG_FORCE_SAP_ACS_START_CH, WLAN_PARAM_Integer,
642 struct hdd_config, force_sap_acs_st_ch,
643 VAR_FLAGS_DYNAMIC_CFG |
644 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
645 CFG_FORCE_SAP_ACS_START_CH_DEFAULT,
646 CFG_FORCE_SAP_ACS_START_CH_MIN,
647 CFG_FORCE_SAP_ACS_START_CH_MAX),
648
649 REG_VARIABLE(CFG_FORCE_SAP_ACS_END_CH, WLAN_PARAM_Integer,
650 struct hdd_config, force_sap_acs_end_ch,
651 VAR_FLAGS_DYNAMIC_CFG |
652 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
653 CFG_FORCE_SAP_ACS_END_CH_DEFAULT,
654 CFG_FORCE_SAP_ACS_END_CH_MIN,
655 CFG_FORCE_SAP_ACS_END_CH_MAX),
656
657 REG_VARIABLE(CFG_AP_KEEP_ALIVE_PERIOD_NAME, WLAN_PARAM_Integer,
658 struct hdd_config, apKeepAlivePeriod,
659 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
660 CFG_AP_KEEP_ALIVE_PERIOD_DEFAULT,
661 CFG_AP_KEEP_ALIVE_PERIOD_MIN,
662 CFG_AP_KEEP_ALIVE_PERIOD_MAX),
663
664 REG_VARIABLE(CFG_GO_KEEP_ALIVE_PERIOD_NAME, WLAN_PARAM_Integer,
665 struct hdd_config, goKeepAlivePeriod,
666 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
667 CFG_GO_KEEP_ALIVE_PERIOD_DEFAULT,
668 CFG_GO_KEEP_ALIVE_PERIOD_MIN,
669 CFG_GO_KEEP_ALIVE_PERIOD_MAX),
670
671 REG_VARIABLE(CFG_AP_LINK_MONITOR_PERIOD_NAME, WLAN_PARAM_Integer,
672 struct hdd_config, apLinkMonitorPeriod,
673 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
674 CFG_AP_LINK_MONITOR_PERIOD_DEFAULT,
675 CFG_AP_LINK_MONITOR_PERIOD_MIN,
676 CFG_AP_LINK_MONITOR_PERIOD_MAX),
677
678 REG_VARIABLE(CFG_GO_LINK_MONITOR_PERIOD_NAME, WLAN_PARAM_Integer,
679 struct hdd_config, goLinkMonitorPeriod,
680 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
681 CFG_GO_LINK_MONITOR_PERIOD_DEFAULT,
682 CFG_GO_LINK_MONITOR_PERIOD_MIN,
683 CFG_GO_LINK_MONITOR_PERIOD_MAX),
684
685 REG_VARIABLE(CFG_DISABLE_PACKET_FILTER, WLAN_PARAM_Integer,
686 struct hdd_config, disablePacketFilter,
687 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
688 CFG_DISABLE_PACKET_FILTER_DEFAULT,
689 CFG_DISABLE_PACKET_FILTER_MIN,
690 CFG_DISABLE_PACKET_FILTER_MAX),
691
692 REG_VARIABLE(CFG_BEACON_INTERVAL_NAME, WLAN_PARAM_Integer,
693 struct hdd_config, nBeaconInterval,
694 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
695 CFG_BEACON_INTERVAL_DEFAULT,
696 CFG_BEACON_INTERVAL_MIN,
697 CFG_BEACON_INTERVAL_MAX),
698
699 REG_VARIABLE(CFG_ROAMING_TIME_NAME, WLAN_PARAM_Integer,
700 struct hdd_config, nRoamingTime,
701 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
702 CFG_ROAMING_TIME_DEFAULT,
703 CFG_ROAMING_TIME_MIN,
704 CFG_ROAMING_TIME_MAX),
705
706 REG_VARIABLE(CFG_VCC_RSSI_TRIGGER_NAME, WLAN_PARAM_Integer,
707 struct hdd_config, nVccRssiTrigger,
708 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
709 CFG_VCC_RSSI_TRIGGER_DEFAULT,
710 CFG_VCC_RSSI_TRIGGER_MIN,
711 CFG_VCC_RSSI_TRIGGER_MAX),
712
713 REG_VARIABLE(CFG_VCC_UL_MAC_LOSS_THRESH_NAME, WLAN_PARAM_Integer,
714 struct hdd_config, nVccUlMacLossThreshold,
715 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
716 CFG_VCC_UL_MAC_LOSS_THRESH_DEFAULT,
717 CFG_VCC_UL_MAC_LOSS_THRESH_MIN,
718 CFG_VCC_UL_MAC_LOSS_THRESH_MAX),
719
720 REG_VARIABLE(CFG_PASSIVE_MAX_CHANNEL_TIME_NAME, WLAN_PARAM_Integer,
721 struct hdd_config, nPassiveMaxChnTime,
722 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
723 CFG_PASSIVE_MAX_CHANNEL_TIME_DEFAULT,
724 CFG_PASSIVE_MAX_CHANNEL_TIME_MIN,
725 CFG_PASSIVE_MAX_CHANNEL_TIME_MAX),
726
727 REG_VARIABLE(CFG_PASSIVE_MIN_CHANNEL_TIME_NAME, WLAN_PARAM_Integer,
728 struct hdd_config, nPassiveMinChnTime,
729 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
730 CFG_PASSIVE_MIN_CHANNEL_TIME_DEFAULT,
731 CFG_PASSIVE_MIN_CHANNEL_TIME_MIN,
732 CFG_PASSIVE_MIN_CHANNEL_TIME_MAX),
733
734 REG_VARIABLE(CFG_ACTIVE_MAX_CHANNEL_TIME_NAME, WLAN_PARAM_Integer,
735 struct hdd_config, nActiveMaxChnTime,
736 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
737 CFG_ACTIVE_MAX_CHANNEL_TIME_DEFAULT,
738 CFG_ACTIVE_MAX_CHANNEL_TIME_MIN,
739 CFG_ACTIVE_MAX_CHANNEL_TIME_MAX),
740
741 REG_VARIABLE(CFG_ACTIVE_MIN_CHANNEL_TIME_NAME, WLAN_PARAM_Integer,
742 struct hdd_config, nActiveMinChnTime,
743 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
744 CFG_ACTIVE_MIN_CHANNEL_TIME_DEFAULT,
745 CFG_ACTIVE_MIN_CHANNEL_TIME_MIN,
746 CFG_ACTIVE_MIN_CHANNEL_TIME_MAX),
747
748 REG_VARIABLE(CFG_RETRY_LIMIT_ZERO_NAME, WLAN_PARAM_Integer,
749 struct hdd_config, retryLimitZero,
750 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
751 CFG_RETRY_LIMIT_ZERO_DEFAULT,
752 CFG_RETRY_LIMIT_ZERO_MIN,
753 CFG_RETRY_LIMIT_ZERO_MAX),
754
755 REG_VARIABLE(CFG_RETRY_LIMIT_ONE_NAME, WLAN_PARAM_Integer,
756 struct hdd_config, retryLimitOne,
757 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
758 CFG_RETRY_LIMIT_ONE_DEFAULT,
759 CFG_RETRY_LIMIT_ONE_MIN,
760 CFG_RETRY_LIMIT_ONE_MAX),
761
762 REG_VARIABLE(CFG_RETRY_LIMIT_TWO_NAME, WLAN_PARAM_Integer,
763 struct hdd_config, retryLimitTwo,
764 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
765 CFG_RETRY_LIMIT_TWO_DEFAULT,
766 CFG_RETRY_LIMIT_TWO_MIN,
767 CFG_RETRY_LIMIT_TWO_MAX),
768
769#ifdef WLAN_AP_STA_CONCURRENCY
770 REG_VARIABLE(CFG_PASSIVE_MAX_CHANNEL_TIME_CONC_NAME, WLAN_PARAM_Integer,
771 struct hdd_config, nPassiveMaxChnTimeConc,
772 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
773 CFG_PASSIVE_MAX_CHANNEL_TIME_CONC_DEFAULT,
774 CFG_PASSIVE_MAX_CHANNEL_TIME_CONC_MIN,
775 CFG_PASSIVE_MAX_CHANNEL_TIME_CONC_MAX),
776
777 REG_VARIABLE(CFG_PASSIVE_MIN_CHANNEL_TIME_CONC_NAME, WLAN_PARAM_Integer,
778 struct hdd_config, nPassiveMinChnTimeConc,
779 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
780 CFG_PASSIVE_MIN_CHANNEL_TIME_CONC_DEFAULT,
781 CFG_PASSIVE_MIN_CHANNEL_TIME_CONC_MIN,
782 CFG_PASSIVE_MIN_CHANNEL_TIME_CONC_MAX),
783
784 REG_VARIABLE(CFG_ACTIVE_MAX_CHANNEL_TIME_CONC_NAME, WLAN_PARAM_Integer,
785 struct hdd_config, nActiveMaxChnTimeConc,
786 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
787 CFG_ACTIVE_MAX_CHANNEL_TIME_CONC_DEFAULT,
788 CFG_ACTIVE_MAX_CHANNEL_TIME_CONC_MIN,
789 CFG_ACTIVE_MAX_CHANNEL_TIME_CONC_MAX),
790
791 REG_VARIABLE(CFG_ACTIVE_MIN_CHANNEL_TIME_CONC_NAME, WLAN_PARAM_Integer,
792 struct hdd_config, nActiveMinChnTimeConc,
793 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
794 CFG_ACTIVE_MIN_CHANNEL_TIME_CONC_DEFAULT,
795 CFG_ACTIVE_MIN_CHANNEL_TIME_CONC_MIN,
796 CFG_ACTIVE_MIN_CHANNEL_TIME_CONC_MAX),
797
798 REG_VARIABLE(CFG_REST_TIME_CONC_NAME, WLAN_PARAM_Integer,
799 struct hdd_config, nRestTimeConc,
800 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
801 CFG_REST_TIME_CONC_DEFAULT,
802 CFG_REST_TIME_CONC_MIN,
803 CFG_REST_TIME_CONC_MAX),
804
805 REG_VARIABLE(CFG_NUM_STA_CHAN_COMBINED_CONC_NAME, WLAN_PARAM_Integer,
806 struct hdd_config, nNumStaChanCombinedConc,
807 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
808 CFG_NUM_STA_CHAN_COMBINED_CONC_DEFAULT,
809 CFG_NUM_STA_CHAN_COMBINED_CONC_MIN,
810 CFG_NUM_STA_CHAN_COMBINED_CONC_MAX),
811
812 REG_VARIABLE(CFG_NUM_P2P_CHAN_COMBINED_CONC_NAME, WLAN_PARAM_Integer,
813 struct hdd_config, nNumP2PChanCombinedConc,
814 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
815 CFG_NUM_P2P_CHAN_COMBINED_CONC_DEFAULT,
816 CFG_NUM_P2P_CHAN_COMBINED_CONC_MIN,
817 CFG_NUM_P2P_CHAN_COMBINED_CONC_MAX),
818#endif
819
820 REG_VARIABLE(CFG_MAX_PS_POLL_NAME, WLAN_PARAM_Integer,
821 struct hdd_config, nMaxPsPoll,
822 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
823 CFG_MAX_PS_POLL_DEFAULT,
824 CFG_MAX_PS_POLL_MIN,
825 CFG_MAX_PS_POLL_MAX),
826
827 REG_VARIABLE(CFG_MAX_TX_POWER_NAME, WLAN_PARAM_Integer,
828 struct hdd_config, nTxPowerCap,
829 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
830 CFG_MAX_TX_POWER_DEFAULT,
831 CFG_MAX_TX_POWER_MIN,
832 CFG_MAX_TX_POWER_MAX),
833
834 REG_VARIABLE(CFG_LOW_GAIN_OVERRIDE_NAME, WLAN_PARAM_Integer,
835 struct hdd_config, fIsLowGainOverride,
836 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
837 CFG_LOW_GAIN_OVERRIDE_DEFAULT,
838 CFG_LOW_GAIN_OVERRIDE_MIN,
839 CFG_LOW_GAIN_OVERRIDE_MAX),
840
841 REG_VARIABLE(CFG_RSSI_FILTER_PERIOD_NAME, WLAN_PARAM_Integer,
842 struct hdd_config, nRssiFilterPeriod,
843 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
844 CFG_RSSI_FILTER_PERIOD_DEFAULT,
845 CFG_RSSI_FILTER_PERIOD_MIN,
846 CFG_RSSI_FILTER_PERIOD_MAX),
847
848 REG_VARIABLE(CFG_IGNORE_DTIM_NAME, WLAN_PARAM_Integer,
849 struct hdd_config, fIgnoreDtim,
850 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
851 CFG_IGNORE_DTIM_DEFAULT,
852 CFG_IGNORE_DTIM_MIN,
853 CFG_IGNORE_DTIM_MAX),
854
855 REG_VARIABLE(CFG_MAX_LI_MODULATED_DTIM_NAME, WLAN_PARAM_Integer,
856 struct hdd_config, fMaxLIModulatedDTIM,
857 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
858 CFG_MAX_LI_MODULATED_DTIM_DEFAULT,
859 CFG_MAX_LI_MODULATED_DTIM_MIN,
860 CFG_MAX_LI_MODULATED_DTIM_MAX),
861
862 REG_VARIABLE(CFG_RX_ANT_CONFIGURATION_NAME, WLAN_PARAM_Integer,
863 struct hdd_config, nRxAnt,
864 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
865 CFG_RX_ANT_CONFIGURATION_NAME_DEFAULT,
866 CFG_RX_ANT_CONFIGURATION_NAME_MIN,
867 CFG_RX_ANT_CONFIGURATION_NAME_MAX),
868
869 REG_VARIABLE(CFG_FW_HEART_BEAT_MONITORING_NAME, WLAN_PARAM_Integer,
870 struct hdd_config, fEnableFwHeartBeatMonitoring,
871 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
872 CFG_FW_HEART_BEAT_MONITORING_DEFAULT,
873 CFG_FW_HEART_BEAT_MONITORING_MIN,
874 CFG_FW_HEART_BEAT_MONITORING_MAX),
875
876 REG_VARIABLE(CFG_FW_BEACON_FILTERING_NAME, WLAN_PARAM_Integer,
877 struct hdd_config, fEnableFwBeaconFiltering,
878 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
879 CFG_FW_BEACON_FILTERING_DEFAULT,
880 CFG_FW_BEACON_FILTERING_MIN,
881 CFG_FW_BEACON_FILTERING_MAX),
882
883 REG_DYNAMIC_VARIABLE(CFG_FW_RSSI_MONITORING_NAME, WLAN_PARAM_Integer,
884 struct hdd_config, fEnableFwRssiMonitoring,
885 VAR_FLAGS_OPTIONAL |
886 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
887 CFG_FW_RSSI_MONITORING_DEFAULT,
888 CFG_FW_RSSI_MONITORING_MIN,
889 CFG_FW_RSSI_MONITORING_MAX,
890 cb_notify_set_fw_rssi_monitoring, 0),
891
892 REG_VARIABLE(CFG_FW_MCC_RTS_CTS_PROT_NAME, WLAN_PARAM_Integer,
893 struct hdd_config, mcc_rts_cts_prot_enable,
894 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
895 CFG_FW_MCC_RTS_CTS_PROT_DEFAULT,
896 CFG_FW_MCC_RTS_CTS_PROT_MIN,
897 CFG_FW_MCC_RTS_CTS_PROT_MAX),
898
899 REG_VARIABLE(CFG_FW_MCC_BCAST_PROB_RESP_NAME, WLAN_PARAM_Integer,
900 struct hdd_config, mcc_bcast_prob_resp_enable,
901 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
902 CFG_FW_MCC_BCAST_PROB_RESP_DEFAULT,
903 CFG_FW_MCC_BCAST_PROB_RESP_MIN,
904 CFG_FW_MCC_BCAST_PROB_RESP_MAX),
905
906 REG_VARIABLE(CFG_DATA_INACTIVITY_TIMEOUT_NAME, WLAN_PARAM_Integer,
907 struct hdd_config, nDataInactivityTimeout,
908 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
909 CFG_DATA_INACTIVITY_TIMEOUT_DEFAULT,
910 CFG_DATA_INACTIVITY_TIMEOUT_MIN,
911 CFG_DATA_INACTIVITY_TIMEOUT_MAX),
912
913 REG_VARIABLE(CFG_QOS_WMM_MODE_NAME, WLAN_PARAM_Integer,
914 struct hdd_config, WmmMode,
915 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
916 CFG_QOS_WMM_MODE_DEFAULT,
917 CFG_QOS_WMM_MODE_MIN,
918 CFG_QOS_WMM_MODE_MAX),
919
920 REG_VARIABLE(CFG_QOS_WMM_80211E_ENABLED_NAME, WLAN_PARAM_Integer,
921 struct hdd_config, b80211eIsEnabled,
922 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
923 CFG_QOS_WMM_80211E_ENABLED_DEFAULT,
924 CFG_QOS_WMM_80211E_ENABLED_MIN,
925 CFG_QOS_WMM_80211E_ENABLED_MAX),
926
927 REG_VARIABLE(CFG_QOS_WMM_UAPSD_MASK_NAME, WLAN_PARAM_HexInteger,
928 struct hdd_config, UapsdMask,
929 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
930 CFG_QOS_WMM_UAPSD_MASK_DEFAULT,
931 CFG_QOS_WMM_UAPSD_MASK_MIN,
932 CFG_QOS_WMM_UAPSD_MASK_MAX),
933
934 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_VO_SRV_INTV_NAME,
935 WLAN_PARAM_Integer,
936 struct hdd_config, InfraUapsdVoSrvIntv,
937 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
938 CFG_QOS_WMM_INFRA_UAPSD_VO_SRV_INTV_DEFAULT,
939 CFG_QOS_WMM_INFRA_UAPSD_VO_SRV_INTV_MIN,
940 CFG_QOS_WMM_INFRA_UAPSD_VO_SRV_INTV_MAX),
941
942 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_VO_SUS_INTV_NAME,
943 WLAN_PARAM_Integer,
944 struct hdd_config, InfraUapsdVoSuspIntv,
945 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
946 CFG_QOS_WMM_INFRA_UAPSD_VO_SUS_INTV_DEFAULT,
947 CFG_QOS_WMM_INFRA_UAPSD_VO_SUS_INTV_MIN,
948 CFG_QOS_WMM_INFRA_UAPSD_VO_SUS_INTV_MAX),
949
950 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_VI_SRV_INTV_NAME,
951 WLAN_PARAM_Integer,
952 struct hdd_config, InfraUapsdViSrvIntv,
953 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
954 CFG_QOS_WMM_INFRA_UAPSD_VI_SRV_INTV_DEFAULT,
955 CFG_QOS_WMM_INFRA_UAPSD_VI_SRV_INTV_MIN,
956 CFG_QOS_WMM_INFRA_UAPSD_VI_SRV_INTV_MAX),
957
958 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_VI_SUS_INTV_NAME,
959 WLAN_PARAM_Integer,
960 struct hdd_config, InfraUapsdViSuspIntv,
961 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
962 CFG_QOS_WMM_INFRA_UAPSD_VI_SUS_INTV_DEFAULT,
963 CFG_QOS_WMM_INFRA_UAPSD_VI_SUS_INTV_MIN,
964 CFG_QOS_WMM_INFRA_UAPSD_VI_SUS_INTV_MAX),
965
966 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_NAME,
967 WLAN_PARAM_Integer,
968 struct hdd_config, InfraUapsdBeSrvIntv,
969 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
970 CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_DEFAULT,
971 CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_MIN,
972 CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_MAX),
973
974 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_NAME,
975 WLAN_PARAM_Integer,
976 struct hdd_config, InfraUapsdBeSuspIntv,
977 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
978 CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_DEFAULT,
979 CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_MIN,
980 CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_MAX),
981
982 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BK_SRV_INTV_NAME,
983 WLAN_PARAM_Integer,
984 struct hdd_config, InfraUapsdBkSrvIntv,
985 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
986 CFG_QOS_WMM_INFRA_UAPSD_BK_SRV_INTV_DEFAULT,
987 CFG_QOS_WMM_INFRA_UAPSD_BK_SRV_INTV_MIN,
988 CFG_QOS_WMM_INFRA_UAPSD_BK_SRV_INTV_MAX),
989
990 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_NAME,
991 WLAN_PARAM_Integer,
992 struct hdd_config, InfraUapsdBkSuspIntv,
993 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
994 CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_DEFAULT,
995 CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_MIN,
996 CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_MAX),
997
998#ifdef FEATURE_WLAN_ESE
999 REG_VARIABLE(CFG_QOS_WMM_INFRA_INACTIVITY_INTERVAL_NAME,
1000 WLAN_PARAM_Integer,
1001 struct hdd_config, InfraInactivityInterval,
1002 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1003 CFG_QOS_WMM_INFRA_INACTIVITY_INTERVAL_DEFAULT,
1004 CFG_QOS_WMM_INFRA_INACTIVITY_INTERVAL_MIN,
1005 CFG_QOS_WMM_INFRA_INACTIVITY_INTERVAL_MAX),
1006
1007 REG_DYNAMIC_VARIABLE(CFG_ESE_FEATURE_ENABLED_NAME, WLAN_PARAM_Integer,
1008 struct hdd_config, isEseIniFeatureEnabled,
1009 VAR_FLAGS_OPTIONAL |
1010 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1011 CFG_ESE_FEATURE_ENABLED_DEFAULT,
1012 CFG_ESE_FEATURE_ENABLED_MIN,
1013 CFG_ESE_FEATURE_ENABLED_MAX,
1014 cb_notify_set_ese_feature_enabled, 0),
1015#endif /* FEATURE_WLAN_ESE */
1016
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001017 /* flag to turn ON/OFF Legacy Fast Roaming */
1018 REG_DYNAMIC_VARIABLE(CFG_LFR_FEATURE_ENABLED_NAME, WLAN_PARAM_Integer,
1019 struct hdd_config, isFastRoamIniFeatureEnabled,
1020 VAR_FLAGS_OPTIONAL |
1021 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1022 CFG_LFR_FEATURE_ENABLED_DEFAULT,
1023 CFG_LFR_FEATURE_ENABLED_MIN,
1024 CFG_LFR_FEATURE_ENABLED_MAX,
1025 notify_is_fast_roam_ini_feature_enabled, 0),
1026
1027 /* flag to turn ON/OFF Motion assistance for Legacy Fast Roaming */
1028 REG_DYNAMIC_VARIABLE(CFG_LFR_MAWC_FEATURE_ENABLED_NAME,
1029 WLAN_PARAM_Integer,
1030 struct hdd_config, MAWCEnabled,
1031 VAR_FLAGS_OPTIONAL |
1032 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1033 CFG_LFR_MAWC_FEATURE_ENABLED_DEFAULT,
1034 CFG_LFR_MAWC_FEATURE_ENABLED_MIN,
1035 CFG_LFR_MAWC_FEATURE_ENABLED_MAX,
1036 notify_is_mawc_ini_feature_enabled, 0),
1037
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001038 /* flag to turn ON/OFF 11r and ESE FastTransition */
1039 REG_DYNAMIC_VARIABLE(CFG_FAST_TRANSITION_ENABLED_NAME,
1040 WLAN_PARAM_Integer,
1041 struct hdd_config, isFastTransitionEnabled,
1042 VAR_FLAGS_OPTIONAL |
1043 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1044 CFG_FAST_TRANSITION_ENABLED_NAME_DEFAULT,
1045 CFG_FAST_TRANSITION_ENABLED_NAME_MIN,
1046 CFG_FAST_TRANSITION_ENABLED_NAME_MAX,
1047 cb_notify_set_fast_transition_enabled, 0),
1048
1049 /* Variable to specify the delta/difference between the RSSI of current AP
1050 * and roamable AP while roaming */
1051 REG_DYNAMIC_VARIABLE(CFG_ROAM_RSSI_DIFF_NAME, WLAN_PARAM_Integer,
1052 struct hdd_config, RoamRssiDiff,
1053 VAR_FLAGS_OPTIONAL |
1054 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1055 CFG_ROAM_RSSI_DIFF_DEFAULT,
1056 CFG_ROAM_RSSI_DIFF_MIN,
1057 CFG_ROAM_RSSI_DIFF_MAX,
1058 cb_notify_set_roam_rssi_diff, 0),
1059
1060 REG_DYNAMIC_VARIABLE(CFG_ENABLE_WES_MODE_NAME, WLAN_PARAM_Integer,
1061 struct hdd_config, isWESModeEnabled,
1062 VAR_FLAGS_OPTIONAL |
1063 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1064 CFG_ENABLE_WES_MODE_NAME_DEFAULT,
1065 CFG_ENABLE_WES_MODE_NAME_MIN,
1066 CFG_ENABLE_WES_MODE_NAME_MAX,
1067 cb_notify_set_wes_mode, 0),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001068#ifdef FEATURE_WLAN_OKC
1069 REG_DYNAMIC_VARIABLE(CFG_OKC_FEATURE_ENABLED_NAME, WLAN_PARAM_Integer,
1070 struct hdd_config, isOkcIniFeatureEnabled,
1071 VAR_FLAGS_OPTIONAL |
1072 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1073 CFG_OKC_FEATURE_ENABLED_DEFAULT,
1074 CFG_OKC_FEATURE_ENABLED_MIN,
1075 CFG_OKC_FEATURE_ENABLED_MAX,
1076 cb_notify_set_okc_feature_enabled, 0),
1077#endif
1078 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_OFFLOAD_ENABLED, WLAN_PARAM_Integer,
1079 struct hdd_config, isRoamOffloadScanEnabled,
1080 VAR_FLAGS_OPTIONAL |
1081 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1082 CFG_ROAM_SCAN_OFFLOAD_ENABLED_DEFAULT,
1083 CFG_ROAM_SCAN_OFFLOAD_ENABLED_MIN,
1084 CFG_ROAM_SCAN_OFFLOAD_ENABLED_MAX,
1085 cb_notify_update_roam_scan_offload_enabled, 0),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001086
1087 REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_VO_NAME, WLAN_PARAM_Integer,
1088 struct hdd_config, InfraDirAcVo,
1089 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1090 CFG_QOS_WMM_INFRA_DIR_AC_VO_DEFAULT,
1091 CFG_QOS_WMM_INFRA_DIR_AC_VO_MIN,
1092 CFG_QOS_WMM_INFRA_DIR_AC_VO_MAX),
1093
1094 REG_VARIABLE(CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VO_NAME,
1095 WLAN_PARAM_HexInteger,
1096 struct hdd_config, InfraNomMsduSizeAcVo,
1097 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1098 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VO_DEFAULT,
1099 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VO_MIN,
1100 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VO_MAX),
1101
1102 REG_VARIABLE(CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VO_NAME,
1103 WLAN_PARAM_HexInteger,
1104 struct hdd_config, InfraMeanDataRateAcVo,
1105 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1106 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VO_DEFAULT,
1107 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VO_MIN,
1108 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VO_MAX),
1109
1110 REG_VARIABLE(CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VO_NAME,
1111 WLAN_PARAM_HexInteger,
1112 struct hdd_config, InfraMinPhyRateAcVo,
1113 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1114 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VO_DEFAULT,
1115 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VO_MIN,
1116 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VO_MAX),
1117
1118 REG_VARIABLE(CFG_QOS_WMM_INFRA_SBA_AC_VO_NAME, WLAN_PARAM_HexInteger,
1119 struct hdd_config, InfraSbaAcVo,
1120 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1121 CFG_QOS_WMM_INFRA_SBA_AC_VO_DEFAULT,
1122 CFG_QOS_WMM_INFRA_SBA_AC_VO_MIN,
1123 CFG_QOS_WMM_INFRA_SBA_AC_VO_MAX),
1124
1125 REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_VI_NAME, WLAN_PARAM_Integer,
1126 struct hdd_config, InfraDirAcVi,
1127 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1128 CFG_QOS_WMM_INFRA_DIR_AC_VI_DEFAULT,
1129 CFG_QOS_WMM_INFRA_DIR_AC_VI_MIN,
1130 CFG_QOS_WMM_INFRA_DIR_AC_VI_MAX),
1131
1132 REG_VARIABLE(CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VI_NAME,
1133 WLAN_PARAM_HexInteger,
1134 struct hdd_config, InfraNomMsduSizeAcVi,
1135 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1136 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VI_DEFAULT,
1137 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VI_MIN,
1138 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VI_MAX),
1139
1140 REG_VARIABLE(CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VI_NAME,
1141 WLAN_PARAM_HexInteger,
1142 struct hdd_config, InfraMeanDataRateAcVi,
1143 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1144 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VI_DEFAULT,
1145 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VI_MIN,
1146 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VI_MAX),
1147
1148 REG_VARIABLE(CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VI_NAME,
1149 WLAN_PARAM_HexInteger,
1150 struct hdd_config, InfraMinPhyRateAcVi,
1151 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1152 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VI_DEFAULT,
1153 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VI_MIN,
1154 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VI_MAX),
1155
1156 REG_VARIABLE(CFG_QOS_WMM_INFRA_SBA_AC_VI_NAME, WLAN_PARAM_HexInteger,
1157 struct hdd_config, InfraSbaAcVi,
1158 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1159 CFG_QOS_WMM_INFRA_SBA_AC_VI_DEFAULT,
1160 CFG_QOS_WMM_INFRA_SBA_AC_VI_MIN,
1161 CFG_QOS_WMM_INFRA_SBA_AC_VI_MAX),
1162
1163 REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_BE_NAME, WLAN_PARAM_Integer,
1164 struct hdd_config, InfraDirAcBe,
1165 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1166 CFG_QOS_WMM_INFRA_DIR_AC_BE_DEFAULT,
1167 CFG_QOS_WMM_INFRA_DIR_AC_BE_MIN,
1168 CFG_QOS_WMM_INFRA_DIR_AC_BE_MAX),
1169
1170 REG_VARIABLE(CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_NAME,
1171 WLAN_PARAM_HexInteger,
1172 struct hdd_config, InfraNomMsduSizeAcBe,
1173 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1174 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_DEFAULT,
1175 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_MIN,
1176 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_MAX),
1177
1178 REG_VARIABLE(CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_NAME,
1179 WLAN_PARAM_HexInteger,
1180 struct hdd_config, InfraMeanDataRateAcBe,
1181 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1182 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_DEFAULT,
1183 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_MIN,
1184 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_MAX),
1185
1186 REG_VARIABLE(CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_NAME,
1187 WLAN_PARAM_HexInteger,
1188 struct hdd_config, InfraMinPhyRateAcBe,
1189 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1190 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_DEFAULT,
1191 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_MIN,
1192 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_MAX),
1193
1194 REG_VARIABLE(CFG_QOS_WMM_INFRA_SBA_AC_BE_NAME, WLAN_PARAM_HexInteger,
1195 struct hdd_config, InfraSbaAcBe,
1196 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1197 CFG_QOS_WMM_INFRA_SBA_AC_BE_DEFAULT,
1198 CFG_QOS_WMM_INFRA_SBA_AC_BE_MIN,
1199 CFG_QOS_WMM_INFRA_SBA_AC_BE_MAX),
1200
1201 REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_BK_NAME, WLAN_PARAM_Integer,
1202 struct hdd_config, InfraDirAcBk,
1203 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1204 CFG_QOS_WMM_INFRA_DIR_AC_BK_DEFAULT,
1205 CFG_QOS_WMM_INFRA_DIR_AC_BK_MIN,
1206 CFG_QOS_WMM_INFRA_DIR_AC_BK_MAX),
1207
1208 REG_VARIABLE(CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BK_NAME,
1209 WLAN_PARAM_HexInteger,
1210 struct hdd_config, InfraNomMsduSizeAcBk,
1211 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1212 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BK_DEFAULT,
1213 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BK_MIN,
1214 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BK_MAX),
1215
1216 REG_VARIABLE(CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BK_NAME,
1217 WLAN_PARAM_HexInteger,
1218 struct hdd_config, InfraMeanDataRateAcBk,
1219 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1220 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BK_DEFAULT,
1221 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BK_MIN,
1222 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BK_MAX),
1223
1224 REG_VARIABLE(CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BK_NAME,
1225 WLAN_PARAM_HexInteger,
1226 struct hdd_config, InfraMinPhyRateAcBk,
1227 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1228 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BK_DEFAULT,
1229 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BK_MIN,
1230 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BK_MAX),
1231
1232 REG_VARIABLE(CFG_QOS_WMM_INFRA_SBA_AC_BK_NAME, WLAN_PARAM_HexInteger,
1233 struct hdd_config, InfraSbaAcBk,
1234 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1235 CFG_QOS_WMM_INFRA_SBA_AC_BK_DEFAULT,
1236 CFG_QOS_WMM_INFRA_SBA_AC_BK_MIN,
1237 CFG_QOS_WMM_INFRA_SBA_AC_BK_MAX),
1238
1239 REG_VARIABLE(CFG_TL_DELAYED_TRGR_FRM_INT_NAME, WLAN_PARAM_Integer,
1240 struct hdd_config, DelayedTriggerFrmInt,
1241 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1242 CFG_TL_DELAYED_TRGR_FRM_INT_DEFAULT,
1243 CFG_TL_DELAYED_TRGR_FRM_INT_MIN,
1244 CFG_TL_DELAYED_TRGR_FRM_INT_MAX),
1245
1246 REG_VARIABLE_STRING(CFG_WOWL_PATTERN_NAME, WLAN_PARAM_String,
1247 struct hdd_config, wowlPattern,
1248 VAR_FLAGS_OPTIONAL,
1249 (void *)CFG_WOWL_PATTERN_DEFAULT),
1250
1251 REG_VARIABLE(CFG_QOS_IMPLICIT_SETUP_ENABLED_NAME, WLAN_PARAM_Integer,
1252 struct hdd_config, bImplicitQosEnabled,
1253 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1254 CFG_QOS_IMPLICIT_SETUP_ENABLED_DEFAULT,
1255 CFG_QOS_IMPLICIT_SETUP_ENABLED_MIN,
1256 CFG_QOS_IMPLICIT_SETUP_ENABLED_MAX),
1257
1258 REG_VARIABLE(CFG_AP_LISTEN_MODE_NAME, WLAN_PARAM_Integer,
1259 struct hdd_config, nEnableListenMode,
1260 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1261 CFG_AP_LISTEN_MODE_DEFAULT,
1262 CFG_AP_LISTEN_MODE_MIN,
1263 CFG_AP_LISTEN_MODE_MAX),
1264
1265 REG_VARIABLE(CFG_AP_AUTO_SHUT_OFF, WLAN_PARAM_Integer,
1266 struct hdd_config, nAPAutoShutOff,
1267 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1268 CFG_AP_AUTO_SHUT_OFF_DEFAULT,
1269 CFG_AP_AUTO_SHUT_OFF_MIN,
1270 CFG_AP_AUTO_SHUT_OFF_MAX),
1271
1272#ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
1273 REG_VARIABLE(CFG_WLAN_MCC_TO_SCC_SWITCH_MODE, WLAN_PARAM_Integer,
1274 struct hdd_config, WlanMccToSccSwitchMode,
1275 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1276 CFG_WLAN_MCC_TO_SCC_SWITCH_MODE_DEFAULT,
1277 CFG_WLAN_MCC_TO_SCC_SWITCH_MODE_MIN,
1278 CFG_WLAN_MCC_TO_SCC_SWITCH_MODE_MAX),
1279#endif
1280#ifdef FEATURE_WLAN_AUTO_SHUTDOWN
1281 REG_VARIABLE(CFG_WLAN_AUTO_SHUTDOWN, WLAN_PARAM_Integer,
1282 struct hdd_config, WlanAutoShutdown,
1283 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1284 CFG_WLAN_AUTO_SHUTDOWN_DEFAULT,
1285 CFG_WLAN_AUTO_SHUTDOWN_MIN,
1286 CFG_WLAN_AUTO_SHUTDOWN_MAX),
1287#endif
1288#if defined WLAN_FEATURE_VOWIFI
1289 REG_VARIABLE(CFG_RRM_ENABLE_NAME, WLAN_PARAM_Integer,
1290 struct hdd_config, fRrmEnable,
1291 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1292 CFG_RRM_ENABLE_DEFAULT,
1293 CFG_RRM_ENABLE_MIN,
1294 CFG_RRM_ENABLE_MAX),
1295
1296 REG_VARIABLE(CFG_RRM_OPERATING_CHAN_MAX_DURATION_NAME,
1297 WLAN_PARAM_Integer,
1298 struct hdd_config, nInChanMeasMaxDuration,
1299 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1300 CFG_RRM_OPERATING_CHAN_MAX_DURATION_DEFAULT,
1301 CFG_RRM_OPERATING_CHAN_MAX_DURATION_MIN,
1302 CFG_RRM_OPERATING_CHAN_MAX_DURATION_MAX),
1303
1304 REG_VARIABLE(CFG_RRM_NON_OPERATING_CHAN_MAX_DURATION_NAME,
1305 WLAN_PARAM_Integer,
1306 struct hdd_config, nOutChanMeasMaxDuration,
1307 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1308 CFG_RRM_NON_OPERATING_CHAN_MAX_DURATION_DEFAULT,
1309 CFG_RRM_NON_OPERATING_CHAN_MAX_DURATION_MIN,
1310 CFG_RRM_NON_OPERATING_CHAN_MAX_DURATION_MAX),
1311
1312 REG_VARIABLE(CFG_RRM_MEAS_RANDOMIZATION_INTVL_NAME, WLAN_PARAM_Integer,
1313 struct hdd_config, nRrmRandnIntvl,
1314 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1315 CFG_RRM_MEAS_RANDOMIZATION_INTVL_DEFAULT,
1316 CFG_RRM_MEAS_RANDOMIZATION_INTVL_MIN,
1317 CFG_RRM_MEAS_RANDOMIZATION_INTVL_MAX),
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08001318
1319 REG_VARIABLE_STRING(CFG_RM_CAPABILITY_NAME, WLAN_PARAM_String,
1320 struct hdd_config, rm_capability,
1321 VAR_FLAGS_OPTIONAL,
1322 (void *) CFG_RM_CAPABILITY_DEFAULT),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001323#endif
1324
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001325 REG_VARIABLE(CFG_FT_RESOURCE_REQ_NAME, WLAN_PARAM_Integer,
1326 struct hdd_config, fFTResourceReqSupported,
1327 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1328 CFG_FT_RESOURCE_REQ_DEFAULT,
1329 CFG_FT_RESOURCE_REQ_MIN,
1330 CFG_FT_RESOURCE_REQ_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001331
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001332 REG_DYNAMIC_VARIABLE(CFG_NEIGHBOR_SCAN_TIMER_PERIOD_NAME,
1333 WLAN_PARAM_Integer,
1334 struct hdd_config, nNeighborScanPeriod,
1335 VAR_FLAGS_OPTIONAL |
1336 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1337 CFG_NEIGHBOR_SCAN_TIMER_PERIOD_DEFAULT,
1338 CFG_NEIGHBOR_SCAN_TIMER_PERIOD_MIN,
1339 CFG_NEIGHBOR_SCAN_TIMER_PERIOD_MAX,
1340 cb_notify_set_neighbor_scan_period, 0),
1341
1342 REG_DYNAMIC_VARIABLE(CFG_NEIGHBOR_LOOKUP_RSSI_THRESHOLD_NAME,
1343 WLAN_PARAM_Integer,
1344 struct hdd_config, nNeighborLookupRssiThreshold,
1345 VAR_FLAGS_OPTIONAL |
1346 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1347 CFG_NEIGHBOR_LOOKUP_RSSI_THRESHOLD_DEFAULT,
1348 CFG_NEIGHBOR_LOOKUP_RSSI_THRESHOLD_MIN,
1349 CFG_NEIGHBOR_LOOKUP_RSSI_THRESHOLD_MAX,
1350 cb_notify_set_neighbor_lookup_rssi_threshold, 0),
1351
1352 REG_DYNAMIC_VARIABLE(CFG_OPPORTUNISTIC_SCAN_THRESHOLD_DIFF_NAME,
1353 WLAN_PARAM_Integer,
1354 struct hdd_config, nOpportunisticThresholdDiff,
1355 VAR_FLAGS_OPTIONAL |
1356 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1357 CFG_OPPORTUNISTIC_SCAN_THRESHOLD_DIFF_DEFAULT,
1358 CFG_OPPORTUNISTIC_SCAN_THRESHOLD_DIFF_MIN,
1359 CFG_OPPORTUNISTIC_SCAN_THRESHOLD_DIFF_MAX,
1360 cb_notify_set_opportunistic_scan_threshold_diff, 0),
1361
1362 REG_DYNAMIC_VARIABLE(CFG_ROAM_RESCAN_RSSI_DIFF_NAME, WLAN_PARAM_Integer,
1363 struct hdd_config, nRoamRescanRssiDiff,
1364 VAR_FLAGS_OPTIONAL |
1365 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1366 CFG_ROAM_RESCAN_RSSI_DIFF_DEFAULT,
1367 CFG_ROAM_RESCAN_RSSI_DIFF_MIN,
1368 CFG_ROAM_RESCAN_RSSI_DIFF_MAX,
1369 cb_notify_set_roam_rescan_rssi_diff, 0),
1370
1371 REG_VARIABLE_STRING(CFG_NEIGHBOR_SCAN_CHAN_LIST_NAME, WLAN_PARAM_String,
1372 struct hdd_config, neighborScanChanList,
1373 VAR_FLAGS_OPTIONAL,
1374 (void *)CFG_NEIGHBOR_SCAN_CHAN_LIST_DEFAULT),
1375
1376 REG_DYNAMIC_VARIABLE(CFG_NEIGHBOR_SCAN_MIN_CHAN_TIME_NAME,
1377 WLAN_PARAM_Integer,
1378 struct hdd_config, nNeighborScanMinChanTime,
1379 VAR_FLAGS_OPTIONAL |
1380 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1381 CFG_NEIGHBOR_SCAN_MIN_CHAN_TIME_DEFAULT,
1382 CFG_NEIGHBOR_SCAN_MIN_CHAN_TIME_MIN,
1383 CFG_NEIGHBOR_SCAN_MIN_CHAN_TIME_MAX,
1384 cb_notify_set_neighbor_scan_min_chan_time, 0),
1385
1386 REG_DYNAMIC_VARIABLE(CFG_NEIGHBOR_SCAN_MAX_CHAN_TIME_NAME,
1387 WLAN_PARAM_Integer,
1388 struct hdd_config, nNeighborScanMaxChanTime,
1389 VAR_FLAGS_OPTIONAL |
1390 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1391 CFG_NEIGHBOR_SCAN_MAX_CHAN_TIME_DEFAULT,
1392 CFG_NEIGHBOR_SCAN_MAX_CHAN_TIME_MIN,
1393 CFG_NEIGHBOR_SCAN_MAX_CHAN_TIME_MAX,
1394 cb_notify_set_neighbor_scan_max_chan_time, 0),
1395
1396 REG_VARIABLE(CFG_11R_NEIGHBOR_REQ_MAX_TRIES_NAME, WLAN_PARAM_Integer,
1397 struct hdd_config, nMaxNeighborReqTries,
1398 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1399 CFG_11R_NEIGHBOR_REQ_MAX_TRIES_DEFAULT,
1400 CFG_11R_NEIGHBOR_REQ_MAX_TRIES_MIN,
1401 CFG_11R_NEIGHBOR_REQ_MAX_TRIES_MAX),
1402
1403 REG_DYNAMIC_VARIABLE(CFG_NEIGHBOR_SCAN_RESULTS_REFRESH_PERIOD_NAME,
1404 WLAN_PARAM_Integer,
1405 struct hdd_config, nNeighborResultsRefreshPeriod,
1406 VAR_FLAGS_OPTIONAL |
1407 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1408 CFG_NEIGHBOR_SCAN_RESULTS_REFRESH_PERIOD_DEFAULT,
1409 CFG_NEIGHBOR_SCAN_RESULTS_REFRESH_PERIOD_MIN,
1410 CFG_NEIGHBOR_SCAN_RESULTS_REFRESH_PERIOD_MAX,
1411 cb_notify_set_neighbor_results_refresh_period, 0),
1412
1413 REG_DYNAMIC_VARIABLE(CFG_EMPTY_SCAN_REFRESH_PERIOD_NAME,
1414 WLAN_PARAM_Integer,
1415 struct hdd_config, nEmptyScanRefreshPeriod,
1416 VAR_FLAGS_OPTIONAL |
1417 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1418 CFG_EMPTY_SCAN_REFRESH_PERIOD_DEFAULT,
1419 CFG_EMPTY_SCAN_REFRESH_PERIOD_MIN,
1420 CFG_EMPTY_SCAN_REFRESH_PERIOD_MAX,
1421 cb_notify_set_empty_scan_refresh_period, 0),
1422
1423 REG_DYNAMIC_VARIABLE(CFG_ROAM_BMISS_FIRST_BCNT_NAME, WLAN_PARAM_Integer,
1424 struct hdd_config, nRoamBmissFirstBcnt,
1425 VAR_FLAGS_OPTIONAL |
1426 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1427 CFG_ROAM_BMISS_FIRST_BCNT_DEFAULT,
1428 CFG_ROAM_BMISS_FIRST_BCNT_MIN,
1429 CFG_ROAM_BMISS_FIRST_BCNT_MAX,
1430 cb_notify_set_roam_bmiss_first_bcnt, 0),
1431
1432 REG_DYNAMIC_VARIABLE(CFG_ROAM_BMISS_FINAL_BCNT_NAME, WLAN_PARAM_Integer,
1433 struct hdd_config, nRoamBmissFinalBcnt,
1434 VAR_FLAGS_OPTIONAL |
1435 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1436 CFG_ROAM_BMISS_FINAL_BCNT_DEFAULT,
1437 CFG_ROAM_BMISS_FINAL_BCNT_MIN,
1438 CFG_ROAM_BMISS_FINAL_BCNT_MAX,
1439 cb_notify_set_roam_bmiss_final_bcnt, 0),
1440
1441 REG_DYNAMIC_VARIABLE(CFG_ROAM_BEACON_RSSI_WEIGHT_NAME,
1442 WLAN_PARAM_Integer,
1443 struct hdd_config, nRoamBeaconRssiWeight,
1444 VAR_FLAGS_OPTIONAL |
1445 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1446 CFG_ROAM_BEACON_RSSI_WEIGHT_DEFAULT,
1447 CFG_ROAM_BEACON_RSSI_WEIGHT_MIN,
1448 CFG_ROAM_BEACON_RSSI_WEIGHT_MAX,
1449 cb_notify_set_roam_beacon_rssi_weight, 0),
1450
1451 REG_DYNAMIC_VARIABLE(CFG_ROAMING_DFS_CHANNEL_NAME, WLAN_PARAM_Integer,
1452 struct hdd_config, allowDFSChannelRoam,
1453 VAR_FLAGS_OPTIONAL |
1454 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1455 CFG_ROAMING_DFS_CHANNEL_DEFAULT,
1456 CFG_ROAMING_DFS_CHANNEL_MIN,
1457 CFG_ROAMING_DFS_CHANNEL_MAX,
1458 cb_notify_set_dfs_scan_mode, 0),
1459
1460 REG_DYNAMIC_VARIABLE(CFG_DELAY_BEFORE_VDEV_STOP_NAME,
1461 WLAN_PARAM_Integer,
1462 struct hdd_config,
1463 delay_before_vdev_stop,
1464 VAR_FLAGS_OPTIONAL |
1465 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1466 CFG_DELAY_BEFORE_VDEV_STOP_DEFAULT,
1467 CFG_DELAY_BEFORE_VDEV_STOP_MIN,
1468 CFG_DELAY_BEFORE_VDEV_STOP_MAX,
1469 cb_notify_set_delay_before_vdev_stop,
1470 0),
1471
1472 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_HI_RSSI_MAXCOUNT_NAME,
1473 WLAN_PARAM_Integer,
1474 struct hdd_config,
1475 nhi_rssi_scan_max_count,
1476 VAR_FLAGS_OPTIONAL |
1477 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1478 CFG_ROAM_SCAN_HI_RSSI_MAXCOUNT_DEFAULT,
1479 CFG_ROAM_SCAN_HI_RSSI_MAXCOUNT_MIN,
1480 CFG_ROAM_SCAN_HI_RSSI_MAXCOUNT_MAX,
1481 cb_notify_set_roam_scan_hi_rssi_scan_params,
1482 eCSR_HI_RSSI_SCAN_MAXCOUNT_ID),
1483
1484 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_HI_RSSI_DELTA_NAME,
1485 WLAN_PARAM_Integer,
1486 struct hdd_config,
1487 nhi_rssi_scan_rssi_delta,
1488 VAR_FLAGS_OPTIONAL |
1489 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1490 CFG_ROAM_SCAN_HI_RSSI_DELTA_DEFAULT,
1491 CFG_ROAM_SCAN_HI_RSSI_DELTA_MIN,
1492 CFG_ROAM_SCAN_HI_RSSI_DELTA_MAX,
1493 cb_notify_set_roam_scan_hi_rssi_scan_params,
1494 eCSR_HI_RSSI_SCAN_RSSI_DELTA_ID),
1495
1496 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_HI_RSSI_DELAY_NAME,
1497 WLAN_PARAM_Integer,
1498 struct hdd_config,
1499 nhi_rssi_scan_delay,
1500 VAR_FLAGS_OPTIONAL |
1501 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1502 CFG_ROAM_SCAN_HI_RSSI_DELAY_DEFAULT,
1503 CFG_ROAM_SCAN_HI_RSSI_DELAY_MIN,
1504 CFG_ROAM_SCAN_HI_RSSI_DELAY_MAX,
1505 cb_notify_set_roam_scan_hi_rssi_scan_params,
1506 eCSR_HI_RSSI_SCAN_DELAY_ID),
1507
1508 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_HI_RSSI_UB_NAME,
1509 WLAN_PARAM_SignedInteger,
1510 struct hdd_config,
1511 nhi_rssi_scan_rssi_ub,
1512 VAR_FLAGS_OPTIONAL |
1513 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1514 CFG_ROAM_SCAN_HI_RSSI_UB_DEFAULT,
1515 CFG_ROAM_SCAN_HI_RSSI_UB_MIN,
1516 CFG_ROAM_SCAN_HI_RSSI_UB_MAX,
1517 cb_notify_set_roam_scan_hi_rssi_scan_params,
1518 eCSR_HI_RSSI_SCAN_RSSI_UB_ID),
1519
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001520 REG_VARIABLE(CFG_QOS_WMM_BURST_SIZE_DEFN_NAME, WLAN_PARAM_Integer,
1521 struct hdd_config, burstSizeDefinition,
1522 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1523 CFG_QOS_WMM_BURST_SIZE_DEFN_DEFAULT,
1524 CFG_QOS_WMM_BURST_SIZE_DEFN_MIN,
1525 CFG_QOS_WMM_BURST_SIZE_DEFN_MAX),
1526
1527 REG_VARIABLE(CFG_MCAST_BCAST_FILTER_SETTING_NAME, WLAN_PARAM_Integer,
1528 struct hdd_config, mcastBcastFilterSetting,
1529 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1530 CFG_MCAST_BCAST_FILTER_SETTING_DEFAULT,
1531 CFG_MCAST_BCAST_FILTER_SETTING_MIN,
1532 CFG_MCAST_BCAST_FILTER_SETTING_MAX),
1533
1534 REG_VARIABLE(CFG_ENABLE_HOST_ARPOFFLOAD_NAME, WLAN_PARAM_Integer,
1535 struct hdd_config, fhostArpOffload,
1536 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1537 CFG_ENABLE_HOST_ARPOFFLOAD_DEFAULT,
1538 CFG_ENABLE_HOST_ARPOFFLOAD_MIN,
1539 CFG_ENABLE_HOST_ARPOFFLOAD_MAX),
1540
1541#ifdef FEATURE_WLAN_RA_FILTERING
1542 REG_VARIABLE(CFG_RA_FILTER_ENABLE_NAME, WLAN_PARAM_Integer,
1543 struct hdd_config, IsRArateLimitEnabled,
1544 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1545 CFG_RA_FILTER_ENABLE_DEFAULT,
1546 CFG_RA_FILTER_ENABLE_MIN,
1547 CFG_RA_FILTER_ENABLE_MAX),
1548
1549 REG_VARIABLE(CFG_RA_RATE_LIMIT_INTERVAL_NAME, WLAN_PARAM_Integer,
1550 struct hdd_config, RArateLimitInterval,
1551 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1552 CFG_RA_RATE_LIMIT_INTERVAL_DEFAULT,
1553 CFG_RA_RATE_LIMIT_INTERVAL_MIN,
1554 CFG_RA_RATE_LIMIT_INTERVAL_MAX),
1555#endif
1556
1557 REG_VARIABLE(CFG_IGNORE_PEER_ERP_INFO_NAME, WLAN_PARAM_Integer,
1558 struct hdd_config, ignore_peer_erp_info,
1559 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1560 CFG_IGNORE_PEER_ERP_INFO_DEFAULT,
1561 CFG_IGNORE_PEER_ERP_INFO_MIN,
1562 CFG_IGNORE_PEER_ERP_INFO_MAX),
1563
1564 REG_VARIABLE(CFG_ENABLE_HOST_SSDP_NAME, WLAN_PARAM_Integer,
1565 struct hdd_config, ssdp,
1566 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1567 CFG_ENABLE_HOST_SSDP_DEFAULT,
1568 CFG_ENABLE_HOST_SSDP_MIN,
1569 CFG_ENABLE_HOST_SSDP_MAX),
1570
1571 REG_VARIABLE(CFG_ENABLE_HOST_NSOFFLOAD_NAME, WLAN_PARAM_Integer,
1572 struct hdd_config, fhostNSOffload,
1573 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1574 CFG_ENABLE_HOST_NSOFFLOAD_DEFAULT,
1575 CFG_ENABLE_HOST_NSOFFLOAD_MIN,
1576 CFG_ENABLE_HOST_NSOFFLOAD_MAX),
1577
1578 REG_VARIABLE(CFG_QOS_WMM_TS_INFO_ACK_POLICY_NAME, WLAN_PARAM_HexInteger,
1579 struct hdd_config, tsInfoAckPolicy,
1580 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1581 CFG_QOS_WMM_TS_INFO_ACK_POLICY_DEFAULT,
1582 CFG_QOS_WMM_TS_INFO_ACK_POLICY_MIN,
1583 CFG_QOS_WMM_TS_INFO_ACK_POLICY_MAX),
1584
1585 REG_VARIABLE(CFG_SINGLE_TID_RC_NAME, WLAN_PARAM_Integer,
1586 struct hdd_config, bSingleTidRc,
1587 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1588 CFG_SINGLE_TID_RC_DEFAULT,
1589 CFG_SINGLE_TID_RC_MIN,
1590 CFG_SINGLE_TID_RC_MAX),
1591
1592 REG_VARIABLE(CFG_DYNAMIC_PSPOLL_VALUE_NAME, WLAN_PARAM_Integer,
1593 struct hdd_config, dynamicPsPollValue,
1594 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1595 CFG_DYNAMIC_PSPOLL_VALUE_DEFAULT,
1596 CFG_DYNAMIC_PSPOLL_VALUE_MIN,
1597 CFG_DYNAMIC_PSPOLL_VALUE_MAX),
1598
1599 REG_VARIABLE(CFG_TELE_BCN_WAKEUP_EN_NAME, WLAN_PARAM_Integer,
1600 struct hdd_config, teleBcnWakeupEn,
1601 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1602 CFG_TELE_BCN_WAKEUP_EN_DEFAULT,
1603 CFG_TELE_BCN_WAKEUP_EN_MIN,
1604 CFG_TELE_BCN_WAKEUP_EN_MAX),
1605
1606 REG_VARIABLE(CFG_INFRA_STA_KEEP_ALIVE_PERIOD_NAME, WLAN_PARAM_Integer,
1607 struct hdd_config, infraStaKeepAlivePeriod,
1608 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1609 CFG_INFRA_STA_KEEP_ALIVE_PERIOD_DEFAULT,
1610 CFG_INFRA_STA_KEEP_ALIVE_PERIOD_MIN,
1611 CFG_INFRA_STA_KEEP_ALIVE_PERIOD_MAX),
1612
1613 REG_VARIABLE(CFG_QOS_ADDTS_WHEN_ACM_IS_OFF_NAME, WLAN_PARAM_Integer,
1614 struct hdd_config, AddTSWhenACMIsOff,
1615 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1616 CFG_QOS_ADDTS_WHEN_ACM_IS_OFF_DEFAULT,
1617 CFG_QOS_ADDTS_WHEN_ACM_IS_OFF_MIN,
1618 CFG_QOS_ADDTS_WHEN_ACM_IS_OFF_MAX),
1619
1620 REG_VARIABLE(CFG_VALIDATE_SCAN_LIST_NAME, WLAN_PARAM_Integer,
1621 struct hdd_config, fValidateScanList,
1622 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1623 CFG_VALIDATE_SCAN_LIST_DEFAULT,
1624 CFG_VALIDATE_SCAN_LIST_MIN,
1625 CFG_VALIDATE_SCAN_LIST_MAX),
1626
1627 REG_VARIABLE(CFG_NULLDATA_AP_RESP_TIMEOUT_NAME, WLAN_PARAM_Integer,
1628 struct hdd_config, nNullDataApRespTimeout,
1629 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1630 CFG_NULLDATA_AP_RESP_TIMEOUT_DEFAULT,
1631 CFG_NULLDATA_AP_RESP_TIMEOUT_MIN,
1632 CFG_NULLDATA_AP_RESP_TIMEOUT_MAX),
1633
1634 REG_VARIABLE(CFG_AP_DATA_AVAIL_POLL_PERIOD_NAME, WLAN_PARAM_Integer,
1635 struct hdd_config, apDataAvailPollPeriodInMs,
1636 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1637 CFG_AP_DATA_AVAIL_POLL_PERIOD_DEFAULT,
1638 CFG_AP_DATA_AVAIL_POLL_PERIOD_MIN,
1639 CFG_AP_DATA_AVAIL_POLL_PERIOD_MAX),
1640
1641 REG_VARIABLE(CFG_BAND_CAPABILITY_NAME, WLAN_PARAM_Integer,
1642 struct hdd_config, nBandCapability,
1643 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1644 CFG_BAND_CAPABILITY_DEFAULT,
1645 CFG_BAND_CAPABILITY_MIN,
1646 CFG_BAND_CAPABILITY_MAX),
1647
1648 REG_VARIABLE(CFG_ENABLE_BEACON_EARLY_TERMINATION_NAME,
1649 WLAN_PARAM_Integer,
1650 struct hdd_config, fEnableBeaconEarlyTermination,
1651 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1652 CFG_ENABLE_BEACON_EARLY_TERMINATION_DEFAULT,
1653 CFG_ENABLE_BEACON_EARLY_TERMINATION_MIN,
1654 CFG_ENABLE_BEACON_EARLY_TERMINATION_MAX),
1655
1656/* CFG_CDF_TRACE_ENABLE Parameters */
1657 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_WDI_NAME, WLAN_PARAM_Integer,
1658 struct hdd_config, cdf_trace_enable_wdi,
1659 VAR_FLAGS_OPTIONAL,
1660 CFG_CDF_TRACE_ENABLE_DEFAULT,
1661 CFG_CDF_TRACE_ENABLE_MIN,
1662 CFG_CDF_TRACE_ENABLE_MAX),
1663
1664 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_HDD_NAME, WLAN_PARAM_Integer,
1665 struct hdd_config, cdf_trace_enable_hdd,
1666 VAR_FLAGS_OPTIONAL,
1667 CFG_CDF_TRACE_ENABLE_DEFAULT,
1668 CFG_CDF_TRACE_ENABLE_MIN,
1669 CFG_CDF_TRACE_ENABLE_MAX),
1670
1671 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_BMI_NAME, WLAN_PARAM_Integer,
1672 struct hdd_config, cdf_trace_enable_bmi,
1673 VAR_FLAGS_OPTIONAL,
1674 CFG_CDF_TRACE_ENABLE_DEFAULT,
1675 CFG_CDF_TRACE_ENABLE_MIN,
1676 CFG_CDF_TRACE_ENABLE_MAX),
1677
1678 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_SME_NAME, WLAN_PARAM_Integer,
1679 struct hdd_config, cdf_trace_enable_sme,
1680 VAR_FLAGS_OPTIONAL,
1681 CFG_CDF_TRACE_ENABLE_DEFAULT,
1682 CFG_CDF_TRACE_ENABLE_MIN,
1683 CFG_CDF_TRACE_ENABLE_MAX),
1684
1685 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_PE_NAME, WLAN_PARAM_Integer,
1686 struct hdd_config, cdf_trace_enable_pe,
1687 VAR_FLAGS_OPTIONAL,
1688 CFG_CDF_TRACE_ENABLE_DEFAULT,
1689 CFG_CDF_TRACE_ENABLE_MIN,
1690 CFG_CDF_TRACE_ENABLE_MAX),
1691
1692 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_WMA_NAME, WLAN_PARAM_Integer,
1693 struct hdd_config, cdf_trace_enable_wma,
1694 VAR_FLAGS_OPTIONAL,
1695 CFG_CDF_TRACE_ENABLE_DEFAULT,
1696 CFG_CDF_TRACE_ENABLE_MIN,
1697 CFG_CDF_TRACE_ENABLE_MAX),
1698
1699 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_SYS_NAME, WLAN_PARAM_Integer,
1700 struct hdd_config, cdf_trace_enable_sys,
1701 VAR_FLAGS_OPTIONAL,
1702 CFG_CDF_TRACE_ENABLE_DEFAULT,
1703 CFG_CDF_TRACE_ENABLE_MIN,
1704 CFG_CDF_TRACE_ENABLE_MAX),
1705
1706 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_CDF_NAME, WLAN_PARAM_Integer,
1707 struct hdd_config, cdf_trace_enable_cdf,
1708 VAR_FLAGS_OPTIONAL,
1709 CFG_CDF_TRACE_ENABLE_DEFAULT,
1710 CFG_CDF_TRACE_ENABLE_MIN,
1711 CFG_CDF_TRACE_ENABLE_MAX),
1712
1713 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_SAP_NAME, WLAN_PARAM_Integer,
1714 struct hdd_config, cdf_trace_enable_sap,
1715 VAR_FLAGS_OPTIONAL,
1716 CFG_CDF_TRACE_ENABLE_DEFAULT,
1717 CFG_CDF_TRACE_ENABLE_MIN,
1718 CFG_CDF_TRACE_ENABLE_MAX),
1719
1720 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_HDD_SAP_NAME, WLAN_PARAM_Integer,
1721 struct hdd_config, cdf_trace_enable_hdd_sap,
1722 VAR_FLAGS_OPTIONAL,
1723 CFG_CDF_TRACE_ENABLE_DEFAULT,
1724 CFG_CDF_TRACE_ENABLE_MIN,
1725 CFG_CDF_TRACE_ENABLE_MAX),
1726
Bhargav Shah480a90f2015-06-24 15:10:14 +05301727 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_CFG_NAME, WLAN_PARAM_Integer,
1728 struct hdd_config, cdf_trace_enable_cfg,
1729 VAR_FLAGS_OPTIONAL,
1730 CFG_CDF_TRACE_ENABLE_DEFAULT,
1731 CFG_CDF_TRACE_ENABLE_MIN,
1732 CFG_CDF_TRACE_ENABLE_MAX),
1733
1734 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_TXRX_NAME, WLAN_PARAM_Integer,
1735 struct hdd_config, cfd_trace_enable_txrx,
1736 VAR_FLAGS_OPTIONAL,
1737 CFG_CDF_TRACE_ENABLE_DEFAULT,
1738 CFG_CDF_TRACE_ENABLE_MIN,
1739 CFG_CDF_TRACE_ENABLE_MAX),
1740
1741 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_HTC_NAME, WLAN_PARAM_Integer,
1742 struct hdd_config, cdf_trace_enable_htc,
1743 VAR_FLAGS_OPTIONAL,
1744 CFG_CDF_TRACE_ENABLE_DEFAULT,
1745 CFG_CDF_TRACE_ENABLE_MIN,
1746 CFG_CDF_TRACE_ENABLE_MAX),
1747
1748 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_HIF_NAME, WLAN_PARAM_Integer,
1749 struct hdd_config, cdf_trace_enable_hif,
1750 VAR_FLAGS_OPTIONAL,
1751 CFG_CDF_TRACE_ENABLE_DEFAULT,
1752 CFG_CDF_TRACE_ENABLE_MIN,
1753 CFG_CDF_TRACE_ENABLE_MAX),
1754
1755 REG_VARIABLE(CFG_CDR_TRACE_ENABLE_HDD_SAP_DATA_NAME, WLAN_PARAM_Integer,
1756 struct hdd_config, cdf_trace_enable_hdd_sap_data,
1757 VAR_FLAGS_OPTIONAL,
1758 CFG_CDF_TRACE_ENABLE_DEFAULT,
1759 CFG_CDF_TRACE_ENABLE_MIN,
1760 CFG_CDF_TRACE_ENABLE_MAX),
1761
1762 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_HDD_DATA_NAME, WLAN_PARAM_Integer,
1763 struct hdd_config, cdf_trace_enable_hdd_data,
1764 VAR_FLAGS_OPTIONAL,
1765 CFG_CDF_TRACE_ENABLE_DEFAULT,
1766 CFG_CDF_TRACE_ENABLE_MIN,
1767 CFG_CDF_TRACE_ENABLE_MAX),
1768
1769 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_EPPING, WLAN_PARAM_Integer,
1770 struct hdd_config, cdf_trace_enable_epping,
1771 VAR_FLAGS_OPTIONAL,
1772 CFG_CDF_TRACE_ENABLE_DEFAULT,
1773 CFG_CDF_TRACE_ENABLE_MIN,
1774 CFG_CDF_TRACE_ENABLE_MAX),
1775
1776 REG_VARIABLE(CFG_CDF_TRACE_ENABLE_CDF_DEVICES, WLAN_PARAM_Integer,
1777 struct hdd_config, cdf_trace_enable_cdf_devices,
1778 VAR_FLAGS_OPTIONAL,
1779 CFG_CDF_TRACE_ENABLE_DEFAULT,
1780 CFG_CDF_TRACE_ENABLE_MIN,
1781 CFG_CDF_TRACE_ENABLE_MAX),
1782
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001783 REG_VARIABLE(CFG_TELE_BCN_TRANS_LI_NAME, WLAN_PARAM_Integer,
1784 struct hdd_config, nTeleBcnTransListenInterval,
1785 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1786 CFG_TELE_BCN_TRANS_LI_DEFAULT,
1787 CFG_TELE_BCN_TRANS_LI_MIN,
1788 CFG_TELE_BCN_TRANS_LI_MAX),
1789
1790 REG_VARIABLE(CFG_TELE_BCN_TRANS_LI_NUM_IDLE_BCNS_NAME,
1791 WLAN_PARAM_Integer,
1792 struct hdd_config, nTeleBcnTransLiNumIdleBeacons,
1793 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1794 CFG_TELE_BCN_TRANS_LI_NUM_IDLE_BCNS_DEFAULT,
1795 CFG_TELE_BCN_TRANS_LI_NUM_IDLE_BCNS_MIN,
1796 CFG_TELE_BCN_TRANS_LI_NUM_IDLE_BCNS_MAX),
1797
1798 REG_VARIABLE(CFG_TELE_BCN_MAX_LI_NAME, WLAN_PARAM_Integer,
1799 struct hdd_config, nTeleBcnMaxListenInterval,
1800 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1801 CFG_TELE_BCN_MAX_LI_DEFAULT,
1802 CFG_TELE_BCN_MAX_LI_MIN,
1803 CFG_TELE_BCN_MAX_LI_MAX),
1804
1805 REG_VARIABLE(CFG_TELE_BCN_MAX_LI_NUM_IDLE_BCNS_NAME, WLAN_PARAM_Integer,
1806 struct hdd_config, nTeleBcnMaxLiNumIdleBeacons,
1807 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1808 CFG_TELE_BCN_MAX_LI_NUM_IDLE_BCNS_DEFAULT,
1809 CFG_TELE_BCN_MAX_LI_NUM_IDLE_BCNS_MIN,
1810 CFG_TELE_BCN_MAX_LI_NUM_IDLE_BCNS_MAX),
1811
1812 REG_VARIABLE(CFG_BCN_EARLY_TERM_WAKE_NAME, WLAN_PARAM_Integer,
1813 struct hdd_config, bcnEarlyTermWakeInterval,
1814 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1815 CFG_BCN_EARLY_TERM_WAKE_DEFAULT,
1816 CFG_BCN_EARLY_TERM_WAKE_MIN,
1817 CFG_BCN_EARLY_TERM_WAKE_MAX),
1818
1819 REG_VARIABLE(CFG_AP_DATA_AVAIL_POLL_PERIOD_NAME, WLAN_PARAM_Integer,
1820 struct hdd_config, apDataAvailPollPeriodInMs,
1821 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1822 CFG_AP_DATA_AVAIL_POLL_PERIOD_DEFAULT,
1823 CFG_AP_DATA_AVAIL_POLL_PERIOD_MIN,
1824 CFG_AP_DATA_AVAIL_POLL_PERIOD_MAX),
1825
1826 REG_VARIABLE(CFG_ENABLE_CLOSE_LOOP_NAME, WLAN_PARAM_Integer,
1827 struct hdd_config, enableCloseLoop,
1828 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1829 CFG_ENABLE_CLOSE_LOOP_DEFAULT,
1830 CFG_ENABLE_CLOSE_LOOP_MIN,
1831 CFG_ENABLE_CLOSE_LOOP_MAX),
1832
1833 REG_VARIABLE(CFG_ENABLE_BYPASS_11D_NAME, WLAN_PARAM_Integer,
1834 struct hdd_config, enableBypass11d,
1835 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1836 CFG_ENABLE_BYPASS_11D_DEFAULT,
1837 CFG_ENABLE_BYPASS_11D_MIN,
1838 CFG_ENABLE_BYPASS_11D_MAX),
1839
1840 REG_VARIABLE(CFG_ENABLE_DFS_CHNL_SCAN_NAME, WLAN_PARAM_Integer,
1841 struct hdd_config, enableDFSChnlScan,
1842 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1843 CFG_ENABLE_DFS_CHNL_SCAN_DEFAULT,
1844 CFG_ENABLE_DFS_CHNL_SCAN_MIN,
1845 CFG_ENABLE_DFS_CHNL_SCAN_MAX),
1846
1847 REG_VARIABLE(CFG_ENABLE_DFS_PNO_CHNL_SCAN_NAME, WLAN_PARAM_Integer,
1848 struct hdd_config, enable_dfs_pno_chnl_scan,
1849 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1850 CFG_ENABLE_DFS_PNO_CHNL_SCAN_DEFAULT,
1851 CFG_ENABLE_DFS_PNO_CHNL_SCAN_MIN,
1852 CFG_ENABLE_DFS_PNO_CHNL_SCAN_MAX),
1853
1854 REG_VARIABLE(CFG_ENABLE_DYNAMIC_DTIM_NAME, WLAN_PARAM_Integer,
1855 struct hdd_config, enableDynamicDTIM,
1856 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1857 CFG_ENABLE_DYNAMIC_DTIM_DEFAULT,
1858 CFG_ENABLE_DYNAMIC_DTIM_MIN,
1859 CFG_ENABLE_DYNAMIC_DTIM_MAX),
1860
1861 REG_VARIABLE(CFG_ENABLE_AUTOMATIC_TX_POWER_CONTROL_NAME,
1862 WLAN_PARAM_Integer,
1863 struct hdd_config, enableAutomaticTxPowerControl,
1864 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1865 CFG_ENABLE_AUTOMATIC_TX_POWER_CONTROL_DEFAULT,
1866 CFG_ENABLE_AUTOMATIC_TX_POWER_CONTROL_MIN,
1867 CFG_ENABLE_AUTOMATIC_TX_POWER_CONTROL_MAX),
1868
1869 REG_VARIABLE(CFG_SHORT_GI_40MHZ_NAME, WLAN_PARAM_Integer,
1870 struct hdd_config, ShortGI40MhzEnable,
1871 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1872 CFG_SHORT_GI_40MHZ_DEFAULT,
1873 CFG_SHORT_GI_40MHZ_MIN,
1874 CFG_SHORT_GI_40MHZ_MAX),
1875
1876 REG_DYNAMIC_VARIABLE(CFG_REPORT_MAX_LINK_SPEED, WLAN_PARAM_Integer,
1877 struct hdd_config, reportMaxLinkSpeed,
1878 VAR_FLAGS_OPTIONAL |
1879 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1880 CFG_REPORT_MAX_LINK_SPEED_DEFAULT,
1881 CFG_REPORT_MAX_LINK_SPEED_MIN,
1882 CFG_REPORT_MAX_LINK_SPEED_MAX,
1883 NULL, 0),
1884
1885 REG_DYNAMIC_VARIABLE(CFG_LINK_SPEED_RSSI_HIGH, WLAN_PARAM_SignedInteger,
1886 struct hdd_config, linkSpeedRssiHigh,
1887 VAR_FLAGS_OPTIONAL |
1888 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1889 CFG_LINK_SPEED_RSSI_HIGH_DEFAULT,
1890 CFG_LINK_SPEED_RSSI_HIGH_MIN,
1891 CFG_LINK_SPEED_RSSI_HIGH_MAX,
1892 NULL, 0),
1893
1894 REG_DYNAMIC_VARIABLE(CFG_LINK_SPEED_RSSI_MID, WLAN_PARAM_SignedInteger,
1895 struct hdd_config, linkSpeedRssiMid,
1896 VAR_FLAGS_OPTIONAL |
1897 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1898 CFG_LINK_SPEED_RSSI_MID_DEFAULT,
1899 CFG_LINK_SPEED_RSSI_MID_MIN,
1900 CFG_LINK_SPEED_RSSI_MID_MAX,
1901 NULL, 0),
1902
1903 REG_DYNAMIC_VARIABLE(CFG_LINK_SPEED_RSSI_LOW, WLAN_PARAM_SignedInteger,
1904 struct hdd_config, linkSpeedRssiLow,
1905 VAR_FLAGS_OPTIONAL |
1906 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1907 CFG_LINK_SPEED_RSSI_LOW_DEFAULT,
1908 CFG_LINK_SPEED_RSSI_LOW_MIN,
1909 CFG_LINK_SPEED_RSSI_LOW_MAX,
1910 NULL, 0),
1911
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001912 REG_DYNAMIC_VARIABLE(CFG_ROAM_PREFER_5GHZ, WLAN_PARAM_Integer,
1913 struct hdd_config, nRoamPrefer5GHz,
1914 VAR_FLAGS_OPTIONAL |
1915 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1916 CFG_ROAM_PREFER_5GHZ_DEFAULT,
1917 CFG_ROAM_PREFER_5GHZ_MIN,
1918 CFG_ROAM_PREFER_5GHZ_MAX,
1919 cb_notify_set_roam_prefer5_g_hz, 0),
1920
1921 REG_DYNAMIC_VARIABLE(CFG_ROAM_INTRA_BAND, WLAN_PARAM_Integer,
1922 struct hdd_config, nRoamIntraBand,
1923 VAR_FLAGS_OPTIONAL |
1924 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1925 CFG_ROAM_INTRA_BAND_DEFAULT,
1926 CFG_ROAM_INTRA_BAND_MIN,
1927 CFG_ROAM_INTRA_BAND_MAX,
1928 cb_notify_set_roam_intra_band, 0),
1929
1930 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_N_PROBES, WLAN_PARAM_Integer,
1931 struct hdd_config, nProbes,
1932 VAR_FLAGS_OPTIONAL |
1933 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1934 CFG_ROAM_SCAN_N_PROBES_DEFAULT,
1935 CFG_ROAM_SCAN_N_PROBES_MIN,
1936 CFG_ROAM_SCAN_N_PROBES_MAX,
1937 cb_notify_set_roam_scan_n_probes, 0),
1938
1939 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_HOME_AWAY_TIME, WLAN_PARAM_Integer,
1940 struct hdd_config, nRoamScanHomeAwayTime,
1941 VAR_FLAGS_OPTIONAL |
1942 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1943 CFG_ROAM_SCAN_HOME_AWAY_TIME_DEFAULT,
1944 CFG_ROAM_SCAN_HOME_AWAY_TIME_MIN,
1945 CFG_ROAM_SCAN_HOME_AWAY_TIME_MAX,
1946 cb_notify_set_roam_scan_home_away_time, 0),
1947
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001948 REG_VARIABLE(CFG_P2P_DEVICE_ADDRESS_ADMINISTRATED_NAME,
1949 WLAN_PARAM_Integer,
1950 struct hdd_config, isP2pDeviceAddrAdministrated,
1951 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1952 CFG_P2P_DEVICE_ADDRESS_ADMINISTRATED_DEFAULT,
1953 CFG_P2P_DEVICE_ADDRESS_ADMINISTRATED_MIN,
1954 CFG_P2P_DEVICE_ADDRESS_ADMINISTRATED_MAX),
1955
1956 REG_VARIABLE(CFG_ENABLE_MCC_ENABLED_NAME, WLAN_PARAM_Integer,
1957 struct hdd_config, enableMCC,
1958 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1959 CFG_ENABLE_MCC_ENABLED_DEFAULT,
1960 CFG_ENABLE_MCC_ENABLED_MIN,
1961 CFG_ENABLE_MCC_ENABLED_MAX),
1962
1963 REG_VARIABLE(CFG_ALLOW_MCC_GO_DIFF_BI_NAME, WLAN_PARAM_Integer,
1964 struct hdd_config, allowMCCGODiffBI,
1965 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1966 CFG_ALLOW_MCC_GO_DIFF_BI_DEFAULT,
1967 CFG_ALLOW_MCC_GO_DIFF_BI_MIN,
1968 CFG_ALLOW_MCC_GO_DIFF_BI_MAX),
1969
1970 REG_VARIABLE(CFG_THERMAL_MIGRATION_ENABLE_NAME, WLAN_PARAM_Integer,
1971 struct hdd_config, thermalMitigationEnable,
1972 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1973 CFG_THERMAL_MIGRATION_ENABLE_DEFAULT,
1974 CFG_THERMAL_MIGRATION_ENABLE_MIN,
1975 CFG_THERMAL_MIGRATION_ENABLE_MAX),
1976
1977 REG_VARIABLE(CFG_THROTTLE_PERIOD_NAME, WLAN_PARAM_Integer,
1978 struct hdd_config, throttlePeriod,
1979 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1980 CFG_THROTTLE_PERIOD_DEFAULT,
1981 CFG_THROTTLE_PERIOD_MIN,
1982 CFG_THROTTLE_PERIOD_MAX),
1983
1984 REG_VARIABLE(CFG_ENABLE_MODULATED_DTIM_NAME, WLAN_PARAM_Integer,
1985 struct hdd_config, enableModulatedDTIM,
1986 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1987 CFG_ENABLE_MODULATED_DTIM_DEFAULT,
1988 CFG_ENABLE_MODULATED_DTIM_MIN,
1989 CFG_ENABLE_MODULATED_DTIM_MAX),
1990
1991 REG_VARIABLE(CFG_MC_ADDR_LIST_ENABLE_NAME, WLAN_PARAM_Integer,
1992 struct hdd_config, fEnableMCAddrList,
1993 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1994 CFG_MC_ADDR_LIST_ENABLE_DEFAULT,
1995 CFG_MC_ADDR_LIST_ENABLE_MIN,
1996 CFG_MC_ADDR_LIST_ENABLE_MAX),
1997
1998#ifdef WLAN_FEATURE_11AC
1999 REG_VARIABLE(CFG_VHT_CHANNEL_WIDTH, WLAN_PARAM_Integer,
2000 struct hdd_config, vhtChannelWidth,
2001 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2002 CFG_VHT_CHANNEL_WIDTH_DEFAULT,
2003 CFG_VHT_CHANNEL_WIDTH_MIN,
2004 CFG_VHT_CHANNEL_WIDTH_MAX),
2005
2006 REG_VARIABLE(CFG_VHT_ENABLE_RX_MCS_8_9, WLAN_PARAM_Integer,
2007 struct hdd_config, vhtRxMCS,
2008 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2009 CFG_VHT_ENABLE_RX_MCS_8_9_DEFAULT,
2010 CFG_VHT_ENABLE_RX_MCS_8_9_MIN,
2011 CFG_VHT_ENABLE_RX_MCS_8_9_MAX),
2012
2013 REG_VARIABLE(CFG_VHT_ENABLE_TX_MCS_8_9, WLAN_PARAM_Integer,
2014 struct hdd_config, vhtTxMCS,
2015 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2016 CFG_VHT_ENABLE_TX_MCS_8_9_DEFAULT,
2017 CFG_VHT_ENABLE_TX_MCS_8_9_MIN,
2018 CFG_VHT_ENABLE_TX_MCS_8_9_MAX),
2019
2020 REG_VARIABLE(CFG_VHT_ENABLE_RX_MCS2x2_8_9, WLAN_PARAM_Integer,
2021 struct hdd_config, vhtRxMCS2x2,
2022 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2023 CFG_VHT_ENABLE_RX_MCS2x2_8_9_DEFAULT,
2024 CFG_VHT_ENABLE_RX_MCS2x2_8_9_MIN,
2025 CFG_VHT_ENABLE_RX_MCS2x2_8_9_MAX),
2026
2027 REG_VARIABLE(CFG_VHT_ENABLE_TX_MCS2x2_8_9, WLAN_PARAM_Integer,
2028 struct hdd_config, vhtTxMCS2x2,
2029 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2030 CFG_VHT_ENABLE_TX_MCS2x2_8_9_DEFAULT,
2031 CFG_VHT_ENABLE_TX_MCS2x2_8_9_MIN,
2032 CFG_VHT_ENABLE_TX_MCS2x2_8_9_MAX),
2033
2034 REG_VARIABLE(CFG_VHT_ENABLE_2x2_CAP_FEATURE, WLAN_PARAM_Integer,
2035 struct hdd_config, enable2x2,
2036 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2037 CFG_VHT_ENABLE_2x2_CAP_FEATURE_DEFAULT,
2038 CFG_VHT_ENABLE_2x2_CAP_FEATURE_MIN,
2039 CFG_VHT_ENABLE_2x2_CAP_FEATURE_MAX),
2040
2041 REG_VARIABLE(CFG_VHT_ENABLE_MU_BFORMEE_CAP_FEATURE, WLAN_PARAM_Integer,
2042 struct hdd_config, enableMuBformee,
2043 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2044 CFG_VHT_ENABLE_MU_BFORMEE_CAP_FEATURE_DEFAULT,
2045 CFG_VHT_ENABLE_MU_BFORMEE_CAP_FEATURE_MIN,
2046 CFG_VHT_ENABLE_MU_BFORMEE_CAP_FEATURE_MAX),
2047
2048 REG_VARIABLE(CFG_VHT_ENABLE_PAID_FEATURE, WLAN_PARAM_Integer,
2049 struct hdd_config, enableVhtpAid,
2050 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2051 CFG_VHT_ENABLE_PAID_FEATURE_DEFAULT,
2052 CFG_VHT_ENABLE_PAID_FEATURE_MIN,
2053 CFG_VHT_ENABLE_PAID_FEATURE_MAX),
2054
2055 REG_VARIABLE(CFG_VHT_ENABLE_GID_FEATURE, WLAN_PARAM_Integer,
2056 struct hdd_config, enableVhtGid,
2057 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2058 CFG_VHT_ENABLE_GID_FEATURE_DEFAULT,
2059 CFG_VHT_ENABLE_GID_FEATURE_MIN,
2060 CFG_VHT_ENABLE_GID_FEATURE_MAX),
2061#endif
2062
2063 REG_VARIABLE(CFG_VHT_ENABLE_1x1_TX_CHAINMASK, WLAN_PARAM_Integer,
2064 struct hdd_config, txchainmask1x1,
2065 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2066 CFG_VHT_ENABLE_1x1_TX_CHAINMASK_DEFAULT,
2067 CFG_VHT_ENABLE_1x1_TX_CHAINMASK_MIN,
2068 CFG_VHT_ENABLE_1x1_TX_CHAINMASK_MAX),
2069
2070 REG_VARIABLE(CFG_VHT_ENABLE_1x1_RX_CHAINMASK, WLAN_PARAM_Integer,
2071 struct hdd_config, rxchainmask1x1,
2072 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2073 CFG_VHT_ENABLE_1x1_RX_CHAINMASK_DEFAULT,
2074 CFG_VHT_ENABLE_1x1_RX_CHAINMASK_MIN,
2075 CFG_VHT_ENABLE_1x1_RX_CHAINMASK_MAX),
2076
2077 REG_VARIABLE(CFG_ENABLE_AMPDUPS_FEATURE, WLAN_PARAM_Integer,
2078 struct hdd_config, enableAmpduPs,
2079 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2080 CFG_ENABLE_AMPDUPS_FEATURE_DEFAULT,
2081 CFG_ENABLE_AMPDUPS_FEATURE_MIN,
2082 CFG_ENABLE_AMPDUPS_FEATURE_MAX),
2083
2084 REG_VARIABLE(CFG_HT_ENABLE_SMPS_CAP_FEATURE, WLAN_PARAM_Integer,
2085 struct hdd_config, enableHtSmps,
2086 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2087 CFG_HT_ENABLE_SMPS_CAP_FEATURE_DEFAULT,
2088 CFG_HT_ENABLE_SMPS_CAP_FEATURE_MIN,
2089 CFG_HT_ENABLE_SMPS_CAP_FEATURE_MAX),
2090
2091 REG_VARIABLE(CFG_HT_SMPS_CAP_FEATURE, WLAN_PARAM_Integer,
2092 struct hdd_config, htSmps,
2093 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2094 CFG_HT_SMPS_CAP_FEATURE_DEFAULT,
2095 CFG_HT_SMPS_CAP_FEATURE_MIN,
2096 CFG_HT_SMPS_CAP_FEATURE_MAX),
2097
2098 REG_VARIABLE(CFG_DISABLE_DFS_CH_SWITCH, WLAN_PARAM_Integer,
2099 struct hdd_config, disableDFSChSwitch,
2100 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2101 CFG_DISABLE_DFS_CH_SWITCH_DEFAULT,
2102 CFG_DISABLE_DFS_CH_SWITCH_MIN,
2103 CFG_DISABLE_DFS_CH_SWITCH_MAX),
2104
2105 REG_VARIABLE(CFG_ENABLE_DFS_MASTER_CAPABILITY, WLAN_PARAM_Integer,
2106 struct hdd_config, enableDFSMasterCap,
2107 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2108 CFG_ENABLE_DFS_MASTER_CAPABILITY_DEFAULT,
2109 CFG_ENABLE_DFS_MASTER_CAPABILITY_MIN,
2110 CFG_ENABLE_DFS_MASTER_CAPABILITY_MAX),
2111
2112 REG_DYNAMIC_VARIABLE(CFG_SAP_PREFERRED_CHANNEL_LOCATION,
2113 WLAN_PARAM_Integer,
2114 struct hdd_config, gSapPreferredChanLocation,
2115 VAR_FLAGS_OPTIONAL |
2116 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2117 CFG_SAP_PREFERRED_CHANNEL_LOCATION_DEFAULT,
2118 CFG_SAP_PREFERRED_CHANNEL_LOCATION_MIN,
2119 CFG_SAP_PREFERRED_CHANNEL_LOCATION_MAX,
2120 cb_notify_set_g_sap_preferred_chan_location, 0),
2121 REG_DYNAMIC_VARIABLE(CFG_DISABLE_DFS_JAPAN_W53, WLAN_PARAM_Integer,
2122 struct hdd_config, gDisableDfsJapanW53,
2123 VAR_FLAGS_OPTIONAL |
2124 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2125 CFG_DISABLE_DFS_JAPAN_W53_DEFAULT,
2126 CFG_DISABLE_DFS_JAPAN_W53_MIN,
2127 CFG_DISABLE_DFS_JAPAN_W53_MAX,
2128 ch_notify_set_g_disable_dfs_japan_w53, 0),
2129 REG_VARIABLE(CFG_ENABLE_FIRST_SCAN_2G_ONLY_NAME, WLAN_PARAM_Integer,
2130 struct hdd_config, enableFirstScan2GOnly,
2131 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2132 CFG_ENABLE_FIRST_SCAN_2G_ONLY_DEFAULT,
2133 CFG_ENABLE_FIRST_SCAN_2G_ONLY_MIN,
2134 CFG_ENABLE_FIRST_SCAN_2G_ONLY_MAX),
2135
2136 REG_VARIABLE(CFG_ENABLE_SKIP_DFS_IN_P2P_SEARCH_NAME, WLAN_PARAM_Integer,
2137 struct hdd_config, skipDfsChnlInP2pSearch,
2138 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2139 CFG_ENABLE_SKIP_DFS_IN_P2P_SEARCH_DEFAULT,
2140 CFG_ENABLE_SKIP_DFS_IN_P2P_SEARCH_MIN,
2141 CFG_ENABLE_SKIP_DFS_IN_P2P_SEARCH_MAX),
2142
2143 REG_VARIABLE(CFG_IGNORE_DYNAMIC_DTIM_IN_P2P_MODE_NAME,
2144 WLAN_PARAM_Integer,
2145 struct hdd_config, ignoreDynamicDtimInP2pMode,
2146 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2147 CFG_IGNORE_DYNAMIC_DTIM_IN_P2P_MODE_DEFAULT,
2148 CFG_IGNORE_DYNAMIC_DTIM_IN_P2P_MODE_MIN,
2149 CFG_IGNORE_DYNAMIC_DTIM_IN_P2P_MODE_MAX),
2150
2151 REG_VARIABLE(CFG_ENABLE_RX_STBC, WLAN_PARAM_Integer,
2152 struct hdd_config, enableRxSTBC,
2153 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2154 CFG_ENABLE_RX_STBC_DEFAULT,
2155 CFG_ENABLE_RX_STBC_MIN,
2156 CFG_ENABLE_RX_STBC_MAX),
2157
2158 REG_VARIABLE(CFG_ENABLE_TX_STBC, WLAN_PARAM_Integer,
2159 struct hdd_config, enableTxSTBC,
2160 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2161 CFG_ENABLE_TX_STBC_DEFAULT,
2162 CFG_ENABLE_TX_STBC_MIN,
2163 CFG_ENABLE_TX_STBC_MAX),
2164
2165 REG_VARIABLE(CFG_ENABLE_RX_LDPC, WLAN_PARAM_Integer,
2166 struct hdd_config, enableRxLDPC,
2167 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2168 CFG_ENABLE_RX_LDPC_DEFAULT,
2169 CFG_ENABLE_RX_LDPC_MIN,
2170 CFG_ENABLE_RX_LDPC_MAX),
2171
2172 REG_VARIABLE(CFG_PPS_ENABLE_5G_EBT, WLAN_PARAM_Integer,
2173 struct hdd_config, enable5gEBT,
2174 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2175 CFG_PPS_ENABLE_5G_EBT_FEATURE_DEFAULT,
2176 CFG_PPS_ENABLE_5G_EBT_FEATURE_MIN,
2177 CFG_PPS_ENABLE_5G_EBT_FEATURE_MAX),
2178
2179#ifdef FEATURE_WLAN_TDLS
2180 REG_VARIABLE(CFG_TDLS_SUPPORT_ENABLE, WLAN_PARAM_Integer,
2181 struct hdd_config, fEnableTDLSSupport,
2182 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2183 CFG_TDLS_SUPPORT_ENABLE_DEFAULT,
2184 CFG_TDLS_SUPPORT_ENABLE_MIN,
2185 CFG_TDLS_SUPPORT_ENABLE_MAX),
2186
2187 REG_VARIABLE(CFG_TDLS_IMPLICIT_TRIGGER, WLAN_PARAM_Integer,
2188 struct hdd_config, fEnableTDLSImplicitTrigger,
2189 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2190 CFG_TDLS_IMPLICIT_TRIGGER_DEFAULT,
2191 CFG_TDLS_IMPLICIT_TRIGGER_MIN,
2192 CFG_TDLS_IMPLICIT_TRIGGER_MAX),
2193
2194 REG_VARIABLE(CFG_TDLS_TX_STATS_PERIOD, WLAN_PARAM_Integer,
2195 struct hdd_config, fTDLSTxStatsPeriod,
2196 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2197 CFG_TDLS_TX_STATS_PERIOD_DEFAULT,
2198 CFG_TDLS_TX_STATS_PERIOD_MIN,
2199 CFG_TDLS_TX_STATS_PERIOD_MAX),
2200
2201 REG_VARIABLE(CFG_TDLS_TX_PACKET_THRESHOLD, WLAN_PARAM_Integer,
2202 struct hdd_config, fTDLSTxPacketThreshold,
2203 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2204 CFG_TDLS_TX_PACKET_THRESHOLD_DEFAULT,
2205 CFG_TDLS_TX_PACKET_THRESHOLD_MIN,
2206 CFG_TDLS_TX_PACKET_THRESHOLD_MAX),
2207
2208 REG_VARIABLE(CFG_TDLS_MAX_DISCOVERY_ATTEMPT, WLAN_PARAM_Integer,
2209 struct hdd_config, fTDLSMaxDiscoveryAttempt,
2210 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2211 CFG_TDLS_MAX_DISCOVERY_ATTEMPT_DEFAULT,
2212 CFG_TDLS_MAX_DISCOVERY_ATTEMPT_MIN,
2213 CFG_TDLS_MAX_DISCOVERY_ATTEMPT_MAX),
2214
Kabilan Kannanca670be2015-11-23 01:56:12 -08002215 REG_VARIABLE(CFG_TDLS_IDLE_TIMEOUT, WLAN_PARAM_Integer,
2216 struct hdd_config, tdls_idle_timeout,
2217 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2218 CFG_TDLS_IDLE_TIMEOUT_DEFAULT,
2219 CFG_TDLS_IDLE_TIMEOUT_MIN,
2220 CFG_TDLS_IDLE_TIMEOUT_MAX),
2221
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002222 REG_VARIABLE(CFG_TDLS_IDLE_PACKET_THRESHOLD, WLAN_PARAM_Integer,
2223 struct hdd_config, fTDLSIdlePacketThreshold,
2224 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2225 CFG_TDLS_IDLE_PACKET_THRESHOLD_DEFAULT,
2226 CFG_TDLS_IDLE_PACKET_THRESHOLD_MIN,
2227 CFG_TDLS_IDLE_PACKET_THRESHOLD_MAX),
2228
2229 REG_VARIABLE(CFG_TDLS_RSSI_TRIGGER_THRESHOLD, WLAN_PARAM_SignedInteger,
2230 struct hdd_config, fTDLSRSSITriggerThreshold,
2231 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2232 CFG_TDLS_RSSI_TRIGGER_THRESHOLD_DEFAULT,
2233 CFG_TDLS_RSSI_TRIGGER_THRESHOLD_MIN,
2234 CFG_TDLS_RSSI_TRIGGER_THRESHOLD_MAX),
2235
2236 REG_VARIABLE(CFG_TDLS_RSSI_TEARDOWN_THRESHOLD, WLAN_PARAM_SignedInteger,
2237 struct hdd_config, fTDLSRSSITeardownThreshold,
2238 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2239 CFG_TDLS_RSSI_TEARDOWN_THRESHOLD_DEFAULT,
2240 CFG_TDLS_RSSI_TEARDOWN_THRESHOLD_MIN,
2241 CFG_TDLS_RSSI_TEARDOWN_THRESHOLD_MAX),
2242
2243 REG_VARIABLE(CFG_TDLS_RSSI_DELTA, WLAN_PARAM_SignedInteger,
2244 struct hdd_config, fTDLSRSSIDelta,
2245 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2246 CFG_TDLS_RSSI_DELTA_DEFAULT,
2247 CFG_TDLS_RSSI_DELTA_MIN,
2248 CFG_TDLS_RSSI_DELTA_MAX),
2249
2250 REG_VARIABLE(CFG_TDLS_QOS_WMM_UAPSD_MASK_NAME, WLAN_PARAM_HexInteger,
2251 struct hdd_config, fTDLSUapsdMask,
2252 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2253 CFG_TDLS_QOS_WMM_UAPSD_MASK_DEFAULT,
2254 CFG_TDLS_QOS_WMM_UAPSD_MASK_MIN,
2255 CFG_TDLS_QOS_WMM_UAPSD_MASK_MAX),
2256
2257 REG_VARIABLE(CFG_TDLS_BUFFER_STA_SUPPORT_ENABLE, WLAN_PARAM_Integer,
2258 struct hdd_config, fEnableTDLSBufferSta,
2259 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2260 CFG_TDLS_BUFFER_STA_SUPPORT_ENABLE_DEFAULT,
2261 CFG_TDLS_BUFFER_STA_SUPPORT_ENABLE_MIN,
2262 CFG_TDLS_BUFFER_STA_SUPPORT_ENABLE_MAX),
2263
2264 REG_VARIABLE(CFG_TDLS_OFF_CHANNEL_SUPPORT_ENABLE, WLAN_PARAM_Integer,
2265 struct hdd_config, fEnableTDLSOffChannel,
2266 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2267 CFG_TDLS_OFF_CHANNEL_SUPPORT_ENABLE_DEFAULT,
2268 CFG_TDLS_OFF_CHANNEL_SUPPORT_ENABLE_MIN,
2269 CFG_TDLS_OFF_CHANNEL_SUPPORT_ENABLE_MAX),
2270
2271 REG_VARIABLE(CFG_TDLS_PREFERRED_OFF_CHANNEL_NUM, WLAN_PARAM_Integer,
2272 struct hdd_config, fTDLSPrefOffChanNum,
2273 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2274 CFG_TDLS_PREFERRED_OFF_CHANNEL_NUM_DEFAULT,
2275 CFG_TDLS_PREFERRED_OFF_CHANNEL_NUM_MIN,
2276 CFG_TDLS_PREFERRED_OFF_CHANNEL_NUM_MAX),
2277
2278 REG_VARIABLE(CFG_TDLS_PREFERRED_OFF_CHANNEL_BW, WLAN_PARAM_Integer,
2279 struct hdd_config, fTDLSPrefOffChanBandwidth,
2280 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2281 CFG_TDLS_PREFERRED_OFF_CHANNEL_BW_DEFAULT,
2282 CFG_TDLS_PREFERRED_OFF_CHANNEL_BW_MIN,
2283 CFG_TDLS_PREFERRED_OFF_CHANNEL_BW_MAX),
2284
2285 REG_VARIABLE(CFG_TDLS_PUAPSD_INACTIVITY_TIME, WLAN_PARAM_Integer,
2286 struct hdd_config, fTDLSPuapsdInactivityTimer,
2287 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2288 CFG_TDLS_PUAPSD_INACTIVITY_TIME_DEFAULT,
2289 CFG_TDLS_PUAPSD_INACTIVITY_TIME_MIN,
2290 CFG_TDLS_PUAPSD_INACTIVITY_TIME_MAX),
2291
2292 REG_VARIABLE(CFG_TDLS_PUAPSD_RX_FRAME_THRESHOLD, WLAN_PARAM_Integer,
2293 struct hdd_config, fTDLSRxFrameThreshold,
2294 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2295 CFG_TDLS_PUAPSD_RX_FRAME_THRESHOLD_DEFAULT,
2296 CFG_TDLS_PUAPSD_RX_FRAME_THRESHOLD_MIN,
2297 CFG_TDLS_PUAPSD_RX_FRAME_THRESHOLD_MAX),
2298
2299 REG_VARIABLE(CFG_TDLS_PUAPSD_PEER_TRAFFIC_IND_WINDOW,
2300 WLAN_PARAM_Integer,
2301 struct hdd_config, fTDLSPuapsdPTIWindow,
2302 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2303 CFG_TDLS_PUAPSD_PEER_TRAFFIC_IND_WINDOW_DEFAULT,
2304 CFG_TDLS_PUAPSD_PEER_TRAFFIC_IND_WINDOW_MIN,
2305 CFG_TDLS_PUAPSD_PEER_TRAFFIC_IND_WINDOW_MAX),
2306
2307 REG_VARIABLE(CFG_TDLS_PUAPSD_PEER_TRAFFIC_RSP_TIMEOUT,
2308 WLAN_PARAM_Integer,
2309 struct hdd_config, fTDLSPuapsdPTRTimeout,
2310 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2311 CFG_TDLS_PUAPSD_PEER_TRAFFIC_RSP_TIMEOUT_DEFAULT,
2312 CFG_TDLS_PUAPSD_PEER_TRAFFIC_RSP_TIMEOUT_MIN,
2313 CFG_TDLS_PUAPSD_PEER_TRAFFIC_RSP_TIMEOUT_MAX),
2314
2315 REG_VARIABLE(CFG_TDLS_EXTERNAL_CONTROL, WLAN_PARAM_Integer,
2316 struct hdd_config, fTDLSExternalControl,
2317 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2318 CFG_TDLS_EXTERNAL_CONTROL_DEFAULT,
2319 CFG_TDLS_EXTERNAL_CONTROL_MIN,
2320 CFG_TDLS_EXTERNAL_CONTROL_MAX),
2321 REG_VARIABLE(CFG_TDLS_WMM_MODE_ENABLE, WLAN_PARAM_Integer,
2322 struct hdd_config, fEnableTDLSWmmMode,
2323 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2324 CFG_TDLS_WMM_MODE_ENABLE_DEFAULT,
2325 CFG_TDLS_WMM_MODE_ENABLE_MIN,
2326 CFG_TDLS_WMM_MODE_ENABLE_MAX),
2327
2328 REG_VARIABLE(CFG_TDLS_SCAN_ENABLE, WLAN_PARAM_Integer,
2329 struct hdd_config, enable_tdls_scan,
2330 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2331 CFG_TDLS_SCAN_ENABLE_DEFAULT,
2332 CFG_TDLS_SCAN_ENABLE_MIN,
2333 CFG_TDLS_SCAN_ENABLE_MAX),
Kabilan Kannan421714b2015-11-23 04:44:59 -08002334
2335 REG_VARIABLE(CFG_TDLS_PEER_KICKOUT_THRESHOLD, WLAN_PARAM_Integer,
2336 struct hdd_config, tdls_peer_kickout_threshold,
2337 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2338 CFG_TDLS_PEER_KICKOUT_THRESHOLD_DEFAULT,
2339 CFG_TDLS_PEER_KICKOUT_THRESHOLD_MIN,
2340 CFG_TDLS_PEER_KICKOUT_THRESHOLD_MAX),
2341
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002342#endif
2343
2344#ifdef WLAN_SOFTAP_VSTA_FEATURE
2345 REG_VARIABLE(CFG_VSTA_SUPPORT_ENABLE, WLAN_PARAM_Integer,
2346 struct hdd_config, fEnableVSTASupport,
2347 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2348 CFG_VSTA_SUPPORT_ENABLE_DEFAULT,
2349 CFG_VSTA_SUPPORT_ENABLE_MIN,
2350 CFG_VSTA_SUPPORT_ENABLE_MAX),
2351#endif
2352 REG_VARIABLE(CFG_ENABLE_LPWR_IMG_TRANSITION_NAME, WLAN_PARAM_Integer,
2353 struct hdd_config, enableLpwrImgTransition,
2354 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2355 CFG_ENABLE_LPWR_IMG_TRANSITION_DEFAULT,
2356 CFG_ENABLE_LPWR_IMG_TRANSITION_MIN,
2357 CFG_ENABLE_LPWR_IMG_TRANSITION_MAX),
2358
2359 REG_VARIABLE(CFG_ENABLE_LPWR_IMG_TRANSITION_NAME, WLAN_PARAM_Integer,
2360 struct hdd_config, enableLpwrImgTransition,
2361 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2362 CFG_ENABLE_LPWR_IMG_TRANSITION_DEFAULT,
2363 CFG_ENABLE_LPWR_IMG_TRANSITION_MIN,
2364 CFG_ENABLE_LPWR_IMG_TRANSITION_MAX),
2365
2366 REG_VARIABLE(CFG_SCAN_AGING_PARAM_NAME, WLAN_PARAM_Integer,
2367 struct hdd_config, scanAgingTimeout,
2368 VAR_FLAGS_OPTIONAL,
2369 CFG_SCAN_AGING_PARAM_DEFAULT,
2370 CFG_SCAN_AGING_PARAM_MIN,
2371 CFG_SCAN_AGING_PARAM_MAX),
2372
2373 REG_VARIABLE(CFG_TX_LDPC_ENABLE_FEATURE, WLAN_PARAM_Integer,
2374 struct hdd_config, enableTxLdpc,
2375 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2376 CFG_TX_LDPC_ENABLE_FEATURE_DEFAULT,
2377 CFG_TX_LDPC_ENABLE_FEATURE_MIN,
2378 CFG_TX_LDPC_ENABLE_FEATURE_MAX),
2379
2380 REG_VARIABLE(CFG_ENABLE_MCC_ADATIVE_SCHEDULER_ENABLED_NAME,
2381 WLAN_PARAM_Integer,
2382 struct hdd_config, enableMCCAdaptiveScheduler,
2383 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2384 CFG_ENABLE_MCC_ADATIVE_SCHEDULER_ENABLED_DEFAULT,
2385 CFG_ENABLE_MCC_ADATIVE_SCHEDULER_ENABLED_MIN,
2386 CFG_ENABLE_MCC_ADATIVE_SCHEDULER_ENABLED_MAX),
2387
2388 REG_VARIABLE(CFG_ANDRIOD_POWER_SAVE_NAME, WLAN_PARAM_Integer,
2389 struct hdd_config, isAndroidPsEn,
2390 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2391 CFG_ANDRIOD_POWER_SAVE_DEFAULT,
2392 CFG_ANDRIOD_POWER_SAVE_MIN,
2393 CFG_ANDRIOD_POWER_SAVE_MAX),
2394
2395 REG_VARIABLE(CFG_IBSS_ADHOC_CHANNEL_5GHZ_NAME, WLAN_PARAM_Integer,
2396 struct hdd_config, AdHocChannel5G,
2397 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2398 CFG_IBSS_ADHOC_CHANNEL_5GHZ_DEFAULT,
2399 CFG_IBSS_ADHOC_CHANNEL_5GHZ_MIN,
2400 CFG_IBSS_ADHOC_CHANNEL_5GHZ_MAX),
2401
2402 REG_VARIABLE(CFG_IBSS_ADHOC_CHANNEL_24GHZ_NAME, WLAN_PARAM_Integer,
2403 struct hdd_config, AdHocChannel24G,
2404 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2405 CFG_IBSS_ADHOC_CHANNEL_24GHZ_DEFAULT,
2406 CFG_IBSS_ADHOC_CHANNEL_24GHZ_MIN,
2407 CFG_IBSS_ADHOC_CHANNEL_24GHZ_MAX),
2408
2409 REG_VARIABLE(CFG_VHT_SU_BEAMFORMEE_CAP_FEATURE, WLAN_PARAM_Integer,
2410 struct hdd_config, enableTxBF,
2411 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2412 CFG_VHT_SU_BEAMFORMEE_CAP_FEATURE_DEFAULT,
2413 CFG_VHT_SU_BEAMFORMEE_CAP_FEATURE_MIN,
2414 CFG_VHT_SU_BEAMFORMEE_CAP_FEATURE_MAX),
2415
Kiran Kumar Lokere5302ab62015-12-16 16:03:16 -08002416 REG_VARIABLE(CFG_VHT_ENABLE_TXBF_SAP_MODE, WLAN_PARAM_Integer,
2417 struct hdd_config, enable_txbf_sap_mode,
2418 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2419 CFG_VHT_ENABLE_TXBF_SAP_MODE_DEFAULT,
2420 CFG_VHT_ENABLE_TXBF_SAP_MODE_MIN,
2421 CFG_VHT_ENABLE_TXBF_SAP_MODE_MAX),
2422
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002423 REG_VARIABLE(CFG_VHT_ENABLE_TXBF_IN_20MHZ, WLAN_PARAM_Integer,
2424 struct hdd_config, enableTxBFin20MHz,
2425 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2426 CFG_VHT_ENABLE_TXBF_IN_20MHZ_DEFAULT,
2427 CFG_VHT_ENABLE_TXBF_IN_20MHZ_MIN,
2428 CFG_VHT_ENABLE_TXBF_IN_20MHZ_MAX),
2429
2430 REG_VARIABLE(CFG_VHT_CSN_BEAMFORMEE_ANT_SUPPORTED, WLAN_PARAM_Integer,
2431 struct hdd_config, txBFCsnValue,
2432 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2433 CFG_VHT_CSN_BEAMFORMEE_ANT_SUPPORTED_DEFAULT,
2434 CFG_VHT_CSN_BEAMFORMEE_ANT_SUPPORTED_MIN,
2435 CFG_VHT_CSN_BEAMFORMEE_ANT_SUPPORTED_MAX),
2436
2437 REG_VARIABLE(CFG_VHT_ENABLE_TX_SU_BEAM_FORMER, WLAN_PARAM_Integer,
2438 struct hdd_config, enable_su_tx_bformer,
2439 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2440 CFG_VHT_ENABLE_TX_SU_BEAM_FORMER_DEFAULT,
2441 CFG_VHT_ENABLE_TX_SU_BEAM_FORMER_MIN,
2442 CFG_VHT_ENABLE_TX_SU_BEAM_FORMER_MAX),
2443
2444 REG_VARIABLE(CFG_SAP_ALLOW_ALL_CHANNEL_PARAM_NAME, WLAN_PARAM_Integer,
2445 struct hdd_config, sapAllowAllChannel,
2446 VAR_FLAGS_OPTIONAL,
2447 CFG_SAP_ALLOW_ALL_CHANNEL_PARAM_DEFAULT,
2448 CFG_SAP_ALLOW_ALL_CHANNEL_PARAM_MIN,
2449 CFG_SAP_ALLOW_ALL_CHANNEL_PARAM_MAX),
2450
2451#ifdef WLAN_FEATURE_11AC
2452 REG_VARIABLE(CFG_DISABLE_LDPC_WITH_TXBF_AP, WLAN_PARAM_Integer,
2453 struct hdd_config, disableLDPCWithTxbfAP,
2454 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2455 CFG_DISABLE_LDPC_WITH_TXBF_AP_DEFAULT,
2456 CFG_DISABLE_LDPC_WITH_TXBF_AP_MIN,
2457 CFG_DISABLE_LDPC_WITH_TXBF_AP_MAX),
2458#endif
2459
2460 REG_DYNAMIC_VARIABLE(CFG_ENABLE_SSR, WLAN_PARAM_Integer,
2461 struct hdd_config, enableSSR,
2462 VAR_FLAGS_OPTIONAL |
2463 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2464 CFG_ENABLE_SSR_DEFAULT,
2465 CFG_ENABLE_SSR_MIN,
2466 CFG_ENABLE_SSR_MAX,
2467 cb_notify_set_enable_ssr, 0),
2468
2469 REG_VARIABLE(CFG_MAX_MEDIUM_TIME, WLAN_PARAM_Integer,
2470 struct hdd_config, cfgMaxMediumTime,
2471 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2472 CFG_MAX_MEDIUM_TIME_STADEFAULT,
2473 CFG_MAX_MEDIUM_TIME_STAMIN,
2474 CFG_MAX_MEDIUM_TIME_STAMAX),
2475
2476
2477
2478#ifdef WLAN_FEATURE_11AC
2479 REG_VARIABLE(CFG_ENABLE_VHT_FOR_24GHZ_NAME, WLAN_PARAM_Integer,
2480 struct hdd_config, enableVhtFor24GHzBand,
2481 VAR_FLAGS_OPTIONAL,
2482 CFG_ENABLE_VHT_FOR_24GHZ_DEFAULT,
2483 CFG_ENABLE_VHT_FOR_24GHZ_MIN,
2484 CFG_ENABLE_VHT_FOR_24GHZ_MAX),
2485#endif
2486
2487 REG_DYNAMIC_VARIABLE(CFG_ENABLE_FAST_ROAM_IN_CONCURRENCY,
2488 WLAN_PARAM_Integer,
2489 struct hdd_config, bFastRoamInConIniFeatureEnabled,
2490 VAR_FLAGS_OPTIONAL |
2491 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2492 CFG_ENABLE_FAST_ROAM_IN_CONCURRENCY_DEFAULT,
2493 CFG_ENABLE_FAST_ROAM_IN_CONCURRENCY_MIN,
2494 CFG_ENABLE_FAST_ROAM_IN_CONCURRENCY_MAX,
2495 cb_notify_set_enable_fast_roam_in_concurrency, 0),
2496
2497 REG_VARIABLE(CFG_ENABLE_ADAPT_RX_DRAIN_NAME, WLAN_PARAM_Integer,
2498 struct hdd_config, fEnableAdaptRxDrain,
2499 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2500 CFG_ENABLE_ADAPT_RX_DRAIN_DEFAULT,
2501 CFG_ENABLE_ADAPT_RX_DRAIN_MIN,
2502 CFG_ENABLE_ADAPT_RX_DRAIN_MAX),
2503
2504 REG_VARIABLE(CFG_FLEX_CONNECT_POWER_FACTOR_NAME, WLAN_PARAM_Integer,
2505 struct hdd_config, flexConnectPowerFactor,
2506 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_MINMAX,
2507 CFG_FLEX_CONNECT_POWER_FACTOR_DEFAULT,
2508 CFG_FLEX_CONNECT_POWER_FACTOR_MIN,
2509 CFG_FLEX_CONNECT_POWER_FACTOR_MAX),
2510
2511 REG_VARIABLE(CFG_ENABLE_HEART_BEAT_OFFLOAD, WLAN_PARAM_Integer,
2512 struct hdd_config, enableIbssHeartBeatOffload,
2513 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2514 CFG_ENABLE_HEART_BEAT_OFFLOAD_DEFAULT,
2515 CFG_ENABLE_HEART_BEAT_OFFLOAD_MIN,
2516 CFG_ENABLE_HEART_BEAT_OFFLOAD_MAX),
2517
2518 REG_VARIABLE(CFG_ANTENNA_DIVERSITY_PARAM_NAME, WLAN_PARAM_Integer,
2519 struct hdd_config, antennaDiversity,
2520 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2521 CFG_ANTENNA_DIVERSITY_PARAM_DEFAULT,
2522 CFG_ANTENNA_DIVERSITY_PARAM_MIN,
2523 CFG_ANTENNA_DIVERSITY_PARAM_MAX),
2524
2525 REG_VARIABLE(CFG_ENABLE_SNR_MONITORING_NAME, WLAN_PARAM_Integer,
2526 struct hdd_config, fEnableSNRMonitoring,
2527 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2528 CFG_ENABLE_SNR_MONITORING_DEFAULT,
2529 CFG_ENABLE_SNR_MONITORING_MIN,
2530 CFG_ENABLE_SNR_MONITORING_MAX),
2531
2532#ifdef FEATURE_WLAN_SCAN_PNO
2533 REG_VARIABLE(CFG_PNO_SCAN_SUPPORT, WLAN_PARAM_Integer,
2534 struct hdd_config, configPNOScanSupport,
2535 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2536 CFG_PNO_SCAN_SUPPORT_DEFAULT,
2537 CFG_PNO_SCAN_SUPPORT_DISABLE,
2538 CFG_PNO_SCAN_SUPPORT_ENABLE),
2539
2540 REG_VARIABLE(CFG_PNO_SCAN_TIMER_REPEAT_VALUE, WLAN_PARAM_Integer,
2541 struct hdd_config, configPNOScanTimerRepeatValue,
2542 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2543 CFG_PNO_SCAN_TIMER_REPEAT_VALUE_DEFAULT,
2544 CFG_PNO_SCAN_TIMER_REPEAT_VALUE_MIN,
2545 CFG_PNO_SCAN_TIMER_REPEAT_VALUE_MAX),
Srinivas Girigowdabdc98162015-09-17 11:06:07 -07002546
2547 REG_VARIABLE(CFG_PNO_SLOW_SCAN_MULTIPLIER, WLAN_PARAM_Integer,
2548 struct hdd_config, pno_slow_scan_multiplier,
2549 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2550 CFG_PNO_SLOW_SCAN_MULTIPLIER_DEFAULT,
2551 CFG_PNO_SLOW_SCAN_MULTIPLIER_MIN,
2552 CFG_PNO_SLOW_SCAN_MULTIPLIER_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002553#endif
2554 REG_VARIABLE(CFG_AMSDU_SUPPORT_IN_AMPDU_NAME, WLAN_PARAM_Integer,
2555 struct hdd_config, isAmsduSupportInAMPDU,
2556 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2557 CFG_AMSDU_SUPPORT_IN_AMPDU_DEFAULT,
2558 CFG_AMSDU_SUPPORT_IN_AMPDU_MIN,
2559 CFG_AMSDU_SUPPORT_IN_AMPDU_MAX),
2560
2561 REG_VARIABLE(CFG_STRICT_5GHZ_PREF_BY_MARGIN, WLAN_PARAM_Integer,
2562 struct hdd_config, nSelect5GHzMargin,
2563 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2564 CFG_STRICT_5GHZ_PREF_BY_MARGIN_DEFAULT,
2565 CFG_STRICT_5GHZ_PREF_BY_MARGIN_MIN,
2566 CFG_STRICT_5GHZ_PREF_BY_MARGIN_MAX),
2567
2568 REG_VARIABLE(CFG_ENABLE_IP_TCP_UDP_CHKSUM_OFFLOAD, WLAN_PARAM_Integer,
2569 struct hdd_config, enable_ip_tcp_udp_checksum_offload,
2570 VAR_FLAGS_OPTIONAL,
2571 CFG_ENABLE_IP_TCP_UDP_CHKSUM_OFFLOAD_DEFAULT,
2572 CFG_ENABLE_IP_TCP_UDP_CHKSUM_OFFLOAD_DISABLE,
2573 CFG_ENABLE_IP_TCP_UDP_CHKSUM_OFFLOAD_ENABLE),
2574
2575 REG_VARIABLE(CFG_POWERSAVE_OFFLOAD_NAME, WLAN_PARAM_Integer,
2576 struct hdd_config, enablePowersaveOffload,
2577 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2578 CFG_POWERSAVE_OFFLOAD_DEFAULT,
2579 CFG_POWERSAVE_OFFLOAD_MIN,
2580 CFG_POWERSAVE_OFFLOAD_MAX),
2581
2582 REG_VARIABLE(CFG_ENABLE_FW_UART_PRINT_NAME, WLAN_PARAM_Integer,
2583 struct hdd_config, enablefwprint,
2584 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2585 CFG_ENABLE_FW_UART_PRINT_DEFAULT,
2586 CFG_ENABLE_FW_UART_PRINT_DISABLE,
2587 CFG_ENABLE_FW_UART_PRINT_ENABLE),
2588
2589 REG_VARIABLE(CFG_ENABLE_FW_LOG_NAME, WLAN_PARAM_Integer,
Komal Seelamc11bb222016-01-27 18:57:10 +05302590 struct hdd_config, enable_fw_log,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002591 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2592 CFG_ENABLE_FW_LOG_DEFAULT,
2593 CFG_ENABLE_FW_LOG_DISABLE,
2594 CFG_ENABLE_FW_LOG_ENABLE),
2595
2596#ifdef IPA_OFFLOAD
2597 REG_VARIABLE(CFG_IPA_OFFLOAD_CONFIG_NAME, WLAN_PARAM_HexInteger,
2598 struct hdd_config, IpaConfig,
2599 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2600 CFG_IPA_OFFLOAD_CONFIG_DEFAULT,
2601 CFG_IPA_OFFLOAD_CONFIG_MIN,
2602 CFG_IPA_OFFLOAD_CONFIG_MAX),
2603
2604 REG_VARIABLE(CFG_IPA_DESC_SIZE_NAME, WLAN_PARAM_Integer,
2605 struct hdd_config, IpaDescSize,
2606 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2607 CFG_IPA_DESC_SIZE_DEFAULT,
2608 CFG_IPA_DESC_SIZE_MIN,
2609 CFG_IPA_DESC_SIZE_MAX),
2610
2611 REG_VARIABLE(CFG_IPA_HIGH_BANDWIDTH_MBPS, WLAN_PARAM_Integer,
2612 struct hdd_config, IpaHighBandwidthMbps,
2613 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2614 CFG_IPA_HIGH_BANDWIDTH_MBPS_DEFAULT,
2615 CFG_IPA_HIGH_BANDWIDTH_MBPS_MIN,
2616 CFG_IPA_HIGH_BANDWIDTH_MBPS_MAX),
2617
2618 REG_VARIABLE(CFG_IPA_MEDIUM_BANDWIDTH_MBPS, WLAN_PARAM_Integer,
2619 struct hdd_config, IpaMediumBandwidthMbps,
2620 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2621 CFG_IPA_MEDIUM_BANDWIDTH_MBPS_DEFAULT,
2622 CFG_IPA_MEDIUM_BANDWIDTH_MBPS_MIN,
2623 CFG_IPA_MEDIUM_BANDWIDTH_MBPS_MAX),
2624
2625 REG_VARIABLE(CFG_IPA_LOW_BANDWIDTH_MBPS, WLAN_PARAM_Integer,
2626 struct hdd_config, IpaLowBandwidthMbps,
2627 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2628 CFG_IPA_LOW_BANDWIDTH_MBPS_DEFAULT,
2629 CFG_IPA_LOW_BANDWIDTH_MBPS_MIN,
2630 CFG_IPA_LOW_BANDWIDTH_MBPS_MAX),
2631#endif
2632
2633#ifdef WLAN_FEATURE_11AC
2634 REG_VARIABLE(CFG_VHT_AMPDU_LEN_EXPONENT_NAME, WLAN_PARAM_Integer,
2635 struct hdd_config, fVhtAmpduLenExponent,
2636 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2637 CFG_VHT_AMPDU_LEN_EXPONENT_DEFAULT,
2638 CFG_VHT_AMPDU_LEN_EXPONENT_MIN,
2639 CFG_VHT_AMPDU_LEN_EXPONENT_MAX),
2640
2641 REG_VARIABLE(CFG_VHT_MPDU_LEN_NAME, WLAN_PARAM_Integer,
2642 struct hdd_config, vhtMpduLen,
2643 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2644 CFG_VHT_MPDU_LEN_DEFAULT,
2645 CFG_VHT_MPDU_LEN_MIN,
2646 CFG_VHT_MPDU_LEN_MAX),
2647#endif
2648
2649 REG_VARIABLE(CFG_MAX_WOW_FILTERS_NAME, WLAN_PARAM_Integer,
2650 struct hdd_config, maxWoWFilters,
2651 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2652 CFG_MAX_WOW_FILTERS_DEFAULT,
2653 CFG_MAX_WOW_FILTERS_MIN,
2654 CFG_MAX_WOW_FILTERS_MAX),
2655
2656 REG_VARIABLE(CFG_WOW_STATUS_NAME, WLAN_PARAM_Integer,
2657 struct hdd_config, wowEnable,
2658 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2659 CFG_WOW_STATUS_DEFAULT,
2660 CFG_WOW_ENABLE_MIN,
2661 CFG_WOW_ENABLE_MAX),
2662
2663 REG_VARIABLE(CFG_COALESING_IN_IBSS_NAME, WLAN_PARAM_Integer,
2664 struct hdd_config, isCoalesingInIBSSAllowed,
2665 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2666 CFG_COALESING_IN_IBSS_DEFAULT,
2667 CFG_COALESING_IN_IBSS_MIN,
2668 CFG_COALESING_IN_IBSS_MAX),
2669
2670 REG_VARIABLE(CFG_IBSS_ATIM_WIN_SIZE_NAME, WLAN_PARAM_Integer,
2671 struct hdd_config, ibssATIMWinSize,
2672 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2673 CFG_IBSS_ATIM_WIN_SIZE_DEFAULT,
2674 CFG_IBSS_ATIM_WIN_SIZE_MIN,
2675 CFG_IBSS_ATIM_WIN_SIZE_MAX),
2676
2677 REG_VARIABLE(CFG_SAP_MAX_NO_PEERS, WLAN_PARAM_Integer,
2678 struct hdd_config, maxNumberOfPeers,
2679 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2680 CFG_SAP_MAX_NO_PEERS_DEFAULT,
2681 CFG_SAP_MAX_NO_PEERS_MIN,
2682 CFG_SAP_MAX_NO_PEERS_MAX),
2683
2684 REG_VARIABLE(CFG_IBSS_IS_POWER_SAVE_ALLOWED_NAME, WLAN_PARAM_Integer,
2685 struct hdd_config, isIbssPowerSaveAllowed,
2686 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2687 CFG_IBSS_IS_POWER_SAVE_ALLOWED_DEFAULT,
2688 CFG_IBSS_IS_POWER_SAVE_ALLOWED_MIN,
2689 CFG_IBSS_IS_POWER_SAVE_ALLOWED_MAX),
2690
2691 REG_VARIABLE(CFG_IBSS_IS_POWER_COLLAPSE_ALLOWED_NAME,
2692 WLAN_PARAM_Integer,
2693 struct hdd_config, isIbssPowerCollapseAllowed,
2694 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2695 CFG_IBSS_IS_POWER_COLLAPSE_ALLOWED_DEFAULT,
2696 CFG_IBSS_IS_POWER_COLLAPSE_ALLOWED_MIN,
2697 CFG_IBSS_IS_POWER_COLLAPSE_ALLOWED_MAX),
2698
2699 REG_VARIABLE(CFG_IBSS_AWAKE_ON_TX_RX_NAME, WLAN_PARAM_Integer,
2700 struct hdd_config, isIbssAwakeOnTxRx,
2701 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2702 CFG_IBSS_AWAKE_ON_TX_RX_DEFAULT,
2703 CFG_IBSS_AWAKE_ON_TX_RX_MIN,
2704 CFG_IBSS_AWAKE_ON_TX_RX_MAX),
2705
2706 REG_VARIABLE(CFG_IBSS_INACTIVITY_TIME_NAME, WLAN_PARAM_Integer,
2707 struct hdd_config, ibssInactivityCount,
2708 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2709 CFG_IBSS_INACTIVITY_TIME_DEFAULT,
2710 CFG_IBSS_INACTIVITY_TIME_MIN,
2711 CFG_IBSS_INACTIVITY_TIME_MAX),
2712
2713 REG_VARIABLE(CFG_IBSS_TXSP_END_INACTIVITY_NAME, WLAN_PARAM_Integer,
2714 struct hdd_config, ibssTxSpEndInactivityTime,
2715 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2716 CFG_IBSS_TXSP_END_INACTIVITY_DEFAULT,
2717 CFG_IBSS_TXSP_END_INACTIVITY_MIN,
2718 CFG_IBSS_TXSP_END_INACTIVITY_MAX),
2719
2720 REG_VARIABLE(CFG_IBSS_PS_WARMUP_TIME_NAME, WLAN_PARAM_Integer,
2721 struct hdd_config, ibssPsWarmupTime,
2722 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2723 CFG_IBSS_PS_WARMUP_TIME_DEFAULT,
2724 CFG_IBSS_PS_WARMUP_TIME_MIN,
2725 CFG_IBSS_PS_WARMUP_TIME_MAX),
2726
2727 REG_VARIABLE(CFG_IBSS_PS_1RX_CHAIN_IN_ATIM_WINDOW_NAME,
2728 WLAN_PARAM_Integer,
2729 struct hdd_config, ibssPs1RxChainInAtimEnable,
2730 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2731 CFG_IBSS_PS_1RX_CHAIN_IN_ATIM_WINDOW_DEFAULT,
2732 CFG_IBSS_PS_1RX_CHAIN_IN_ATIM_WINDOW_MIN,
2733 CFG_IBSS_PS_1RX_CHAIN_IN_ATIM_WINDOW_MAX),
2734
2735 REG_VARIABLE(CFG_THERMAL_TEMP_MIN_LEVEL0_NAME, WLAN_PARAM_Integer,
2736 struct hdd_config, thermalTempMinLevel0,
2737 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2738 CFG_THERMAL_TEMP_MIN_LEVEL0_DEFAULT,
2739 CFG_THERMAL_TEMP_MIN_LEVEL0_MIN,
2740 CFG_THERMAL_TEMP_MIN_LEVEL0_MAX),
2741
2742 REG_VARIABLE(CFG_THERMAL_TEMP_MAX_LEVEL0_NAME, WLAN_PARAM_Integer,
2743 struct hdd_config, thermalTempMaxLevel0,
2744 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2745 CFG_THERMAL_TEMP_MAX_LEVEL0_DEFAULT,
2746 CFG_THERMAL_TEMP_MAX_LEVEL0_MIN,
2747 CFG_THERMAL_TEMP_MAX_LEVEL0_MAX),
2748
2749 REG_VARIABLE(CFG_THERMAL_TEMP_MIN_LEVEL1_NAME, WLAN_PARAM_Integer,
2750 struct hdd_config, thermalTempMinLevel1,
2751 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2752 CFG_THERMAL_TEMP_MIN_LEVEL1_DEFAULT,
2753 CFG_THERMAL_TEMP_MIN_LEVEL1_MIN,
2754 CFG_THERMAL_TEMP_MIN_LEVEL1_MAX),
2755
2756 REG_VARIABLE(CFG_THERMAL_TEMP_MAX_LEVEL1_NAME, WLAN_PARAM_Integer,
2757 struct hdd_config, thermalTempMaxLevel1,
2758 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2759 CFG_THERMAL_TEMP_MAX_LEVEL1_DEFAULT,
2760 CFG_THERMAL_TEMP_MAX_LEVEL1_MIN,
2761 CFG_THERMAL_TEMP_MAX_LEVEL1_MAX),
2762
2763 REG_VARIABLE(CFG_THERMAL_TEMP_MIN_LEVEL2_NAME, WLAN_PARAM_Integer,
2764 struct hdd_config, thermalTempMinLevel2,
2765 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2766 CFG_THERMAL_TEMP_MIN_LEVEL2_DEFAULT,
2767 CFG_THERMAL_TEMP_MIN_LEVEL2_MIN,
2768 CFG_THERMAL_TEMP_MIN_LEVEL2_MAX),
2769
2770 REG_VARIABLE(CFG_THERMAL_TEMP_MAX_LEVEL2_NAME, WLAN_PARAM_Integer,
2771 struct hdd_config, thermalTempMaxLevel2,
2772 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2773 CFG_THERMAL_TEMP_MAX_LEVEL2_DEFAULT,
2774 CFG_THERMAL_TEMP_MAX_LEVEL2_MIN,
2775 CFG_THERMAL_TEMP_MAX_LEVEL2_MAX),
2776
2777 REG_VARIABLE(CFG_THERMAL_TEMP_MIN_LEVEL3_NAME, WLAN_PARAM_Integer,
2778 struct hdd_config, thermalTempMinLevel3,
2779 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2780 CFG_THERMAL_TEMP_MIN_LEVEL3_DEFAULT,
2781 CFG_THERMAL_TEMP_MIN_LEVEL3_MIN,
2782 CFG_THERMAL_TEMP_MIN_LEVEL3_MAX),
2783
2784 REG_VARIABLE(CFG_THERMAL_TEMP_MAX_LEVEL3_NAME, WLAN_PARAM_Integer,
2785 struct hdd_config, thermalTempMaxLevel3,
2786 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2787 CFG_THERMAL_TEMP_MAX_LEVEL3_DEFAULT,
2788 CFG_THERMAL_TEMP_MAX_LEVEL3_MIN,
2789 CFG_THERMAL_TEMP_MAX_LEVEL3_MAX),
2790
2791 REG_VARIABLE(CFG_SET_TXPOWER_LIMIT2G_NAME, WLAN_PARAM_Integer,
2792 struct hdd_config, TxPower2g,
2793 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2794 CFG_SET_TXPOWER_LIMIT2G_DEFAULT,
2795 CFG_SET_TXPOWER_LIMIT2G_MIN,
2796 CFG_SET_TXPOWER_LIMIT2G_MAX),
2797
2798 REG_VARIABLE(CFG_SET_TXPOWER_LIMIT5G_NAME, WLAN_PARAM_Integer,
2799 struct hdd_config, TxPower5g,
2800 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2801 CFG_SET_TXPOWER_LIMIT5G_DEFAULT,
2802 CFG_SET_TXPOWER_LIMIT5G_MIN,
2803 CFG_SET_TXPOWER_LIMIT5G_MAX),
2804
2805 REG_VARIABLE(CFG_ENABLE_DEBUG_CONNECT_ISSUE, WLAN_PARAM_Integer,
2806 struct hdd_config, gEnableDebugLog,
2807 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2808 CFG_ENABLE_DEBUG_CONNECT_ISSUE_DEFAULT,
2809 CFG_ENABLE_DEBUG_CONNECT_ISSUE_MIN,
2810 CFG_ENABLE_DEBUG_CONNECT_ISSUE_MAX),
2811
2812 REG_VARIABLE(CFG_ENABLE_RX_THREAD, WLAN_PARAM_Integer,
2813 struct hdd_config, enableRxThread,
2814 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2815 CFG_ENABLE_RX_THREAD_DEFAULT,
2816 CFG_ENABLE_RX_THREAD_MIN,
2817 CFG_ENABLE_RX_THREAD_MAX),
2818
2819 REG_VARIABLE(CFG_ENABLE_DFS_PHYERR_FILTEROFFLOAD_NAME,
2820 WLAN_PARAM_Integer,
2821 struct hdd_config, fDfsPhyerrFilterOffload,
2822 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2823 CFG_ENABLE_DFS_PHYERR_FILTEROFFLOAD_DEFAULT,
2824 CFG_ENABLE_DFS_PHYERR_FILTEROFFLOAD_MIN,
2825 CFG_ENABLE_DFS_PHYERR_FILTEROFFLOAD_MAX),
2826
2827 REG_VARIABLE(CFG_ENABLE_OVERLAP_CH, WLAN_PARAM_Integer,
2828 struct hdd_config, gEnableOverLapCh,
2829 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2830 CFG_ENABLE_OVERLAP_CH_DEFAULT,
2831 CFG_ENABLE_OVERLAP_CH_MIN,
2832 CFG_ENABLE_OVERLAP_CH_MAX),
2833
2834 REG_VARIABLE(CFG_REG_CHANGE_DEF_COUNTRY_NAME, WLAN_PARAM_Integer,
2835 struct hdd_config, fRegChangeDefCountry,
2836 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2837 CFG_REG_CHANGE_DEF_COUNTRY_DEFAULT,
2838 CFG_REG_CHANGE_DEF_COUNTRY_MIN,
2839 CFG_REG_CHANGE_DEF_COUNTRY_MAX),
2840
2841#ifdef QCA_LL_LEGACY_TX_FLOW_CONTROL
2842 REG_VARIABLE(CFG_LL_TX_FLOW_LWM, WLAN_PARAM_Integer,
2843 struct hdd_config, TxFlowLowWaterMark,
2844 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2845 CFG_LL_TX_FLOW_LWM_DEFAULT,
2846 CFG_LL_TX_FLOW_LWM_MIN,
2847 CFG_LL_TX_FLOW_LWM_MAX),
2848 REG_VARIABLE(CFG_LL_TX_FLOW_HWM_OFFSET, WLAN_PARAM_Integer,
2849 struct hdd_config, TxFlowHighWaterMarkOffset,
2850 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2851 CFG_LL_TX_FLOW_HWM_OFFSET_DEFAULT,
2852 CFG_LL_TX_FLOW_HWM_OFFSET_MIN,
2853 CFG_LL_TX_FLOW_HWM_OFFSET_MAX),
2854 REG_VARIABLE(CFG_LL_TX_FLOW_MAX_Q_DEPTH, WLAN_PARAM_Integer,
2855 struct hdd_config, TxFlowMaxQueueDepth,
2856 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2857 CFG_LL_TX_FLOW_MAX_Q_DEPTH_DEFAULT,
2858 CFG_LL_TX_FLOW_MAX_Q_DEPTH_MIN,
2859 CFG_LL_TX_FLOW_MAX_Q_DEPTH_MAX),
2860 REG_VARIABLE(CFG_LL_TX_LBW_FLOW_LWM, WLAN_PARAM_Integer,
2861 struct hdd_config, TxLbwFlowLowWaterMark,
2862 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2863 CFG_LL_TX_LBW_FLOW_LWM_DEFAULT,
2864 CFG_LL_TX_LBW_FLOW_LWM_MIN,
2865 CFG_LL_TX_LBW_FLOW_LWM_MAX),
2866
2867 REG_VARIABLE(CFG_LL_TX_LBW_FLOW_HWM_OFFSET, WLAN_PARAM_Integer,
2868 struct hdd_config, TxLbwFlowHighWaterMarkOffset,
2869 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2870 CFG_LL_TX_LBW_FLOW_HWM_OFFSET_DEFAULT,
2871 CFG_LL_TX_LBW_FLOW_HWM_OFFSET_MIN,
2872 CFG_LL_TX_LBW_FLOW_HWM_OFFSET_MAX),
2873
2874 REG_VARIABLE(CFG_LL_TX_LBW_FLOW_MAX_Q_DEPTH, WLAN_PARAM_Integer,
2875 struct hdd_config, TxLbwFlowMaxQueueDepth,
2876 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2877 CFG_LL_TX_LBW_FLOW_MAX_Q_DEPTH_DEFAULT,
2878 CFG_LL_TX_LBW_FLOW_MAX_Q_DEPTH_MIN,
2879 CFG_LL_TX_LBW_FLOW_MAX_Q_DEPTH_MAX),
2880
2881 REG_VARIABLE(CFG_LL_TX_HBW_FLOW_LWM, WLAN_PARAM_Integer,
2882 struct hdd_config, TxHbwFlowLowWaterMark,
2883 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2884 CFG_LL_TX_HBW_FLOW_LWM_DEFAULT,
2885 CFG_LL_TX_HBW_FLOW_LWM_MIN,
2886 CFG_LL_TX_HBW_FLOW_LWM_MAX),
2887
2888 REG_VARIABLE(CFG_LL_TX_HBW_FLOW_HWM_OFFSET, WLAN_PARAM_Integer,
2889 struct hdd_config, TxHbwFlowHighWaterMarkOffset,
2890 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2891 CFG_LL_TX_HBW_FLOW_HWM_OFFSET_DEFAULT,
2892 CFG_LL_TX_HBW_FLOW_HWM_OFFSET_MIN,
2893 CFG_LL_TX_HBW_FLOW_HWM_OFFSET_MAX),
2894
2895 REG_VARIABLE(CFG_LL_TX_HBW_FLOW_MAX_Q_DEPTH, WLAN_PARAM_Integer,
2896 struct hdd_config, TxHbwFlowMaxQueueDepth,
2897 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2898 CFG_LL_TX_HBW_FLOW_MAX_Q_DEPTH_DEFAULT,
2899 CFG_LL_TX_HBW_FLOW_MAX_Q_DEPTH_MIN,
2900 CFG_LL_TX_HBW_FLOW_MAX_Q_DEPTH_MAX),
2901#endif /* QCA_LL_LEGACY_TX_FLOW_CONTROL */
2902#ifdef QCA_LL_TX_FLOW_CONTROL_V2
2903
2904 REG_VARIABLE(CFG_LL_TX_FLOW_STOP_QUEUE_TH, WLAN_PARAM_Integer,
2905 struct hdd_config, TxFlowStopQueueThreshold,
2906 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2907 CFG_LL_TX_FLOW_STOP_QUEUE_TH_DEFAULT,
2908 CFG_LL_TX_FLOW_STOP_QUEUE_TH_MIN,
2909 CFG_LL_TX_FLOW_STOP_QUEUE_TH_MAX),
2910
2911 REG_VARIABLE(CFG_LL_TX_FLOW_START_QUEUE_OFFSET, WLAN_PARAM_Integer,
2912 struct hdd_config, TxFlowStartQueueOffset,
2913 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2914 CFG_LL_TX_FLOW_START_QUEUE_OFFSET_DEFAULT,
2915 CFG_LL_TX_FLOW_START_QUEUE_OFFSET_MIN,
2916 CFG_LL_TX_FLOW_START_QUEUE_OFFSET_MAX),
2917
2918#endif
2919 REG_VARIABLE(CFG_INITIAL_DWELL_TIME_NAME, WLAN_PARAM_Integer,
2920 struct hdd_config, nInitialDwellTime,
2921 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2922 CFG_INITIAL_DWELL_TIME_DEFAULT,
2923 CFG_INITIAL_DWELL_TIME_MIN,
2924 CFG_INITIAL_DWELL_TIME_MAX),
2925
2926 REG_VARIABLE(CFG_INITIAL_SCAN_NO_DFS_CHNL_NAME, WLAN_PARAM_Integer,
2927 struct hdd_config, initial_scan_no_dfs_chnl,
2928 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2929 CFG_INITIAL_SCAN_NO_DFS_CHNL_DEFAULT,
2930 CFG_INITIAL_SCAN_NO_DFS_CHNL_MIN,
2931 CFG_INITIAL_SCAN_NO_DFS_CHNL_MAX),
2932
2933 REG_VARIABLE(CFG_SAP_MAX_OFFLOAD_PEERS, WLAN_PARAM_Integer,
2934 struct hdd_config, apMaxOffloadPeers,
2935 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2936 CFG_SAP_MAX_OFFLOAD_PEERS_DEFAULT,
2937 CFG_SAP_MAX_OFFLOAD_PEERS_MIN,
2938 CFG_SAP_MAX_OFFLOAD_PEERS_MAX),
2939
2940 REG_VARIABLE(CFG_SAP_MAX_OFFLOAD_REORDER_BUFFS, WLAN_PARAM_Integer,
2941 struct hdd_config, apMaxOffloadReorderBuffs,
2942 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2943 CFG_SAP_MAX_OFFLOAD_REORDER_BUFFS_DEFAULT,
2944 CFG_SAP_MAX_OFFLOAD_REORDER_BUFFS_MIN,
2945 CFG_SAP_MAX_OFFLOAD_REORDER_BUFFS_MAX),
2946
2947 REG_VARIABLE(CFG_ADVERTISE_CONCURRENT_OPERATION_NAME,
2948 WLAN_PARAM_Integer,
2949 struct hdd_config, advertiseConcurrentOperation,
2950 VAR_FLAGS_OPTIONAL,
2951 CFG_ADVERTISE_CONCURRENT_OPERATION_DEFAULT,
2952 CFG_ADVERTISE_CONCURRENT_OPERATION_MIN,
2953 CFG_ADVERTISE_CONCURRENT_OPERATION_MAX),
2954
2955 REG_VARIABLE(CFG_ENABLE_MEMORY_DEEP_SLEEP, WLAN_PARAM_Integer,
2956 struct hdd_config, enableMemDeepSleep,
2957 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2958 CFG_ENABLE_MEMORY_DEEP_SLEEP_DEFAULT,
2959 CFG_ENABLE_MEMORY_DEEP_SLEEP_MIN,
2960 CFG_ENABLE_MEMORY_DEEP_SLEEP_MAX),
2961
2962 REG_VARIABLE(CFG_DEFAULT_RATE_INDEX_24GH, WLAN_PARAM_Integer,
2963 struct hdd_config, defaultRateIndex24Ghz,
2964 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2965 CFG_DEFAULT_RATE_INDEX_24GH_DEFAULT,
2966 CFG_DEFAULT_RATE_INDEX_24GH_MIN,
2967 CFG_DEFAULT_RATE_INDEX_24GH_MAX),
2968
2969#ifdef MEMORY_DEBUG
2970 REG_VARIABLE(CFG_ENABLE_MEMORY_DEBUG_NAME, WLAN_PARAM_Integer,
2971 struct hdd_config, IsMemoryDebugSupportEnabled,
2972 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2973 CFG_ENABLE_MEMORY_DEBUG_DEFAULT,
2974 CFG_ENABLE_MEMORY_DEBUG_MIN,
2975 CFG_ENABLE_MEMORY_DEBUG_MAX),
2976#endif
2977
2978 REG_VARIABLE(CFG_DEBUG_P2P_REMAIN_ON_CHANNEL_NAME, WLAN_PARAM_Integer,
2979 struct hdd_config, debugP2pRemainOnChannel,
2980 VAR_FLAGS_OPTIONAL,
2981 CFG_DEBUG_P2P_REMAIN_ON_CHANNEL_DEFAULT,
2982 CFG_DEBUG_P2P_REMAIN_ON_CHANNEL_MIN,
2983 CFG_DEBUG_P2P_REMAIN_ON_CHANNEL_MAX),
2984
2985 REG_VARIABLE(CFG_ENABLE_PACKET_LOG, WLAN_PARAM_Integer,
2986 struct hdd_config, enablePacketLog,
2987 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2988 CFG_ENABLE_PACKET_LOG_DEFAULT,
2989 CFG_ENABLE_PACKET_LOG_MIN,
2990 CFG_ENABLE_PACKET_LOG_MAX),
2991
2992#ifdef WLAN_FEATURE_ROAM_OFFLOAD
2993 REG_VARIABLE(CFG_ROAMING_OFFLOAD_NAME, WLAN_PARAM_Integer,
2994 struct hdd_config, isRoamOffloadEnabled,
2995 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2996 CFG_ROAMING_OFFLOAD_DEFAULT,
2997 CFG_ROAMING_OFFLOAD_MIN,
2998 CFG_ROAMING_OFFLOAD_MAX),
2999#endif
3000#ifdef MSM_PLATFORM
3001 REG_VARIABLE(CFG_BUS_BANDWIDTH_HIGH_THRESHOLD, WLAN_PARAM_Integer,
3002 struct hdd_config, busBandwidthHighThreshold,
3003 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3004 CFG_BUS_BANDWIDTH_HIGH_THRESHOLD_DEFAULT,
3005 CFG_BUS_BANDWIDTH_HIGH_THRESHOLD_MIN,
3006 CFG_BUS_BANDWIDTH_HIGH_THRESHOLD_MAX),
3007
3008 REG_VARIABLE(CFG_BUS_BANDWIDTH_MEDIUM_THRESHOLD, WLAN_PARAM_Integer,
3009 struct hdd_config, busBandwidthMediumThreshold,
3010 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3011 CFG_BUS_BANDWIDTH_MEDIUM_THRESHOLD_DEFAULT,
3012 CFG_BUS_BANDWIDTH_MEDIUM_THRESHOLD_MIN,
3013 CFG_BUS_BANDWIDTH_MEDIUM_THRESHOLD_MAX),
3014
3015 REG_VARIABLE(CFG_BUS_BANDWIDTH_LOW_THRESHOLD, WLAN_PARAM_Integer,
3016 struct hdd_config, busBandwidthLowThreshold,
3017 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3018 CFG_BUS_BANDWIDTH_LOW_THRESHOLD_DEFAULT,
3019 CFG_BUS_BANDWIDTH_LOW_THRESHOLD_MIN,
3020 CFG_BUS_BANDWIDTH_LOW_THRESHOLD_MAX),
3021
3022 REG_VARIABLE(CFG_BUS_BANDWIDTH_COMPUTE_INTERVAL, WLAN_PARAM_Integer,
3023 struct hdd_config, busBandwidthComputeInterval,
3024 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3025 CFG_BUS_BANDWIDTH_COMPUTE_INTERVAL_DEFAULT,
3026 CFG_BUS_BANDWIDTH_COMPUTE_INTERVAL_MIN,
3027 CFG_BUS_BANDWIDTH_COMPUTE_INTERVAL_MAX),
3028 REG_VARIABLE(CFG_TCP_DELACK_THRESHOLD_HIGH, WLAN_PARAM_Integer,
3029 struct hdd_config, tcpDelackThresholdHigh,
3030 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3031 CFG_TCP_DELACK_THRESHOLD_HIGH_DEFAULT,
3032 CFG_TCP_DELACK_THRESHOLD_HIGH_MIN,
3033 CFG_TCP_DELACK_THRESHOLD_HIGH_MAX),
3034 REG_VARIABLE(CFG_TCP_DELACK_THRESHOLD_LOW, WLAN_PARAM_Integer,
3035 struct hdd_config, tcpDelackThresholdLow,
3036 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3037 CFG_TCP_DELACK_THRESHOLD_LOW_DEFAULT,
3038 CFG_TCP_DELACK_THRESHOLD_LOW_MIN,
3039 CFG_TCP_DELACK_THRESHOLD_LOW_MAX),
Mohit Khannae71e2262015-11-10 09:37:24 -08003040
3041 REG_VARIABLE(CFG_TCP_TX_HIGH_TPUT_THRESHOLD_NAME, WLAN_PARAM_Integer,
3042 struct hdd_config, tcp_tx_high_tput_thres,
3043 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3044 CFG_TCP_TX_HIGH_TPUT_THRESHOLD_DEFAULT,
3045 CFG_TCP_TX_HIGH_TPUT_THRESHOLD_MIN,
3046 CFG_TCP_TX_HIGH_TPUT_THRESHOLD_MAX),
3047
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003048#endif
3049
3050 REG_VARIABLE(CFG_ENABLE_FW_LOG_TYPE, WLAN_PARAM_Integer,
3051 struct hdd_config, enableFwLogType,
3052 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3053 CFG_ENABLE_FW_LOG_TYPE_DEFAULT,
3054 CFG_ENABLE_FW_LOG_TYPE_MIN,
3055 CFG_ENABLE_FW_LOG_TYPE_MAX),
3056
3057 REG_VARIABLE(CFG_ENABLE_FW_DEBUG_LOG_LEVEL, WLAN_PARAM_Integer,
3058 struct hdd_config, enableFwLogLevel,
3059 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3060 CFG_ENABLE_FW_DEBUG_LOG_LEVEL_DEFAULT,
3061 CFG_ENABLE_FW_DEBUG_LOG_LEVEL_MIN,
3062 CFG_ENABLE_FW_DEBUG_LOG_LEVEL_MAX),
3063
3064 REG_VARIABLE_STRING(CFG_ENABLE_FW_MODULE_LOG_LEVEL, WLAN_PARAM_String,
3065 struct hdd_config, enableFwModuleLogLevel,
3066 VAR_FLAGS_OPTIONAL,
3067 (void *)CFG_ENABLE_FW_MODULE_LOG_DEFAULT),
3068
3069#ifdef WLAN_FEATURE_11W
3070 REG_VARIABLE(CFG_PMF_SA_QUERY_MAX_RETRIES_NAME, WLAN_PARAM_Integer,
3071 struct hdd_config, pmfSaQueryMaxRetries,
3072 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3073 CFG_PMF_SA_QUERY_MAX_RETRIES_DEFAULT,
3074 CFG_PMF_SA_QUERY_MAX_RETRIES_MIN,
3075 CFG_PMF_SA_QUERY_MAX_RETRIES_MAX),
3076
3077 REG_VARIABLE(CFG_PMF_SA_QUERY_RETRY_INTERVAL_NAME, WLAN_PARAM_Integer,
3078 struct hdd_config, pmfSaQueryRetryInterval,
3079 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3080 CFG_PMF_SA_QUERY_RETRY_INTERVAL_DEFAULT,
3081 CFG_PMF_SA_QUERY_RETRY_INTERVAL_MIN,
3082 CFG_PMF_SA_QUERY_RETRY_INTERVAL_MAX),
3083#endif
3084 REG_VARIABLE(CFG_MAX_CONCURRENT_CONNECTIONS_NAME, WLAN_PARAM_Integer,
3085 struct hdd_config, gMaxConcurrentActiveSessions,
3086 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3087 CFG_MAX_CONCURRENT_CONNECTIONS_DEFAULT,
3088 CFG_MAX_CONCURRENT_CONNECTIONS_MIN,
3089 CFG_MAX_CONCURRENT_CONNECTIONS_MAX),
3090
3091#ifdef FEATURE_GREEN_AP
3092 REG_VARIABLE(CFG_ENABLE_GREEN_AP_FEATURE, WLAN_PARAM_Integer,
3093 struct hdd_config, enableGreenAP,
3094 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3095 CFG_ENABLE_GREEN_AP_FEATURE_DEFAULT,
3096 CFG_ENABLE_GREEN_AP_FEATURE_MIN,
3097 CFG_ENABLE_GREEN_AP_FEATURE_MAX),
Ryan Hsucb118cf2015-11-09 16:03:53 -08003098 REG_VARIABLE(CFG_ENABLE_EGAP_ENABLE_FEATURE, WLAN_PARAM_Integer,
3099 struct hdd_config, enable_egap,
3100 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3101 CFG_ENABLE_EGAP_ENABLE_FEATURE_DEFAULT,
3102 CFG_ENABLE_EGAP_ENABLE_FEATURE_MIN,
3103 CFG_ENABLE_EGAP_ENABLE_FEATURE_MAX),
3104 REG_VARIABLE(CFG_ENABLE_EGAP_INACT_TIME_FEATURE, WLAN_PARAM_Integer,
3105 struct hdd_config, egap_inact_time,
3106 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3107 CFG_ENABLE_EGAP_INACT_TIME_FEATURE_DEFAULT,
3108 CFG_ENABLE_EGAP_INACT_TIME_FEATURE_MIN,
3109 CFG_ENABLE_EGAP_INACT_TIME_FEATURE_MAX),
3110 REG_VARIABLE(CFG_ENABLE_EGAP_WAIT_TIME_FEATURE, WLAN_PARAM_Integer,
3111 struct hdd_config, egap_wait_time,
3112 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3113 CFG_ENABLE_EGAP_WAIT_TIME_FEATURE_DEFAULT,
3114 CFG_ENABLE_EGAP_WAIT_TIME_FEATURE_MIN,
3115 CFG_ENABLE_EGAP_WAIT_TIME_FEATURE_MAX),
3116 REG_VARIABLE(CFG_ENABLE_EGAP_FLAGS_FEATURE, WLAN_PARAM_Integer,
3117 struct hdd_config, egap_feature_flag,
3118 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3119 CFG_ENABLE_EGAP_FLAGS_FEATURE_DEFAULT,
3120 CFG_ENABLE_EGAP_FLAGS_FEATURE_MIN,
3121 CFG_ENABLE_EGAP_FLAGS_FEATURE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003122#endif
3123
3124 REG_VARIABLE(CFG_IGNORE_CAC_NAME, WLAN_PARAM_Integer,
3125 struct hdd_config, ignoreCAC,
3126 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3127 CFG_IGNORE_CAC_DEFAULT,
3128 CFG_IGNORE_CAC_MIN,
3129 CFG_IGNORE_CAC_MAX),
3130
3131 REG_VARIABLE(CFG_ENABLE_SAP_DFS_CH_SIFS_BURST_NAME, WLAN_PARAM_Integer,
3132 struct hdd_config, IsSapDfsChSifsBurstEnabled,
3133 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3134 CFG_ENABLE_SAP_DFS_CH_SIFS_BURST_DEFAULT,
3135 CFG_ENABLE_SAP_DFS_CH_SIFS_BURST_MIN,
3136 CFG_ENABLE_SAP_DFS_CH_SIFS_BURST_MAX),
3137
3138 REG_VARIABLE(CFG_DFS_RADAR_PRI_MULTIPLIER_NAME, WLAN_PARAM_Integer,
3139 struct hdd_config, dfsRadarPriMultiplier,
3140 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3141 CFG_DFS_RADAR_PRI_MULTIPLIER_DEFAULT,
3142 CFG_DFS_RADAR_PRI_MULTIPLIER_MIN,
3143 CFG_DFS_RADAR_PRI_MULTIPLIER_MAX),
3144
3145 REG_VARIABLE(CFG_REORDER_OFFLOAD_SUPPORT_NAME, WLAN_PARAM_Integer,
3146 struct hdd_config, reorderOffloadSupport,
3147 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3148 CFG_REORDER_OFFLOAD_SUPPORT_DEFAULT,
3149 CFG_REORDER_OFFLOAD_SUPPORT_MIN,
3150 CFG_REORDER_OFFLOAD_SUPPORT_MAX),
3151
3152 REG_VARIABLE(CFG_IPA_UC_TX_BUF_COUNT_NAME, WLAN_PARAM_Integer,
3153 struct hdd_config, IpaUcTxBufCount,
3154 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3155 CFG_IPA_UC_TX_BUF_COUNT_DEFAULT,
3156 CFG_IPA_UC_TX_BUF_COUNT_MIN,
3157 CFG_IPA_UC_TX_BUF_COUNT_MAX),
3158
3159 REG_VARIABLE(CFG_IPA_UC_TX_BUF_SIZE_NAME, WLAN_PARAM_Integer,
3160 struct hdd_config, IpaUcTxBufSize,
3161 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3162 CFG_IPA_UC_TX_BUF_SIZE_DEFAULT,
3163 CFG_IPA_UC_TX_BUF_SIZE_MIN,
3164 CFG_IPA_UC_TX_BUF_SIZE_MAX),
3165
3166 REG_VARIABLE(CFG_IPA_UC_RX_IND_RING_COUNT_NAME, WLAN_PARAM_Integer,
3167 struct hdd_config, IpaUcRxIndRingCount,
3168 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3169 CFG_IPA_UC_RX_IND_RING_COUNT_DEFAULT,
3170 CFG_IPA_UC_RX_IND_RING_COUNT_MIN,
3171 CFG_IPA_UC_RX_IND_RING_COUNT_MAX),
3172
3173 REG_VARIABLE(CFG_IPA_UC_TX_PARTITION_BASE_NAME, WLAN_PARAM_Integer,
3174 struct hdd_config, IpaUcTxPartitionBase,
3175 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3176 CFG_IPA_UC_TX_PARTITION_BASE_DEFAULT,
3177 CFG_IPA_UC_TX_PARTITION_BASE_MIN,
3178 CFG_IPA_UC_TX_PARTITION_BASE_MAX),
3179#ifdef WLAN_LOGGING_SOCK_SVC_ENABLE
3180 REG_VARIABLE(CFG_WLAN_LOGGING_SUPPORT_NAME, WLAN_PARAM_Integer,
3181 struct hdd_config, wlanLoggingEnable,
3182 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3183 CFG_WLAN_LOGGING_SUPPORT_DEFAULT,
3184 CFG_WLAN_LOGGING_SUPPORT_DISABLE,
3185 CFG_WLAN_LOGGING_SUPPORT_ENABLE),
3186
3187 REG_VARIABLE(CFG_WLAN_LOGGING_FE_CONSOLE_SUPPORT_NAME,
3188 WLAN_PARAM_Integer,
3189 struct hdd_config, wlanLoggingFEToConsole,
3190 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3191 CFG_WLAN_LOGGING_FE_CONSOLE_SUPPORT_DEFAULT,
3192 CFG_WLAN_LOGGING_FE_CONSOLE_SUPPORT_DISABLE,
3193 CFG_WLAN_LOGGING_FE_CONSOLE_SUPPORT_ENABLE),
3194
3195 REG_VARIABLE(CFG_WLAN_LOGGING_NUM_BUF_NAME, WLAN_PARAM_Integer,
3196 struct hdd_config, wlanLoggingNumBuf,
3197 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3198 CFG_WLAN_LOGGING_NUM_BUF_DEFAULT,
3199 CFG_WLAN_LOGGING_NUM_BUF_MIN,
3200 CFG_WLAN_LOGGING_NUM_BUF_MAX),
3201#endif /* WLAN_LOGGING_SOCK_SVC_ENABLE */
3202
3203 REG_VARIABLE(CFG_ENABLE_SIFS_BURST, WLAN_PARAM_Integer,
3204 struct hdd_config, enableSifsBurst,
3205 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3206 CFG_ENABLE_SIFS_BURST_DEFAULT,
3207 CFG_ENABLE_SIFS_BURST_MIN,
3208 CFG_ENABLE_SIFS_BURST_MAX),
3209
3210#ifdef WLAN_FEATURE_LPSS
3211 REG_VARIABLE(CFG_ENABLE_LPASS_SUPPORT, WLAN_PARAM_Integer,
Komal Seelamc11bb222016-01-27 18:57:10 +05303212 struct hdd_config, enable_lpass_support,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003213 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3214 CFG_ENABLE_LPASS_SUPPORT_DEFAULT,
3215 CFG_ENABLE_LPASS_SUPPORT_MIN,
3216 CFG_ENABLE_LPASS_SUPPORT_MAX),
3217#endif
3218
3219#ifdef WLAN_FEATURE_NAN
3220 REG_VARIABLE(CFG_ENABLE_NAN_SUPPORT, WLAN_PARAM_Integer,
3221 struct hdd_config, enable_nan_support,
3222 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3223 CFG_ENABLE_NAN_SUPPORT_DEFAULT,
3224 CFG_ENABLE_NAN_SUPPORT_MIN,
3225 CFG_ENABLE_NAN_SUPPORT_MAX),
3226#endif
3227
3228 REG_VARIABLE(CFG_ENABLE_SELF_RECOVERY, WLAN_PARAM_Integer,
3229 struct hdd_config, enableSelfRecovery,
3230 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3231 CFG_ENABLE_SELF_RECOVERY_DEFAULT,
3232 CFG_ENABLE_SELF_RECOVERY_MIN,
3233 CFG_ENABLE_SELF_RECOVERY_MAX),
3234
3235#ifdef FEATURE_WLAN_FORCE_SAP_SCC
3236 REG_VARIABLE(CFG_SAP_SCC_CHAN_AVOIDANCE, WLAN_PARAM_Integer,
3237 struct hdd_config, SapSccChanAvoidance,
3238 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3239 CFG_SAP_SCC_CHAN_AVOIDANCE_DEFAULT,
3240 CFG_SAP_SCC_CHAN_AVOIDANCE_MIN,
3241 CFG_SAP_SCC_CHAN_AVOIDANCE_MAX),
3242#endif /* FEATURE_WLAN_FORCE_SAP_SCC */
3243
3244 REG_VARIABLE(CFG_ENABLE_SAP_SUSPEND, WLAN_PARAM_Integer,
3245 struct hdd_config, enableSapSuspend,
3246 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3247 CFG_ENABLE_SAP_SUSPEND_DEFAULT,
3248 CFG_ENABLE_SAP_SUSPEND_MIN,
3249 CFG_ENABLE_SAP_SUSPEND_MAX),
3250
3251#ifdef WLAN_FEATURE_EXTWOW_SUPPORT
3252 REG_VARIABLE(CFG_EXTWOW_GO_TO_SUSPEND, WLAN_PARAM_Integer,
3253 struct hdd_config, extWowGotoSuspend,
3254 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3255 CFG_EXTWOW_GO_TO_SUSPEND_DEFAULT,
3256 CFG_EXTWOW_GO_TO_SUSPEND_MIN,
3257 CFG_EXTWOW_GO_TO_SUSPEND_MAX),
3258
3259 REG_VARIABLE(CFG_EXTWOW_APP1_WAKE_PIN_NUMBER, WLAN_PARAM_Integer,
3260 struct hdd_config, extWowApp1WakeupPinNumber,
3261 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3262 CFG_EXTWOW_APP1_WAKE_PIN_NUMBER_DEFAULT,
3263 CFG_EXTWOW_APP1_WAKE_PIN_NUMBER_MIN,
3264 CFG_EXTWOW_APP1_WAKE_PIN_NUMBER_MAX),
3265
3266 REG_VARIABLE(CFG_EXTWOW_APP2_WAKE_PIN_NUMBER, WLAN_PARAM_Integer,
3267 struct hdd_config, extWowApp2WakeupPinNumber,
3268 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3269 CFG_EXTWOW_APP2_WAKE_PIN_NUMBER_DEFAULT,
3270 CFG_EXTWOW_APP2_WAKE_PIN_NUMBER_MIN,
3271 CFG_EXTWOW_APP2_WAKE_PIN_NUMBER_MAX),
3272
3273 REG_VARIABLE(CFG_EXTWOW_KA_INIT_PING_INTERVAL, WLAN_PARAM_Integer,
3274 struct hdd_config, extWowApp2KAInitPingInterval,
3275 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3276 CFG_EXTWOW_KA_INIT_PING_INTERVAL_DEFAULT,
3277 CFG_EXTWOW_KA_INIT_PING_INTERVAL_MIN,
3278 CFG_EXTWOW_KA_INIT_PING_INTERVAL_MAX),
3279
3280 REG_VARIABLE(CFG_EXTWOW_KA_MIN_PING_INTERVAL, WLAN_PARAM_Integer,
3281 struct hdd_config, extWowApp2KAMinPingInterval,
3282 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3283 CFG_EXTWOW_KA_MIN_PING_INTERVAL_DEFAULT,
3284 CFG_EXTWOW_KA_MIN_PING_INTERVAL_MIN,
3285 CFG_EXTWOW_KA_MIN_PING_INTERVAL_MAX),
3286
3287 REG_VARIABLE(CFG_EXTWOW_KA_MAX_PING_INTERVAL, WLAN_PARAM_Integer,
3288 struct hdd_config, extWowApp2KAMaxPingInterval,
3289 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3290 CFG_EXTWOW_KA_MAX_PING_INTERVAL_DEFAULT,
3291 CFG_EXTWOW_KA_MAX_PING_INTERVAL_MIN,
3292 CFG_EXTWOW_KA_MAX_PING_INTERVAL_MAX),
3293
3294 REG_VARIABLE(CFG_EXTWOW_KA_INC_PING_INTERVAL, WLAN_PARAM_Integer,
3295 struct hdd_config, extWowApp2KAIncPingInterval,
3296 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3297 CFG_EXTWOW_KA_INC_PING_INTERVAL_DEFAULT,
3298 CFG_EXTWOW_KA_INC_PING_INTERVAL_MIN,
3299 CFG_EXTWOW_KA_INC_PING_INTERVAL_MAX),
3300
3301 REG_VARIABLE(CFG_EXTWOW_TCP_SRC_PORT, WLAN_PARAM_Integer,
3302 struct hdd_config, extWowApp2TcpSrcPort,
3303 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3304 CFG_EXTWOW_TCP_SRC_PORT_DEFAULT,
3305 CFG_EXTWOW_TCP_SRC_PORT_MIN,
3306 CFG_EXTWOW_TCP_SRC_PORT_MAX),
3307
3308 REG_VARIABLE(CFG_EXTWOW_TCP_DST_PORT, WLAN_PARAM_Integer,
3309 struct hdd_config, extWowApp2TcpDstPort,
3310 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3311 CFG_EXTWOW_TCP_DST_PORT_DEFAULT,
3312 CFG_EXTWOW_TCP_DST_PORT_MIN,
3313 CFG_EXTWOW_TCP_DST_PORT_MAX),
3314
3315 REG_VARIABLE(CFG_EXTWOW_TCP_TX_TIMEOUT, WLAN_PARAM_Integer,
3316 struct hdd_config, extWowApp2TcpTxTimeout,
3317 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3318 CFG_EXTWOW_TCP_TX_TIMEOUT_DEFAULT,
3319 CFG_EXTWOW_TCP_TX_TIMEOUT_MIN,
3320 CFG_EXTWOW_TCP_TX_TIMEOUT_MAX),
3321
3322 REG_VARIABLE(CFG_EXTWOW_TCP_RX_TIMEOUT, WLAN_PARAM_Integer,
3323 struct hdd_config, extWowApp2TcpRxTimeout,
3324 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3325 CFG_EXTWOW_TCP_RX_TIMEOUT_DEFAULT,
3326 CFG_EXTWOW_TCP_RX_TIMEOUT_MIN,
3327 CFG_EXTWOW_TCP_RX_TIMEOUT_MAX),
3328#endif
3329 REG_VARIABLE(CFG_ENABLE_DEAUTH_TO_DISASSOC_MAP_NAME, WLAN_PARAM_Integer,
3330 struct hdd_config, gEnableDeauthToDisassocMap,
3331 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3332 CFG_ENABLE_DEAUTH_TO_DISASSOC_MAP_DEFAULT,
3333 CFG_ENABLE_DEAUTH_TO_DISASSOC_MAP_MIN,
3334 CFG_ENABLE_DEAUTH_TO_DISASSOC_MAP_MAX),
3335#ifdef DHCP_SERVER_OFFLOAD
3336 REG_VARIABLE(CFG_DHCP_SERVER_OFFLOAD_SUPPORT_NAME, WLAN_PARAM_Integer,
3337 struct hdd_config, enableDHCPServerOffload,
3338 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3339 CFG_DHCP_SERVER_OFFLOAD_SUPPORT_DEFAULT,
3340 CFG_DHCP_SERVER_OFFLOAD_SUPPORT_MIN,
3341 CFG_DHCP_SERVER_OFFLOAD_SUPPORT_MAX),
3342 REG_VARIABLE(CFG_DHCP_SERVER_OFFLOAD_NUM_CLIENT_NAME,
3343 WLAN_PARAM_Integer,
3344 struct hdd_config, dhcpMaxNumClients,
3345 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3346 CFG_DHCP_SERVER_OFFLOAD_NUM_CLIENT_DEFAULT,
3347 CFG_DHCP_SERVER_OFFLOAD_NUM_CLIENT_MIN,
3348 CFG_DHCP_SERVER_OFFLOAD_NUM_CLIENT_MAX),
3349 REG_VARIABLE_STRING(CFG_DHCP_SERVER_IP_NAME, WLAN_PARAM_String,
3350 struct hdd_config, dhcpServerIP,
3351 VAR_FLAGS_OPTIONAL,
3352 (void *)CFG_DHCP_SERVER_IP_DEFAULT),
3353#endif /* DHCP_SERVER_OFFLOAD */
3354
3355 REG_VARIABLE(CFG_ENABLE_DEAUTH_BEFORE_CONNECTION, WLAN_PARAM_Integer,
3356 struct hdd_config, sendDeauthBeforeCon,
3357 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3358 CFG_ENABLE_DEAUTH_BEFORE_CONNECTION_DEFAULT,
3359 CFG_ENABLE_DEAUTH_BEFORE_CONNECTION_MIN,
3360 CFG_ENABLE_DEAUTH_BEFORE_CONNECTION_MAX),
3361
3362 REG_VARIABLE(CFG_ENABLE_MAC_ADDR_SPOOFING, WLAN_PARAM_Integer,
3363 struct hdd_config, enable_mac_spoofing,
3364 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3365 CFG_ENABLE_MAC_ADDR_SPOOFING_DEFAULT,
3366 CFG_ENABLE_MAC_ADDR_SPOOFING_MIN,
3367 CFG_ENABLE_MAC_ADDR_SPOOFING_MAX),
3368
3369 REG_VARIABLE(CFG_ENABLE_CUSTOM_CONC_RULE1_NAME, WLAN_PARAM_Integer,
3370 struct hdd_config, conc_custom_rule1,
3371 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3372 CFG_ENABLE_CUSTOM_CONC_RULE1_NAME_DEFAULT,
3373 CFG_ENABLE_CUSTOM_CONC_RULE1_NAME_MIN,
3374 CFG_ENABLE_CUSTOM_CONC_RULE1_NAME_MAX),
3375
3376 REG_VARIABLE(CFG_ENABLE_CUSTOM_CONC_RULE2_NAME, WLAN_PARAM_Integer,
3377 struct hdd_config, conc_custom_rule2,
3378 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3379 CFG_ENABLE_CUSTOM_CONC_RULE2_NAME_DEFAULT,
3380 CFG_ENABLE_CUSTOM_CONC_RULE2_NAME_MIN,
3381 CFG_ENABLE_CUSTOM_CONC_RULE2_NAME_MAX),
3382
3383 REG_VARIABLE(CFG_ENABLE_STA_CONNECTION_IN_5GHZ, WLAN_PARAM_Integer,
3384 struct hdd_config, is_sta_connection_in_5gz_enabled,
3385 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3386 CFG_ENABLE_STA_CONNECTION_IN_5GHZ_DEFAULT,
3387 CFG_ENABLE_STA_CONNECTION_IN_5GHZ_MIN,
3388 CFG_ENABLE_STA_CONNECTION_IN_5GHZ_MAX),
3389
3390 REG_VARIABLE(CFG_STA_MIRACAST_MCC_REST_TIME_VAL, WLAN_PARAM_Integer,
3391 struct hdd_config, sta_miracast_mcc_rest_time_val,
3392 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3393 CFG_STA_MIRACAST_MCC_REST_TIME_VAL_DEFAULT,
3394 CFG_STA_MIRACAST_MCC_REST_TIME_VAL_MIN,
3395 CFG_STA_MIRACAST_MCC_REST_TIME_VAL_MAX),
3396
3397#ifdef FEATURE_AP_MCC_CH_AVOIDANCE
3398 REG_VARIABLE(CFG_SAP_MCC_CHANNEL_AVOIDANCE_NAME,
3399 WLAN_PARAM_Integer,
3400 struct hdd_config,
3401 sap_channel_avoidance,
3402 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3403 CFG_SAP_MCC_CHANNEL_AVOIDANCE_DEFAULT,
3404 CFG_SAP_MCC_CHANNEL_AVOIDANCE_MIN,
3405 CFG_SAP_MCC_CHANNEL_AVOIDANCE_MAX),
3406#endif /* FEATURE_AP_MCC_CH_AVOIDANCE */
3407
3408 REG_VARIABLE(CFG_SAP_P2P_11AC_OVERRIDE_NAME, WLAN_PARAM_Integer,
3409 struct hdd_config, sap_p2p_11ac_override,
3410 VAR_FLAGS_OPTIONAL |
3411 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3412 CFG_SAP_P2P_11AC_OVERRIDE_DEFAULT,
3413 CFG_SAP_P2P_11AC_OVERRIDE_MIN,
3414 CFG_SAP_P2P_11AC_OVERRIDE_MAX),
3415
3416 REG_VARIABLE(CFG_ENABLE_RAMDUMP_COLLECTION, WLAN_PARAM_Integer,
3417 struct hdd_config, is_ramdump_enabled,
3418 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3419 CFG_ENABLE_RAMDUMP_COLLECTION_DEFAULT,
3420 CFG_ENABLE_RAMDUMP_COLLECTION_MIN,
3421 CFG_ENABLE_RAMDUMP_COLLECTION_MAX),
3422
3423 REG_VARIABLE(CFG_SAP_DOT11MC, WLAN_PARAM_Integer,
3424 struct hdd_config, sap_dot11mc,
3425 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3426 CFG_SAP_DOT11MC_DEFAULT,
3427 CFG_SAP_DOT11MC_MIN,
3428 CFG_SAP_DOT11MC_MAX),
3429
3430 REG_VARIABLE(CFG_ENABLE_NON_DFS_CHAN_ON_RADAR, WLAN_PARAM_Integer,
3431 struct hdd_config, prefer_non_dfs_on_radar,
3432 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3433 CFG_ENABLE_NON_DFS_CHAN_ON_RADAR_DEFAULT,
3434 CFG_ENABLE_NON_DFS_CHAN_ON_RADAR_MIN,
3435 CFG_ENABLE_NON_DFS_CHAN_ON_RADAR_MAX),
3436
3437 REG_VARIABLE(CFG_MULTICAST_HOST_FW_MSGS, WLAN_PARAM_Integer,
3438 struct hdd_config, multicast_host_fw_msgs,
3439 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3440 CFG_MULTICAST_HOST_FW_MSGS_DEFAULT,
3441 CFG_MULTICAST_HOST_FW_MSGS_MIN,
3442 CFG_MULTICAST_HOST_FW_MSGS_MAX),
3443
3444 REG_VARIABLE(CFG_CONC_SYSTEM_PREF, WLAN_PARAM_Integer,
3445 struct hdd_config, conc_system_pref,
3446 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3447 CFG_CONC_SYSTEM_PREF_DEFAULT,
3448 CFG_CONC_SYSTEM_PREF_MIN,
3449 CFG_CONC_SYSTEM_PREF_MAX),
3450
3451 REG_VARIABLE(CFG_POLICY_MNGR_ENABLE, WLAN_PARAM_Integer,
3452 struct hdd_config, policy_manager_enabled,
3453 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3454 CFG_POLICY_MNGR_ENABLE_DEFAULT,
3455 CFG_POLICY_MNGR_ENABLE_MIN,
3456 CFG_POLICY_MNGR_ENABLE_MAX),
3457
3458 REG_VARIABLE(CFG_TSO_ENABLED_NAME, WLAN_PARAM_Integer,
3459 struct hdd_config, tso_enable,
3460 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3461 CFG_TSO_ENABLED_DEFAULT,
3462 CFG_TSO_ENABLED_MIN,
3463 CFG_TSO_ENABLED_MAX),
3464
3465 REG_VARIABLE(CFG_LRO_ENABLED_NAME, WLAN_PARAM_Integer,
3466 struct hdd_config, lro_enable,
3467 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3468 CFG_LRO_ENABLED_DEFAULT,
3469 CFG_LRO_ENABLED_MIN,
3470 CFG_LRO_ENABLED_MAX),
3471
3472 REG_VARIABLE(CFG_ACTIVE_MODE_OFFLOAD, WLAN_PARAM_Integer,
3473 struct hdd_config, active_mode_offload,
3474 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3475 CFG_ACTIVE_MODE_OFFLOAD_DEFAULT,
3476 CFG_ACTIVE_MODE_OFFLOAD_MIN,
3477 CFG_ACTIVE_MODE_OFFLOAD_MAX),
3478
3479 REG_VARIABLE(CFG_FINE_TIME_MEAS_CAPABILITY, WLAN_PARAM_HexInteger,
3480 struct hdd_config, fine_time_meas_cap,
3481 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3482 CFG_FINE_TIME_MEAS_CAPABILITY_DEFAULT,
3483 CFG_FINE_TIME_MEAS_CAPABILITY_MIN,
3484 CFG_FINE_TIME_MEAS_CAPABILITY_MAX),
3485
3486#ifdef WLAN_FEATURE_FASTPATH
3487 REG_VARIABLE(CFG_ENABLE_FASTPATH, WLAN_PARAM_Integer,
3488 struct hdd_config, fastpath_enable,
3489 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3490 CFG_ENABLE_FASTPATH_DEFAULT,
3491 CFG_ENABLE_FASTPATH_MIN,
3492 CFG_ENABLE_FASTPATH_MAX),
3493#endif
3494 REG_VARIABLE(CFG_MAX_SCAN_COUNT_NAME, WLAN_PARAM_Integer,
3495 struct hdd_config, max_scan_count,
3496 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3497 CFG_MAX_SCAN_COUNT_DEFAULT,
3498 CFG_MAX_SCAN_COUNT_MIN,
3499 CFG_MAX_SCAN_COUNT_MAX),
3500
3501 REG_VARIABLE(CFG_DOT11P_MODE_NAME, WLAN_PARAM_Integer,
3502 struct hdd_config, dot11p_mode,
3503 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3504 CFG_DOT11P_MODE_DEFAULT,
3505 CFG_DOT11P_MODE_MIN,
3506 CFG_DOT11P_MODE_MAX),
3507
3508#ifdef FEATURE_NAPI
3509 REG_VARIABLE(CFG_NAPI_NAME, WLAN_PARAM_Integer,
3510 struct hdd_config, napi_enable,
3511 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3512 CFG_NAPI_DEFAULT,
3513 CFG_NAPI_MIN,
3514 CFG_NAPI_MAX),
3515#endif /* FEATURE_NAPI */
3516
3517#ifdef FEATURE_WLAN_EXTSCAN
3518 REG_VARIABLE(CFG_EXTSCAN_PASSIVE_MAX_CHANNEL_TIME_NAME,
3519 WLAN_PARAM_Integer,
3520 struct hdd_config, extscan_passive_max_chn_time,
3521 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3522 CFG_EXTSCAN_PASSIVE_MAX_CHANNEL_TIME_DEFAULT,
3523 CFG_EXTSCAN_PASSIVE_MAX_CHANNEL_TIME_MIN,
3524 CFG_EXTSCAN_PASSIVE_MAX_CHANNEL_TIME_MAX),
3525
3526 REG_VARIABLE(CFG_EXTSCAN_PASSIVE_MIN_CHANNEL_TIME_NAME,
3527 WLAN_PARAM_Integer,
3528 struct hdd_config, extscan_passive_min_chn_time,
3529 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3530 CFG_EXTSCAN_PASSIVE_MIN_CHANNEL_TIME_DEFAULT,
3531 CFG_EXTSCAN_PASSIVE_MIN_CHANNEL_TIME_MIN,
3532 CFG_EXTSCAN_PASSIVE_MIN_CHANNEL_TIME_MAX),
3533
3534 REG_VARIABLE(CFG_EXTSCAN_ACTIVE_MAX_CHANNEL_TIME_NAME,
3535 WLAN_PARAM_Integer,
3536 struct hdd_config, extscan_active_max_chn_time,
3537 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3538 CFG_EXTSCAN_ACTIVE_MAX_CHANNEL_TIME_DEFAULT,
3539 CFG_EXTSCAN_ACTIVE_MAX_CHANNEL_TIME_MIN,
3540 CFG_EXTSCAN_ACTIVE_MAX_CHANNEL_TIME_MAX),
3541
3542 REG_VARIABLE(CFG_EXTSCAN_ACTIVE_MIN_CHANNEL_TIME_NAME,
3543 WLAN_PARAM_Integer,
3544 struct hdd_config, extscan_active_min_chn_time,
3545 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3546 CFG_EXTSCAN_ACTIVE_MIN_CHANNEL_TIME_DEFAULT,
3547 CFG_EXTSCAN_ACTIVE_MIN_CHANNEL_TIME_MIN,
3548 CFG_EXTSCAN_ACTIVE_MIN_CHANNEL_TIME_MAX),
3549#endif
3550
3551 REG_VARIABLE(CFG_CE_CLASSIFY_ENABLE_NAME, WLAN_PARAM_Integer,
3552 struct hdd_config, ce_classify_enabled,
3553 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3554 CFG_CE_CLASSIFY_ENABLE_DEFAULT,
3555 CFG_CE_CLASSIFY_ENABLE_MIN,
3556 CFG_CE_CLASSIFY_ENABLE_MAX),
3557
3558 REG_VARIABLE(CFG_DUAL_MAC_FEATURE_DISABLE, WLAN_PARAM_HexInteger,
3559 struct hdd_config, dual_mac_feature_disable,
3560 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3561 CFG_DUAL_MAC_FEATURE_DISABLE_DEFAULT,
3562 CFG_DUAL_MAC_FEATURE_DISABLE_MIN,
3563 CFG_DUAL_MAC_FEATURE_DISABLE_MAX),
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07003564#ifdef FEATURE_WLAN_SCAN_PNO
3565 REG_VARIABLE(CFG_PNO_CHANNEL_PREDICTION_NAME, WLAN_PARAM_Integer,
3566 struct hdd_config, pno_channel_prediction,
3567 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3568 CFG_PNO_CHANNEL_PREDICTION_DEFAULT,
3569 CFG_PNO_CHANNEL_PREDICTION_MIN,
3570 CFG_PNO_CHANNEL_PREDICTION_MAX),
3571
3572 REG_VARIABLE(CFG_TOP_K_NUM_OF_CHANNELS_NAME, WLAN_PARAM_Integer,
3573 struct hdd_config, top_k_num_of_channels,
3574 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3575 CFG_TOP_K_NUM_OF_CHANNELS_DEFAULT,
3576 CFG_TOP_K_NUM_OF_CHANNELS_MIN,
3577 CFG_TOP_K_NUM_OF_CHANNELS_MAX),
3578
3579 REG_VARIABLE(CFG_STATIONARY_THRESHOLD_NAME, WLAN_PARAM_Integer,
3580 struct hdd_config, stationary_thresh,
3581 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3582 CFG_STATIONARY_THRESHOLD_DEFAULT,
3583 CFG_STATIONARY_THRESHOLD_MIN,
3584 CFG_STATIONARY_THRESHOLD_MAX),
3585
3586 REG_VARIABLE(CFG_CHANNEL_PREDICTION_FULL_SCAN_MS_NAME,
3587 WLAN_PARAM_Integer,
3588 struct hdd_config, channel_prediction_full_scan,
3589 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3590 CFG_CHANNEL_PREDICTION_FULL_SCAN_MS_DEFAULT,
3591 CFG_CHANNEL_PREDICTION_FULL_SCAN_MS_MIN,
3592 CFG_CHANNEL_PREDICTION_FULL_SCAN_MS_MAX),
3593#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003594
3595 REG_VARIABLE(CFG_TX_CHAIN_MASK_CCK, WLAN_PARAM_Integer,
3596 struct hdd_config, tx_chain_mask_cck,
3597 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3598 CFG_TX_CHAIN_MASK_CCK_DEFAULT,
3599 CFG_TX_CHAIN_MASK_CCK_MIN,
3600 CFG_TX_CHAIN_MASK_CCK_MAX),
3601
3602 REG_VARIABLE(CFG_TX_CHAIN_MASK_1SS, WLAN_PARAM_Integer,
3603 struct hdd_config, tx_chain_mask_1ss,
3604 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3605 CFG_TX_CHAIN_MASK_1SS_DEFAULT,
3606 CFG_TX_CHAIN_MASK_1SS_MIN,
3607 CFG_TX_CHAIN_MASK_1SS_MAX),
3608
3609 REG_VARIABLE(CFG_SELF_GEN_FRM_PWR, WLAN_PARAM_Integer,
3610 struct hdd_config, self_gen_frm_pwr,
3611 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3612 CFG_SELF_GEN_FRM_PWR_DEFAULT,
3613 CFG_SELF_GEN_FRM_PWR_MIN,
3614 CFG_SELF_GEN_FRM_PWR_MAX),
3615
Varun Reddy Yeturu05186292015-09-28 17:12:33 -07003616 REG_VARIABLE(CFG_EARLY_STOP_SCAN_ENABLE, WLAN_PARAM_Integer,
3617 struct hdd_config, early_stop_scan_enable,
3618 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3619 CFG_EARLY_STOP_SCAN_ENABLE_DEFAULT,
3620 CFG_EARLY_STOP_SCAN_ENABLE_MIN,
3621 CFG_EARLY_STOP_SCAN_ENABLE_MAX),
3622
3623 REG_VARIABLE(CFG_EARLY_STOP_SCAN_MIN_THRESHOLD,
3624 WLAN_PARAM_SignedInteger, struct hdd_config,
3625 early_stop_scan_min_threshold,
3626 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3627 CFG_EARLY_STOP_SCAN_MIN_THRESHOLD_DEFAULT,
3628 CFG_EARLY_STOP_SCAN_MIN_THRESHOLD_MIN,
3629 CFG_EARLY_STOP_SCAN_MIN_THRESHOLD_MAX),
3630
3631 REG_VARIABLE(CFG_EARLY_STOP_SCAN_MAX_THRESHOLD,
3632 WLAN_PARAM_SignedInteger, struct hdd_config,
3633 early_stop_scan_max_threshold,
3634 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3635 CFG_EARLY_STOP_SCAN_MAX_THRESHOLD_DEFAULT,
3636 CFG_EARLY_STOP_SCAN_MAX_THRESHOLD_MIN,
3637 CFG_EARLY_STOP_SCAN_MAX_THRESHOLD_MAX),
3638
Varun Reddy Yeturu044bda22015-11-21 22:03:40 -08003639 REG_VARIABLE(CFG_FIRST_SCAN_BUCKET_THRESHOLD_NAME,
3640 WLAN_PARAM_SignedInteger,
3641 struct hdd_config, first_scan_bucket_threshold,
3642 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3643 CFG_FIRST_SCAN_BUCKET_THRESHOLD_DEFAULT,
3644 CFG_FIRST_SCAN_BUCKET_THRESHOLD_MIN,
3645 CFG_FIRST_SCAN_BUCKET_THRESHOLD_MAX),
3646
Ravi Joshi742495d2015-11-09 18:56:53 -08003647#ifdef FEATURE_LFR_SUBNET_DETECTION
3648 REG_VARIABLE(CFG_ENABLE_LFR_SUBNET_DETECTION, WLAN_PARAM_Integer,
3649 struct hdd_config, enable_lfr_subnet_detection,
3650 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3651 CFG_ENABLE_LFR_SUBNET_DEFAULT,
3652 CFG_ENABLE_LFR_SUBNET_MIN,
3653 CFG_ENABLE_LFR_SUBNET_MAX),
3654#endif
Deepak Dhamdhere68929ec2015-08-05 15:16:35 -07003655
3656 REG_VARIABLE(CFG_INFORM_BSS_RSSI_RAW_NAME, WLAN_PARAM_Integer,
3657 struct hdd_config, inform_bss_rssi_raw,
3658 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3659 CFG_INFORM_BSS_RSSI_RAW_DEFAULT,
3660 CFG_INFORM_BSS_RSSI_RAW_MIN,
3661 CFG_INFORM_BSS_RSSI_RAW_MAX),
Tushnim Bhattacharyya24e12a62015-10-12 14:51:56 -07003662
3663#ifdef QCA_WIFI_3_0_EMU
3664 REG_VARIABLE(CFG_ENABLE_M2M_LIMITATION, WLAN_PARAM_Integer,
3665 struct hdd_config, enable_m2m_limitation,
3666 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3667 CFG_ENABLE_LFR_SUBNET_DEFAULT,
3668 CFG_ENABLE_LFR_SUBNET_MIN,
3669 CFG_ENABLE_LFR_SUBNET_MAX),
3670#endif
3671
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003672};
3673
3674
3675/**
3676 * get_next_line() - find and locate the new line pointer
3677 * @str: pointer to string
3678 *
3679 * This function returns a pointer to the character after the occurence
3680 * of a new line character. It also modifies the original string by replacing
3681 * the '\n' character with the null character.
3682 *
3683 * Return: the pointer to the character at new line,
3684 * or NULL if no new line character was found
3685 */
3686static char *get_next_line(char *str)
3687{
3688 char c;
3689
3690 if (str == NULL || *str == '\0') {
3691 return NULL;
3692 }
3693
3694 c = *str;
3695 while (c != '\n' && c != '\0' && c != 0xd) {
3696 str = str + 1;
3697 c = *str;
3698 }
3699
3700 if (c == '\0') {
3701 return NULL;
3702 } else {
3703 *str = '\0';
3704 return str + 1;
3705 }
3706
3707 return NULL;
3708}
3709
3710/** look for space. Ascii values to look are
3711 * 0x09 == horizontal tab
3712 * 0x0a == Newline ("\n")
3713 * 0x0b == vertical tab
3714 * 0x0c == Newpage or feed form.
3715 * 0x0d == carriage return (CR or "\r")
3716 * Null ('\0') should not considered as space.
3717 */
3718#define i_isspace(ch) (((ch) >= 0x09 && (ch) <= 0x0d) || (ch) == ' ')
3719
3720/**
3721 * i_trim() - trims any leading and trailing white spaces
3722 * @str: pointer to string
3723 *
3724 * Return: the pointer of the string
3725 */
3726static char *i_trim(char *str)
3727{
3728 char *ptr;
3729
3730 if (*str == '\0')
3731 return str;
3732
3733 /* Find the first non white-space */
3734 ptr = str;
3735 while (i_isspace(*ptr))
3736 ptr++;
3737
3738 if (*ptr == '\0')
3739 return str;
3740
3741 /* This is the new start of the string */
3742 str = ptr;
3743
3744 /* Find the last non white-space */
3745 ptr += strlen(ptr) - 1;
3746
3747 while (ptr != str && i_isspace(*ptr))
3748 ptr--;
3749
3750 /* Null terminate the following character */
3751 ptr[1] = '\0';
3752
3753 return str;
3754}
3755
3756/* Maximum length of the confgiuration name and value */
3757#define CFG_VALUE_MAX_LEN 256
3758#define CFG_ENTRY_MAX_LEN (32+CFG_VALUE_MAX_LEN)
3759
3760/**
3761 * hdd_cfg_get_config() - get the configuration content
3762 * @reg_table: pointer to configuration table
3763 * @cRegTableEntries: number of the configuration entries
3764 * @ini_struct: pointer to the hdd config knob
3765 * @pHddCtx: pointer to hdd context
3766 * @pBuf: buffer to store the configuration
3767 * @buflen: size of the buffer
3768 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303769 * Return: QDF_STATUS_SUCCESS if the configuration and buffer size can carry
3770 * the content, otherwise QDF_STATUS_E_RESOURCES
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003771 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303772static QDF_STATUS hdd_cfg_get_config(REG_TABLE_ENTRY *reg_table,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003773 unsigned long cRegTableEntries,
3774 uint8_t *ini_struct,
3775 hdd_context_t *pHddCtx, char *pBuf,
3776 int buflen)
3777{
3778 unsigned int idx;
3779 REG_TABLE_ENTRY *pRegEntry = reg_table;
3780 uint32_t value;
3781 char valueStr[CFG_VALUE_MAX_LEN];
3782 char configStr[CFG_ENTRY_MAX_LEN];
3783 char *fmt;
3784 void *pField;
3785 struct cdf_mac_addr *pMacAddr;
3786 char *pCur = pBuf;
3787 int curlen;
3788
3789 /* start with an empty string */
3790 *pCur = '\0';
3791
3792 for (idx = 0; idx < cRegTableEntries; idx++, pRegEntry++) {
3793 pField = ini_struct + pRegEntry->VarOffset;
3794
3795 if ((WLAN_PARAM_Integer == pRegEntry->RegType) ||
3796 (WLAN_PARAM_SignedInteger == pRegEntry->RegType) ||
3797 (WLAN_PARAM_HexInteger == pRegEntry->RegType)) {
3798 value = 0;
3799 memcpy(&value, pField, pRegEntry->VarSize);
3800 if (WLAN_PARAM_HexInteger == pRegEntry->RegType) {
3801 fmt = "%x";
3802 } else if (WLAN_PARAM_SignedInteger ==
3803 pRegEntry->RegType) {
3804 fmt = "%d";
3805 } else {
3806 fmt = "%u";
3807 }
3808 snprintf(valueStr, CFG_VALUE_MAX_LEN, fmt, value);
3809 } else if (WLAN_PARAM_String == pRegEntry->RegType) {
3810 snprintf(valueStr, CFG_VALUE_MAX_LEN, "%s",
3811 (char *)pField);
3812 } else if (WLAN_PARAM_MacAddr == pRegEntry->RegType) {
3813 pMacAddr = (struct cdf_mac_addr *) pField;
3814 snprintf(valueStr, CFG_VALUE_MAX_LEN,
3815 "%02x:%02x:%02x:%02x:%02x:%02x",
3816 pMacAddr->bytes[0],
3817 pMacAddr->bytes[1],
3818 pMacAddr->bytes[2],
3819 pMacAddr->bytes[3],
3820 pMacAddr->bytes[4], pMacAddr->bytes[5]);
3821 } else {
3822 snprintf(valueStr, CFG_VALUE_MAX_LEN, "(unhandled)");
3823 }
3824 curlen = scnprintf(configStr, CFG_ENTRY_MAX_LEN,
3825 "%s=[%s]%s\n",
3826 pRegEntry->RegName,
3827 valueStr,
3828 test_bit(idx,
3829 (void *)&pHddCtx->config->
3830 bExplicitCfg) ? "*" : "");
3831
3832 /* Ideally we want to return the config to the application,
3833 * however the config is too big so we just printk() for now
3834 */
3835#ifdef RETURN_IN_BUFFER
3836 if (curlen <= buflen) {
3837 /* copy string + '\0' */
3838 memcpy(pCur, configStr, curlen + 1);
3839
3840 /* account for addition; */
3841 pCur += curlen;
3842 buflen -= curlen;
3843 } else {
3844 /* buffer space exhausted, return what we have */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303845 return QDF_STATUS_E_RESOURCES;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003846 }
3847#else
3848 printk(KERN_INFO "%s", configStr);
3849#endif /* RETURN_IN_BUFFER */
3850
3851 }
3852
3853#ifndef RETURN_IN_BUFFER
3854 /* notify application that output is in system log */
3855 snprintf(pCur, buflen, "WLAN configuration written to system log");
3856#endif /* RETURN_IN_BUFFER */
3857
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303858 return QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003859}
3860
3861/** struct tCfgIniEntry - ini configuration entry
3862 *
3863 * @name: name of the entry
3864 * @value: value of the entry
3865 */
3866typedef struct {
3867 char *name;
3868 char *value;
3869} tCfgIniEntry;
3870
3871/**
3872 * find_cfg_item() - find the configuration item
3873 * @iniTable: pointer to configuration table
3874 * @entries: number fo the configuration entries
3875 * @name: the interested configuration to find
3876 * @value: the value to read back
3877 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303878 * Return: QDF_STATUS_SUCCESS if the interested configuration is found,
3879 * otherwise QDF_STATUS_E_FAILURE
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003880 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303881static QDF_STATUS find_cfg_item(tCfgIniEntry *iniTable, unsigned long entries,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003882 char *name, char **value)
3883{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303884 QDF_STATUS status = QDF_STATUS_E_FAILURE;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003885 unsigned long i;
3886
3887 for (i = 0; i < entries; i++) {
3888 if (strcmp(iniTable[i].name, name) == 0) {
3889 *value = iniTable[i].value;
3890 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
3891 "Found %s entry for Name=[%s] Value=[%s] ",
3892 WLAN_INI_FILE, name, *value);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303893 return QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003894 }
3895 }
3896
3897 return status;
3898}
3899
3900/**
3901 * parse_hex_digit() - conversion to hex value
3902 * @c: the character to convert
3903 *
3904 * Return: the hex value, otherwise 0
3905 */
3906static int parse_hex_digit(char c)
3907{
3908 if (c >= '0' && c <= '9')
3909 return c - '0';
3910 if (c >= 'a' && c <= 'f')
3911 return c - 'a' + 10;
3912 if (c >= 'A' && c <= 'F')
3913 return c - 'A' + 10;
3914
3915 return 0;
3916}
3917
3918/**
3919 * update_mac_from_string() - convert string to 6 bytes mac address
3920 * @pHddCtx: the pointer to hdd context
3921 * @macTable: the macTable to carry the conversion
3922 * @num: number of the interface
3923 *
3924 * 00AA00BB00CC -> 0x00 0xAA 0x00 0xBB 0x00 0xCC
3925 *
3926 * Return: None
3927 */
3928static void update_mac_from_string(hdd_context_t *pHddCtx,
3929 tCfgIniEntry *macTable, int num)
3930{
3931 int i = 0, j = 0, res = 0;
3932 char *candidate = NULL;
3933 struct cdf_mac_addr macaddr[CDF_MAX_CONCURRENCY_PERSONA];
3934
3935 memset(macaddr, 0, sizeof(macaddr));
3936
3937 for (i = 0; i < num; i++) {
3938 candidate = macTable[i].value;
3939 for (j = 0; j < CDF_MAC_ADDR_SIZE; j++) {
3940 res =
3941 hex2bin(&macaddr[i].bytes[j], &candidate[(j << 1)],
3942 1);
3943 if (res < 0)
3944 break;
3945 }
3946 if (res == 0 && !cdf_is_macaddr_zero(&macaddr[i])) {
3947 cdf_mem_copy((uint8_t *) &pHddCtx->config->
3948 intfMacAddr[i].bytes[0],
3949 (uint8_t *) &macaddr[i].bytes[0],
3950 CDF_MAC_ADDR_SIZE);
3951 }
3952 }
3953}
3954
3955/**
3956 * hdd_apply_cfg_ini() - apply the ini configuration file
3957 * @pHddCtx: the pointer to hdd context
3958 * @iniTable: pointer to configuration table
3959 * @entries: number fo the configuration entries
3960 * It overwrites the MAC address if config file exist.
3961 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303962 * Return: QDF_STATUS_SUCCESS if the ini configuration file is correctly parsed,
3963 * otherwise QDF_STATUS_E_INVAL
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003964 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303965static QDF_STATUS hdd_apply_cfg_ini(hdd_context_t *pHddCtx,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003966 tCfgIniEntry *iniTable,
3967 unsigned long entries)
3968{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303969 QDF_STATUS match_status = QDF_STATUS_E_FAILURE;
3970 QDF_STATUS ret_status = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003971 unsigned int idx;
3972 void *pField;
3973 char *value_str = NULL;
3974 unsigned long len_value_str;
3975 char *candidate;
3976 uint32_t value;
3977 int32_t svalue;
3978 void *pStructBase = pHddCtx->config;
3979 REG_TABLE_ENTRY *pRegEntry = g_registry_table;
3980 unsigned long cRegTableEntries = CDF_ARRAY_SIZE(g_registry_table);
3981 uint32_t cbOutString;
3982 int i;
3983 int rv;
3984
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003985 if (MAX_CFG_INI_ITEMS < cRegTableEntries) {
Srinivas Girigowdaba3091c2015-11-16 17:18:40 -08003986 hddLog(LOGE, FL("MAX_CFG_INI_ITEMS too small, must be at least %ld"),
3987 cRegTableEntries);
3988 WARN_ON(1);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003989 }
3990
3991 for (idx = 0; idx < cRegTableEntries; idx++, pRegEntry++) {
3992 /* Calculate the address of the destination field in the structure. */
3993 pField = ((uint8_t *) pStructBase) + pRegEntry->VarOffset;
3994
3995 match_status =
3996 find_cfg_item(iniTable, entries, pRegEntry->RegName,
3997 &value_str);
3998
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05303999 if ((match_status != QDF_STATUS_SUCCESS)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004000 && (pRegEntry->Flags & VAR_FLAGS_REQUIRED)) {
4001 /* If we could not read the cfg item and it is required, this is an error. */
4002 hddLog(LOGE,
4003 "%s: Failed to read required config parameter %s",
4004 __func__, pRegEntry->RegName);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304005 ret_status = QDF_STATUS_E_FAILURE;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004006 break;
4007 }
4008
4009 if ((WLAN_PARAM_Integer == pRegEntry->RegType) ||
4010 (WLAN_PARAM_HexInteger == pRegEntry->RegType)) {
4011 /* If successfully read from the registry, use the value read.
4012 * If not, use the default value.
4013 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304014 if (match_status == QDF_STATUS_SUCCESS
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004015 && (WLAN_PARAM_Integer == pRegEntry->RegType)) {
4016 rv = kstrtou32(value_str, 10, &value);
4017 if (rv < 0) {
4018 hddLog(LOGE,
4019 "%s: Reg Parameter %s invalid. Enforcing default",
4020 __func__, pRegEntry->RegName);
4021 value = pRegEntry->VarDefault;
4022 }
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304023 } else if (match_status == QDF_STATUS_SUCCESS
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004024 && (WLAN_PARAM_HexInteger ==
4025 pRegEntry->RegType)) {
4026 rv = kstrtou32(value_str, 16, &value);
4027 if (rv < 0) {
4028 hddLog(LOGE,
4029 "%s: Reg paramter %s invalid. Enforcing default",
4030 __func__, pRegEntry->RegName);
4031 value = pRegEntry->VarDefault;
4032 }
4033 } else {
4034 value = pRegEntry->VarDefault;
4035 }
4036
4037 /* If this parameter needs range checking, do it here. */
4038 if (pRegEntry->Flags & VAR_FLAGS_RANGE_CHECK) {
4039 if (value > pRegEntry->VarMax) {
4040 hddLog(LOGE,
4041 "%s: Reg Parameter %s > allowed Maximum [%u > %lu]. Enforcing Maximum",
4042 __func__, pRegEntry->RegName,
4043 value, pRegEntry->VarMax);
4044 value = pRegEntry->VarMax;
4045 }
4046
4047 if (value < pRegEntry->VarMin) {
4048 hddLog(LOGE,
4049 "%s: Reg Parameter %s < allowed Minimum [%u < %lu]. Enforcing Minimum",
4050 __func__, pRegEntry->RegName,
4051 value, pRegEntry->VarMin);
4052 value = pRegEntry->VarMin;
4053 }
4054 }
4055 /* If this parameter needs range checking, do it here. */
4056 else if (pRegEntry->
4057 Flags & VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT) {
4058 if (value > pRegEntry->VarMax) {
4059 hddLog(LOGE,
4060 "%s: Reg Parameter %s > allowed Maximum [%u > %lu]. Enforcing Default= %lu",
4061 __func__, pRegEntry->RegName,
4062 value, pRegEntry->VarMax,
4063 pRegEntry->VarDefault);
4064 value = pRegEntry->VarDefault;
4065 }
4066
4067 if (value < pRegEntry->VarMin) {
4068 hddLog(LOGE,
4069 "%s: Reg Parameter %s < allowed Minimum [%u < %lu]. Enforcing Default= %lu",
4070 __func__, pRegEntry->RegName,
4071 value, pRegEntry->VarMin,
4072 pRegEntry->VarDefault);
4073 value = pRegEntry->VarDefault;
4074 }
4075 }
4076 /* Move the variable into the output field. */
4077 memcpy(pField, &value, pRegEntry->VarSize);
4078 } else if (WLAN_PARAM_SignedInteger == pRegEntry->RegType) {
4079 /* If successfully read from the registry, use the value read.
4080 * If not, use the default value.
4081 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304082 if (QDF_STATUS_SUCCESS == match_status) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004083 rv = kstrtos32(value_str, 10, &svalue);
4084 if (rv < 0) {
4085 hddLog(CDF_TRACE_LEVEL_WARN,
4086 "%s: Reg Parameter %s invalid. Enforcing Default",
4087 __func__, pRegEntry->RegName);
4088 svalue =
4089 (int32_t) pRegEntry->VarDefault;
4090 }
4091 } else {
4092 svalue = (int32_t) pRegEntry->VarDefault;
4093 }
4094
4095 /* If this parameter needs range checking, do it here. */
4096 if (pRegEntry->Flags & VAR_FLAGS_RANGE_CHECK) {
4097 if (svalue > (int32_t) pRegEntry->VarMax) {
4098 hddLog(LOGE,
4099 "%s: Reg Parameter %s > allowed Maximum "
4100 "[%d > %d]. Enforcing Maximum",
4101 __func__, pRegEntry->RegName,
4102 svalue, (int)pRegEntry->VarMax);
4103 svalue = (int32_t) pRegEntry->VarMax;
4104 }
4105
4106 if (svalue < (int32_t) pRegEntry->VarMin) {
4107 hddLog(LOGE,
4108 "%s: Reg Parameter %s < allowed Minimum "
4109 "[%d < %d]. Enforcing Minimum",
4110 __func__, pRegEntry->RegName,
4111 svalue, (int)pRegEntry->VarMin);
4112 svalue = (int32_t) pRegEntry->VarMin;
4113 }
4114 }
4115 /* If this parameter needs range checking, do it here. */
4116 else if (pRegEntry->
4117 Flags & VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT) {
4118 if (svalue > (int32_t) pRegEntry->VarMax) {
4119 hddLog(LOGE,
4120 "%s: Reg Parameter %s > allowed Maximum "
4121 "[%d > %d]. Enforcing Default= %d",
4122 __func__, pRegEntry->RegName,
4123 svalue, (int)pRegEntry->VarMax,
4124 (int)pRegEntry->VarDefault);
4125 svalue =
4126 (int32_t) pRegEntry->VarDefault;
4127 }
4128
4129 if (svalue < (int32_t) pRegEntry->VarMin) {
4130 hddLog(LOGE,
4131 "%s: Reg Parameter %s < allowed Minimum "
4132 "[%d < %d]. Enforcing Default= %d",
4133 __func__, pRegEntry->RegName,
4134 svalue, (int)pRegEntry->VarMin,
4135 (int)pRegEntry->VarDefault);
4136 svalue = pRegEntry->VarDefault;
4137 }
4138 }
4139 /* Move the variable into the output field. */
4140 memcpy(pField, &svalue, pRegEntry->VarSize);
4141 }
4142 /* Handle string parameters */
4143 else if (WLAN_PARAM_String == pRegEntry->RegType) {
4144#ifdef WLAN_CFG_DEBUG
4145 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4146 "RegName = %s, VarOffset %u VarSize %u VarDefault %s",
4147 pRegEntry->RegName, pRegEntry->VarOffset,
4148 pRegEntry->VarSize,
4149 (char *)pRegEntry->VarDefault);
4150#endif
4151
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304152 if (match_status == QDF_STATUS_SUCCESS) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004153 len_value_str = strlen(value_str);
4154
4155 if (len_value_str > (pRegEntry->VarSize - 1)) {
4156 hddLog(LOGE,
4157 "%s: Invalid Value=[%s] specified for Name=[%s] in %s",
4158 __func__, value_str,
4159 pRegEntry->RegName,
4160 WLAN_INI_FILE);
4161 cbOutString =
4162 util_min(strlen
4163 ((char *)pRegEntry->
4164 VarDefault),
4165 pRegEntry->VarSize - 1);
4166 memcpy(pField,
4167 (void *)(pRegEntry->VarDefault),
4168 cbOutString);
4169 ((uint8_t *) pField)[cbOutString] =
4170 '\0';
4171 } else {
4172 memcpy(pField, (void *)(value_str),
4173 len_value_str);
4174 ((uint8_t *) pField)[len_value_str] =
4175 '\0';
4176 }
4177 } else {
4178 /* Failed to read the string parameter from the registry. Use the default. */
4179 cbOutString =
4180 util_min(strlen((char *)pRegEntry->VarDefault),
4181 pRegEntry->VarSize - 1);
4182 memcpy(pField, (void *)(pRegEntry->VarDefault),
4183 cbOutString);
4184 ((uint8_t *) pField)[cbOutString] = '\0';
4185 }
4186 } else if (WLAN_PARAM_MacAddr == pRegEntry->RegType) {
4187 if (pRegEntry->VarSize != CDF_MAC_ADDR_SIZE) {
4188 hddLog(LOGE,
4189 "%s: Invalid VarSize %u for Name=[%s]",
4190 __func__, pRegEntry->VarSize,
4191 pRegEntry->RegName);
4192 continue;
4193 }
4194 candidate = (char *)pRegEntry->VarDefault;
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304195 if (match_status == QDF_STATUS_SUCCESS) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004196 len_value_str = strlen(value_str);
4197 if (len_value_str != (CDF_MAC_ADDR_SIZE * 2)) {
4198 hddLog(LOGE,
4199 "%s: Invalid MAC addr [%s] specified for Name=[%s] in %s",
4200 __func__, value_str,
4201 pRegEntry->RegName,
4202 WLAN_INI_FILE);
4203 } else
4204 candidate = value_str;
4205 }
4206 /* parse the string and store it in the byte array */
4207 for (i = 0; i < CDF_MAC_ADDR_SIZE; i++) {
4208 ((char *)pField)[i] =
4209 (char)(parse_hex_digit(candidate[i * 2]) *
4210 16 +
4211 parse_hex_digit(candidate[i * 2 + 1]));
4212 }
4213 } else {
4214 hddLog(LOGE,
4215 "%s: Unknown param type for name[%s] in registry table",
4216 __func__, pRegEntry->RegName);
4217 }
4218
4219 /* did we successfully parse a cfg item for this parameter? */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304220 if ((match_status == QDF_STATUS_SUCCESS) &&
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004221 (idx < MAX_CFG_INI_ITEMS)) {
4222 set_bit(idx, (void *)&pHddCtx->config->bExplicitCfg);
4223 }
4224 }
4225
4226 return ret_status;
4227}
4228
4229/**
4230 * hdd_execute_config_command() - executes an arbitrary configuration command
4231 * @reg_table: the pointer to configuration table
4232 * @tableSize: the size of the configuration table
4233 * @ini_struct: pointer to the hdd config knob
4234 * @pHddCtx: the pointer to hdd context
4235 * @command: the command to run
4236 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304237 * Return: QDF_STATUS_SUCCESS if the command is found and able to execute,
4238 * otherwise the appropriate QDF_STATUS will be returned
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004239 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304240static QDF_STATUS hdd_execute_config_command(REG_TABLE_ENTRY *reg_table,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004241 unsigned long tableSize,
4242 uint8_t *ini_struct,
4243 hdd_context_t *pHddCtx,
4244 char *command)
4245{
4246 REG_TABLE_ENTRY *pRegEntry;
4247 char *clone;
4248 char *pCmd;
4249 void *pField;
4250 char *name;
4251 char *value_str;
4252 uint32_t value;
4253 int32_t svalue;
4254 size_t len_value_str;
4255 unsigned int idx;
4256 unsigned int i;
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304257 QDF_STATUS vstatus;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004258 int rv;
4259
4260 /* assume failure until proven otherwise */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304261 vstatus = QDF_STATUS_E_FAILURE;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004262
4263 /* clone the command so that we can manipulate it */
4264 clone = kstrdup(command, GFP_ATOMIC);
4265 if (NULL == clone) {
4266 hddLog(LOGE,
4267 "%s: memory allocation failure, unable to process [%s]",
4268 __func__, command);
4269 return vstatus;
4270 }
4271 /* 'clone' will point to the beginning of the string so it can be freed
4272 * 'pCmd' will be used to walk/parse the command
4273 */
4274 pCmd = clone;
4275
4276 /* get rid of leading/trailing whitespace */
4277 pCmd = i_trim(pCmd);
4278 if ('\0' == *pCmd) {
4279 /* only whitespace */
4280 hddLog(LOGE, "%s: invalid command, only whitespace:[%s]",
4281 __func__, command);
4282 goto done;
4283 }
4284 /* parse the <name> = <value> */
4285 name = pCmd;
4286 while (('=' != *pCmd) && ('\0' != *pCmd)) {
4287 pCmd++;
4288 }
4289 if ('\0' == *pCmd) {
4290 /* did not find '=' */
4291 hddLog(LOGE, "%s: invalid command, no '=':[%s]",
4292 __func__, command);
4293 goto done;
4294 }
4295 /* replace '=' with NUL to terminate the <name> */
4296 *pCmd++ = '\0';
4297 name = i_trim(name);
4298 if ('\0' == *name) {
4299 /* did not find a name */
4300 hddLog(LOGE, "%s: invalid command, no <name>:[%s]",
4301 __func__, command);
4302 goto done;
4303 }
4304
4305 value_str = i_trim(pCmd);
4306 if ('\0' == *value_str) {
4307 /* did not find a value */
4308 hddLog(LOGE, "%s: invalid command, no <value>:[%s]",
4309 __func__, command);
4310 goto done;
4311 }
4312 /* lookup the configuration item */
4313 for (idx = 0; idx < tableSize; idx++) {
4314 if (0 == strcmp(name, reg_table[idx].RegName)) {
4315 /* found a match */
4316 break;
4317 }
4318 }
4319 if (tableSize == idx) {
4320 /* did not match the name */
4321 hddLog(LOGE,
4322 "%s: invalid command, unknown configuration item:[%s]",
4323 __func__, command);
4324 goto done;
4325 }
4326
4327 pRegEntry = &reg_table[idx];
4328 if (!(pRegEntry->Flags & VAR_FLAGS_DYNAMIC_CFG)) {
4329 /* does not support dynamic configuration */
4330 hddLog(LOGE, "%s: Global_Registry_Table.%s does not support "
4331 "dynamic configuration", __func__, name);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304332 vstatus = QDF_STATUS_E_PERM;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004333 goto done;
4334 }
4335
4336 pField = ini_struct + pRegEntry->VarOffset;
4337
4338 switch (pRegEntry->RegType) {
4339 case WLAN_PARAM_Integer:
4340 rv = kstrtou32(value_str, 10, &value);
4341 if (rv < 0)
4342 goto done;
4343 if (value < pRegEntry->VarMin) {
4344 /* out of range */
4345 hddLog(LOGE,
4346 "%s: invalid command, value %u < min value %lu",
4347 __func__, value, pRegEntry->VarMin);
4348 goto done;
4349 }
4350 if (value > pRegEntry->VarMax) {
4351 /* out of range */
4352 hddLog(LOGE,
4353 "%s: invalid command, value %u > max value %lu",
4354 __func__, value, pRegEntry->VarMax);
4355 goto done;
4356 }
4357 memcpy(pField, &value, pRegEntry->VarSize);
4358 break;
4359
4360 case WLAN_PARAM_HexInteger:
4361 rv = kstrtou32(value_str, 16, &value);
4362 if (rv < 0)
4363 goto done;
4364 if (value < pRegEntry->VarMin) {
4365 /* out of range */
4366 hddLog(LOGE,
4367 "%s: invalid command, value %x < min value %lx",
4368 __func__, value, pRegEntry->VarMin);
4369 goto done;
4370 }
4371 if (value > pRegEntry->VarMax) {
4372 /* out of range */
4373 hddLog(LOGE,
4374 "%s: invalid command, value %x > max value %lx",
4375 __func__, value, pRegEntry->VarMax);
4376 goto done;
4377 }
4378 memcpy(pField, &value, pRegEntry->VarSize);
4379 break;
4380
4381 case WLAN_PARAM_SignedInteger:
4382 rv = kstrtos32(value_str, 10, &svalue);
4383 if (rv < 0)
4384 goto done;
4385 if (svalue < (int32_t) pRegEntry->VarMin) {
4386 /* out of range */
4387 hddLog(LOGE,
4388 "%s: invalid command, value %d < min value %d",
4389 __func__, svalue, (int)pRegEntry->VarMin);
4390 goto done;
4391 }
4392 if (svalue > (int32_t) pRegEntry->VarMax) {
4393 /* out of range */
4394 hddLog(LOGE,
4395 "%s: invalid command, value %d > max value %d",
4396 __func__, svalue, (int)pRegEntry->VarMax);
4397 goto done;
4398 }
4399 memcpy(pField, &svalue, pRegEntry->VarSize);
4400 break;
4401
4402 case WLAN_PARAM_String:
4403 len_value_str = strlen(value_str);
4404 if (len_value_str > (pRegEntry->VarSize - 1)) {
4405 /* too big */
4406 hddLog(LOGE,
4407 "%s: invalid command, string [%s] length "
4408 "%zu exceeds maximum length %u",
4409 __func__, value_str,
4410 len_value_str, (pRegEntry->VarSize - 1));
4411 goto done;
4412 }
4413 /* copy string plus NUL */
4414 memcpy(pField, value_str, (len_value_str + 1));
4415 break;
4416
4417 case WLAN_PARAM_MacAddr:
4418 len_value_str = strlen(value_str);
4419 if (len_value_str != (CDF_MAC_ADDR_SIZE * 2)) {
4420 /* out of range */
4421 hddLog(LOGE,
4422 "%s: invalid command, MAC address [%s] length "
4423 "%zu is not expected length %u",
4424 __func__, value_str,
4425 len_value_str, (CDF_MAC_ADDR_SIZE * 2));
4426 goto done;
4427 }
4428 /* parse the string and store it in the byte array */
4429 for (i = 0; i < CDF_MAC_ADDR_SIZE; i++) {
4430 ((char *)pField)[i] = (char)
4431 ((parse_hex_digit(value_str[(i * 2)]) * 16) +
4432 parse_hex_digit(value_str[(i * 2) + 1]));
4433 }
4434 break;
4435
4436 default:
4437 goto done;
4438 }
4439
4440 /* if we get here, we had a successful modification */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304441 vstatus = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004442
4443 /* config table has been modified, is there a notifier? */
4444 if (NULL != pRegEntry->pfnDynamicnotify) {
4445 (pRegEntry->pfnDynamicnotify)(pHddCtx, pRegEntry->notifyId);
4446 }
4447 /* note that this item was explicitly configured */
4448 if (idx < MAX_CFG_INI_ITEMS) {
4449 set_bit(idx, (void *)&pHddCtx->config->bExplicitCfg);
4450 }
4451done:
4452 kfree(clone);
4453 return vstatus;
4454}
4455
4456/**
4457 * hdd_set_power_save_offload_config() - set power save offload configuration
4458 * @pHddCtx: the pointer to hdd context
4459 *
4460 * Return: none
4461 */
4462static void hdd_set_power_save_offload_config(hdd_context_t *pHddCtx)
4463{
4464 struct hdd_config *pConfig = pHddCtx->config;
4465 uint32_t listenInterval = 0;
4466
4467 if (strcmp(pConfig->PowerUsageControl, "Min") == 0) {
4468 listenInterval = pConfig->nBmpsMinListenInterval;
4469 } else if (strcmp(pConfig->PowerUsageControl, "Max") == 0) {
4470 listenInterval = pConfig->nBmpsMaxListenInterval;
4471 } else if (strcmp(pConfig->PowerUsageControl, "Mod") == 0) {
4472 listenInterval = pConfig->nBmpsModListenInterval;
4473 }
4474
4475 /*
4476 * Based on Mode Set the LI
4477 * Otherwise default LI value of 1 will
4478 * be taken
4479 */
4480 if (listenInterval) {
4481 /*
4482 * setcfg for listenInterval.
4483 * Make sure CFG is updated because PE reads this
4484 * from CFG at the time of assoc or reassoc
4485 */
4486 sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_LISTEN_INTERVAL,
4487 listenInterval);
4488 }
4489
4490}
4491
4492/**
4493 * hdd_cfg_print() - print the hdd configuration
4494 * @iniTable: pointer to hdd context
4495 *
4496 * Return: None
4497 */
4498void hdd_cfg_print(hdd_context_t *pHddCtx)
4499{
4500 int i;
4501
4502 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4503 "*********Config values in HDD Adapter*******");
4504 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4505 "Name = [RTSThreshold] Value = %u",
4506 pHddCtx->config->RTSThreshold);
4507 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4508 "Name = [OperatingChannel] Value = [%u]",
4509 pHddCtx->config->OperatingChannel);
4510 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4511 "Name = [PowerUsageControl] Value = [%s]",
4512 pHddCtx->config->PowerUsageControl);
4513 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4514 "Name = [fIsImpsEnabled] Value = [%u]",
4515 pHddCtx->config->fIsImpsEnabled);
4516 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4517 "Name = [nVccRssiTrigger] Value = [%u]",
4518 pHddCtx->config->nVccRssiTrigger);
4519 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4520 "Name = [gIbssBssid] Value =[" MAC_ADDRESS_STR "]",
4521 MAC_ADDR_ARRAY(pHddCtx->config->IbssBssid.bytes));
4522
4523 for (i = 0; i < CDF_MAX_CONCURRENCY_PERSONA; i++) {
4524 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4525 "Name = [Intf%dMacAddress] Value =[" MAC_ADDRESS_STR "]",
4526 i, MAC_ADDR_ARRAY(pHddCtx->config->intfMacAddr[i].bytes));
4527 }
4528
4529 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4530 "Name = [gApEnableUapsd] value = [%u]",
4531 pHddCtx->config->apUapsdEnabled);
4532
4533 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4534 "Name = [gEnableApProt] value = [%u]",
4535 pHddCtx->config->apProtEnabled);
4536 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4537 "Name = [gAPAutoShutOff] Value = [%u]",
4538 pHddCtx->config->nAPAutoShutOff);
4539#ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
4540 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4541 "Name = [gWlanMccToSccSwitchMode] Value = [%u]",
4542 pHddCtx->config->WlanMccToSccSwitchMode);
4543#endif
4544#ifdef FEATURE_WLAN_AUTO_SHUTDOWN
4545 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4546 "Name = [gWlanAutoShutdown] Value = [%u]",
4547 pHddCtx->config->WlanAutoShutdown);
4548#endif
4549 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4550 "Name = [gEnableListenMode] Value = [%u]",
4551 pHddCtx->config->nEnableListenMode);
4552 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4553 "Name = [gApProtection] value = [%u]",
4554 pHddCtx->config->apProtection);
4555 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4556 "Name = [gEnableApOBSSProt] value = [%u]",
4557 pHddCtx->config->apOBSSProtEnabled);
4558 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4559 "Name = [%s] value = [%u]", CFG_FORCE_SAP_ACS,
4560 pHddCtx->config->force_sap_acs);
4561 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4562 "Name = [%s] value = [%u]", CFG_FORCE_SAP_ACS_START_CH,
4563 pHddCtx->config->force_sap_acs_st_ch);
4564 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4565 "Name = [%s] value = [%u]", CFG_FORCE_SAP_ACS_END_CH,
4566 pHddCtx->config->force_sap_acs_end_ch);
4567#ifdef FEATURE_AP_MCC_CH_AVOIDANCE
4568 CDF_TRACE(CDF_MODULE_ID_HDD,
4569 CDF_TRACE_LEVEL_INFO_HIGH,
4570 "Name = [sap_channel_avoidance] value = [%u]",
4571 pHddCtx->config->sap_channel_avoidance);
4572#endif /* FEATURE_AP_MCC_CH_AVOIDANCE */
4573 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4574 "Name = [%s] value = [%u]", CFG_SAP_P2P_11AC_OVERRIDE_NAME,
4575 pHddCtx->config->sap_p2p_11ac_override);
4576 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4577 "Name = [ChannelBondingMode] Value = [%u]",
4578 pHddCtx->config->nChannelBondingMode24GHz);
4579 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4580 "Name = [ChannelBondingMode] Value = [%u]",
4581 pHddCtx->config->nChannelBondingMode5GHz);
4582 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4583 "Name = [dot11Mode] Value = [%u]",
4584 pHddCtx->config->dot11Mode);
4585 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4586 "Name = [WmmMode] Value = [%u] ", pHddCtx->config->WmmMode);
4587 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4588 "Name = [UapsdMask] Value = [0x%x] ",
4589 pHddCtx->config->UapsdMask);
4590 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004591 "Name = [ImplicitQosIsEnabled] Value = [%u]",
4592 (int)pHddCtx->config->bImplicitQosEnabled);
4593
4594 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4595 "Name = [InfraUapsdVoSrvIntv] Value = [%u] ",
4596 pHddCtx->config->InfraUapsdVoSrvIntv);
4597 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4598 "Name = [InfraUapsdVoSuspIntv] Value = [%u] ",
4599 pHddCtx->config->InfraUapsdVoSuspIntv);
4600
4601 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4602 "Name = [InfraUapsdViSrvIntv] Value = [%u] ",
4603 pHddCtx->config->InfraUapsdViSrvIntv);
4604 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4605 "Name = [InfraUapsdViSuspIntv] Value = [%u] ",
4606 pHddCtx->config->InfraUapsdViSuspIntv);
4607
4608 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4609 "Name = [InfraUapsdBeSrvIntv] Value = [%u] ",
4610 pHddCtx->config->InfraUapsdBeSrvIntv);
4611 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4612 "Name = [InfraUapsdBeSuspIntv] Value = [%u] ",
4613 pHddCtx->config->InfraUapsdBeSuspIntv);
4614
4615 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4616 "Name = [InfraUapsdBkSrvIntv] Value = [%u] ",
4617 pHddCtx->config->InfraUapsdBkSrvIntv);
4618 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4619 "Name = [InfraUapsdBkSuspIntv] Value = [%u] ",
4620 pHddCtx->config->InfraUapsdBkSuspIntv);
4621#ifdef FEATURE_WLAN_ESE
4622 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4623 "Name = [InfraInactivityInterval] Value = [%u] ",
4624 pHddCtx->config->InfraInactivityInterval);
4625 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4626 "Name = [EseEnabled] Value = [%u] ",
4627 pHddCtx->config->isEseIniFeatureEnabled);
4628 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4629 "Name = [FastTransitionEnabled] Value = [%u] ",
4630 pHddCtx->config->isFastTransitionEnabled);
4631 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4632 "Name = [gTxPowerCap] Value = [%u] dBm ",
4633 pHddCtx->config->nTxPowerCap);
4634#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004635 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4636 "Name = [FastRoamEnabled] Value = [%u] ",
4637 pHddCtx->config->isFastRoamIniFeatureEnabled);
4638 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4639 "Name = [MAWCEnabled] Value = [%u] ",
4640 pHddCtx->config->MAWCEnabled);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004641 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4642 "Name = [RoamRssiDiff] Value = [%u] ",
4643 pHddCtx->config->RoamRssiDiff);
4644 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4645 "Name = [isWESModeEnabled] Value = [%u] ",
4646 pHddCtx->config->isWESModeEnabled);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004647#ifdef FEATURE_WLAN_OKC
4648 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4649 "Name = [OkcEnabled] Value = [%u] ",
4650 pHddCtx->config->isOkcIniFeatureEnabled);
4651#endif
4652#ifdef FEATURE_WLAN_SCAN_PNO
4653 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4654 "Name = [configPNOScanSupport] Value = [%u] ",
4655 pHddCtx->config->configPNOScanSupport);
4656 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4657 "Name = [configPNOScanTimerRepeatValue] Value = [%u] ",
4658 pHddCtx->config->configPNOScanTimerRepeatValue);
Srinivas Girigowdabdc98162015-09-17 11:06:07 -07004659 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4660 "Name = [gPNOSlowScanMultiplier] Value = [%u] ",
4661 pHddCtx->config->pno_slow_scan_multiplier);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004662#endif
4663#ifdef FEATURE_WLAN_TDLS
4664 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4665 "Name = [fEnableTDLSSupport] Value = [%u] ",
4666 pHddCtx->config->fEnableTDLSSupport);
4667 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4668 "Name = [fEnableTDLSImplicitTrigger] Value = [%u] ",
4669 pHddCtx->config->fEnableTDLSImplicitTrigger);
4670 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4671 "Name = [fTDLSExternalControl] Value = [%u] ",
4672 pHddCtx->config->fTDLSExternalControl);
4673 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4674 "Name = [fTDLSUapsdMask] Value = [%u] ",
4675 pHddCtx->config->fTDLSUapsdMask);
4676 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4677 "Name = [fEnableTDLSBufferSta] Value = [%u] ",
4678 pHddCtx->config->fEnableTDLSBufferSta);
4679 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4680 "Name = [fEnableTDLSWmmMode] Value = [%u] ",
4681 pHddCtx->config->fEnableTDLSWmmMode);
4682 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4683 "Name = [enable_tdls_scan] Value = [%u]",
4684 pHddCtx->config->enable_tdls_scan);
4685#endif
4686 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4687 "Name = [InfraDirAcVo] Value = [%u] ",
4688 pHddCtx->config->InfraDirAcVo);
4689 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4690 "Name = [InfraNomMsduSizeAcVo] Value = [0x%x] ",
4691 pHddCtx->config->InfraNomMsduSizeAcVo);
4692 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4693 "Name = [InfraMeanDataRateAcVo] Value = [0x%x] ",
4694 pHddCtx->config->InfraMeanDataRateAcVo);
4695 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4696 "Name = [InfraMinPhyRateAcVo] Value = [0x%x] ",
4697 pHddCtx->config->InfraMinPhyRateAcVo);
4698 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4699 "Name = [InfraSbaAcVo] Value = [0x%x] ",
4700 pHddCtx->config->InfraSbaAcVo);
4701
4702 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4703 "Name = [InfraDirAcVi] Value = [%u] ",
4704 pHddCtx->config->InfraDirAcVi);
4705 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4706 "Name = [InfraNomMsduSizeAcVi] Value = [0x%x] ",
4707 pHddCtx->config->InfraNomMsduSizeAcVi);
4708 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4709 "Name = [InfraMeanDataRateAcVi] Value = [0x%x] ",
4710 pHddCtx->config->InfraMeanDataRateAcVi);
4711 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4712 "Name = [InfraMinPhyRateAcVi] Value = [0x%x] ",
4713 pHddCtx->config->InfraMinPhyRateAcVi);
4714 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4715 "Name = [InfraSbaAcVi] Value = [0x%x] ",
4716 pHddCtx->config->InfraSbaAcVi);
4717
4718 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4719 "Name = [InfraDirAcBe] Value = [%u] ",
4720 pHddCtx->config->InfraDirAcBe);
4721 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4722 "Name = [InfraNomMsduSizeAcBe] Value = [0x%x] ",
4723 pHddCtx->config->InfraNomMsduSizeAcBe);
4724 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4725 "Name = [InfraMeanDataRateAcBe] Value = [0x%x] ",
4726 pHddCtx->config->InfraMeanDataRateAcBe);
4727 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4728 "Name = [InfraMinPhyRateAcBe] Value = [0x%x] ",
4729 pHddCtx->config->InfraMinPhyRateAcBe);
4730 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4731 "Name = [InfraSbaAcBe] Value = [0x%x] ",
4732 pHddCtx->config->InfraSbaAcBe);
4733
4734 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4735 "Name = [InfraDirAcBk] Value = [%u] ",
4736 pHddCtx->config->InfraDirAcBk);
4737 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4738 "Name = [InfraNomMsduSizeAcBk] Value = [0x%x] ",
4739 pHddCtx->config->InfraNomMsduSizeAcBk);
4740 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4741 "Name = [InfraMeanDataRateAcBk] Value = [0x%x] ",
4742 pHddCtx->config->InfraMeanDataRateAcBk);
4743 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4744 "Name = [InfraMinPhyRateAcBk] Value = [0x%x] ",
4745 pHddCtx->config->InfraMinPhyRateAcBk);
4746 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4747 "Name = [InfraSbaAcBk] Value = [0x%x] ",
4748 pHddCtx->config->InfraSbaAcBk);
4749
4750 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4751 "Name = [DelayedTriggerFrmInt] Value = [%u] ",
4752 pHddCtx->config->DelayedTriggerFrmInt);
4753 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4754 "Name = [mcastBcastFilterSetting] Value = [%u] ",
4755 pHddCtx->config->mcastBcastFilterSetting);
4756 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4757 "Name = [fhostArpOffload] Value = [%u] ",
4758 pHddCtx->config->fhostArpOffload);
4759 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4760 "Name = [ssdp] Value = [%u] ", pHddCtx->config->ssdp);
4761#ifdef FEATURE_WLAN_RA_FILTERING
4762 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4763 "Name = [RArateLimitInterval] Value = [%u] ",
4764 pHddCtx->config->RArateLimitInterval);
4765 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4766 "Name = [IsRArateLimitEnabled] Value = [%u] ",
4767 pHddCtx->config->IsRArateLimitEnabled);
4768#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004769 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4770 "Name = [fFTResourceReqSupported] Value = [%u] ",
4771 pHddCtx->config->fFTResourceReqSupported);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004772
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004773 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4774 "Name = [nNeighborLookupRssiThreshold] Value = [%u] ",
4775 pHddCtx->config->nNeighborLookupRssiThreshold);
4776 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4777 "Name = [delay_before_vdev_stop] Value = [%u] ",
4778 pHddCtx->config->delay_before_vdev_stop);
4779 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4780 "Name = [nOpportunisticThresholdDiff] Value = [%u] ",
4781 pHddCtx->config->nOpportunisticThresholdDiff);
4782 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4783 "Name = [nRoamRescanRssiDiff] Value = [%u] ",
4784 pHddCtx->config->nRoamRescanRssiDiff);
4785 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4786 "Name = [nNeighborScanMinChanTime] Value = [%u] ",
4787 pHddCtx->config->nNeighborScanMinChanTime);
4788 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4789 "Name = [nNeighborScanMaxChanTime] Value = [%u] ",
4790 pHddCtx->config->nNeighborScanMaxChanTime);
4791 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4792 "Name = [nMaxNeighborRetries] Value = [%u] ",
4793 pHddCtx->config->nMaxNeighborReqTries);
4794 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4795 "Name = [nNeighborScanPeriod] Value = [%u] ",
4796 pHddCtx->config->nNeighborScanPeriod);
4797 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4798 "Name = [nNeighborScanResultsRefreshPeriod] Value = [%u] ",
4799 pHddCtx->config->nNeighborResultsRefreshPeriod);
4800 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4801 "Name = [nEmptyScanRefreshPeriod] Value = [%u] ",
4802 pHddCtx->config->nEmptyScanRefreshPeriod);
4803 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4804 "Name = [nRoamBmissFirstBcnt] Value = [%u] ",
4805 pHddCtx->config->nRoamBmissFirstBcnt);
4806 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4807 "Name = [nRoamBmissFinalBcnt] Value = [%u] ",
4808 pHddCtx->config->nRoamBmissFinalBcnt);
4809 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4810 "Name = [nRoamBeaconRssiWeight] Value = [%u] ",
4811 pHddCtx->config->nRoamBeaconRssiWeight);
4812 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4813 "Name = [allowDFSChannelRoam] Value = [%u] ",
4814 pHddCtx->config->allowDFSChannelRoam);
4815 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4816 "Name = [nhi_rssi_scan_max_count] Value = [%u] ",
4817 pHddCtx->config->nhi_rssi_scan_max_count);
4818 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4819 "Name = [nhi_rssi_scan_rssi_delta] Value = [%u] ",
4820 pHddCtx->config->nhi_rssi_scan_rssi_delta);
4821 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4822 "Name = [nhi_rssi_scan_delay] Value = [%u] ",
4823 pHddCtx->config->nhi_rssi_scan_delay);
4824 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4825 "Name = [nhi_rssi_scan_rssi_ub] Value = [%u] ",
4826 pHddCtx->config->nhi_rssi_scan_rssi_ub);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004827 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4828 "Name = [burstSizeDefinition] Value = [0x%x] ",
4829 pHddCtx->config->burstSizeDefinition);
4830 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4831 "Name = [tsInfoAckPolicy] Value = [0x%x] ",
4832 pHddCtx->config->tsInfoAckPolicy);
4833 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4834 "Name = [rfSettlingTimeUs] Value = [%u] ",
4835 pHddCtx->config->rfSettlingTimeUs);
4836 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4837 "Name = [bSingleTidRc] Value = [%u] ",
4838 pHddCtx->config->bSingleTidRc);
4839 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4840 "Name = [gDynamicPSPollvalue] Value = [%u] ",
4841 pHddCtx->config->dynamicPsPollValue);
4842 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4843 "Name = [gAddTSWhenACMIsOff] Value = [%u] ",
4844 pHddCtx->config->AddTSWhenACMIsOff);
4845 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4846 "Name = [gValidateScanList] Value = [%u] ",
4847 pHddCtx->config->fValidateScanList);
4848
4849 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4850 "Name = [gStaKeepAlivePeriod] Value = [%u] ",
4851 pHddCtx->config->infraStaKeepAlivePeriod);
4852 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4853 "Name = [gApDataAvailPollInterVal] Value = [%u] ",
4854 pHddCtx->config->apDataAvailPollPeriodInMs);
4855 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4856 "Name = [BandCapability] Value = [%u] ",
4857 pHddCtx->config->nBandCapability);
4858 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4859 "Name = [fEnableBeaconEarlyTermination] Value = [%u] ",
4860 pHddCtx->config->fEnableBeaconEarlyTermination);
4861 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4862 "Name = [teleBcnWakeupEnable] Value = [%u] ",
4863 pHddCtx->config->teleBcnWakeupEn);
4864 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4865 "Name = [transListenInterval] Value = [%u] ",
4866 pHddCtx->config->nTeleBcnTransListenInterval);
4867 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4868 "Name = [transLiNumIdleBeacons] Value = [%u] ",
4869 pHddCtx->config->nTeleBcnTransLiNumIdleBeacons);
4870 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4871 "Name = [maxListenInterval] Value = [%u] ",
4872 pHddCtx->config->nTeleBcnMaxListenInterval);
4873 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4874 "Name = [maxLiNumIdleBeacons] Value = [%u] ",
4875 pHddCtx->config->nTeleBcnMaxLiNumIdleBeacons);
4876 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4877 "Name = [bcnEarlyTermWakeInterval] Value = [%u] ",
4878 pHddCtx->config->bcnEarlyTermWakeInterval);
4879 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4880 "Name = [gApDataAvailPollInterVal] Value = [%u] ",
4881 pHddCtx->config->apDataAvailPollPeriodInMs);
4882 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4883 "Name = [gEnableBypass11d] Value = [%u] ",
4884 pHddCtx->config->enableBypass11d);
4885 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4886 "Name = [gEnableDFSChnlScan] Value = [%u] ",
4887 pHddCtx->config->enableDFSChnlScan);
4888 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4889 "Name = [gEnableDFSPnoChnlScan] Value = [%u] ",
4890 pHddCtx->config->enable_dfs_pno_chnl_scan);
4891 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4892 "Name = [gReportMaxLinkSpeed] Value = [%u] ",
4893 pHddCtx->config->reportMaxLinkSpeed);
4894 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4895 "Name = [thermalMitigationEnable] Value = [%u] ",
4896 pHddCtx->config->thermalMitigationEnable);
4897#ifdef WLAN_FEATURE_11AC
4898 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4899 "Name = [gVhtChannelWidth] value = [%u]",
4900 pHddCtx->config->vhtChannelWidth);
4901#endif
4902 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4903 "Name = [enableFirstScan2GOnly] Value = [%u] ",
4904 pHddCtx->config->enableFirstScan2GOnly);
4905 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4906 "Name = [skipDfsChnlInP2pSearch] Value = [%u] ",
4907 pHddCtx->config->skipDfsChnlInP2pSearch);
4908 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4909 "Name = [ignoreDynamicDtimInP2pMode] Value = [%u] ",
4910 pHddCtx->config->ignoreDynamicDtimInP2pMode);
4911 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4912 "Name = [enableRxSTBC] Value = [%u] ",
4913 pHddCtx->config->enableRxSTBC);
4914 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4915 "Name = [gEnableLpwrImgTransition] Value = [%u] ",
4916 pHddCtx->config->enableLpwrImgTransition);
4917 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4918 "Name = [gEnableSSR] Value = [%u] ",
4919 pHddCtx->config->enableSSR);
4920 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4921 "Name = [gEnableVhtFor24GHzBand] Value = [%u] ",
4922 pHddCtx->config->enableVhtFor24GHzBand);
4923
4924 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4925 "Name = [gFlexConnectPowerFactor] Value = [%u] ",
4926 pHddCtx->config->flexConnectPowerFactor);
4927 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4928 "Name = [gEnableIbssHeartBeatOffload] Value = [%u] ",
4929 pHddCtx->config->enableIbssHeartBeatOffload);
4930 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4931 "Name = [gAntennaDiversity] Value = [%u] ",
4932 pHddCtx->config->antennaDiversity);
4933 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4934 "Name = [gGoLinkMonitorPeriod] Value = [%u]",
4935 pHddCtx->config->goLinkMonitorPeriod);
4936 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4937 "Name = [gApLinkMonitorPeriod] Value = [%u]",
4938 pHddCtx->config->apLinkMonitorPeriod);
4939 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4940 "Name = [gGoKeepAlivePeriod] Value = [%u]",
4941 pHddCtx->config->goKeepAlivePeriod);
4942 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4943 "Name = [gApKeepAlivePeriod]Value = [%u]",
4944 pHddCtx->config->apKeepAlivePeriod);
4945 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4946 "Name = [gAmsduSupportInAMPDU] Value = [%u] ",
4947 pHddCtx->config->isAmsduSupportInAMPDU);
4948 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4949 "Name = [nSelect5GHzMargin] Value = [%u] ",
4950 pHddCtx->config->nSelect5GHzMargin);
4951 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4952 "Name = [gCoalesingInIBSS] Value = [%u] ",
4953 pHddCtx->config->isCoalesingInIBSSAllowed);
4954 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4955 "Name = [gIbssATIMWinSize] Value = [%u] ",
4956 pHddCtx->config->ibssATIMWinSize);
4957 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4958 "Name = [gIbssIsPowerSaveAllowed] Value = [%u] ",
4959 pHddCtx->config->isIbssPowerSaveAllowed);
4960 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4961 "Name = [gIbssIsPowerCollapseAllowed] Value = [%u] ",
4962 pHddCtx->config->isIbssPowerCollapseAllowed);
4963 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4964 "Name = [gIbssAwakeOnTxRx] Value = [%u] ",
4965 pHddCtx->config->isIbssAwakeOnTxRx);
4966 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4967 "Name = [gIbssInactivityTime] Value = [%u] ",
4968 pHddCtx->config->ibssInactivityCount);
4969 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4970 "Name = [gIbssTxSpEndInactivityTime] Value = [%u] ",
4971 pHddCtx->config->ibssTxSpEndInactivityTime);
4972 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4973 "Name = [gIbssPsWarmupTime] Value = [%u] ",
4974 pHddCtx->config->ibssPsWarmupTime);
4975 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4976 "Name = [gIbssPs1RxChainInAtim] Value = [%u] ",
4977 pHddCtx->config->ibssPs1RxChainInAtimEnable);
4978 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4979 "Name = [fDfsPhyerrFilterOffload] Value = [%u] ",
4980 pHddCtx->config->fDfsPhyerrFilterOffload);
4981 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4982 "Name = [gIgnorePeerErpInfo] Value = [%u] ",
4983 pHddCtx->config->ignore_peer_erp_info);
4984#ifdef IPA_OFFLOAD
4985 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4986 "Name = [gIPAConfig] Value = [0x%x] ",
4987 pHddCtx->config->IpaConfig);
4988 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4989 "Name = [gIPADescSize] Value = [%u] ",
4990 pHddCtx->config->IpaDescSize);
4991 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4992 "Name = [IpaHighBandwidthMbpsg] Value = [%u] ",
4993 pHddCtx->config->IpaHighBandwidthMbps);
4994 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4995 "Name = [IpaMediumBandwidthMbps] Value = [%u] ",
4996 pHddCtx->config->IpaMediumBandwidthMbps);
4997 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
4998 "Name = [IpaLowBandwidthMbps] Value = [%u] ",
4999 pHddCtx->config->IpaLowBandwidthMbps);
5000#endif
5001 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5002 "Name = [gEnableOverLapCh] Value = [%u] ",
5003 pHddCtx->config->gEnableOverLapCh);
5004 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5005 "Name = [gMaxOffloadPeers] Value = [%u] ",
5006 pHddCtx->config->apMaxOffloadPeers);
5007 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5008 "Name = [gMaxOffloadReorderBuffs] value = [%u] ",
5009 pHddCtx->config->apMaxOffloadReorderBuffs);
5010 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5011 "Name = [gAllowDFSChannelRoam] Value = [%u] ",
5012 pHddCtx->config->allowDFSChannelRoam);
5013 hddLog(CDF_TRACE_LEVEL_INFO_HIGH,
5014 "Name = [gMaxConcurrentActiveSessions] Value = [%u] ",
5015 pHddCtx->config->gMaxConcurrentActiveSessions);
5016
5017#ifdef MSM_PLATFORM
5018 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5019 "Name = [gBusBandwidthHighThreshold] Value = [%u] ",
5020 pHddCtx->config->busBandwidthHighThreshold);
5021 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5022 "Name = [gBusBandwidthMediumThreshold] Value = [%u] ",
5023 pHddCtx->config->busBandwidthMediumThreshold);
5024 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5025 "Name = [gBusBandwidthLowThreshold] Value = [%u] ",
5026 pHddCtx->config->busBandwidthLowThreshold);
5027 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5028 "Name = [gbusBandwidthComputeInterval] Value = [%u] ",
5029 pHddCtx->config->busBandwidthComputeInterval);
5030 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5031 "Name = [gTcpDelAckThresholdHigh] Value = [%u] ",
5032 pHddCtx->config->tcpDelackThresholdHigh);
5033 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5034 "Name = [gTcpDelAckThresholdLow] Value = [%u] ",
5035 pHddCtx->config->tcpDelackThresholdLow);
Mohit Khannae71e2262015-11-10 09:37:24 -08005036 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5037 "Name = [%s] Value = [%u] ",
5038 CFG_TCP_TX_HIGH_TPUT_THRESHOLD_NAME,
5039 pHddCtx->config->tcp_tx_high_tput_thres);
5040
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005041#endif
5042
5043 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5044 "Name = [gIgnoreCAC] Value = [%u] ",
5045 pHddCtx->config->ignoreCAC);
5046 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5047 "Name = [gSapPreferredChanLocation] Value = [%u] ",
5048 pHddCtx->config->gSapPreferredChanLocation);
5049 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5050 "Name = [gDisableDfsJapanW53] Value = [%u] ",
5051 pHddCtx->config->gDisableDfsJapanW53);
5052#ifdef FEATURE_GREEN_AP
5053 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5054 "Name = [gEnableGreenAp] Value = [%u] ",
5055 pHddCtx->config->enableGreenAP);
Ryan Hsucb118cf2015-11-09 16:03:53 -08005056 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5057 "Name = [gEenableEGAP] Value = [%u] ",
5058 pHddCtx->config->enable_egap);
5059 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5060 "Name = [gEGAPInactTime] Value = [%u] ",
5061 pHddCtx->config->egap_inact_time);
5062 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5063 "Name = [gEGAPWaitTime] Value = [%u] ",
5064 pHddCtx->config->egap_wait_time);
5065 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5066 "Name = [gEGAPFeatures] Value = [%u] ",
5067 pHddCtx->config->egap_feature_flag);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005068#endif
5069#ifdef WLAN_FEATURE_ROAM_OFFLOAD
5070 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5071 "Name = [isRoamOffloadEnabled] Value = [%u]",
5072 pHddCtx->config->isRoamOffloadEnabled);
5073#endif
5074 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5075 "Name = [gEnableSifsBurst] Value = [%u]",
5076 pHddCtx->config->enableSifsBurst);
5077
5078#ifdef WLAN_FEATURE_LPSS
5079 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5080 "Name = [gEnableLpassSupport] Value = [%u] ",
Komal Seelamc11bb222016-01-27 18:57:10 +05305081 pHddCtx->config->enable_lpass_support);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005082#endif
5083
5084 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5085 "Name = [gEnableSelfRecovery] Value = [%u]",
5086 pHddCtx->config->enableSelfRecovery);
5087
5088 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5089 "Name = [gEnableSapSuspend] Value = [%u]",
5090 pHddCtx->config->enableSapSuspend);
5091
5092#ifdef WLAN_FEATURE_EXTWOW_SUPPORT
5093 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5094 "Name = [gExtWoWgotoSuspend] Value = [%u]",
5095 pHddCtx->config->extWowGotoSuspend);
5096
5097 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5098 "Name = [gExtWowApp1WakeupPinNumber] Value = [%u]",
5099 pHddCtx->config->extWowApp1WakeupPinNumber);
5100
5101 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5102 "Name = [gExtWowApp2WakeupPinNumber] Value = [%u]",
5103 pHddCtx->config->extWowApp2WakeupPinNumber);
5104
5105 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5106 "Name = [gExtWoWApp2KAInitPingInterval] Value = [%u]",
5107 pHddCtx->config->extWowApp2KAInitPingInterval);
5108
5109 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5110 "Name = [gExtWoWApp2KAMinPingInterval] Value = [%u]",
5111 pHddCtx->config->extWowApp2KAMinPingInterval);
5112
5113 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5114 "Name = [gExtWoWApp2KAMaxPingInterval] Value = [%u]",
5115 pHddCtx->config->extWowApp2KAMaxPingInterval);
5116
5117 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5118 "Name = [gExtWoWApp2KAIncPingInterval] Value = [%u]",
5119 pHddCtx->config->extWowApp2KAIncPingInterval);
5120
5121 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5122 "Name = [gExtWoWApp2TcpSrcPort] Value = [%u]",
5123 pHddCtx->config->extWowApp2TcpSrcPort);
5124
5125 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5126 "Name = [gExtWoWApp2TcpDstPort] Value = [%u]",
5127 pHddCtx->config->extWowApp2TcpDstPort);
5128
5129 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5130 "Name = [gExtWoWApp2TcpTxTimeout] Value = [%u]",
5131 pHddCtx->config->extWowApp2TcpTxTimeout);
5132
5133 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5134 "Name = [gExtWoWApp2TcpRxTimeout] Value = [%u]",
5135 pHddCtx->config->extWowApp2TcpRxTimeout);
5136#endif
5137
5138#ifdef DHCP_SERVER_OFFLOAD
5139 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5140 "Name = [gDHCPServerOffloadEnable] Value = [%u]",
5141 pHddCtx->config->enableDHCPServerOffload);
5142 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5143 "Name = [gDHCPMaxNumClients] Value = [%u]",
5144 pHddCtx->config->dhcpMaxNumClients);
5145 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5146 "Name = [gDHCPServerIP] Value = [%s]",
5147 pHddCtx->config->dhcpServerIP);
5148#endif
5149
5150 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5151 "Name = [gEnableDumpCollect] Value = [%u]",
5152 pHddCtx->config->is_ramdump_enabled);
5153
5154 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5155 "Name = [gP2PListenDeferInterval] Value = [%u]",
5156 pHddCtx->config->p2p_listen_defer_interval);
5157 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
5158 "Name = [is_ps_enabled] value = [%d]",
5159 pHddCtx->config->is_ps_enabled);
5160 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
5161 "Name = [policy_manager_enabled] value = [%d]",
5162 pHddCtx->config->policy_manager_enabled);
5163 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
5164 "Name = [tso_enable] value = [%d]",
5165 pHddCtx->config->tso_enable);
5166 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
5167 "Name = [LROEnable] value = [%d]",
5168 pHddCtx->config->lro_enable);
5169 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
5170 "Name = [active_mode_offload] value = [%d]",
5171 pHddCtx->config->active_mode_offload);
5172 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
5173 "Name = [gfine_time_meas_cap] value = [%u]",
5174 pHddCtx->config->fine_time_meas_cap);
5175#ifdef WLAN_FEATURE_FASTPATH
5176 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5177 "Name = [fastpath_enable] Value = [%u]",
5178 pHddCtx->config->fastpath_enable);
5179#endif
5180 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
5181 "Name = [max_scan_count] value = [%d]",
5182 pHddCtx->config->max_scan_count);
5183#ifdef FEATURE_NAPI_DEBUG
5184 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
5185 "Name = [%s] value = [%d]",
5186 CFG_ENABLE_RX_THREAD, pHddCtx->config->enableRxThread);
5187 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
5188 "Name = [%s] value = [%d]",
5189 CFG_NAPI_NAME, pHddCtx->config->napi_enable);
5190#endif
5191 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
5192 "Name = [%s] Value = [%u]",
5193 CFG_CE_CLASSIFY_ENABLE_NAME,
5194 pHddCtx->config->ce_classify_enabled);
5195 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
5196 "Name = [%s] value = [%u]",
5197 CFG_DUAL_MAC_FEATURE_DISABLE,
5198 pHddCtx->config->dual_mac_feature_disable);
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07005199#ifdef FEATURE_WLAN_SCAN_PNO
5200 hddLog(LOGE, "Name = [%s] Value = [%u]",
5201 CFG_PNO_CHANNEL_PREDICTION_NAME,
5202 pHddCtx->config->pno_channel_prediction);
5203 hddLog(LOGE, "Name = [%s] Value = [%u]",
5204 CFG_TOP_K_NUM_OF_CHANNELS_NAME,
5205 pHddCtx->config->top_k_num_of_channels);
5206 hddLog(LOGE, "Name = [%s] Value = [%u]",
5207 CFG_STATIONARY_THRESHOLD_NAME,
5208 pHddCtx->config->stationary_thresh);
5209 hddLog(LOGE, "Name = [%s] Value = [%u]",
5210 CFG_CHANNEL_PREDICTION_FULL_SCAN_MS_NAME,
5211 pHddCtx->config->channel_prediction_full_scan);
5212#endif
Varun Reddy Yeturu05186292015-09-28 17:12:33 -07005213 hddLog(LOGE, "Name = [%s] Value = [%d]",
5214 CFG_EARLY_STOP_SCAN_ENABLE,
5215 pHddCtx->config->early_stop_scan_enable);
5216 hddLog(LOGE, "Name = [%s] Value = [%d]",
5217 CFG_EARLY_STOP_SCAN_MIN_THRESHOLD,
5218 pHddCtx->config->early_stop_scan_min_threshold);
5219 hddLog(LOGE, "Name = [%s] Value = [%d]",
5220 CFG_EARLY_STOP_SCAN_MAX_THRESHOLD,
5221 pHddCtx->config->early_stop_scan_max_threshold);
Varun Reddy Yeturu044bda22015-11-21 22:03:40 -08005222 hddLog(LOGE, "Name = [%s] Value = [%d]",
5223 CFG_FIRST_SCAN_BUCKET_THRESHOLD_NAME,
5224 pHddCtx->config->first_scan_bucket_threshold);
Krishna Kumaar Natarajan22b59a72015-11-23 18:54:58 -08005225 hddLog(LOGE, "Name = [%s] Value = [%u]",
5226 CFG_HT_MPDU_DENSITY_NAME,
5227 pHddCtx->config->ht_mpdu_density);
5228
Ravi Joshi742495d2015-11-09 18:56:53 -08005229
5230#ifdef FEATURE_LFR_SUBNET_DETECTION
5231 hddLog(LOGE, "Name = [%s] Value = [%d]",
5232 CFG_ENABLE_LFR_SUBNET_DETECTION,
5233 pHddCtx->config->enable_lfr_subnet_detection);
5234#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005235}
5236
5237
5238/**
5239 * hdd_update_mac_config() - update MAC address from cfg file
5240 * @pHddCtx: the pointer to hdd context
5241 *
5242 * It overwrites the MAC address if config file exist.
5243 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305244 * Return: QDF_STATUS_SUCCESS if the MAC address is found from cfg file
5245 * and overwritten, otherwise QDF_STATUS_E_INVAL
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005246 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305247QDF_STATUS hdd_update_mac_config(hdd_context_t *pHddCtx)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005248{
5249 int status, i = 0;
5250 const struct firmware *fw = NULL;
5251 char *line, *buffer = NULL;
5252 char *name, *value;
5253 tCfgIniEntry macTable[CDF_MAX_CONCURRENCY_PERSONA];
5254 tSirMacAddr customMacAddr;
5255
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305256 QDF_STATUS qdf_status = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005257
5258 memset(macTable, 0, sizeof(macTable));
5259 status = request_firmware(&fw, WLAN_MAC_FILE, pHddCtx->parent_dev);
5260
5261 if (status) {
5262 hddLog(CDF_TRACE_LEVEL_WARN, "%s: request_firmware failed %d",
5263 __func__, status);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305264 qdf_status = QDF_STATUS_E_FAILURE;
5265 return qdf_status;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005266 }
5267 if (!fw || !fw->data || !fw->size) {
5268 hddLog(CDF_TRACE_LEVEL_FATAL, "%s: invalid firmware", __func__);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305269 qdf_status = QDF_STATUS_E_INVAL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005270 goto config_exit;
5271 }
5272
5273 buffer = (char *)fw->data;
5274
5275 /* data format:
5276 * Intf0MacAddress=00AA00BB00CC
5277 * Intf1MacAddress=00AA00BB00CD
5278 * END
5279 */
5280 while (buffer != NULL) {
5281 line = get_next_line(buffer);
5282 buffer = i_trim(buffer);
5283
5284 if (strlen((char *)buffer) == 0 || *buffer == '#') {
5285 buffer = line;
5286 continue;
5287 }
5288 if (strncmp(buffer, "END", 3) == 0)
5289 break;
5290
5291 name = buffer;
5292 buffer = strnchr(buffer, strlen(buffer), '=');
5293 if (buffer) {
5294 *buffer++ = '\0';
5295 i_trim(name);
5296 if (strlen(name) != 0) {
5297 buffer = i_trim(buffer);
5298 if (strlen(buffer) == 12) {
5299 value = buffer;
5300 macTable[i].name = name;
5301 macTable[i++].value = value;
5302 if (i >= CDF_MAX_CONCURRENCY_PERSONA)
5303 break;
5304 }
5305 }
5306 }
5307 buffer = line;
5308 }
5309 if (i <= CDF_MAX_CONCURRENCY_PERSONA) {
5310 hddLog(CDF_TRACE_LEVEL_INFO, "%s: %d Mac addresses provided",
5311 __func__, i);
5312 } else {
5313 hddLog(CDF_TRACE_LEVEL_ERROR,
5314 "%s: invalid number of Mac address provided, nMac = %d",
5315 __func__, i);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305316 qdf_status = QDF_STATUS_E_INVAL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005317 goto config_exit;
5318 }
5319
5320 update_mac_from_string(pHddCtx, &macTable[0], i);
5321
5322 cdf_mem_copy(&customMacAddr,
5323 &pHddCtx->config->intfMacAddr[0].bytes[0],
5324 sizeof(tSirMacAddr));
5325 sme_set_custom_mac_addr(customMacAddr);
5326
5327config_exit:
5328 release_firmware(fw);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305329 return qdf_status;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005330}
5331
5332/**
5333 * hdd_parse_config_ini() - parse the ini configuration file
5334 * @pHddCtx: the pointer to hdd context
5335 *
5336 * This function reads the qcom_cfg.ini file and
5337 * parses each 'Name=Value' pair in the ini file
5338 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305339 * Return: QDF_STATUS_SUCCESS if the qcom_cfg.ini is correctly read,
5340 * otherwise QDF_STATUS_E_INVAL
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005341 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305342QDF_STATUS hdd_parse_config_ini(hdd_context_t *pHddCtx)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005343{
5344 int status, i = 0;
5345 /** Pointer for firmware image data */
5346 const struct firmware *fw = NULL;
5347 char *buffer, *line, *pTemp = NULL;
5348 size_t size;
5349 char *name, *value;
5350 /* cfgIniTable is static to avoid excess stack usage */
5351 static tCfgIniEntry cfgIniTable[MAX_CFG_INI_ITEMS];
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305352 QDF_STATUS qdf_status = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005353
5354 memset(cfgIniTable, 0, sizeof(cfgIniTable));
5355
5356 status = request_firmware(&fw, WLAN_INI_FILE, pHddCtx->parent_dev);
5357
5358 if (status) {
5359 hddLog(CDF_TRACE_LEVEL_FATAL, "%s: request_firmware failed %d",
5360 __func__, status);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305361 qdf_status = QDF_STATUS_E_FAILURE;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005362 goto config_exit;
5363 }
5364 if (!fw || !fw->data || !fw->size) {
5365 hddLog(CDF_TRACE_LEVEL_FATAL, "%s: %s download failed",
5366 __func__, WLAN_INI_FILE);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305367 qdf_status = QDF_STATUS_E_FAILURE;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005368 goto config_exit;
5369 }
5370
5371 hddLog(LOG1, "%s: qcom_cfg.ini Size %zu", __func__, fw->size);
5372
5373 buffer = (char *)cdf_mem_malloc(fw->size);
5374
5375 if (NULL == buffer) {
5376 hddLog(CDF_TRACE_LEVEL_FATAL, FL("cdf_mem_malloc failure"));
5377 release_firmware(fw);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305378 return QDF_STATUS_E_NOMEM;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005379 }
5380 pTemp = buffer;
5381
5382 cdf_mem_copy((void *)buffer, (void *)fw->data, fw->size);
5383 size = fw->size;
5384
5385 while (buffer != NULL) {
5386 line = get_next_line(buffer);
5387 buffer = i_trim(buffer);
5388
5389 hddLog(LOG1, "%s: item", buffer);
5390
5391 if (strlen((char *)buffer) == 0 || *buffer == '#') {
5392 buffer = line;
5393 continue;
5394 } else if (strncmp(buffer, "END", 3) == 0) {
5395 break;
5396 } else {
5397 name = buffer;
5398 while (*buffer != '=' && *buffer != '\0')
5399 buffer++;
5400 if (*buffer != '\0') {
5401 *buffer++ = '\0';
5402 i_trim(name);
5403 if (strlen(name) != 0) {
5404 buffer = i_trim(buffer);
5405 if (strlen(buffer) > 0) {
5406 value = buffer;
5407 while (!i_isspace(*buffer)
5408 && *buffer != '\0')
5409 buffer++;
5410 *buffer = '\0';
5411 cfgIniTable[i].name = name;
5412 cfgIniTable[i++].value = value;
5413 if (i >= MAX_CFG_INI_ITEMS) {
5414 hddLog(LOGE,
5415 "%s: Number of items in %s > %d",
5416 __func__,
5417 WLAN_INI_FILE,
5418 MAX_CFG_INI_ITEMS);
5419 break;
5420 }
5421 }
5422 }
5423 }
5424 }
5425 buffer = line;
5426 }
5427
5428 /* Loop through the registry table and apply all these configs */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305429 qdf_status = hdd_apply_cfg_ini(pHddCtx, cfgIniTable, i);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005430#ifdef FEATURE_NAPI
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305431 if (QDF_STATUS_SUCCESS == qdf_status)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005432 hdd_napi_event(NAPI_EVT_INI_FILE,
5433 (void *)pHddCtx->config->napi_enable);
5434#endif /* FEATURE_NAPI */
5435
5436config_exit:
5437 release_firmware(fw);
5438 cdf_mem_free(pTemp);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305439 return qdf_status;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005440}
5441
5442/**
5443 * hdd_cfg_xlate_to_csr_phy_mode() - convert PHY mode
5444 * @dot11Mode: the mode to convert
5445 *
5446 * Convert the configuration PHY mode to CSR PHY mode
5447 *
5448 * Return: the CSR phy mode value
5449 */
5450eCsrPhyMode hdd_cfg_xlate_to_csr_phy_mode(eHddDot11Mode dot11Mode)
5451{
5452 switch (dot11Mode) {
5453 case (eHDD_DOT11_MODE_abg):
5454 return eCSR_DOT11_MODE_abg;
5455 case (eHDD_DOT11_MODE_11b):
5456 return eCSR_DOT11_MODE_11b;
5457 case (eHDD_DOT11_MODE_11g):
5458 return eCSR_DOT11_MODE_11g;
5459 default:
5460 case (eHDD_DOT11_MODE_11n):
5461 return eCSR_DOT11_MODE_11n;
5462 case (eHDD_DOT11_MODE_11g_ONLY):
5463 return eCSR_DOT11_MODE_11g_ONLY;
5464 case (eHDD_DOT11_MODE_11n_ONLY):
5465 return eCSR_DOT11_MODE_11n_ONLY;
5466 case (eHDD_DOT11_MODE_11b_ONLY):
5467 return eCSR_DOT11_MODE_11b_ONLY;
5468#ifdef WLAN_FEATURE_11AC
5469 case (eHDD_DOT11_MODE_11ac_ONLY):
5470 return eCSR_DOT11_MODE_11ac_ONLY;
5471 case (eHDD_DOT11_MODE_11ac):
5472 return eCSR_DOT11_MODE_11ac;
5473#else
5474 /* If 11AC support is not compiled set Auto mode */
5475 case (eHDD_DOT11_MODE_11ac):
5476 case (eHDD_DOT11_MODE_11ac_ONLY):
5477 return eCSR_DOT11_MODE_AUTO;
5478#endif
5479 case (eHDD_DOT11_MODE_AUTO):
5480 return eCSR_DOT11_MODE_AUTO;
5481 case (eHDD_DOT11_MODE_11a):
5482 return eCSR_DOT11_MODE_11a;
5483 }
5484
5485}
5486
5487/**
5488 * hdd_set_idle_ps_config() - set idle power save configuration
5489 * @pHddCtx: the pointer to hdd context
5490 * @val: the value to configure
5491 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305492 * Return: QDF_STATUS_SUCCESS if command set correctly,
5493 * otherwise the QDF_STATUS return from SME layer
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005494 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305495QDF_STATUS hdd_set_idle_ps_config(hdd_context_t *pHddCtx, uint32_t val)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005496{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305497 QDF_STATUS status = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005498
5499 hddLog(LOG1, "hdd_set_idle_ps_config: Enter Val %d", val);
5500
Kiran Kumar Lokerefc2803d2016-01-11 19:31:38 -08005501 status = sme_set_idle_powersave_config(pHddCtx->pcds_context,
5502 pHddCtx->hHal, val);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305503 if (QDF_STATUS_SUCCESS != status)
Kiran Kumar Lokerefc2803d2016-01-11 19:31:38 -08005504 hddLog(LOGE, "Fail to Set Idle PS Config val %d", val);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005505 return status;
5506}
5507
5508/**
5509 * hdd_set_fine_time_meas_cap() - set fine timing measurement capability
5510 * @hdd_ctx: HDD context
5511 * @sme_config: pointer to SME config
5512 *
5513 * This function is used to pass fine timing measurement capability coming
5514 * from INI to SME. This function make sure that configure INI is supported
5515 * by the device. Use bit mask to mask out the unsupported capabilities.
5516 *
5517 * Return: None
5518 */
5519static void hdd_set_fine_time_meas_cap(hdd_context_t *hdd_ctx,
5520 tSmeConfigParams *sme_config)
5521{
5522 struct hdd_config *config = hdd_ctx->config;
5523 uint32_t capability = config->fine_time_meas_cap;
5524
5525 /* Make sure only supported capabilities are enabled in INI */
5526 capability &= CFG_FINE_TIME_MEAS_CAPABILITY_MAX;
Krunal Soni1878d3a2016-01-14 13:00:44 -08005527 sme_config->csrConfig.fine_time_meas_cap = capability;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005528
5529 hddLog(LOG1, FL("fine time meas capability - INI: %04x Enabled: %04x"),
Krunal Soni1878d3a2016-01-14 13:00:44 -08005530 config->fine_time_meas_cap,
5531 sme_config->csrConfig.fine_time_meas_cap);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005532
5533 return;
5534}
5535
5536/**
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005537 * hdd_convert_string_to_u8_array() - used to convert string into u8 array
5538 * @str: String to be converted
5539 * @hex_array: Array where converted value is stored
5540 * @len: Length of the populated array
5541 * @array_max_len: Maximum length of the array
5542 * @to_hex: true, if conversion required for hex string
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005543 *
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005544 * This API is called to convert string (each byte separated by
5545 * a comma) into an u8 array
5546 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305547 * Return: QDF_STATUS
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005548 */
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005549
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305550static QDF_STATUS hdd_convert_string_to_array(char *str, uint8_t *array,
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005551 uint8_t *len, uint8_t array_max_len, bool to_hex)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005552{
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005553 char *format, *s = str;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005554
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005555 if (str == NULL || array == NULL || len == NULL)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305556 return QDF_STATUS_E_INVAL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005557
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005558 format = (to_hex) ? "%02x" : "%d";
5559
5560 *len = 0;
5561 while ((s != NULL) && (*len < array_max_len)) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005562 int val;
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005563 /* Increment length only if sscanf successfully extracted
5564 * one element. Any other return value means error.
5565 * Ignore it. */
5566 if (sscanf(s, format, &val) == 1) {
5567 array[*len] = (uint8_t) val;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005568 *len += 1;
5569 }
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005570
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005571 s = strpbrk(s, ",");
5572 if (s)
5573 s++;
5574 }
5575
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305576 return QDF_STATUS_SUCCESS;
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005577}
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005578
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005579/**
5580 * hdd_hex_string_to_u8_array() - used to convert hex string into u8 array
5581 * @str: Hexadecimal string
5582 * @hex_array: Array where converted value is stored
5583 * @len: Length of the populated array
5584 * @array_max_len: Maximum length of the array
5585 *
5586 * This API is called to convert hexadecimal string (each byte separated by
5587 * a comma) into an u8 array
5588 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305589 * Return: QDF_STATUS
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005590 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305591QDF_STATUS hdd_hex_string_to_u8_array(char *str, uint8_t *hex_array,
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005592 uint8_t *len, uint8_t array_max_len)
5593{
5594 return hdd_convert_string_to_array(str, hex_array, len,
5595 array_max_len, true);
5596}
5597
5598/**
5599 * hdd_string_to_u8_array() - used to convert decimal string into u8 array
5600 * @str: Decimal string
5601 * @hex_array: Array where converted value is stored
5602 * @len: Length of the populated array
5603 * @array_max_len: Maximum length of the array
5604 *
5605 * This API is called to convert decimal string (each byte separated by
5606 * a comma) into an u8 array
5607 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305608 * Return: QDF_STATUS
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005609 */
5610
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305611QDF_STATUS hdd_string_to_u8_array(char *str, uint8_t *array,
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08005612 uint8_t *len, uint8_t array_max_len)
5613{
5614 return hdd_convert_string_to_array(str, array, len,
5615 array_max_len, false);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005616}
5617
5618/**
5619 * hdd_update_config_dat() - scan the string and convery to u8 array
5620 * @str: the pointer to the string
5621 * @intArray: the pointer of buffer to store the u8 value
5622 * @len: size of the buffer
5623 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305624 * Return: QDF_STATUS_SUCCESS if the configuration could be updated corectly,
5625 * otherwise QDF_STATUS_E_INVAL
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005626 */
5627bool hdd_update_config_dat(hdd_context_t *pHddCtx)
5628{
5629 bool fStatus = true;
5630 uint32_t val;
5631 uint16_t val16;
5632
5633 struct hdd_config *pConfig = pHddCtx->config;
5634 tSirMacHTCapabilityInfo *phtCapInfo;
5635
5636 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_SHORT_GI_20MHZ,
5637 pConfig->ShortGI20MhzEnable) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305638 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005639 fStatus = false;
5640 hddLog(LOGE, "Could not pass on WNI_CFG_SHORT_GI_20MHZ to CFG");
5641 }
5642
5643 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_FIXED_RATE, pConfig->TxRate)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305644 == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005645 fStatus = false;
5646 hddLog(LOGE, "Could not pass on WNI_CFG_FIXED_RATE to CFG");
5647 }
5648
5649 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_MAX_RX_AMPDU_FACTOR,
5650 pConfig->MaxRxAmpduFactor) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305651 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005652 fStatus = false;
5653 hddLog(LOGE,
5654 "Could not pass on WNI_CFG_HT_AMPDU_PARAMS_MAX_RX_AMPDU_FACTOR to CFG");
5655 }
5656
Krishna Kumaar Natarajan22b59a72015-11-23 18:54:58 -08005657 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_MPDU_DENSITY,
5658 pConfig->ht_mpdu_density) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305659 QDF_STATUS_E_FAILURE) {
Krishna Kumaar Natarajan22b59a72015-11-23 18:54:58 -08005660 fStatus = false;
5661 hddLog(LOGE,
5662 "Could not pass on WNI_CFG_MPDU_DENSITY to CFG");
5663 }
5664
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005665 if (sme_cfg_set_int
5666 (pHddCtx->hHal, WNI_CFG_SHORT_PREAMBLE,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305667 pConfig->fIsShortPreamble) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005668 fStatus = false;
5669 hddLog(LOGE,
5670 "Could not pass on WNI_CFG_SHORT_PREAMBLE to CFG");
5671 }
5672
5673 if (sme_cfg_set_int(pHddCtx->hHal,
5674 WNI_CFG_PASSIVE_MINIMUM_CHANNEL_TIME,
5675 pConfig->nPassiveMinChnTime)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305676 == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005677 fStatus = false;
5678 hddLog(LOGE,
5679 "Could not pass on WNI_CFG_PASSIVE_MINIMUM_CHANNEL_TIME"
5680 " to CFG");
5681 }
5682
5683 if (sme_cfg_set_int(pHddCtx->hHal,
5684 WNI_CFG_PASSIVE_MAXIMUM_CHANNEL_TIME,
5685 pConfig->nPassiveMaxChnTime)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305686 == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005687 fStatus = false;
5688 hddLog(LOGE,
5689 "Could not pass on WNI_CFG_PASSIVE_MAXIMUM_CHANNEL_TIME"
5690 " to CFG");
5691 }
5692
5693 if (sme_cfg_set_int
5694 (pHddCtx->hHal, WNI_CFG_BEACON_INTERVAL,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305695 pConfig->nBeaconInterval) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005696 fStatus = false;
5697 hddLog(LOGE,
5698 "Could not pass on WNI_CFG_BEACON_INTERVAL to CFG");
5699 }
5700
5701 if (sme_cfg_set_int
5702 (pHddCtx->hHal, WNI_CFG_MAX_PS_POLL,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305703 pConfig->nMaxPsPoll) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005704 fStatus = false;
5705 hddLog(LOGE, "Could not pass on WNI_CFG_MAX_PS_POLL to CFG");
5706 }
5707
5708 if (sme_cfg_set_int
5709 (pHddCtx->hHal, WNI_CFG_CURRENT_RX_ANTENNA,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305710 pConfig->nRxAnt) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005711 fStatus = false;
5712 hddLog(LOGE,
5713 "Could not pass on WNI_CFG_CURRENT_RX_ANTENNA to CFG");
5714 }
5715
5716 if (sme_cfg_set_int (pHddCtx->hHal, WNI_CFG_LOW_GAIN_OVERRIDE,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305717 pConfig->fIsLowGainOverride) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005718 fStatus = false;
5719 hddLog(LOGE,
5720 "Could not pass on WNI_CFG_LOW_GAIN_OVERRIDE to HAL");
5721 }
5722
5723 if (sme_cfg_set_int
5724 (pHddCtx->hHal, WNI_CFG_RSSI_FILTER_PERIOD,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305725 pConfig->nRssiFilterPeriod) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005726 fStatus = false;
5727 hddLog(LOGE,
5728 "Could not pass on WNI_CFG_RSSI_FILTER_PERIOD to CFG");
5729 }
5730
5731 if (sme_cfg_set_int
5732 (pHddCtx->hHal, WNI_CFG_IGNORE_DTIM,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305733 pConfig->fIgnoreDtim) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005734 fStatus = false;
5735 hddLog(LOGE,
5736 "Could not pass on WNI_IGNORE_DTIM to CFG");
5737 }
5738
5739 if (sme_cfg_set_int
5740 (pHddCtx->hHal, WNI_CFG_PS_ENABLE_HEART_BEAT,
5741 pConfig->fEnableFwHeartBeatMonitoring)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305742 == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005743 fStatus = false;
5744 hddLog(LOGE,
5745 "Could not pass on WNI_CFG_PS_HEART_BEAT to CFG");
5746 }
5747
5748 if (sme_cfg_set_int
5749 (pHddCtx->hHal, WNI_CFG_PS_ENABLE_BCN_FILTER,
5750 pConfig->fEnableFwBeaconFiltering) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305751 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005752 fStatus = false;
5753 hddLog(LOGE,
5754 "Could not pass on WNI_CFG_PS_BCN_FILTER to CFG");
5755 }
5756
5757 if (sme_cfg_set_int
5758 (pHddCtx->hHal, WNI_CFG_PS_ENABLE_RSSI_MONITOR,
5759 pConfig->fEnableFwRssiMonitoring) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305760 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005761 fStatus = false;
5762 hddLog(LOGE,
5763 "Could not pass on WNI_CFG_PS_RSSI_MONITOR to CFG");
5764 }
5765
5766 if (sme_cfg_set_int
5767 (pHddCtx->hHal, WNI_CFG_PS_DATA_INACTIVITY_TIMEOUT,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305768 pConfig->nDataInactivityTimeout) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005769 fStatus = false;
5770 hddLog(LOGE,
5771 "Could not pass on WNI_CFG_PS_DATA_INACTIVITY_TIMEOUT to CFG");
5772 }
5773
5774 if (sme_cfg_set_int
5775 (pHddCtx->hHal, WNI_CFG_ENABLE_LTE_COEX,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305776 pConfig->enableLTECoex) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005777 fStatus = false;
5778 hddLog(LOGE,
5779 "Could not pass on WNI_CFG_ENABLE_LTE_COEX to CFG");
5780 }
5781
5782 if (sme_cfg_set_int
5783 (pHddCtx->hHal, WNI_CFG_ENABLE_PHY_AGC_LISTEN_MODE,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305784 pConfig->nEnableListenMode) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005785 fStatus = false;
5786 hddLog(LOGE,
5787 "Could not pass on WNI_CFG_ENABLE_PHY_AGC_LISTEN_MODE to CFG");
5788 }
5789
5790 if (sme_cfg_set_int
5791 (pHddCtx->hHal, WNI_CFG_AP_KEEP_ALIVE_TIMEOUT,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305792 pConfig->apKeepAlivePeriod) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005793 fStatus = false;
5794 hddLog(LOGE,
5795 "Could not pass on WNI_CFG_AP_KEEP_ALIVE_TIMEOUT to CFG");
5796 }
5797
5798 if (sme_cfg_set_int
5799 (pHddCtx->hHal, WNI_CFG_GO_KEEP_ALIVE_TIMEOUT,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305800 pConfig->goKeepAlivePeriod) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005801 fStatus = false;
5802 hddLog(LOGE,
5803 "Could not pass on WNI_CFG_GO_KEEP_ALIVE_TIMEOUT to CFG");
5804 }
5805
5806 if (sme_cfg_set_int
5807 (pHddCtx->hHal, WNI_CFG_AP_LINK_MONITOR_TIMEOUT,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305808 pConfig->apLinkMonitorPeriod) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005809 fStatus = false;
5810 hddLog(LOGE,
5811 "Could not pass on WNI_CFG_AP_LINK_MONITOR_TIMEOUT to CFG");
5812 }
5813
5814 if (sme_cfg_set_int
5815 (pHddCtx->hHal, WNI_CFG_GO_LINK_MONITOR_TIMEOUT,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305816 pConfig->goLinkMonitorPeriod) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005817 fStatus = false;
5818 hddLog(LOGE,
5819 "Could not pass on WNI_CFG_GO_LINK_MONITOR_TIMEOUT to CFG");
5820 }
5821
5822#if defined WLAN_FEATURE_VOWIFI
5823 if (sme_cfg_set_int
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005824 (pHddCtx->hHal, WNI_CFG_MCAST_BCAST_FILTER_SETTING,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305825 pConfig->mcastBcastFilterSetting) == QDF_STATUS_E_FAILURE)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005826 fStatus = false;
5827 hddLog(LOGE,
5828 "Could not pass on WNI_CFG_MCAST_BCAST_FILTER_SETTING to CFG");
5829#endif
5830
5831 if (sme_cfg_set_int
5832 (pHddCtx->hHal, WNI_CFG_SINGLE_TID_RC,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305833 pConfig->bSingleTidRc) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005834 fStatus = false;
5835 hddLog(LOGE,
5836 "Could not pass on WNI_CFG_SINGLE_TID_RC to CFG");
5837 }
5838
5839 if (sme_cfg_set_int
5840 (pHddCtx->hHal, WNI_CFG_TELE_BCN_WAKEUP_EN,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305841 pConfig->teleBcnWakeupEn) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005842 fStatus = false;
5843 hddLog(LOGE,
5844 "Could not pass on WNI_CFG_TELE_BCN_WAKEUP_EN to CFG");
5845 }
5846
5847 if (sme_cfg_set_int
5848 (pHddCtx->hHal, WNI_CFG_TELE_BCN_TRANS_LI,
5849 pConfig->nTeleBcnTransListenInterval) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305850 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005851 fStatus = false;
5852 hddLog(LOGE,
5853 "Could not pass on WNI_CFG_TELE_BCN_TRANS_LI to CFG");
5854 }
5855
5856 if (sme_cfg_set_int
5857 (pHddCtx->hHal, WNI_CFG_TELE_BCN_MAX_LI,
5858 pConfig->nTeleBcnMaxListenInterval) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305859 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005860 fStatus = false;
5861 hddLog(LOGE,
5862 "Could not pass on WNI_CFG_TELE_BCN_MAX_LI to CFG");
5863 }
5864
5865 if (sme_cfg_set_int
5866 (pHddCtx->hHal, WNI_CFG_TELE_BCN_TRANS_LI_IDLE_BCNS,
5867 pConfig->nTeleBcnTransLiNumIdleBeacons) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305868 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005869 fStatus = false;
5870 hddLog(LOGE,
5871 "Could not pass on WNI_CFG_TELE_BCN_TRANS_LI_IDLE_BCNS to CFG");
5872 }
5873
5874 if (sme_cfg_set_int
5875 (pHddCtx->hHal, WNI_CFG_TELE_BCN_MAX_LI_IDLE_BCNS,
5876 pConfig->nTeleBcnMaxLiNumIdleBeacons) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305877 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005878 fStatus = false;
5879 hddLog(LOGE,
5880 "Could not pass on WNI_CFG_TELE_BCN_MAX_LI_IDLE_BCNS to CFG");
5881 }
5882
5883 if (sme_cfg_set_int
5884 (pHddCtx->hHal, WNI_CFG_RF_SETTLING_TIME_CLK,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305885 pConfig->rfSettlingTimeUs) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005886 fStatus = false;
5887 hddLog(LOGE,
5888 "Could not pass on WNI_CFG_RF_SETTLING_TIME_CLK to CFG");
5889 }
5890
5891 if (sme_cfg_set_int
5892 (pHddCtx->hHal, WNI_CFG_INFRA_STA_KEEP_ALIVE_PERIOD,
5893 pConfig->infraStaKeepAlivePeriod) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305894 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005895 fStatus = false;
5896 hddLog(LOGE,
5897 "Could not pass on WNI_CFG_INFRA_STA_KEEP_ALIVE_PERIOD to CFG");
5898 }
5899 if (sme_cfg_set_int
5900 (pHddCtx->hHal, WNI_CFG_DYNAMIC_PS_POLL_VALUE,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305901 pConfig->dynamicPsPollValue) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005902 fStatus = false;
5903 hddLog(LOGE,
5904 "Could not pass on WNI_CFG_DYNAMIC_PS_POLL_VALUE to CFG");
5905 }
5906
5907 if (sme_cfg_set_int
5908 (pHddCtx->hHal, WNI_CFG_PS_NULLDATA_AP_RESP_TIMEOUT,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305909 pConfig->nNullDataApRespTimeout) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005910 fStatus = false;
5911 hddLog(LOGE,
5912 "Could not pass on WNI_CFG_PS_NULLDATA_DELAY_TIMEOUT to CFG");
5913 }
5914
5915 if (sme_cfg_set_int
5916 (pHddCtx->hHal, WNI_CFG_AP_DATA_AVAIL_POLL_PERIOD,
5917 pConfig->apDataAvailPollPeriodInMs) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305918 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005919 fStatus = false;
5920 hddLog(LOGE,
5921 "Could not pass on WNI_CFG_AP_DATA_AVAIL_POLL_PERIOD to CFG");
5922 }
5923 if (sme_cfg_set_int
5924 (pHddCtx->hHal, WNI_CFG_FRAGMENTATION_THRESHOLD,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305925 pConfig->FragmentationThreshold) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005926 fStatus = false;
5927 hddLog(LOGE,
5928 "Could not pass on WNI_CFG_FRAGMENTATION_THRESHOLD to CFG");
5929 }
5930 if (sme_cfg_set_int
5931 (pHddCtx->hHal, WNI_CFG_RTS_THRESHOLD,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305932 pConfig->RTSThreshold) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005933 fStatus = false;
5934 hddLog(LOGE,
5935 "Could not pass on WNI_CFG_RTS_THRESHOLD to CFG");
5936 }
5937
5938 if (sme_cfg_set_int
5939 (pHddCtx->hHal, WNI_CFG_11D_ENABLED,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305940 pConfig->Is11dSupportEnabled) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005941 fStatus = false;
5942 hddLog(LOGE,
5943 "Could not pass on WNI_CFG_11D_ENABLED to CFG");
5944 }
5945
5946 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_DFS_MASTER_ENABLED,
5947 pConfig->enableDFSMasterCap) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305948 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005949 fStatus = false;
5950 hddLog(LOGE,
5951 "Failure: Could not set value for WNI_CFG_DFS_MASTER_ENABLED");
5952 }
5953
5954 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_VHT_ENABLE_TXBF_20MHZ,
5955 pConfig->enableTxBFin20MHz) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305956 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005957 fStatus = false;
5958 hddLog(LOGE,
5959 "Could not set value for WNI_CFG_VHT_ENABLE_TXBF_20MHZ");
5960 }
5961
5962 if (sme_cfg_set_int
5963 (pHddCtx->hHal, WNI_CFG_HEART_BEAT_THRESHOLD,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305964 pConfig->HeartbeatThresh24) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005965 fStatus = false;
5966 hddLog(LOGE,
5967 "Could not pass on WNI_CFG_HEART_BEAT_THRESHOLD to CFG");
5968 }
5969
5970 if (sme_cfg_set_int
5971 (pHddCtx->hHal, WNI_CFG_AP_DATA_AVAIL_POLL_PERIOD,
5972 pConfig->apDataAvailPollPeriodInMs) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305973 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005974 fStatus = false;
5975 hddLog(LOGE,
5976 "Could not pass on WNI_CFG_AP_DATA_AVAIL_POLL_PERIOD to CFG");
5977 }
5978
5979 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_ENABLE_CLOSE_LOOP,
5980 pConfig->enableCloseLoop) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305981 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005982 fStatus = false;
5983 hddLog(LOGE,
5984 "Could not pass on WNI_CFG_ENABLE_CLOSE_LOOP to CFG");
5985 }
5986
5987 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_TX_PWR_CTRL_ENABLE,
5988 pConfig->enableAutomaticTxPowerControl)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305989 == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005990 fStatus = false;
5991 hddLog(LOGE,
5992 "Could not pass on WNI_CFG_TX_PWR_CTRL_ENABLE to CFG");
5993 }
5994
5995 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_SHORT_GI_40MHZ,
5996 pConfig->ShortGI40MhzEnable) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305997 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005998 fStatus = false;
5999 hddLog(LOGE, "Could not pass on WNI_CFG_SHORT_GI_40MHZ to CFG");
6000 }
6001
6002 if (sme_cfg_set_int
6003 (pHddCtx->hHal, WNI_CFG_ENABLE_MC_ADDR_LIST,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306004 pConfig->fEnableMCAddrList) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006005 fStatus = false;
6006 hddLog(LOGE,
6007 "Could not pass on WNI_CFG_ENABLE_MC_ADDR_LIST to CFG");
6008 }
6009 /* Based on cfg.ini, update the Basic MCS set, RX/TX MCS map
6010 * in the cfg.dat. Valid values are 0(MCS0-7), 1(MCS0-8), 2(MCS0-9)
6011 * we update only the least significant 2 bits in the
6012 * corresponding fields.
6013 */
6014 if ((pConfig->dot11Mode == eHDD_DOT11_MODE_AUTO) ||
6015 (pConfig->dot11Mode == eHDD_DOT11_MODE_11ac_ONLY) ||
6016 (pConfig->dot11Mode == eHDD_DOT11_MODE_11ac)) {
6017 uint32_t temp = 0;
6018
6019 sme_cfg_get_int(pHddCtx->hHal,
6020 WNI_CFG_VHT_BASIC_MCS_SET, &temp);
6021 temp = (temp & 0xFFFC) | pConfig->vhtRxMCS;
6022 if (pConfig->enable2x2)
6023 temp = (temp & 0xFFF3) | (pConfig->vhtRxMCS2x2 << 2);
6024 if (sme_cfg_set_int(pHddCtx->hHal,
6025 WNI_CFG_VHT_BASIC_MCS_SET, temp) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306026 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006027 fStatus = false;
6028 hddLog(LOGE,
6029 "Could not pass on WNI_CFG_VHT_BASIC_MCS_SET to CFG");
6030 }
6031
6032 sme_cfg_get_int(pHddCtx->hHal, WNI_CFG_VHT_RX_MCS_MAP,
6033 &temp);
6034 temp = (temp & 0xFFFC) | pConfig->vhtRxMCS;
6035 if (pConfig->enable2x2)
6036 temp = (temp & 0xFFF3) | (pConfig->vhtRxMCS2x2 << 2);
6037 if (sme_cfg_set_int(pHddCtx->hHal,
6038 WNI_CFG_VHT_RX_MCS_MAP, temp)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306039 == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006040 fStatus = false;
6041 hddLog(LOGE,
6042 "Could not pass on WNI_CFG_VHT_RX_MCS_MAP to CFG");
6043 }
6044 sme_cfg_get_int(pHddCtx->hHal, WNI_CFG_VHT_TX_MCS_MAP, &temp);
6045 temp = (temp & 0xFFFC) | pConfig->vhtTxMCS;
6046 if (pConfig->enable2x2)
6047 temp = (temp & 0xFFF3) | (pConfig->vhtTxMCS2x2 << 2);
6048 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
6049 "vhtRxMCS2x2 - %x temp - %u enable2x2 %d",
6050 pConfig->vhtRxMCS2x2, temp,
6051 pConfig->enable2x2);
6052
6053 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_VHT_TX_MCS_MAP,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306054 temp) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006055 fStatus = false;
6056 hddLog(LOGE,
6057 "Could not pass on WNI_CFG_VHT_TX_MCS_MAP to CFG");
6058 }
6059 /* Currently shortGI40Mhz is used for shortGI80Mhz */
6060 if (sme_cfg_set_int
6061 (pHddCtx->hHal, WNI_CFG_VHT_SHORT_GI_80MHZ,
6062 pConfig->ShortGI40MhzEnable) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306063 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006064 fStatus = false;
6065 hddLog(LOGE,
6066 "Could not pass WNI_VHT_SHORT_GI_80MHZ to CFG");
6067 }
6068 /* Hardware is capable of doing
6069 * 128K AMPDU in 11AC mode */
6070 if (sme_cfg_set_int(pHddCtx->hHal,
6071 WNI_CFG_VHT_AMPDU_LEN_EXPONENT,
6072 pConfig->fVhtAmpduLenExponent) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306073 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006074 fStatus = false;
6075 hddLog(LOGE,
6076 "Could not pass on WNI_CFG_VHT_AMPDU_LEN_EXPONENT to CFG");
6077 }
6078 /* Change MU Bformee only when TxBF is enabled */
6079 if (pConfig->enableTxBF) {
6080 sme_cfg_get_int(pHddCtx->hHal,
6081 WNI_CFG_VHT_MU_BEAMFORMEE_CAP, &temp);
6082
6083 if (temp != pConfig->enableMuBformee) {
6084 if (sme_cfg_set_int(pHddCtx->hHal,
6085 WNI_CFG_VHT_MU_BEAMFORMEE_CAP,
6086 pConfig->enableMuBformee
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306087 ) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006088 fStatus = false;
6089 hddLog(LOGE,
6090 "Could not pass on WNI_CFG_VHT_MU_BEAMFORMEE_CAP to CFG");
6091 }
6092 }
6093 }
6094 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_VHT_MAX_MPDU_LENGTH,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306095 pConfig->vhtMpduLen) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006096 fStatus = false;
6097 hddLog(LOGE,
6098 "Could not pass on WNI_CFG_VHT_MAX_MPDU_LENGTH to CFG");
6099 }
6100
6101 if (pConfig->enable2x2 && pConfig->enable_su_tx_bformer) {
6102 if (sme_cfg_set_int(pHddCtx->hHal,
6103 WNI_CFG_VHT_SU_BEAMFORMER_CAP,
6104 pConfig->enable_su_tx_bformer) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306105 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006106 fStatus = false;
6107 hdd_err("set SU_BEAMFORMER_CAP to CFG failed");
6108 }
6109 if (sme_cfg_set_int(pHddCtx->hHal,
6110 WNI_CFG_VHT_NUM_SOUNDING_DIMENSIONS,
6111 NUM_OF_SOUNDING_DIMENSIONS) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306112 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006113 fStatus = false;
6114 hdd_err("failed to set NUM_OF_SOUNDING_DIM");
6115 }
6116 }
6117 }
6118
6119 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_HT_RX_STBC,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306120 pConfig->enableRxSTBC) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006121 fStatus = false;
6122 hddLog(LOGE, "Could not pass on WNI_CFG_HT_RX_STBC to CFG");
6123 }
6124
6125 sme_cfg_get_int(pHddCtx->hHal, WNI_CFG_HT_CAP_INFO, &val);
6126 val16 = (uint16_t) val;
6127 phtCapInfo = (tSirMacHTCapabilityInfo *) &val16;
6128 phtCapInfo->rxSTBC = pConfig->enableRxSTBC;
6129 phtCapInfo->advCodingCap = pConfig->enableRxLDPC;
6130 val = val16;
6131 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_HT_CAP_INFO, val)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306132 == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006133 fStatus = false;
6134 hddLog(LOGE, "Could not pass on WNI_CFG_HT_CAP_INFO to CFG");
6135 }
6136
6137 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_VHT_RXSTBC,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306138 pConfig->enableRxSTBC) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006139 fStatus = false;
6140 hddLog(LOGE, "Could not pass on WNI_CFG_VHT_RXSTBC to CFG");
6141 }
6142
6143 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_VHT_TXSTBC,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306144 pConfig->enableTxSTBC) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006145 fStatus = false;
6146 hddLog(LOGE, "Could not pass on WNI_CFG_VHT_TXSTBC to CFG");
6147 }
6148
6149 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_VHT_LDPC_CODING_CAP,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306150 pConfig->enableRxLDPC) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006151 fStatus = false;
6152 hddLog(LOGE,
6153 "Could not pass on WNI_CFG_VHT_LDPC_CODING_CAP to CFG");
6154 }
6155#ifdef WLAN_SOFTAP_VSTA_FEATURE
6156 if (pConfig->fEnableVSTASupport) {
6157 sme_cfg_get_int(pHddCtx->hHal, WNI_CFG_ASSOC_STA_LIMIT, &val);
6158 if (val <= WNI_CFG_ASSOC_STA_LIMIT_STADEF)
6159 val = WNI_CFG_ASSOC_STA_LIMIT_STAMAX;
6160 } else {
6161 val = pConfig->maxNumberOfPeers;
6162
6163 }
6164 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_ASSOC_STA_LIMIT, val) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306165 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006166 fStatus = false;
6167 hddLog(LOGE,
6168 "Could not pass on WNI_CFG_ASSOC_STA_LIMIT to CFG");
6169 }
6170#endif
6171 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_ENABLE_LPWR_IMG_TRANSITION,
6172 pConfig->enableLpwrImgTransition)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306173 == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006174 fStatus = false;
6175 hddLog(LOGE,
6176 "Could not pass on WNI_CFG_ENABLE_LPWR_IMG_TRANSITION to CFG");
6177 }
6178
6179 if (sme_cfg_set_int
6180 (pHddCtx->hHal, WNI_CFG_ENABLE_MCC_ADAPTIVE_SCHED,
6181 pConfig->enableMCCAdaptiveScheduler) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306182 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006183 fStatus = false;
6184 hddLog(LOGE,
6185 "Could not pass on WNI_CFG_ENABLE_MCC_ADAPTIVE_SCHED to CFG");
6186 }
6187 if (sme_cfg_set_int
6188 (pHddCtx->hHal, WNI_CFG_DISABLE_LDPC_WITH_TXBF_AP,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306189 pConfig->disableLDPCWithTxbfAP) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006190 fStatus = false;
6191 hddLog(LOGE,
6192 "Could not pass on WNI_CFG_DISABLE_LDPC_WITH_TXBF_AP to CFG");
6193 }
6194
6195 if (sme_cfg_set_int
6196 (pHddCtx->hHal, WNI_CFG_DYNAMIC_THRESHOLD_ZERO,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306197 pConfig->retryLimitZero) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006198 fStatus = false;
6199 hddLog(LOGE,
6200 "Could not pass on WNI_CFG_DYNAMIC_THRESHOLD_ZERO to CFG");
6201 }
6202
6203 if (sme_cfg_set_int
6204 (pHddCtx->hHal, WNI_CFG_DYNAMIC_THRESHOLD_ONE,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306205 pConfig->retryLimitOne) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006206 fStatus = false;
6207 hddLog(LOGE,
6208 "Could not pass on WNI_CFG_DYNAMIC_THRESHOLD_ONE to CFG");
6209 }
6210
6211 if (sme_cfg_set_int
6212 (pHddCtx->hHal, WNI_CFG_DYNAMIC_THRESHOLD_TWO,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306213 pConfig->retryLimitTwo) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006214 fStatus = false;
6215 hddLog(LOGE,
6216 "Could not pass on WNI_CFG_DYNAMIC_THRESHOLD_TWO to CFG");
6217 }
6218
6219 if (sme_cfg_set_int
6220 (pHddCtx->hHal, WNI_CFG_MAX_MEDIUM_TIME,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306221 pConfig->cfgMaxMediumTime) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006222 fStatus = false;
6223 hddLog(LOGE,
6224 "Could not pass on WNI_CFG_MAX_MEDIUM_TIME to CFG");
6225 }
6226#ifdef FEATURE_WLAN_TDLS
6227
6228 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_TDLS_QOS_WMM_UAPSD_MASK,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306229 pConfig->fTDLSUapsdMask) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006230 fStatus = false;
6231 hddLog(LOGE,
6232 "Could not pass on WNI_CFG_TDLS_QOS_WMM_UAPSD_MASK to CFG");
6233 }
6234 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_TDLS_BUF_STA_ENABLED,
6235 pConfig->fEnableTDLSBufferSta) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306236 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006237 fStatus = false;
6238 hddLog(LOGE,
6239 "Could not pass on WNI_CFG_TDLS_BUF_STA_ENABLED to CFG");
6240 }
6241 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_TDLS_PUAPSD_INACT_TIME,
6242 pConfig->fTDLSPuapsdInactivityTimer) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306243 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006244 fStatus = false;
6245 hddLog(LOGE,
6246 "Could not pass on WNI_CFG_TDLS_PUAPSD_INACT_TIME to CFG");
6247 }
6248 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_TDLS_RX_FRAME_THRESHOLD,
6249 pConfig->fTDLSRxFrameThreshold) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306250 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006251 fStatus = false;
6252 hddLog(LOGE,
6253 "Could not pass on WNI_CFG_TDLS_RX_FRAME_THRESHOLD to CFG");
6254 }
6255
6256 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_TDLS_OFF_CHANNEL_ENABLED,
6257 pConfig->fEnableTDLSOffChannel) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306258 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006259 fStatus = false;
6260 hddLog(LOGE,
6261 "Could not pass on WNI_CFG_TDLS_BUF_STA_ENABLED to CFG");
6262 }
6263 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_TDLS_WMM_MODE_ENABLED,
6264 pConfig->fEnableTDLSWmmMode) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306265 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006266 fStatus = false;
6267 hddLog(LOGE,
6268 "Could not pass on WNI_CFG_TDLS_WMM_MODE_ENABLED to CFG");
6269 }
6270#endif
6271
6272 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_ENABLE_ADAPT_RX_DRAIN,
6273 pConfig->fEnableAdaptRxDrain) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306274 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006275 fStatus = false;
6276 hddLog(LOGE,
6277 "Could not pass on WNI_CFG_ENABLE_ADAPT_RX_DRAIN to CFG");
6278 }
6279
6280 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_FLEX_CONNECT_POWER_FACTOR,
6281 pConfig->flexConnectPowerFactor) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306282 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006283 fStatus = false;
6284 hddLog(LOGE, "Failure: Could not pass on "
6285 "WNI_CFG_FLEX_CONNECT_POWER_FACTOR to CFG");
6286 }
6287
6288 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_ANTENNA_DIVESITY,
6289 pConfig->antennaDiversity) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306290 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006291 fStatus = false;
6292 hddLog(LOGE,
6293 "Could not pass on WNI_CFG_ANTENNA_DIVESITY to CFG");
6294 }
6295
6296 if (sme_cfg_set_int(pHddCtx->hHal,
6297 WNI_CFG_DEFAULT_RATE_INDEX_24GHZ,
6298 pConfig->defaultRateIndex24Ghz) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306299 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006300 fStatus = false;
6301 hddLog(LOGE,
6302 "Could not pass on WNI_CFG_DEFAULT_RATE_INDEX_24GHZ to CFG");
6303 }
6304
6305 if (sme_cfg_set_int(pHddCtx->hHal,
6306 WNI_CFG_DEBUG_P2P_REMAIN_ON_CHANNEL,
6307 pConfig->debugP2pRemainOnChannel) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306308 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006309 fStatus = false;
6310 hddLog(LOGE,
6311 "Could not pass on WNI_CFG_DEBUG_P2P_REMAIN_ON_CHANNEL to CFG");
6312 }
6313#ifdef WLAN_FEATURE_11W
6314 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_PMF_SA_QUERY_MAX_RETRIES,
6315 pConfig->pmfSaQueryMaxRetries) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306316 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006317 fStatus = false;
6318 hddLog(LOGE,
6319 "Could not pass on WNI_CFG_SA_QUERY_MAX_RETRIES to CFG");
6320 }
6321
6322 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_PMF_SA_QUERY_RETRY_INTERVAL,
6323 pConfig->pmfSaQueryRetryInterval) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306324 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006325 fStatus = false;
6326 hddLog(LOGE,
6327 "Could not pass on WNI_CFG_SA_QUERY_RETRY_INTERVAL to CFG");
6328 }
6329#endif
6330
6331 if (sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_IBSS_ATIM_WIN_SIZE,
6332 pConfig->ibssATIMWinSize) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306333 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006334 fStatus = false;
6335 hddLog(LOGE,
6336 "Could not pass on WNI_CFG_IBSS_ATIM_WIN_SIZE to CFG");
6337 }
6338 return fStatus;
6339}
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006340#ifdef FEATURE_WLAN_SCAN_PNO
6341/**
6342 * hdd_set_pno_channel_prediction_config() - Set PNO configuration
6343 * @sme_config: Config params from SME Context
6344 * @hdd_ctx: Config params from HDD Context
6345 *
6346 * Copy the PNO Channel prediction feature configuration parameters
6347 * from HDD context to SME context.
6348 *
6349 * Return: None
6350 */
6351void hdd_set_pno_channel_prediction_config(
6352 tpSmeConfigParams sme_config, hdd_context_t *hdd_ctx)
6353{
Krunal Soni1878d3a2016-01-14 13:00:44 -08006354 sme_config->csrConfig.dual_mac_feature_disable =
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006355 hdd_ctx->config->dual_mac_feature_disable;
Krunal Soni1878d3a2016-01-14 13:00:44 -08006356 sme_config->csrConfig.pno_channel_prediction =
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006357 hdd_ctx->config->pno_channel_prediction;
Krunal Soni1878d3a2016-01-14 13:00:44 -08006358 sme_config->csrConfig.top_k_num_of_channels =
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006359 hdd_ctx->config->top_k_num_of_channels;
Krunal Soni1878d3a2016-01-14 13:00:44 -08006360 sme_config->csrConfig.stationary_thresh =
6361 hdd_ctx->config->stationary_thresh;
6362 sme_config->csrConfig.channel_prediction_full_scan =
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006363 hdd_ctx->config->channel_prediction_full_scan;
6364}
6365#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006366/**
6367 * hdd_set_sme_config() -initializes the sme configuration parameters
6368 *
6369 * @pHddCtx: the pointer to hdd context
6370 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306371 * Return: QDF_STATUS_SUCCESS if configuration is correctly applied,
6372 * otherwise the appropriate QDF_STATUS would be returned
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006373 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306374QDF_STATUS hdd_set_sme_config(hdd_context_t *pHddCtx)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006375{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306376 QDF_STATUS status = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006377 tSmeConfigParams *smeConfig;
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006378 uint8_t rrm_capab_len;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006379
6380 struct hdd_config *pConfig = pHddCtx->config;
6381
6382 smeConfig = cdf_mem_malloc(sizeof(*smeConfig));
6383 if (NULL == smeConfig) {
6384 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_ERROR,
6385 "%s: unable to allocate smeConfig", __func__);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306386 return QDF_STATUS_E_NOMEM;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006387 }
6388 cdf_mem_zero(smeConfig, sizeof(*smeConfig));
6389
6390 CDF_TRACE(CDF_MODULE_ID_HDD, CDF_TRACE_LEVEL_INFO_HIGH,
6391 "%s bWmmIsEnabled=%d 802_11e_enabled=%d dot11Mode=%d",
6392 __func__, pConfig->WmmMode, pConfig->b80211eIsEnabled,
6393 pConfig->dot11Mode);
6394
6395 /* Config params obtained from the registry
6396 * To Do: set regulatory information here
6397 */
6398
6399 smeConfig->csrConfig.RTSThreshold = pConfig->RTSThreshold;
6400 smeConfig->csrConfig.FragmentationThreshold =
6401 pConfig->FragmentationThreshold;
6402 smeConfig->csrConfig.shortSlotTime = pConfig->ShortSlotTimeEnabled;
6403 smeConfig->csrConfig.Is11dSupportEnabled = pConfig->Is11dSupportEnabled;
6404 smeConfig->csrConfig.HeartbeatThresh24 = pConfig->HeartbeatThresh24;
6405
6406 smeConfig->csrConfig.phyMode =
6407 hdd_cfg_xlate_to_csr_phy_mode(pConfig->dot11Mode);
6408
6409 if (pConfig->dot11Mode == eHDD_DOT11_MODE_abg ||
6410 pConfig->dot11Mode == eHDD_DOT11_MODE_11b ||
6411 pConfig->dot11Mode == eHDD_DOT11_MODE_11g ||
6412 pConfig->dot11Mode == eHDD_DOT11_MODE_11b_ONLY ||
6413 pConfig->dot11Mode == eHDD_DOT11_MODE_11g_ONLY) {
6414 smeConfig->csrConfig.channelBondingMode24GHz = 0;
6415 smeConfig->csrConfig.channelBondingMode5GHz = 0;
6416 } else {
6417 smeConfig->csrConfig.channelBondingMode24GHz =
6418 pConfig->nChannelBondingMode24GHz;
6419 smeConfig->csrConfig.channelBondingMode5GHz =
6420 pConfig->nChannelBondingMode5GHz;
6421 }
6422 smeConfig->csrConfig.TxRate = pConfig->TxRate;
6423 smeConfig->csrConfig.nScanResultAgeCount = pConfig->ScanResultAgeCount;
6424 smeConfig->csrConfig.scanAgeTimeNCNPS = pConfig->nScanAgeTimeNCNPS;
6425 smeConfig->csrConfig.scanAgeTimeNCPS = pConfig->nScanAgeTimeNCPS;
6426 smeConfig->csrConfig.scanAgeTimeCNPS = pConfig->nScanAgeTimeCNPS;
6427 smeConfig->csrConfig.scanAgeTimeCPS = pConfig->nScanAgeTimeCPS;
6428 smeConfig->csrConfig.AdHocChannel24 = pConfig->OperatingChannel;
6429 smeConfig->csrConfig.fSupplicantCountryCodeHasPriority =
6430 pConfig->fSupplicantCountryCodeHasPriority;
6431 smeConfig->csrConfig.bCatRssiOffset = pConfig->nRssiCatGap;
6432 smeConfig->csrConfig.vccRssiThreshold = pConfig->nVccRssiTrigger;
6433 smeConfig->csrConfig.vccUlMacLossThreshold =
6434 pConfig->nVccUlMacLossThreshold;
6435 smeConfig->csrConfig.nRoamingTime = pConfig->nRoamingTime;
6436 smeConfig->csrConfig.nInitialDwellTime = pConfig->nInitialDwellTime;
6437 smeConfig->csrConfig.initial_scan_no_dfs_chnl =
6438 pConfig->initial_scan_no_dfs_chnl;
6439 smeConfig->csrConfig.nActiveMaxChnTime = pConfig->nActiveMaxChnTime;
6440 smeConfig->csrConfig.nActiveMinChnTime = pConfig->nActiveMinChnTime;
6441 smeConfig->csrConfig.nPassiveMaxChnTime = pConfig->nPassiveMaxChnTime;
6442 smeConfig->csrConfig.nPassiveMinChnTime = pConfig->nPassiveMinChnTime;
6443#ifdef WLAN_AP_STA_CONCURRENCY
6444 smeConfig->csrConfig.nActiveMaxChnTimeConc =
6445 pConfig->nActiveMaxChnTimeConc;
6446 smeConfig->csrConfig.nActiveMinChnTimeConc =
6447 pConfig->nActiveMinChnTimeConc;
6448 smeConfig->csrConfig.nPassiveMaxChnTimeConc =
6449 pConfig->nPassiveMaxChnTimeConc;
6450 smeConfig->csrConfig.nPassiveMinChnTimeConc =
6451 pConfig->nPassiveMinChnTimeConc;
6452 smeConfig->csrConfig.nRestTimeConc = pConfig->nRestTimeConc;
6453 smeConfig->csrConfig.nNumStaChanCombinedConc =
6454 pConfig->nNumStaChanCombinedConc;
6455 smeConfig->csrConfig.nNumP2PChanCombinedConc =
6456 pConfig->nNumP2PChanCombinedConc;
6457
6458#endif
6459 smeConfig->csrConfig.Is11eSupportEnabled = pConfig->b80211eIsEnabled;
6460 smeConfig->csrConfig.WMMSupportMode = pConfig->WmmMode;
6461
6462#if defined WLAN_FEATURE_VOWIFI
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006463 smeConfig->rrmConfig.rrm_enabled = pConfig->fRrmEnable;
6464 smeConfig->rrmConfig.max_randn_interval = pConfig->nRrmRandnIntvl;
6465 hdd_hex_string_to_u8_array(pConfig->rm_capability,
6466 smeConfig->rrmConfig.rm_capability, &rrm_capab_len,
6467 DOT11F_IE_RRMENABLEDCAP_MAX_LEN);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006468#endif
6469 /* Remaining config params not obtained from registry
6470 * On RF EVB beacon using channel 1.
6471 */
6472#ifdef WLAN_FEATURE_11AC
6473 smeConfig->csrConfig.nVhtChannelWidth = pConfig->vhtChannelWidth;
6474 smeConfig->csrConfig.enableTxBF = pConfig->enableTxBF;
Kiran Kumar Lokere5302ab62015-12-16 16:03:16 -08006475 smeConfig->csrConfig.enable_txbf_sap_mode =
6476 pConfig->enable_txbf_sap_mode;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006477 smeConfig->csrConfig.txBFCsnValue = pConfig->txBFCsnValue;
6478 smeConfig->csrConfig.enable2x2 = pConfig->enable2x2;
6479 smeConfig->csrConfig.enableVhtFor24GHz = pConfig->enableVhtFor24GHzBand;
6480 smeConfig->csrConfig.enableMuBformee = pConfig->enableMuBformee;
6481 smeConfig->csrConfig.enableVhtpAid = pConfig->enableVhtpAid;
6482 smeConfig->csrConfig.enableVhtGid = pConfig->enableVhtGid;
6483#endif
6484 smeConfig->csrConfig.enableAmpduPs = pConfig->enableAmpduPs;
6485 smeConfig->csrConfig.enableHtSmps = pConfig->enableHtSmps;
6486 smeConfig->csrConfig.htSmps = pConfig->htSmps;
6487 smeConfig->csrConfig.AdHocChannel5G = pConfig->AdHocChannel5G;
6488 smeConfig->csrConfig.AdHocChannel24 = pConfig->AdHocChannel24G;
6489 smeConfig->csrConfig.ProprietaryRatesEnabled = 0;
6490 smeConfig->csrConfig.HeartbeatThresh50 = 40;
6491 smeConfig->csrConfig.bandCapability = pConfig->nBandCapability;
6492 if (pConfig->nBandCapability == eCSR_BAND_24) {
6493 smeConfig->csrConfig.Is11hSupportEnabled = 0;
6494 } else {
6495 smeConfig->csrConfig.Is11hSupportEnabled =
6496 pConfig->Is11hSupportEnabled;
6497 }
6498 smeConfig->csrConfig.cbChoice = 0;
6499 smeConfig->csrConfig.eBand = pConfig->nBandCapability;
6500 smeConfig->csrConfig.nTxPowerCap = pConfig->nTxPowerCap;
6501 smeConfig->csrConfig.fEnableBypass11d = pConfig->enableBypass11d;
6502 smeConfig->csrConfig.fEnableDFSChnlScan = pConfig->enableDFSChnlScan;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006503 smeConfig->csrConfig.nRoamPrefer5GHz = pConfig->nRoamPrefer5GHz;
6504 smeConfig->csrConfig.nRoamIntraBand = pConfig->nRoamIntraBand;
6505 smeConfig->csrConfig.nProbes = pConfig->nProbes;
6506
6507 smeConfig->csrConfig.nRoamScanHomeAwayTime =
6508 pConfig->nRoamScanHomeAwayTime;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006509 smeConfig->csrConfig.fFirstScanOnly2GChnl =
6510 pConfig->enableFirstScan2GOnly;
6511
Peng Xuf5d60c82015-10-02 17:17:03 -07006512 smeConfig->csrConfig.Csr11dinfo.Channels.numChannels = 0;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006513
6514 hdd_set_power_save_offload_config(pHddCtx);
6515
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006516 smeConfig->csrConfig.csr11rConfig.IsFTResourceReqSupported =
6517 pConfig->fFTResourceReqSupported;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006518 smeConfig->csrConfig.isFastRoamIniFeatureEnabled =
6519 pConfig->isFastRoamIniFeatureEnabled;
6520 smeConfig->csrConfig.MAWCEnabled = pConfig->MAWCEnabled;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006521#ifdef FEATURE_WLAN_ESE
6522 smeConfig->csrConfig.isEseIniFeatureEnabled =
6523 pConfig->isEseIniFeatureEnabled;
6524 if (pConfig->isEseIniFeatureEnabled) {
6525 pConfig->isFastTransitionEnabled = true;
6526 }
6527#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006528 smeConfig->csrConfig.isFastTransitionEnabled =
6529 pConfig->isFastTransitionEnabled;
6530 smeConfig->csrConfig.RoamRssiDiff = pConfig->RoamRssiDiff;
6531 smeConfig->csrConfig.isWESModeEnabled = pConfig->isWESModeEnabled;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006532 smeConfig->csrConfig.isRoamOffloadScanEnabled =
6533 pConfig->isRoamOffloadScanEnabled;
6534 smeConfig->csrConfig.bFastRoamInConIniFeatureEnabled =
6535 pConfig->bFastRoamInConIniFeatureEnabled;
6536
6537 if (0 == smeConfig->csrConfig.isRoamOffloadScanEnabled) {
6538 /* Disable roaming in concurrency if roam scan offload is disabled */
6539 smeConfig->csrConfig.bFastRoamInConIniFeatureEnabled = 0;
6540 }
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006541 smeConfig->csrConfig.neighborRoamConfig.nNeighborLookupRssiThreshold =
6542 pConfig->nNeighborLookupRssiThreshold;
6543 smeConfig->csrConfig.neighborRoamConfig.delay_before_vdev_stop =
6544 pConfig->delay_before_vdev_stop;
6545 smeConfig->csrConfig.neighborRoamConfig.nOpportunisticThresholdDiff =
6546 pConfig->nOpportunisticThresholdDiff;
6547 smeConfig->csrConfig.neighborRoamConfig.nRoamRescanRssiDiff =
6548 pConfig->nRoamRescanRssiDiff;
6549 smeConfig->csrConfig.neighborRoamConfig.nNeighborScanMaxChanTime =
6550 pConfig->nNeighborScanMaxChanTime;
6551 smeConfig->csrConfig.neighborRoamConfig.nNeighborScanMinChanTime =
6552 pConfig->nNeighborScanMinChanTime;
6553 smeConfig->csrConfig.neighborRoamConfig.nNeighborScanTimerPeriod =
6554 pConfig->nNeighborScanPeriod;
6555 smeConfig->csrConfig.neighborRoamConfig.nMaxNeighborRetries =
6556 pConfig->nMaxNeighborReqTries;
6557 smeConfig->csrConfig.neighborRoamConfig.nNeighborResultsRefreshPeriod =
6558 pConfig->nNeighborResultsRefreshPeriod;
6559 smeConfig->csrConfig.neighborRoamConfig.nEmptyScanRefreshPeriod =
6560 pConfig->nEmptyScanRefreshPeriod;
6561 hdd_string_to_u8_array(pConfig->neighborScanChanList,
6562 smeConfig->csrConfig.neighborRoamConfig.
6563 neighborScanChanList.channelList,
6564 &smeConfig->csrConfig.neighborRoamConfig.
6565 neighborScanChanList.numChannels,
6566 WNI_CFG_VALID_CHANNEL_LIST_LEN);
6567 smeConfig->csrConfig.neighborRoamConfig.nRoamBmissFirstBcnt =
6568 pConfig->nRoamBmissFirstBcnt;
6569 smeConfig->csrConfig.neighborRoamConfig.nRoamBmissFinalBcnt =
6570 pConfig->nRoamBmissFinalBcnt;
6571 smeConfig->csrConfig.neighborRoamConfig.nRoamBeaconRssiWeight =
6572 pConfig->nRoamBeaconRssiWeight;
6573 smeConfig->csrConfig.neighborRoamConfig.nhi_rssi_scan_max_count =
6574 pConfig->nhi_rssi_scan_max_count;
6575 smeConfig->csrConfig.neighborRoamConfig.nhi_rssi_scan_rssi_delta =
6576 pConfig->nhi_rssi_scan_rssi_delta;
6577 smeConfig->csrConfig.neighborRoamConfig.nhi_rssi_scan_delay =
6578 pConfig->nhi_rssi_scan_delay;
6579 smeConfig->csrConfig.neighborRoamConfig.nhi_rssi_scan_rssi_ub =
6580 pConfig->nhi_rssi_scan_rssi_ub;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006581 smeConfig->csrConfig.addTSWhenACMIsOff = pConfig->AddTSWhenACMIsOff;
6582 smeConfig->csrConfig.fValidateList = pConfig->fValidateScanList;
6583 smeConfig->csrConfig.allowDFSChannelRoam = pConfig->allowDFSChannelRoam;
6584
6585 /* Enable/Disable MCC */
6586 smeConfig->csrConfig.fEnableMCCMode = pConfig->enableMCC;
6587 smeConfig->csrConfig.mcc_rts_cts_prot_enable =
6588 pConfig->mcc_rts_cts_prot_enable;
6589 smeConfig->csrConfig.mcc_bcast_prob_resp_enable =
6590 pConfig->mcc_bcast_prob_resp_enable;
6591 smeConfig->csrConfig.fAllowMCCGODiffBI = pConfig->allowMCCGODiffBI;
6592
6593 /* Scan Results Aging Time out value */
6594 smeConfig->csrConfig.scanCfgAgingTime = pConfig->scanAgingTimeout;
6595
6596 smeConfig->csrConfig.enableTxLdpc = pConfig->enableTxLdpc;
6597#ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
6598 smeConfig->csrConfig.cc_switch_mode = pConfig->WlanMccToSccSwitchMode;
6599#endif
6600
6601 smeConfig->csrConfig.isAmsduSupportInAMPDU =
6602 pConfig->isAmsduSupportInAMPDU;
6603 smeConfig->csrConfig.nSelect5GHzMargin = pConfig->nSelect5GHzMargin;
6604
6605 smeConfig->csrConfig.isCoalesingInIBSSAllowed =
6606 pHddCtx->config->isCoalesingInIBSSAllowed;
6607 smeConfig->csrConfig.ignore_peer_erp_info =
6608 pConfig->ignore_peer_erp_info;
6609 /* update SSR config */
6610 sme_update_enable_ssr((tHalHandle) (pHddCtx->hHal),
6611 pHddCtx->config->enableSSR);
6612
6613#ifdef FEATURE_WLAN_SCAN_PNO
6614 /* Update PNO offoad status */
Krunal Soni1878d3a2016-01-14 13:00:44 -08006615 smeConfig->csrConfig.pnoOffload = pHddCtx->config->PnoOffload;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006616#endif
6617
6618 /* Update maximum interfaces information */
Krunal Soni1878d3a2016-01-14 13:00:44 -08006619 smeConfig->csrConfig.max_intf_count = pHddCtx->max_intf_count;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006620
Krunal Soni1878d3a2016-01-14 13:00:44 -08006621 smeConfig->csrConfig.fEnableDebugLog = pHddCtx->config->gEnableDebugLog;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006622
Krunal Soni1878d3a2016-01-14 13:00:44 -08006623 smeConfig->csrConfig.enable5gEBT = pHddCtx->config->enable5gEBT;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006624
Krunal Soni1878d3a2016-01-14 13:00:44 -08006625 smeConfig->csrConfig.enableSelfRecovery =
6626 pHddCtx->config->enableSelfRecovery;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006627#ifdef WLAN_FEATURE_ROAM_OFFLOAD
6628 smeConfig->csrConfig.isRoamOffloadEnabled =
6629 pHddCtx->config->isRoamOffloadEnabled;
6630#endif
6631 smeConfig->csrConfig.conc_custom_rule1 =
6632 pHddCtx->config->conc_custom_rule1;
6633 smeConfig->csrConfig.conc_custom_rule2 =
6634 pHddCtx->config->conc_custom_rule2;
6635 smeConfig->csrConfig.is_sta_connection_in_5gz_enabled =
6636 pHddCtx->config->is_sta_connection_in_5gz_enabled;
6637
Krunal Soni1878d3a2016-01-14 13:00:44 -08006638 smeConfig->csrConfig.f_sta_miracast_mcc_rest_time_val =
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006639 pHddCtx->config->sta_miracast_mcc_rest_time_val;
6640
6641#ifdef FEATURE_AP_MCC_CH_AVOIDANCE
Krunal Soni1878d3a2016-01-14 13:00:44 -08006642 smeConfig->csrConfig.sap_channel_avoidance =
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006643 pHddCtx->config->sap_channel_avoidance;
6644#endif /* FEATURE_AP_MCC_CH_AVOIDANCE */
6645
Krunal Soni1878d3a2016-01-14 13:00:44 -08006646 smeConfig->csrConfig.f_prefer_non_dfs_on_radar =
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006647 pHddCtx->config->prefer_non_dfs_on_radar;
6648
Krunal Soni1878d3a2016-01-14 13:00:44 -08006649 smeConfig->csrConfig.is_ps_enabled = pHddCtx->config->is_ps_enabled;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006650 hdd_set_fine_time_meas_cap(pHddCtx, smeConfig);
6651
6652 cds_set_multicast_logging(pHddCtx->config->multicast_host_fw_msgs);
6653
6654 smeConfig->csrConfig.sendDeauthBeforeCon = pConfig->sendDeauthBeforeCon;
6655
Krunal Soni1878d3a2016-01-14 13:00:44 -08006656 smeConfig->csrConfig.policy_manager_enabled =
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006657 pHddCtx->config->policy_manager_enabled;
6658 smeConfig->csrConfig.max_scan_count =
6659 pHddCtx->config->max_scan_count;
6660
6661 /* Update 802.11p config */
6662 smeConfig->csrConfig.enable_dot11p =
6663 (pHddCtx->config->dot11p_mode != WLAN_HDD_11P_DISABLED);
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006664 hdd_set_pno_channel_prediction_config(smeConfig, pHddCtx);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006665
Krunal Soni1878d3a2016-01-14 13:00:44 -08006666 smeConfig->csrConfig.early_stop_scan_enable =
Varun Reddy Yeturu05186292015-09-28 17:12:33 -07006667 pHddCtx->config->early_stop_scan_enable;
Krunal Soni1878d3a2016-01-14 13:00:44 -08006668 smeConfig->csrConfig.early_stop_scan_min_threshold =
Varun Reddy Yeturu05186292015-09-28 17:12:33 -07006669 pHddCtx->config->early_stop_scan_min_threshold;
Krunal Soni1878d3a2016-01-14 13:00:44 -08006670 smeConfig->csrConfig.early_stop_scan_max_threshold =
Varun Reddy Yeturu05186292015-09-28 17:12:33 -07006671 pHddCtx->config->early_stop_scan_max_threshold;
Varun Reddy Yeturu044bda22015-11-21 22:03:40 -08006672 smeConfig->csrConfig.first_scan_bucket_threshold =
6673 pHddCtx->config->first_scan_bucket_threshold;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006674 status = sme_update_config(pHddCtx->hHal, smeConfig);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306675 if (!QDF_IS_STATUS_SUCCESS(status)) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006676 hddLog(LOGE, "sme_update_config() return failure %d",
6677 status);
6678 }
6679
6680 cdf_mem_free(smeConfig);
6681 return status;
6682}
6683
6684/**
6685 * hdd_execute_global_config_command() - execute the global config command
6686 * @pHddCtx: the pointer to hdd context
6687 * @command: the command to run
6688 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306689 * Return: the QDF_STATUS return from hdd_execute_config_command
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006690 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306691QDF_STATUS hdd_execute_global_config_command(hdd_context_t *pHddCtx,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006692 char *command)
6693{
6694 return hdd_execute_config_command(g_registry_table,
6695 ARRAY_SIZE(g_registry_table),
6696 (uint8_t *) pHddCtx->config,
6697 pHddCtx, command);
6698}
6699
6700/**
6701 * hdd_cfg_get_global_config() - get the configuration table
6702 * @pHddCtx: pointer to hdd context
6703 * @pBuf: buffer to store the configuration
6704 * @buflen: size of the buffer
6705 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306706 * Return: QDF_STATUS_SUCCESS if the configuration and buffer size can carry
6707 * the content, otherwise QDF_STATUS_E_RESOURCES
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006708 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306709QDF_STATUS hdd_cfg_get_global_config(hdd_context_t *pHddCtx, char *pBuf,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006710 int buflen)
6711{
6712 return hdd_cfg_get_config(g_registry_table,
6713 ARRAY_SIZE(g_registry_table),
6714 (uint8_t *) pHddCtx->config, pHddCtx, pBuf,
6715 buflen);
6716}
6717
6718/**
6719 * hdd_is_okc_mode_enabled() - returns whether OKC mode is enabled or not
6720 * @pHddCtx: the pointer to hdd context
6721 *
6722 * Return: true if OKC is enabled, otherwise false
6723 */
6724bool hdd_is_okc_mode_enabled(hdd_context_t *pHddCtx)
6725{
6726 if (NULL == pHddCtx) {
6727 hddLog(CDF_TRACE_LEVEL_FATAL, "%s: pHddCtx is NULL", __func__);
6728 return -EINVAL;
6729 }
6730#ifdef FEATURE_WLAN_OKC
6731 return pHddCtx->config->isOkcIniFeatureEnabled;
6732#else
6733 return false;
6734#endif
6735}
6736
6737/**
6738 * hdd_update_nss() - Update the number of spatial streams supported.
6739 * Ensure that nss is either 1 or 2 before calling this.
6740 *
6741 * @hdd_ctx: the pointer to hdd context
6742 * @nss: the number of spatial streams to be updated
6743 *
6744 * This function is used to modify the number of spatial streams
6745 * supported when not in connected state.
6746 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306747 * Return: QDF_STATUS_SUCCESS if nss is correctly updated,
6748 * otherwise QDF_STATUS_E_FAILURE would be returned
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006749 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306750QDF_STATUS hdd_update_nss(hdd_context_t *hdd_ctx, uint8_t nss)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006751{
6752 struct hdd_config *hdd_config = hdd_ctx->config;
6753 uint32_t temp = 0;
6754 uint32_t rx_supp_data_rate, tx_supp_data_rate;
6755 bool status = true;
6756 tSirMacHTCapabilityInfo *ht_cap_info;
6757 uint8_t mcs_set[SIZE_OF_SUPPORTED_MCS_SET] = {0};
6758 uint8_t mcs_set_temp[SIZE_OF_SUPPORTED_MCS_SET];
6759 uint32_t val;
6760 uint16_t val16;
6761 uint8_t enable2x2;
6762
6763 if ((nss == 2) && (hdd_ctx->num_rf_chains != 2)) {
6764 hddLog(LOGE, "No support for 2 spatial streams");
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306765 return QDF_STATUS_E_INVAL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006766 }
6767
6768 enable2x2 = (nss == 1) ? 0 : 1;
6769
6770 if (hdd_config->enable2x2 == enable2x2) {
6771 hddLog(LOGE, "NSS same as requested");
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306772 return QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006773 }
6774
6775 if (true == sme_is_any_session_in_connected_state(hdd_ctx->hHal)) {
6776 hddLog(LOGE, "Connected sessions present, Do not change NSS");
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306777 return QDF_STATUS_E_INVAL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006778 }
6779
6780 hdd_config->enable2x2 = enable2x2;
6781
6782 if (!hdd_config->enable2x2) {
6783 /* 1x1 */
6784 rx_supp_data_rate = HDD_VHT_RX_HIGHEST_SUPPORTED_DATA_RATE_1_1;
6785 tx_supp_data_rate = HDD_VHT_TX_HIGHEST_SUPPORTED_DATA_RATE_1_1;
6786 } else {
6787 /* 2x2 */
6788 rx_supp_data_rate = HDD_VHT_RX_HIGHEST_SUPPORTED_DATA_RATE_2_2;
6789 tx_supp_data_rate = HDD_VHT_TX_HIGHEST_SUPPORTED_DATA_RATE_2_2;
6790 }
6791
6792 /* Update Rx Highest Long GI data Rate */
6793 if (sme_cfg_set_int(hdd_ctx->hHal,
6794 WNI_CFG_VHT_RX_HIGHEST_SUPPORTED_DATA_RATE,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306795 rx_supp_data_rate) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006796 status = false;
6797 hddLog(LOGE,
6798 "Could not pass on WNI_CFG_VHT_RX_HIGHEST_SUPPORTED_DATA_RATE to CFG");
6799 }
6800
6801 /* Update Tx Highest Long GI data Rate */
6802 if (sme_cfg_set_int(hdd_ctx->hHal,
6803 WNI_CFG_VHT_TX_HIGHEST_SUPPORTED_DATA_RATE,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306804 tx_supp_data_rate) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006805 status = false;
6806 hddLog(LOGE,
6807 "Could not pass on WNI_CFG_VHT_TX_HIGHEST_SUPPORTED_DATA_RATE to CFG");
6808 }
6809
6810 sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_HT_CAP_INFO, &temp);
6811 val16 = (uint16_t)temp;
6812 ht_cap_info = (tSirMacHTCapabilityInfo *)&val16;
6813 if (!(hdd_ctx->ht_tx_stbc_supported && hdd_config->enable2x2))
6814 ht_cap_info->txSTBC = 0;
6815 else
6816 ht_cap_info->txSTBC = hdd_config->enableTxSTBC;
6817 temp = val16;
6818 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_HT_CAP_INFO,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306819 temp) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006820 status = false;
6821 hddLog(LOGE, "Could not pass on WNI_CFG_HT_CAP_INFO to CFG");
6822 }
6823
6824 sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_VHT_BASIC_MCS_SET, &temp);
6825 temp = (temp & 0xFFFC) | hdd_config->vhtRxMCS;
6826 if (hdd_config->enable2x2)
6827 temp = (temp & 0xFFF3) | (hdd_config->vhtRxMCS2x2 << 2);
6828 else
6829 temp |= 0x000C;
6830
6831 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_BASIC_MCS_SET,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306832 temp) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006833 status = false;
6834 hddLog(LOGE,
6835 "Could not pass on WNI_CFG_VHT_BASIC_MCS_SET to CFG");
6836 }
6837
6838 sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_VHT_RX_MCS_MAP, &temp);
6839 temp = (temp & 0xFFFC) | hdd_config->vhtRxMCS;
6840 if (hdd_config->enable2x2)
6841 temp = (temp & 0xFFF3) | (hdd_config->vhtRxMCS2x2 << 2);
6842 else
6843 temp |= 0x000C;
6844
6845 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_RX_MCS_MAP,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306846 temp) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006847 status = false;
6848 hddLog(LOGE, "Could not pass on WNI_CFG_VHT_RX_MCS_MAP to CFG");
6849 }
6850
6851 sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_VHT_TX_MCS_MAP, &temp);
6852 temp = (temp & 0xFFFC) | hdd_config->vhtTxMCS;
6853 if (hdd_config->enable2x2)
6854 temp = (temp & 0xFFF3) | (hdd_config->vhtTxMCS2x2 << 2);
6855 else
6856 temp |= 0x000C;
6857
6858 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_TX_MCS_MAP,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306859 temp) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006860 status = false;
6861 hddLog(LOGE, "Could not pass on WNI_CFG_VHT_TX_MCS_MAP to CFG");
6862 }
6863
6864#define WLAN_HDD_RX_MCS_ALL_NSTREAM_RATES 0xff
6865 val = SIZE_OF_SUPPORTED_MCS_SET;
6866 sme_cfg_get_str(hdd_ctx->hHal, WNI_CFG_SUPPORTED_MCS_SET,
6867 mcs_set_temp, &val);
6868
6869 mcs_set[0] = mcs_set_temp[0];
6870 if (hdd_config->enable2x2)
6871 for (val = 0; val < nss; val++)
6872 mcs_set[val] = WLAN_HDD_RX_MCS_ALL_NSTREAM_RATES;
6873
6874 if (sme_cfg_set_str(hdd_ctx->hHal, WNI_CFG_SUPPORTED_MCS_SET,
6875 mcs_set,
6876 SIZE_OF_SUPPORTED_MCS_SET) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306877 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006878 status = false;
6879 hddLog(LOGE, "Could not pass on MCS SET to CFG");
6880 }
6881#undef WLAN_HDD_RX_MCS_ALL_NSTREAM_RATES
6882
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306883 if (QDF_STATUS_SUCCESS != sme_update_nss(hdd_ctx->hHal, nss))
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006884 status = false;
6885
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306886 return (status == false) ? QDF_STATUS_E_FAILURE : QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006887}