blob: 4ad684334918b0b696fb9241037719d865784669 [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>
Anurag Chouhan6d760662016-02-20 16:05:43 +053043#include <qdf_types.h>
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080044#include <csr_api.h>
45#include <wlan_hdd_misc.h>
46#include <wlan_hdd_napi.h>
Manjunathappa Prakash59f861d2016-04-21 10:33:31 -070047#include <cds_concurrency.h>
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080048
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080049static void
50cb_notify_set_roam_prefer5_g_hz(hdd_context_t *pHddCtx, unsigned long notifyId)
51{
52 sme_update_roam_prefer5_g_hz(pHddCtx->hHal,
53 pHddCtx->config->nRoamPrefer5GHz);
54}
55
56static void
57cb_notify_set_roam_rssi_diff(hdd_context_t *pHddCtx, unsigned long notifyId)
58{
59 sme_update_roam_rssi_diff(pHddCtx->hHal,
60 0, pHddCtx->config->RoamRssiDiff);
61}
62
63static void
64cb_notify_set_fast_transition_enabled(hdd_context_t *pHddCtx,
65 unsigned long notifyId)
66{
67 sme_update_fast_transition_enabled(pHddCtx->hHal,
68 pHddCtx->config->
69 isFastTransitionEnabled);
70}
71
72static void
73cb_notify_set_roam_intra_band(hdd_context_t *pHddCtx, unsigned long notifyId)
74{
75 sme_set_roam_intra_band(pHddCtx->hHal, pHddCtx->config->nRoamIntraBand);
76}
77
78static void cb_notify_set_wes_mode(hdd_context_t *pHddCtx, unsigned long notifyId)
79{
80 /* At the point this routine is called, the value in the hdd config
81 table has already been updated */
82 sme_update_wes_mode(pHddCtx->hHal, pHddCtx->config->isWESModeEnabled, 0);
83}
84
85static void
86cb_notify_set_roam_scan_n_probes(hdd_context_t *pHddCtx, unsigned long notifyId)
87{
88 sme_update_roam_scan_n_probes(pHddCtx->hHal, 0, pHddCtx->config->nProbes);
89}
90
91static void
92cb_notify_set_roam_scan_home_away_time(hdd_context_t *pHddCtx, unsigned long notifyId)
93{
94 sme_update_roam_scan_home_away_time(pHddCtx->hHal, 0,
95 pHddCtx->config->nRoamScanHomeAwayTime,
96 true);
97}
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080098
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080099static void
100notify_is_fast_roam_ini_feature_enabled(hdd_context_t *pHddCtx,
101 unsigned long notifyId)
102{
103 /* At the point this routine is called, the value in the hdd config
104 table has already been updated */
105 sme_update_is_fast_roam_ini_feature_enabled(pHddCtx->hHal, 0,
106 pHddCtx->config->
107 isFastRoamIniFeatureEnabled);
108}
109
110static void
111notify_is_mawc_ini_feature_enabled(hdd_context_t *pHddCtx, unsigned long notifyId)
112{
113 /* At the point this routine is called, the value in the hdd config
114 table has already been updated */
115 sme_update_is_mawc_ini_feature_enabled(pHddCtx->hHal,
116 pHddCtx->config->MAWCEnabled);
117}
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800118
119#ifdef FEATURE_WLAN_ESE
120static void
121cb_notify_set_ese_feature_enabled(hdd_context_t *pHddCtx, unsigned long notifyId)
122{
123 /* At the point this routine is called, the value in the hdd config
124 table has already been updated */
125 sme_update_is_ese_feature_enabled(pHddCtx->hHal, 0,
126 pHddCtx->config->isEseIniFeatureEnabled);
127}
128#endif
129
130static void
131cb_notify_set_fw_rssi_monitoring(hdd_context_t *pHddCtx, unsigned long notifyId)
132{
133 /* At the point this routine is called, the value in the hdd config
134 table has already been updated */
135 sme_update_config_fw_rssi_monitoring(pHddCtx->hHal,
136 pHddCtx->config->
137 fEnableFwRssiMonitoring);
138}
139
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800140static void cb_notify_set_opportunistic_scan_threshold_diff(hdd_context_t *pHddCtx,
141 unsigned long notifyId)
142{
143 /* At the point this routine is called, the value in the hdd config
144 table has already been updated */
145 sme_set_roam_opportunistic_scan_threshold_diff(pHddCtx->hHal, 0,
146 pHddCtx->config->
147 nOpportunisticThresholdDiff);
148}
149
150static void cb_notify_set_roam_rescan_rssi_diff(hdd_context_t *pHddCtx,
151 unsigned long notifyId)
152{
153 /* At the point this routine is called, the value in the hdd config
154 table has already been updated */
155 sme_set_roam_rescan_rssi_diff(pHddCtx->hHal,
156 0, pHddCtx->config->nRoamRescanRssiDiff);
157}
158
159static void
160cb_notify_set_neighbor_lookup_rssi_threshold(hdd_context_t *pHddCtx,
161 unsigned long notifyId)
162{
163 /* At the point this routine is called, the value in the hdd config
164 table has already been updated */
165 sme_set_neighbor_lookup_rssi_threshold(pHddCtx->hHal, 0,
166 pHddCtx->config->
167 nNeighborLookupRssiThreshold);
168}
169
170static void
171cb_notify_set_delay_before_vdev_stop(hdd_context_t *hdd_ctx,
172 unsigned long notify_id)
173{
174 /*
175 * At the point this routine is called, the value in the cfg_ini
176 * table has already been updated
177 */
178 sme_set_delay_before_vdev_stop(hdd_ctx->hHal, 0,
179 hdd_ctx->config->delay_before_vdev_stop);
180}
181
182static void
183cb_notify_set_neighbor_scan_period(hdd_context_t *pHddCtx, unsigned long notifyId)
184{
185 /* At the point this routine is called, the value in the hdd config
186 table has already been updated */
187 sme_set_neighbor_scan_period(pHddCtx->hHal, 0,
188 pHddCtx->config->nNeighborScanPeriod);
189}
190
191static void
192cb_notify_set_neighbor_results_refresh_period(hdd_context_t *pHddCtx,
193 unsigned long notifyId)
194{
195 /* At the point this routine is called, the value in the hdd config
196 table has already been updated */
197 sme_set_neighbor_scan_refresh_period(pHddCtx->hHal, 0,
198 pHddCtx->config->
199 nNeighborResultsRefreshPeriod);
200}
201
202static void
203cb_notify_set_empty_scan_refresh_period(hdd_context_t *pHddCtx,
204 unsigned long notifyId)
205{
206 /* At the point this routine is called, the value in the hdd config
207 table has already been updated */
208 sme_update_empty_scan_refresh_period(pHddCtx->hHal, 0,
209 pHddCtx->config->
210 nEmptyScanRefreshPeriod);
211}
212
213static void
214cb_notify_set_neighbor_scan_min_chan_time(hdd_context_t *pHddCtx,
215 unsigned long notifyId)
216{
217 /* At the point this routine is called, the value in the hdd config
218 table has already been updated */
219 sme_set_neighbor_scan_min_chan_time(pHddCtx->hHal,
220 pHddCtx->config->
221 nNeighborScanMinChanTime, 0);
222}
223
224static void
225cb_notify_set_neighbor_scan_max_chan_time(hdd_context_t *pHddCtx,
226 unsigned long notifyId)
227{
228 sme_set_neighbor_scan_max_chan_time(pHddCtx->hHal, 0,
229 pHddCtx->config->
230 nNeighborScanMaxChanTime);
231}
232
233static void cb_notify_set_roam_bmiss_first_bcnt(hdd_context_t *pHddCtx,
234 unsigned long notifyId)
235{
236 /* At the point this routine is called, the value in the hdd config
237 table has already been updated */
238 sme_set_roam_bmiss_first_bcnt(pHddCtx->hHal,
239 0, pHddCtx->config->nRoamBmissFirstBcnt);
240}
241
242static void cb_notify_set_roam_bmiss_final_bcnt(hdd_context_t *pHddCtx,
243 unsigned long notifyId)
244{
245 sme_set_roam_bmiss_final_bcnt(pHddCtx->hHal, 0,
246 pHddCtx->config->nRoamBmissFinalBcnt);
247}
248
249static void cb_notify_set_roam_beacon_rssi_weight(hdd_context_t *pHddCtx,
250 unsigned long notifyId)
251{
252 sme_set_roam_beacon_rssi_weight(pHddCtx->hHal, 0,
253 pHddCtx->config->nRoamBeaconRssiWeight);
254}
255
256static void
257cb_notify_set_dfs_scan_mode(hdd_context_t *pHddCtx, unsigned long notifyId)
258{
259 /* At the point this routine is called, the value in the hdd config
260 table has already been updated */
261 sme_update_dfs_scan_mode(pHddCtx->hHal, 0,
262 pHddCtx->config->allowDFSChannelRoam);
263}
264
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800265static void cb_notify_set_enable_ssr(hdd_context_t *pHddCtx,
266 unsigned long notifyId)
267{
268 sme_update_enable_ssr(pHddCtx->hHal, pHddCtx->config->enableSSR);
269}
270
271static void cb_notify_set_g_sap_preferred_chan_location(hdd_context_t *pHddCtx,
272 unsigned long notifyId)
273{
274 wlansap_set_dfs_preferred_channel_location(pHddCtx->hHal,
275 pHddCtx->config->
276 gSapPreferredChanLocation);
277}
278static void ch_notify_set_g_disable_dfs_japan_w53(hdd_context_t *pHddCtx,
279 unsigned long notifyId)
280{
281 wlansap_set_dfs_restrict_japan_w53(pHddCtx->hHal,
282 pHddCtx->config->
283 gDisableDfsJapanW53);
284}
285static void
286cb_notify_update_roam_scan_offload_enabled(hdd_context_t *pHddCtx,
287 unsigned long notifyId)
288{
289 sme_update_roam_scan_offload_enabled(pHddCtx->hHal,
290 pHddCtx->config->
291 isRoamOffloadScanEnabled);
292 if (0 == pHddCtx->config->isRoamOffloadScanEnabled) {
293 pHddCtx->config->bFastRoamInConIniFeatureEnabled = 0;
294 sme_update_enable_fast_roam_in_concurrency(pHddCtx->hHal,
295 pHddCtx->config->
296 bFastRoamInConIniFeatureEnabled);
297 }
298}
299
300static void
301cb_notify_set_enable_fast_roam_in_concurrency(hdd_context_t *pHddCtx,
302 unsigned long notifyId)
303{
304 sme_update_enable_fast_roam_in_concurrency(pHddCtx->hHal,
305 pHddCtx->config->
306 bFastRoamInConIniFeatureEnabled);
307}
308
309/**
310 * cb_notify_set_roam_scan_hi_rssi_scan_params() - configure hi rssi
311 * scan params from cfg to sme.
312 * @hdd_ctx: HDD context data structure
313 * @notify_id: Identifies 1 of the 4 parameters to be modified
314 *
315 * Picks up the value from hdd configuration and passes it to SME.
316 * Return: void
317 */
318
319static void
320cb_notify_set_roam_scan_hi_rssi_scan_params(hdd_context_t *hdd_ctx,
321 unsigned long notify_id)
322{
323 int32_t val;
324
325 if (wlan_hdd_validate_context(hdd_ctx)) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800326 return;
327 }
328
329 switch (notify_id) {
330 case eCSR_HI_RSSI_SCAN_MAXCOUNT_ID:
331 val = hdd_ctx->config->nhi_rssi_scan_max_count;
332 break;
333
334 case eCSR_HI_RSSI_SCAN_RSSI_DELTA_ID:
335 val = hdd_ctx->config->nhi_rssi_scan_rssi_delta;
336 break;
337
338 case eCSR_HI_RSSI_SCAN_DELAY_ID:
339 val = hdd_ctx->config->nhi_rssi_scan_delay;
340 break;
341
342 case eCSR_HI_RSSI_SCAN_RSSI_UB_ID:
343 val = hdd_ctx->config->nhi_rssi_scan_rssi_ub;
344 break;
345
346 default:
347 return;
348 }
349
350 sme_update_roam_scan_hi_rssi_scan_params(hdd_ctx->hHal, 0,
351 notify_id, val);
352}
353
354
355REG_TABLE_ENTRY g_registry_table[] = {
356 REG_VARIABLE(CFG_RTS_THRESHOLD_NAME, WLAN_PARAM_Integer,
357 struct hdd_config, RTSThreshold,
358 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
359 CFG_RTS_THRESHOLD_DEFAULT,
360 CFG_RTS_THRESHOLD_MIN,
361 CFG_RTS_THRESHOLD_MAX),
362
363 REG_VARIABLE(CFG_FRAG_THRESHOLD_NAME, WLAN_PARAM_Integer,
364 struct hdd_config, FragmentationThreshold,
365 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
366 CFG_FRAG_THRESHOLD_DEFAULT,
367 CFG_FRAG_THRESHOLD_MIN,
368 CFG_FRAG_THRESHOLD_MAX),
369
370 REG_VARIABLE(CFG_OPERATING_CHANNEL_NAME, WLAN_PARAM_Integer,
371 struct hdd_config, OperatingChannel,
372 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
373 CFG_OPERATING_CHANNEL_DEFAULT,
374 CFG_OPERATING_CHANNEL_MIN,
375 CFG_OPERATING_CHANNEL_MAX),
376
377 REG_VARIABLE(CFG_SHORT_SLOT_TIME_ENABLED_NAME, WLAN_PARAM_Integer,
378 struct hdd_config, ShortSlotTimeEnabled,
379 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
380 CFG_SHORT_SLOT_TIME_ENABLED_DEFAULT,
381 CFG_SHORT_SLOT_TIME_ENABLED_MIN,
382 CFG_SHORT_SLOT_TIME_ENABLED_MAX),
383
384 REG_VARIABLE(CFG_11D_SUPPORT_ENABLED_NAME, WLAN_PARAM_Integer,
385 struct hdd_config, Is11dSupportEnabled,
386 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
387 CFG_11D_SUPPORT_ENABLED_DEFAULT,
388 CFG_11D_SUPPORT_ENABLED_MIN,
389 CFG_11D_SUPPORT_ENABLED_MAX),
390
391 REG_VARIABLE(CFG_11H_SUPPORT_ENABLED_NAME, WLAN_PARAM_Integer,
392 struct hdd_config, Is11hSupportEnabled,
393 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
394 CFG_11H_SUPPORT_ENABLED_DEFAULT,
395 CFG_11H_SUPPORT_ENABLED_MIN,
396 CFG_11H_SUPPORT_ENABLED_MAX),
397
398 REG_VARIABLE(CFG_COUNTRY_CODE_PRIORITY_NAME, WLAN_PARAM_Integer,
399 struct hdd_config, fSupplicantCountryCodeHasPriority,
400 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
401 CFG_COUNTRY_CODE_PRIORITY_DEFAULT,
402 CFG_COUNTRY_CODE_PRIORITY_MIN,
403 CFG_COUNTRY_CODE_PRIORITY_MAX),
404
405 REG_VARIABLE(CFG_HEARTBEAT_THRESH_24_NAME, WLAN_PARAM_Integer,
406 struct hdd_config, HeartbeatThresh24,
407 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
408 CFG_HEARTBEAT_THRESH_24_DEFAULT,
409 CFG_HEARTBEAT_THRESH_24_MIN,
410 CFG_HEARTBEAT_THRESH_24_MAX),
411
412 REG_VARIABLE_STRING(CFG_POWER_USAGE_NAME, WLAN_PARAM_String,
413 struct hdd_config, PowerUsageControl,
414 VAR_FLAGS_OPTIONAL,
415 (void *)CFG_POWER_USAGE_DEFAULT),
416
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800417 REG_VARIABLE(CFG_ENABLE_IMPS_NAME, WLAN_PARAM_Integer,
418 struct hdd_config, fIsImpsEnabled,
419 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
420 CFG_ENABLE_IMPS_DEFAULT,
421 CFG_ENABLE_IMPS_MIN,
422 CFG_ENABLE_IMPS_MAX),
423
424 REG_VARIABLE(CFG_ENABLE_PS_NAME, WLAN_PARAM_Integer,
425 struct hdd_config, is_ps_enabled,
426 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
427 CFG_ENABLE_PS_DEFAULT,
428 CFG_ENABLE_PS_MIN,
429 CFG_ENABLE_PS_MAX),
430
431 REG_VARIABLE(CFG_BMPS_MINIMUM_LI_NAME, WLAN_PARAM_Integer,
432 struct hdd_config, nBmpsMinListenInterval,
433 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
434 CFG_BMPS_MINIMUM_LI_DEFAULT,
435 CFG_BMPS_MINIMUM_LI_MIN,
436 CFG_BMPS_MINIMUM_LI_MAX),
437
438 REG_VARIABLE(CFG_BMPS_MAXIMUM_LI_NAME, WLAN_PARAM_Integer,
439 struct hdd_config, nBmpsMaxListenInterval,
440 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
441 CFG_BMPS_MAXIMUM_LI_DEFAULT,
442 CFG_BMPS_MAXIMUM_LI_MIN,
443 CFG_BMPS_MAXIMUM_LI_MAX),
444
445 REG_VARIABLE(CFG_BMPS_MODERATE_LI_NAME, WLAN_PARAM_Integer,
446 struct hdd_config, nBmpsModListenInterval,
447 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
448 CFG_BMPS_MODERATE_LI_DEFAULT,
449 CFG_BMPS_MODERATE_LI_MIN,
450 CFG_BMPS_MODERATE_LI_MAX),
451
452 REG_VARIABLE(CFG_DOT11_MODE_NAME, WLAN_PARAM_Integer,
453 struct hdd_config, dot11Mode,
454 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
455 CFG_DOT11_MODE_DEFAULT,
456 CFG_DOT11_MODE_MIN,
457 CFG_DOT11_MODE_MAX),
458
459 REG_VARIABLE(CFG_CHANNEL_BONDING_MODE_24GHZ_NAME, WLAN_PARAM_Integer,
460 struct hdd_config, nChannelBondingMode24GHz,
461 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
462 CFG_CHANNEL_BONDING_MODE_DEFAULT,
463 CFG_CHANNEL_BONDING_MODE_MIN,
464 CFG_CHANNEL_BONDING_MODE_MAX),
465
466 REG_VARIABLE(CFG_CHANNEL_BONDING_MODE_5GHZ_NAME, WLAN_PARAM_Integer,
467 struct hdd_config, nChannelBondingMode5GHz,
468 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
469 CFG_CHANNEL_BONDING_MODE_DEFAULT,
470 CFG_CHANNEL_BONDING_MODE_MIN,
471 CFG_CHANNEL_BONDING_MODE_MAX),
472
473 REG_VARIABLE(CFG_MAX_RX_AMPDU_FACTOR_NAME, WLAN_PARAM_Integer,
474 struct hdd_config, MaxRxAmpduFactor,
475 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
476 CFG_MAX_RX_AMPDU_FACTOR_DEFAULT,
477 CFG_MAX_RX_AMPDU_FACTOR_MIN,
478 CFG_MAX_RX_AMPDU_FACTOR_MAX),
479
Krishna Kumaar Natarajan22b59a72015-11-23 18:54:58 -0800480 REG_VARIABLE(CFG_HT_MPDU_DENSITY_NAME, WLAN_PARAM_Integer,
481 struct hdd_config, ht_mpdu_density,
482 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK ,
483 CFG_HT_MPDU_DENSITY_DEFAULT,
484 CFG_HT_MPDU_DENSITY_MIN,
485 CFG_HT_MPDU_DENSITY_MAX),
486
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800487 REG_VARIABLE(CFG_FIXED_RATE_NAME, WLAN_PARAM_Integer,
488 struct hdd_config, TxRate,
489 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
490 CFG_FIXED_RATE_DEFAULT,
491 CFG_FIXED_RATE_MIN,
492 CFG_FIXED_RATE_MAX),
493
494 REG_VARIABLE(CFG_SHORT_GI_20MHZ_NAME, WLAN_PARAM_Integer,
495 struct hdd_config, ShortGI20MhzEnable,
496 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
497 CFG_SHORT_GI_20MHZ_DEFAULT,
498 CFG_SHORT_GI_20MHZ_MIN,
499 CFG_SHORT_GI_20MHZ_MAX),
500
501 REG_VARIABLE(CFG_SCAN_RESULT_AGE_COUNT_NAME, WLAN_PARAM_Integer,
502 struct hdd_config, ScanResultAgeCount,
503 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
504 CFG_SCAN_RESULT_AGE_COUNT_DEFAULT,
505 CFG_SCAN_RESULT_AGE_COUNT_MIN,
506 CFG_SCAN_RESULT_AGE_COUNT_MAX),
507
508 REG_VARIABLE(CFG_SCAN_RESULT_AGE_TIME_NCNPS_NAME, WLAN_PARAM_Integer,
509 struct hdd_config, nScanAgeTimeNCNPS,
510 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
511 CFG_SCAN_RESULT_AGE_TIME_NCNPS_DEFAULT,
512 CFG_SCAN_RESULT_AGE_TIME_NCNPS_MIN,
513 CFG_SCAN_RESULT_AGE_TIME_NCNPS_MAX),
514
515 REG_VARIABLE(CFG_SCAN_RESULT_AGE_TIME_NCPS_NAME, WLAN_PARAM_Integer,
516 struct hdd_config, nScanAgeTimeNCPS,
517 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
518 CFG_SCAN_RESULT_AGE_TIME_NCPS_DEFAULT,
519 CFG_SCAN_RESULT_AGE_TIME_NCPS_MIN,
520 CFG_SCAN_RESULT_AGE_TIME_NCPS_MAX),
521
522 REG_VARIABLE(CFG_SCAN_RESULT_AGE_TIME_CNPS_NAME, WLAN_PARAM_Integer,
523 struct hdd_config, nScanAgeTimeCNPS,
524 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
525 CFG_SCAN_RESULT_AGE_TIME_CNPS_DEFAULT,
526 CFG_SCAN_RESULT_AGE_TIME_CNPS_MIN,
527 CFG_SCAN_RESULT_AGE_TIME_CNPS_MAX),
528
529 REG_VARIABLE(CFG_SCAN_RESULT_AGE_TIME_CPS_NAME, WLAN_PARAM_Integer,
530 struct hdd_config, nScanAgeTimeCPS,
531 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
532 CFG_SCAN_RESULT_AGE_TIME_CPS_DEFAULT,
533 CFG_SCAN_RESULT_AGE_TIME_CPS_MIN,
534 CFG_SCAN_RESULT_AGE_TIME_CPS_MAX),
535
536 REG_VARIABLE(CFG_RSSI_CATEGORY_GAP_NAME, WLAN_PARAM_Integer,
537 struct hdd_config, nRssiCatGap,
538 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
539 CFG_RSSI_CATEGORY_GAP_DEFAULT,
540 CFG_RSSI_CATEGORY_GAP_MIN,
541 CFG_RSSI_CATEGORY_GAP_MAX),
542
543 REG_VARIABLE(CFG_SHORT_PREAMBLE_NAME, WLAN_PARAM_Integer,
544 struct hdd_config, fIsShortPreamble,
545 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
546 CFG_SHORT_PREAMBLE_DEFAULT,
547 CFG_SHORT_PREAMBLE_MIN,
548 CFG_SHORT_PREAMBLE_MAX),
549
550 REG_VARIABLE_STRING(CFG_IBSS_BSSID_NAME, WLAN_PARAM_MacAddr,
551 struct hdd_config, IbssBssid,
552 VAR_FLAGS_OPTIONAL,
553 (void *)CFG_IBSS_BSSID_DEFAULT),
554
555 REG_VARIABLE_STRING(CFG_INTF0_MAC_ADDR_NAME, WLAN_PARAM_MacAddr,
556 struct hdd_config, intfMacAddr[0],
557 VAR_FLAGS_OPTIONAL,
558 (void *)CFG_INTF0_MAC_ADDR_DEFAULT),
559
560 REG_VARIABLE_STRING(CFG_INTF1_MAC_ADDR_NAME, WLAN_PARAM_MacAddr,
561 struct hdd_config, intfMacAddr[1],
562 VAR_FLAGS_OPTIONAL,
563 (void *)CFG_INTF1_MAC_ADDR_DEFAULT),
564
565 REG_VARIABLE_STRING(CFG_INTF2_MAC_ADDR_NAME, WLAN_PARAM_MacAddr,
566 struct hdd_config, intfMacAddr[2],
567 VAR_FLAGS_OPTIONAL,
568 (void *)CFG_INTF2_MAC_ADDR_DEFAULT),
569
570 REG_VARIABLE_STRING(CFG_INTF3_MAC_ADDR_NAME, WLAN_PARAM_MacAddr,
571 struct hdd_config, intfMacAddr[3],
572 VAR_FLAGS_OPTIONAL,
573 (void *)CFG_INTF3_MAC_ADDR_DEFAULT),
574
575 REG_VARIABLE(CFG_AP_QOS_UAPSD_MODE_NAME, WLAN_PARAM_Integer,
576 struct hdd_config, apUapsdEnabled,
577 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
578 CFG_AP_QOS_UAPSD_MODE_DEFAULT,
579 CFG_AP_QOS_UAPSD_MODE_MIN,
580 CFG_AP_QOS_UAPSD_MODE_MAX),
581
582
583 REG_VARIABLE(CFG_AP_ENABLE_RANDOM_BSSID_NAME, WLAN_PARAM_Integer,
584 struct hdd_config, apRandomBssidEnabled,
585 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
586 CFG_AP_ENABLE_RANDOM_BSSID_DEFAULT,
587 CFG_AP_ENABLE_RANDOM_BSSID_MIN,
588 CFG_AP_ENABLE_RANDOM_BSSID_MAX),
589
590 REG_VARIABLE(CFG_AP_ENABLE_PROTECTION_MODE_NAME, WLAN_PARAM_Integer,
591 struct hdd_config, apProtEnabled,
592 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
593 CFG_AP_ENABLE_PROTECTION_MODE_DEFAULT,
594 CFG_AP_ENABLE_PROTECTION_MODE_MIN,
595 CFG_AP_ENABLE_PROTECTION_MODE_MAX),
596
597 REG_VARIABLE(CFG_AP_PROTECTION_MODE_NAME, WLAN_PARAM_HexInteger,
598 struct hdd_config, apProtection,
599 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
600 CFG_AP_PROTECTION_MODE_DEFAULT,
601 CFG_AP_PROTECTION_MODE_MIN,
602 CFG_AP_PROTECTION_MODE_MAX),
603
604 REG_VARIABLE(CFG_AP_OBSS_PROTECTION_MODE_NAME, WLAN_PARAM_Integer,
605 struct hdd_config, apOBSSProtEnabled,
606 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
607 CFG_AP_OBSS_PROTECTION_MODE_DEFAULT,
608 CFG_AP_OBSS_PROTECTION_MODE_MIN,
609 CFG_AP_OBSS_PROTECTION_MODE_MAX),
610
611 REG_VARIABLE(CFG_AP_STA_SECURITY_SEPERATION_NAME, WLAN_PARAM_Integer,
612 struct hdd_config, apDisableIntraBssFwd,
613 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
614 CFG_AP_STA_SECURITY_SEPERATION_DEFAULT,
615 CFG_AP_STA_SECURITY_SEPERATION_MIN,
616 CFG_AP_STA_SECURITY_SEPERATION_MAX),
617
618 REG_VARIABLE(CFG_ENABLE_LTE_COEX, WLAN_PARAM_Integer,
619 struct hdd_config, enableLTECoex,
620 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
621 CFG_ENABLE_LTE_COEX_DEFAULT,
622 CFG_ENABLE_LTE_COEX_MIN,
623 CFG_ENABLE_LTE_COEX_MAX),
624 REG_VARIABLE(CFG_FORCE_SAP_ACS, WLAN_PARAM_Integer,
625 struct hdd_config, force_sap_acs,
626 VAR_FLAGS_DYNAMIC_CFG |
627 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
628 CFG_FORCE_SAP_ACS_DEFAULT,
629 CFG_FORCE_SAP_ACS_MIN,
630 CFG_FORCE_SAP_ACS_MAX),
631
632 REG_VARIABLE(CFG_FORCE_SAP_ACS_START_CH, WLAN_PARAM_Integer,
633 struct hdd_config, force_sap_acs_st_ch,
634 VAR_FLAGS_DYNAMIC_CFG |
635 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
636 CFG_FORCE_SAP_ACS_START_CH_DEFAULT,
637 CFG_FORCE_SAP_ACS_START_CH_MIN,
638 CFG_FORCE_SAP_ACS_START_CH_MAX),
639
640 REG_VARIABLE(CFG_FORCE_SAP_ACS_END_CH, WLAN_PARAM_Integer,
641 struct hdd_config, force_sap_acs_end_ch,
642 VAR_FLAGS_DYNAMIC_CFG |
643 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
644 CFG_FORCE_SAP_ACS_END_CH_DEFAULT,
645 CFG_FORCE_SAP_ACS_END_CH_MIN,
646 CFG_FORCE_SAP_ACS_END_CH_MAX),
647
648 REG_VARIABLE(CFG_AP_KEEP_ALIVE_PERIOD_NAME, WLAN_PARAM_Integer,
649 struct hdd_config, apKeepAlivePeriod,
650 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
651 CFG_AP_KEEP_ALIVE_PERIOD_DEFAULT,
652 CFG_AP_KEEP_ALIVE_PERIOD_MIN,
653 CFG_AP_KEEP_ALIVE_PERIOD_MAX),
654
655 REG_VARIABLE(CFG_GO_KEEP_ALIVE_PERIOD_NAME, WLAN_PARAM_Integer,
656 struct hdd_config, goKeepAlivePeriod,
657 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
658 CFG_GO_KEEP_ALIVE_PERIOD_DEFAULT,
659 CFG_GO_KEEP_ALIVE_PERIOD_MIN,
660 CFG_GO_KEEP_ALIVE_PERIOD_MAX),
661
662 REG_VARIABLE(CFG_AP_LINK_MONITOR_PERIOD_NAME, WLAN_PARAM_Integer,
663 struct hdd_config, apLinkMonitorPeriod,
664 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
665 CFG_AP_LINK_MONITOR_PERIOD_DEFAULT,
666 CFG_AP_LINK_MONITOR_PERIOD_MIN,
667 CFG_AP_LINK_MONITOR_PERIOD_MAX),
668
669 REG_VARIABLE(CFG_GO_LINK_MONITOR_PERIOD_NAME, WLAN_PARAM_Integer,
670 struct hdd_config, goLinkMonitorPeriod,
671 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
672 CFG_GO_LINK_MONITOR_PERIOD_DEFAULT,
673 CFG_GO_LINK_MONITOR_PERIOD_MIN,
674 CFG_GO_LINK_MONITOR_PERIOD_MAX),
675
676 REG_VARIABLE(CFG_DISABLE_PACKET_FILTER, WLAN_PARAM_Integer,
677 struct hdd_config, disablePacketFilter,
678 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
679 CFG_DISABLE_PACKET_FILTER_DEFAULT,
680 CFG_DISABLE_PACKET_FILTER_MIN,
681 CFG_DISABLE_PACKET_FILTER_MAX),
682
683 REG_VARIABLE(CFG_BEACON_INTERVAL_NAME, WLAN_PARAM_Integer,
684 struct hdd_config, nBeaconInterval,
685 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
686 CFG_BEACON_INTERVAL_DEFAULT,
687 CFG_BEACON_INTERVAL_MIN,
688 CFG_BEACON_INTERVAL_MAX),
689
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800690 REG_VARIABLE(CFG_VCC_RSSI_TRIGGER_NAME, WLAN_PARAM_Integer,
691 struct hdd_config, nVccRssiTrigger,
692 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
693 CFG_VCC_RSSI_TRIGGER_DEFAULT,
694 CFG_VCC_RSSI_TRIGGER_MIN,
695 CFG_VCC_RSSI_TRIGGER_MAX),
696
697 REG_VARIABLE(CFG_VCC_UL_MAC_LOSS_THRESH_NAME, WLAN_PARAM_Integer,
698 struct hdd_config, nVccUlMacLossThreshold,
699 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
700 CFG_VCC_UL_MAC_LOSS_THRESH_DEFAULT,
701 CFG_VCC_UL_MAC_LOSS_THRESH_MIN,
702 CFG_VCC_UL_MAC_LOSS_THRESH_MAX),
703
704 REG_VARIABLE(CFG_PASSIVE_MAX_CHANNEL_TIME_NAME, WLAN_PARAM_Integer,
705 struct hdd_config, nPassiveMaxChnTime,
706 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
707 CFG_PASSIVE_MAX_CHANNEL_TIME_DEFAULT,
708 CFG_PASSIVE_MAX_CHANNEL_TIME_MIN,
709 CFG_PASSIVE_MAX_CHANNEL_TIME_MAX),
710
711 REG_VARIABLE(CFG_PASSIVE_MIN_CHANNEL_TIME_NAME, WLAN_PARAM_Integer,
712 struct hdd_config, nPassiveMinChnTime,
713 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
714 CFG_PASSIVE_MIN_CHANNEL_TIME_DEFAULT,
715 CFG_PASSIVE_MIN_CHANNEL_TIME_MIN,
716 CFG_PASSIVE_MIN_CHANNEL_TIME_MAX),
717
718 REG_VARIABLE(CFG_ACTIVE_MAX_CHANNEL_TIME_NAME, WLAN_PARAM_Integer,
719 struct hdd_config, nActiveMaxChnTime,
720 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
721 CFG_ACTIVE_MAX_CHANNEL_TIME_DEFAULT,
722 CFG_ACTIVE_MAX_CHANNEL_TIME_MIN,
723 CFG_ACTIVE_MAX_CHANNEL_TIME_MAX),
724
725 REG_VARIABLE(CFG_ACTIVE_MIN_CHANNEL_TIME_NAME, WLAN_PARAM_Integer,
726 struct hdd_config, nActiveMinChnTime,
727 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
728 CFG_ACTIVE_MIN_CHANNEL_TIME_DEFAULT,
729 CFG_ACTIVE_MIN_CHANNEL_TIME_MIN,
730 CFG_ACTIVE_MIN_CHANNEL_TIME_MAX),
731
732 REG_VARIABLE(CFG_RETRY_LIMIT_ZERO_NAME, WLAN_PARAM_Integer,
733 struct hdd_config, retryLimitZero,
734 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
735 CFG_RETRY_LIMIT_ZERO_DEFAULT,
736 CFG_RETRY_LIMIT_ZERO_MIN,
737 CFG_RETRY_LIMIT_ZERO_MAX),
738
739 REG_VARIABLE(CFG_RETRY_LIMIT_ONE_NAME, WLAN_PARAM_Integer,
740 struct hdd_config, retryLimitOne,
741 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
742 CFG_RETRY_LIMIT_ONE_DEFAULT,
743 CFG_RETRY_LIMIT_ONE_MIN,
744 CFG_RETRY_LIMIT_ONE_MAX),
745
746 REG_VARIABLE(CFG_RETRY_LIMIT_TWO_NAME, WLAN_PARAM_Integer,
747 struct hdd_config, retryLimitTwo,
748 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
749 CFG_RETRY_LIMIT_TWO_DEFAULT,
750 CFG_RETRY_LIMIT_TWO_MIN,
751 CFG_RETRY_LIMIT_TWO_MAX),
752
753#ifdef WLAN_AP_STA_CONCURRENCY
754 REG_VARIABLE(CFG_PASSIVE_MAX_CHANNEL_TIME_CONC_NAME, WLAN_PARAM_Integer,
755 struct hdd_config, nPassiveMaxChnTimeConc,
756 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
757 CFG_PASSIVE_MAX_CHANNEL_TIME_CONC_DEFAULT,
758 CFG_PASSIVE_MAX_CHANNEL_TIME_CONC_MIN,
759 CFG_PASSIVE_MAX_CHANNEL_TIME_CONC_MAX),
760
761 REG_VARIABLE(CFG_PASSIVE_MIN_CHANNEL_TIME_CONC_NAME, WLAN_PARAM_Integer,
762 struct hdd_config, nPassiveMinChnTimeConc,
763 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
764 CFG_PASSIVE_MIN_CHANNEL_TIME_CONC_DEFAULT,
765 CFG_PASSIVE_MIN_CHANNEL_TIME_CONC_MIN,
766 CFG_PASSIVE_MIN_CHANNEL_TIME_CONC_MAX),
767
768 REG_VARIABLE(CFG_ACTIVE_MAX_CHANNEL_TIME_CONC_NAME, WLAN_PARAM_Integer,
769 struct hdd_config, nActiveMaxChnTimeConc,
770 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
771 CFG_ACTIVE_MAX_CHANNEL_TIME_CONC_DEFAULT,
772 CFG_ACTIVE_MAX_CHANNEL_TIME_CONC_MIN,
773 CFG_ACTIVE_MAX_CHANNEL_TIME_CONC_MAX),
774
775 REG_VARIABLE(CFG_ACTIVE_MIN_CHANNEL_TIME_CONC_NAME, WLAN_PARAM_Integer,
776 struct hdd_config, nActiveMinChnTimeConc,
777 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
778 CFG_ACTIVE_MIN_CHANNEL_TIME_CONC_DEFAULT,
779 CFG_ACTIVE_MIN_CHANNEL_TIME_CONC_MIN,
780 CFG_ACTIVE_MIN_CHANNEL_TIME_CONC_MAX),
781
782 REG_VARIABLE(CFG_REST_TIME_CONC_NAME, WLAN_PARAM_Integer,
783 struct hdd_config, nRestTimeConc,
784 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
785 CFG_REST_TIME_CONC_DEFAULT,
786 CFG_REST_TIME_CONC_MIN,
787 CFG_REST_TIME_CONC_MAX),
788
Agrawal Ashish17bb3902016-05-05 13:29:40 +0530789 REG_VARIABLE(CFG_MIN_REST_TIME_NAME, WLAN_PARAM_Integer,
790 struct hdd_config, min_rest_time_conc,
791 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
792 CFG_MIN_REST_TIME_DEFAULT,
793 CFG_MIN_REST_TIME_MIN,
794 CFG_MIN_REST_TIME_MAX),
795
796 REG_VARIABLE(CFG_IDLE_TIME_NAME , WLAN_PARAM_Integer,
797 struct hdd_config, idle_time_conc,
798 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
799 CFG_IDLE_TIME_DEFAULT,
800 CFG_IDLE_TIME_MIN,
801 CFG_IDLE_TIME_MAX) ,
802
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800803 REG_VARIABLE(CFG_NUM_STA_CHAN_COMBINED_CONC_NAME, WLAN_PARAM_Integer,
804 struct hdd_config, nNumStaChanCombinedConc,
805 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
806 CFG_NUM_STA_CHAN_COMBINED_CONC_DEFAULT,
807 CFG_NUM_STA_CHAN_COMBINED_CONC_MIN,
808 CFG_NUM_STA_CHAN_COMBINED_CONC_MAX),
809
810 REG_VARIABLE(CFG_NUM_P2P_CHAN_COMBINED_CONC_NAME, WLAN_PARAM_Integer,
811 struct hdd_config, nNumP2PChanCombinedConc,
812 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
813 CFG_NUM_P2P_CHAN_COMBINED_CONC_DEFAULT,
814 CFG_NUM_P2P_CHAN_COMBINED_CONC_MIN,
815 CFG_NUM_P2P_CHAN_COMBINED_CONC_MAX),
816#endif
817
818 REG_VARIABLE(CFG_MAX_PS_POLL_NAME, WLAN_PARAM_Integer,
819 struct hdd_config, nMaxPsPoll,
820 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
821 CFG_MAX_PS_POLL_DEFAULT,
822 CFG_MAX_PS_POLL_MIN,
823 CFG_MAX_PS_POLL_MAX),
824
825 REG_VARIABLE(CFG_MAX_TX_POWER_NAME, WLAN_PARAM_Integer,
826 struct hdd_config, nTxPowerCap,
827 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
828 CFG_MAX_TX_POWER_DEFAULT,
829 CFG_MAX_TX_POWER_MIN,
830 CFG_MAX_TX_POWER_MAX),
831
Padma, Santhosh Kumar29df3622016-08-16 19:15:16 +0530832 REG_VARIABLE(CFG_TX_POWER_CTRL_NAME, WLAN_PARAM_Integer,
833 struct hdd_config, allow_tpc_from_ap,
834 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
835 CFG_TX_POWER_CTRL_DEFAULT,
836 CFG_TX_POWER_CTRL_MIN,
837 CFG_TX_POWER_CTRL_MAX),
838
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800839 REG_VARIABLE(CFG_LOW_GAIN_OVERRIDE_NAME, WLAN_PARAM_Integer,
840 struct hdd_config, fIsLowGainOverride,
841 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
842 CFG_LOW_GAIN_OVERRIDE_DEFAULT,
843 CFG_LOW_GAIN_OVERRIDE_MIN,
844 CFG_LOW_GAIN_OVERRIDE_MAX),
845
846 REG_VARIABLE(CFG_RSSI_FILTER_PERIOD_NAME, WLAN_PARAM_Integer,
847 struct hdd_config, nRssiFilterPeriod,
848 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
849 CFG_RSSI_FILTER_PERIOD_DEFAULT,
850 CFG_RSSI_FILTER_PERIOD_MIN,
851 CFG_RSSI_FILTER_PERIOD_MAX),
852
853 REG_VARIABLE(CFG_IGNORE_DTIM_NAME, WLAN_PARAM_Integer,
854 struct hdd_config, fIgnoreDtim,
855 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
856 CFG_IGNORE_DTIM_DEFAULT,
857 CFG_IGNORE_DTIM_MIN,
858 CFG_IGNORE_DTIM_MAX),
859
860 REG_VARIABLE(CFG_MAX_LI_MODULATED_DTIM_NAME, WLAN_PARAM_Integer,
861 struct hdd_config, fMaxLIModulatedDTIM,
862 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
863 CFG_MAX_LI_MODULATED_DTIM_DEFAULT,
864 CFG_MAX_LI_MODULATED_DTIM_MIN,
865 CFG_MAX_LI_MODULATED_DTIM_MAX),
866
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800867 REG_VARIABLE(CFG_FW_HEART_BEAT_MONITORING_NAME, WLAN_PARAM_Integer,
868 struct hdd_config, fEnableFwHeartBeatMonitoring,
869 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
870 CFG_FW_HEART_BEAT_MONITORING_DEFAULT,
871 CFG_FW_HEART_BEAT_MONITORING_MIN,
872 CFG_FW_HEART_BEAT_MONITORING_MAX),
873
874 REG_VARIABLE(CFG_FW_BEACON_FILTERING_NAME, WLAN_PARAM_Integer,
875 struct hdd_config, fEnableFwBeaconFiltering,
876 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
877 CFG_FW_BEACON_FILTERING_DEFAULT,
878 CFG_FW_BEACON_FILTERING_MIN,
879 CFG_FW_BEACON_FILTERING_MAX),
880
881 REG_DYNAMIC_VARIABLE(CFG_FW_RSSI_MONITORING_NAME, WLAN_PARAM_Integer,
882 struct hdd_config, fEnableFwRssiMonitoring,
883 VAR_FLAGS_OPTIONAL |
884 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
885 CFG_FW_RSSI_MONITORING_DEFAULT,
886 CFG_FW_RSSI_MONITORING_MIN,
887 CFG_FW_RSSI_MONITORING_MAX,
888 cb_notify_set_fw_rssi_monitoring, 0),
889
890 REG_VARIABLE(CFG_FW_MCC_RTS_CTS_PROT_NAME, WLAN_PARAM_Integer,
891 struct hdd_config, mcc_rts_cts_prot_enable,
892 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
893 CFG_FW_MCC_RTS_CTS_PROT_DEFAULT,
894 CFG_FW_MCC_RTS_CTS_PROT_MIN,
895 CFG_FW_MCC_RTS_CTS_PROT_MAX),
896
897 REG_VARIABLE(CFG_FW_MCC_BCAST_PROB_RESP_NAME, WLAN_PARAM_Integer,
898 struct hdd_config, mcc_bcast_prob_resp_enable,
899 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
900 CFG_FW_MCC_BCAST_PROB_RESP_DEFAULT,
901 CFG_FW_MCC_BCAST_PROB_RESP_MIN,
902 CFG_FW_MCC_BCAST_PROB_RESP_MAX),
903
904 REG_VARIABLE(CFG_DATA_INACTIVITY_TIMEOUT_NAME, WLAN_PARAM_Integer,
905 struct hdd_config, nDataInactivityTimeout,
906 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
907 CFG_DATA_INACTIVITY_TIMEOUT_DEFAULT,
908 CFG_DATA_INACTIVITY_TIMEOUT_MIN,
909 CFG_DATA_INACTIVITY_TIMEOUT_MAX),
910
911 REG_VARIABLE(CFG_QOS_WMM_MODE_NAME, WLAN_PARAM_Integer,
912 struct hdd_config, WmmMode,
913 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
914 CFG_QOS_WMM_MODE_DEFAULT,
915 CFG_QOS_WMM_MODE_MIN,
916 CFG_QOS_WMM_MODE_MAX),
917
918 REG_VARIABLE(CFG_QOS_WMM_80211E_ENABLED_NAME, WLAN_PARAM_Integer,
919 struct hdd_config, b80211eIsEnabled,
920 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
921 CFG_QOS_WMM_80211E_ENABLED_DEFAULT,
922 CFG_QOS_WMM_80211E_ENABLED_MIN,
923 CFG_QOS_WMM_80211E_ENABLED_MAX),
924
925 REG_VARIABLE(CFG_QOS_WMM_UAPSD_MASK_NAME, WLAN_PARAM_HexInteger,
926 struct hdd_config, UapsdMask,
927 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
928 CFG_QOS_WMM_UAPSD_MASK_DEFAULT,
929 CFG_QOS_WMM_UAPSD_MASK_MIN,
930 CFG_QOS_WMM_UAPSD_MASK_MAX),
931
932 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_VO_SRV_INTV_NAME,
933 WLAN_PARAM_Integer,
934 struct hdd_config, InfraUapsdVoSrvIntv,
935 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
936 CFG_QOS_WMM_INFRA_UAPSD_VO_SRV_INTV_DEFAULT,
937 CFG_QOS_WMM_INFRA_UAPSD_VO_SRV_INTV_MIN,
938 CFG_QOS_WMM_INFRA_UAPSD_VO_SRV_INTV_MAX),
939
940 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_VO_SUS_INTV_NAME,
941 WLAN_PARAM_Integer,
942 struct hdd_config, InfraUapsdVoSuspIntv,
943 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
944 CFG_QOS_WMM_INFRA_UAPSD_VO_SUS_INTV_DEFAULT,
945 CFG_QOS_WMM_INFRA_UAPSD_VO_SUS_INTV_MIN,
946 CFG_QOS_WMM_INFRA_UAPSD_VO_SUS_INTV_MAX),
947
948 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_VI_SRV_INTV_NAME,
949 WLAN_PARAM_Integer,
950 struct hdd_config, InfraUapsdViSrvIntv,
951 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
952 CFG_QOS_WMM_INFRA_UAPSD_VI_SRV_INTV_DEFAULT,
953 CFG_QOS_WMM_INFRA_UAPSD_VI_SRV_INTV_MIN,
954 CFG_QOS_WMM_INFRA_UAPSD_VI_SRV_INTV_MAX),
955
956 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_VI_SUS_INTV_NAME,
957 WLAN_PARAM_Integer,
958 struct hdd_config, InfraUapsdViSuspIntv,
959 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
960 CFG_QOS_WMM_INFRA_UAPSD_VI_SUS_INTV_DEFAULT,
961 CFG_QOS_WMM_INFRA_UAPSD_VI_SUS_INTV_MIN,
962 CFG_QOS_WMM_INFRA_UAPSD_VI_SUS_INTV_MAX),
963
964 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_NAME,
965 WLAN_PARAM_Integer,
966 struct hdd_config, InfraUapsdBeSrvIntv,
967 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
968 CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_DEFAULT,
969 CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_MIN,
970 CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_MAX),
971
972 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_NAME,
973 WLAN_PARAM_Integer,
974 struct hdd_config, InfraUapsdBeSuspIntv,
975 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
976 CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_DEFAULT,
977 CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_MIN,
978 CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_MAX),
979
980 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BK_SRV_INTV_NAME,
981 WLAN_PARAM_Integer,
982 struct hdd_config, InfraUapsdBkSrvIntv,
983 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
984 CFG_QOS_WMM_INFRA_UAPSD_BK_SRV_INTV_DEFAULT,
985 CFG_QOS_WMM_INFRA_UAPSD_BK_SRV_INTV_MIN,
986 CFG_QOS_WMM_INFRA_UAPSD_BK_SRV_INTV_MAX),
987
988 REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_NAME,
989 WLAN_PARAM_Integer,
990 struct hdd_config, InfraUapsdBkSuspIntv,
991 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
992 CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_DEFAULT,
993 CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_MIN,
994 CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_MAX),
995
996#ifdef FEATURE_WLAN_ESE
997 REG_VARIABLE(CFG_QOS_WMM_INFRA_INACTIVITY_INTERVAL_NAME,
998 WLAN_PARAM_Integer,
999 struct hdd_config, InfraInactivityInterval,
1000 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1001 CFG_QOS_WMM_INFRA_INACTIVITY_INTERVAL_DEFAULT,
1002 CFG_QOS_WMM_INFRA_INACTIVITY_INTERVAL_MIN,
1003 CFG_QOS_WMM_INFRA_INACTIVITY_INTERVAL_MAX),
1004
1005 REG_DYNAMIC_VARIABLE(CFG_ESE_FEATURE_ENABLED_NAME, WLAN_PARAM_Integer,
1006 struct hdd_config, isEseIniFeatureEnabled,
1007 VAR_FLAGS_OPTIONAL |
1008 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1009 CFG_ESE_FEATURE_ENABLED_DEFAULT,
1010 CFG_ESE_FEATURE_ENABLED_MIN,
1011 CFG_ESE_FEATURE_ENABLED_MAX,
1012 cb_notify_set_ese_feature_enabled, 0),
1013#endif /* FEATURE_WLAN_ESE */
1014
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001015 /* flag to turn ON/OFF Legacy Fast Roaming */
1016 REG_DYNAMIC_VARIABLE(CFG_LFR_FEATURE_ENABLED_NAME, WLAN_PARAM_Integer,
1017 struct hdd_config, isFastRoamIniFeatureEnabled,
1018 VAR_FLAGS_OPTIONAL |
1019 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1020 CFG_LFR_FEATURE_ENABLED_DEFAULT,
1021 CFG_LFR_FEATURE_ENABLED_MIN,
1022 CFG_LFR_FEATURE_ENABLED_MAX,
1023 notify_is_fast_roam_ini_feature_enabled, 0),
1024
1025 /* flag to turn ON/OFF Motion assistance for Legacy Fast Roaming */
1026 REG_DYNAMIC_VARIABLE(CFG_LFR_MAWC_FEATURE_ENABLED_NAME,
1027 WLAN_PARAM_Integer,
1028 struct hdd_config, MAWCEnabled,
1029 VAR_FLAGS_OPTIONAL |
1030 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1031 CFG_LFR_MAWC_FEATURE_ENABLED_DEFAULT,
1032 CFG_LFR_MAWC_FEATURE_ENABLED_MIN,
1033 CFG_LFR_MAWC_FEATURE_ENABLED_MAX,
1034 notify_is_mawc_ini_feature_enabled, 0),
1035
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001036 /* flag to turn ON/OFF 11r and ESE FastTransition */
1037 REG_DYNAMIC_VARIABLE(CFG_FAST_TRANSITION_ENABLED_NAME,
1038 WLAN_PARAM_Integer,
1039 struct hdd_config, isFastTransitionEnabled,
1040 VAR_FLAGS_OPTIONAL |
1041 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1042 CFG_FAST_TRANSITION_ENABLED_NAME_DEFAULT,
1043 CFG_FAST_TRANSITION_ENABLED_NAME_MIN,
1044 CFG_FAST_TRANSITION_ENABLED_NAME_MAX,
1045 cb_notify_set_fast_transition_enabled, 0),
1046
1047 /* Variable to specify the delta/difference between the RSSI of current AP
1048 * and roamable AP while roaming */
1049 REG_DYNAMIC_VARIABLE(CFG_ROAM_RSSI_DIFF_NAME, WLAN_PARAM_Integer,
1050 struct hdd_config, RoamRssiDiff,
1051 VAR_FLAGS_OPTIONAL |
1052 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1053 CFG_ROAM_RSSI_DIFF_DEFAULT,
1054 CFG_ROAM_RSSI_DIFF_MIN,
1055 CFG_ROAM_RSSI_DIFF_MAX,
1056 cb_notify_set_roam_rssi_diff, 0),
1057
1058 REG_DYNAMIC_VARIABLE(CFG_ENABLE_WES_MODE_NAME, WLAN_PARAM_Integer,
1059 struct hdd_config, isWESModeEnabled,
1060 VAR_FLAGS_OPTIONAL |
1061 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1062 CFG_ENABLE_WES_MODE_NAME_DEFAULT,
1063 CFG_ENABLE_WES_MODE_NAME_MIN,
1064 CFG_ENABLE_WES_MODE_NAME_MAX,
1065 cb_notify_set_wes_mode, 0),
Deepak Dhamdheref2a7d8b2016-08-19 16:17:38 -07001066 REG_VARIABLE(CFG_OKC_FEATURE_ENABLED_NAME, WLAN_PARAM_Integer,
1067 struct hdd_config, isOkcIniFeatureEnabled,
1068 VAR_FLAGS_OPTIONAL |
1069 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1070 CFG_OKC_FEATURE_ENABLED_DEFAULT,
1071 CFG_OKC_FEATURE_ENABLED_MIN,
1072 CFG_OKC_FEATURE_ENABLED_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001073 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_OFFLOAD_ENABLED, WLAN_PARAM_Integer,
1074 struct hdd_config, isRoamOffloadScanEnabled,
1075 VAR_FLAGS_OPTIONAL |
1076 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1077 CFG_ROAM_SCAN_OFFLOAD_ENABLED_DEFAULT,
1078 CFG_ROAM_SCAN_OFFLOAD_ENABLED_MIN,
1079 CFG_ROAM_SCAN_OFFLOAD_ENABLED_MAX,
1080 cb_notify_update_roam_scan_offload_enabled, 0),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001081
1082 REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_VO_NAME, WLAN_PARAM_Integer,
1083 struct hdd_config, InfraDirAcVo,
1084 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1085 CFG_QOS_WMM_INFRA_DIR_AC_VO_DEFAULT,
1086 CFG_QOS_WMM_INFRA_DIR_AC_VO_MIN,
1087 CFG_QOS_WMM_INFRA_DIR_AC_VO_MAX),
1088
1089 REG_VARIABLE(CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VO_NAME,
1090 WLAN_PARAM_HexInteger,
1091 struct hdd_config, InfraNomMsduSizeAcVo,
1092 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1093 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VO_DEFAULT,
1094 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VO_MIN,
1095 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VO_MAX),
1096
1097 REG_VARIABLE(CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VO_NAME,
1098 WLAN_PARAM_HexInteger,
1099 struct hdd_config, InfraMeanDataRateAcVo,
1100 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1101 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VO_DEFAULT,
1102 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VO_MIN,
1103 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VO_MAX),
1104
1105 REG_VARIABLE(CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VO_NAME,
1106 WLAN_PARAM_HexInteger,
1107 struct hdd_config, InfraMinPhyRateAcVo,
1108 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1109 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VO_DEFAULT,
1110 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VO_MIN,
1111 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VO_MAX),
1112
1113 REG_VARIABLE(CFG_QOS_WMM_INFRA_SBA_AC_VO_NAME, WLAN_PARAM_HexInteger,
1114 struct hdd_config, InfraSbaAcVo,
1115 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1116 CFG_QOS_WMM_INFRA_SBA_AC_VO_DEFAULT,
1117 CFG_QOS_WMM_INFRA_SBA_AC_VO_MIN,
1118 CFG_QOS_WMM_INFRA_SBA_AC_VO_MAX),
1119
1120 REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_VI_NAME, WLAN_PARAM_Integer,
1121 struct hdd_config, InfraDirAcVi,
1122 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1123 CFG_QOS_WMM_INFRA_DIR_AC_VI_DEFAULT,
1124 CFG_QOS_WMM_INFRA_DIR_AC_VI_MIN,
1125 CFG_QOS_WMM_INFRA_DIR_AC_VI_MAX),
1126
1127 REG_VARIABLE(CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VI_NAME,
1128 WLAN_PARAM_HexInteger,
1129 struct hdd_config, InfraNomMsduSizeAcVi,
1130 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1131 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VI_DEFAULT,
1132 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VI_MIN,
1133 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_VI_MAX),
1134
1135 REG_VARIABLE(CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VI_NAME,
1136 WLAN_PARAM_HexInteger,
1137 struct hdd_config, InfraMeanDataRateAcVi,
1138 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1139 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VI_DEFAULT,
1140 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VI_MIN,
1141 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_VI_MAX),
1142
1143 REG_VARIABLE(CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VI_NAME,
1144 WLAN_PARAM_HexInteger,
1145 struct hdd_config, InfraMinPhyRateAcVi,
1146 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1147 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VI_DEFAULT,
1148 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VI_MIN,
1149 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_VI_MAX),
1150
1151 REG_VARIABLE(CFG_QOS_WMM_INFRA_SBA_AC_VI_NAME, WLAN_PARAM_HexInteger,
1152 struct hdd_config, InfraSbaAcVi,
1153 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1154 CFG_QOS_WMM_INFRA_SBA_AC_VI_DEFAULT,
1155 CFG_QOS_WMM_INFRA_SBA_AC_VI_MIN,
1156 CFG_QOS_WMM_INFRA_SBA_AC_VI_MAX),
1157
1158 REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_BE_NAME, WLAN_PARAM_Integer,
1159 struct hdd_config, InfraDirAcBe,
1160 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1161 CFG_QOS_WMM_INFRA_DIR_AC_BE_DEFAULT,
1162 CFG_QOS_WMM_INFRA_DIR_AC_BE_MIN,
1163 CFG_QOS_WMM_INFRA_DIR_AC_BE_MAX),
1164
1165 REG_VARIABLE(CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_NAME,
1166 WLAN_PARAM_HexInteger,
1167 struct hdd_config, InfraNomMsduSizeAcBe,
1168 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1169 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_DEFAULT,
1170 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_MIN,
1171 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_MAX),
1172
1173 REG_VARIABLE(CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_NAME,
1174 WLAN_PARAM_HexInteger,
1175 struct hdd_config, InfraMeanDataRateAcBe,
1176 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1177 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_DEFAULT,
1178 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_MIN,
1179 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_MAX),
1180
1181 REG_VARIABLE(CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_NAME,
1182 WLAN_PARAM_HexInteger,
1183 struct hdd_config, InfraMinPhyRateAcBe,
1184 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1185 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_DEFAULT,
1186 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_MIN,
1187 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_MAX),
1188
1189 REG_VARIABLE(CFG_QOS_WMM_INFRA_SBA_AC_BE_NAME, WLAN_PARAM_HexInteger,
1190 struct hdd_config, InfraSbaAcBe,
1191 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1192 CFG_QOS_WMM_INFRA_SBA_AC_BE_DEFAULT,
1193 CFG_QOS_WMM_INFRA_SBA_AC_BE_MIN,
1194 CFG_QOS_WMM_INFRA_SBA_AC_BE_MAX),
1195
1196 REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_BK_NAME, WLAN_PARAM_Integer,
1197 struct hdd_config, InfraDirAcBk,
1198 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1199 CFG_QOS_WMM_INFRA_DIR_AC_BK_DEFAULT,
1200 CFG_QOS_WMM_INFRA_DIR_AC_BK_MIN,
1201 CFG_QOS_WMM_INFRA_DIR_AC_BK_MAX),
1202
1203 REG_VARIABLE(CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BK_NAME,
1204 WLAN_PARAM_HexInteger,
1205 struct hdd_config, InfraNomMsduSizeAcBk,
1206 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1207 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BK_DEFAULT,
1208 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BK_MIN,
1209 CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BK_MAX),
1210
1211 REG_VARIABLE(CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BK_NAME,
1212 WLAN_PARAM_HexInteger,
1213 struct hdd_config, InfraMeanDataRateAcBk,
1214 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1215 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BK_DEFAULT,
1216 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BK_MIN,
1217 CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BK_MAX),
1218
1219 REG_VARIABLE(CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BK_NAME,
1220 WLAN_PARAM_HexInteger,
1221 struct hdd_config, InfraMinPhyRateAcBk,
1222 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1223 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BK_DEFAULT,
1224 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BK_MIN,
1225 CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BK_MAX),
1226
1227 REG_VARIABLE(CFG_QOS_WMM_INFRA_SBA_AC_BK_NAME, WLAN_PARAM_HexInteger,
1228 struct hdd_config, InfraSbaAcBk,
1229 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1230 CFG_QOS_WMM_INFRA_SBA_AC_BK_DEFAULT,
1231 CFG_QOS_WMM_INFRA_SBA_AC_BK_MIN,
1232 CFG_QOS_WMM_INFRA_SBA_AC_BK_MAX),
1233
1234 REG_VARIABLE(CFG_TL_DELAYED_TRGR_FRM_INT_NAME, WLAN_PARAM_Integer,
1235 struct hdd_config, DelayedTriggerFrmInt,
1236 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1237 CFG_TL_DELAYED_TRGR_FRM_INT_DEFAULT,
1238 CFG_TL_DELAYED_TRGR_FRM_INT_MIN,
1239 CFG_TL_DELAYED_TRGR_FRM_INT_MAX),
1240
1241 REG_VARIABLE_STRING(CFG_WOWL_PATTERN_NAME, WLAN_PARAM_String,
1242 struct hdd_config, wowlPattern,
1243 VAR_FLAGS_OPTIONAL,
1244 (void *)CFG_WOWL_PATTERN_DEFAULT),
1245
1246 REG_VARIABLE(CFG_QOS_IMPLICIT_SETUP_ENABLED_NAME, WLAN_PARAM_Integer,
1247 struct hdd_config, bImplicitQosEnabled,
1248 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1249 CFG_QOS_IMPLICIT_SETUP_ENABLED_DEFAULT,
1250 CFG_QOS_IMPLICIT_SETUP_ENABLED_MIN,
1251 CFG_QOS_IMPLICIT_SETUP_ENABLED_MAX),
1252
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001253 REG_VARIABLE(CFG_AP_AUTO_SHUT_OFF, WLAN_PARAM_Integer,
1254 struct hdd_config, nAPAutoShutOff,
1255 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1256 CFG_AP_AUTO_SHUT_OFF_DEFAULT,
1257 CFG_AP_AUTO_SHUT_OFF_MIN,
1258 CFG_AP_AUTO_SHUT_OFF_MAX),
1259
1260#ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
1261 REG_VARIABLE(CFG_WLAN_MCC_TO_SCC_SWITCH_MODE, WLAN_PARAM_Integer,
1262 struct hdd_config, WlanMccToSccSwitchMode,
1263 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1264 CFG_WLAN_MCC_TO_SCC_SWITCH_MODE_DEFAULT,
1265 CFG_WLAN_MCC_TO_SCC_SWITCH_MODE_MIN,
1266 CFG_WLAN_MCC_TO_SCC_SWITCH_MODE_MAX),
1267#endif
1268#ifdef FEATURE_WLAN_AUTO_SHUTDOWN
1269 REG_VARIABLE(CFG_WLAN_AUTO_SHUTDOWN, WLAN_PARAM_Integer,
1270 struct hdd_config, WlanAutoShutdown,
1271 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1272 CFG_WLAN_AUTO_SHUTDOWN_DEFAULT,
1273 CFG_WLAN_AUTO_SHUTDOWN_MIN,
1274 CFG_WLAN_AUTO_SHUTDOWN_MAX),
1275#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001276 REG_VARIABLE(CFG_RRM_ENABLE_NAME, WLAN_PARAM_Integer,
1277 struct hdd_config, fRrmEnable,
1278 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1279 CFG_RRM_ENABLE_DEFAULT,
1280 CFG_RRM_ENABLE_MIN,
1281 CFG_RRM_ENABLE_MAX),
1282
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001283 REG_VARIABLE(CFG_RRM_MEAS_RANDOMIZATION_INTVL_NAME, WLAN_PARAM_Integer,
1284 struct hdd_config, nRrmRandnIntvl,
1285 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1286 CFG_RRM_MEAS_RANDOMIZATION_INTVL_DEFAULT,
1287 CFG_RRM_MEAS_RANDOMIZATION_INTVL_MIN,
1288 CFG_RRM_MEAS_RANDOMIZATION_INTVL_MAX),
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08001289
1290 REG_VARIABLE_STRING(CFG_RM_CAPABILITY_NAME, WLAN_PARAM_String,
1291 struct hdd_config, rm_capability,
1292 VAR_FLAGS_OPTIONAL,
1293 (void *) CFG_RM_CAPABILITY_DEFAULT),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001294
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001295 REG_VARIABLE(CFG_FT_RESOURCE_REQ_NAME, WLAN_PARAM_Integer,
1296 struct hdd_config, fFTResourceReqSupported,
1297 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1298 CFG_FT_RESOURCE_REQ_DEFAULT,
1299 CFG_FT_RESOURCE_REQ_MIN,
1300 CFG_FT_RESOURCE_REQ_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001301
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001302 REG_DYNAMIC_VARIABLE(CFG_NEIGHBOR_SCAN_TIMER_PERIOD_NAME,
1303 WLAN_PARAM_Integer,
1304 struct hdd_config, nNeighborScanPeriod,
1305 VAR_FLAGS_OPTIONAL |
1306 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1307 CFG_NEIGHBOR_SCAN_TIMER_PERIOD_DEFAULT,
1308 CFG_NEIGHBOR_SCAN_TIMER_PERIOD_MIN,
1309 CFG_NEIGHBOR_SCAN_TIMER_PERIOD_MAX,
1310 cb_notify_set_neighbor_scan_period, 0),
1311
1312 REG_DYNAMIC_VARIABLE(CFG_NEIGHBOR_LOOKUP_RSSI_THRESHOLD_NAME,
1313 WLAN_PARAM_Integer,
1314 struct hdd_config, nNeighborLookupRssiThreshold,
1315 VAR_FLAGS_OPTIONAL |
1316 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1317 CFG_NEIGHBOR_LOOKUP_RSSI_THRESHOLD_DEFAULT,
1318 CFG_NEIGHBOR_LOOKUP_RSSI_THRESHOLD_MIN,
1319 CFG_NEIGHBOR_LOOKUP_RSSI_THRESHOLD_MAX,
1320 cb_notify_set_neighbor_lookup_rssi_threshold, 0),
1321
1322 REG_DYNAMIC_VARIABLE(CFG_OPPORTUNISTIC_SCAN_THRESHOLD_DIFF_NAME,
1323 WLAN_PARAM_Integer,
1324 struct hdd_config, nOpportunisticThresholdDiff,
1325 VAR_FLAGS_OPTIONAL |
1326 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1327 CFG_OPPORTUNISTIC_SCAN_THRESHOLD_DIFF_DEFAULT,
1328 CFG_OPPORTUNISTIC_SCAN_THRESHOLD_DIFF_MIN,
1329 CFG_OPPORTUNISTIC_SCAN_THRESHOLD_DIFF_MAX,
1330 cb_notify_set_opportunistic_scan_threshold_diff, 0),
1331
1332 REG_DYNAMIC_VARIABLE(CFG_ROAM_RESCAN_RSSI_DIFF_NAME, WLAN_PARAM_Integer,
1333 struct hdd_config, nRoamRescanRssiDiff,
1334 VAR_FLAGS_OPTIONAL |
1335 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1336 CFG_ROAM_RESCAN_RSSI_DIFF_DEFAULT,
1337 CFG_ROAM_RESCAN_RSSI_DIFF_MIN,
1338 CFG_ROAM_RESCAN_RSSI_DIFF_MAX,
1339 cb_notify_set_roam_rescan_rssi_diff, 0),
1340
1341 REG_VARIABLE_STRING(CFG_NEIGHBOR_SCAN_CHAN_LIST_NAME, WLAN_PARAM_String,
1342 struct hdd_config, neighborScanChanList,
1343 VAR_FLAGS_OPTIONAL,
1344 (void *)CFG_NEIGHBOR_SCAN_CHAN_LIST_DEFAULT),
1345
1346 REG_DYNAMIC_VARIABLE(CFG_NEIGHBOR_SCAN_MIN_CHAN_TIME_NAME,
1347 WLAN_PARAM_Integer,
1348 struct hdd_config, nNeighborScanMinChanTime,
1349 VAR_FLAGS_OPTIONAL |
1350 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1351 CFG_NEIGHBOR_SCAN_MIN_CHAN_TIME_DEFAULT,
1352 CFG_NEIGHBOR_SCAN_MIN_CHAN_TIME_MIN,
1353 CFG_NEIGHBOR_SCAN_MIN_CHAN_TIME_MAX,
1354 cb_notify_set_neighbor_scan_min_chan_time, 0),
1355
1356 REG_DYNAMIC_VARIABLE(CFG_NEIGHBOR_SCAN_MAX_CHAN_TIME_NAME,
1357 WLAN_PARAM_Integer,
1358 struct hdd_config, nNeighborScanMaxChanTime,
1359 VAR_FLAGS_OPTIONAL |
1360 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1361 CFG_NEIGHBOR_SCAN_MAX_CHAN_TIME_DEFAULT,
1362 CFG_NEIGHBOR_SCAN_MAX_CHAN_TIME_MIN,
1363 CFG_NEIGHBOR_SCAN_MAX_CHAN_TIME_MAX,
1364 cb_notify_set_neighbor_scan_max_chan_time, 0),
1365
1366 REG_VARIABLE(CFG_11R_NEIGHBOR_REQ_MAX_TRIES_NAME, WLAN_PARAM_Integer,
1367 struct hdd_config, nMaxNeighborReqTries,
1368 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1369 CFG_11R_NEIGHBOR_REQ_MAX_TRIES_DEFAULT,
1370 CFG_11R_NEIGHBOR_REQ_MAX_TRIES_MIN,
1371 CFG_11R_NEIGHBOR_REQ_MAX_TRIES_MAX),
1372
1373 REG_DYNAMIC_VARIABLE(CFG_NEIGHBOR_SCAN_RESULTS_REFRESH_PERIOD_NAME,
1374 WLAN_PARAM_Integer,
1375 struct hdd_config, nNeighborResultsRefreshPeriod,
1376 VAR_FLAGS_OPTIONAL |
1377 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1378 CFG_NEIGHBOR_SCAN_RESULTS_REFRESH_PERIOD_DEFAULT,
1379 CFG_NEIGHBOR_SCAN_RESULTS_REFRESH_PERIOD_MIN,
1380 CFG_NEIGHBOR_SCAN_RESULTS_REFRESH_PERIOD_MAX,
1381 cb_notify_set_neighbor_results_refresh_period, 0),
1382
1383 REG_DYNAMIC_VARIABLE(CFG_EMPTY_SCAN_REFRESH_PERIOD_NAME,
1384 WLAN_PARAM_Integer,
1385 struct hdd_config, nEmptyScanRefreshPeriod,
1386 VAR_FLAGS_OPTIONAL |
1387 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1388 CFG_EMPTY_SCAN_REFRESH_PERIOD_DEFAULT,
1389 CFG_EMPTY_SCAN_REFRESH_PERIOD_MIN,
1390 CFG_EMPTY_SCAN_REFRESH_PERIOD_MAX,
1391 cb_notify_set_empty_scan_refresh_period, 0),
1392
1393 REG_DYNAMIC_VARIABLE(CFG_ROAM_BMISS_FIRST_BCNT_NAME, WLAN_PARAM_Integer,
1394 struct hdd_config, nRoamBmissFirstBcnt,
1395 VAR_FLAGS_OPTIONAL |
1396 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1397 CFG_ROAM_BMISS_FIRST_BCNT_DEFAULT,
1398 CFG_ROAM_BMISS_FIRST_BCNT_MIN,
1399 CFG_ROAM_BMISS_FIRST_BCNT_MAX,
1400 cb_notify_set_roam_bmiss_first_bcnt, 0),
1401
1402 REG_DYNAMIC_VARIABLE(CFG_ROAM_BMISS_FINAL_BCNT_NAME, WLAN_PARAM_Integer,
1403 struct hdd_config, nRoamBmissFinalBcnt,
1404 VAR_FLAGS_OPTIONAL |
1405 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1406 CFG_ROAM_BMISS_FINAL_BCNT_DEFAULT,
1407 CFG_ROAM_BMISS_FINAL_BCNT_MIN,
1408 CFG_ROAM_BMISS_FINAL_BCNT_MAX,
1409 cb_notify_set_roam_bmiss_final_bcnt, 0),
1410
1411 REG_DYNAMIC_VARIABLE(CFG_ROAM_BEACON_RSSI_WEIGHT_NAME,
1412 WLAN_PARAM_Integer,
1413 struct hdd_config, nRoamBeaconRssiWeight,
1414 VAR_FLAGS_OPTIONAL |
1415 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1416 CFG_ROAM_BEACON_RSSI_WEIGHT_DEFAULT,
1417 CFG_ROAM_BEACON_RSSI_WEIGHT_MIN,
1418 CFG_ROAM_BEACON_RSSI_WEIGHT_MAX,
1419 cb_notify_set_roam_beacon_rssi_weight, 0),
1420
1421 REG_DYNAMIC_VARIABLE(CFG_ROAMING_DFS_CHANNEL_NAME, WLAN_PARAM_Integer,
1422 struct hdd_config, allowDFSChannelRoam,
1423 VAR_FLAGS_OPTIONAL |
1424 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1425 CFG_ROAMING_DFS_CHANNEL_DEFAULT,
1426 CFG_ROAMING_DFS_CHANNEL_MIN,
1427 CFG_ROAMING_DFS_CHANNEL_MAX,
1428 cb_notify_set_dfs_scan_mode, 0),
1429
1430 REG_DYNAMIC_VARIABLE(CFG_DELAY_BEFORE_VDEV_STOP_NAME,
1431 WLAN_PARAM_Integer,
1432 struct hdd_config,
1433 delay_before_vdev_stop,
1434 VAR_FLAGS_OPTIONAL |
1435 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1436 CFG_DELAY_BEFORE_VDEV_STOP_DEFAULT,
1437 CFG_DELAY_BEFORE_VDEV_STOP_MIN,
1438 CFG_DELAY_BEFORE_VDEV_STOP_MAX,
1439 cb_notify_set_delay_before_vdev_stop,
1440 0),
1441
1442 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_HI_RSSI_MAXCOUNT_NAME,
1443 WLAN_PARAM_Integer,
1444 struct hdd_config,
1445 nhi_rssi_scan_max_count,
1446 VAR_FLAGS_OPTIONAL |
1447 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1448 CFG_ROAM_SCAN_HI_RSSI_MAXCOUNT_DEFAULT,
1449 CFG_ROAM_SCAN_HI_RSSI_MAXCOUNT_MIN,
1450 CFG_ROAM_SCAN_HI_RSSI_MAXCOUNT_MAX,
1451 cb_notify_set_roam_scan_hi_rssi_scan_params,
1452 eCSR_HI_RSSI_SCAN_MAXCOUNT_ID),
1453
1454 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_HI_RSSI_DELTA_NAME,
1455 WLAN_PARAM_Integer,
1456 struct hdd_config,
1457 nhi_rssi_scan_rssi_delta,
1458 VAR_FLAGS_OPTIONAL |
1459 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1460 CFG_ROAM_SCAN_HI_RSSI_DELTA_DEFAULT,
1461 CFG_ROAM_SCAN_HI_RSSI_DELTA_MIN,
1462 CFG_ROAM_SCAN_HI_RSSI_DELTA_MAX,
1463 cb_notify_set_roam_scan_hi_rssi_scan_params,
1464 eCSR_HI_RSSI_SCAN_RSSI_DELTA_ID),
1465
1466 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_HI_RSSI_DELAY_NAME,
1467 WLAN_PARAM_Integer,
1468 struct hdd_config,
1469 nhi_rssi_scan_delay,
1470 VAR_FLAGS_OPTIONAL |
1471 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1472 CFG_ROAM_SCAN_HI_RSSI_DELAY_DEFAULT,
1473 CFG_ROAM_SCAN_HI_RSSI_DELAY_MIN,
1474 CFG_ROAM_SCAN_HI_RSSI_DELAY_MAX,
1475 cb_notify_set_roam_scan_hi_rssi_scan_params,
1476 eCSR_HI_RSSI_SCAN_DELAY_ID),
1477
1478 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_HI_RSSI_UB_NAME,
1479 WLAN_PARAM_SignedInteger,
1480 struct hdd_config,
1481 nhi_rssi_scan_rssi_ub,
1482 VAR_FLAGS_OPTIONAL |
1483 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1484 CFG_ROAM_SCAN_HI_RSSI_UB_DEFAULT,
1485 CFG_ROAM_SCAN_HI_RSSI_UB_MIN,
1486 CFG_ROAM_SCAN_HI_RSSI_UB_MAX,
1487 cb_notify_set_roam_scan_hi_rssi_scan_params,
1488 eCSR_HI_RSSI_SCAN_RSSI_UB_ID),
1489
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001490 REG_VARIABLE(CFG_QOS_WMM_BURST_SIZE_DEFN_NAME, WLAN_PARAM_Integer,
1491 struct hdd_config, burstSizeDefinition,
1492 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1493 CFG_QOS_WMM_BURST_SIZE_DEFN_DEFAULT,
1494 CFG_QOS_WMM_BURST_SIZE_DEFN_MIN,
1495 CFG_QOS_WMM_BURST_SIZE_DEFN_MAX),
1496
1497 REG_VARIABLE(CFG_MCAST_BCAST_FILTER_SETTING_NAME, WLAN_PARAM_Integer,
1498 struct hdd_config, mcastBcastFilterSetting,
1499 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1500 CFG_MCAST_BCAST_FILTER_SETTING_DEFAULT,
1501 CFG_MCAST_BCAST_FILTER_SETTING_MIN,
1502 CFG_MCAST_BCAST_FILTER_SETTING_MAX),
1503
1504 REG_VARIABLE(CFG_ENABLE_HOST_ARPOFFLOAD_NAME, WLAN_PARAM_Integer,
1505 struct hdd_config, fhostArpOffload,
1506 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1507 CFG_ENABLE_HOST_ARPOFFLOAD_DEFAULT,
1508 CFG_ENABLE_HOST_ARPOFFLOAD_MIN,
1509 CFG_ENABLE_HOST_ARPOFFLOAD_MAX),
1510
1511#ifdef FEATURE_WLAN_RA_FILTERING
1512 REG_VARIABLE(CFG_RA_FILTER_ENABLE_NAME, WLAN_PARAM_Integer,
1513 struct hdd_config, IsRArateLimitEnabled,
1514 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1515 CFG_RA_FILTER_ENABLE_DEFAULT,
1516 CFG_RA_FILTER_ENABLE_MIN,
1517 CFG_RA_FILTER_ENABLE_MAX),
1518
1519 REG_VARIABLE(CFG_RA_RATE_LIMIT_INTERVAL_NAME, WLAN_PARAM_Integer,
1520 struct hdd_config, RArateLimitInterval,
1521 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1522 CFG_RA_RATE_LIMIT_INTERVAL_DEFAULT,
1523 CFG_RA_RATE_LIMIT_INTERVAL_MIN,
1524 CFG_RA_RATE_LIMIT_INTERVAL_MAX),
1525#endif
1526
1527 REG_VARIABLE(CFG_IGNORE_PEER_ERP_INFO_NAME, WLAN_PARAM_Integer,
1528 struct hdd_config, ignore_peer_erp_info,
1529 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1530 CFG_IGNORE_PEER_ERP_INFO_DEFAULT,
1531 CFG_IGNORE_PEER_ERP_INFO_MIN,
1532 CFG_IGNORE_PEER_ERP_INFO_MAX),
1533
1534 REG_VARIABLE(CFG_ENABLE_HOST_SSDP_NAME, WLAN_PARAM_Integer,
1535 struct hdd_config, ssdp,
1536 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1537 CFG_ENABLE_HOST_SSDP_DEFAULT,
1538 CFG_ENABLE_HOST_SSDP_MIN,
1539 CFG_ENABLE_HOST_SSDP_MAX),
1540
Houston Hoffmanc7c69f02016-03-24 22:45:52 -07001541#ifdef FEATURE_RUNTIME_PM
1542 REG_VARIABLE(CFG_ENABLE_RUNTIME_PM, WLAN_PARAM_Integer,
1543 struct hdd_config, runtime_pm,
1544 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1545 CFG_ENABLE_RUNTIME_PM_DEFAULT,
1546 CFG_ENABLE_RUNTIME_PM_MIN,
1547 CFG_ENABLE_RUNTIME_PM_MAX),
1548
1549 REG_VARIABLE(CFG_RUNTIME_PM_DELAY_NAME, WLAN_PARAM_Integer,
1550 struct hdd_config, runtime_pm_delay,
1551 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1552 CFG_RUNTIME_PM_DELAY_DEFAULT,
1553 CFG_RUNTIME_PM_DELAY_MIN,
1554 CFG_RUNTIME_PM_DELAY_MAX),
1555#endif
1556
1557
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001558 REG_VARIABLE(CFG_ENABLE_HOST_NSOFFLOAD_NAME, WLAN_PARAM_Integer,
1559 struct hdd_config, fhostNSOffload,
1560 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1561 CFG_ENABLE_HOST_NSOFFLOAD_DEFAULT,
1562 CFG_ENABLE_HOST_NSOFFLOAD_MIN,
1563 CFG_ENABLE_HOST_NSOFFLOAD_MAX),
1564
1565 REG_VARIABLE(CFG_QOS_WMM_TS_INFO_ACK_POLICY_NAME, WLAN_PARAM_HexInteger,
1566 struct hdd_config, tsInfoAckPolicy,
1567 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1568 CFG_QOS_WMM_TS_INFO_ACK_POLICY_DEFAULT,
1569 CFG_QOS_WMM_TS_INFO_ACK_POLICY_MIN,
1570 CFG_QOS_WMM_TS_INFO_ACK_POLICY_MAX),
1571
1572 REG_VARIABLE(CFG_SINGLE_TID_RC_NAME, WLAN_PARAM_Integer,
1573 struct hdd_config, bSingleTidRc,
1574 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1575 CFG_SINGLE_TID_RC_DEFAULT,
1576 CFG_SINGLE_TID_RC_MIN,
1577 CFG_SINGLE_TID_RC_MAX),
1578
1579 REG_VARIABLE(CFG_DYNAMIC_PSPOLL_VALUE_NAME, WLAN_PARAM_Integer,
1580 struct hdd_config, dynamicPsPollValue,
1581 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1582 CFG_DYNAMIC_PSPOLL_VALUE_DEFAULT,
1583 CFG_DYNAMIC_PSPOLL_VALUE_MIN,
1584 CFG_DYNAMIC_PSPOLL_VALUE_MAX),
1585
1586 REG_VARIABLE(CFG_TELE_BCN_WAKEUP_EN_NAME, WLAN_PARAM_Integer,
1587 struct hdd_config, teleBcnWakeupEn,
1588 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1589 CFG_TELE_BCN_WAKEUP_EN_DEFAULT,
1590 CFG_TELE_BCN_WAKEUP_EN_MIN,
1591 CFG_TELE_BCN_WAKEUP_EN_MAX),
1592
1593 REG_VARIABLE(CFG_INFRA_STA_KEEP_ALIVE_PERIOD_NAME, WLAN_PARAM_Integer,
1594 struct hdd_config, infraStaKeepAlivePeriod,
1595 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1596 CFG_INFRA_STA_KEEP_ALIVE_PERIOD_DEFAULT,
1597 CFG_INFRA_STA_KEEP_ALIVE_PERIOD_MIN,
1598 CFG_INFRA_STA_KEEP_ALIVE_PERIOD_MAX),
1599
1600 REG_VARIABLE(CFG_QOS_ADDTS_WHEN_ACM_IS_OFF_NAME, WLAN_PARAM_Integer,
1601 struct hdd_config, AddTSWhenACMIsOff,
1602 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1603 CFG_QOS_ADDTS_WHEN_ACM_IS_OFF_DEFAULT,
1604 CFG_QOS_ADDTS_WHEN_ACM_IS_OFF_MIN,
1605 CFG_QOS_ADDTS_WHEN_ACM_IS_OFF_MAX),
1606
1607 REG_VARIABLE(CFG_VALIDATE_SCAN_LIST_NAME, WLAN_PARAM_Integer,
1608 struct hdd_config, fValidateScanList,
1609 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1610 CFG_VALIDATE_SCAN_LIST_DEFAULT,
1611 CFG_VALIDATE_SCAN_LIST_MIN,
1612 CFG_VALIDATE_SCAN_LIST_MAX),
1613
1614 REG_VARIABLE(CFG_NULLDATA_AP_RESP_TIMEOUT_NAME, WLAN_PARAM_Integer,
1615 struct hdd_config, nNullDataApRespTimeout,
1616 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1617 CFG_NULLDATA_AP_RESP_TIMEOUT_DEFAULT,
1618 CFG_NULLDATA_AP_RESP_TIMEOUT_MIN,
1619 CFG_NULLDATA_AP_RESP_TIMEOUT_MAX),
1620
1621 REG_VARIABLE(CFG_AP_DATA_AVAIL_POLL_PERIOD_NAME, WLAN_PARAM_Integer,
1622 struct hdd_config, apDataAvailPollPeriodInMs,
1623 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1624 CFG_AP_DATA_AVAIL_POLL_PERIOD_DEFAULT,
1625 CFG_AP_DATA_AVAIL_POLL_PERIOD_MIN,
1626 CFG_AP_DATA_AVAIL_POLL_PERIOD_MAX),
1627
1628 REG_VARIABLE(CFG_BAND_CAPABILITY_NAME, WLAN_PARAM_Integer,
1629 struct hdd_config, nBandCapability,
1630 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1631 CFG_BAND_CAPABILITY_DEFAULT,
1632 CFG_BAND_CAPABILITY_MIN,
1633 CFG_BAND_CAPABILITY_MAX),
1634
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301635/* CFG_QDF_TRACE_ENABLE Parameters */
1636 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_WDI_NAME, WLAN_PARAM_Integer,
1637 struct hdd_config, qdf_trace_enable_wdi,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001638 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301639 CFG_QDF_TRACE_ENABLE_DEFAULT,
1640 CFG_QDF_TRACE_ENABLE_MIN,
1641 CFG_QDF_TRACE_ENABLE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001642
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301643 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_HDD_NAME, WLAN_PARAM_Integer,
1644 struct hdd_config, qdf_trace_enable_hdd,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001645 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301646 CFG_QDF_TRACE_ENABLE_DEFAULT,
1647 CFG_QDF_TRACE_ENABLE_MIN,
1648 CFG_QDF_TRACE_ENABLE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001649
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301650 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_BMI_NAME, WLAN_PARAM_Integer,
1651 struct hdd_config, qdf_trace_enable_bmi,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001652 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301653 CFG_QDF_TRACE_ENABLE_DEFAULT,
1654 CFG_QDF_TRACE_ENABLE_MIN,
1655 CFG_QDF_TRACE_ENABLE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001656
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301657 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_SME_NAME, WLAN_PARAM_Integer,
1658 struct hdd_config, qdf_trace_enable_sme,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001659 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301660 CFG_QDF_TRACE_ENABLE_DEFAULT,
1661 CFG_QDF_TRACE_ENABLE_MIN,
1662 CFG_QDF_TRACE_ENABLE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001663
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301664 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_PE_NAME, WLAN_PARAM_Integer,
1665 struct hdd_config, qdf_trace_enable_pe,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001666 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301667 CFG_QDF_TRACE_ENABLE_DEFAULT,
1668 CFG_QDF_TRACE_ENABLE_MIN,
1669 CFG_QDF_TRACE_ENABLE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001670
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301671 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_WMA_NAME, WLAN_PARAM_Integer,
1672 struct hdd_config, qdf_trace_enable_wma,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001673 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301674 CFG_QDF_TRACE_ENABLE_DEFAULT,
1675 CFG_QDF_TRACE_ENABLE_MIN,
1676 CFG_QDF_TRACE_ENABLE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001677
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301678 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_SYS_NAME, WLAN_PARAM_Integer,
1679 struct hdd_config, qdf_trace_enable_sys,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001680 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301681 CFG_QDF_TRACE_ENABLE_DEFAULT,
1682 CFG_QDF_TRACE_ENABLE_MIN,
1683 CFG_QDF_TRACE_ENABLE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001684
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301685 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_QDF_NAME, WLAN_PARAM_Integer,
1686 struct hdd_config, qdf_trace_enable_qdf,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001687 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301688 CFG_QDF_TRACE_ENABLE_DEFAULT,
1689 CFG_QDF_TRACE_ENABLE_MIN,
1690 CFG_QDF_TRACE_ENABLE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001691
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301692 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_SAP_NAME, WLAN_PARAM_Integer,
1693 struct hdd_config, qdf_trace_enable_sap,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001694 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301695 CFG_QDF_TRACE_ENABLE_DEFAULT,
1696 CFG_QDF_TRACE_ENABLE_MIN,
1697 CFG_QDF_TRACE_ENABLE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001698
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301699 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_HDD_SAP_NAME, WLAN_PARAM_Integer,
1700 struct hdd_config, qdf_trace_enable_hdd_sap,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001701 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301702 CFG_QDF_TRACE_ENABLE_DEFAULT,
1703 CFG_QDF_TRACE_ENABLE_MIN,
1704 CFG_QDF_TRACE_ENABLE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001705
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301706 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_CFG_NAME, WLAN_PARAM_Integer,
1707 struct hdd_config, qdf_trace_enable_cfg,
Bhargav Shah480a90f2015-06-24 15:10:14 +05301708 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301709 CFG_QDF_TRACE_ENABLE_DEFAULT,
1710 CFG_QDF_TRACE_ENABLE_MIN,
1711 CFG_QDF_TRACE_ENABLE_MAX),
Bhargav Shah480a90f2015-06-24 15:10:14 +05301712
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301713 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_TXRX_NAME, WLAN_PARAM_Integer,
Bhargav Shah480a90f2015-06-24 15:10:14 +05301714 struct hdd_config, cfd_trace_enable_txrx,
1715 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301716 CFG_QDF_TRACE_ENABLE_DEFAULT,
1717 CFG_QDF_TRACE_ENABLE_MIN,
1718 CFG_QDF_TRACE_ENABLE_MAX),
Bhargav Shah480a90f2015-06-24 15:10:14 +05301719
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301720 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_HTC_NAME, WLAN_PARAM_Integer,
1721 struct hdd_config, qdf_trace_enable_htc,
Bhargav Shah480a90f2015-06-24 15:10:14 +05301722 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301723 CFG_QDF_TRACE_ENABLE_DEFAULT,
1724 CFG_QDF_TRACE_ENABLE_MIN,
1725 CFG_QDF_TRACE_ENABLE_MAX),
Bhargav Shah480a90f2015-06-24 15:10:14 +05301726
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301727 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_HIF_NAME, WLAN_PARAM_Integer,
1728 struct hdd_config, qdf_trace_enable_hif,
Bhargav Shah480a90f2015-06-24 15:10:14 +05301729 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301730 CFG_QDF_TRACE_ENABLE_DEFAULT,
1731 CFG_QDF_TRACE_ENABLE_MIN,
1732 CFG_QDF_TRACE_ENABLE_MAX),
Bhargav Shah480a90f2015-06-24 15:10:14 +05301733
1734 REG_VARIABLE(CFG_CDR_TRACE_ENABLE_HDD_SAP_DATA_NAME, WLAN_PARAM_Integer,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301735 struct hdd_config, qdf_trace_enable_hdd_sap_data,
Bhargav Shah480a90f2015-06-24 15:10:14 +05301736 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301737 CFG_QDF_TRACE_ENABLE_DEFAULT,
1738 CFG_QDF_TRACE_ENABLE_MIN,
1739 CFG_QDF_TRACE_ENABLE_MAX),
Bhargav Shah480a90f2015-06-24 15:10:14 +05301740
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301741 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_HDD_DATA_NAME, WLAN_PARAM_Integer,
1742 struct hdd_config, qdf_trace_enable_hdd_data,
Bhargav Shah480a90f2015-06-24 15:10:14 +05301743 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301744 CFG_QDF_TRACE_ENABLE_DEFAULT,
1745 CFG_QDF_TRACE_ENABLE_MIN,
1746 CFG_QDF_TRACE_ENABLE_MAX),
Bhargav Shah480a90f2015-06-24 15:10:14 +05301747
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301748 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_EPPING, WLAN_PARAM_Integer,
1749 struct hdd_config, qdf_trace_enable_epping,
Bhargav Shah480a90f2015-06-24 15:10:14 +05301750 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301751 CFG_QDF_TRACE_ENABLE_DEFAULT,
1752 CFG_QDF_TRACE_ENABLE_MIN,
1753 CFG_QDF_TRACE_ENABLE_MAX),
Bhargav Shah480a90f2015-06-24 15:10:14 +05301754
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301755 REG_VARIABLE(CFG_QDF_TRACE_ENABLE_QDF_DEVICES, WLAN_PARAM_Integer,
1756 struct hdd_config, qdf_trace_enable_qdf_devices,
Bhargav Shah480a90f2015-06-24 15:10:14 +05301757 VAR_FLAGS_OPTIONAL,
Anurag Chouhanf04e84f2016-03-03 10:12:12 +05301758 CFG_QDF_TRACE_ENABLE_DEFAULT,
1759 CFG_QDF_TRACE_ENABLE_MIN,
1760 CFG_QDF_TRACE_ENABLE_MAX),
Bhargav Shah480a90f2015-06-24 15:10:14 +05301761
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001762 REG_VARIABLE(CFG_TELE_BCN_TRANS_LI_NAME, WLAN_PARAM_Integer,
1763 struct hdd_config, nTeleBcnTransListenInterval,
1764 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1765 CFG_TELE_BCN_TRANS_LI_DEFAULT,
1766 CFG_TELE_BCN_TRANS_LI_MIN,
1767 CFG_TELE_BCN_TRANS_LI_MAX),
1768
1769 REG_VARIABLE(CFG_TELE_BCN_TRANS_LI_NUM_IDLE_BCNS_NAME,
1770 WLAN_PARAM_Integer,
1771 struct hdd_config, nTeleBcnTransLiNumIdleBeacons,
1772 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1773 CFG_TELE_BCN_TRANS_LI_NUM_IDLE_BCNS_DEFAULT,
1774 CFG_TELE_BCN_TRANS_LI_NUM_IDLE_BCNS_MIN,
1775 CFG_TELE_BCN_TRANS_LI_NUM_IDLE_BCNS_MAX),
1776
1777 REG_VARIABLE(CFG_TELE_BCN_MAX_LI_NAME, WLAN_PARAM_Integer,
1778 struct hdd_config, nTeleBcnMaxListenInterval,
1779 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1780 CFG_TELE_BCN_MAX_LI_DEFAULT,
1781 CFG_TELE_BCN_MAX_LI_MIN,
1782 CFG_TELE_BCN_MAX_LI_MAX),
1783
1784 REG_VARIABLE(CFG_TELE_BCN_MAX_LI_NUM_IDLE_BCNS_NAME, WLAN_PARAM_Integer,
1785 struct hdd_config, nTeleBcnMaxLiNumIdleBeacons,
1786 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1787 CFG_TELE_BCN_MAX_LI_NUM_IDLE_BCNS_DEFAULT,
1788 CFG_TELE_BCN_MAX_LI_NUM_IDLE_BCNS_MIN,
1789 CFG_TELE_BCN_MAX_LI_NUM_IDLE_BCNS_MAX),
1790
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001791 REG_VARIABLE(CFG_AP_DATA_AVAIL_POLL_PERIOD_NAME, WLAN_PARAM_Integer,
1792 struct hdd_config, apDataAvailPollPeriodInMs,
1793 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1794 CFG_AP_DATA_AVAIL_POLL_PERIOD_DEFAULT,
1795 CFG_AP_DATA_AVAIL_POLL_PERIOD_MIN,
1796 CFG_AP_DATA_AVAIL_POLL_PERIOD_MAX),
1797
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001798 REG_VARIABLE(CFG_ENABLE_BYPASS_11D_NAME, WLAN_PARAM_Integer,
1799 struct hdd_config, enableBypass11d,
1800 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1801 CFG_ENABLE_BYPASS_11D_DEFAULT,
1802 CFG_ENABLE_BYPASS_11D_MIN,
1803 CFG_ENABLE_BYPASS_11D_MAX),
1804
1805 REG_VARIABLE(CFG_ENABLE_DFS_CHNL_SCAN_NAME, WLAN_PARAM_Integer,
1806 struct hdd_config, enableDFSChnlScan,
1807 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1808 CFG_ENABLE_DFS_CHNL_SCAN_DEFAULT,
1809 CFG_ENABLE_DFS_CHNL_SCAN_MIN,
1810 CFG_ENABLE_DFS_CHNL_SCAN_MAX),
1811
1812 REG_VARIABLE(CFG_ENABLE_DFS_PNO_CHNL_SCAN_NAME, WLAN_PARAM_Integer,
1813 struct hdd_config, enable_dfs_pno_chnl_scan,
1814 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1815 CFG_ENABLE_DFS_PNO_CHNL_SCAN_DEFAULT,
1816 CFG_ENABLE_DFS_PNO_CHNL_SCAN_MIN,
1817 CFG_ENABLE_DFS_PNO_CHNL_SCAN_MAX),
1818
1819 REG_VARIABLE(CFG_ENABLE_DYNAMIC_DTIM_NAME, WLAN_PARAM_Integer,
1820 struct hdd_config, enableDynamicDTIM,
1821 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1822 CFG_ENABLE_DYNAMIC_DTIM_DEFAULT,
1823 CFG_ENABLE_DYNAMIC_DTIM_MIN,
1824 CFG_ENABLE_DYNAMIC_DTIM_MAX),
1825
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001826 REG_VARIABLE(CFG_SHORT_GI_40MHZ_NAME, WLAN_PARAM_Integer,
1827 struct hdd_config, ShortGI40MhzEnable,
1828 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1829 CFG_SHORT_GI_40MHZ_DEFAULT,
1830 CFG_SHORT_GI_40MHZ_MIN,
1831 CFG_SHORT_GI_40MHZ_MAX),
1832
1833 REG_DYNAMIC_VARIABLE(CFG_REPORT_MAX_LINK_SPEED, WLAN_PARAM_Integer,
1834 struct hdd_config, reportMaxLinkSpeed,
1835 VAR_FLAGS_OPTIONAL |
1836 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1837 CFG_REPORT_MAX_LINK_SPEED_DEFAULT,
1838 CFG_REPORT_MAX_LINK_SPEED_MIN,
1839 CFG_REPORT_MAX_LINK_SPEED_MAX,
1840 NULL, 0),
1841
1842 REG_DYNAMIC_VARIABLE(CFG_LINK_SPEED_RSSI_HIGH, WLAN_PARAM_SignedInteger,
1843 struct hdd_config, linkSpeedRssiHigh,
1844 VAR_FLAGS_OPTIONAL |
1845 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1846 CFG_LINK_SPEED_RSSI_HIGH_DEFAULT,
1847 CFG_LINK_SPEED_RSSI_HIGH_MIN,
1848 CFG_LINK_SPEED_RSSI_HIGH_MAX,
1849 NULL, 0),
1850
1851 REG_DYNAMIC_VARIABLE(CFG_LINK_SPEED_RSSI_MID, WLAN_PARAM_SignedInteger,
1852 struct hdd_config, linkSpeedRssiMid,
1853 VAR_FLAGS_OPTIONAL |
1854 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1855 CFG_LINK_SPEED_RSSI_MID_DEFAULT,
1856 CFG_LINK_SPEED_RSSI_MID_MIN,
1857 CFG_LINK_SPEED_RSSI_MID_MAX,
1858 NULL, 0),
1859
1860 REG_DYNAMIC_VARIABLE(CFG_LINK_SPEED_RSSI_LOW, WLAN_PARAM_SignedInteger,
1861 struct hdd_config, linkSpeedRssiLow,
1862 VAR_FLAGS_OPTIONAL |
1863 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1864 CFG_LINK_SPEED_RSSI_LOW_DEFAULT,
1865 CFG_LINK_SPEED_RSSI_LOW_MIN,
1866 CFG_LINK_SPEED_RSSI_LOW_MAX,
1867 NULL, 0),
1868
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001869 REG_DYNAMIC_VARIABLE(CFG_ROAM_PREFER_5GHZ, WLAN_PARAM_Integer,
1870 struct hdd_config, nRoamPrefer5GHz,
1871 VAR_FLAGS_OPTIONAL |
1872 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1873 CFG_ROAM_PREFER_5GHZ_DEFAULT,
1874 CFG_ROAM_PREFER_5GHZ_MIN,
1875 CFG_ROAM_PREFER_5GHZ_MAX,
1876 cb_notify_set_roam_prefer5_g_hz, 0),
1877
1878 REG_DYNAMIC_VARIABLE(CFG_ROAM_INTRA_BAND, WLAN_PARAM_Integer,
1879 struct hdd_config, nRoamIntraBand,
1880 VAR_FLAGS_OPTIONAL |
1881 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1882 CFG_ROAM_INTRA_BAND_DEFAULT,
1883 CFG_ROAM_INTRA_BAND_MIN,
1884 CFG_ROAM_INTRA_BAND_MAX,
1885 cb_notify_set_roam_intra_band, 0),
1886
1887 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_N_PROBES, WLAN_PARAM_Integer,
1888 struct hdd_config, nProbes,
1889 VAR_FLAGS_OPTIONAL |
1890 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1891 CFG_ROAM_SCAN_N_PROBES_DEFAULT,
1892 CFG_ROAM_SCAN_N_PROBES_MIN,
1893 CFG_ROAM_SCAN_N_PROBES_MAX,
1894 cb_notify_set_roam_scan_n_probes, 0),
1895
1896 REG_DYNAMIC_VARIABLE(CFG_ROAM_SCAN_HOME_AWAY_TIME, WLAN_PARAM_Integer,
1897 struct hdd_config, nRoamScanHomeAwayTime,
1898 VAR_FLAGS_OPTIONAL |
1899 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1900 CFG_ROAM_SCAN_HOME_AWAY_TIME_DEFAULT,
1901 CFG_ROAM_SCAN_HOME_AWAY_TIME_MIN,
1902 CFG_ROAM_SCAN_HOME_AWAY_TIME_MAX,
1903 cb_notify_set_roam_scan_home_away_time, 0),
1904
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001905 REG_VARIABLE(CFG_P2P_DEVICE_ADDRESS_ADMINISTRATED_NAME,
1906 WLAN_PARAM_Integer,
1907 struct hdd_config, isP2pDeviceAddrAdministrated,
1908 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1909 CFG_P2P_DEVICE_ADDRESS_ADMINISTRATED_DEFAULT,
1910 CFG_P2P_DEVICE_ADDRESS_ADMINISTRATED_MIN,
1911 CFG_P2P_DEVICE_ADDRESS_ADMINISTRATED_MAX),
1912
1913 REG_VARIABLE(CFG_ENABLE_MCC_ENABLED_NAME, WLAN_PARAM_Integer,
1914 struct hdd_config, enableMCC,
1915 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1916 CFG_ENABLE_MCC_ENABLED_DEFAULT,
1917 CFG_ENABLE_MCC_ENABLED_MIN,
1918 CFG_ENABLE_MCC_ENABLED_MAX),
1919
1920 REG_VARIABLE(CFG_ALLOW_MCC_GO_DIFF_BI_NAME, WLAN_PARAM_Integer,
1921 struct hdd_config, allowMCCGODiffBI,
1922 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1923 CFG_ALLOW_MCC_GO_DIFF_BI_DEFAULT,
1924 CFG_ALLOW_MCC_GO_DIFF_BI_MIN,
1925 CFG_ALLOW_MCC_GO_DIFF_BI_MAX),
1926
1927 REG_VARIABLE(CFG_THERMAL_MIGRATION_ENABLE_NAME, WLAN_PARAM_Integer,
1928 struct hdd_config, thermalMitigationEnable,
1929 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1930 CFG_THERMAL_MIGRATION_ENABLE_DEFAULT,
1931 CFG_THERMAL_MIGRATION_ENABLE_MIN,
1932 CFG_THERMAL_MIGRATION_ENABLE_MAX),
1933
1934 REG_VARIABLE(CFG_THROTTLE_PERIOD_NAME, WLAN_PARAM_Integer,
1935 struct hdd_config, throttlePeriod,
1936 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1937 CFG_THROTTLE_PERIOD_DEFAULT,
1938 CFG_THROTTLE_PERIOD_MIN,
1939 CFG_THROTTLE_PERIOD_MAX),
1940
Poddar, Siddarth83905022016-04-16 17:56:08 -07001941 REG_VARIABLE(CFG_THROTTLE_DUTY_CYCLE_LEVEL0_NAME, WLAN_PARAM_Integer,
1942 struct hdd_config, throttle_dutycycle_level0,
1943 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1944 CFG_THROTTLE_DUTY_CYCLE_LEVEL0_DEFAULT,
1945 CFG_THROTTLE_DUTY_CYCLE_LEVEL0_MIN,
1946 CFG_THROTTLE_DUTY_CYCLE_LEVEL0_MAX),
1947
1948 REG_VARIABLE(CFG_THROTTLE_DUTY_CYCLE_LEVEL1_NAME, WLAN_PARAM_Integer,
1949 struct hdd_config, throttle_dutycycle_level1,
1950 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1951 CFG_THROTTLE_DUTY_CYCLE_LEVEL1_DEFAULT,
1952 CFG_THROTTLE_DUTY_CYCLE_LEVEL1_MIN,
1953 CFG_THROTTLE_DUTY_CYCLE_LEVEL1_MAX),
1954
1955 REG_VARIABLE(CFG_THROTTLE_DUTY_CYCLE_LEVEL2_NAME, WLAN_PARAM_Integer,
1956 struct hdd_config, throttle_dutycycle_level2,
1957 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1958 CFG_THROTTLE_DUTY_CYCLE_LEVEL2_DEFAULT,
1959 CFG_THROTTLE_DUTY_CYCLE_LEVEL2_MIN,
1960 CFG_THROTTLE_DUTY_CYCLE_LEVEL2_MAX),
1961
1962 REG_VARIABLE(CFG_THROTTLE_DUTY_CYCLE_LEVEL3_NAME, WLAN_PARAM_Integer,
1963 struct hdd_config, throttle_dutycycle_level3,
1964 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1965 CFG_THROTTLE_DUTY_CYCLE_LEVEL3_DEFAULT,
1966 CFG_THROTTLE_DUTY_CYCLE_LEVEL3_MIN,
1967 CFG_THROTTLE_DUTY_CYCLE_LEVEL3_MAX),
1968
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001969 REG_VARIABLE(CFG_ENABLE_MODULATED_DTIM_NAME, WLAN_PARAM_Integer,
1970 struct hdd_config, enableModulatedDTIM,
1971 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1972 CFG_ENABLE_MODULATED_DTIM_DEFAULT,
1973 CFG_ENABLE_MODULATED_DTIM_MIN,
1974 CFG_ENABLE_MODULATED_DTIM_MAX),
1975
1976 REG_VARIABLE(CFG_MC_ADDR_LIST_ENABLE_NAME, WLAN_PARAM_Integer,
1977 struct hdd_config, fEnableMCAddrList,
1978 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
1979 CFG_MC_ADDR_LIST_ENABLE_DEFAULT,
1980 CFG_MC_ADDR_LIST_ENABLE_MIN,
1981 CFG_MC_ADDR_LIST_ENABLE_MAX),
1982
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001983 REG_VARIABLE(CFG_VHT_CHANNEL_WIDTH, WLAN_PARAM_Integer,
1984 struct hdd_config, vhtChannelWidth,
1985 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
1986 CFG_VHT_CHANNEL_WIDTH_DEFAULT,
1987 CFG_VHT_CHANNEL_WIDTH_MIN,
1988 CFG_VHT_CHANNEL_WIDTH_MAX),
1989
1990 REG_VARIABLE(CFG_VHT_ENABLE_RX_MCS_8_9, WLAN_PARAM_Integer,
1991 struct hdd_config, vhtRxMCS,
1992 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
1993 CFG_VHT_ENABLE_RX_MCS_8_9_DEFAULT,
1994 CFG_VHT_ENABLE_RX_MCS_8_9_MIN,
1995 CFG_VHT_ENABLE_RX_MCS_8_9_MAX),
1996
1997 REG_VARIABLE(CFG_VHT_ENABLE_TX_MCS_8_9, WLAN_PARAM_Integer,
1998 struct hdd_config, vhtTxMCS,
1999 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2000 CFG_VHT_ENABLE_TX_MCS_8_9_DEFAULT,
2001 CFG_VHT_ENABLE_TX_MCS_8_9_MIN,
2002 CFG_VHT_ENABLE_TX_MCS_8_9_MAX),
2003
2004 REG_VARIABLE(CFG_VHT_ENABLE_RX_MCS2x2_8_9, WLAN_PARAM_Integer,
2005 struct hdd_config, vhtRxMCS2x2,
2006 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2007 CFG_VHT_ENABLE_RX_MCS2x2_8_9_DEFAULT,
2008 CFG_VHT_ENABLE_RX_MCS2x2_8_9_MIN,
2009 CFG_VHT_ENABLE_RX_MCS2x2_8_9_MAX),
2010
2011 REG_VARIABLE(CFG_VHT_ENABLE_TX_MCS2x2_8_9, WLAN_PARAM_Integer,
2012 struct hdd_config, vhtTxMCS2x2,
2013 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2014 CFG_VHT_ENABLE_TX_MCS2x2_8_9_DEFAULT,
2015 CFG_VHT_ENABLE_TX_MCS2x2_8_9_MIN,
2016 CFG_VHT_ENABLE_TX_MCS2x2_8_9_MAX),
2017
2018 REG_VARIABLE(CFG_VHT_ENABLE_2x2_CAP_FEATURE, WLAN_PARAM_Integer,
2019 struct hdd_config, enable2x2,
2020 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2021 CFG_VHT_ENABLE_2x2_CAP_FEATURE_DEFAULT,
2022 CFG_VHT_ENABLE_2x2_CAP_FEATURE_MIN,
2023 CFG_VHT_ENABLE_2x2_CAP_FEATURE_MAX),
2024
Kiran Kumar Lokere666bf852016-05-02 12:23:02 -07002025 REG_VARIABLE(CFG_VDEV_TYPE_NSS_2G, WLAN_PARAM_Integer,
2026 struct hdd_config, vdev_type_nss_2g,
2027 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2028 CFG_VDEV_TYPE_NSS_2G_DEFAULT,
2029 CFG_VDEV_TYPE_NSS_2G_MIN,
2030 CFG_VDEV_TYPE_NSS_2G_MAX),
2031
2032 REG_VARIABLE(CFG_VDEV_TYPE_NSS_5G, WLAN_PARAM_Integer,
2033 struct hdd_config, vdev_type_nss_5g,
2034 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2035 CFG_VDEV_TYPE_NSS_5G_DEFAULT,
2036 CFG_VDEV_TYPE_NSS_5G_MIN,
2037 CFG_VDEV_TYPE_NSS_5G_MAX),
2038
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002039 REG_VARIABLE(CFG_VHT_ENABLE_MU_BFORMEE_CAP_FEATURE, WLAN_PARAM_Integer,
2040 struct hdd_config, enableMuBformee,
2041 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2042 CFG_VHT_ENABLE_MU_BFORMEE_CAP_FEATURE_DEFAULT,
2043 CFG_VHT_ENABLE_MU_BFORMEE_CAP_FEATURE_MIN,
2044 CFG_VHT_ENABLE_MU_BFORMEE_CAP_FEATURE_MAX),
2045
2046 REG_VARIABLE(CFG_VHT_ENABLE_PAID_FEATURE, WLAN_PARAM_Integer,
2047 struct hdd_config, enableVhtpAid,
2048 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2049 CFG_VHT_ENABLE_PAID_FEATURE_DEFAULT,
2050 CFG_VHT_ENABLE_PAID_FEATURE_MIN,
2051 CFG_VHT_ENABLE_PAID_FEATURE_MAX),
2052
2053 REG_VARIABLE(CFG_VHT_ENABLE_GID_FEATURE, WLAN_PARAM_Integer,
2054 struct hdd_config, enableVhtGid,
2055 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2056 CFG_VHT_ENABLE_GID_FEATURE_DEFAULT,
2057 CFG_VHT_ENABLE_GID_FEATURE_MIN,
2058 CFG_VHT_ENABLE_GID_FEATURE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002059
2060 REG_VARIABLE(CFG_VHT_ENABLE_1x1_TX_CHAINMASK, WLAN_PARAM_Integer,
2061 struct hdd_config, txchainmask1x1,
2062 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2063 CFG_VHT_ENABLE_1x1_TX_CHAINMASK_DEFAULT,
2064 CFG_VHT_ENABLE_1x1_TX_CHAINMASK_MIN,
2065 CFG_VHT_ENABLE_1x1_TX_CHAINMASK_MAX),
2066
2067 REG_VARIABLE(CFG_VHT_ENABLE_1x1_RX_CHAINMASK, WLAN_PARAM_Integer,
2068 struct hdd_config, rxchainmask1x1,
2069 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2070 CFG_VHT_ENABLE_1x1_RX_CHAINMASK_DEFAULT,
2071 CFG_VHT_ENABLE_1x1_RX_CHAINMASK_MIN,
2072 CFG_VHT_ENABLE_1x1_RX_CHAINMASK_MAX),
2073
2074 REG_VARIABLE(CFG_ENABLE_AMPDUPS_FEATURE, WLAN_PARAM_Integer,
2075 struct hdd_config, enableAmpduPs,
2076 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2077 CFG_ENABLE_AMPDUPS_FEATURE_DEFAULT,
2078 CFG_ENABLE_AMPDUPS_FEATURE_MIN,
2079 CFG_ENABLE_AMPDUPS_FEATURE_MAX),
2080
2081 REG_VARIABLE(CFG_HT_ENABLE_SMPS_CAP_FEATURE, WLAN_PARAM_Integer,
2082 struct hdd_config, enableHtSmps,
2083 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2084 CFG_HT_ENABLE_SMPS_CAP_FEATURE_DEFAULT,
2085 CFG_HT_ENABLE_SMPS_CAP_FEATURE_MIN,
2086 CFG_HT_ENABLE_SMPS_CAP_FEATURE_MAX),
2087
2088 REG_VARIABLE(CFG_HT_SMPS_CAP_FEATURE, WLAN_PARAM_Integer,
2089 struct hdd_config, htSmps,
2090 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2091 CFG_HT_SMPS_CAP_FEATURE_DEFAULT,
2092 CFG_HT_SMPS_CAP_FEATURE_MIN,
2093 CFG_HT_SMPS_CAP_FEATURE_MAX),
2094
2095 REG_VARIABLE(CFG_DISABLE_DFS_CH_SWITCH, WLAN_PARAM_Integer,
2096 struct hdd_config, disableDFSChSwitch,
2097 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2098 CFG_DISABLE_DFS_CH_SWITCH_DEFAULT,
2099 CFG_DISABLE_DFS_CH_SWITCH_MIN,
2100 CFG_DISABLE_DFS_CH_SWITCH_MAX),
2101
2102 REG_VARIABLE(CFG_ENABLE_DFS_MASTER_CAPABILITY, WLAN_PARAM_Integer,
2103 struct hdd_config, enableDFSMasterCap,
2104 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2105 CFG_ENABLE_DFS_MASTER_CAPABILITY_DEFAULT,
2106 CFG_ENABLE_DFS_MASTER_CAPABILITY_MIN,
2107 CFG_ENABLE_DFS_MASTER_CAPABILITY_MAX),
2108
2109 REG_DYNAMIC_VARIABLE(CFG_SAP_PREFERRED_CHANNEL_LOCATION,
2110 WLAN_PARAM_Integer,
2111 struct hdd_config, gSapPreferredChanLocation,
2112 VAR_FLAGS_OPTIONAL |
2113 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2114 CFG_SAP_PREFERRED_CHANNEL_LOCATION_DEFAULT,
2115 CFG_SAP_PREFERRED_CHANNEL_LOCATION_MIN,
2116 CFG_SAP_PREFERRED_CHANNEL_LOCATION_MAX,
2117 cb_notify_set_g_sap_preferred_chan_location, 0),
2118 REG_DYNAMIC_VARIABLE(CFG_DISABLE_DFS_JAPAN_W53, WLAN_PARAM_Integer,
2119 struct hdd_config, gDisableDfsJapanW53,
2120 VAR_FLAGS_OPTIONAL |
2121 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2122 CFG_DISABLE_DFS_JAPAN_W53_DEFAULT,
2123 CFG_DISABLE_DFS_JAPAN_W53_MIN,
2124 CFG_DISABLE_DFS_JAPAN_W53_MAX,
2125 ch_notify_set_g_disable_dfs_japan_w53, 0),
2126 REG_VARIABLE(CFG_ENABLE_FIRST_SCAN_2G_ONLY_NAME, WLAN_PARAM_Integer,
2127 struct hdd_config, enableFirstScan2GOnly,
2128 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2129 CFG_ENABLE_FIRST_SCAN_2G_ONLY_DEFAULT,
2130 CFG_ENABLE_FIRST_SCAN_2G_ONLY_MIN,
2131 CFG_ENABLE_FIRST_SCAN_2G_ONLY_MAX),
2132
2133 REG_VARIABLE(CFG_ENABLE_SKIP_DFS_IN_P2P_SEARCH_NAME, WLAN_PARAM_Integer,
2134 struct hdd_config, skipDfsChnlInP2pSearch,
2135 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2136 CFG_ENABLE_SKIP_DFS_IN_P2P_SEARCH_DEFAULT,
2137 CFG_ENABLE_SKIP_DFS_IN_P2P_SEARCH_MIN,
2138 CFG_ENABLE_SKIP_DFS_IN_P2P_SEARCH_MAX),
2139
2140 REG_VARIABLE(CFG_IGNORE_DYNAMIC_DTIM_IN_P2P_MODE_NAME,
2141 WLAN_PARAM_Integer,
2142 struct hdd_config, ignoreDynamicDtimInP2pMode,
2143 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2144 CFG_IGNORE_DYNAMIC_DTIM_IN_P2P_MODE_DEFAULT,
2145 CFG_IGNORE_DYNAMIC_DTIM_IN_P2P_MODE_MIN,
2146 CFG_IGNORE_DYNAMIC_DTIM_IN_P2P_MODE_MAX),
2147
2148 REG_VARIABLE(CFG_ENABLE_RX_STBC, WLAN_PARAM_Integer,
2149 struct hdd_config, enableRxSTBC,
2150 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2151 CFG_ENABLE_RX_STBC_DEFAULT,
2152 CFG_ENABLE_RX_STBC_MIN,
2153 CFG_ENABLE_RX_STBC_MAX),
2154
2155 REG_VARIABLE(CFG_ENABLE_TX_STBC, WLAN_PARAM_Integer,
2156 struct hdd_config, enableTxSTBC,
2157 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2158 CFG_ENABLE_TX_STBC_DEFAULT,
2159 CFG_ENABLE_TX_STBC_MIN,
2160 CFG_ENABLE_TX_STBC_MAX),
2161
2162 REG_VARIABLE(CFG_ENABLE_RX_LDPC, WLAN_PARAM_Integer,
2163 struct hdd_config, enableRxLDPC,
2164 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2165 CFG_ENABLE_RX_LDPC_DEFAULT,
2166 CFG_ENABLE_RX_LDPC_MIN,
2167 CFG_ENABLE_RX_LDPC_MAX),
2168
2169 REG_VARIABLE(CFG_PPS_ENABLE_5G_EBT, WLAN_PARAM_Integer,
2170 struct hdd_config, enable5gEBT,
2171 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2172 CFG_PPS_ENABLE_5G_EBT_FEATURE_DEFAULT,
2173 CFG_PPS_ENABLE_5G_EBT_FEATURE_MIN,
2174 CFG_PPS_ENABLE_5G_EBT_FEATURE_MAX),
2175
2176#ifdef FEATURE_WLAN_TDLS
2177 REG_VARIABLE(CFG_TDLS_SUPPORT_ENABLE, WLAN_PARAM_Integer,
2178 struct hdd_config, fEnableTDLSSupport,
2179 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2180 CFG_TDLS_SUPPORT_ENABLE_DEFAULT,
2181 CFG_TDLS_SUPPORT_ENABLE_MIN,
2182 CFG_TDLS_SUPPORT_ENABLE_MAX),
2183
2184 REG_VARIABLE(CFG_TDLS_IMPLICIT_TRIGGER, WLAN_PARAM_Integer,
2185 struct hdd_config, fEnableTDLSImplicitTrigger,
2186 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2187 CFG_TDLS_IMPLICIT_TRIGGER_DEFAULT,
2188 CFG_TDLS_IMPLICIT_TRIGGER_MIN,
2189 CFG_TDLS_IMPLICIT_TRIGGER_MAX),
2190
2191 REG_VARIABLE(CFG_TDLS_TX_STATS_PERIOD, WLAN_PARAM_Integer,
2192 struct hdd_config, fTDLSTxStatsPeriod,
2193 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2194 CFG_TDLS_TX_STATS_PERIOD_DEFAULT,
2195 CFG_TDLS_TX_STATS_PERIOD_MIN,
2196 CFG_TDLS_TX_STATS_PERIOD_MAX),
2197
2198 REG_VARIABLE(CFG_TDLS_TX_PACKET_THRESHOLD, WLAN_PARAM_Integer,
2199 struct hdd_config, fTDLSTxPacketThreshold,
2200 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2201 CFG_TDLS_TX_PACKET_THRESHOLD_DEFAULT,
2202 CFG_TDLS_TX_PACKET_THRESHOLD_MIN,
2203 CFG_TDLS_TX_PACKET_THRESHOLD_MAX),
2204
2205 REG_VARIABLE(CFG_TDLS_MAX_DISCOVERY_ATTEMPT, WLAN_PARAM_Integer,
2206 struct hdd_config, fTDLSMaxDiscoveryAttempt,
2207 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2208 CFG_TDLS_MAX_DISCOVERY_ATTEMPT_DEFAULT,
2209 CFG_TDLS_MAX_DISCOVERY_ATTEMPT_MIN,
2210 CFG_TDLS_MAX_DISCOVERY_ATTEMPT_MAX),
2211
Kabilan Kannanca670be2015-11-23 01:56:12 -08002212 REG_VARIABLE(CFG_TDLS_IDLE_TIMEOUT, WLAN_PARAM_Integer,
2213 struct hdd_config, tdls_idle_timeout,
2214 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2215 CFG_TDLS_IDLE_TIMEOUT_DEFAULT,
2216 CFG_TDLS_IDLE_TIMEOUT_MIN,
2217 CFG_TDLS_IDLE_TIMEOUT_MAX),
2218
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002219 REG_VARIABLE(CFG_TDLS_IDLE_PACKET_THRESHOLD, WLAN_PARAM_Integer,
2220 struct hdd_config, fTDLSIdlePacketThreshold,
2221 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2222 CFG_TDLS_IDLE_PACKET_THRESHOLD_DEFAULT,
2223 CFG_TDLS_IDLE_PACKET_THRESHOLD_MIN,
2224 CFG_TDLS_IDLE_PACKET_THRESHOLD_MAX),
2225
2226 REG_VARIABLE(CFG_TDLS_RSSI_TRIGGER_THRESHOLD, WLAN_PARAM_SignedInteger,
2227 struct hdd_config, fTDLSRSSITriggerThreshold,
2228 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2229 CFG_TDLS_RSSI_TRIGGER_THRESHOLD_DEFAULT,
2230 CFG_TDLS_RSSI_TRIGGER_THRESHOLD_MIN,
2231 CFG_TDLS_RSSI_TRIGGER_THRESHOLD_MAX),
2232
2233 REG_VARIABLE(CFG_TDLS_RSSI_TEARDOWN_THRESHOLD, WLAN_PARAM_SignedInteger,
2234 struct hdd_config, fTDLSRSSITeardownThreshold,
2235 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2236 CFG_TDLS_RSSI_TEARDOWN_THRESHOLD_DEFAULT,
2237 CFG_TDLS_RSSI_TEARDOWN_THRESHOLD_MIN,
2238 CFG_TDLS_RSSI_TEARDOWN_THRESHOLD_MAX),
2239
2240 REG_VARIABLE(CFG_TDLS_RSSI_DELTA, WLAN_PARAM_SignedInteger,
2241 struct hdd_config, fTDLSRSSIDelta,
2242 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2243 CFG_TDLS_RSSI_DELTA_DEFAULT,
2244 CFG_TDLS_RSSI_DELTA_MIN,
2245 CFG_TDLS_RSSI_DELTA_MAX),
2246
2247 REG_VARIABLE(CFG_TDLS_QOS_WMM_UAPSD_MASK_NAME, WLAN_PARAM_HexInteger,
2248 struct hdd_config, fTDLSUapsdMask,
2249 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2250 CFG_TDLS_QOS_WMM_UAPSD_MASK_DEFAULT,
2251 CFG_TDLS_QOS_WMM_UAPSD_MASK_MIN,
2252 CFG_TDLS_QOS_WMM_UAPSD_MASK_MAX),
2253
2254 REG_VARIABLE(CFG_TDLS_BUFFER_STA_SUPPORT_ENABLE, WLAN_PARAM_Integer,
2255 struct hdd_config, fEnableTDLSBufferSta,
2256 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2257 CFG_TDLS_BUFFER_STA_SUPPORT_ENABLE_DEFAULT,
2258 CFG_TDLS_BUFFER_STA_SUPPORT_ENABLE_MIN,
2259 CFG_TDLS_BUFFER_STA_SUPPORT_ENABLE_MAX),
2260
2261 REG_VARIABLE(CFG_TDLS_OFF_CHANNEL_SUPPORT_ENABLE, WLAN_PARAM_Integer,
2262 struct hdd_config, fEnableTDLSOffChannel,
2263 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2264 CFG_TDLS_OFF_CHANNEL_SUPPORT_ENABLE_DEFAULT,
2265 CFG_TDLS_OFF_CHANNEL_SUPPORT_ENABLE_MIN,
2266 CFG_TDLS_OFF_CHANNEL_SUPPORT_ENABLE_MAX),
2267
2268 REG_VARIABLE(CFG_TDLS_PREFERRED_OFF_CHANNEL_NUM, WLAN_PARAM_Integer,
2269 struct hdd_config, fTDLSPrefOffChanNum,
2270 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2271 CFG_TDLS_PREFERRED_OFF_CHANNEL_NUM_DEFAULT,
2272 CFG_TDLS_PREFERRED_OFF_CHANNEL_NUM_MIN,
2273 CFG_TDLS_PREFERRED_OFF_CHANNEL_NUM_MAX),
2274
2275 REG_VARIABLE(CFG_TDLS_PREFERRED_OFF_CHANNEL_BW, WLAN_PARAM_Integer,
2276 struct hdd_config, fTDLSPrefOffChanBandwidth,
2277 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2278 CFG_TDLS_PREFERRED_OFF_CHANNEL_BW_DEFAULT,
2279 CFG_TDLS_PREFERRED_OFF_CHANNEL_BW_MIN,
2280 CFG_TDLS_PREFERRED_OFF_CHANNEL_BW_MAX),
2281
2282 REG_VARIABLE(CFG_TDLS_PUAPSD_INACTIVITY_TIME, WLAN_PARAM_Integer,
2283 struct hdd_config, fTDLSPuapsdInactivityTimer,
2284 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2285 CFG_TDLS_PUAPSD_INACTIVITY_TIME_DEFAULT,
2286 CFG_TDLS_PUAPSD_INACTIVITY_TIME_MIN,
2287 CFG_TDLS_PUAPSD_INACTIVITY_TIME_MAX),
2288
2289 REG_VARIABLE(CFG_TDLS_PUAPSD_RX_FRAME_THRESHOLD, WLAN_PARAM_Integer,
2290 struct hdd_config, fTDLSRxFrameThreshold,
2291 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2292 CFG_TDLS_PUAPSD_RX_FRAME_THRESHOLD_DEFAULT,
2293 CFG_TDLS_PUAPSD_RX_FRAME_THRESHOLD_MIN,
2294 CFG_TDLS_PUAPSD_RX_FRAME_THRESHOLD_MAX),
2295
2296 REG_VARIABLE(CFG_TDLS_PUAPSD_PEER_TRAFFIC_IND_WINDOW,
2297 WLAN_PARAM_Integer,
2298 struct hdd_config, fTDLSPuapsdPTIWindow,
2299 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2300 CFG_TDLS_PUAPSD_PEER_TRAFFIC_IND_WINDOW_DEFAULT,
2301 CFG_TDLS_PUAPSD_PEER_TRAFFIC_IND_WINDOW_MIN,
2302 CFG_TDLS_PUAPSD_PEER_TRAFFIC_IND_WINDOW_MAX),
2303
2304 REG_VARIABLE(CFG_TDLS_PUAPSD_PEER_TRAFFIC_RSP_TIMEOUT,
2305 WLAN_PARAM_Integer,
2306 struct hdd_config, fTDLSPuapsdPTRTimeout,
2307 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2308 CFG_TDLS_PUAPSD_PEER_TRAFFIC_RSP_TIMEOUT_DEFAULT,
2309 CFG_TDLS_PUAPSD_PEER_TRAFFIC_RSP_TIMEOUT_MIN,
2310 CFG_TDLS_PUAPSD_PEER_TRAFFIC_RSP_TIMEOUT_MAX),
2311
2312 REG_VARIABLE(CFG_TDLS_EXTERNAL_CONTROL, WLAN_PARAM_Integer,
2313 struct hdd_config, fTDLSExternalControl,
2314 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2315 CFG_TDLS_EXTERNAL_CONTROL_DEFAULT,
2316 CFG_TDLS_EXTERNAL_CONTROL_MIN,
2317 CFG_TDLS_EXTERNAL_CONTROL_MAX),
2318 REG_VARIABLE(CFG_TDLS_WMM_MODE_ENABLE, WLAN_PARAM_Integer,
2319 struct hdd_config, fEnableTDLSWmmMode,
2320 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2321 CFG_TDLS_WMM_MODE_ENABLE_DEFAULT,
2322 CFG_TDLS_WMM_MODE_ENABLE_MIN,
2323 CFG_TDLS_WMM_MODE_ENABLE_MAX),
2324
2325 REG_VARIABLE(CFG_TDLS_SCAN_ENABLE, WLAN_PARAM_Integer,
2326 struct hdd_config, enable_tdls_scan,
2327 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2328 CFG_TDLS_SCAN_ENABLE_DEFAULT,
2329 CFG_TDLS_SCAN_ENABLE_MIN,
2330 CFG_TDLS_SCAN_ENABLE_MAX),
Kabilan Kannan421714b2015-11-23 04:44:59 -08002331
2332 REG_VARIABLE(CFG_TDLS_PEER_KICKOUT_THRESHOLD, WLAN_PARAM_Integer,
2333 struct hdd_config, tdls_peer_kickout_threshold,
2334 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2335 CFG_TDLS_PEER_KICKOUT_THRESHOLD_DEFAULT,
2336 CFG_TDLS_PEER_KICKOUT_THRESHOLD_MIN,
2337 CFG_TDLS_PEER_KICKOUT_THRESHOLD_MAX),
2338
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002339#endif
2340
2341#ifdef WLAN_SOFTAP_VSTA_FEATURE
2342 REG_VARIABLE(CFG_VSTA_SUPPORT_ENABLE, WLAN_PARAM_Integer,
2343 struct hdd_config, fEnableVSTASupport,
2344 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2345 CFG_VSTA_SUPPORT_ENABLE_DEFAULT,
2346 CFG_VSTA_SUPPORT_ENABLE_MIN,
2347 CFG_VSTA_SUPPORT_ENABLE_MAX),
2348#endif
2349 REG_VARIABLE(CFG_ENABLE_LPWR_IMG_TRANSITION_NAME, WLAN_PARAM_Integer,
2350 struct hdd_config, enableLpwrImgTransition,
2351 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2352 CFG_ENABLE_LPWR_IMG_TRANSITION_DEFAULT,
2353 CFG_ENABLE_LPWR_IMG_TRANSITION_MIN,
2354 CFG_ENABLE_LPWR_IMG_TRANSITION_MAX),
2355
2356 REG_VARIABLE(CFG_ENABLE_LPWR_IMG_TRANSITION_NAME, WLAN_PARAM_Integer,
2357 struct hdd_config, enableLpwrImgTransition,
2358 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2359 CFG_ENABLE_LPWR_IMG_TRANSITION_DEFAULT,
2360 CFG_ENABLE_LPWR_IMG_TRANSITION_MIN,
2361 CFG_ENABLE_LPWR_IMG_TRANSITION_MAX),
2362
2363 REG_VARIABLE(CFG_SCAN_AGING_PARAM_NAME, WLAN_PARAM_Integer,
2364 struct hdd_config, scanAgingTimeout,
2365 VAR_FLAGS_OPTIONAL,
2366 CFG_SCAN_AGING_PARAM_DEFAULT,
2367 CFG_SCAN_AGING_PARAM_MIN,
2368 CFG_SCAN_AGING_PARAM_MAX),
2369
2370 REG_VARIABLE(CFG_TX_LDPC_ENABLE_FEATURE, WLAN_PARAM_Integer,
2371 struct hdd_config, enableTxLdpc,
2372 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2373 CFG_TX_LDPC_ENABLE_FEATURE_DEFAULT,
2374 CFG_TX_LDPC_ENABLE_FEATURE_MIN,
2375 CFG_TX_LDPC_ENABLE_FEATURE_MAX),
2376
2377 REG_VARIABLE(CFG_ENABLE_MCC_ADATIVE_SCHEDULER_ENABLED_NAME,
2378 WLAN_PARAM_Integer,
2379 struct hdd_config, enableMCCAdaptiveScheduler,
2380 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2381 CFG_ENABLE_MCC_ADATIVE_SCHEDULER_ENABLED_DEFAULT,
2382 CFG_ENABLE_MCC_ADATIVE_SCHEDULER_ENABLED_MIN,
2383 CFG_ENABLE_MCC_ADATIVE_SCHEDULER_ENABLED_MAX),
2384
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002385 REG_VARIABLE(CFG_IBSS_ADHOC_CHANNEL_5GHZ_NAME, WLAN_PARAM_Integer,
2386 struct hdd_config, AdHocChannel5G,
2387 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2388 CFG_IBSS_ADHOC_CHANNEL_5GHZ_DEFAULT,
2389 CFG_IBSS_ADHOC_CHANNEL_5GHZ_MIN,
2390 CFG_IBSS_ADHOC_CHANNEL_5GHZ_MAX),
2391
2392 REG_VARIABLE(CFG_IBSS_ADHOC_CHANNEL_24GHZ_NAME, WLAN_PARAM_Integer,
2393 struct hdd_config, AdHocChannel24G,
2394 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2395 CFG_IBSS_ADHOC_CHANNEL_24GHZ_DEFAULT,
2396 CFG_IBSS_ADHOC_CHANNEL_24GHZ_MIN,
2397 CFG_IBSS_ADHOC_CHANNEL_24GHZ_MAX),
2398
2399 REG_VARIABLE(CFG_VHT_SU_BEAMFORMEE_CAP_FEATURE, WLAN_PARAM_Integer,
2400 struct hdd_config, enableTxBF,
2401 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2402 CFG_VHT_SU_BEAMFORMEE_CAP_FEATURE_DEFAULT,
2403 CFG_VHT_SU_BEAMFORMEE_CAP_FEATURE_MIN,
2404 CFG_VHT_SU_BEAMFORMEE_CAP_FEATURE_MAX),
2405
Kiran Kumar Lokere5302ab62015-12-16 16:03:16 -08002406 REG_VARIABLE(CFG_VHT_ENABLE_TXBF_SAP_MODE, WLAN_PARAM_Integer,
2407 struct hdd_config, enable_txbf_sap_mode,
2408 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2409 CFG_VHT_ENABLE_TXBF_SAP_MODE_DEFAULT,
2410 CFG_VHT_ENABLE_TXBF_SAP_MODE_MIN,
2411 CFG_VHT_ENABLE_TXBF_SAP_MODE_MAX),
2412
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002413 REG_VARIABLE(CFG_VHT_ENABLE_TXBF_IN_20MHZ, WLAN_PARAM_Integer,
2414 struct hdd_config, enableTxBFin20MHz,
2415 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2416 CFG_VHT_ENABLE_TXBF_IN_20MHZ_DEFAULT,
2417 CFG_VHT_ENABLE_TXBF_IN_20MHZ_MIN,
2418 CFG_VHT_ENABLE_TXBF_IN_20MHZ_MAX),
2419
2420 REG_VARIABLE(CFG_VHT_CSN_BEAMFORMEE_ANT_SUPPORTED, WLAN_PARAM_Integer,
2421 struct hdd_config, txBFCsnValue,
2422 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2423 CFG_VHT_CSN_BEAMFORMEE_ANT_SUPPORTED_DEFAULT,
2424 CFG_VHT_CSN_BEAMFORMEE_ANT_SUPPORTED_MIN,
2425 CFG_VHT_CSN_BEAMFORMEE_ANT_SUPPORTED_MAX),
2426
2427 REG_VARIABLE(CFG_VHT_ENABLE_TX_SU_BEAM_FORMER, WLAN_PARAM_Integer,
2428 struct hdd_config, enable_su_tx_bformer,
2429 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2430 CFG_VHT_ENABLE_TX_SU_BEAM_FORMER_DEFAULT,
2431 CFG_VHT_ENABLE_TX_SU_BEAM_FORMER_MIN,
2432 CFG_VHT_ENABLE_TX_SU_BEAM_FORMER_MAX),
2433
2434 REG_VARIABLE(CFG_SAP_ALLOW_ALL_CHANNEL_PARAM_NAME, WLAN_PARAM_Integer,
2435 struct hdd_config, sapAllowAllChannel,
2436 VAR_FLAGS_OPTIONAL,
2437 CFG_SAP_ALLOW_ALL_CHANNEL_PARAM_DEFAULT,
2438 CFG_SAP_ALLOW_ALL_CHANNEL_PARAM_MIN,
2439 CFG_SAP_ALLOW_ALL_CHANNEL_PARAM_MAX),
2440
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002441 REG_VARIABLE(CFG_DISABLE_LDPC_WITH_TXBF_AP, WLAN_PARAM_Integer,
2442 struct hdd_config, disableLDPCWithTxbfAP,
2443 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2444 CFG_DISABLE_LDPC_WITH_TXBF_AP_DEFAULT,
2445 CFG_DISABLE_LDPC_WITH_TXBF_AP_MIN,
2446 CFG_DISABLE_LDPC_WITH_TXBF_AP_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002447
2448 REG_DYNAMIC_VARIABLE(CFG_ENABLE_SSR, WLAN_PARAM_Integer,
2449 struct hdd_config, enableSSR,
2450 VAR_FLAGS_OPTIONAL |
2451 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2452 CFG_ENABLE_SSR_DEFAULT,
2453 CFG_ENABLE_SSR_MIN,
2454 CFG_ENABLE_SSR_MAX,
2455 cb_notify_set_enable_ssr, 0),
2456
2457 REG_VARIABLE(CFG_MAX_MEDIUM_TIME, WLAN_PARAM_Integer,
2458 struct hdd_config, cfgMaxMediumTime,
2459 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2460 CFG_MAX_MEDIUM_TIME_STADEFAULT,
2461 CFG_MAX_MEDIUM_TIME_STAMIN,
2462 CFG_MAX_MEDIUM_TIME_STAMAX),
2463
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002464 REG_VARIABLE(CFG_ENABLE_VHT_FOR_24GHZ_NAME, WLAN_PARAM_Integer,
2465 struct hdd_config, enableVhtFor24GHzBand,
2466 VAR_FLAGS_OPTIONAL,
2467 CFG_ENABLE_VHT_FOR_24GHZ_DEFAULT,
2468 CFG_ENABLE_VHT_FOR_24GHZ_MIN,
2469 CFG_ENABLE_VHT_FOR_24GHZ_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002470
Kapil Gupta4b2efbb2016-10-03 13:07:20 +05302471
2472 REG_VARIABLE(CFG_ENABLE_VENDOR_VHT_FOR_24GHZ_NAME, WLAN_PARAM_Integer,
2473 struct hdd_config, enable_sap_vendor_vht,
2474 VAR_FLAGS_OPTIONAL,
2475 CFG_ENABLE_VENDOR_VHT_FOR_24GHZ_DEFAULT,
2476 CFG_ENABLE_VENDOR_VHT_FOR_24GHZ_MIN,
2477 CFG_ENABLE_VENDOR_VHT_FOR_24GHZ_MAX),
2478
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002479 REG_DYNAMIC_VARIABLE(CFG_ENABLE_FAST_ROAM_IN_CONCURRENCY,
2480 WLAN_PARAM_Integer,
2481 struct hdd_config, bFastRoamInConIniFeatureEnabled,
2482 VAR_FLAGS_OPTIONAL |
2483 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2484 CFG_ENABLE_FAST_ROAM_IN_CONCURRENCY_DEFAULT,
2485 CFG_ENABLE_FAST_ROAM_IN_CONCURRENCY_MIN,
2486 CFG_ENABLE_FAST_ROAM_IN_CONCURRENCY_MAX,
2487 cb_notify_set_enable_fast_roam_in_concurrency, 0),
2488
2489 REG_VARIABLE(CFG_ENABLE_ADAPT_RX_DRAIN_NAME, WLAN_PARAM_Integer,
2490 struct hdd_config, fEnableAdaptRxDrain,
2491 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2492 CFG_ENABLE_ADAPT_RX_DRAIN_DEFAULT,
2493 CFG_ENABLE_ADAPT_RX_DRAIN_MIN,
2494 CFG_ENABLE_ADAPT_RX_DRAIN_MAX),
2495
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002496 REG_VARIABLE(CFG_ENABLE_HEART_BEAT_OFFLOAD, WLAN_PARAM_Integer,
2497 struct hdd_config, enableIbssHeartBeatOffload,
2498 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2499 CFG_ENABLE_HEART_BEAT_OFFLOAD_DEFAULT,
2500 CFG_ENABLE_HEART_BEAT_OFFLOAD_MIN,
2501 CFG_ENABLE_HEART_BEAT_OFFLOAD_MAX),
2502
2503 REG_VARIABLE(CFG_ANTENNA_DIVERSITY_PARAM_NAME, WLAN_PARAM_Integer,
2504 struct hdd_config, antennaDiversity,
2505 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2506 CFG_ANTENNA_DIVERSITY_PARAM_DEFAULT,
2507 CFG_ANTENNA_DIVERSITY_PARAM_MIN,
2508 CFG_ANTENNA_DIVERSITY_PARAM_MAX),
2509
2510 REG_VARIABLE(CFG_ENABLE_SNR_MONITORING_NAME, WLAN_PARAM_Integer,
2511 struct hdd_config, fEnableSNRMonitoring,
2512 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2513 CFG_ENABLE_SNR_MONITORING_DEFAULT,
2514 CFG_ENABLE_SNR_MONITORING_MIN,
2515 CFG_ENABLE_SNR_MONITORING_MAX),
2516
2517#ifdef FEATURE_WLAN_SCAN_PNO
2518 REG_VARIABLE(CFG_PNO_SCAN_SUPPORT, WLAN_PARAM_Integer,
2519 struct hdd_config, configPNOScanSupport,
2520 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2521 CFG_PNO_SCAN_SUPPORT_DEFAULT,
2522 CFG_PNO_SCAN_SUPPORT_DISABLE,
2523 CFG_PNO_SCAN_SUPPORT_ENABLE),
2524
2525 REG_VARIABLE(CFG_PNO_SCAN_TIMER_REPEAT_VALUE, WLAN_PARAM_Integer,
2526 struct hdd_config, configPNOScanTimerRepeatValue,
2527 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2528 CFG_PNO_SCAN_TIMER_REPEAT_VALUE_DEFAULT,
2529 CFG_PNO_SCAN_TIMER_REPEAT_VALUE_MIN,
2530 CFG_PNO_SCAN_TIMER_REPEAT_VALUE_MAX),
Srinivas Girigowdabdc98162015-09-17 11:06:07 -07002531
2532 REG_VARIABLE(CFG_PNO_SLOW_SCAN_MULTIPLIER, WLAN_PARAM_Integer,
2533 struct hdd_config, pno_slow_scan_multiplier,
2534 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2535 CFG_PNO_SLOW_SCAN_MULTIPLIER_DEFAULT,
2536 CFG_PNO_SLOW_SCAN_MULTIPLIER_MIN,
2537 CFG_PNO_SLOW_SCAN_MULTIPLIER_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002538#endif
2539 REG_VARIABLE(CFG_AMSDU_SUPPORT_IN_AMPDU_NAME, WLAN_PARAM_Integer,
2540 struct hdd_config, isAmsduSupportInAMPDU,
2541 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2542 CFG_AMSDU_SUPPORT_IN_AMPDU_DEFAULT,
2543 CFG_AMSDU_SUPPORT_IN_AMPDU_MIN,
2544 CFG_AMSDU_SUPPORT_IN_AMPDU_MAX),
2545
2546 REG_VARIABLE(CFG_STRICT_5GHZ_PREF_BY_MARGIN, WLAN_PARAM_Integer,
2547 struct hdd_config, nSelect5GHzMargin,
2548 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2549 CFG_STRICT_5GHZ_PREF_BY_MARGIN_DEFAULT,
2550 CFG_STRICT_5GHZ_PREF_BY_MARGIN_MIN,
2551 CFG_STRICT_5GHZ_PREF_BY_MARGIN_MAX),
2552
2553 REG_VARIABLE(CFG_ENABLE_IP_TCP_UDP_CHKSUM_OFFLOAD, WLAN_PARAM_Integer,
2554 struct hdd_config, enable_ip_tcp_udp_checksum_offload,
2555 VAR_FLAGS_OPTIONAL,
2556 CFG_ENABLE_IP_TCP_UDP_CHKSUM_OFFLOAD_DEFAULT,
2557 CFG_ENABLE_IP_TCP_UDP_CHKSUM_OFFLOAD_DISABLE,
2558 CFG_ENABLE_IP_TCP_UDP_CHKSUM_OFFLOAD_ENABLE),
2559
2560 REG_VARIABLE(CFG_POWERSAVE_OFFLOAD_NAME, WLAN_PARAM_Integer,
2561 struct hdd_config, enablePowersaveOffload,
2562 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2563 CFG_POWERSAVE_OFFLOAD_DEFAULT,
2564 CFG_POWERSAVE_OFFLOAD_MIN,
2565 CFG_POWERSAVE_OFFLOAD_MAX),
2566
2567 REG_VARIABLE(CFG_ENABLE_FW_UART_PRINT_NAME, WLAN_PARAM_Integer,
2568 struct hdd_config, enablefwprint,
2569 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2570 CFG_ENABLE_FW_UART_PRINT_DEFAULT,
2571 CFG_ENABLE_FW_UART_PRINT_DISABLE,
2572 CFG_ENABLE_FW_UART_PRINT_ENABLE),
2573
2574 REG_VARIABLE(CFG_ENABLE_FW_LOG_NAME, WLAN_PARAM_Integer,
Komal Seelamc11bb222016-01-27 18:57:10 +05302575 struct hdd_config, enable_fw_log,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002576 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2577 CFG_ENABLE_FW_LOG_DEFAULT,
2578 CFG_ENABLE_FW_LOG_DISABLE,
2579 CFG_ENABLE_FW_LOG_ENABLE),
2580
2581#ifdef IPA_OFFLOAD
2582 REG_VARIABLE(CFG_IPA_OFFLOAD_CONFIG_NAME, WLAN_PARAM_HexInteger,
2583 struct hdd_config, IpaConfig,
2584 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2585 CFG_IPA_OFFLOAD_CONFIG_DEFAULT,
2586 CFG_IPA_OFFLOAD_CONFIG_MIN,
2587 CFG_IPA_OFFLOAD_CONFIG_MAX),
2588
2589 REG_VARIABLE(CFG_IPA_DESC_SIZE_NAME, WLAN_PARAM_Integer,
2590 struct hdd_config, IpaDescSize,
2591 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2592 CFG_IPA_DESC_SIZE_DEFAULT,
2593 CFG_IPA_DESC_SIZE_MIN,
2594 CFG_IPA_DESC_SIZE_MAX),
2595
2596 REG_VARIABLE(CFG_IPA_HIGH_BANDWIDTH_MBPS, WLAN_PARAM_Integer,
2597 struct hdd_config, IpaHighBandwidthMbps,
2598 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2599 CFG_IPA_HIGH_BANDWIDTH_MBPS_DEFAULT,
2600 CFG_IPA_HIGH_BANDWIDTH_MBPS_MIN,
2601 CFG_IPA_HIGH_BANDWIDTH_MBPS_MAX),
2602
2603 REG_VARIABLE(CFG_IPA_MEDIUM_BANDWIDTH_MBPS, WLAN_PARAM_Integer,
2604 struct hdd_config, IpaMediumBandwidthMbps,
2605 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2606 CFG_IPA_MEDIUM_BANDWIDTH_MBPS_DEFAULT,
2607 CFG_IPA_MEDIUM_BANDWIDTH_MBPS_MIN,
2608 CFG_IPA_MEDIUM_BANDWIDTH_MBPS_MAX),
2609
2610 REG_VARIABLE(CFG_IPA_LOW_BANDWIDTH_MBPS, WLAN_PARAM_Integer,
2611 struct hdd_config, IpaLowBandwidthMbps,
2612 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2613 CFG_IPA_LOW_BANDWIDTH_MBPS_DEFAULT,
2614 CFG_IPA_LOW_BANDWIDTH_MBPS_MIN,
2615 CFG_IPA_LOW_BANDWIDTH_MBPS_MAX),
2616#endif
2617
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002618 REG_VARIABLE(CFG_VHT_AMPDU_LEN_EXPONENT_NAME, WLAN_PARAM_Integer,
2619 struct hdd_config, fVhtAmpduLenExponent,
2620 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2621 CFG_VHT_AMPDU_LEN_EXPONENT_DEFAULT,
2622 CFG_VHT_AMPDU_LEN_EXPONENT_MIN,
2623 CFG_VHT_AMPDU_LEN_EXPONENT_MAX),
2624
2625 REG_VARIABLE(CFG_VHT_MPDU_LEN_NAME, WLAN_PARAM_Integer,
2626 struct hdd_config, vhtMpduLen,
2627 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2628 CFG_VHT_MPDU_LEN_DEFAULT,
2629 CFG_VHT_MPDU_LEN_MIN,
2630 CFG_VHT_MPDU_LEN_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002631
2632 REG_VARIABLE(CFG_MAX_WOW_FILTERS_NAME, WLAN_PARAM_Integer,
2633 struct hdd_config, maxWoWFilters,
2634 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2635 CFG_MAX_WOW_FILTERS_DEFAULT,
2636 CFG_MAX_WOW_FILTERS_MIN,
2637 CFG_MAX_WOW_FILTERS_MAX),
2638
2639 REG_VARIABLE(CFG_WOW_STATUS_NAME, WLAN_PARAM_Integer,
2640 struct hdd_config, wowEnable,
2641 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2642 CFG_WOW_STATUS_DEFAULT,
2643 CFG_WOW_ENABLE_MIN,
2644 CFG_WOW_ENABLE_MAX),
2645
2646 REG_VARIABLE(CFG_COALESING_IN_IBSS_NAME, WLAN_PARAM_Integer,
2647 struct hdd_config, isCoalesingInIBSSAllowed,
2648 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2649 CFG_COALESING_IN_IBSS_DEFAULT,
2650 CFG_COALESING_IN_IBSS_MIN,
2651 CFG_COALESING_IN_IBSS_MAX),
2652
2653 REG_VARIABLE(CFG_IBSS_ATIM_WIN_SIZE_NAME, WLAN_PARAM_Integer,
2654 struct hdd_config, ibssATIMWinSize,
2655 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2656 CFG_IBSS_ATIM_WIN_SIZE_DEFAULT,
2657 CFG_IBSS_ATIM_WIN_SIZE_MIN,
2658 CFG_IBSS_ATIM_WIN_SIZE_MAX),
2659
2660 REG_VARIABLE(CFG_SAP_MAX_NO_PEERS, WLAN_PARAM_Integer,
2661 struct hdd_config, maxNumberOfPeers,
2662 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2663 CFG_SAP_MAX_NO_PEERS_DEFAULT,
2664 CFG_SAP_MAX_NO_PEERS_MIN,
2665 CFG_SAP_MAX_NO_PEERS_MAX),
2666
2667 REG_VARIABLE(CFG_IBSS_IS_POWER_SAVE_ALLOWED_NAME, WLAN_PARAM_Integer,
2668 struct hdd_config, isIbssPowerSaveAllowed,
2669 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2670 CFG_IBSS_IS_POWER_SAVE_ALLOWED_DEFAULT,
2671 CFG_IBSS_IS_POWER_SAVE_ALLOWED_MIN,
2672 CFG_IBSS_IS_POWER_SAVE_ALLOWED_MAX),
2673
2674 REG_VARIABLE(CFG_IBSS_IS_POWER_COLLAPSE_ALLOWED_NAME,
2675 WLAN_PARAM_Integer,
2676 struct hdd_config, isIbssPowerCollapseAllowed,
2677 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2678 CFG_IBSS_IS_POWER_COLLAPSE_ALLOWED_DEFAULT,
2679 CFG_IBSS_IS_POWER_COLLAPSE_ALLOWED_MIN,
2680 CFG_IBSS_IS_POWER_COLLAPSE_ALLOWED_MAX),
2681
2682 REG_VARIABLE(CFG_IBSS_AWAKE_ON_TX_RX_NAME, WLAN_PARAM_Integer,
2683 struct hdd_config, isIbssAwakeOnTxRx,
2684 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2685 CFG_IBSS_AWAKE_ON_TX_RX_DEFAULT,
2686 CFG_IBSS_AWAKE_ON_TX_RX_MIN,
2687 CFG_IBSS_AWAKE_ON_TX_RX_MAX),
2688
2689 REG_VARIABLE(CFG_IBSS_INACTIVITY_TIME_NAME, WLAN_PARAM_Integer,
2690 struct hdd_config, ibssInactivityCount,
2691 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2692 CFG_IBSS_INACTIVITY_TIME_DEFAULT,
2693 CFG_IBSS_INACTIVITY_TIME_MIN,
2694 CFG_IBSS_INACTIVITY_TIME_MAX),
2695
2696 REG_VARIABLE(CFG_IBSS_TXSP_END_INACTIVITY_NAME, WLAN_PARAM_Integer,
2697 struct hdd_config, ibssTxSpEndInactivityTime,
2698 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2699 CFG_IBSS_TXSP_END_INACTIVITY_DEFAULT,
2700 CFG_IBSS_TXSP_END_INACTIVITY_MIN,
2701 CFG_IBSS_TXSP_END_INACTIVITY_MAX),
2702
2703 REG_VARIABLE(CFG_IBSS_PS_WARMUP_TIME_NAME, WLAN_PARAM_Integer,
2704 struct hdd_config, ibssPsWarmupTime,
2705 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2706 CFG_IBSS_PS_WARMUP_TIME_DEFAULT,
2707 CFG_IBSS_PS_WARMUP_TIME_MIN,
2708 CFG_IBSS_PS_WARMUP_TIME_MAX),
2709
2710 REG_VARIABLE(CFG_IBSS_PS_1RX_CHAIN_IN_ATIM_WINDOW_NAME,
2711 WLAN_PARAM_Integer,
2712 struct hdd_config, ibssPs1RxChainInAtimEnable,
2713 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2714 CFG_IBSS_PS_1RX_CHAIN_IN_ATIM_WINDOW_DEFAULT,
2715 CFG_IBSS_PS_1RX_CHAIN_IN_ATIM_WINDOW_MIN,
2716 CFG_IBSS_PS_1RX_CHAIN_IN_ATIM_WINDOW_MAX),
2717
2718 REG_VARIABLE(CFG_THERMAL_TEMP_MIN_LEVEL0_NAME, WLAN_PARAM_Integer,
2719 struct hdd_config, thermalTempMinLevel0,
2720 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2721 CFG_THERMAL_TEMP_MIN_LEVEL0_DEFAULT,
2722 CFG_THERMAL_TEMP_MIN_LEVEL0_MIN,
2723 CFG_THERMAL_TEMP_MIN_LEVEL0_MAX),
2724
2725 REG_VARIABLE(CFG_THERMAL_TEMP_MAX_LEVEL0_NAME, WLAN_PARAM_Integer,
2726 struct hdd_config, thermalTempMaxLevel0,
2727 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2728 CFG_THERMAL_TEMP_MAX_LEVEL0_DEFAULT,
2729 CFG_THERMAL_TEMP_MAX_LEVEL0_MIN,
2730 CFG_THERMAL_TEMP_MAX_LEVEL0_MAX),
2731
2732 REG_VARIABLE(CFG_THERMAL_TEMP_MIN_LEVEL1_NAME, WLAN_PARAM_Integer,
2733 struct hdd_config, thermalTempMinLevel1,
2734 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2735 CFG_THERMAL_TEMP_MIN_LEVEL1_DEFAULT,
2736 CFG_THERMAL_TEMP_MIN_LEVEL1_MIN,
2737 CFG_THERMAL_TEMP_MIN_LEVEL1_MAX),
2738
2739 REG_VARIABLE(CFG_THERMAL_TEMP_MAX_LEVEL1_NAME, WLAN_PARAM_Integer,
2740 struct hdd_config, thermalTempMaxLevel1,
2741 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2742 CFG_THERMAL_TEMP_MAX_LEVEL1_DEFAULT,
2743 CFG_THERMAL_TEMP_MAX_LEVEL1_MIN,
2744 CFG_THERMAL_TEMP_MAX_LEVEL1_MAX),
2745
2746 REG_VARIABLE(CFG_THERMAL_TEMP_MIN_LEVEL2_NAME, WLAN_PARAM_Integer,
2747 struct hdd_config, thermalTempMinLevel2,
2748 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2749 CFG_THERMAL_TEMP_MIN_LEVEL2_DEFAULT,
2750 CFG_THERMAL_TEMP_MIN_LEVEL2_MIN,
2751 CFG_THERMAL_TEMP_MIN_LEVEL2_MAX),
2752
2753 REG_VARIABLE(CFG_THERMAL_TEMP_MAX_LEVEL2_NAME, WLAN_PARAM_Integer,
2754 struct hdd_config, thermalTempMaxLevel2,
2755 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2756 CFG_THERMAL_TEMP_MAX_LEVEL2_DEFAULT,
2757 CFG_THERMAL_TEMP_MAX_LEVEL2_MIN,
2758 CFG_THERMAL_TEMP_MAX_LEVEL2_MAX),
2759
2760 REG_VARIABLE(CFG_THERMAL_TEMP_MIN_LEVEL3_NAME, WLAN_PARAM_Integer,
2761 struct hdd_config, thermalTempMinLevel3,
2762 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2763 CFG_THERMAL_TEMP_MIN_LEVEL3_DEFAULT,
2764 CFG_THERMAL_TEMP_MIN_LEVEL3_MIN,
2765 CFG_THERMAL_TEMP_MIN_LEVEL3_MAX),
2766
2767 REG_VARIABLE(CFG_THERMAL_TEMP_MAX_LEVEL3_NAME, WLAN_PARAM_Integer,
2768 struct hdd_config, thermalTempMaxLevel3,
2769 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2770 CFG_THERMAL_TEMP_MAX_LEVEL3_DEFAULT,
2771 CFG_THERMAL_TEMP_MAX_LEVEL3_MIN,
2772 CFG_THERMAL_TEMP_MAX_LEVEL3_MAX),
2773
2774 REG_VARIABLE(CFG_SET_TXPOWER_LIMIT2G_NAME, WLAN_PARAM_Integer,
2775 struct hdd_config, TxPower2g,
2776 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2777 CFG_SET_TXPOWER_LIMIT2G_DEFAULT,
2778 CFG_SET_TXPOWER_LIMIT2G_MIN,
2779 CFG_SET_TXPOWER_LIMIT2G_MAX),
2780
2781 REG_VARIABLE(CFG_SET_TXPOWER_LIMIT5G_NAME, WLAN_PARAM_Integer,
2782 struct hdd_config, TxPower5g,
2783 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2784 CFG_SET_TXPOWER_LIMIT5G_DEFAULT,
2785 CFG_SET_TXPOWER_LIMIT5G_MIN,
2786 CFG_SET_TXPOWER_LIMIT5G_MAX),
2787
2788 REG_VARIABLE(CFG_ENABLE_DEBUG_CONNECT_ISSUE, WLAN_PARAM_Integer,
2789 struct hdd_config, gEnableDebugLog,
2790 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2791 CFG_ENABLE_DEBUG_CONNECT_ISSUE_DEFAULT,
2792 CFG_ENABLE_DEBUG_CONNECT_ISSUE_MIN,
2793 CFG_ENABLE_DEBUG_CONNECT_ISSUE_MAX),
2794
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08002795 REG_VARIABLE(CFG_ENABLE_DFS_PHYERR_FILTEROFFLOAD_NAME,
2796 WLAN_PARAM_Integer,
2797 struct hdd_config, fDfsPhyerrFilterOffload,
2798 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2799 CFG_ENABLE_DFS_PHYERR_FILTEROFFLOAD_DEFAULT,
2800 CFG_ENABLE_DFS_PHYERR_FILTEROFFLOAD_MIN,
2801 CFG_ENABLE_DFS_PHYERR_FILTEROFFLOAD_MAX),
2802
2803 REG_VARIABLE(CFG_ENABLE_OVERLAP_CH, WLAN_PARAM_Integer,
2804 struct hdd_config, gEnableOverLapCh,
2805 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2806 CFG_ENABLE_OVERLAP_CH_DEFAULT,
2807 CFG_ENABLE_OVERLAP_CH_MIN,
2808 CFG_ENABLE_OVERLAP_CH_MAX),
2809
2810 REG_VARIABLE(CFG_REG_CHANGE_DEF_COUNTRY_NAME, WLAN_PARAM_Integer,
2811 struct hdd_config, fRegChangeDefCountry,
2812 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2813 CFG_REG_CHANGE_DEF_COUNTRY_DEFAULT,
2814 CFG_REG_CHANGE_DEF_COUNTRY_MIN,
2815 CFG_REG_CHANGE_DEF_COUNTRY_MAX),
2816
2817#ifdef QCA_LL_LEGACY_TX_FLOW_CONTROL
2818 REG_VARIABLE(CFG_LL_TX_FLOW_LWM, WLAN_PARAM_Integer,
2819 struct hdd_config, TxFlowLowWaterMark,
2820 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2821 CFG_LL_TX_FLOW_LWM_DEFAULT,
2822 CFG_LL_TX_FLOW_LWM_MIN,
2823 CFG_LL_TX_FLOW_LWM_MAX),
2824 REG_VARIABLE(CFG_LL_TX_FLOW_HWM_OFFSET, WLAN_PARAM_Integer,
2825 struct hdd_config, TxFlowHighWaterMarkOffset,
2826 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2827 CFG_LL_TX_FLOW_HWM_OFFSET_DEFAULT,
2828 CFG_LL_TX_FLOW_HWM_OFFSET_MIN,
2829 CFG_LL_TX_FLOW_HWM_OFFSET_MAX),
2830 REG_VARIABLE(CFG_LL_TX_FLOW_MAX_Q_DEPTH, WLAN_PARAM_Integer,
2831 struct hdd_config, TxFlowMaxQueueDepth,
2832 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2833 CFG_LL_TX_FLOW_MAX_Q_DEPTH_DEFAULT,
2834 CFG_LL_TX_FLOW_MAX_Q_DEPTH_MIN,
2835 CFG_LL_TX_FLOW_MAX_Q_DEPTH_MAX),
2836 REG_VARIABLE(CFG_LL_TX_LBW_FLOW_LWM, WLAN_PARAM_Integer,
2837 struct hdd_config, TxLbwFlowLowWaterMark,
2838 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2839 CFG_LL_TX_LBW_FLOW_LWM_DEFAULT,
2840 CFG_LL_TX_LBW_FLOW_LWM_MIN,
2841 CFG_LL_TX_LBW_FLOW_LWM_MAX),
2842
2843 REG_VARIABLE(CFG_LL_TX_LBW_FLOW_HWM_OFFSET, WLAN_PARAM_Integer,
2844 struct hdd_config, TxLbwFlowHighWaterMarkOffset,
2845 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2846 CFG_LL_TX_LBW_FLOW_HWM_OFFSET_DEFAULT,
2847 CFG_LL_TX_LBW_FLOW_HWM_OFFSET_MIN,
2848 CFG_LL_TX_LBW_FLOW_HWM_OFFSET_MAX),
2849
2850 REG_VARIABLE(CFG_LL_TX_LBW_FLOW_MAX_Q_DEPTH, WLAN_PARAM_Integer,
2851 struct hdd_config, TxLbwFlowMaxQueueDepth,
2852 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2853 CFG_LL_TX_LBW_FLOW_MAX_Q_DEPTH_DEFAULT,
2854 CFG_LL_TX_LBW_FLOW_MAX_Q_DEPTH_MIN,
2855 CFG_LL_TX_LBW_FLOW_MAX_Q_DEPTH_MAX),
2856
2857 REG_VARIABLE(CFG_LL_TX_HBW_FLOW_LWM, WLAN_PARAM_Integer,
2858 struct hdd_config, TxHbwFlowLowWaterMark,
2859 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2860 CFG_LL_TX_HBW_FLOW_LWM_DEFAULT,
2861 CFG_LL_TX_HBW_FLOW_LWM_MIN,
2862 CFG_LL_TX_HBW_FLOW_LWM_MAX),
2863
2864 REG_VARIABLE(CFG_LL_TX_HBW_FLOW_HWM_OFFSET, WLAN_PARAM_Integer,
2865 struct hdd_config, TxHbwFlowHighWaterMarkOffset,
2866 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2867 CFG_LL_TX_HBW_FLOW_HWM_OFFSET_DEFAULT,
2868 CFG_LL_TX_HBW_FLOW_HWM_OFFSET_MIN,
2869 CFG_LL_TX_HBW_FLOW_HWM_OFFSET_MAX),
2870
2871 REG_VARIABLE(CFG_LL_TX_HBW_FLOW_MAX_Q_DEPTH, WLAN_PARAM_Integer,
2872 struct hdd_config, TxHbwFlowMaxQueueDepth,
2873 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2874 CFG_LL_TX_HBW_FLOW_MAX_Q_DEPTH_DEFAULT,
2875 CFG_LL_TX_HBW_FLOW_MAX_Q_DEPTH_MIN,
2876 CFG_LL_TX_HBW_FLOW_MAX_Q_DEPTH_MAX),
2877#endif /* QCA_LL_LEGACY_TX_FLOW_CONTROL */
2878#ifdef QCA_LL_TX_FLOW_CONTROL_V2
2879
2880 REG_VARIABLE(CFG_LL_TX_FLOW_STOP_QUEUE_TH, WLAN_PARAM_Integer,
2881 struct hdd_config, TxFlowStopQueueThreshold,
2882 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2883 CFG_LL_TX_FLOW_STOP_QUEUE_TH_DEFAULT,
2884 CFG_LL_TX_FLOW_STOP_QUEUE_TH_MIN,
2885 CFG_LL_TX_FLOW_STOP_QUEUE_TH_MAX),
2886
2887 REG_VARIABLE(CFG_LL_TX_FLOW_START_QUEUE_OFFSET, WLAN_PARAM_Integer,
2888 struct hdd_config, TxFlowStartQueueOffset,
2889 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2890 CFG_LL_TX_FLOW_START_QUEUE_OFFSET_DEFAULT,
2891 CFG_LL_TX_FLOW_START_QUEUE_OFFSET_MIN,
2892 CFG_LL_TX_FLOW_START_QUEUE_OFFSET_MAX),
2893
2894#endif
2895 REG_VARIABLE(CFG_INITIAL_DWELL_TIME_NAME, WLAN_PARAM_Integer,
2896 struct hdd_config, nInitialDwellTime,
2897 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2898 CFG_INITIAL_DWELL_TIME_DEFAULT,
2899 CFG_INITIAL_DWELL_TIME_MIN,
2900 CFG_INITIAL_DWELL_TIME_MAX),
2901
2902 REG_VARIABLE(CFG_INITIAL_SCAN_NO_DFS_CHNL_NAME, WLAN_PARAM_Integer,
2903 struct hdd_config, initial_scan_no_dfs_chnl,
2904 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2905 CFG_INITIAL_SCAN_NO_DFS_CHNL_DEFAULT,
2906 CFG_INITIAL_SCAN_NO_DFS_CHNL_MIN,
2907 CFG_INITIAL_SCAN_NO_DFS_CHNL_MAX),
2908
2909 REG_VARIABLE(CFG_SAP_MAX_OFFLOAD_PEERS, WLAN_PARAM_Integer,
2910 struct hdd_config, apMaxOffloadPeers,
2911 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2912 CFG_SAP_MAX_OFFLOAD_PEERS_DEFAULT,
2913 CFG_SAP_MAX_OFFLOAD_PEERS_MIN,
2914 CFG_SAP_MAX_OFFLOAD_PEERS_MAX),
2915
2916 REG_VARIABLE(CFG_SAP_MAX_OFFLOAD_REORDER_BUFFS, WLAN_PARAM_Integer,
2917 struct hdd_config, apMaxOffloadReorderBuffs,
2918 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2919 CFG_SAP_MAX_OFFLOAD_REORDER_BUFFS_DEFAULT,
2920 CFG_SAP_MAX_OFFLOAD_REORDER_BUFFS_MIN,
2921 CFG_SAP_MAX_OFFLOAD_REORDER_BUFFS_MAX),
2922
2923 REG_VARIABLE(CFG_ADVERTISE_CONCURRENT_OPERATION_NAME,
2924 WLAN_PARAM_Integer,
2925 struct hdd_config, advertiseConcurrentOperation,
2926 VAR_FLAGS_OPTIONAL,
2927 CFG_ADVERTISE_CONCURRENT_OPERATION_DEFAULT,
2928 CFG_ADVERTISE_CONCURRENT_OPERATION_MIN,
2929 CFG_ADVERTISE_CONCURRENT_OPERATION_MAX),
2930
2931 REG_VARIABLE(CFG_ENABLE_MEMORY_DEEP_SLEEP, WLAN_PARAM_Integer,
2932 struct hdd_config, enableMemDeepSleep,
2933 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2934 CFG_ENABLE_MEMORY_DEEP_SLEEP_DEFAULT,
2935 CFG_ENABLE_MEMORY_DEEP_SLEEP_MIN,
2936 CFG_ENABLE_MEMORY_DEEP_SLEEP_MAX),
2937
2938 REG_VARIABLE(CFG_DEFAULT_RATE_INDEX_24GH, WLAN_PARAM_Integer,
2939 struct hdd_config, defaultRateIndex24Ghz,
2940 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2941 CFG_DEFAULT_RATE_INDEX_24GH_DEFAULT,
2942 CFG_DEFAULT_RATE_INDEX_24GH_MIN,
2943 CFG_DEFAULT_RATE_INDEX_24GH_MAX),
2944
2945#ifdef MEMORY_DEBUG
2946 REG_VARIABLE(CFG_ENABLE_MEMORY_DEBUG_NAME, WLAN_PARAM_Integer,
2947 struct hdd_config, IsMemoryDebugSupportEnabled,
2948 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2949 CFG_ENABLE_MEMORY_DEBUG_DEFAULT,
2950 CFG_ENABLE_MEMORY_DEBUG_MIN,
2951 CFG_ENABLE_MEMORY_DEBUG_MAX),
2952#endif
2953
2954 REG_VARIABLE(CFG_DEBUG_P2P_REMAIN_ON_CHANNEL_NAME, WLAN_PARAM_Integer,
2955 struct hdd_config, debugP2pRemainOnChannel,
2956 VAR_FLAGS_OPTIONAL,
2957 CFG_DEBUG_P2P_REMAIN_ON_CHANNEL_DEFAULT,
2958 CFG_DEBUG_P2P_REMAIN_ON_CHANNEL_MIN,
2959 CFG_DEBUG_P2P_REMAIN_ON_CHANNEL_MAX),
2960
2961 REG_VARIABLE(CFG_ENABLE_PACKET_LOG, WLAN_PARAM_Integer,
2962 struct hdd_config, enablePacketLog,
2963 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2964 CFG_ENABLE_PACKET_LOG_DEFAULT,
2965 CFG_ENABLE_PACKET_LOG_MIN,
2966 CFG_ENABLE_PACKET_LOG_MAX),
2967
2968#ifdef WLAN_FEATURE_ROAM_OFFLOAD
2969 REG_VARIABLE(CFG_ROAMING_OFFLOAD_NAME, WLAN_PARAM_Integer,
2970 struct hdd_config, isRoamOffloadEnabled,
2971 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
2972 CFG_ROAMING_OFFLOAD_DEFAULT,
2973 CFG_ROAMING_OFFLOAD_MIN,
2974 CFG_ROAMING_OFFLOAD_MAX),
2975#endif
2976#ifdef MSM_PLATFORM
2977 REG_VARIABLE(CFG_BUS_BANDWIDTH_HIGH_THRESHOLD, WLAN_PARAM_Integer,
2978 struct hdd_config, busBandwidthHighThreshold,
2979 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2980 CFG_BUS_BANDWIDTH_HIGH_THRESHOLD_DEFAULT,
2981 CFG_BUS_BANDWIDTH_HIGH_THRESHOLD_MIN,
2982 CFG_BUS_BANDWIDTH_HIGH_THRESHOLD_MAX),
2983
2984 REG_VARIABLE(CFG_BUS_BANDWIDTH_MEDIUM_THRESHOLD, WLAN_PARAM_Integer,
2985 struct hdd_config, busBandwidthMediumThreshold,
2986 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2987 CFG_BUS_BANDWIDTH_MEDIUM_THRESHOLD_DEFAULT,
2988 CFG_BUS_BANDWIDTH_MEDIUM_THRESHOLD_MIN,
2989 CFG_BUS_BANDWIDTH_MEDIUM_THRESHOLD_MAX),
2990
2991 REG_VARIABLE(CFG_BUS_BANDWIDTH_LOW_THRESHOLD, WLAN_PARAM_Integer,
2992 struct hdd_config, busBandwidthLowThreshold,
2993 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
2994 CFG_BUS_BANDWIDTH_LOW_THRESHOLD_DEFAULT,
2995 CFG_BUS_BANDWIDTH_LOW_THRESHOLD_MIN,
2996 CFG_BUS_BANDWIDTH_LOW_THRESHOLD_MAX),
2997
2998 REG_VARIABLE(CFG_BUS_BANDWIDTH_COMPUTE_INTERVAL, WLAN_PARAM_Integer,
2999 struct hdd_config, busBandwidthComputeInterval,
3000 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3001 CFG_BUS_BANDWIDTH_COMPUTE_INTERVAL_DEFAULT,
3002 CFG_BUS_BANDWIDTH_COMPUTE_INTERVAL_MIN,
3003 CFG_BUS_BANDWIDTH_COMPUTE_INTERVAL_MAX),
Ravi Joshie2331e82015-07-01 18:18:54 -07003004
3005 REG_VARIABLE(CFG_ENABLE_TCP_DELACK, WLAN_PARAM_Integer,
3006 struct hdd_config, enable_tcp_delack,
3007 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3008 CFG_ENABLE_TCP_DELACK_DEFAULT,
3009 CFG_ENABLE_TCP_DELACK_MIN,
3010 CFG_ENABLE_TCP_DELACK_MAX),
3011
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003012 REG_VARIABLE(CFG_TCP_DELACK_THRESHOLD_HIGH, WLAN_PARAM_Integer,
3013 struct hdd_config, tcpDelackThresholdHigh,
3014 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3015 CFG_TCP_DELACK_THRESHOLD_HIGH_DEFAULT,
3016 CFG_TCP_DELACK_THRESHOLD_HIGH_MIN,
3017 CFG_TCP_DELACK_THRESHOLD_HIGH_MAX),
Ravi Joshie2331e82015-07-01 18:18:54 -07003018
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003019 REG_VARIABLE(CFG_TCP_DELACK_THRESHOLD_LOW, WLAN_PARAM_Integer,
3020 struct hdd_config, tcpDelackThresholdLow,
3021 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3022 CFG_TCP_DELACK_THRESHOLD_LOW_DEFAULT,
3023 CFG_TCP_DELACK_THRESHOLD_LOW_MIN,
3024 CFG_TCP_DELACK_THRESHOLD_LOW_MAX),
Mohit Khannae71e2262015-11-10 09:37:24 -08003025
Ravi Joshib89e7f72016-09-07 13:43:15 -07003026 REG_VARIABLE(CFG_TCP_DELACK_TIMER_COUNT, WLAN_PARAM_Integer,
3027 struct hdd_config, tcp_delack_timer_count,
3028 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3029 CFG_TCP_DELACK_TIMER_COUNT_DEFAULT,
3030 CFG_TCP_DELACK_TIMER_COUNT_MIN,
3031 CFG_TCP_DELACK_TIMER_COUNT_MAX),
Mohit Khannae71e2262015-11-10 09:37:24 -08003032
Ravi Joshib89e7f72016-09-07 13:43:15 -07003033 REG_VARIABLE(CFG_TCP_TX_HIGH_TPUT_THRESHOLD_NAME, WLAN_PARAM_Integer,
3034 struct hdd_config, tcp_tx_high_tput_thres,
3035 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3036 CFG_TCP_TX_HIGH_TPUT_THRESHOLD_DEFAULT,
3037 CFG_TCP_TX_HIGH_TPUT_THRESHOLD_MIN,
3038 CFG_TCP_TX_HIGH_TPUT_THRESHOLD_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003039#endif
3040
3041 REG_VARIABLE(CFG_ENABLE_FW_LOG_TYPE, WLAN_PARAM_Integer,
3042 struct hdd_config, enableFwLogType,
3043 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3044 CFG_ENABLE_FW_LOG_TYPE_DEFAULT,
3045 CFG_ENABLE_FW_LOG_TYPE_MIN,
3046 CFG_ENABLE_FW_LOG_TYPE_MAX),
3047
3048 REG_VARIABLE(CFG_ENABLE_FW_DEBUG_LOG_LEVEL, WLAN_PARAM_Integer,
3049 struct hdd_config, enableFwLogLevel,
3050 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3051 CFG_ENABLE_FW_DEBUG_LOG_LEVEL_DEFAULT,
3052 CFG_ENABLE_FW_DEBUG_LOG_LEVEL_MIN,
3053 CFG_ENABLE_FW_DEBUG_LOG_LEVEL_MAX),
3054
3055 REG_VARIABLE_STRING(CFG_ENABLE_FW_MODULE_LOG_LEVEL, WLAN_PARAM_String,
3056 struct hdd_config, enableFwModuleLogLevel,
3057 VAR_FLAGS_OPTIONAL,
3058 (void *)CFG_ENABLE_FW_MODULE_LOG_DEFAULT),
3059
3060#ifdef WLAN_FEATURE_11W
3061 REG_VARIABLE(CFG_PMF_SA_QUERY_MAX_RETRIES_NAME, WLAN_PARAM_Integer,
3062 struct hdd_config, pmfSaQueryMaxRetries,
3063 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3064 CFG_PMF_SA_QUERY_MAX_RETRIES_DEFAULT,
3065 CFG_PMF_SA_QUERY_MAX_RETRIES_MIN,
3066 CFG_PMF_SA_QUERY_MAX_RETRIES_MAX),
3067
3068 REG_VARIABLE(CFG_PMF_SA_QUERY_RETRY_INTERVAL_NAME, WLAN_PARAM_Integer,
3069 struct hdd_config, pmfSaQueryRetryInterval,
3070 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3071 CFG_PMF_SA_QUERY_RETRY_INTERVAL_DEFAULT,
3072 CFG_PMF_SA_QUERY_RETRY_INTERVAL_MIN,
3073 CFG_PMF_SA_QUERY_RETRY_INTERVAL_MAX),
3074#endif
3075 REG_VARIABLE(CFG_MAX_CONCURRENT_CONNECTIONS_NAME, WLAN_PARAM_Integer,
3076 struct hdd_config, gMaxConcurrentActiveSessions,
3077 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3078 CFG_MAX_CONCURRENT_CONNECTIONS_DEFAULT,
3079 CFG_MAX_CONCURRENT_CONNECTIONS_MIN,
3080 CFG_MAX_CONCURRENT_CONNECTIONS_MAX),
3081
3082#ifdef FEATURE_GREEN_AP
3083 REG_VARIABLE(CFG_ENABLE_GREEN_AP_FEATURE, WLAN_PARAM_Integer,
3084 struct hdd_config, enableGreenAP,
3085 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3086 CFG_ENABLE_GREEN_AP_FEATURE_DEFAULT,
3087 CFG_ENABLE_GREEN_AP_FEATURE_MIN,
3088 CFG_ENABLE_GREEN_AP_FEATURE_MAX),
Ryan Hsucb118cf2015-11-09 16:03:53 -08003089 REG_VARIABLE(CFG_ENABLE_EGAP_ENABLE_FEATURE, WLAN_PARAM_Integer,
3090 struct hdd_config, enable_egap,
3091 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3092 CFG_ENABLE_EGAP_ENABLE_FEATURE_DEFAULT,
3093 CFG_ENABLE_EGAP_ENABLE_FEATURE_MIN,
3094 CFG_ENABLE_EGAP_ENABLE_FEATURE_MAX),
3095 REG_VARIABLE(CFG_ENABLE_EGAP_INACT_TIME_FEATURE, WLAN_PARAM_Integer,
3096 struct hdd_config, egap_inact_time,
3097 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3098 CFG_ENABLE_EGAP_INACT_TIME_FEATURE_DEFAULT,
3099 CFG_ENABLE_EGAP_INACT_TIME_FEATURE_MIN,
3100 CFG_ENABLE_EGAP_INACT_TIME_FEATURE_MAX),
3101 REG_VARIABLE(CFG_ENABLE_EGAP_WAIT_TIME_FEATURE, WLAN_PARAM_Integer,
3102 struct hdd_config, egap_wait_time,
3103 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3104 CFG_ENABLE_EGAP_WAIT_TIME_FEATURE_DEFAULT,
3105 CFG_ENABLE_EGAP_WAIT_TIME_FEATURE_MIN,
3106 CFG_ENABLE_EGAP_WAIT_TIME_FEATURE_MAX),
3107 REG_VARIABLE(CFG_ENABLE_EGAP_FLAGS_FEATURE, WLAN_PARAM_Integer,
3108 struct hdd_config, egap_feature_flag,
3109 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3110 CFG_ENABLE_EGAP_FLAGS_FEATURE_DEFAULT,
3111 CFG_ENABLE_EGAP_FLAGS_FEATURE_MIN,
3112 CFG_ENABLE_EGAP_FLAGS_FEATURE_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003113#endif
3114
3115 REG_VARIABLE(CFG_IGNORE_CAC_NAME, WLAN_PARAM_Integer,
3116 struct hdd_config, ignoreCAC,
3117 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3118 CFG_IGNORE_CAC_DEFAULT,
3119 CFG_IGNORE_CAC_MIN,
3120 CFG_IGNORE_CAC_MAX),
3121
3122 REG_VARIABLE(CFG_ENABLE_SAP_DFS_CH_SIFS_BURST_NAME, WLAN_PARAM_Integer,
3123 struct hdd_config, IsSapDfsChSifsBurstEnabled,
3124 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3125 CFG_ENABLE_SAP_DFS_CH_SIFS_BURST_DEFAULT,
3126 CFG_ENABLE_SAP_DFS_CH_SIFS_BURST_MIN,
3127 CFG_ENABLE_SAP_DFS_CH_SIFS_BURST_MAX),
3128
3129 REG_VARIABLE(CFG_DFS_RADAR_PRI_MULTIPLIER_NAME, WLAN_PARAM_Integer,
3130 struct hdd_config, dfsRadarPriMultiplier,
3131 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3132 CFG_DFS_RADAR_PRI_MULTIPLIER_DEFAULT,
3133 CFG_DFS_RADAR_PRI_MULTIPLIER_MIN,
3134 CFG_DFS_RADAR_PRI_MULTIPLIER_MAX),
3135
3136 REG_VARIABLE(CFG_REORDER_OFFLOAD_SUPPORT_NAME, WLAN_PARAM_Integer,
3137 struct hdd_config, reorderOffloadSupport,
3138 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3139 CFG_REORDER_OFFLOAD_SUPPORT_DEFAULT,
3140 CFG_REORDER_OFFLOAD_SUPPORT_MIN,
3141 CFG_REORDER_OFFLOAD_SUPPORT_MAX),
3142
3143 REG_VARIABLE(CFG_IPA_UC_TX_BUF_COUNT_NAME, WLAN_PARAM_Integer,
3144 struct hdd_config, IpaUcTxBufCount,
3145 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3146 CFG_IPA_UC_TX_BUF_COUNT_DEFAULT,
3147 CFG_IPA_UC_TX_BUF_COUNT_MIN,
3148 CFG_IPA_UC_TX_BUF_COUNT_MAX),
3149
3150 REG_VARIABLE(CFG_IPA_UC_TX_BUF_SIZE_NAME, WLAN_PARAM_Integer,
3151 struct hdd_config, IpaUcTxBufSize,
3152 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3153 CFG_IPA_UC_TX_BUF_SIZE_DEFAULT,
3154 CFG_IPA_UC_TX_BUF_SIZE_MIN,
3155 CFG_IPA_UC_TX_BUF_SIZE_MAX),
3156
3157 REG_VARIABLE(CFG_IPA_UC_RX_IND_RING_COUNT_NAME, WLAN_PARAM_Integer,
3158 struct hdd_config, IpaUcRxIndRingCount,
3159 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3160 CFG_IPA_UC_RX_IND_RING_COUNT_DEFAULT,
3161 CFG_IPA_UC_RX_IND_RING_COUNT_MIN,
3162 CFG_IPA_UC_RX_IND_RING_COUNT_MAX),
3163
3164 REG_VARIABLE(CFG_IPA_UC_TX_PARTITION_BASE_NAME, WLAN_PARAM_Integer,
3165 struct hdd_config, IpaUcTxPartitionBase,
3166 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3167 CFG_IPA_UC_TX_PARTITION_BASE_DEFAULT,
3168 CFG_IPA_UC_TX_PARTITION_BASE_MIN,
3169 CFG_IPA_UC_TX_PARTITION_BASE_MAX),
3170#ifdef WLAN_LOGGING_SOCK_SVC_ENABLE
3171 REG_VARIABLE(CFG_WLAN_LOGGING_SUPPORT_NAME, WLAN_PARAM_Integer,
3172 struct hdd_config, wlanLoggingEnable,
3173 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3174 CFG_WLAN_LOGGING_SUPPORT_DEFAULT,
3175 CFG_WLAN_LOGGING_SUPPORT_DISABLE,
3176 CFG_WLAN_LOGGING_SUPPORT_ENABLE),
3177
3178 REG_VARIABLE(CFG_WLAN_LOGGING_FE_CONSOLE_SUPPORT_NAME,
3179 WLAN_PARAM_Integer,
3180 struct hdd_config, wlanLoggingFEToConsole,
3181 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3182 CFG_WLAN_LOGGING_FE_CONSOLE_SUPPORT_DEFAULT,
3183 CFG_WLAN_LOGGING_FE_CONSOLE_SUPPORT_DISABLE,
3184 CFG_WLAN_LOGGING_FE_CONSOLE_SUPPORT_ENABLE),
3185
3186 REG_VARIABLE(CFG_WLAN_LOGGING_NUM_BUF_NAME, WLAN_PARAM_Integer,
3187 struct hdd_config, wlanLoggingNumBuf,
3188 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3189 CFG_WLAN_LOGGING_NUM_BUF_DEFAULT,
3190 CFG_WLAN_LOGGING_NUM_BUF_MIN,
3191 CFG_WLAN_LOGGING_NUM_BUF_MAX),
3192#endif /* WLAN_LOGGING_SOCK_SVC_ENABLE */
3193
3194 REG_VARIABLE(CFG_ENABLE_SIFS_BURST, WLAN_PARAM_Integer,
3195 struct hdd_config, enableSifsBurst,
3196 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3197 CFG_ENABLE_SIFS_BURST_DEFAULT,
3198 CFG_ENABLE_SIFS_BURST_MIN,
3199 CFG_ENABLE_SIFS_BURST_MAX),
3200
3201#ifdef WLAN_FEATURE_LPSS
3202 REG_VARIABLE(CFG_ENABLE_LPASS_SUPPORT, WLAN_PARAM_Integer,
Komal Seelamc11bb222016-01-27 18:57:10 +05303203 struct hdd_config, enable_lpass_support,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003204 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3205 CFG_ENABLE_LPASS_SUPPORT_DEFAULT,
3206 CFG_ENABLE_LPASS_SUPPORT_MIN,
3207 CFG_ENABLE_LPASS_SUPPORT_MAX),
3208#endif
3209
3210#ifdef WLAN_FEATURE_NAN
3211 REG_VARIABLE(CFG_ENABLE_NAN_SUPPORT, WLAN_PARAM_Integer,
3212 struct hdd_config, enable_nan_support,
3213 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3214 CFG_ENABLE_NAN_SUPPORT_DEFAULT,
3215 CFG_ENABLE_NAN_SUPPORT_MIN,
3216 CFG_ENABLE_NAN_SUPPORT_MAX),
3217#endif
3218
3219 REG_VARIABLE(CFG_ENABLE_SELF_RECOVERY, WLAN_PARAM_Integer,
3220 struct hdd_config, enableSelfRecovery,
3221 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3222 CFG_ENABLE_SELF_RECOVERY_DEFAULT,
3223 CFG_ENABLE_SELF_RECOVERY_MIN,
3224 CFG_ENABLE_SELF_RECOVERY_MAX),
3225
3226#ifdef FEATURE_WLAN_FORCE_SAP_SCC
3227 REG_VARIABLE(CFG_SAP_SCC_CHAN_AVOIDANCE, WLAN_PARAM_Integer,
3228 struct hdd_config, SapSccChanAvoidance,
3229 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3230 CFG_SAP_SCC_CHAN_AVOIDANCE_DEFAULT,
3231 CFG_SAP_SCC_CHAN_AVOIDANCE_MIN,
3232 CFG_SAP_SCC_CHAN_AVOIDANCE_MAX),
3233#endif /* FEATURE_WLAN_FORCE_SAP_SCC */
3234
3235 REG_VARIABLE(CFG_ENABLE_SAP_SUSPEND, WLAN_PARAM_Integer,
3236 struct hdd_config, enableSapSuspend,
3237 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3238 CFG_ENABLE_SAP_SUSPEND_DEFAULT,
3239 CFG_ENABLE_SAP_SUSPEND_MIN,
3240 CFG_ENABLE_SAP_SUSPEND_MAX),
3241
3242#ifdef WLAN_FEATURE_EXTWOW_SUPPORT
3243 REG_VARIABLE(CFG_EXTWOW_GO_TO_SUSPEND, WLAN_PARAM_Integer,
3244 struct hdd_config, extWowGotoSuspend,
3245 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3246 CFG_EXTWOW_GO_TO_SUSPEND_DEFAULT,
3247 CFG_EXTWOW_GO_TO_SUSPEND_MIN,
3248 CFG_EXTWOW_GO_TO_SUSPEND_MAX),
3249
3250 REG_VARIABLE(CFG_EXTWOW_APP1_WAKE_PIN_NUMBER, WLAN_PARAM_Integer,
3251 struct hdd_config, extWowApp1WakeupPinNumber,
3252 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3253 CFG_EXTWOW_APP1_WAKE_PIN_NUMBER_DEFAULT,
3254 CFG_EXTWOW_APP1_WAKE_PIN_NUMBER_MIN,
3255 CFG_EXTWOW_APP1_WAKE_PIN_NUMBER_MAX),
3256
3257 REG_VARIABLE(CFG_EXTWOW_APP2_WAKE_PIN_NUMBER, WLAN_PARAM_Integer,
3258 struct hdd_config, extWowApp2WakeupPinNumber,
3259 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3260 CFG_EXTWOW_APP2_WAKE_PIN_NUMBER_DEFAULT,
3261 CFG_EXTWOW_APP2_WAKE_PIN_NUMBER_MIN,
3262 CFG_EXTWOW_APP2_WAKE_PIN_NUMBER_MAX),
3263
3264 REG_VARIABLE(CFG_EXTWOW_KA_INIT_PING_INTERVAL, WLAN_PARAM_Integer,
3265 struct hdd_config, extWowApp2KAInitPingInterval,
3266 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3267 CFG_EXTWOW_KA_INIT_PING_INTERVAL_DEFAULT,
3268 CFG_EXTWOW_KA_INIT_PING_INTERVAL_MIN,
3269 CFG_EXTWOW_KA_INIT_PING_INTERVAL_MAX),
3270
3271 REG_VARIABLE(CFG_EXTWOW_KA_MIN_PING_INTERVAL, WLAN_PARAM_Integer,
3272 struct hdd_config, extWowApp2KAMinPingInterval,
3273 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3274 CFG_EXTWOW_KA_MIN_PING_INTERVAL_DEFAULT,
3275 CFG_EXTWOW_KA_MIN_PING_INTERVAL_MIN,
3276 CFG_EXTWOW_KA_MIN_PING_INTERVAL_MAX),
3277
3278 REG_VARIABLE(CFG_EXTWOW_KA_MAX_PING_INTERVAL, WLAN_PARAM_Integer,
3279 struct hdd_config, extWowApp2KAMaxPingInterval,
3280 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3281 CFG_EXTWOW_KA_MAX_PING_INTERVAL_DEFAULT,
3282 CFG_EXTWOW_KA_MAX_PING_INTERVAL_MIN,
3283 CFG_EXTWOW_KA_MAX_PING_INTERVAL_MAX),
3284
3285 REG_VARIABLE(CFG_EXTWOW_KA_INC_PING_INTERVAL, WLAN_PARAM_Integer,
3286 struct hdd_config, extWowApp2KAIncPingInterval,
3287 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3288 CFG_EXTWOW_KA_INC_PING_INTERVAL_DEFAULT,
3289 CFG_EXTWOW_KA_INC_PING_INTERVAL_MIN,
3290 CFG_EXTWOW_KA_INC_PING_INTERVAL_MAX),
3291
3292 REG_VARIABLE(CFG_EXTWOW_TCP_SRC_PORT, WLAN_PARAM_Integer,
3293 struct hdd_config, extWowApp2TcpSrcPort,
3294 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3295 CFG_EXTWOW_TCP_SRC_PORT_DEFAULT,
3296 CFG_EXTWOW_TCP_SRC_PORT_MIN,
3297 CFG_EXTWOW_TCP_SRC_PORT_MAX),
3298
3299 REG_VARIABLE(CFG_EXTWOW_TCP_DST_PORT, WLAN_PARAM_Integer,
3300 struct hdd_config, extWowApp2TcpDstPort,
3301 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3302 CFG_EXTWOW_TCP_DST_PORT_DEFAULT,
3303 CFG_EXTWOW_TCP_DST_PORT_MIN,
3304 CFG_EXTWOW_TCP_DST_PORT_MAX),
3305
3306 REG_VARIABLE(CFG_EXTWOW_TCP_TX_TIMEOUT, WLAN_PARAM_Integer,
3307 struct hdd_config, extWowApp2TcpTxTimeout,
3308 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3309 CFG_EXTWOW_TCP_TX_TIMEOUT_DEFAULT,
3310 CFG_EXTWOW_TCP_TX_TIMEOUT_MIN,
3311 CFG_EXTWOW_TCP_TX_TIMEOUT_MAX),
3312
3313 REG_VARIABLE(CFG_EXTWOW_TCP_RX_TIMEOUT, WLAN_PARAM_Integer,
3314 struct hdd_config, extWowApp2TcpRxTimeout,
3315 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3316 CFG_EXTWOW_TCP_RX_TIMEOUT_DEFAULT,
3317 CFG_EXTWOW_TCP_RX_TIMEOUT_MIN,
3318 CFG_EXTWOW_TCP_RX_TIMEOUT_MAX),
3319#endif
3320 REG_VARIABLE(CFG_ENABLE_DEAUTH_TO_DISASSOC_MAP_NAME, WLAN_PARAM_Integer,
3321 struct hdd_config, gEnableDeauthToDisassocMap,
3322 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3323 CFG_ENABLE_DEAUTH_TO_DISASSOC_MAP_DEFAULT,
3324 CFG_ENABLE_DEAUTH_TO_DISASSOC_MAP_MIN,
3325 CFG_ENABLE_DEAUTH_TO_DISASSOC_MAP_MAX),
3326#ifdef DHCP_SERVER_OFFLOAD
3327 REG_VARIABLE(CFG_DHCP_SERVER_OFFLOAD_SUPPORT_NAME, WLAN_PARAM_Integer,
3328 struct hdd_config, enableDHCPServerOffload,
3329 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3330 CFG_DHCP_SERVER_OFFLOAD_SUPPORT_DEFAULT,
3331 CFG_DHCP_SERVER_OFFLOAD_SUPPORT_MIN,
3332 CFG_DHCP_SERVER_OFFLOAD_SUPPORT_MAX),
3333 REG_VARIABLE(CFG_DHCP_SERVER_OFFLOAD_NUM_CLIENT_NAME,
3334 WLAN_PARAM_Integer,
3335 struct hdd_config, dhcpMaxNumClients,
3336 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3337 CFG_DHCP_SERVER_OFFLOAD_NUM_CLIENT_DEFAULT,
3338 CFG_DHCP_SERVER_OFFLOAD_NUM_CLIENT_MIN,
3339 CFG_DHCP_SERVER_OFFLOAD_NUM_CLIENT_MAX),
3340 REG_VARIABLE_STRING(CFG_DHCP_SERVER_IP_NAME, WLAN_PARAM_String,
3341 struct hdd_config, dhcpServerIP,
3342 VAR_FLAGS_OPTIONAL,
3343 (void *)CFG_DHCP_SERVER_IP_DEFAULT),
3344#endif /* DHCP_SERVER_OFFLOAD */
3345
3346 REG_VARIABLE(CFG_ENABLE_DEAUTH_BEFORE_CONNECTION, WLAN_PARAM_Integer,
3347 struct hdd_config, sendDeauthBeforeCon,
3348 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3349 CFG_ENABLE_DEAUTH_BEFORE_CONNECTION_DEFAULT,
3350 CFG_ENABLE_DEAUTH_BEFORE_CONNECTION_MIN,
3351 CFG_ENABLE_DEAUTH_BEFORE_CONNECTION_MAX),
3352
3353 REG_VARIABLE(CFG_ENABLE_MAC_ADDR_SPOOFING, WLAN_PARAM_Integer,
3354 struct hdd_config, enable_mac_spoofing,
3355 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3356 CFG_ENABLE_MAC_ADDR_SPOOFING_DEFAULT,
3357 CFG_ENABLE_MAC_ADDR_SPOOFING_MIN,
3358 CFG_ENABLE_MAC_ADDR_SPOOFING_MAX),
3359
3360 REG_VARIABLE(CFG_ENABLE_CUSTOM_CONC_RULE1_NAME, WLAN_PARAM_Integer,
3361 struct hdd_config, conc_custom_rule1,
3362 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3363 CFG_ENABLE_CUSTOM_CONC_RULE1_NAME_DEFAULT,
3364 CFG_ENABLE_CUSTOM_CONC_RULE1_NAME_MIN,
3365 CFG_ENABLE_CUSTOM_CONC_RULE1_NAME_MAX),
3366
3367 REG_VARIABLE(CFG_ENABLE_CUSTOM_CONC_RULE2_NAME, WLAN_PARAM_Integer,
3368 struct hdd_config, conc_custom_rule2,
3369 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3370 CFG_ENABLE_CUSTOM_CONC_RULE2_NAME_DEFAULT,
3371 CFG_ENABLE_CUSTOM_CONC_RULE2_NAME_MIN,
3372 CFG_ENABLE_CUSTOM_CONC_RULE2_NAME_MAX),
3373
3374 REG_VARIABLE(CFG_ENABLE_STA_CONNECTION_IN_5GHZ, WLAN_PARAM_Integer,
3375 struct hdd_config, is_sta_connection_in_5gz_enabled,
3376 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3377 CFG_ENABLE_STA_CONNECTION_IN_5GHZ_DEFAULT,
3378 CFG_ENABLE_STA_CONNECTION_IN_5GHZ_MIN,
3379 CFG_ENABLE_STA_CONNECTION_IN_5GHZ_MAX),
3380
3381 REG_VARIABLE(CFG_STA_MIRACAST_MCC_REST_TIME_VAL, WLAN_PARAM_Integer,
3382 struct hdd_config, sta_miracast_mcc_rest_time_val,
3383 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3384 CFG_STA_MIRACAST_MCC_REST_TIME_VAL_DEFAULT,
3385 CFG_STA_MIRACAST_MCC_REST_TIME_VAL_MIN,
3386 CFG_STA_MIRACAST_MCC_REST_TIME_VAL_MAX),
3387
3388#ifdef FEATURE_AP_MCC_CH_AVOIDANCE
3389 REG_VARIABLE(CFG_SAP_MCC_CHANNEL_AVOIDANCE_NAME,
3390 WLAN_PARAM_Integer,
3391 struct hdd_config,
3392 sap_channel_avoidance,
3393 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3394 CFG_SAP_MCC_CHANNEL_AVOIDANCE_DEFAULT,
3395 CFG_SAP_MCC_CHANNEL_AVOIDANCE_MIN,
3396 CFG_SAP_MCC_CHANNEL_AVOIDANCE_MAX),
3397#endif /* FEATURE_AP_MCC_CH_AVOIDANCE */
3398
3399 REG_VARIABLE(CFG_SAP_P2P_11AC_OVERRIDE_NAME, WLAN_PARAM_Integer,
3400 struct hdd_config, sap_p2p_11ac_override,
3401 VAR_FLAGS_OPTIONAL |
3402 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3403 CFG_SAP_P2P_11AC_OVERRIDE_DEFAULT,
3404 CFG_SAP_P2P_11AC_OVERRIDE_MIN,
3405 CFG_SAP_P2P_11AC_OVERRIDE_MAX),
3406
3407 REG_VARIABLE(CFG_ENABLE_RAMDUMP_COLLECTION, WLAN_PARAM_Integer,
3408 struct hdd_config, is_ramdump_enabled,
3409 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3410 CFG_ENABLE_RAMDUMP_COLLECTION_DEFAULT,
3411 CFG_ENABLE_RAMDUMP_COLLECTION_MIN,
3412 CFG_ENABLE_RAMDUMP_COLLECTION_MAX),
3413
3414 REG_VARIABLE(CFG_SAP_DOT11MC, WLAN_PARAM_Integer,
3415 struct hdd_config, sap_dot11mc,
3416 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3417 CFG_SAP_DOT11MC_DEFAULT,
3418 CFG_SAP_DOT11MC_MIN,
3419 CFG_SAP_DOT11MC_MAX),
3420
3421 REG_VARIABLE(CFG_ENABLE_NON_DFS_CHAN_ON_RADAR, WLAN_PARAM_Integer,
3422 struct hdd_config, prefer_non_dfs_on_radar,
3423 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3424 CFG_ENABLE_NON_DFS_CHAN_ON_RADAR_DEFAULT,
3425 CFG_ENABLE_NON_DFS_CHAN_ON_RADAR_MIN,
3426 CFG_ENABLE_NON_DFS_CHAN_ON_RADAR_MAX),
3427
3428 REG_VARIABLE(CFG_MULTICAST_HOST_FW_MSGS, WLAN_PARAM_Integer,
3429 struct hdd_config, multicast_host_fw_msgs,
3430 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3431 CFG_MULTICAST_HOST_FW_MSGS_DEFAULT,
3432 CFG_MULTICAST_HOST_FW_MSGS_MIN,
3433 CFG_MULTICAST_HOST_FW_MSGS_MAX),
3434
3435 REG_VARIABLE(CFG_CONC_SYSTEM_PREF, WLAN_PARAM_Integer,
3436 struct hdd_config, conc_system_pref,
3437 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3438 CFG_CONC_SYSTEM_PREF_DEFAULT,
3439 CFG_CONC_SYSTEM_PREF_MIN,
3440 CFG_CONC_SYSTEM_PREF_MAX),
3441
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003442 REG_VARIABLE(CFG_TSO_ENABLED_NAME, WLAN_PARAM_Integer,
3443 struct hdd_config, tso_enable,
3444 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3445 CFG_TSO_ENABLED_DEFAULT,
3446 CFG_TSO_ENABLED_MIN,
3447 CFG_TSO_ENABLED_MAX),
3448
3449 REG_VARIABLE(CFG_LRO_ENABLED_NAME, WLAN_PARAM_Integer,
3450 struct hdd_config, lro_enable,
3451 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3452 CFG_LRO_ENABLED_DEFAULT,
3453 CFG_LRO_ENABLED_MIN,
3454 CFG_LRO_ENABLED_MAX),
3455
Rajeev Kumardd3bc602016-08-16 14:21:05 -07003456 REG_VARIABLE(CFG_BPF_PACKET_FILTER_OFFLOAD, WLAN_PARAM_Integer,
3457 struct hdd_config, bpf_packet_filter_enable,
3458 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3459 CFG_BPF_PACKET_FILTER_OFFLOAD_DEFAULT,
3460 CFG_BPF_PACKET_FILTER_OFFLOAD_MIN,
3461 CFG_BPF_PACKET_FILTER_OFFLOAD_MAX),
3462
Manjunathappa Prakashfff753c2016-09-01 19:34:56 -07003463 REG_VARIABLE(CFG_FLOW_STEERING_ENABLED_NAME, WLAN_PARAM_Integer,
3464 struct hdd_config, flow_steering_enable,
3465 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3466 CFG_FLOW_STEERING_ENABLED_DEFAULT,
3467 CFG_FLOW_STEERING_ENABLED_MIN,
3468 CFG_FLOW_STEERING_ENABLED_MAX),
3469
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003470 REG_VARIABLE(CFG_ACTIVE_MODE_OFFLOAD, WLAN_PARAM_Integer,
3471 struct hdd_config, active_mode_offload,
3472 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3473 CFG_ACTIVE_MODE_OFFLOAD_DEFAULT,
3474 CFG_ACTIVE_MODE_OFFLOAD_MIN,
3475 CFG_ACTIVE_MODE_OFFLOAD_MAX),
3476
3477 REG_VARIABLE(CFG_FINE_TIME_MEAS_CAPABILITY, WLAN_PARAM_HexInteger,
3478 struct hdd_config, fine_time_meas_cap,
3479 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3480 CFG_FINE_TIME_MEAS_CAPABILITY_DEFAULT,
3481 CFG_FINE_TIME_MEAS_CAPABILITY_MIN,
3482 CFG_FINE_TIME_MEAS_CAPABILITY_MAX),
3483
3484#ifdef WLAN_FEATURE_FASTPATH
3485 REG_VARIABLE(CFG_ENABLE_FASTPATH, WLAN_PARAM_Integer,
3486 struct hdd_config, fastpath_enable,
3487 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3488 CFG_ENABLE_FASTPATH_DEFAULT,
3489 CFG_ENABLE_FASTPATH_MIN,
3490 CFG_ENABLE_FASTPATH_MAX),
3491#endif
3492 REG_VARIABLE(CFG_MAX_SCAN_COUNT_NAME, WLAN_PARAM_Integer,
3493 struct hdd_config, max_scan_count,
3494 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3495 CFG_MAX_SCAN_COUNT_DEFAULT,
3496 CFG_MAX_SCAN_COUNT_MIN,
3497 CFG_MAX_SCAN_COUNT_MAX),
3498
3499 REG_VARIABLE(CFG_DOT11P_MODE_NAME, WLAN_PARAM_Integer,
3500 struct hdd_config, dot11p_mode,
3501 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3502 CFG_DOT11P_MODE_DEFAULT,
3503 CFG_DOT11P_MODE_MIN,
3504 CFG_DOT11P_MODE_MAX),
3505
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003506#ifdef FEATURE_WLAN_EXTSCAN
Manjeet Singh0f2ce5c2016-09-01 12:08:57 +05303507 REG_VARIABLE(CFG_EXTSCAN_ALLOWED_NAME, WLAN_PARAM_Integer,
3508 struct hdd_config, extscan_enabled,
3509 VAR_FLAGS_OPTIONAL |
3510 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3511 CFG_EXTSCAN_ALLOWED_DEF,
3512 CFG_EXTSCAN_ALLOWED_MIN,
3513 CFG_EXTSCAN_ALLOWED_MAX),
3514
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003515 REG_VARIABLE(CFG_EXTSCAN_PASSIVE_MAX_CHANNEL_TIME_NAME,
3516 WLAN_PARAM_Integer,
3517 struct hdd_config, extscan_passive_max_chn_time,
3518 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3519 CFG_EXTSCAN_PASSIVE_MAX_CHANNEL_TIME_DEFAULT,
3520 CFG_EXTSCAN_PASSIVE_MAX_CHANNEL_TIME_MIN,
3521 CFG_EXTSCAN_PASSIVE_MAX_CHANNEL_TIME_MAX),
3522
3523 REG_VARIABLE(CFG_EXTSCAN_PASSIVE_MIN_CHANNEL_TIME_NAME,
3524 WLAN_PARAM_Integer,
3525 struct hdd_config, extscan_passive_min_chn_time,
3526 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3527 CFG_EXTSCAN_PASSIVE_MIN_CHANNEL_TIME_DEFAULT,
3528 CFG_EXTSCAN_PASSIVE_MIN_CHANNEL_TIME_MIN,
3529 CFG_EXTSCAN_PASSIVE_MIN_CHANNEL_TIME_MAX),
3530
3531 REG_VARIABLE(CFG_EXTSCAN_ACTIVE_MAX_CHANNEL_TIME_NAME,
3532 WLAN_PARAM_Integer,
3533 struct hdd_config, extscan_active_max_chn_time,
3534 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3535 CFG_EXTSCAN_ACTIVE_MAX_CHANNEL_TIME_DEFAULT,
3536 CFG_EXTSCAN_ACTIVE_MAX_CHANNEL_TIME_MIN,
3537 CFG_EXTSCAN_ACTIVE_MAX_CHANNEL_TIME_MAX),
3538
3539 REG_VARIABLE(CFG_EXTSCAN_ACTIVE_MIN_CHANNEL_TIME_NAME,
3540 WLAN_PARAM_Integer,
3541 struct hdd_config, extscan_active_min_chn_time,
3542 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3543 CFG_EXTSCAN_ACTIVE_MIN_CHANNEL_TIME_DEFAULT,
3544 CFG_EXTSCAN_ACTIVE_MIN_CHANNEL_TIME_MIN,
3545 CFG_EXTSCAN_ACTIVE_MIN_CHANNEL_TIME_MAX),
3546#endif
3547
3548 REG_VARIABLE(CFG_CE_CLASSIFY_ENABLE_NAME, WLAN_PARAM_Integer,
3549 struct hdd_config, ce_classify_enabled,
3550 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3551 CFG_CE_CLASSIFY_ENABLE_DEFAULT,
3552 CFG_CE_CLASSIFY_ENABLE_MIN,
3553 CFG_CE_CLASSIFY_ENABLE_MAX),
3554
3555 REG_VARIABLE(CFG_DUAL_MAC_FEATURE_DISABLE, WLAN_PARAM_HexInteger,
3556 struct hdd_config, dual_mac_feature_disable,
3557 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3558 CFG_DUAL_MAC_FEATURE_DISABLE_DEFAULT,
3559 CFG_DUAL_MAC_FEATURE_DISABLE_MIN,
3560 CFG_DUAL_MAC_FEATURE_DISABLE_MAX),
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07003561#ifdef FEATURE_WLAN_SCAN_PNO
3562 REG_VARIABLE(CFG_PNO_CHANNEL_PREDICTION_NAME, WLAN_PARAM_Integer,
3563 struct hdd_config, pno_channel_prediction,
3564 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3565 CFG_PNO_CHANNEL_PREDICTION_DEFAULT,
3566 CFG_PNO_CHANNEL_PREDICTION_MIN,
3567 CFG_PNO_CHANNEL_PREDICTION_MAX),
3568
3569 REG_VARIABLE(CFG_TOP_K_NUM_OF_CHANNELS_NAME, WLAN_PARAM_Integer,
3570 struct hdd_config, top_k_num_of_channels,
3571 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3572 CFG_TOP_K_NUM_OF_CHANNELS_DEFAULT,
3573 CFG_TOP_K_NUM_OF_CHANNELS_MIN,
3574 CFG_TOP_K_NUM_OF_CHANNELS_MAX),
3575
3576 REG_VARIABLE(CFG_STATIONARY_THRESHOLD_NAME, WLAN_PARAM_Integer,
3577 struct hdd_config, stationary_thresh,
3578 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3579 CFG_STATIONARY_THRESHOLD_DEFAULT,
3580 CFG_STATIONARY_THRESHOLD_MIN,
3581 CFG_STATIONARY_THRESHOLD_MAX),
3582
3583 REG_VARIABLE(CFG_CHANNEL_PREDICTION_FULL_SCAN_MS_NAME,
3584 WLAN_PARAM_Integer,
3585 struct hdd_config, channel_prediction_full_scan,
3586 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3587 CFG_CHANNEL_PREDICTION_FULL_SCAN_MS_DEFAULT,
3588 CFG_CHANNEL_PREDICTION_FULL_SCAN_MS_MIN,
3589 CFG_CHANNEL_PREDICTION_FULL_SCAN_MS_MAX),
Gupta, Kapil96c7f2f2016-04-25 19:13:41 +05303590
3591 REG_VARIABLE(CFG_ADAPTIVE_PNOSCAN_DWELL_MODE_NAME,
3592 WLAN_PARAM_Integer,
3593 struct hdd_config, pnoscan_adaptive_dwell_mode,
3594 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3595 CFG_ADAPTIVE_PNOSCAN_DWELL_MODE_DEFAULT,
3596 CFG_ADAPTIVE_PNOSCAN_DWELL_MODE_MIN,
3597 CFG_ADAPTIVE_PNOSCAN_DWELL_MODE_MAX),
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07003598#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003599
3600 REG_VARIABLE(CFG_TX_CHAIN_MASK_CCK, WLAN_PARAM_Integer,
3601 struct hdd_config, tx_chain_mask_cck,
3602 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3603 CFG_TX_CHAIN_MASK_CCK_DEFAULT,
3604 CFG_TX_CHAIN_MASK_CCK_MIN,
3605 CFG_TX_CHAIN_MASK_CCK_MAX),
3606
3607 REG_VARIABLE(CFG_TX_CHAIN_MASK_1SS, WLAN_PARAM_Integer,
3608 struct hdd_config, tx_chain_mask_1ss,
3609 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3610 CFG_TX_CHAIN_MASK_1SS_DEFAULT,
3611 CFG_TX_CHAIN_MASK_1SS_MIN,
3612 CFG_TX_CHAIN_MASK_1SS_MAX),
3613
3614 REG_VARIABLE(CFG_SELF_GEN_FRM_PWR, WLAN_PARAM_Integer,
3615 struct hdd_config, self_gen_frm_pwr,
3616 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3617 CFG_SELF_GEN_FRM_PWR_DEFAULT,
3618 CFG_SELF_GEN_FRM_PWR_MIN,
3619 CFG_SELF_GEN_FRM_PWR_MAX),
3620
Varun Reddy Yeturu05186292015-09-28 17:12:33 -07003621 REG_VARIABLE(CFG_EARLY_STOP_SCAN_ENABLE, WLAN_PARAM_Integer,
3622 struct hdd_config, early_stop_scan_enable,
3623 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3624 CFG_EARLY_STOP_SCAN_ENABLE_DEFAULT,
3625 CFG_EARLY_STOP_SCAN_ENABLE_MIN,
3626 CFG_EARLY_STOP_SCAN_ENABLE_MAX),
3627
3628 REG_VARIABLE(CFG_EARLY_STOP_SCAN_MIN_THRESHOLD,
3629 WLAN_PARAM_SignedInteger, struct hdd_config,
3630 early_stop_scan_min_threshold,
3631 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3632 CFG_EARLY_STOP_SCAN_MIN_THRESHOLD_DEFAULT,
3633 CFG_EARLY_STOP_SCAN_MIN_THRESHOLD_MIN,
3634 CFG_EARLY_STOP_SCAN_MIN_THRESHOLD_MAX),
3635
3636 REG_VARIABLE(CFG_EARLY_STOP_SCAN_MAX_THRESHOLD,
3637 WLAN_PARAM_SignedInteger, struct hdd_config,
3638 early_stop_scan_max_threshold,
3639 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3640 CFG_EARLY_STOP_SCAN_MAX_THRESHOLD_DEFAULT,
3641 CFG_EARLY_STOP_SCAN_MAX_THRESHOLD_MIN,
3642 CFG_EARLY_STOP_SCAN_MAX_THRESHOLD_MAX),
3643
Varun Reddy Yeturu044bda22015-11-21 22:03:40 -08003644 REG_VARIABLE(CFG_FIRST_SCAN_BUCKET_THRESHOLD_NAME,
3645 WLAN_PARAM_SignedInteger,
3646 struct hdd_config, first_scan_bucket_threshold,
3647 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3648 CFG_FIRST_SCAN_BUCKET_THRESHOLD_DEFAULT,
3649 CFG_FIRST_SCAN_BUCKET_THRESHOLD_MIN,
3650 CFG_FIRST_SCAN_BUCKET_THRESHOLD_MAX),
3651
Ravi Joshi742495d2015-11-09 18:56:53 -08003652#ifdef FEATURE_LFR_SUBNET_DETECTION
3653 REG_VARIABLE(CFG_ENABLE_LFR_SUBNET_DETECTION, WLAN_PARAM_Integer,
3654 struct hdd_config, enable_lfr_subnet_detection,
3655 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3656 CFG_ENABLE_LFR_SUBNET_DEFAULT,
3657 CFG_ENABLE_LFR_SUBNET_MIN,
3658 CFG_ENABLE_LFR_SUBNET_MAX),
3659#endif
Sandeep Puligilla93a29ec2016-02-12 16:10:56 -08003660 REG_VARIABLE(CFG_OBSS_HT40_SCAN_ACTIVE_DWELL_TIME_NAME,
3661 WLAN_PARAM_Integer,
3662 struct hdd_config, obss_active_dwelltime,
3663 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3664 CFG_OBSS_HT40_SCAN_ACTIVE_DWELL_TIME_DEFAULT,
3665 CFG_OBSS_HT40_SCAN_ACTIVE_DWELL_TIME_MIN,
3666 CFG_OBSS_HT40_SCAN_ACTIVE_DWELL_TIME_MAX),
3667
3668 REG_VARIABLE(CFG_OBSS_HT40_SCAN_PASSIVE_DWELL_TIME_NAME,
3669 WLAN_PARAM_Integer,
3670 struct hdd_config, obss_passive_dwelltime,
3671 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3672 CFG_OBSS_HT40_SCAN_PASSIVE_DWELL_TIME_DEFAULT,
3673 CFG_OBSS_HT40_SCAN_PASSIVE_DWELL_TIME_MIN,
3674 CFG_OBSS_HT40_SCAN_PASSIVE_DWELL_TIME_MAX),
3675
3676 REG_VARIABLE(CFG_OBSS_HT40_SCAN_WIDTH_TRIGGER_INTERVAL_NAME,
3677 WLAN_PARAM_Integer,
3678 struct hdd_config, obss_width_trigger_interval,
3679 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3680 CFG_OBSS_HT40_SCAN_WIDTH_TRIGGER_INTERVAL_DEFAULT,
3681 CFG_OBSS_HT40_SCAN_WIDTH_TRIGGER_INTERVAL_MIN,
3682 CFG_OBSS_HT40_SCAN_WIDTH_TRIGGER_INTERVAL_MAX),
Deepak Dhamdhere68929ec2015-08-05 15:16:35 -07003683
3684 REG_VARIABLE(CFG_INFORM_BSS_RSSI_RAW_NAME, WLAN_PARAM_Integer,
3685 struct hdd_config, inform_bss_rssi_raw,
3686 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3687 CFG_INFORM_BSS_RSSI_RAW_DEFAULT,
3688 CFG_INFORM_BSS_RSSI_RAW_MIN,
3689 CFG_INFORM_BSS_RSSI_RAW_MAX),
Tushnim Bhattacharyya24e12a62015-10-12 14:51:56 -07003690
Manikandan Mohan976e7562016-03-15 16:33:31 -07003691#ifdef WLAN_FEATURE_TSF
3692 REG_VARIABLE(CFG_SET_TSF_GPIO_PIN_NAME, WLAN_PARAM_Integer,
3693 struct hdd_config, tsf_gpio_pin,
3694 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3695 CFG_SET_TSF_GPIO_PIN_DEFAULT,
3696 CFG_SET_TSF_GPIO_PIN_MIN,
3697 CFG_SET_TSF_GPIO_PIN_MAX),
3698#endif
3699
Gupta, Kapilc68ad462016-02-01 19:17:23 +05303700 REG_VARIABLE(CFG_ROAM_DENSE_TRAFFIC_THRESHOLD, WLAN_PARAM_Integer,
3701 struct hdd_config, roam_dense_traffic_thresh,
3702 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3703 CFG_ROAM_DENSE_TRAFFIC_THRESHOLD_DEFAULT,
3704 CFG_ROAM_DENSE_TRAFFIC_THRESHOLD_MIN,
3705 CFG_ROAM_DENSE_TRAFFIC_THRESHOLD_MAX),
3706
3707 REG_VARIABLE(CFG_ROAM_DENSE_RSSI_THRE_OFFSET, WLAN_PARAM_Integer,
3708 struct hdd_config, roam_dense_rssi_thresh_offset,
3709 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3710 CFG_ROAM_DENSE_RSSI_THRE_OFFSET_DEFAULT,
3711 CFG_ROAM_DENSE_RSSI_THRE_OFFSET_MIN,
3712 CFG_ROAM_DENSE_RSSI_THRE_OFFSET_MAX),
3713
Abhishek Singh165bc602016-03-21 12:43:00 +05303714 REG_VARIABLE(CFG_IGNORE_PEER_HT_MODE_NAME, WLAN_PARAM_Integer,
3715 struct hdd_config, ignore_peer_ht_opmode,
3716 VAR_FLAGS_OPTIONAL |
3717 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3718 CFG_IGNORE_PEER_HT_MODE_DEFAULT,
3719 CFG_IGNORE_PEER_HT_MODE_MIN,
3720 CFG_IGNORE_PEER_HT_MODE_MAX),
3721
Gupta, Kapilc68ad462016-02-01 19:17:23 +05303722 REG_VARIABLE(CFG_ROAM_DENSE_MIN_APS, WLAN_PARAM_Integer,
3723 struct hdd_config, roam_dense_min_aps,
3724 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3725 CFG_ROAM_DENSE_MIN_APS_DEFAULT,
3726 CFG_ROAM_DENSE_MIN_APS_MIN,
3727 CFG_ROAM_DENSE_MIN_APS_MAX),
3728
Abhishek Singh5ea86532016-04-27 14:10:53 +05303729 REG_VARIABLE(CFG_ENABLE_FATAL_EVENT_TRIGGER, WLAN_PARAM_Integer,
3730 struct hdd_config, enable_fatal_event,
3731 VAR_FLAGS_OPTIONAL |
3732 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3733 CFG_ENABLE_FATAL_EVENT_TRIGGER_DEFAULT,
3734 CFG_ENABLE_FATAL_EVENT_TRIGGER_MIN,
3735 CFG_ENABLE_FATAL_EVENT_TRIGGER_MAX),
3736
Abhishek Singh10ecf582016-05-04 17:48:59 +05303737 REG_VARIABLE(CFG_ENABLE_EDCA_INI_NAME, WLAN_PARAM_Integer,
3738 struct hdd_config, enable_edca_params,
3739 VAR_FLAGS_OPTIONAL |
3740 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3741 CFG_ENABLE_EDCA_INI_DEFAULT,
3742 CFG_ENABLE_EDCA_INI_MIN,
3743 CFG_ENABLE_EDCA_INI_MAX),
3744
Agrawal Ashishb2d1a452016-05-05 12:23:58 +05303745 REG_VARIABLE(CFG_ENABLE_GO_CTS2SELF_FOR_STA, WLAN_PARAM_Integer,
3746 struct hdd_config, enable_go_cts2self_for_sta,
3747 VAR_FLAGS_OPTIONAL |
3748 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3749 CFG_ENABLE_GO_CTS2SELF_FOR_STA_DEFAULT,
3750 CFG_ENABLE_GO_CTS2SELF_FOR_STA_MIN,
3751 CFG_ENABLE_GO_CTS2SELF_FOR_STA_MAX),
3752
Abhishek Singh10ecf582016-05-04 17:48:59 +05303753 REG_VARIABLE(CFG_EDCA_VO_CWMIN_VALUE_NAME, WLAN_PARAM_Integer,
3754 struct hdd_config, edca_vo_cwmin,
3755 VAR_FLAGS_OPTIONAL |
3756 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3757 CFG_EDCA_VO_CWMIN_VALUE_DEFAULT,
3758 CFG_EDCA_VO_CWMIN_VALUE_MIN,
3759 CFG_EDCA_VO_CWMIN_VALUE_MAX),
3760
3761 REG_VARIABLE(CFG_EDCA_VI_CWMIN_VALUE_NAME, WLAN_PARAM_Integer,
3762 struct hdd_config, edca_vi_cwmin,
3763 VAR_FLAGS_OPTIONAL |
3764 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3765 CFG_EDCA_VI_CWMIN_VALUE_DEFAULT,
3766 CFG_EDCA_VI_CWMIN_VALUE_MIN,
3767 CFG_EDCA_VI_CWMIN_VALUE_MAX),
3768
3769 REG_VARIABLE(CFG_EDCA_BK_CWMIN_VALUE_NAME, WLAN_PARAM_Integer,
3770 struct hdd_config, edca_bk_cwmin,
3771 VAR_FLAGS_OPTIONAL |
3772 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3773 CFG_EDCA_BK_CWMIN_VALUE_DEFAULT,
3774 CFG_EDCA_BK_CWMIN_VALUE_MIN,
3775 CFG_EDCA_BK_CWMIN_VALUE_MAX),
3776
3777 REG_VARIABLE(CFG_EDCA_BE_CWMIN_VALUE_NAME, WLAN_PARAM_Integer,
3778 struct hdd_config, edca_be_cwmin,
3779 VAR_FLAGS_OPTIONAL |
3780 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3781 CFG_EDCA_BE_CWMIN_VALUE_DEFAULT,
3782 CFG_EDCA_BE_CWMIN_VALUE_MIN,
3783 CFG_EDCA_BE_CWMIN_VALUE_MAX),
3784
3785 REG_VARIABLE(CFG_EDCA_VO_CWMAX_VALUE_NAME, WLAN_PARAM_Integer,
3786 struct hdd_config, edca_vo_cwmax,
3787 VAR_FLAGS_OPTIONAL |
3788 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3789 CFG_EDCA_VO_CWMAX_VALUE_DEFAULT,
3790 CFG_EDCA_VO_CWMAX_VALUE_MIN,
3791 CFG_EDCA_VO_CWMAX_VALUE_MAX),
3792
3793 REG_VARIABLE(CFG_EDCA_VI_CWMAX_VALUE_NAME, WLAN_PARAM_Integer,
3794 struct hdd_config, edca_vi_cwmax,
3795 VAR_FLAGS_OPTIONAL |
3796 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3797 CFG_EDCA_VI_CWMAX_VALUE_DEFAULT,
3798 CFG_EDCA_VI_CWMAX_VALUE_MIN,
3799 CFG_EDCA_VI_CWMAX_VALUE_MAX),
3800
3801 REG_VARIABLE(CFG_EDCA_BK_CWMAX_VALUE_NAME, WLAN_PARAM_Integer,
3802 struct hdd_config, edca_bk_cwmax,
3803 VAR_FLAGS_OPTIONAL |
3804 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3805 CFG_EDCA_BK_CWMAX_VALUE_DEFAULT,
3806 CFG_EDCA_BK_CWMAX_VALUE_MIN,
3807 CFG_EDCA_BK_CWMAX_VALUE_MAX),
3808
3809 REG_VARIABLE(CFG_EDCA_BE_CWMAX_VALUE_NAME, WLAN_PARAM_Integer,
3810 struct hdd_config, edca_be_cwmax,
3811 VAR_FLAGS_OPTIONAL |
3812 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3813 CFG_EDCA_BE_CWMAX_VALUE_DEFAULT,
3814 CFG_EDCA_BE_CWMAX_VALUE_MIN,
3815 CFG_EDCA_BE_CWMAX_VALUE_MAX),
3816
3817 REG_VARIABLE(CFG_EDCA_VO_AIFS_VALUE_NAME, WLAN_PARAM_Integer,
3818 struct hdd_config, edca_vo_aifs,
3819 VAR_FLAGS_OPTIONAL |
3820 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3821 CFG_EDCA_VO_AIFS_VALUE_DEFAULT,
3822 CFG_EDCA_VO_AIFS_VALUE_MIN,
3823 CFG_EDCA_VO_AIFS_VALUE_MAX),
3824
3825 REG_VARIABLE(CFG_EDCA_VI_AIFS_VALUE_NAME, WLAN_PARAM_Integer,
3826 struct hdd_config, edca_vi_aifs,
3827 VAR_FLAGS_OPTIONAL |
3828 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3829 CFG_EDCA_VI_AIFS_VALUE_DEFAULT,
3830 CFG_EDCA_VI_AIFS_VALUE_MIN,
3831 CFG_EDCA_VI_AIFS_VALUE_MAX),
3832
3833 REG_VARIABLE(CFG_EDCA_BK_AIFS_VALUE_NAME, WLAN_PARAM_Integer,
3834 struct hdd_config, edca_bk_aifs,
3835 VAR_FLAGS_OPTIONAL |
3836 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3837 CFG_EDCA_BK_AIFS_VALUE_DEFAULT,
3838 CFG_EDCA_BK_AIFS_VALUE_MIN,
3839 CFG_EDCA_BK_AIFS_VALUE_MAX),
3840
3841 REG_VARIABLE(CFG_EDCA_BE_AIFS_VALUE_NAME, WLAN_PARAM_Integer,
3842 struct hdd_config, edca_be_aifs,
3843 VAR_FLAGS_OPTIONAL |
3844 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3845 CFG_EDCA_BE_AIFS_VALUE_DEFAULT,
3846 CFG_EDCA_BE_AIFS_VALUE_MIN,
3847 CFG_EDCA_BE_AIFS_VALUE_MAX),
Deepak Dhamdhere3385d752016-05-25 20:36:47 -07003848#ifdef WLAN_FEATURE_NAN_DATAPATH
3849 REG_VARIABLE(CFG_ENABLE_NAN_DATAPATH_NAME, WLAN_PARAM_Integer,
3850 struct hdd_config, enable_nan_datapath,
3851 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3852 CFG_ENABLE_NAN_DATAPATH_DEFAULT,
3853 CFG_ENABLE_NAN_DATAPATH_MIN,
3854 CFG_ENABLE_NAN_DATAPATH_MAX),
3855
3856 REG_VARIABLE(CFG_ENABLE_NAN_NDI_CHANNEL_NAME, WLAN_PARAM_Integer,
3857 struct hdd_config, nan_datapath_ndi_channel,
3858 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3859 CFG_ENABLE_NAN_NDI_CHANNEL_DEFAULT,
3860 CFG_ENABLE_NAN_NDI_CHANNEL_MIN,
3861 CFG_ENABLE_NAN_NDI_CHANNEL_MAX),
3862#endif
Kapil Gupta0ed58dc2016-04-22 15:35:26 +05303863 REG_VARIABLE(CFG_CREATE_BUG_REPORT_FOR_SCAN, WLAN_PARAM_Integer,
3864 struct hdd_config, bug_report_for_no_scan_results,
3865 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3866 CFG_CREATE_BUG_REPORT_FOR_SCAN_DEFAULT,
3867 CFG_CREATE_BUG_REPORT_FOR_SCAN_DISABLE,
3868 CFG_CREATE_BUG_REPORT_FOR_SCAN_ENABLE),
Abhishek Singh5ea86532016-04-27 14:10:53 +05303869
Nirav Shahcc1f1ae2016-04-26 11:41:29 +05303870 REG_VARIABLE(CFG_ENABLE_DP_TRACE, WLAN_PARAM_Integer,
3871 struct hdd_config, enable_dp_trace,
3872 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3873 CFG_ENABLE_DP_TRACE_DEFAULT,
3874 CFG_ENABLE_DP_TRACE_MIN,
3875 CFG_ENABLE_DP_TRACE_MAX),
Gupta, Kapil96c7f2f2016-04-25 19:13:41 +05303876
3877 REG_VARIABLE(CFG_ADAPTIVE_SCAN_DWELL_MODE_NAME, WLAN_PARAM_Integer,
3878 struct hdd_config, scan_adaptive_dwell_mode,
3879 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3880 CFG_ADAPTIVE_SCAN_DWELL_MODE_DEFAULT,
3881 CFG_ADAPTIVE_SCAN_DWELL_MODE_MIN,
3882 CFG_ADAPTIVE_SCAN_DWELL_MODE_MAX),
3883
3884 REG_VARIABLE(CFG_ADAPTIVE_ROAMSCAN_DWELL_MODE_NAME, WLAN_PARAM_Integer,
3885 struct hdd_config, roamscan_adaptive_dwell_mode,
3886 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3887 CFG_ADAPTIVE_ROAMSCAN_DWELL_MODE_DEFAULT,
3888 CFG_ADAPTIVE_ROAMSCAN_DWELL_MODE_MIN,
3889 CFG_ADAPTIVE_ROAMSCAN_DWELL_MODE_MAX),
3890
3891 REG_VARIABLE(CFG_ADAPTIVE_EXTSCAN_DWELL_MODE_NAME, WLAN_PARAM_Integer,
3892 struct hdd_config, extscan_adaptive_dwell_mode,
3893 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3894 CFG_ADAPTIVE_EXTSCAN_DWELL_MODE_DEFAULT,
3895 CFG_ADAPTIVE_EXTSCAN_DWELL_MODE_MIN,
3896 CFG_ADAPTIVE_EXTSCAN_DWELL_MODE_MAX),
3897
3898 REG_VARIABLE(CFG_ADAPTIVE_DWELL_MODE_ENABLED_NAME, WLAN_PARAM_Integer,
3899 struct hdd_config, adaptive_dwell_mode_enabled,
3900 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3901 CFG_ADAPTIVE_DWELL_MODE_ENABLED_DEFAULT,
3902 CFG_ADAPTIVE_DWELL_MODE_ENABLED_MIN,
3903 CFG_ADAPTIVE_DWELL_MODE_ENABLED_MAX),
3904
3905 REG_VARIABLE(CFG_GLOBAL_ADAPTIVE_DWELL_MODE_NAME, WLAN_PARAM_Integer,
3906 struct hdd_config, global_adapt_dwelltime_mode,
3907 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3908 CFG_GLOBAL_ADAPTIVE_DWELL_MODE_DEFAULT,
3909 CFG_GLOBAL_ADAPTIVE_DWELL_MODE_MIN,
3910 CFG_GLOBAL_ADAPTIVE_DWELL_MODE_MAX),
3911
3912 REG_VARIABLE(CFG_ADAPT_DWELL_LPF_WEIGHT_NAME, WLAN_PARAM_Integer,
3913 struct hdd_config, adapt_dwell_lpf_weight,
3914 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3915 CFG_ADAPT_DWELL_LPF_WEIGHT_DEFAULT,
3916 CFG_ADAPT_DWELL_LPF_WEIGHT_MIN,
3917 CFG_ADAPT_DWELL_LPF_WEIGHT_MAX),
3918
Naveen Rawat64e477e2016-05-20 10:34:56 -07003919 REG_VARIABLE(CFG_SUB_20_CHANNEL_WIDTH_NAME, WLAN_PARAM_Integer,
3920 struct hdd_config, enable_sub_20_channel_width,
3921 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3922 CFG_SUB_20_CHANNEL_WIDTH_DEFAULT,
3923 CFG_SUB_20_CHANNEL_WIDTH_MIN,
3924 CFG_SUB_20_CHANNEL_WIDTH_MAX),
3925
Rajeev Kumar Sirasanagandlaaf474742016-09-06 17:54:50 +05303926 REG_VARIABLE(CFG_TGT_GTX_USR_CFG_NAME, WLAN_PARAM_Integer,
3927 struct hdd_config, tgt_gtx_usr_cfg,
3928 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3929 CFG_TGT_GTX_USR_CFG_DEFAULT,
3930 CFG_TGT_GTX_USR_CFG_MIN,
3931 CFG_TGT_GTX_USR_CFG_MAX),
3932
Gupta, Kapil96c7f2f2016-04-25 19:13:41 +05303933 REG_VARIABLE(CFG_ADAPT_DWELL_PASMON_INTVAL_NAME, WLAN_PARAM_Integer,
3934 struct hdd_config, adapt_dwell_passive_mon_intval,
3935 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3936 CFG_ADAPT_DWELL_PASMON_INTVAL_DEFAULT,
3937 CFG_ADAPT_DWELL_PASMON_INTVAL_MIN,
3938 CFG_ADAPT_DWELL_PASMON_INTVAL_MAX),
3939
3940 REG_VARIABLE(CFG_ADAPT_DWELL_WIFI_THRESH_NAME, WLAN_PARAM_Integer,
3941 struct hdd_config, adapt_dwell_wifi_act_threshold,
3942 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3943 CFG_ADAPT_DWELL_WIFI_THRESH_DEFAULT,
3944 CFG_ADAPT_DWELL_WIFI_THRESH_MIN,
3945 CFG_ADAPT_DWELL_WIFI_THRESH_MAX),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003946
Nirav Shahbd36b062016-07-18 11:12:59 +05303947 REG_VARIABLE(CFG_RX_MODE_NAME, WLAN_PARAM_Integer,
3948 struct hdd_config, rx_mode,
3949 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3950 CFG_RX_MODE_DEFAULT,
3951 CFG_RX_MODE_MIN,
3952 CFG_RX_MODE_MAX),
3953
3954 REG_VARIABLE_STRING(CFG_RPS_RX_QUEUE_CPU_MAP_LIST_NAME,
3955 WLAN_PARAM_String,
3956 struct hdd_config, cpu_map_list,
3957 VAR_FLAGS_OPTIONAL,
3958 (void *)CFG_RPS_RX_QUEUE_CPU_MAP_LIST_DEFAULT),
3959
Amar Singhal18517882016-08-08 12:26:20 -07003960 REG_VARIABLE(CFG_INDOOR_CHANNEL_SUPPORT_NAME,
3961 WLAN_PARAM_Integer,
3962 struct hdd_config, indoor_channel_support,
3963 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3964 CFG_INDOOR_CHANNEL_SUPPORT_DEFAULT,
3965 CFG_INDOOR_CHANNEL_SUPPORT_MIN,
3966 CFG_INDOOR_CHANNEL_SUPPORT_MAX),
3967
Mukul Sharmaf7d62e12016-09-03 15:16:22 +05303968 REG_VARIABLE(CFG_BUG_ON_REINIT_FAILURE_NAME, WLAN_PARAM_Integer,
3969 struct hdd_config, bug_on_reinit_failure,
3970 VAR_FLAGS_OPTIONAL |
3971 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3972 CFG_BUG_ON_REINIT_FAILURE_DEFAULT,
3973 CFG_BUG_ON_REINIT_FAILURE_MIN,
3974 CFG_BUG_ON_REINIT_FAILURE_MAX),
3975
Arun Khandavallifae92942016-08-01 13:31:08 +05303976 REG_VARIABLE(CFG_INTERFACE_CHANGE_WAIT_NAME, WLAN_PARAM_Integer,
3977 struct hdd_config, iface_change_wait_time,
3978 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK,
3979 CFG_INTERFACE_CHANGE_WAIT_DEFAULT,
3980 CFG_INTERFACE_CHANGE_WAIT_MIN,
3981 CFG_INTERFACE_CHANGE_WAIT_MAX),
Ravi Joshibb8d4512016-08-22 10:14:52 -07003982
3983 REG_VARIABLE(CFG_FILTER_MULTICAST_REPLAY_NAME,
3984 WLAN_PARAM_Integer,
3985 struct hdd_config, multicast_replay_filter,
3986 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3987 CFG_FILTER_MULTICAST_REPLAY_DEFAULT,
3988 CFG_FILTER_MULTICAST_REPLAY_MIN,
3989 CFG_FILTER_MULTICAST_REPLAY_MAX),
Manjeet Singhe7ecb7c2016-09-03 12:34:53 +05303990
3991 REG_VARIABLE(CFG_SIFS_BURST_DURATION_NAME, WLAN_PARAM_Integer,
3992 struct hdd_config, sifs_burst_duration,
3993 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
3994 CFG_SIFS_BURST_DURATION_DEFAULT,
3995 CFG_SIFS_BURST_DURATION_MIN,
3996 CFG_SIFS_BURST_DURATION_MAX),
Selvaraj, Sridharebda0f22016-08-29 16:05:23 +05303997 REG_VARIABLE(CFG_OPTIMIZE_CA_EVENT_NAME, WLAN_PARAM_Integer,
3998 struct hdd_config, goptimize_chan_avoid_event,
3999 VAR_FLAGS_OPTIONAL |
4000 VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
4001 CFG_OPTIMIZE_CA_EVENT_DEFAULT,
4002 CFG_OPTIMIZE_CA_EVENT_DISABLE,
4003 CFG_OPTIMIZE_CA_EVENT_ENABLE),
Padma, Santhosh Kumara7119672016-08-16 16:05:14 +05304004
4005 REG_VARIABLE(CFG_TX_AGGREGATION_SIZE, WLAN_PARAM_Integer,
4006 struct hdd_config, tx_aggregation_size,
4007 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
4008 CFG_TX_AGGREGATION_SIZE_DEFAULT,
4009 CFG_TX_AGGREGATION_SIZE_MIN,
4010 CFG_TX_AGGREGATION_SIZE_MAX),
4011
4012 REG_VARIABLE(CFG_RX_AGGREGATION_SIZE, WLAN_PARAM_Integer,
4013 struct hdd_config, rx_aggregation_size,
4014 VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
4015 CFG_RX_AGGREGATION_SIZE_DEFAULT,
4016 CFG_RX_AGGREGATION_SIZE_MIN,
4017 CFG_RX_AGGREGATION_SIZE_MAX),
Arun Khandavallifae92942016-08-01 13:31:08 +05304018};
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004019
4020/**
4021 * get_next_line() - find and locate the new line pointer
4022 * @str: pointer to string
4023 *
4024 * This function returns a pointer to the character after the occurence
4025 * of a new line character. It also modifies the original string by replacing
4026 * the '\n' character with the null character.
4027 *
4028 * Return: the pointer to the character at new line,
4029 * or NULL if no new line character was found
4030 */
4031static char *get_next_line(char *str)
4032{
4033 char c;
4034
4035 if (str == NULL || *str == '\0') {
4036 return NULL;
4037 }
4038
4039 c = *str;
4040 while (c != '\n' && c != '\0' && c != 0xd) {
4041 str = str + 1;
4042 c = *str;
4043 }
4044
4045 if (c == '\0') {
4046 return NULL;
4047 } else {
4048 *str = '\0';
4049 return str + 1;
4050 }
4051
4052 return NULL;
4053}
4054
4055/** look for space. Ascii values to look are
4056 * 0x09 == horizontal tab
4057 * 0x0a == Newline ("\n")
4058 * 0x0b == vertical tab
4059 * 0x0c == Newpage or feed form.
4060 * 0x0d == carriage return (CR or "\r")
4061 * Null ('\0') should not considered as space.
4062 */
4063#define i_isspace(ch) (((ch) >= 0x09 && (ch) <= 0x0d) || (ch) == ' ')
4064
4065/**
4066 * i_trim() - trims any leading and trailing white spaces
4067 * @str: pointer to string
4068 *
4069 * Return: the pointer of the string
4070 */
4071static char *i_trim(char *str)
4072{
4073 char *ptr;
4074
4075 if (*str == '\0')
4076 return str;
4077
4078 /* Find the first non white-space */
4079 ptr = str;
4080 while (i_isspace(*ptr))
4081 ptr++;
4082
4083 if (*ptr == '\0')
4084 return str;
4085
4086 /* This is the new start of the string */
4087 str = ptr;
4088
4089 /* Find the last non white-space */
4090 ptr += strlen(ptr) - 1;
4091
4092 while (ptr != str && i_isspace(*ptr))
4093 ptr--;
4094
4095 /* Null terminate the following character */
4096 ptr[1] = '\0';
4097
4098 return str;
4099}
4100
4101/* Maximum length of the confgiuration name and value */
4102#define CFG_VALUE_MAX_LEN 256
4103#define CFG_ENTRY_MAX_LEN (32+CFG_VALUE_MAX_LEN)
4104
4105/**
4106 * hdd_cfg_get_config() - get the configuration content
4107 * @reg_table: pointer to configuration table
4108 * @cRegTableEntries: number of the configuration entries
4109 * @ini_struct: pointer to the hdd config knob
4110 * @pHddCtx: pointer to hdd context
4111 * @pBuf: buffer to store the configuration
4112 * @buflen: size of the buffer
4113 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304114 * Return: QDF_STATUS_SUCCESS if the configuration and buffer size can carry
4115 * the content, otherwise QDF_STATUS_E_RESOURCES
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004116 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304117static QDF_STATUS hdd_cfg_get_config(REG_TABLE_ENTRY *reg_table,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004118 unsigned long cRegTableEntries,
4119 uint8_t *ini_struct,
4120 hdd_context_t *pHddCtx, char *pBuf,
4121 int buflen)
4122{
4123 unsigned int idx;
4124 REG_TABLE_ENTRY *pRegEntry = reg_table;
4125 uint32_t value;
4126 char valueStr[CFG_VALUE_MAX_LEN];
4127 char configStr[CFG_ENTRY_MAX_LEN];
4128 char *fmt;
4129 void *pField;
Anurag Chouhan6d760662016-02-20 16:05:43 +05304130 struct qdf_mac_addr *pMacAddr;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004131 char *pCur = pBuf;
4132 int curlen;
4133
4134 /* start with an empty string */
4135 *pCur = '\0';
4136
4137 for (idx = 0; idx < cRegTableEntries; idx++, pRegEntry++) {
4138 pField = ini_struct + pRegEntry->VarOffset;
4139
4140 if ((WLAN_PARAM_Integer == pRegEntry->RegType) ||
4141 (WLAN_PARAM_SignedInteger == pRegEntry->RegType) ||
4142 (WLAN_PARAM_HexInteger == pRegEntry->RegType)) {
4143 value = 0;
4144 memcpy(&value, pField, pRegEntry->VarSize);
4145 if (WLAN_PARAM_HexInteger == pRegEntry->RegType) {
4146 fmt = "%x";
4147 } else if (WLAN_PARAM_SignedInteger ==
4148 pRegEntry->RegType) {
4149 fmt = "%d";
4150 } else {
4151 fmt = "%u";
4152 }
4153 snprintf(valueStr, CFG_VALUE_MAX_LEN, fmt, value);
4154 } else if (WLAN_PARAM_String == pRegEntry->RegType) {
4155 snprintf(valueStr, CFG_VALUE_MAX_LEN, "%s",
4156 (char *)pField);
4157 } else if (WLAN_PARAM_MacAddr == pRegEntry->RegType) {
Anurag Chouhan6d760662016-02-20 16:05:43 +05304158 pMacAddr = (struct qdf_mac_addr *) pField;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004159 snprintf(valueStr, CFG_VALUE_MAX_LEN,
4160 "%02x:%02x:%02x:%02x:%02x:%02x",
4161 pMacAddr->bytes[0],
4162 pMacAddr->bytes[1],
4163 pMacAddr->bytes[2],
4164 pMacAddr->bytes[3],
4165 pMacAddr->bytes[4], pMacAddr->bytes[5]);
4166 } else {
4167 snprintf(valueStr, CFG_VALUE_MAX_LEN, "(unhandled)");
4168 }
4169 curlen = scnprintf(configStr, CFG_ENTRY_MAX_LEN,
4170 "%s=[%s]%s\n",
4171 pRegEntry->RegName,
4172 valueStr,
4173 test_bit(idx,
4174 (void *)&pHddCtx->config->
4175 bExplicitCfg) ? "*" : "");
4176
4177 /* Ideally we want to return the config to the application,
4178 * however the config is too big so we just printk() for now
4179 */
4180#ifdef RETURN_IN_BUFFER
Hanumanth Reddy Pothulaadf163e2016-09-07 15:11:58 +05304181 if (curlen < buflen) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004182 /* copy string + '\0' */
4183 memcpy(pCur, configStr, curlen + 1);
4184
4185 /* account for addition; */
4186 pCur += curlen;
4187 buflen -= curlen;
4188 } else {
4189 /* buffer space exhausted, return what we have */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304190 return QDF_STATUS_E_RESOURCES;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004191 }
4192#else
4193 printk(KERN_INFO "%s", configStr);
4194#endif /* RETURN_IN_BUFFER */
4195
4196 }
4197
4198#ifndef RETURN_IN_BUFFER
4199 /* notify application that output is in system log */
4200 snprintf(pCur, buflen, "WLAN configuration written to system log");
4201#endif /* RETURN_IN_BUFFER */
4202
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304203 return QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004204}
4205
4206/** struct tCfgIniEntry - ini configuration entry
4207 *
4208 * @name: name of the entry
4209 * @value: value of the entry
4210 */
4211typedef struct {
4212 char *name;
4213 char *value;
4214} tCfgIniEntry;
4215
4216/**
4217 * find_cfg_item() - find the configuration item
4218 * @iniTable: pointer to configuration table
4219 * @entries: number fo the configuration entries
4220 * @name: the interested configuration to find
4221 * @value: the value to read back
4222 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304223 * Return: QDF_STATUS_SUCCESS if the interested configuration is found,
4224 * otherwise QDF_STATUS_E_FAILURE
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004225 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304226static QDF_STATUS find_cfg_item(tCfgIniEntry *iniTable, unsigned long entries,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004227 char *name, char **value)
4228{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304229 QDF_STATUS status = QDF_STATUS_E_FAILURE;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004230 unsigned long i;
4231
4232 for (i = 0; i < entries; i++) {
4233 if (strcmp(iniTable[i].name, name) == 0) {
4234 *value = iniTable[i].value;
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304235 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004236 "Found %s entry for Name=[%s] Value=[%s] ",
4237 WLAN_INI_FILE, name, *value);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304238 return QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004239 }
4240 }
4241
4242 return status;
4243}
4244
4245/**
4246 * parse_hex_digit() - conversion to hex value
4247 * @c: the character to convert
4248 *
4249 * Return: the hex value, otherwise 0
4250 */
4251static int parse_hex_digit(char c)
4252{
4253 if (c >= '0' && c <= '9')
4254 return c - '0';
4255 if (c >= 'a' && c <= 'f')
4256 return c - 'a' + 10;
4257 if (c >= 'A' && c <= 'F')
4258 return c - 'A' + 10;
4259
4260 return 0;
4261}
4262
4263/**
4264 * update_mac_from_string() - convert string to 6 bytes mac address
4265 * @pHddCtx: the pointer to hdd context
4266 * @macTable: the macTable to carry the conversion
4267 * @num: number of the interface
4268 *
4269 * 00AA00BB00CC -> 0x00 0xAA 0x00 0xBB 0x00 0xCC
4270 *
4271 * Return: None
4272 */
4273static void update_mac_from_string(hdd_context_t *pHddCtx,
4274 tCfgIniEntry *macTable, int num)
4275{
4276 int i = 0, j = 0, res = 0;
4277 char *candidate = NULL;
Anurag Chouhan6d760662016-02-20 16:05:43 +05304278 struct qdf_mac_addr macaddr[QDF_MAX_CONCURRENCY_PERSONA];
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004279
4280 memset(macaddr, 0, sizeof(macaddr));
4281
4282 for (i = 0; i < num; i++) {
4283 candidate = macTable[i].value;
Anurag Chouhan6d760662016-02-20 16:05:43 +05304284 for (j = 0; j < QDF_MAC_ADDR_SIZE; j++) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004285 res =
4286 hex2bin(&macaddr[i].bytes[j], &candidate[(j << 1)],
4287 1);
4288 if (res < 0)
4289 break;
4290 }
Anurag Chouhanc5548422016-02-24 18:33:27 +05304291 if (res == 0 && !qdf_is_macaddr_zero(&macaddr[i])) {
Anurag Chouhan600c3a02016-03-01 10:33:54 +05304292 qdf_mem_copy((uint8_t *) &pHddCtx->config->
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004293 intfMacAddr[i].bytes[0],
4294 (uint8_t *) &macaddr[i].bytes[0],
Anurag Chouhan6d760662016-02-20 16:05:43 +05304295 QDF_MAC_ADDR_SIZE);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004296 }
4297 }
4298}
4299
4300/**
4301 * hdd_apply_cfg_ini() - apply the ini configuration file
4302 * @pHddCtx: the pointer to hdd context
4303 * @iniTable: pointer to configuration table
4304 * @entries: number fo the configuration entries
4305 * It overwrites the MAC address if config file exist.
4306 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304307 * Return: QDF_STATUS_SUCCESS if the ini configuration file is correctly parsed,
4308 * otherwise QDF_STATUS_E_INVAL
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004309 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304310static QDF_STATUS hdd_apply_cfg_ini(hdd_context_t *pHddCtx,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004311 tCfgIniEntry *iniTable,
4312 unsigned long entries)
4313{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304314 QDF_STATUS match_status = QDF_STATUS_E_FAILURE;
4315 QDF_STATUS ret_status = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004316 unsigned int idx;
4317 void *pField;
4318 char *value_str = NULL;
4319 unsigned long len_value_str;
4320 char *candidate;
4321 uint32_t value;
4322 int32_t svalue;
4323 void *pStructBase = pHddCtx->config;
4324 REG_TABLE_ENTRY *pRegEntry = g_registry_table;
Anurag Chouhan6d760662016-02-20 16:05:43 +05304325 unsigned long cRegTableEntries = QDF_ARRAY_SIZE(g_registry_table);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004326 uint32_t cbOutString;
4327 int i;
4328 int rv;
4329
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004330 if (MAX_CFG_INI_ITEMS < cRegTableEntries) {
Srinivas Girigowdaba3091c2015-11-16 17:18:40 -08004331 hddLog(LOGE, FL("MAX_CFG_INI_ITEMS too small, must be at least %ld"),
4332 cRegTableEntries);
4333 WARN_ON(1);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004334 }
4335
4336 for (idx = 0; idx < cRegTableEntries; idx++, pRegEntry++) {
4337 /* Calculate the address of the destination field in the structure. */
4338 pField = ((uint8_t *) pStructBase) + pRegEntry->VarOffset;
4339
4340 match_status =
4341 find_cfg_item(iniTable, entries, pRegEntry->RegName,
4342 &value_str);
4343
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304344 if ((match_status != QDF_STATUS_SUCCESS)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004345 && (pRegEntry->Flags & VAR_FLAGS_REQUIRED)) {
4346 /* If we could not read the cfg item and it is required, this is an error. */
4347 hddLog(LOGE,
4348 "%s: Failed to read required config parameter %s",
4349 __func__, pRegEntry->RegName);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304350 ret_status = QDF_STATUS_E_FAILURE;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004351 break;
4352 }
4353
4354 if ((WLAN_PARAM_Integer == pRegEntry->RegType) ||
4355 (WLAN_PARAM_HexInteger == pRegEntry->RegType)) {
4356 /* If successfully read from the registry, use the value read.
4357 * If not, use the default value.
4358 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304359 if (match_status == QDF_STATUS_SUCCESS
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004360 && (WLAN_PARAM_Integer == pRegEntry->RegType)) {
4361 rv = kstrtou32(value_str, 10, &value);
4362 if (rv < 0) {
4363 hddLog(LOGE,
4364 "%s: Reg Parameter %s invalid. Enforcing default",
4365 __func__, pRegEntry->RegName);
4366 value = pRegEntry->VarDefault;
4367 }
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304368 } else if (match_status == QDF_STATUS_SUCCESS
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004369 && (WLAN_PARAM_HexInteger ==
4370 pRegEntry->RegType)) {
4371 rv = kstrtou32(value_str, 16, &value);
4372 if (rv < 0) {
4373 hddLog(LOGE,
4374 "%s: Reg paramter %s invalid. Enforcing default",
4375 __func__, pRegEntry->RegName);
4376 value = pRegEntry->VarDefault;
4377 }
4378 } else {
4379 value = pRegEntry->VarDefault;
4380 }
4381
4382 /* If this parameter needs range checking, do it here. */
4383 if (pRegEntry->Flags & VAR_FLAGS_RANGE_CHECK) {
4384 if (value > pRegEntry->VarMax) {
4385 hddLog(LOGE,
4386 "%s: Reg Parameter %s > allowed Maximum [%u > %lu]. Enforcing Maximum",
4387 __func__, pRegEntry->RegName,
4388 value, pRegEntry->VarMax);
4389 value = pRegEntry->VarMax;
4390 }
4391
4392 if (value < pRegEntry->VarMin) {
4393 hddLog(LOGE,
4394 "%s: Reg Parameter %s < allowed Minimum [%u < %lu]. Enforcing Minimum",
4395 __func__, pRegEntry->RegName,
4396 value, pRegEntry->VarMin);
4397 value = pRegEntry->VarMin;
4398 }
4399 }
4400 /* If this parameter needs range checking, do it here. */
4401 else if (pRegEntry->
4402 Flags & VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT) {
4403 if (value > pRegEntry->VarMax) {
4404 hddLog(LOGE,
4405 "%s: Reg Parameter %s > allowed Maximum [%u > %lu]. Enforcing Default= %lu",
4406 __func__, pRegEntry->RegName,
4407 value, pRegEntry->VarMax,
4408 pRegEntry->VarDefault);
4409 value = pRegEntry->VarDefault;
4410 }
4411
4412 if (value < pRegEntry->VarMin) {
4413 hddLog(LOGE,
4414 "%s: Reg Parameter %s < allowed Minimum [%u < %lu]. Enforcing Default= %lu",
4415 __func__, pRegEntry->RegName,
4416 value, pRegEntry->VarMin,
4417 pRegEntry->VarDefault);
4418 value = pRegEntry->VarDefault;
4419 }
4420 }
4421 /* Move the variable into the output field. */
4422 memcpy(pField, &value, pRegEntry->VarSize);
4423 } else if (WLAN_PARAM_SignedInteger == pRegEntry->RegType) {
4424 /* If successfully read from the registry, use the value read.
4425 * If not, use the default value.
4426 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304427 if (QDF_STATUS_SUCCESS == match_status) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004428 rv = kstrtos32(value_str, 10, &svalue);
4429 if (rv < 0) {
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304430 hddLog(QDF_TRACE_LEVEL_WARN,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004431 "%s: Reg Parameter %s invalid. Enforcing Default",
4432 __func__, pRegEntry->RegName);
4433 svalue =
4434 (int32_t) pRegEntry->VarDefault;
4435 }
4436 } else {
4437 svalue = (int32_t) pRegEntry->VarDefault;
4438 }
4439
4440 /* If this parameter needs range checking, do it here. */
4441 if (pRegEntry->Flags & VAR_FLAGS_RANGE_CHECK) {
4442 if (svalue > (int32_t) pRegEntry->VarMax) {
4443 hddLog(LOGE,
4444 "%s: Reg Parameter %s > allowed Maximum "
4445 "[%d > %d]. Enforcing Maximum",
4446 __func__, pRegEntry->RegName,
4447 svalue, (int)pRegEntry->VarMax);
4448 svalue = (int32_t) pRegEntry->VarMax;
4449 }
4450
4451 if (svalue < (int32_t) pRegEntry->VarMin) {
4452 hddLog(LOGE,
4453 "%s: Reg Parameter %s < allowed Minimum "
4454 "[%d < %d]. Enforcing Minimum",
4455 __func__, pRegEntry->RegName,
4456 svalue, (int)pRegEntry->VarMin);
4457 svalue = (int32_t) pRegEntry->VarMin;
4458 }
4459 }
4460 /* If this parameter needs range checking, do it here. */
4461 else if (pRegEntry->
4462 Flags & VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT) {
4463 if (svalue > (int32_t) pRegEntry->VarMax) {
4464 hddLog(LOGE,
4465 "%s: Reg Parameter %s > allowed Maximum "
4466 "[%d > %d]. Enforcing Default= %d",
4467 __func__, pRegEntry->RegName,
4468 svalue, (int)pRegEntry->VarMax,
4469 (int)pRegEntry->VarDefault);
4470 svalue =
4471 (int32_t) pRegEntry->VarDefault;
4472 }
4473
4474 if (svalue < (int32_t) pRegEntry->VarMin) {
4475 hddLog(LOGE,
4476 "%s: Reg Parameter %s < allowed Minimum "
4477 "[%d < %d]. Enforcing Default= %d",
4478 __func__, pRegEntry->RegName,
4479 svalue, (int)pRegEntry->VarMin,
4480 (int)pRegEntry->VarDefault);
4481 svalue = pRegEntry->VarDefault;
4482 }
4483 }
4484 /* Move the variable into the output field. */
4485 memcpy(pField, &svalue, pRegEntry->VarSize);
4486 }
4487 /* Handle string parameters */
4488 else if (WLAN_PARAM_String == pRegEntry->RegType) {
4489#ifdef WLAN_CFG_DEBUG
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304490 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004491 "RegName = %s, VarOffset %u VarSize %u VarDefault %s",
4492 pRegEntry->RegName, pRegEntry->VarOffset,
4493 pRegEntry->VarSize,
4494 (char *)pRegEntry->VarDefault);
4495#endif
4496
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304497 if (match_status == QDF_STATUS_SUCCESS) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004498 len_value_str = strlen(value_str);
4499
4500 if (len_value_str > (pRegEntry->VarSize - 1)) {
4501 hddLog(LOGE,
4502 "%s: Invalid Value=[%s] specified for Name=[%s] in %s",
4503 __func__, value_str,
4504 pRegEntry->RegName,
4505 WLAN_INI_FILE);
4506 cbOutString =
4507 util_min(strlen
4508 ((char *)pRegEntry->
4509 VarDefault),
4510 pRegEntry->VarSize - 1);
4511 memcpy(pField,
4512 (void *)(pRegEntry->VarDefault),
4513 cbOutString);
4514 ((uint8_t *) pField)[cbOutString] =
4515 '\0';
4516 } else {
4517 memcpy(pField, (void *)(value_str),
4518 len_value_str);
4519 ((uint8_t *) pField)[len_value_str] =
4520 '\0';
4521 }
4522 } else {
4523 /* Failed to read the string parameter from the registry. Use the default. */
4524 cbOutString =
4525 util_min(strlen((char *)pRegEntry->VarDefault),
4526 pRegEntry->VarSize - 1);
4527 memcpy(pField, (void *)(pRegEntry->VarDefault),
4528 cbOutString);
4529 ((uint8_t *) pField)[cbOutString] = '\0';
4530 }
4531 } else if (WLAN_PARAM_MacAddr == pRegEntry->RegType) {
Anurag Chouhan6d760662016-02-20 16:05:43 +05304532 if (pRegEntry->VarSize != QDF_MAC_ADDR_SIZE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004533 hddLog(LOGE,
4534 "%s: Invalid VarSize %u for Name=[%s]",
4535 __func__, pRegEntry->VarSize,
4536 pRegEntry->RegName);
4537 continue;
4538 }
4539 candidate = (char *)pRegEntry->VarDefault;
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304540 if (match_status == QDF_STATUS_SUCCESS) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004541 len_value_str = strlen(value_str);
Anurag Chouhan6d760662016-02-20 16:05:43 +05304542 if (len_value_str != (QDF_MAC_ADDR_SIZE * 2)) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004543 hddLog(LOGE,
4544 "%s: Invalid MAC addr [%s] specified for Name=[%s] in %s",
4545 __func__, value_str,
4546 pRegEntry->RegName,
4547 WLAN_INI_FILE);
4548 } else
4549 candidate = value_str;
4550 }
4551 /* parse the string and store it in the byte array */
Anurag Chouhan6d760662016-02-20 16:05:43 +05304552 for (i = 0; i < QDF_MAC_ADDR_SIZE; i++) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004553 ((char *)pField)[i] =
4554 (char)(parse_hex_digit(candidate[i * 2]) *
4555 16 +
4556 parse_hex_digit(candidate[i * 2 + 1]));
4557 }
4558 } else {
4559 hddLog(LOGE,
4560 "%s: Unknown param type for name[%s] in registry table",
4561 __func__, pRegEntry->RegName);
4562 }
4563
4564 /* did we successfully parse a cfg item for this parameter? */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304565 if ((match_status == QDF_STATUS_SUCCESS) &&
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004566 (idx < MAX_CFG_INI_ITEMS)) {
4567 set_bit(idx, (void *)&pHddCtx->config->bExplicitCfg);
4568 }
4569 }
4570
4571 return ret_status;
4572}
4573
4574/**
4575 * hdd_execute_config_command() - executes an arbitrary configuration command
4576 * @reg_table: the pointer to configuration table
4577 * @tableSize: the size of the configuration table
4578 * @ini_struct: pointer to the hdd config knob
4579 * @pHddCtx: the pointer to hdd context
4580 * @command: the command to run
4581 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304582 * Return: QDF_STATUS_SUCCESS if the command is found and able to execute,
4583 * otherwise the appropriate QDF_STATUS will be returned
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004584 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304585static QDF_STATUS hdd_execute_config_command(REG_TABLE_ENTRY *reg_table,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004586 unsigned long tableSize,
4587 uint8_t *ini_struct,
4588 hdd_context_t *pHddCtx,
4589 char *command)
4590{
4591 REG_TABLE_ENTRY *pRegEntry;
4592 char *clone;
4593 char *pCmd;
4594 void *pField;
4595 char *name;
4596 char *value_str;
4597 uint32_t value;
4598 int32_t svalue;
4599 size_t len_value_str;
4600 unsigned int idx;
4601 unsigned int i;
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304602 QDF_STATUS vstatus;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004603 int rv;
4604
4605 /* assume failure until proven otherwise */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304606 vstatus = QDF_STATUS_E_FAILURE;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004607
4608 /* clone the command so that we can manipulate it */
4609 clone = kstrdup(command, GFP_ATOMIC);
4610 if (NULL == clone) {
4611 hddLog(LOGE,
4612 "%s: memory allocation failure, unable to process [%s]",
4613 __func__, command);
4614 return vstatus;
4615 }
4616 /* 'clone' will point to the beginning of the string so it can be freed
4617 * 'pCmd' will be used to walk/parse the command
4618 */
4619 pCmd = clone;
4620
4621 /* get rid of leading/trailing whitespace */
4622 pCmd = i_trim(pCmd);
4623 if ('\0' == *pCmd) {
4624 /* only whitespace */
4625 hddLog(LOGE, "%s: invalid command, only whitespace:[%s]",
4626 __func__, command);
4627 goto done;
4628 }
4629 /* parse the <name> = <value> */
4630 name = pCmd;
4631 while (('=' != *pCmd) && ('\0' != *pCmd)) {
4632 pCmd++;
4633 }
4634 if ('\0' == *pCmd) {
4635 /* did not find '=' */
4636 hddLog(LOGE, "%s: invalid command, no '=':[%s]",
4637 __func__, command);
4638 goto done;
4639 }
4640 /* replace '=' with NUL to terminate the <name> */
4641 *pCmd++ = '\0';
4642 name = i_trim(name);
4643 if ('\0' == *name) {
4644 /* did not find a name */
4645 hddLog(LOGE, "%s: invalid command, no <name>:[%s]",
4646 __func__, command);
4647 goto done;
4648 }
4649
4650 value_str = i_trim(pCmd);
4651 if ('\0' == *value_str) {
4652 /* did not find a value */
4653 hddLog(LOGE, "%s: invalid command, no <value>:[%s]",
4654 __func__, command);
4655 goto done;
4656 }
4657 /* lookup the configuration item */
4658 for (idx = 0; idx < tableSize; idx++) {
4659 if (0 == strcmp(name, reg_table[idx].RegName)) {
4660 /* found a match */
4661 break;
4662 }
4663 }
4664 if (tableSize == idx) {
4665 /* did not match the name */
4666 hddLog(LOGE,
4667 "%s: invalid command, unknown configuration item:[%s]",
4668 __func__, command);
4669 goto done;
4670 }
4671
4672 pRegEntry = &reg_table[idx];
4673 if (!(pRegEntry->Flags & VAR_FLAGS_DYNAMIC_CFG)) {
4674 /* does not support dynamic configuration */
4675 hddLog(LOGE, "%s: Global_Registry_Table.%s does not support "
4676 "dynamic configuration", __func__, name);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304677 vstatus = QDF_STATUS_E_PERM;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004678 goto done;
4679 }
4680
4681 pField = ini_struct + pRegEntry->VarOffset;
4682
4683 switch (pRegEntry->RegType) {
4684 case WLAN_PARAM_Integer:
4685 rv = kstrtou32(value_str, 10, &value);
4686 if (rv < 0)
4687 goto done;
4688 if (value < pRegEntry->VarMin) {
4689 /* out of range */
4690 hddLog(LOGE,
4691 "%s: invalid command, value %u < min value %lu",
4692 __func__, value, pRegEntry->VarMin);
4693 goto done;
4694 }
4695 if (value > pRegEntry->VarMax) {
4696 /* out of range */
4697 hddLog(LOGE,
4698 "%s: invalid command, value %u > max value %lu",
4699 __func__, value, pRegEntry->VarMax);
4700 goto done;
4701 }
4702 memcpy(pField, &value, pRegEntry->VarSize);
4703 break;
4704
4705 case WLAN_PARAM_HexInteger:
4706 rv = kstrtou32(value_str, 16, &value);
4707 if (rv < 0)
4708 goto done;
4709 if (value < pRegEntry->VarMin) {
4710 /* out of range */
4711 hddLog(LOGE,
4712 "%s: invalid command, value %x < min value %lx",
4713 __func__, value, pRegEntry->VarMin);
4714 goto done;
4715 }
4716 if (value > pRegEntry->VarMax) {
4717 /* out of range */
4718 hddLog(LOGE,
4719 "%s: invalid command, value %x > max value %lx",
4720 __func__, value, pRegEntry->VarMax);
4721 goto done;
4722 }
4723 memcpy(pField, &value, pRegEntry->VarSize);
4724 break;
4725
4726 case WLAN_PARAM_SignedInteger:
4727 rv = kstrtos32(value_str, 10, &svalue);
4728 if (rv < 0)
4729 goto done;
4730 if (svalue < (int32_t) pRegEntry->VarMin) {
4731 /* out of range */
4732 hddLog(LOGE,
4733 "%s: invalid command, value %d < min value %d",
4734 __func__, svalue, (int)pRegEntry->VarMin);
4735 goto done;
4736 }
4737 if (svalue > (int32_t) pRegEntry->VarMax) {
4738 /* out of range */
4739 hddLog(LOGE,
4740 "%s: invalid command, value %d > max value %d",
4741 __func__, svalue, (int)pRegEntry->VarMax);
4742 goto done;
4743 }
4744 memcpy(pField, &svalue, pRegEntry->VarSize);
4745 break;
4746
4747 case WLAN_PARAM_String:
4748 len_value_str = strlen(value_str);
4749 if (len_value_str > (pRegEntry->VarSize - 1)) {
4750 /* too big */
4751 hddLog(LOGE,
4752 "%s: invalid command, string [%s] length "
4753 "%zu exceeds maximum length %u",
4754 __func__, value_str,
4755 len_value_str, (pRegEntry->VarSize - 1));
4756 goto done;
4757 }
4758 /* copy string plus NUL */
4759 memcpy(pField, value_str, (len_value_str + 1));
4760 break;
4761
4762 case WLAN_PARAM_MacAddr:
4763 len_value_str = strlen(value_str);
Anurag Chouhan6d760662016-02-20 16:05:43 +05304764 if (len_value_str != (QDF_MAC_ADDR_SIZE * 2)) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004765 /* out of range */
4766 hddLog(LOGE,
4767 "%s: invalid command, MAC address [%s] length "
4768 "%zu is not expected length %u",
4769 __func__, value_str,
Anurag Chouhan6d760662016-02-20 16:05:43 +05304770 len_value_str, (QDF_MAC_ADDR_SIZE * 2));
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004771 goto done;
4772 }
4773 /* parse the string and store it in the byte array */
Anurag Chouhan6d760662016-02-20 16:05:43 +05304774 for (i = 0; i < QDF_MAC_ADDR_SIZE; i++) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004775 ((char *)pField)[i] = (char)
4776 ((parse_hex_digit(value_str[(i * 2)]) * 16) +
4777 parse_hex_digit(value_str[(i * 2) + 1]));
4778 }
4779 break;
4780
4781 default:
4782 goto done;
4783 }
4784
4785 /* if we get here, we had a successful modification */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05304786 vstatus = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004787
4788 /* config table has been modified, is there a notifier? */
4789 if (NULL != pRegEntry->pfnDynamicnotify) {
4790 (pRegEntry->pfnDynamicnotify)(pHddCtx, pRegEntry->notifyId);
4791 }
4792 /* note that this item was explicitly configured */
4793 if (idx < MAX_CFG_INI_ITEMS) {
4794 set_bit(idx, (void *)&pHddCtx->config->bExplicitCfg);
4795 }
4796done:
4797 kfree(clone);
4798 return vstatus;
4799}
4800
4801/**
4802 * hdd_set_power_save_offload_config() - set power save offload configuration
4803 * @pHddCtx: the pointer to hdd context
4804 *
4805 * Return: none
4806 */
4807static void hdd_set_power_save_offload_config(hdd_context_t *pHddCtx)
4808{
4809 struct hdd_config *pConfig = pHddCtx->config;
4810 uint32_t listenInterval = 0;
4811
4812 if (strcmp(pConfig->PowerUsageControl, "Min") == 0) {
4813 listenInterval = pConfig->nBmpsMinListenInterval;
4814 } else if (strcmp(pConfig->PowerUsageControl, "Max") == 0) {
4815 listenInterval = pConfig->nBmpsMaxListenInterval;
4816 } else if (strcmp(pConfig->PowerUsageControl, "Mod") == 0) {
4817 listenInterval = pConfig->nBmpsModListenInterval;
4818 }
4819
4820 /*
4821 * Based on Mode Set the LI
4822 * Otherwise default LI value of 1 will
4823 * be taken
4824 */
4825 if (listenInterval) {
4826 /*
4827 * setcfg for listenInterval.
4828 * Make sure CFG is updated because PE reads this
4829 * from CFG at the time of assoc or reassoc
4830 */
4831 sme_cfg_set_int(pHddCtx->hHal, WNI_CFG_LISTEN_INTERVAL,
4832 listenInterval);
4833 }
4834
4835}
4836
Houston Hoffmanc7c69f02016-03-24 22:45:52 -07004837#ifdef FEATURE_RUNTIME_PM
4838static void hdd_cfg_print_runtime_pm(hdd_context_t *hdd_ctx)
4839{
4840 hdd_info("Name = [gRuntimePM] Value = [%u] ",
4841 hdd_ctx->config->runtime_pm);
4842
4843 hdd_info("Name = [gRuntimePMDelay] Value = [%u] ",
4844 hdd_ctx->config->runtime_pm_delay);
4845}
4846#else
4847static void hdd_cfg_print_runtime_pm(hdd_context_t *hdd_ctx)
4848{
4849}
4850#endif
4851
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004852/**
4853 * hdd_cfg_print() - print the hdd configuration
4854 * @iniTable: pointer to hdd context
4855 *
4856 * Return: None
4857 */
4858void hdd_cfg_print(hdd_context_t *pHddCtx)
4859{
4860 int i;
4861
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304862 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004863 "*********Config values in HDD Adapter*******");
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304864 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004865 "Name = [RTSThreshold] Value = %u",
4866 pHddCtx->config->RTSThreshold);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304867 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004868 "Name = [OperatingChannel] Value = [%u]",
4869 pHddCtx->config->OperatingChannel);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304870 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004871 "Name = [PowerUsageControl] Value = [%s]",
4872 pHddCtx->config->PowerUsageControl);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304873 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004874 "Name = [fIsImpsEnabled] Value = [%u]",
4875 pHddCtx->config->fIsImpsEnabled);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304876 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004877 "Name = [nVccRssiTrigger] Value = [%u]",
4878 pHddCtx->config->nVccRssiTrigger);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304879 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004880 "Name = [gIbssBssid] Value =[" MAC_ADDRESS_STR "]",
4881 MAC_ADDR_ARRAY(pHddCtx->config->IbssBssid.bytes));
4882
Anurag Chouhan6d760662016-02-20 16:05:43 +05304883 for (i = 0; i < QDF_MAX_CONCURRENCY_PERSONA; i++) {
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304884 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004885 "Name = [Intf%dMacAddress] Value =[" MAC_ADDRESS_STR "]",
4886 i, MAC_ADDR_ARRAY(pHddCtx->config->intfMacAddr[i].bytes));
4887 }
4888
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304889 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004890 "Name = [gApEnableUapsd] value = [%u]",
4891 pHddCtx->config->apUapsdEnabled);
4892
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304893 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004894 "Name = [gEnableApProt] value = [%u]",
4895 pHddCtx->config->apProtEnabled);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304896 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004897 "Name = [gAPAutoShutOff] Value = [%u]",
4898 pHddCtx->config->nAPAutoShutOff);
4899#ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304900 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004901 "Name = [gWlanMccToSccSwitchMode] Value = [%u]",
4902 pHddCtx->config->WlanMccToSccSwitchMode);
4903#endif
4904#ifdef FEATURE_WLAN_AUTO_SHUTDOWN
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304905 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004906 "Name = [gWlanAutoShutdown] Value = [%u]",
4907 pHddCtx->config->WlanAutoShutdown);
4908#endif
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304909 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004910 "Name = [gApProtection] value = [%u]",
4911 pHddCtx->config->apProtection);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304912 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004913 "Name = [gEnableApOBSSProt] value = [%u]",
4914 pHddCtx->config->apOBSSProtEnabled);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304915 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004916 "Name = [%s] value = [%u]", CFG_FORCE_SAP_ACS,
4917 pHddCtx->config->force_sap_acs);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304918 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004919 "Name = [%s] value = [%u]", CFG_FORCE_SAP_ACS_START_CH,
4920 pHddCtx->config->force_sap_acs_st_ch);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304921 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004922 "Name = [%s] value = [%u]", CFG_FORCE_SAP_ACS_END_CH,
4923 pHddCtx->config->force_sap_acs_end_ch);
4924#ifdef FEATURE_AP_MCC_CH_AVOIDANCE
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304925 QDF_TRACE(QDF_MODULE_ID_HDD,
4926 QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004927 "Name = [sap_channel_avoidance] value = [%u]",
4928 pHddCtx->config->sap_channel_avoidance);
4929#endif /* FEATURE_AP_MCC_CH_AVOIDANCE */
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304930 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004931 "Name = [%s] value = [%u]", CFG_SAP_P2P_11AC_OVERRIDE_NAME,
4932 pHddCtx->config->sap_p2p_11ac_override);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304933 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004934 "Name = [ChannelBondingMode] Value = [%u]",
4935 pHddCtx->config->nChannelBondingMode24GHz);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304936 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004937 "Name = [ChannelBondingMode] Value = [%u]",
4938 pHddCtx->config->nChannelBondingMode5GHz);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304939 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004940 "Name = [dot11Mode] Value = [%u]",
4941 pHddCtx->config->dot11Mode);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304942 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004943 "Name = [WmmMode] Value = [%u] ", pHddCtx->config->WmmMode);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304944 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004945 "Name = [UapsdMask] Value = [0x%x] ",
4946 pHddCtx->config->UapsdMask);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304947 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004948 "Name = [ImplicitQosIsEnabled] Value = [%u]",
4949 (int)pHddCtx->config->bImplicitQosEnabled);
4950
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304951 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004952 "Name = [InfraUapsdVoSrvIntv] Value = [%u] ",
4953 pHddCtx->config->InfraUapsdVoSrvIntv);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304954 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004955 "Name = [InfraUapsdVoSuspIntv] Value = [%u] ",
4956 pHddCtx->config->InfraUapsdVoSuspIntv);
4957
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304958 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004959 "Name = [InfraUapsdViSrvIntv] Value = [%u] ",
4960 pHddCtx->config->InfraUapsdViSrvIntv);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304961 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004962 "Name = [InfraUapsdViSuspIntv] Value = [%u] ",
4963 pHddCtx->config->InfraUapsdViSuspIntv);
4964
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304965 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004966 "Name = [InfraUapsdBeSrvIntv] Value = [%u] ",
4967 pHddCtx->config->InfraUapsdBeSrvIntv);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304968 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004969 "Name = [InfraUapsdBeSuspIntv] Value = [%u] ",
4970 pHddCtx->config->InfraUapsdBeSuspIntv);
4971
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304972 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004973 "Name = [InfraUapsdBkSrvIntv] Value = [%u] ",
4974 pHddCtx->config->InfraUapsdBkSrvIntv);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304975 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004976 "Name = [InfraUapsdBkSuspIntv] Value = [%u] ",
4977 pHddCtx->config->InfraUapsdBkSuspIntv);
4978#ifdef FEATURE_WLAN_ESE
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304979 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004980 "Name = [InfraInactivityInterval] Value = [%u] ",
4981 pHddCtx->config->InfraInactivityInterval);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304982 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004983 "Name = [EseEnabled] Value = [%u] ",
4984 pHddCtx->config->isEseIniFeatureEnabled);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304985 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004986 "Name = [FastTransitionEnabled] Value = [%u] ",
4987 pHddCtx->config->isFastTransitionEnabled);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304988 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004989 "Name = [gTxPowerCap] Value = [%u] dBm ",
4990 pHddCtx->config->nTxPowerCap);
4991#endif
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304992 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Padma, Santhosh Kumar29df3622016-08-16 19:15:16 +05304993 "Name = [gAllowTPCfromAP] Value = [%u] ",
4994 pHddCtx->config->allow_tpc_from_ap);
4995 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004996 "Name = [FastRoamEnabled] Value = [%u] ",
4997 pHddCtx->config->isFastRoamIniFeatureEnabled);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05304998 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08004999 "Name = [MAWCEnabled] Value = [%u] ",
5000 pHddCtx->config->MAWCEnabled);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305001 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005002 "Name = [RoamRssiDiff] Value = [%u] ",
5003 pHddCtx->config->RoamRssiDiff);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305004 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005005 "Name = [isWESModeEnabled] Value = [%u] ",
5006 pHddCtx->config->isWESModeEnabled);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305007 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005008 "Name = [OkcEnabled] Value = [%u] ",
5009 pHddCtx->config->isOkcIniFeatureEnabled);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005010#ifdef FEATURE_WLAN_SCAN_PNO
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305011 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005012 "Name = [configPNOScanSupport] Value = [%u] ",
5013 pHddCtx->config->configPNOScanSupport);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305014 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005015 "Name = [configPNOScanTimerRepeatValue] Value = [%u] ",
5016 pHddCtx->config->configPNOScanTimerRepeatValue);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305017 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Srinivas Girigowdabdc98162015-09-17 11:06:07 -07005018 "Name = [gPNOSlowScanMultiplier] Value = [%u] ",
5019 pHddCtx->config->pno_slow_scan_multiplier);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005020#endif
5021#ifdef FEATURE_WLAN_TDLS
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305022 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005023 "Name = [fEnableTDLSSupport] Value = [%u] ",
5024 pHddCtx->config->fEnableTDLSSupport);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305025 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005026 "Name = [fEnableTDLSImplicitTrigger] Value = [%u] ",
5027 pHddCtx->config->fEnableTDLSImplicitTrigger);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305028 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005029 "Name = [fTDLSExternalControl] Value = [%u] ",
5030 pHddCtx->config->fTDLSExternalControl);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305031 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005032 "Name = [fTDLSUapsdMask] Value = [%u] ",
5033 pHddCtx->config->fTDLSUapsdMask);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305034 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005035 "Name = [fEnableTDLSBufferSta] Value = [%u] ",
5036 pHddCtx->config->fEnableTDLSBufferSta);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305037 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005038 "Name = [fEnableTDLSWmmMode] Value = [%u] ",
5039 pHddCtx->config->fEnableTDLSWmmMode);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305040 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005041 "Name = [enable_tdls_scan] Value = [%u]",
5042 pHddCtx->config->enable_tdls_scan);
5043#endif
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305044 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005045 "Name = [InfraDirAcVo] Value = [%u] ",
5046 pHddCtx->config->InfraDirAcVo);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305047 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005048 "Name = [InfraNomMsduSizeAcVo] Value = [0x%x] ",
5049 pHddCtx->config->InfraNomMsduSizeAcVo);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305050 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005051 "Name = [InfraMeanDataRateAcVo] Value = [0x%x] ",
5052 pHddCtx->config->InfraMeanDataRateAcVo);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305053 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005054 "Name = [InfraMinPhyRateAcVo] Value = [0x%x] ",
5055 pHddCtx->config->InfraMinPhyRateAcVo);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305056 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005057 "Name = [InfraSbaAcVo] Value = [0x%x] ",
5058 pHddCtx->config->InfraSbaAcVo);
5059
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305060 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005061 "Name = [InfraDirAcVi] Value = [%u] ",
5062 pHddCtx->config->InfraDirAcVi);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305063 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005064 "Name = [InfraNomMsduSizeAcVi] Value = [0x%x] ",
5065 pHddCtx->config->InfraNomMsduSizeAcVi);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305066 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005067 "Name = [InfraMeanDataRateAcVi] Value = [0x%x] ",
5068 pHddCtx->config->InfraMeanDataRateAcVi);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305069 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005070 "Name = [InfraMinPhyRateAcVi] Value = [0x%x] ",
5071 pHddCtx->config->InfraMinPhyRateAcVi);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305072 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005073 "Name = [InfraSbaAcVi] Value = [0x%x] ",
5074 pHddCtx->config->InfraSbaAcVi);
5075
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305076 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005077 "Name = [InfraDirAcBe] Value = [%u] ",
5078 pHddCtx->config->InfraDirAcBe);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305079 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005080 "Name = [InfraNomMsduSizeAcBe] Value = [0x%x] ",
5081 pHddCtx->config->InfraNomMsduSizeAcBe);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305082 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005083 "Name = [InfraMeanDataRateAcBe] Value = [0x%x] ",
5084 pHddCtx->config->InfraMeanDataRateAcBe);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305085 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005086 "Name = [InfraMinPhyRateAcBe] Value = [0x%x] ",
5087 pHddCtx->config->InfraMinPhyRateAcBe);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305088 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005089 "Name = [InfraSbaAcBe] Value = [0x%x] ",
5090 pHddCtx->config->InfraSbaAcBe);
5091
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305092 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005093 "Name = [InfraDirAcBk] Value = [%u] ",
5094 pHddCtx->config->InfraDirAcBk);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305095 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005096 "Name = [InfraNomMsduSizeAcBk] Value = [0x%x] ",
5097 pHddCtx->config->InfraNomMsduSizeAcBk);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305098 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005099 "Name = [InfraMeanDataRateAcBk] Value = [0x%x] ",
5100 pHddCtx->config->InfraMeanDataRateAcBk);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305101 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005102 "Name = [InfraMinPhyRateAcBk] Value = [0x%x] ",
5103 pHddCtx->config->InfraMinPhyRateAcBk);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305104 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005105 "Name = [InfraSbaAcBk] Value = [0x%x] ",
5106 pHddCtx->config->InfraSbaAcBk);
5107
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305108 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005109 "Name = [DelayedTriggerFrmInt] Value = [%u] ",
5110 pHddCtx->config->DelayedTriggerFrmInt);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305111 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005112 "Name = [mcastBcastFilterSetting] Value = [%u] ",
5113 pHddCtx->config->mcastBcastFilterSetting);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305114 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005115 "Name = [fhostArpOffload] Value = [%u] ",
5116 pHddCtx->config->fhostArpOffload);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305117 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005118 "Name = [ssdp] Value = [%u] ", pHddCtx->config->ssdp);
Houston Hoffmanc7c69f02016-03-24 22:45:52 -07005119 hdd_cfg_print_runtime_pm(pHddCtx);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005120#ifdef FEATURE_WLAN_RA_FILTERING
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305121 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005122 "Name = [RArateLimitInterval] Value = [%u] ",
5123 pHddCtx->config->RArateLimitInterval);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305124 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005125 "Name = [IsRArateLimitEnabled] Value = [%u] ",
5126 pHddCtx->config->IsRArateLimitEnabled);
5127#endif
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305128 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005129 "Name = [fFTResourceReqSupported] Value = [%u] ",
5130 pHddCtx->config->fFTResourceReqSupported);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005131
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305132 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005133 "Name = [nNeighborLookupRssiThreshold] Value = [%u] ",
5134 pHddCtx->config->nNeighborLookupRssiThreshold);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305135 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005136 "Name = [delay_before_vdev_stop] Value = [%u] ",
5137 pHddCtx->config->delay_before_vdev_stop);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305138 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005139 "Name = [nOpportunisticThresholdDiff] Value = [%u] ",
5140 pHddCtx->config->nOpportunisticThresholdDiff);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305141 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005142 "Name = [nRoamRescanRssiDiff] Value = [%u] ",
5143 pHddCtx->config->nRoamRescanRssiDiff);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305144 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005145 "Name = [nNeighborScanMinChanTime] Value = [%u] ",
5146 pHddCtx->config->nNeighborScanMinChanTime);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305147 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005148 "Name = [nNeighborScanMaxChanTime] Value = [%u] ",
5149 pHddCtx->config->nNeighborScanMaxChanTime);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305150 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005151 "Name = [nMaxNeighborRetries] Value = [%u] ",
5152 pHddCtx->config->nMaxNeighborReqTries);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305153 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005154 "Name = [nNeighborScanPeriod] Value = [%u] ",
5155 pHddCtx->config->nNeighborScanPeriod);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305156 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005157 "Name = [nNeighborScanResultsRefreshPeriod] Value = [%u] ",
5158 pHddCtx->config->nNeighborResultsRefreshPeriod);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305159 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005160 "Name = [nEmptyScanRefreshPeriod] Value = [%u] ",
5161 pHddCtx->config->nEmptyScanRefreshPeriod);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305162 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005163 "Name = [nRoamBmissFirstBcnt] Value = [%u] ",
5164 pHddCtx->config->nRoamBmissFirstBcnt);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305165 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005166 "Name = [nRoamBmissFinalBcnt] Value = [%u] ",
5167 pHddCtx->config->nRoamBmissFinalBcnt);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305168 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005169 "Name = [nRoamBeaconRssiWeight] Value = [%u] ",
5170 pHddCtx->config->nRoamBeaconRssiWeight);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305171 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005172 "Name = [allowDFSChannelRoam] Value = [%u] ",
5173 pHddCtx->config->allowDFSChannelRoam);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305174 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005175 "Name = [nhi_rssi_scan_max_count] Value = [%u] ",
5176 pHddCtx->config->nhi_rssi_scan_max_count);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305177 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005178 "Name = [nhi_rssi_scan_rssi_delta] Value = [%u] ",
5179 pHddCtx->config->nhi_rssi_scan_rssi_delta);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305180 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005181 "Name = [nhi_rssi_scan_delay] Value = [%u] ",
5182 pHddCtx->config->nhi_rssi_scan_delay);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305183 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005184 "Name = [nhi_rssi_scan_rssi_ub] Value = [%u] ",
5185 pHddCtx->config->nhi_rssi_scan_rssi_ub);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305186 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005187 "Name = [burstSizeDefinition] Value = [0x%x] ",
5188 pHddCtx->config->burstSizeDefinition);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305189 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005190 "Name = [tsInfoAckPolicy] Value = [0x%x] ",
5191 pHddCtx->config->tsInfoAckPolicy);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305192 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005193 "Name = [rfSettlingTimeUs] Value = [%u] ",
5194 pHddCtx->config->rfSettlingTimeUs);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305195 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005196 "Name = [bSingleTidRc] Value = [%u] ",
5197 pHddCtx->config->bSingleTidRc);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305198 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005199 "Name = [gDynamicPSPollvalue] Value = [%u] ",
5200 pHddCtx->config->dynamicPsPollValue);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305201 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005202 "Name = [gAddTSWhenACMIsOff] Value = [%u] ",
5203 pHddCtx->config->AddTSWhenACMIsOff);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305204 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005205 "Name = [gValidateScanList] Value = [%u] ",
5206 pHddCtx->config->fValidateScanList);
5207
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305208 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005209 "Name = [gStaKeepAlivePeriod] Value = [%u] ",
5210 pHddCtx->config->infraStaKeepAlivePeriod);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305211 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005212 "Name = [gApDataAvailPollInterVal] Value = [%u] ",
5213 pHddCtx->config->apDataAvailPollPeriodInMs);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305214 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005215 "Name = [BandCapability] Value = [%u] ",
5216 pHddCtx->config->nBandCapability);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305217 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005218 "Name = [teleBcnWakeupEnable] Value = [%u] ",
5219 pHddCtx->config->teleBcnWakeupEn);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305220 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005221 "Name = [transListenInterval] Value = [%u] ",
5222 pHddCtx->config->nTeleBcnTransListenInterval);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305223 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005224 "Name = [transLiNumIdleBeacons] Value = [%u] ",
5225 pHddCtx->config->nTeleBcnTransLiNumIdleBeacons);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305226 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005227 "Name = [maxListenInterval] Value = [%u] ",
5228 pHddCtx->config->nTeleBcnMaxListenInterval);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305229 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005230 "Name = [maxLiNumIdleBeacons] Value = [%u] ",
5231 pHddCtx->config->nTeleBcnMaxLiNumIdleBeacons);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305232 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005233 "Name = [gApDataAvailPollInterVal] Value = [%u] ",
5234 pHddCtx->config->apDataAvailPollPeriodInMs);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305235 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005236 "Name = [gEnableBypass11d] Value = [%u] ",
5237 pHddCtx->config->enableBypass11d);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305238 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005239 "Name = [gEnableDFSChnlScan] Value = [%u] ",
5240 pHddCtx->config->enableDFSChnlScan);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305241 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005242 "Name = [gEnableDFSPnoChnlScan] Value = [%u] ",
5243 pHddCtx->config->enable_dfs_pno_chnl_scan);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305244 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005245 "Name = [gReportMaxLinkSpeed] Value = [%u] ",
5246 pHddCtx->config->reportMaxLinkSpeed);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305247 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005248 "Name = [thermalMitigationEnable] Value = [%u] ",
5249 pHddCtx->config->thermalMitigationEnable);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305250 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005251 "Name = [gVhtChannelWidth] value = [%u]",
5252 pHddCtx->config->vhtChannelWidth);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305253 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005254 "Name = [enableFirstScan2GOnly] Value = [%u] ",
5255 pHddCtx->config->enableFirstScan2GOnly);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305256 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005257 "Name = [skipDfsChnlInP2pSearch] Value = [%u] ",
5258 pHddCtx->config->skipDfsChnlInP2pSearch);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305259 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005260 "Name = [ignoreDynamicDtimInP2pMode] Value = [%u] ",
5261 pHddCtx->config->ignoreDynamicDtimInP2pMode);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305262 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005263 "Name = [enableRxSTBC] Value = [%u] ",
5264 pHddCtx->config->enableRxSTBC);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305265 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005266 "Name = [gEnableLpwrImgTransition] Value = [%u] ",
5267 pHddCtx->config->enableLpwrImgTransition);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305268 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005269 "Name = [gEnableSSR] Value = [%u] ",
5270 pHddCtx->config->enableSSR);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305271 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005272 "Name = [gEnableVhtFor24GHzBand] Value = [%u] ",
5273 pHddCtx->config->enableVhtFor24GHzBand);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305274 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005275 "Name = [gEnableIbssHeartBeatOffload] Value = [%u] ",
5276 pHddCtx->config->enableIbssHeartBeatOffload);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305277 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005278 "Name = [gAntennaDiversity] Value = [%u] ",
5279 pHddCtx->config->antennaDiversity);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305280 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005281 "Name = [gGoLinkMonitorPeriod] Value = [%u]",
5282 pHddCtx->config->goLinkMonitorPeriod);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305283 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005284 "Name = [gApLinkMonitorPeriod] Value = [%u]",
5285 pHddCtx->config->apLinkMonitorPeriod);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305286 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005287 "Name = [gGoKeepAlivePeriod] Value = [%u]",
5288 pHddCtx->config->goKeepAlivePeriod);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305289 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005290 "Name = [gApKeepAlivePeriod]Value = [%u]",
5291 pHddCtx->config->apKeepAlivePeriod);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305292 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005293 "Name = [gAmsduSupportInAMPDU] Value = [%u] ",
5294 pHddCtx->config->isAmsduSupportInAMPDU);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305295 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005296 "Name = [nSelect5GHzMargin] Value = [%u] ",
5297 pHddCtx->config->nSelect5GHzMargin);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305298 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005299 "Name = [gCoalesingInIBSS] Value = [%u] ",
5300 pHddCtx->config->isCoalesingInIBSSAllowed);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305301 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005302 "Name = [gIbssATIMWinSize] Value = [%u] ",
5303 pHddCtx->config->ibssATIMWinSize);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305304 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005305 "Name = [gIbssIsPowerSaveAllowed] Value = [%u] ",
5306 pHddCtx->config->isIbssPowerSaveAllowed);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305307 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005308 "Name = [gIbssIsPowerCollapseAllowed] Value = [%u] ",
5309 pHddCtx->config->isIbssPowerCollapseAllowed);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305310 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005311 "Name = [gIbssAwakeOnTxRx] Value = [%u] ",
5312 pHddCtx->config->isIbssAwakeOnTxRx);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305313 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005314 "Name = [gIbssInactivityTime] Value = [%u] ",
5315 pHddCtx->config->ibssInactivityCount);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305316 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005317 "Name = [gIbssTxSpEndInactivityTime] Value = [%u] ",
5318 pHddCtx->config->ibssTxSpEndInactivityTime);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305319 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005320 "Name = [gIbssPsWarmupTime] Value = [%u] ",
5321 pHddCtx->config->ibssPsWarmupTime);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305322 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005323 "Name = [gIbssPs1RxChainInAtim] Value = [%u] ",
5324 pHddCtx->config->ibssPs1RxChainInAtimEnable);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305325 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005326 "Name = [fDfsPhyerrFilterOffload] Value = [%u] ",
5327 pHddCtx->config->fDfsPhyerrFilterOffload);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305328 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005329 "Name = [gIgnorePeerErpInfo] Value = [%u] ",
5330 pHddCtx->config->ignore_peer_erp_info);
5331#ifdef IPA_OFFLOAD
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305332 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005333 "Name = [gIPAConfig] Value = [0x%x] ",
5334 pHddCtx->config->IpaConfig);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305335 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005336 "Name = [gIPADescSize] Value = [%u] ",
5337 pHddCtx->config->IpaDescSize);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305338 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005339 "Name = [IpaHighBandwidthMbpsg] Value = [%u] ",
5340 pHddCtx->config->IpaHighBandwidthMbps);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305341 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005342 "Name = [IpaMediumBandwidthMbps] Value = [%u] ",
5343 pHddCtx->config->IpaMediumBandwidthMbps);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305344 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005345 "Name = [IpaLowBandwidthMbps] Value = [%u] ",
5346 pHddCtx->config->IpaLowBandwidthMbps);
5347#endif
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305348 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005349 "Name = [gEnableOverLapCh] Value = [%u] ",
5350 pHddCtx->config->gEnableOverLapCh);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305351 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005352 "Name = [gMaxOffloadPeers] Value = [%u] ",
5353 pHddCtx->config->apMaxOffloadPeers);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305354 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005355 "Name = [gMaxOffloadReorderBuffs] value = [%u] ",
5356 pHddCtx->config->apMaxOffloadReorderBuffs);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305357 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005358 "Name = [gAllowDFSChannelRoam] Value = [%u] ",
5359 pHddCtx->config->allowDFSChannelRoam);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305360 hddLog(QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005361 "Name = [gMaxConcurrentActiveSessions] Value = [%u] ",
5362 pHddCtx->config->gMaxConcurrentActiveSessions);
5363
5364#ifdef MSM_PLATFORM
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305365 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005366 "Name = [gBusBandwidthHighThreshold] Value = [%u] ",
5367 pHddCtx->config->busBandwidthHighThreshold);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305368 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005369 "Name = [gBusBandwidthMediumThreshold] Value = [%u] ",
5370 pHddCtx->config->busBandwidthMediumThreshold);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305371 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005372 "Name = [gBusBandwidthLowThreshold] Value = [%u] ",
5373 pHddCtx->config->busBandwidthLowThreshold);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305374 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005375 "Name = [gbusBandwidthComputeInterval] Value = [%u] ",
5376 pHddCtx->config->busBandwidthComputeInterval);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305377 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Ravi Joshie2331e82015-07-01 18:18:54 -07005378 "Name = [%s] Value = [%u] ",
5379 CFG_ENABLE_TCP_DELACK,
5380 pHddCtx->config->enable_tcp_delack);
5381 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005382 "Name = [gTcpDelAckThresholdHigh] Value = [%u] ",
5383 pHddCtx->config->tcpDelackThresholdHigh);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305384 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005385 "Name = [gTcpDelAckThresholdLow] Value = [%u] ",
5386 pHddCtx->config->tcpDelackThresholdLow);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305387 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Ravi Joshib89e7f72016-09-07 13:43:15 -07005388 "Name = [%s] Value = [%u] ",
5389 CFG_TCP_DELACK_TIMER_COUNT,
5390 pHddCtx->config->tcp_delack_timer_count);
5391 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
5392 "Name = [%s] Value = [%u] ",
5393 CFG_TCP_TX_HIGH_TPUT_THRESHOLD_NAME,
5394 pHddCtx->config->tcp_tx_high_tput_thres);
Mohit Khannae71e2262015-11-10 09:37:24 -08005395
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005396#endif
5397
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305398 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005399 "Name = [gIgnoreCAC] Value = [%u] ",
5400 pHddCtx->config->ignoreCAC);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305401 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005402 "Name = [gSapPreferredChanLocation] Value = [%u] ",
5403 pHddCtx->config->gSapPreferredChanLocation);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305404 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005405 "Name = [gDisableDfsJapanW53] Value = [%u] ",
5406 pHddCtx->config->gDisableDfsJapanW53);
5407#ifdef FEATURE_GREEN_AP
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305408 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005409 "Name = [gEnableGreenAp] Value = [%u] ",
5410 pHddCtx->config->enableGreenAP);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305411 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Ryan Hsucb118cf2015-11-09 16:03:53 -08005412 "Name = [gEenableEGAP] Value = [%u] ",
5413 pHddCtx->config->enable_egap);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305414 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Ryan Hsucb118cf2015-11-09 16:03:53 -08005415 "Name = [gEGAPInactTime] Value = [%u] ",
5416 pHddCtx->config->egap_inact_time);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305417 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Ryan Hsucb118cf2015-11-09 16:03:53 -08005418 "Name = [gEGAPWaitTime] Value = [%u] ",
5419 pHddCtx->config->egap_wait_time);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305420 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Ryan Hsucb118cf2015-11-09 16:03:53 -08005421 "Name = [gEGAPFeatures] Value = [%u] ",
5422 pHddCtx->config->egap_feature_flag);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005423#endif
5424#ifdef WLAN_FEATURE_ROAM_OFFLOAD
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305425 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005426 "Name = [isRoamOffloadEnabled] Value = [%u]",
5427 pHddCtx->config->isRoamOffloadEnabled);
5428#endif
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305429 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005430 "Name = [gEnableSifsBurst] Value = [%u]",
5431 pHddCtx->config->enableSifsBurst);
5432
5433#ifdef WLAN_FEATURE_LPSS
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305434 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005435 "Name = [gEnableLpassSupport] Value = [%u] ",
Komal Seelamc11bb222016-01-27 18:57:10 +05305436 pHddCtx->config->enable_lpass_support);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005437#endif
5438
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305439 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005440 "Name = [gEnableSelfRecovery] Value = [%u]",
5441 pHddCtx->config->enableSelfRecovery);
5442
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305443 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005444 "Name = [gEnableSapSuspend] Value = [%u]",
5445 pHddCtx->config->enableSapSuspend);
5446
5447#ifdef WLAN_FEATURE_EXTWOW_SUPPORT
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305448 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005449 "Name = [gExtWoWgotoSuspend] Value = [%u]",
5450 pHddCtx->config->extWowGotoSuspend);
5451
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305452 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005453 "Name = [gExtWowApp1WakeupPinNumber] Value = [%u]",
5454 pHddCtx->config->extWowApp1WakeupPinNumber);
5455
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305456 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005457 "Name = [gExtWowApp2WakeupPinNumber] Value = [%u]",
5458 pHddCtx->config->extWowApp2WakeupPinNumber);
5459
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305460 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005461 "Name = [gExtWoWApp2KAInitPingInterval] Value = [%u]",
5462 pHddCtx->config->extWowApp2KAInitPingInterval);
5463
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305464 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005465 "Name = [gExtWoWApp2KAMinPingInterval] Value = [%u]",
5466 pHddCtx->config->extWowApp2KAMinPingInterval);
5467
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305468 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005469 "Name = [gExtWoWApp2KAMaxPingInterval] Value = [%u]",
5470 pHddCtx->config->extWowApp2KAMaxPingInterval);
5471
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305472 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005473 "Name = [gExtWoWApp2KAIncPingInterval] Value = [%u]",
5474 pHddCtx->config->extWowApp2KAIncPingInterval);
5475
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305476 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005477 "Name = [gExtWoWApp2TcpSrcPort] Value = [%u]",
5478 pHddCtx->config->extWowApp2TcpSrcPort);
5479
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305480 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005481 "Name = [gExtWoWApp2TcpDstPort] Value = [%u]",
5482 pHddCtx->config->extWowApp2TcpDstPort);
5483
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305484 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005485 "Name = [gExtWoWApp2TcpTxTimeout] Value = [%u]",
5486 pHddCtx->config->extWowApp2TcpTxTimeout);
5487
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305488 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005489 "Name = [gExtWoWApp2TcpRxTimeout] Value = [%u]",
5490 pHddCtx->config->extWowApp2TcpRxTimeout);
5491#endif
5492
5493#ifdef DHCP_SERVER_OFFLOAD
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305494 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005495 "Name = [gDHCPServerOffloadEnable] Value = [%u]",
5496 pHddCtx->config->enableDHCPServerOffload);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305497 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005498 "Name = [gDHCPMaxNumClients] Value = [%u]",
5499 pHddCtx->config->dhcpMaxNumClients);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305500 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005501 "Name = [gDHCPServerIP] Value = [%s]",
5502 pHddCtx->config->dhcpServerIP);
5503#endif
5504
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305505 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005506 "Name = [gEnableDumpCollect] Value = [%u]",
5507 pHddCtx->config->is_ramdump_enabled);
5508
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305509 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005510 "Name = [gP2PListenDeferInterval] Value = [%u]",
5511 pHddCtx->config->p2p_listen_defer_interval);
Archana Ramachandrane87005c2016-08-23 16:57:30 -07005512 hdd_notice("Name = [is_ps_enabled] value = [%d]",
5513 pHddCtx->config->is_ps_enabled);
5514 hdd_notice("Name = [tso_enable] value = [%d]",
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005515 pHddCtx->config->tso_enable);
Archana Ramachandrane87005c2016-08-23 16:57:30 -07005516 hdd_notice("Name = [LROEnable] value = [%d]",
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005517 pHddCtx->config->lro_enable);
Archana Ramachandrane87005c2016-08-23 16:57:30 -07005518 hdd_notice("Name = [active_mode_offload] value = [%d]",
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005519 pHddCtx->config->active_mode_offload);
Archana Ramachandrane87005c2016-08-23 16:57:30 -07005520 hdd_notice("Name = [gfine_time_meas_cap] value = [%u]",
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005521 pHddCtx->config->fine_time_meas_cap);
5522#ifdef WLAN_FEATURE_FASTPATH
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305523 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005524 "Name = [fastpath_enable] Value = [%u]",
5525 pHddCtx->config->fastpath_enable);
5526#endif
Archana Ramachandrane87005c2016-08-23 16:57:30 -07005527 hdd_notice("Name = [max_scan_count] value = [%d]",
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005528 pHddCtx->config->max_scan_count);
Archana Ramachandrane87005c2016-08-23 16:57:30 -07005529 hdd_notice("Name = [%s] value = [%d]",
Nirav Shahbd36b062016-07-18 11:12:59 +05305530 CFG_RX_MODE_NAME, pHddCtx->config->rx_mode);
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305531 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005532 "Name = [%s] Value = [%u]",
5533 CFG_CE_CLASSIFY_ENABLE_NAME,
5534 pHddCtx->config->ce_classify_enabled);
Archana Ramachandrane87005c2016-08-23 16:57:30 -07005535 hdd_notice("Name = [%s] value = [%u]",
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005536 CFG_DUAL_MAC_FEATURE_DISABLE,
5537 pHddCtx->config->dual_mac_feature_disable);
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07005538#ifdef FEATURE_WLAN_SCAN_PNO
Archana Ramachandrane87005c2016-08-23 16:57:30 -07005539 hdd_notice("Name = [%s] Value = [%u]",
5540 CFG_PNO_CHANNEL_PREDICTION_NAME,
5541 pHddCtx->config->pno_channel_prediction);
5542 hdd_notice("Name = [%s] Value = [%u]",
5543 CFG_TOP_K_NUM_OF_CHANNELS_NAME,
5544 pHddCtx->config->top_k_num_of_channels);
5545 hdd_notice("Name = [%s] Value = [%u]",
5546 CFG_STATIONARY_THRESHOLD_NAME,
5547 pHddCtx->config->stationary_thresh);
5548 hdd_notice("Name = [%s] Value = [%u]",
5549 CFG_CHANNEL_PREDICTION_FULL_SCAN_MS_NAME,
5550 pHddCtx->config->channel_prediction_full_scan);
5551 hdd_notice("Name = [%s] Value = [%u]",
5552 CFG_ADAPTIVE_PNOSCAN_DWELL_MODE_NAME,
5553 pHddCtx->config->pnoscan_adaptive_dwell_mode);
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07005554#endif
Archana Ramachandrane87005c2016-08-23 16:57:30 -07005555 hdd_notice("Name = [%s] Value = [%d]",
5556 CFG_EARLY_STOP_SCAN_ENABLE,
5557 pHddCtx->config->early_stop_scan_enable);
5558 hdd_notice("Name = [%s] Value = [%d]",
5559 CFG_EARLY_STOP_SCAN_MIN_THRESHOLD,
5560 pHddCtx->config->early_stop_scan_min_threshold);
5561 hdd_notice("Name = [%s] Value = [%d]",
5562 CFG_EARLY_STOP_SCAN_MAX_THRESHOLD,
5563 pHddCtx->config->early_stop_scan_max_threshold);
5564 hdd_notice("Name = [%s] Value = [%d]",
5565 CFG_FIRST_SCAN_BUCKET_THRESHOLD_NAME,
5566 pHddCtx->config->first_scan_bucket_threshold);
5567 hdd_notice("Name = [%s] Value = [%u]",
5568 CFG_HT_MPDU_DENSITY_NAME,
5569 pHddCtx->config->ht_mpdu_density);
Krishna Kumaar Natarajan22b59a72015-11-23 18:54:58 -08005570
Ravi Joshi742495d2015-11-09 18:56:53 -08005571
5572#ifdef FEATURE_LFR_SUBNET_DETECTION
Archana Ramachandrane87005c2016-08-23 16:57:30 -07005573 hdd_notice("Name = [%s] Value = [%d]",
5574 CFG_ENABLE_LFR_SUBNET_DETECTION,
5575 pHddCtx->config->enable_lfr_subnet_detection);
Ravi Joshi742495d2015-11-09 18:56:53 -08005576#endif
Gupta, Kapilc68ad462016-02-01 19:17:23 +05305577 hdd_info("Name = [%s] Value = [%u]",
5578 CFG_ROAM_DENSE_TRAFFIC_THRESHOLD,
5579 pHddCtx->config->roam_dense_traffic_thresh);
5580 hdd_info("Name = [%s] Value = [%u]",
5581 CFG_ROAM_DENSE_RSSI_THRE_OFFSET,
5582 pHddCtx->config->roam_dense_rssi_thresh_offset);
5583 hdd_info("Name = [%s] Value = [%u]",
Abhishek Singh165bc602016-03-21 12:43:00 +05305584 CFG_IGNORE_PEER_HT_MODE_NAME,
5585 pHddCtx->config->ignore_peer_ht_opmode);
5586 hdd_info("Name = [%s] Value = [%u]",
Kapil Gupta4b2efbb2016-10-03 13:07:20 +05305587 CFG_ENABLE_VENDOR_VHT_FOR_24GHZ_NAME,
5588 pHddCtx->config->enable_sap_vendor_vht);
5589 hdd_info("Name = [%s] Value = [%u]",
Abhishek Singh5ea86532016-04-27 14:10:53 +05305590 CFG_ENABLE_FATAL_EVENT_TRIGGER,
5591 pHddCtx->config->enable_fatal_event);
5592 hdd_info("Name = [%s] Value = [%u]",
Gupta, Kapilc68ad462016-02-01 19:17:23 +05305593 CFG_ROAM_DENSE_MIN_APS,
5594 pHddCtx->config->roam_dense_min_aps);
Agrawal Ashish17bb3902016-05-05 13:29:40 +05305595 hdd_info("Name = [%s] Value = [%u]",
5596 CFG_MIN_REST_TIME_NAME,
5597 pHddCtx->config->min_rest_time_conc);
5598 hdd_info("Name = [%s] Value = [%u]",
5599 CFG_IDLE_TIME_NAME,
5600 pHddCtx->config->idle_time_conc);
Mukul Sharmaf7d62e12016-09-03 15:16:22 +05305601 hdd_info("Name = [%s] Value = [%d]",
5602 CFG_BUG_ON_REINIT_FAILURE_NAME,
5603 pHddCtx->config->bug_on_reinit_failure);
Arun Khandavallifae92942016-08-01 13:31:08 +05305604 hdd_info("Name = [%s] Value = [%u]",
5605 CFG_INTERFACE_CHANGE_WAIT_NAME,
5606 pHddCtx->config->iface_change_wait_time);
Agrawal Ashish17bb3902016-05-05 13:29:40 +05305607
Abhishek Singh10ecf582016-05-04 17:48:59 +05305608 hdd_info("Name = [%s] Value = [%u]",
5609 CFG_ENABLE_EDCA_INI_NAME,
5610 pHddCtx->config->enable_edca_params);
5611
5612 hdd_info("Name = [%s] Value = [%u]",
5613 CFG_EDCA_VO_CWMIN_VALUE_NAME,
5614 pHddCtx->config->edca_vo_cwmin);
5615 hdd_info("Name = [%s] Value = [%u]",
5616 CFG_EDCA_VI_CWMIN_VALUE_NAME,
5617 pHddCtx->config->edca_vi_cwmin);
5618 hdd_info("Name = [%s] Value = [%u]",
5619 CFG_EDCA_BK_CWMIN_VALUE_NAME,
5620 pHddCtx->config->edca_bk_cwmin);
5621 hdd_info("Name = [%s] Value = [%u]",
5622 CFG_EDCA_BE_CWMIN_VALUE_NAME,
5623 pHddCtx->config->edca_be_cwmin);
5624
5625 hdd_info("Name = [%s] Value = [%u]",
5626 CFG_EDCA_VO_CWMAX_VALUE_NAME,
5627 pHddCtx->config->edca_vo_cwmax);
5628 hdd_info("Name = [%s] Value = [%u]",
5629 CFG_EDCA_VI_CWMAX_VALUE_NAME,
5630 pHddCtx->config->edca_vi_cwmax);
5631 hdd_info("Name = [%s] Value = [%u]",
5632 CFG_EDCA_BK_CWMAX_VALUE_NAME,
5633 pHddCtx->config->edca_bk_cwmax);
5634 hdd_info("Name = [%s] Value = [%u]",
5635 CFG_EDCA_BE_CWMAX_VALUE_NAME,
5636 pHddCtx->config->edca_be_cwmax);
5637
5638 hdd_info("Name = [%s] Value = [%u]",
5639 CFG_EDCA_VO_AIFS_VALUE_NAME,
5640 pHddCtx->config->edca_vo_aifs);
5641 hdd_info("Name = [%s] Value = [%u]",
5642 CFG_EDCA_VI_AIFS_VALUE_NAME,
5643 pHddCtx->config->edca_vi_aifs);
5644 hdd_info("Name = [%s] Value = [%u]",
5645 CFG_EDCA_BK_AIFS_VALUE_NAME,
5646 pHddCtx->config->edca_bk_aifs);
5647 hdd_info("Name = [%s] Value = [%u]",
5648 CFG_EDCA_BE_AIFS_VALUE_NAME,
5649 pHddCtx->config->edca_be_aifs);
Nirav Shahcc1f1ae2016-04-26 11:41:29 +05305650 hdd_info("Name = [%s] Value = [%u]",
5651 CFG_ENABLE_DP_TRACE,
5652 pHddCtx->config->enable_dp_trace);
Gupta, Kapil96c7f2f2016-04-25 19:13:41 +05305653 hdd_info("Name = [%s] Value = [%u]",
5654 CFG_ADAPTIVE_SCAN_DWELL_MODE_NAME,
5655 pHddCtx->config->scan_adaptive_dwell_mode);
5656 hdd_info("Name = [%s] Value = [%u]",
5657 CFG_ADAPTIVE_ROAMSCAN_DWELL_MODE_NAME,
5658 pHddCtx->config->roamscan_adaptive_dwell_mode);
5659 hdd_info("Name = [%s] Value = [%u]",
5660 CFG_ADAPTIVE_EXTSCAN_DWELL_MODE_NAME,
5661 pHddCtx->config->extscan_adaptive_dwell_mode);
5662 hdd_info("Name = [%s] Value = [%u]",
5663 CFG_ADAPTIVE_DWELL_MODE_ENABLED_NAME,
5664 pHddCtx->config->adaptive_dwell_mode_enabled);
5665 hdd_info("Name = [%s] Value = [%u]",
5666 CFG_GLOBAL_ADAPTIVE_DWELL_MODE_NAME,
5667 pHddCtx->config->global_adapt_dwelltime_mode);
5668 hdd_info("Name = [%s] Value = [%u]",
5669 CFG_ADAPT_DWELL_LPF_WEIGHT_NAME,
5670 pHddCtx->config->adapt_dwell_lpf_weight);
5671 hdd_info("Name = [%s] Value = [%u]",
5672 CFG_ADAPT_DWELL_PASMON_INTVAL_NAME,
5673 pHddCtx->config->adapt_dwell_passive_mon_intval);
5674 hdd_info("Name = [%s] Value = [%u]",
5675 CFG_ADAPT_DWELL_WIFI_THRESH_NAME,
5676 pHddCtx->config->adapt_dwell_wifi_act_threshold);
Naveen Rawat64e477e2016-05-20 10:34:56 -07005677 hdd_info("Name = [%s] value = [%u]",
5678 CFG_SUB_20_CHANNEL_WIDTH_NAME,
5679 pHddCtx->config->enable_sub_20_channel_width);
Rajeev Kumar Sirasanagandlaaf474742016-09-06 17:54:50 +05305680 hdd_info("Name = [%s] Value = [%u]",
5681 CFG_TGT_GTX_USR_CFG_NAME,
5682 pHddCtx->config->tgt_gtx_usr_cfg);
Deepak Dhamdhere3385d752016-05-25 20:36:47 -07005683 hdd_ndp_print_ini_config(pHddCtx);
Krishna Kumaar Natarajancc077c22016-08-02 10:41:53 -07005684 hdd_info("Name = [%s] Value = [%s]",
5685 CFG_RM_CAPABILITY_NAME,
5686 pHddCtx->config->rm_capability);
Rajeev Kumardd3bc602016-08-16 14:21:05 -07005687 hdd_info("Name = [%s] Value = [%d]",
5688 CFG_BPF_PACKET_FILTER_OFFLOAD,
5689 pHddCtx->config->bpf_packet_filter_enable);
Ravi Joshibb8d4512016-08-22 10:14:52 -07005690 hdd_info("Name = [%s] Value = [%d]",
5691 CFG_FILTER_MULTICAST_REPLAY_NAME,
5692 pHddCtx->config->multicast_replay_filter);
Agrawal Ashishb2d1a452016-05-05 12:23:58 +05305693 hdd_info("Name = [%s] Value = [%u]",
5694 CFG_ENABLE_GO_CTS2SELF_FOR_STA,
5695 pHddCtx->config->enable_go_cts2self_for_sta);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005696}
5697
5698
5699/**
5700 * hdd_update_mac_config() - update MAC address from cfg file
5701 * @pHddCtx: the pointer to hdd context
5702 *
5703 * It overwrites the MAC address if config file exist.
5704 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305705 * Return: QDF_STATUS_SUCCESS if the MAC address is found from cfg file
5706 * and overwritten, otherwise QDF_STATUS_E_INVAL
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005707 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305708QDF_STATUS hdd_update_mac_config(hdd_context_t *pHddCtx)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005709{
5710 int status, i = 0;
5711 const struct firmware *fw = NULL;
5712 char *line, *buffer = NULL;
Yuanyuan Liu6043d3c2016-07-25 11:40:38 -07005713 char *temp = NULL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005714 char *name, *value;
Anurag Chouhan6d760662016-02-20 16:05:43 +05305715 tCfgIniEntry macTable[QDF_MAX_CONCURRENCY_PERSONA];
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005716 tSirMacAddr customMacAddr;
5717
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305718 QDF_STATUS qdf_status = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005719
5720 memset(macTable, 0, sizeof(macTable));
5721 status = request_firmware(&fw, WLAN_MAC_FILE, pHddCtx->parent_dev);
5722
5723 if (status) {
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305724 hddLog(QDF_TRACE_LEVEL_WARN, "%s: request_firmware failed %d",
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005725 __func__, status);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305726 qdf_status = QDF_STATUS_E_FAILURE;
5727 return qdf_status;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005728 }
5729 if (!fw || !fw->data || !fw->size) {
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305730 hddLog(QDF_TRACE_LEVEL_FATAL, "%s: invalid firmware", __func__);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305731 qdf_status = QDF_STATUS_E_INVAL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005732 goto config_exit;
5733 }
5734
Yuanyuan Liu6043d3c2016-07-25 11:40:38 -07005735 hdd_debug("wlan_mac.bin size %zu", fw->size);
5736
5737 temp = qdf_mem_malloc(fw->size);
5738
5739 if (temp == NULL) {
5740 hdd_err("fail to alloc memory");
5741 qdf_status = QDF_STATUS_E_NOMEM;
5742 goto config_exit;
5743 }
5744 buffer = temp;
5745 qdf_mem_copy(buffer, fw->data, fw->size);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005746
5747 /* data format:
5748 * Intf0MacAddress=00AA00BB00CC
5749 * Intf1MacAddress=00AA00BB00CD
5750 * END
5751 */
5752 while (buffer != NULL) {
5753 line = get_next_line(buffer);
5754 buffer = i_trim(buffer);
5755
5756 if (strlen((char *)buffer) == 0 || *buffer == '#') {
5757 buffer = line;
5758 continue;
5759 }
5760 if (strncmp(buffer, "END", 3) == 0)
5761 break;
5762
5763 name = buffer;
5764 buffer = strnchr(buffer, strlen(buffer), '=');
5765 if (buffer) {
5766 *buffer++ = '\0';
5767 i_trim(name);
5768 if (strlen(name) != 0) {
5769 buffer = i_trim(buffer);
5770 if (strlen(buffer) == 12) {
5771 value = buffer;
5772 macTable[i].name = name;
5773 macTable[i++].value = value;
Anurag Chouhan6d760662016-02-20 16:05:43 +05305774 if (i >= QDF_MAX_CONCURRENCY_PERSONA)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005775 break;
5776 }
5777 }
5778 }
5779 buffer = line;
5780 }
Anurag Chouhan6d760662016-02-20 16:05:43 +05305781 if (i <= QDF_MAX_CONCURRENCY_PERSONA) {
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305782 hddLog(QDF_TRACE_LEVEL_INFO, "%s: %d Mac addresses provided",
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005783 __func__, i);
5784 } else {
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305785 hddLog(QDF_TRACE_LEVEL_ERROR,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005786 "%s: invalid number of Mac address provided, nMac = %d",
5787 __func__, i);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305788 qdf_status = QDF_STATUS_E_INVAL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005789 goto config_exit;
5790 }
5791
5792 update_mac_from_string(pHddCtx, &macTable[0], i);
5793
Anurag Chouhan600c3a02016-03-01 10:33:54 +05305794 qdf_mem_copy(&customMacAddr,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005795 &pHddCtx->config->intfMacAddr[0].bytes[0],
5796 sizeof(tSirMacAddr));
5797 sme_set_custom_mac_addr(customMacAddr);
5798
5799config_exit:
Yuanyuan Liu6043d3c2016-07-25 11:40:38 -07005800 qdf_mem_free(temp);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005801 release_firmware(fw);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305802 return qdf_status;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005803}
5804
5805/**
Manjunathappa Prakash59f861d2016-04-21 10:33:31 -07005806 * hdd_disable_runtime_pm() - Override to disable runtime_pm.
5807 * @cfg_ini: Handle to struct hdd_config
5808 *
5809 * Return: None
5810 */
5811#ifdef FEATURE_RUNTIME_PM
5812static void hdd_disable_runtime_pm(struct hdd_config *cfg_ini)
5813{
5814 cfg_ini->runtime_pm = 0;
5815}
5816#else
5817static void hdd_disable_runtime_pm(struct hdd_config *cfg_ini)
5818{
5819}
5820#endif
5821
5822/**
5823 * hdd_disable_auto_shutdown() - Override to disable auto_shutdown.
5824 * @cfg_ini: Handle to struct hdd_config
5825 *
5826 * Return: None
5827 */
5828#ifdef FEATURE_WLAN_AUTO_SHUTDOWN
5829static void hdd_disable_auto_shutdown(struct hdd_config *cfg_ini)
5830{
5831 cfg_ini->WlanAutoShutdown = 0;
5832}
5833#else
5834static void hdd_disable_auto_shutdown(struct hdd_config *cfg_ini)
5835{
5836}
5837#endif
5838
5839/**
5840 * hdd_override_all_ps() - overrides to disables all the powersave features.
5841 * @hdd_ctx: Pointer to HDD context.
5842 * Overrides below powersave ini configurations.
5843 * gEnableImps=0
5844 * gEnableBmps=0
5845 * gRuntimePM=0
5846 * gWlanAutoShutdown = 0
5847 * gEnableSuspend=0
5848 * gEnablePowerSaveOffload=0
5849 * gEnableWoW=0
5850 *
5851 * Return: None
5852 */
5853static void hdd_override_all_ps(hdd_context_t *hdd_ctx)
5854{
5855 struct hdd_config *cfg_ini = hdd_ctx->config;
5856
5857 cfg_ini->fIsImpsEnabled = 0;
5858 cfg_ini->is_ps_enabled = 0;
5859 hdd_disable_runtime_pm(cfg_ini);
5860 hdd_disable_auto_shutdown(cfg_ini);
5861 cfg_ini->enablePowersaveOffload = 0;
5862 cfg_ini->wowEnable = 0;
5863}
5864
5865/**
Nirav Shahbd36b062016-07-18 11:12:59 +05305866 * hdd_set_rx_mode_value() - set rx_mode values
5867 * @hdd_ctx: hdd context
5868 *
5869 * Return: none
5870 */
Jeff Johnsonf1bf3a62016-10-05 15:48:13 -07005871static void hdd_set_rx_mode_value(hdd_context_t *hdd_ctx)
Nirav Shahbd36b062016-07-18 11:12:59 +05305872{
5873 if (hdd_ctx->config->rx_mode & CFG_ENABLE_RX_THREAD &&
5874 hdd_ctx->config->rx_mode & CFG_ENABLE_RPS) {
5875 hdd_err("rx_mode wrong configuration. Make it default");
5876 hdd_ctx->config->rx_mode = CFG_RX_MODE_DEFAULT;
5877 }
5878
5879 if (hdd_ctx->config->rx_mode & CFG_ENABLE_RX_THREAD)
5880 hdd_ctx->enableRxThread = true;
5881
5882 if (hdd_ctx->config->rx_mode & CFG_ENABLE_RPS)
5883 hdd_ctx->rps = true;
5884
5885 if (hdd_ctx->config->rx_mode & CFG_ENABLE_NAPI)
5886 hdd_ctx->napi_enable = true;
5887}
5888
5889/**
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005890 * hdd_parse_config_ini() - parse the ini configuration file
5891 * @pHddCtx: the pointer to hdd context
5892 *
5893 * This function reads the qcom_cfg.ini file and
5894 * parses each 'Name=Value' pair in the ini file
5895 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305896 * Return: QDF_STATUS_SUCCESS if the qcom_cfg.ini is correctly read,
5897 * otherwise QDF_STATUS_E_INVAL
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005898 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305899QDF_STATUS hdd_parse_config_ini(hdd_context_t *pHddCtx)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005900{
5901 int status, i = 0;
5902 /** Pointer for firmware image data */
5903 const struct firmware *fw = NULL;
5904 char *buffer, *line, *pTemp = NULL;
5905 size_t size;
5906 char *name, *value;
5907 /* cfgIniTable is static to avoid excess stack usage */
5908 static tCfgIniEntry cfgIniTable[MAX_CFG_INI_ITEMS];
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305909 QDF_STATUS qdf_status = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005910
5911 memset(cfgIniTable, 0, sizeof(cfgIniTable));
5912
5913 status = request_firmware(&fw, WLAN_INI_FILE, pHddCtx->parent_dev);
5914
5915 if (status) {
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305916 hddLog(QDF_TRACE_LEVEL_FATAL, "%s: request_firmware failed %d",
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005917 __func__, status);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305918 qdf_status = QDF_STATUS_E_FAILURE;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005919 goto config_exit;
5920 }
5921 if (!fw || !fw->data || !fw->size) {
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05305922 hddLog(QDF_TRACE_LEVEL_FATAL, "%s: %s download failed",
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005923 __func__, WLAN_INI_FILE);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305924 qdf_status = QDF_STATUS_E_FAILURE;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005925 goto config_exit;
5926 }
5927
5928 hddLog(LOG1, "%s: qcom_cfg.ini Size %zu", __func__, fw->size);
5929
Anurag Chouhan600c3a02016-03-01 10:33:54 +05305930 buffer = (char *)qdf_mem_malloc(fw->size);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005931
5932 if (NULL == buffer) {
Anurag Chouhan600c3a02016-03-01 10:33:54 +05305933 hddLog(QDF_TRACE_LEVEL_FATAL, FL("qdf_mem_malloc failure"));
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005934 release_firmware(fw);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305935 return QDF_STATUS_E_NOMEM;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005936 }
5937 pTemp = buffer;
5938
Anurag Chouhan600c3a02016-03-01 10:33:54 +05305939 qdf_mem_copy((void *)buffer, (void *)fw->data, fw->size);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005940 size = fw->size;
5941
5942 while (buffer != NULL) {
5943 line = get_next_line(buffer);
5944 buffer = i_trim(buffer);
5945
5946 hddLog(LOG1, "%s: item", buffer);
5947
5948 if (strlen((char *)buffer) == 0 || *buffer == '#') {
5949 buffer = line;
5950 continue;
5951 } else if (strncmp(buffer, "END", 3) == 0) {
5952 break;
5953 } else {
5954 name = buffer;
5955 while (*buffer != '=' && *buffer != '\0')
5956 buffer++;
5957 if (*buffer != '\0') {
5958 *buffer++ = '\0';
5959 i_trim(name);
5960 if (strlen(name) != 0) {
5961 buffer = i_trim(buffer);
5962 if (strlen(buffer) > 0) {
5963 value = buffer;
5964 while (!i_isspace(*buffer)
5965 && *buffer != '\0')
5966 buffer++;
5967 *buffer = '\0';
5968 cfgIniTable[i].name = name;
5969 cfgIniTable[i++].value = value;
5970 if (i >= MAX_CFG_INI_ITEMS) {
5971 hddLog(LOGE,
5972 "%s: Number of items in %s > %d",
5973 __func__,
5974 WLAN_INI_FILE,
5975 MAX_CFG_INI_ITEMS);
5976 break;
5977 }
5978 }
5979 }
5980 }
5981 }
5982 buffer = line;
5983 }
5984
5985 /* Loop through the registry table and apply all these configs */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305986 qdf_status = hdd_apply_cfg_ini(pHddCtx, cfgIniTable, i);
Nirav Shahbd36b062016-07-18 11:12:59 +05305987 hdd_set_rx_mode_value(pHddCtx);
Manjunathappa Prakash59f861d2016-04-21 10:33:31 -07005988 if (QDF_GLOBAL_MONITOR_MODE == cds_get_conparam())
5989 hdd_override_all_ps(pHddCtx);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005990
5991config_exit:
5992 release_firmware(fw);
Anurag Chouhan600c3a02016-03-01 10:33:54 +05305993 qdf_mem_free(pTemp);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05305994 return qdf_status;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08005995}
5996
5997/**
5998 * hdd_cfg_xlate_to_csr_phy_mode() - convert PHY mode
5999 * @dot11Mode: the mode to convert
6000 *
6001 * Convert the configuration PHY mode to CSR PHY mode
6002 *
6003 * Return: the CSR phy mode value
6004 */
6005eCsrPhyMode hdd_cfg_xlate_to_csr_phy_mode(eHddDot11Mode dot11Mode)
6006{
6007 switch (dot11Mode) {
6008 case (eHDD_DOT11_MODE_abg):
6009 return eCSR_DOT11_MODE_abg;
6010 case (eHDD_DOT11_MODE_11b):
6011 return eCSR_DOT11_MODE_11b;
6012 case (eHDD_DOT11_MODE_11g):
6013 return eCSR_DOT11_MODE_11g;
6014 default:
6015 case (eHDD_DOT11_MODE_11n):
6016 return eCSR_DOT11_MODE_11n;
6017 case (eHDD_DOT11_MODE_11g_ONLY):
6018 return eCSR_DOT11_MODE_11g_ONLY;
6019 case (eHDD_DOT11_MODE_11n_ONLY):
6020 return eCSR_DOT11_MODE_11n_ONLY;
6021 case (eHDD_DOT11_MODE_11b_ONLY):
6022 return eCSR_DOT11_MODE_11b_ONLY;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006023 case (eHDD_DOT11_MODE_11ac_ONLY):
6024 return eCSR_DOT11_MODE_11ac_ONLY;
6025 case (eHDD_DOT11_MODE_11ac):
6026 return eCSR_DOT11_MODE_11ac;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006027 case (eHDD_DOT11_MODE_AUTO):
6028 return eCSR_DOT11_MODE_AUTO;
6029 case (eHDD_DOT11_MODE_11a):
6030 return eCSR_DOT11_MODE_11a;
6031 }
6032
6033}
6034
6035/**
6036 * hdd_set_idle_ps_config() - set idle power save configuration
6037 * @pHddCtx: the pointer to hdd context
6038 * @val: the value to configure
6039 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306040 * Return: QDF_STATUS_SUCCESS if command set correctly,
6041 * otherwise the QDF_STATUS return from SME layer
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006042 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306043QDF_STATUS hdd_set_idle_ps_config(hdd_context_t *pHddCtx, uint32_t val)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006044{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306045 QDF_STATUS status = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006046
6047 hddLog(LOG1, "hdd_set_idle_ps_config: Enter Val %d", val);
6048
Kiran Kumar Lokerefc2803d2016-01-11 19:31:38 -08006049 status = sme_set_idle_powersave_config(pHddCtx->pcds_context,
6050 pHddCtx->hHal, val);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306051 if (QDF_STATUS_SUCCESS != status)
Kiran Kumar Lokerefc2803d2016-01-11 19:31:38 -08006052 hddLog(LOGE, "Fail to Set Idle PS Config val %d", val);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006053 return status;
6054}
6055
6056/**
6057 * hdd_set_fine_time_meas_cap() - set fine timing measurement capability
6058 * @hdd_ctx: HDD context
6059 * @sme_config: pointer to SME config
6060 *
6061 * This function is used to pass fine timing measurement capability coming
6062 * from INI to SME. This function make sure that configure INI is supported
6063 * by the device. Use bit mask to mask out the unsupported capabilities.
6064 *
6065 * Return: None
6066 */
6067static void hdd_set_fine_time_meas_cap(hdd_context_t *hdd_ctx,
6068 tSmeConfigParams *sme_config)
6069{
6070 struct hdd_config *config = hdd_ctx->config;
6071 uint32_t capability = config->fine_time_meas_cap;
6072
6073 /* Make sure only supported capabilities are enabled in INI */
6074 capability &= CFG_FINE_TIME_MEAS_CAPABILITY_MAX;
Krunal Soni1878d3a2016-01-14 13:00:44 -08006075 sme_config->csrConfig.fine_time_meas_cap = capability;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006076
6077 hddLog(LOG1, FL("fine time meas capability - INI: %04x Enabled: %04x"),
Krunal Soni1878d3a2016-01-14 13:00:44 -08006078 config->fine_time_meas_cap,
6079 sme_config->csrConfig.fine_time_meas_cap);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006080
6081 return;
6082}
6083
6084/**
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006085 * hdd_convert_string_to_u8_array() - used to convert string into u8 array
6086 * @str: String to be converted
6087 * @hex_array: Array where converted value is stored
6088 * @len: Length of the populated array
6089 * @array_max_len: Maximum length of the array
6090 * @to_hex: true, if conversion required for hex string
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006091 *
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006092 * This API is called to convert string (each byte separated by
6093 * a comma) into an u8 array
6094 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306095 * Return: QDF_STATUS
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006096 */
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006097
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306098static QDF_STATUS hdd_convert_string_to_array(char *str, uint8_t *array,
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006099 uint8_t *len, uint8_t array_max_len, bool to_hex)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006100{
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006101 char *format, *s = str;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006102
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006103 if (str == NULL || array == NULL || len == NULL)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306104 return QDF_STATUS_E_INVAL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006105
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006106 format = (to_hex) ? "%02x" : "%d";
6107
6108 *len = 0;
6109 while ((s != NULL) && (*len < array_max_len)) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006110 int val;
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006111 /* Increment length only if sscanf successfully extracted
6112 * one element. Any other return value means error.
6113 * Ignore it. */
6114 if (sscanf(s, format, &val) == 1) {
6115 array[*len] = (uint8_t) val;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006116 *len += 1;
6117 }
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006118
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006119 s = strpbrk(s, ",");
6120 if (s)
6121 s++;
6122 }
6123
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306124 return QDF_STATUS_SUCCESS;
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006125}
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006126
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006127/**
6128 * hdd_hex_string_to_u8_array() - used to convert hex string into u8 array
6129 * @str: Hexadecimal string
6130 * @hex_array: Array where converted value is stored
6131 * @len: Length of the populated array
6132 * @array_max_len: Maximum length of the array
6133 *
6134 * This API is called to convert hexadecimal string (each byte separated by
6135 * a comma) into an u8 array
6136 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306137 * Return: QDF_STATUS
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006138 */
Jeff Johnsonf1bf3a62016-10-05 15:48:13 -07006139static QDF_STATUS hdd_hex_string_to_u8_array(char *str, uint8_t *hex_array,
6140 uint8_t *len,
6141 uint8_t array_max_len)
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006142{
6143 return hdd_convert_string_to_array(str, hex_array, len,
6144 array_max_len, true);
6145}
6146
6147/**
6148 * hdd_string_to_u8_array() - used to convert decimal string into u8 array
6149 * @str: Decimal string
6150 * @hex_array: Array where converted value is stored
6151 * @len: Length of the populated array
6152 * @array_max_len: Maximum length of the array
6153 *
6154 * This API is called to convert decimal string (each byte separated by
6155 * a comma) into an u8 array
6156 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306157 * Return: QDF_STATUS
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006158 */
6159
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306160QDF_STATUS hdd_string_to_u8_array(char *str, uint8_t *array,
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006161 uint8_t *len, uint8_t array_max_len)
6162{
6163 return hdd_convert_string_to_array(str, array, len,
6164 array_max_len, false);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006165}
6166
6167/**
Nirav Shahbd36b062016-07-18 11:12:59 +05306168 * hdd_hex_string_to_u16_array() - convert a hex string to a uint16 array
6169 * @str: input string
6170 * @int_array: pointer to input array of type uint16
6171 * @len: pointer to number of elements which the function adds to the array
6172 * @int_array_max_len: maximum number of elements in input uint16 array
6173 *
6174 * This function is used to convert a space separated hex string to an array of
6175 * uint16_t. For example, an input string str = "a b c d" would be converted to
6176 * a unint16 array, int_array = {0xa, 0xb, 0xc, 0xd}, *len = 4.
6177 * This assumes that input value int_array_max_len >= 4.
6178 *
6179 * Return: QDF_STATUS_SUCCESS - if the conversion is successful
6180 * non zero value - if the conversion is a failure
6181 */
6182QDF_STATUS hdd_hex_string_to_u16_array(char *str,
6183 uint16_t *int_array, uint8_t *len, uint8_t int_array_max_len)
6184{
6185 char *s = str;
6186 uint32_t val = 0;
6187
6188 if (str == NULL || int_array == NULL || len == NULL)
6189 return QDF_STATUS_E_INVAL;
6190
6191 hdd_err("str %p intArray %p intArrayMaxLen %d",
6192 s, int_array, int_array_max_len);
6193
6194 *len = 0;
6195
6196 while ((s != NULL) && (*len < int_array_max_len)) {
6197 /*
6198 * Increment length only if sscanf successfully extracted one
6199 * element. Any other return value means error. Ignore it.
6200 */
6201 if (sscanf(s, "%x", &val) == 1) {
6202 int_array[*len] = (uint16_t) val;
6203 hdd_debug("s %p val %x intArray[%d]=0x%x",
6204 s, val, *len, int_array[*len]);
6205 *len += 1;
6206 }
6207 s = strpbrk(s, " ");
6208 if (s)
6209 s++;
6210 }
6211 return QDF_STATUS_SUCCESS;
6212}
6213
Nirav Shahbd36b062016-07-18 11:12:59 +05306214/**
Krunal Soni52198e42016-09-26 13:53:09 -07006215 * hdd_update_ht_cap_in_cfg() - to update HT cap in global CFG
Krunal Sonidf0f8742016-09-26 14:56:31 -07006216 * @hdd_ctx: pointer to hdd context
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006217 *
Krunal Soni52198e42016-09-26 13:53:09 -07006218 * This API will update the HT config in CFG after taking intersection
6219 * of INI and firmware capabilities provided reading CFG
6220 *
6221 * Return: true or false
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006222 */
Krunal Sonidf0f8742016-09-26 14:56:31 -07006223static bool hdd_update_ht_cap_in_cfg(hdd_context_t *hdd_ctx)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006224{
Krunal Soni5c390162016-09-26 15:07:05 -07006225 uint32_t val32;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006226 uint16_t val16;
Krunal Soni5c390162016-09-26 15:07:05 -07006227 bool status = true;
Krunal Sonidf0f8742016-09-26 14:56:31 -07006228 tSirMacHTCapabilityInfo *ht_cap_info;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006229
Krunal Sonidf0f8742016-09-26 14:56:31 -07006230 if (sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_HT_CAP_INFO,
Krunal Soni5c390162016-09-26 15:07:05 -07006231 &val32) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306232 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006233 status = false;
Krunal Soni5c390162016-09-26 15:07:05 -07006234 hdd_err("Could not get WNI_CFG_HT_CAP_INFO");
Sandeep Puligilla607f34a2016-05-25 14:37:47 -07006235 }
Krunal Soni5c390162016-09-26 15:07:05 -07006236 val16 = (uint16_t) val32;
Krunal Sonidf0f8742016-09-26 14:56:31 -07006237 ht_cap_info = (tSirMacHTCapabilityInfo *) &val16;
Krunal Soni5c390162016-09-26 15:07:05 -07006238 ht_cap_info->advCodingCap &= hdd_ctx->config->enableRxLDPC;
6239 ht_cap_info->rxSTBC = QDF_MIN(ht_cap_info->rxSTBC,
6240 hdd_ctx->config->enableRxSTBC);
6241 ht_cap_info->txSTBC &= hdd_ctx->config->enableTxSTBC;
6242 ht_cap_info->shortGI20MHz &= hdd_ctx->config->ShortGI20MhzEnable;
6243 ht_cap_info->shortGI40MHz &= hdd_ctx->config->ShortGI40MhzEnable;
6244 val32 = val16;
6245 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_HT_CAP_INFO, val32) ==
6246 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006247 status = false;
Krunal Soni5c390162016-09-26 15:07:05 -07006248 hdd_err("Could not set WNI_CFG_HT_CAP_INFO");
Krunal Soni52198e42016-09-26 13:53:09 -07006249 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006250 return status;
Krunal Soni52198e42016-09-26 13:53:09 -07006251}
6252
6253/**
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006254 * hdd_update_vht_cap_in_cfg() - to update VHT cap in global CFG
Krunal Sonidf0f8742016-09-26 14:56:31 -07006255 * @hdd_ctx: pointer to hdd context
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006256 *
6257 * This API will update the VHT config in CFG after taking intersection
6258 * of INI and firmware capabilities provided reading CFG
6259 *
6260 * Return: true or false
6261 */
Krunal Sonidf0f8742016-09-26 14:56:31 -07006262static bool hdd_update_vht_cap_in_cfg(hdd_context_t *hdd_ctx)
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006263{
Krunal Sonidf0f8742016-09-26 14:56:31 -07006264 bool status = true;
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006265 uint32_t val;
Krunal Sonidf0f8742016-09-26 14:56:31 -07006266 struct hdd_config *config = hdd_ctx->config;
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006267
Krunal Sonidf0f8742016-09-26 14:56:31 -07006268 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_ENABLE_TXBF_20MHZ,
6269 config->enableTxBFin20MHz) ==
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006270 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006271 status = false;
6272 hdd_err("Couldn't set value for WNI_CFG_VHT_ENABLE_TXBF_20MHZ");
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006273 }
6274 /* Based on cfg.ini, update the Basic MCS set, RX/TX MCS map
6275 * in the cfg.dat. Valid values are 0(MCS0-7), 1(MCS0-8), 2(MCS0-9)
6276 * we update only the least significant 2 bits in the
6277 * corresponding fields.
6278 */
Krunal Sonidf0f8742016-09-26 14:56:31 -07006279 if ((config->dot11Mode == eHDD_DOT11_MODE_AUTO) ||
6280 (config->dot11Mode == eHDD_DOT11_MODE_11ac_ONLY) ||
6281 (config->dot11Mode == eHDD_DOT11_MODE_11ac)) {
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006282 /* Currently shortGI40Mhz is used for shortGI80Mhz */
Krunal Sonidf0f8742016-09-26 14:56:31 -07006283 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_SHORT_GI_80MHZ,
6284 config->ShortGI40MhzEnable) == QDF_STATUS_E_FAILURE) {
6285 status = false;
6286 hdd_err("Couldn't pass WNI_VHT_SHORT_GI_80MHZ to CFG");
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006287 }
6288 /* Hardware is capable of doing
6289 * 128K AMPDU in 11AC mode */
Krunal Sonidf0f8742016-09-26 14:56:31 -07006290 if (sme_cfg_set_int(hdd_ctx->hHal,
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006291 WNI_CFG_VHT_AMPDU_LEN_EXPONENT,
Krunal Sonidf0f8742016-09-26 14:56:31 -07006292 config->fVhtAmpduLenExponent) ==
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006293 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006294 status = false;
6295 hdd_err("Couldn't pass on WNI_CFG_VHT_AMPDU_LEN_EXPONENT to CFG");
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006296 }
6297 /* Change MU Bformee only when TxBF is enabled */
Krunal Sonidf0f8742016-09-26 14:56:31 -07006298 if (config->enableTxBF) {
6299 sme_cfg_get_int(hdd_ctx->hHal,
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006300 WNI_CFG_VHT_MU_BEAMFORMEE_CAP, &val);
6301
Krunal Sonidf0f8742016-09-26 14:56:31 -07006302 if (val != config->enableMuBformee) {
6303 if (sme_cfg_set_int(hdd_ctx->hHal,
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006304 WNI_CFG_VHT_MU_BEAMFORMEE_CAP,
Krunal Sonidf0f8742016-09-26 14:56:31 -07006305 config->enableMuBformee
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006306 ) == QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006307 status = false;
6308 hdd_err("Couldn't pass on WNI_CFG_VHT_MU_BEAMFORMEE_CAP to CFG");
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006309 }
6310 }
6311 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006312 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_MAX_MPDU_LENGTH,
6313 config->vhtMpduLen) == QDF_STATUS_E_FAILURE) {
6314 status = false;
6315 hdd_err("Couldn't pass on WNI_CFG_VHT_MAX_MPDU_LENGTH to CFG");
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006316 }
6317
Krunal Sonidf0f8742016-09-26 14:56:31 -07006318 if (config->enable2x2 && config->enable_su_tx_bformer) {
6319 if (sme_cfg_set_int(hdd_ctx->hHal,
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006320 WNI_CFG_VHT_SU_BEAMFORMER_CAP,
Krunal Sonidf0f8742016-09-26 14:56:31 -07006321 config->enable_su_tx_bformer) ==
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006322 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006323 status = false;
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006324 hdd_err("set SU_BEAMFORMER_CAP to CFG failed");
6325 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006326 if (sme_cfg_set_int(hdd_ctx->hHal,
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006327 WNI_CFG_VHT_NUM_SOUNDING_DIMENSIONS,
6328 NUM_OF_SOUNDING_DIMENSIONS) ==
6329 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006330 status = false;
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006331 hdd_err("failed to set NUM_OF_SOUNDING_DIM");
6332 }
6333 }
6334 }
6335
Krunal Sonidf0f8742016-09-26 14:56:31 -07006336 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_RXSTBC,
6337 config->enableRxSTBC) == QDF_STATUS_E_FAILURE) {
6338 status = false;
6339 hdd_err("Couldn't pass on WNI_CFG_VHT_RXSTBC to CFG");
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006340 }
6341
Krunal Sonidf0f8742016-09-26 14:56:31 -07006342 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_TXSTBC,
6343 config->enableTxSTBC) == QDF_STATUS_E_FAILURE) {
6344 status = false;
6345 hdd_err("Couldn't pass on WNI_CFG_VHT_TXSTBC to CFG");
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006346 }
6347
Krunal Soni5c390162016-09-26 15:07:05 -07006348 if (sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_VHT_LDPC_CODING_CAP, &val) ==
6349 QDF_STATUS_E_FAILURE) {
6350 status &= false;
6351 hdd_err("Could not get WNI_CFG_VHT_LDPC_CODING_CAP");
6352 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006353 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_LDPC_CODING_CAP,
Krunal Soni5c390162016-09-26 15:07:05 -07006354 config->enableRxLDPC & val) == QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006355 status = false;
6356 hdd_err("Couldn't pass on WNI_CFG_VHT_LDPC_CODING_CAP to CFG");
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006357 }
6358
Krunal Sonidf0f8742016-09-26 14:56:31 -07006359 if (sme_cfg_set_int(hdd_ctx->hHal,
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006360 WNI_CFG_VHT_CSN_BEAMFORMEE_ANT_SUPPORTED,
Krunal Sonidf0f8742016-09-26 14:56:31 -07006361 config->txBFCsnValue) ==
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006362 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006363 status = false;
6364 hdd_err("Couldn't pass on WNI_CFG_VHT_CSN_BEAMFORMEE_ANT_SUPPORTED to CFG");
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006365 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006366 return status;
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006367
6368}
6369
6370/**
Krunal Sonidf0f8742016-09-26 14:56:31 -07006371 * hdd_update_config_cfg() - API to update INI setting based on hw/fw caps
6372 * @hdd_ctx: pointer to hdd_ctx
Krunal Soni52198e42016-09-26 13:53:09 -07006373 *
Krunal Sonidf0f8742016-09-26 14:56:31 -07006374 * This API reads the cfg file which is updated with hardware/firmware
6375 * capabilities and intersect it with INI setting provided by user. After
6376 * taking intersection it adjust cfg it self. For example, if user has enabled
6377 * RX LDPC through INI but hardware/firmware doesn't support it then disable
6378 * it in CFG file here.
6379 *
6380 * Return: true or false based on outcome.
Krunal Soni52198e42016-09-26 13:53:09 -07006381 */
Krunal Sonidf0f8742016-09-26 14:56:31 -07006382bool hdd_update_config_cfg(hdd_context_t *hdd_ctx)
Krunal Soni52198e42016-09-26 13:53:09 -07006383{
Krunal Sonidf0f8742016-09-26 14:56:31 -07006384 bool status = true;
Krunal Soni52198e42016-09-26 13:53:09 -07006385 uint32_t val;
Krunal Sonidf0f8742016-09-26 14:56:31 -07006386 struct hdd_config *config = hdd_ctx->config;
Krunal Soni52198e42016-09-26 13:53:09 -07006387
6388 /*
6389 * During the initialization both 2G and 5G capabilities should be same.
6390 * So read 5G HT capablity and update 2G and 5G capablities.
6391 */
Krunal Sonidf0f8742016-09-26 14:56:31 -07006392 if (!hdd_update_ht_cap_in_cfg(hdd_ctx)) {
6393 status = false;
6394 hdd_err("Couldn't set HT CAP in cfg");
Krunal Soni52198e42016-09-26 13:53:09 -07006395 }
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006396
Krunal Sonidf0f8742016-09-26 14:56:31 -07006397 if (!hdd_update_vht_cap_in_cfg(hdd_ctx)) {
6398 status = false;
6399 hdd_err("Couldn't set VHT CAP in cfg");
Krunal Soni6c7c39f2016-09-26 14:30:34 -07006400 }
6401
Krunal Sonidf0f8742016-09-26 14:56:31 -07006402 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_FIXED_RATE, config->TxRate)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306403 == QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006404 status = false;
6405 hdd_err("Couldn't pass on WNI_CFG_FIXED_RATE to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006406 }
6407
Krunal Sonidf0f8742016-09-26 14:56:31 -07006408 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_MAX_RX_AMPDU_FACTOR,
6409 config->MaxRxAmpduFactor) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306410 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006411 status = false;
6412 hdd_err("Couldn't pass on WNI_CFG_HT_AMPDU_PARAMS_MAX_RX_AMPDU_FACTOR to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006413 }
6414
Krunal Sonidf0f8742016-09-26 14:56:31 -07006415 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_MPDU_DENSITY,
6416 config->ht_mpdu_density) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306417 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006418 status = false;
6419 hdd_err("Couldn't pass on WNI_CFG_MPDU_DENSITY to CFG");
Krishna Kumaar Natarajan22b59a72015-11-23 18:54:58 -08006420 }
6421
Krunal Sonidf0f8742016-09-26 14:56:31 -07006422 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_SHORT_PREAMBLE,
6423 config->fIsShortPreamble) == QDF_STATUS_E_FAILURE) {
6424 status = false;
6425 hdd_err("Couldn't pass on WNI_CFG_SHORT_PREAMBLE to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006426 }
6427
Krunal Sonidf0f8742016-09-26 14:56:31 -07006428 if (sme_cfg_set_int(hdd_ctx->hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006429 WNI_CFG_PASSIVE_MINIMUM_CHANNEL_TIME,
Krunal Sonidf0f8742016-09-26 14:56:31 -07006430 config->nPassiveMinChnTime)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306431 == QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006432 status = false;
6433 hdd_err("Couldn't pass on WNI_CFG_PASSIVE_MINIMUM_CHANNEL_TIME to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006434 }
6435
Krunal Sonidf0f8742016-09-26 14:56:31 -07006436 if (sme_cfg_set_int(hdd_ctx->hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006437 WNI_CFG_PASSIVE_MAXIMUM_CHANNEL_TIME,
Krunal Sonidf0f8742016-09-26 14:56:31 -07006438 config->nPassiveMaxChnTime)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306439 == QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006440 status = false;
6441 hdd_err("Couldn't pass on WNI_CFG_PASSIVE_MAXIMUM_CHANNEL_TIME to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006442 }
6443
Krunal Sonidf0f8742016-09-26 14:56:31 -07006444 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_BEACON_INTERVAL,
6445 config->nBeaconInterval) == QDF_STATUS_E_FAILURE) {
6446 status = false;
6447 hdd_err("Couldn't pass on WNI_CFG_BEACON_INTERVAL to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006448 }
6449
Krunal Sonidf0f8742016-09-26 14:56:31 -07006450 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_MAX_PS_POLL,
6451 config->nMaxPsPoll) == QDF_STATUS_E_FAILURE) {
6452 status = false;
6453 hdd_err("Couldn't pass on WNI_CFG_MAX_PS_POLL to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006454 }
6455
Krunal Sonidf0f8742016-09-26 14:56:31 -07006456 if (sme_cfg_set_int (hdd_ctx->hHal, WNI_CFG_LOW_GAIN_OVERRIDE,
6457 config->fIsLowGainOverride) == QDF_STATUS_E_FAILURE) {
6458 status = false;
6459 hdd_err("Couldn't pass on WNI_CFG_LOW_GAIN_OVERRIDE to HAL");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006460 }
6461
Krunal Sonidf0f8742016-09-26 14:56:31 -07006462 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_RSSI_FILTER_PERIOD,
6463 config->nRssiFilterPeriod) == QDF_STATUS_E_FAILURE) {
6464 status = false;
6465 hdd_err("Couldn't pass on WNI_CFG_RSSI_FILTER_PERIOD to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006466 }
6467
Krunal Sonidf0f8742016-09-26 14:56:31 -07006468 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_IGNORE_DTIM,
6469 config->fIgnoreDtim) == QDF_STATUS_E_FAILURE) {
6470 status = false;
6471 hdd_err("Couldn't pass on WNI_IGNORE_DTIM to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006472 }
6473
Krunal Sonidf0f8742016-09-26 14:56:31 -07006474 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_PS_ENABLE_HEART_BEAT,
6475 config->fEnableFwHeartBeatMonitoring)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306476 == QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006477 status = false;
6478 hdd_err("Couldn't pass on WNI_CFG_PS_HEART_BEAT to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006479 }
6480
Krunal Sonidf0f8742016-09-26 14:56:31 -07006481 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_PS_ENABLE_BCN_FILTER,
6482 config->fEnableFwBeaconFiltering) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306483 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006484 status = false;
6485 hdd_err("Couldn't pass on WNI_CFG_PS_BCN_FILTER to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006486 }
6487
Krunal Sonidf0f8742016-09-26 14:56:31 -07006488 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_PS_ENABLE_RSSI_MONITOR,
6489 config->fEnableFwRssiMonitoring) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306490 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006491 status = false;
6492 hdd_err("Couldn't pass on WNI_CFG_PS_RSSI_MONITOR to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006493 }
6494
Krunal Sonidf0f8742016-09-26 14:56:31 -07006495 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_PS_DATA_INACTIVITY_TIMEOUT,
6496 config->nDataInactivityTimeout) == QDF_STATUS_E_FAILURE) {
6497 status = false;
6498 hdd_err("Couldn't pass on WNI_CFG_PS_DATA_INACTIVITY_TIMEOUT to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006499 }
6500
Krunal Sonidf0f8742016-09-26 14:56:31 -07006501 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_ENABLE_LTE_COEX,
6502 config->enableLTECoex) == QDF_STATUS_E_FAILURE) {
6503 status = false;
6504 hdd_err("Couldn't pass on WNI_CFG_ENABLE_LTE_COEX to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006505 }
6506
Krunal Sonidf0f8742016-09-26 14:56:31 -07006507 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_AP_KEEP_ALIVE_TIMEOUT,
6508 config->apKeepAlivePeriod) == QDF_STATUS_E_FAILURE) {
6509 status = false;
6510 hdd_err("Couldn't pass on WNI_CFG_AP_KEEP_ALIVE_TIMEOUT to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006511 }
6512
Krunal Sonidf0f8742016-09-26 14:56:31 -07006513 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_GO_KEEP_ALIVE_TIMEOUT,
6514 config->goKeepAlivePeriod) == QDF_STATUS_E_FAILURE) {
6515 status = false;
6516 hdd_err("Couldn't pass on WNI_CFG_GO_KEEP_ALIVE_TIMEOUT to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006517 }
6518
Krunal Sonidf0f8742016-09-26 14:56:31 -07006519 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_AP_LINK_MONITOR_TIMEOUT,
6520 config->apLinkMonitorPeriod) == QDF_STATUS_E_FAILURE) {
6521 status = false;
6522 hdd_err("Couldn't pass on WNI_CFG_AP_LINK_MONITOR_TIMEOUT to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006523 }
6524
Krunal Sonidf0f8742016-09-26 14:56:31 -07006525 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_GO_LINK_MONITOR_TIMEOUT,
6526 config->goLinkMonitorPeriod) == QDF_STATUS_E_FAILURE) {
6527 status = false;
6528 hdd_err("Couldn't pass on WNI_CFG_GO_LINK_MONITOR_TIMEOUT to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006529 }
6530
Krunal Sonidf0f8742016-09-26 14:56:31 -07006531 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_MCAST_BCAST_FILTER_SETTING,
6532 config->mcastBcastFilterSetting) == QDF_STATUS_E_FAILURE)
6533 status = false;
6534 hdd_err("Couldn't pass on WNI_CFG_MCAST_BCAST_FILTER_SETTING to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006535
Krunal Sonidf0f8742016-09-26 14:56:31 -07006536 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_SINGLE_TID_RC,
6537 config->bSingleTidRc) == QDF_STATUS_E_FAILURE) {
6538 status = false;
6539 hdd_err("Couldn't pass on WNI_CFG_SINGLE_TID_RC to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006540 }
6541
Krunal Sonidf0f8742016-09-26 14:56:31 -07006542 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TELE_BCN_WAKEUP_EN,
6543 config->teleBcnWakeupEn) == QDF_STATUS_E_FAILURE) {
6544 status = false;
6545 hdd_err("Couldn't pass on WNI_CFG_TELE_BCN_WAKEUP_EN to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006546 }
6547
Krunal Sonidf0f8742016-09-26 14:56:31 -07006548 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TELE_BCN_TRANS_LI,
6549 config->nTeleBcnTransListenInterval) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306550 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006551 status = false;
6552 hdd_err("Couldn't pass on WNI_CFG_TELE_BCN_TRANS_LI to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006553 }
6554
Krunal Sonidf0f8742016-09-26 14:56:31 -07006555 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TELE_BCN_MAX_LI,
6556 config->nTeleBcnMaxListenInterval) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306557 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006558 status = false;
6559 hdd_err("Couldn't pass on WNI_CFG_TELE_BCN_MAX_LI to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006560 }
6561
Krunal Sonidf0f8742016-09-26 14:56:31 -07006562 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TELE_BCN_TRANS_LI_IDLE_BCNS,
6563 config->nTeleBcnTransLiNumIdleBeacons) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306564 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006565 status = false;
6566 hdd_err("Couldn't pass on WNI_CFG_TELE_BCN_TRANS_LI_IDLE_BCNS to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006567 }
6568
Krunal Sonidf0f8742016-09-26 14:56:31 -07006569 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TELE_BCN_MAX_LI_IDLE_BCNS,
6570 config->nTeleBcnMaxLiNumIdleBeacons) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306571 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006572 status = false;
6573 hdd_err("Couldn't pass on WNI_CFG_TELE_BCN_MAX_LI_IDLE_BCNS to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006574 }
6575
Krunal Sonidf0f8742016-09-26 14:56:31 -07006576 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_RF_SETTLING_TIME_CLK,
6577 config->rfSettlingTimeUs) == QDF_STATUS_E_FAILURE) {
6578 status = false;
6579 hdd_err("Couldn't pass on WNI_CFG_RF_SETTLING_TIME_CLK to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006580 }
6581
Krunal Sonidf0f8742016-09-26 14:56:31 -07006582 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_INFRA_STA_KEEP_ALIVE_PERIOD,
6583 config->infraStaKeepAlivePeriod) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306584 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006585 status = false;
6586 hdd_err("Couldn't pass on WNI_CFG_INFRA_STA_KEEP_ALIVE_PERIOD to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006587 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006588 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_DYNAMIC_PS_POLL_VALUE,
6589 config->dynamicPsPollValue) == QDF_STATUS_E_FAILURE) {
6590 status = false;
6591 hdd_err("Couldn't pass on WNI_CFG_DYNAMIC_PS_POLL_VALUE to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006592 }
6593
Krunal Sonidf0f8742016-09-26 14:56:31 -07006594 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_PS_NULLDATA_AP_RESP_TIMEOUT,
6595 config->nNullDataApRespTimeout) == QDF_STATUS_E_FAILURE) {
6596 status = false;
6597 hdd_err("Couldn't pass on WNI_CFG_PS_NULLDATA_DELAY_TIMEOUT to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006598 }
6599
Krunal Sonidf0f8742016-09-26 14:56:31 -07006600 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_AP_DATA_AVAIL_POLL_PERIOD,
6601 config->apDataAvailPollPeriodInMs) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306602 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006603 status = false;
6604 hdd_err("Couldn't pass on WNI_CFG_AP_DATA_AVAIL_POLL_PERIOD to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006605 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006606 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_FRAGMENTATION_THRESHOLD,
6607 config->FragmentationThreshold) == QDF_STATUS_E_FAILURE) {
6608 status = false;
6609 hdd_err("Couldn't pass on WNI_CFG_FRAGMENTATION_THRESHOLD to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006610 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006611 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_RTS_THRESHOLD,
6612 config->RTSThreshold) == QDF_STATUS_E_FAILURE) {
6613 status = false;
6614 hdd_err("Couldn't pass on WNI_CFG_RTS_THRESHOLD to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006615 }
6616
Krunal Sonidf0f8742016-09-26 14:56:31 -07006617 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_11D_ENABLED,
6618 config->Is11dSupportEnabled) == QDF_STATUS_E_FAILURE) {
6619 status = false;
6620 hdd_err("Couldn't pass on WNI_CFG_11D_ENABLED to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006621 }
6622
Krunal Sonidf0f8742016-09-26 14:56:31 -07006623 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_DFS_MASTER_ENABLED,
6624 config->enableDFSMasterCap) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306625 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006626 status = false;
6627 hdd_err("Failure: Couldn't set value for WNI_CFG_DFS_MASTER_ENABLED");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006628 }
6629
Krunal Sonidf0f8742016-09-26 14:56:31 -07006630 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_HEART_BEAT_THRESHOLD,
6631 config->HeartbeatThresh24) == QDF_STATUS_E_FAILURE) {
6632 status = false;
6633 hdd_err("Couldn't pass on WNI_CFG_HEART_BEAT_THRESHOLD to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006634 }
6635
Krunal Sonidf0f8742016-09-26 14:56:31 -07006636 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_AP_DATA_AVAIL_POLL_PERIOD,
6637 config->apDataAvailPollPeriodInMs) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306638 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006639 status = false;
6640 hdd_err("Couldn't pass on WNI_CFG_AP_DATA_AVAIL_POLL_PERIOD to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006641 }
6642
Krunal Sonidf0f8742016-09-26 14:56:31 -07006643 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_ENABLE_MC_ADDR_LIST,
6644 config->fEnableMCAddrList) == QDF_STATUS_E_FAILURE) {
6645 status = false;
6646 hdd_err("Couldn't pass on WNI_CFG_ENABLE_MC_ADDR_LIST to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006647 }
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006648
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006649#ifdef WLAN_SOFTAP_VSTA_FEATURE
Krunal Sonidf0f8742016-09-26 14:56:31 -07006650 if (config->fEnableVSTASupport) {
6651 sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_ASSOC_STA_LIMIT, &val);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006652 if (val <= WNI_CFG_ASSOC_STA_LIMIT_STADEF)
6653 val = WNI_CFG_ASSOC_STA_LIMIT_STAMAX;
6654 } else {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006655 val = config->maxNumberOfPeers;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006656
6657 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006658 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_ASSOC_STA_LIMIT, val) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306659 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006660 status = false;
6661 hdd_err("Couldn't pass on WNI_CFG_ASSOC_STA_LIMIT to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006662 }
6663#endif
Krunal Sonidf0f8742016-09-26 14:56:31 -07006664 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_ENABLE_LPWR_IMG_TRANSITION,
6665 config->enableLpwrImgTransition)
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306666 == QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006667 status = false;
6668 hdd_err("Couldn't pass on WNI_CFG_ENABLE_LPWR_IMG_TRANSITION to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006669 }
6670
Krunal Sonidf0f8742016-09-26 14:56:31 -07006671 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_ENABLE_MCC_ADAPTIVE_SCHED,
6672 config->enableMCCAdaptiveScheduler) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306673 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006674 status = false;
6675 hdd_err("Couldn't pass on WNI_CFG_ENABLE_MCC_ADAPTIVE_SCHED to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006676 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006677 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_DISABLE_LDPC_WITH_TXBF_AP,
6678 config->disableLDPCWithTxbfAP) == QDF_STATUS_E_FAILURE) {
6679 status = false;
6680 hdd_err("Couldn't pass on WNI_CFG_DISABLE_LDPC_WITH_TXBF_AP to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006681 }
6682
Krunal Sonidf0f8742016-09-26 14:56:31 -07006683 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_DYNAMIC_THRESHOLD_ZERO,
6684 config->retryLimitZero) == QDF_STATUS_E_FAILURE) {
6685 status = false;
6686 hdd_err("Couldn't pass on WNI_CFG_DYNAMIC_THRESHOLD_ZERO to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006687 }
6688
Krunal Sonidf0f8742016-09-26 14:56:31 -07006689 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_DYNAMIC_THRESHOLD_ONE,
6690 config->retryLimitOne) == QDF_STATUS_E_FAILURE) {
6691 status = false;
6692 hdd_err("Couldn't pass on WNI_CFG_DYNAMIC_THRESHOLD_ONE to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006693 }
6694
Krunal Sonidf0f8742016-09-26 14:56:31 -07006695 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_DYNAMIC_THRESHOLD_TWO,
6696 config->retryLimitTwo) == QDF_STATUS_E_FAILURE) {
6697 status = false;
6698 hdd_err("Couldn't pass on WNI_CFG_DYNAMIC_THRESHOLD_TWO to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006699 }
6700
Krunal Sonidf0f8742016-09-26 14:56:31 -07006701 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_MAX_MEDIUM_TIME,
6702 config->cfgMaxMediumTime) == QDF_STATUS_E_FAILURE) {
6703 status = false;
6704 hdd_err("Couldn't pass on WNI_CFG_MAX_MEDIUM_TIME to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006705 }
6706#ifdef FEATURE_WLAN_TDLS
6707
Krunal Sonidf0f8742016-09-26 14:56:31 -07006708 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TDLS_QOS_WMM_UAPSD_MASK,
6709 config->fTDLSUapsdMask) == QDF_STATUS_E_FAILURE) {
6710 status = false;
6711 hdd_err("Couldn't pass on WNI_CFG_TDLS_QOS_WMM_UAPSD_MASK to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006712 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006713 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TDLS_BUF_STA_ENABLED,
6714 config->fEnableTDLSBufferSta) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306715 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006716 status = false;
6717 hdd_err("Couldn't pass on WNI_CFG_TDLS_BUF_STA_ENABLED to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006718 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006719 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TDLS_PUAPSD_INACT_TIME,
6720 config->fTDLSPuapsdInactivityTimer) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306721 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006722 status = false;
6723 hdd_err("Couldn't pass on WNI_CFG_TDLS_PUAPSD_INACT_TIME to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006724 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006725 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TDLS_RX_FRAME_THRESHOLD,
6726 config->fTDLSRxFrameThreshold) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306727 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006728 status = false;
6729 hdd_err("Couldn't pass on WNI_CFG_TDLS_RX_FRAME_THRESHOLD to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006730 }
6731
Krunal Sonidf0f8742016-09-26 14:56:31 -07006732 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TDLS_OFF_CHANNEL_ENABLED,
6733 config->fEnableTDLSOffChannel) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306734 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006735 status = false;
6736 hdd_err("Couldn't pass on WNI_CFG_TDLS_BUF_STA_ENABLED to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006737 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006738 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TDLS_WMM_MODE_ENABLED,
6739 config->fEnableTDLSWmmMode) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306740 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006741 status = false;
6742 hdd_err("Couldn't pass on WNI_CFG_TDLS_WMM_MODE_ENABLED to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006743 }
6744#endif
6745
Krunal Sonidf0f8742016-09-26 14:56:31 -07006746 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_ENABLE_ADAPT_RX_DRAIN,
6747 config->fEnableAdaptRxDrain) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306748 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006749 status = false;
6750 hdd_err("Couldn't pass on WNI_CFG_ENABLE_ADAPT_RX_DRAIN to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006751 }
6752
Krunal Sonidf0f8742016-09-26 14:56:31 -07006753 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_ANTENNA_DIVESITY,
6754 config->antennaDiversity) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306755 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006756 status = false;
6757 hdd_err("Couldn't pass on WNI_CFG_ANTENNA_DIVESITY to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006758 }
6759
Krunal Sonidf0f8742016-09-26 14:56:31 -07006760 if (sme_cfg_set_int(hdd_ctx->hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006761 WNI_CFG_DEFAULT_RATE_INDEX_24GHZ,
Krunal Sonidf0f8742016-09-26 14:56:31 -07006762 config->defaultRateIndex24Ghz) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306763 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006764 status = false;
6765 hdd_err("Couldn't pass on WNI_CFG_DEFAULT_RATE_INDEX_24GHZ to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006766 }
6767
Krunal Sonidf0f8742016-09-26 14:56:31 -07006768 if (sme_cfg_set_int(hdd_ctx->hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006769 WNI_CFG_DEBUG_P2P_REMAIN_ON_CHANNEL,
Krunal Sonidf0f8742016-09-26 14:56:31 -07006770 config->debugP2pRemainOnChannel) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306771 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006772 status = false;
6773 hdd_err("Couldn't pass on WNI_CFG_DEBUG_P2P_REMAIN_ON_CHANNEL to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006774 }
6775#ifdef WLAN_FEATURE_11W
Krunal Sonidf0f8742016-09-26 14:56:31 -07006776 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_PMF_SA_QUERY_MAX_RETRIES,
6777 config->pmfSaQueryMaxRetries) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306778 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006779 status = false;
6780 hdd_err("Couldn't pass on WNI_CFG_SA_QUERY_MAX_RETRIES to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006781 }
6782
Krunal Sonidf0f8742016-09-26 14:56:31 -07006783 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_PMF_SA_QUERY_RETRY_INTERVAL,
6784 config->pmfSaQueryRetryInterval) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306785 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006786 status = false;
6787 hdd_err("Couldn't pass on WNI_CFG_SA_QUERY_RETRY_INTERVAL to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006788 }
6789#endif
6790
Krunal Sonidf0f8742016-09-26 14:56:31 -07006791 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_IBSS_ATIM_WIN_SIZE,
6792 config->ibssATIMWinSize) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306793 QDF_STATUS_E_FAILURE) {
Krunal Sonidf0f8742016-09-26 14:56:31 -07006794 status = false;
6795 hdd_err("Couldn't pass on WNI_CFG_IBSS_ATIM_WIN_SIZE to CFG");
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006796 }
Krunal Soni53993f72016-07-08 18:20:03 -07006797
Krunal Sonidf0f8742016-09-26 14:56:31 -07006798 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_TGT_GTX_USR_CFG,
6799 config->tgt_gtx_usr_cfg) == QDF_STATUS_E_FAILURE) {
6800 status = false;
6801 hdd_err("Couldn't pass on WNI_CFG_TGT_GTX_USR_CFG to CCM");
Rajeev Kumar Sirasanagandlaaf474742016-09-06 17:54:50 +05306802 }
Krunal Sonidf0f8742016-09-26 14:56:31 -07006803 return status;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006804}
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006805#ifdef FEATURE_WLAN_SCAN_PNO
6806/**
6807 * hdd_set_pno_channel_prediction_config() - Set PNO configuration
6808 * @sme_config: Config params from SME Context
6809 * @hdd_ctx: Config params from HDD Context
6810 *
6811 * Copy the PNO Channel prediction feature configuration parameters
6812 * from HDD context to SME context.
6813 *
6814 * Return: None
6815 */
6816void hdd_set_pno_channel_prediction_config(
6817 tpSmeConfigParams sme_config, hdd_context_t *hdd_ctx)
6818{
Krunal Soni1878d3a2016-01-14 13:00:44 -08006819 sme_config->csrConfig.dual_mac_feature_disable =
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006820 hdd_ctx->config->dual_mac_feature_disable;
Krunal Soni1878d3a2016-01-14 13:00:44 -08006821 sme_config->csrConfig.pno_channel_prediction =
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006822 hdd_ctx->config->pno_channel_prediction;
Krunal Soni1878d3a2016-01-14 13:00:44 -08006823 sme_config->csrConfig.top_k_num_of_channels =
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006824 hdd_ctx->config->top_k_num_of_channels;
Krunal Soni1878d3a2016-01-14 13:00:44 -08006825 sme_config->csrConfig.stationary_thresh =
6826 hdd_ctx->config->stationary_thresh;
6827 sme_config->csrConfig.channel_prediction_full_scan =
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006828 hdd_ctx->config->channel_prediction_full_scan;
Gupta, Kapil96c7f2f2016-04-25 19:13:41 +05306829 sme_config->csrConfig.pnoscan_adaptive_dwell_mode =
6830 hdd_ctx->config->pnoscan_adaptive_dwell_mode;
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07006831}
6832#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006833/**
6834 * hdd_set_sme_config() -initializes the sme configuration parameters
6835 *
6836 * @pHddCtx: the pointer to hdd context
6837 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306838 * Return: QDF_STATUS_SUCCESS if configuration is correctly applied,
6839 * otherwise the appropriate QDF_STATUS would be returned
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006840 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306841QDF_STATUS hdd_set_sme_config(hdd_context_t *pHddCtx)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006842{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306843 QDF_STATUS status = QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006844 tSmeConfigParams *smeConfig;
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006845 uint8_t rrm_capab_len;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006846
6847 struct hdd_config *pConfig = pHddCtx->config;
6848
Anurag Chouhan600c3a02016-03-01 10:33:54 +05306849 smeConfig = qdf_mem_malloc(sizeof(*smeConfig));
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006850 if (NULL == smeConfig) {
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05306851 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_ERROR,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006852 "%s: unable to allocate smeConfig", __func__);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05306853 return QDF_STATUS_E_NOMEM;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006854 }
Anurag Chouhan600c3a02016-03-01 10:33:54 +05306855 qdf_mem_zero(smeConfig, sizeof(*smeConfig));
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006856
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05306857 QDF_TRACE(QDF_MODULE_ID_HDD, QDF_TRACE_LEVEL_INFO_HIGH,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006858 "%s bWmmIsEnabled=%d 802_11e_enabled=%d dot11Mode=%d",
6859 __func__, pConfig->WmmMode, pConfig->b80211eIsEnabled,
6860 pConfig->dot11Mode);
6861
6862 /* Config params obtained from the registry
6863 * To Do: set regulatory information here
6864 */
6865
6866 smeConfig->csrConfig.RTSThreshold = pConfig->RTSThreshold;
6867 smeConfig->csrConfig.FragmentationThreshold =
6868 pConfig->FragmentationThreshold;
6869 smeConfig->csrConfig.shortSlotTime = pConfig->ShortSlotTimeEnabled;
6870 smeConfig->csrConfig.Is11dSupportEnabled = pConfig->Is11dSupportEnabled;
6871 smeConfig->csrConfig.HeartbeatThresh24 = pConfig->HeartbeatThresh24;
6872
6873 smeConfig->csrConfig.phyMode =
6874 hdd_cfg_xlate_to_csr_phy_mode(pConfig->dot11Mode);
6875
6876 if (pConfig->dot11Mode == eHDD_DOT11_MODE_abg ||
6877 pConfig->dot11Mode == eHDD_DOT11_MODE_11b ||
6878 pConfig->dot11Mode == eHDD_DOT11_MODE_11g ||
6879 pConfig->dot11Mode == eHDD_DOT11_MODE_11b_ONLY ||
6880 pConfig->dot11Mode == eHDD_DOT11_MODE_11g_ONLY) {
6881 smeConfig->csrConfig.channelBondingMode24GHz = 0;
6882 smeConfig->csrConfig.channelBondingMode5GHz = 0;
6883 } else {
6884 smeConfig->csrConfig.channelBondingMode24GHz =
6885 pConfig->nChannelBondingMode24GHz;
6886 smeConfig->csrConfig.channelBondingMode5GHz =
6887 pConfig->nChannelBondingMode5GHz;
6888 }
6889 smeConfig->csrConfig.TxRate = pConfig->TxRate;
6890 smeConfig->csrConfig.nScanResultAgeCount = pConfig->ScanResultAgeCount;
6891 smeConfig->csrConfig.scanAgeTimeNCNPS = pConfig->nScanAgeTimeNCNPS;
6892 smeConfig->csrConfig.scanAgeTimeNCPS = pConfig->nScanAgeTimeNCPS;
6893 smeConfig->csrConfig.scanAgeTimeCNPS = pConfig->nScanAgeTimeCNPS;
6894 smeConfig->csrConfig.scanAgeTimeCPS = pConfig->nScanAgeTimeCPS;
6895 smeConfig->csrConfig.AdHocChannel24 = pConfig->OperatingChannel;
6896 smeConfig->csrConfig.fSupplicantCountryCodeHasPriority =
6897 pConfig->fSupplicantCountryCodeHasPriority;
6898 smeConfig->csrConfig.bCatRssiOffset = pConfig->nRssiCatGap;
6899 smeConfig->csrConfig.vccRssiThreshold = pConfig->nVccRssiTrigger;
6900 smeConfig->csrConfig.vccUlMacLossThreshold =
6901 pConfig->nVccUlMacLossThreshold;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006902 smeConfig->csrConfig.nInitialDwellTime = pConfig->nInitialDwellTime;
6903 smeConfig->csrConfig.initial_scan_no_dfs_chnl =
6904 pConfig->initial_scan_no_dfs_chnl;
6905 smeConfig->csrConfig.nActiveMaxChnTime = pConfig->nActiveMaxChnTime;
6906 smeConfig->csrConfig.nActiveMinChnTime = pConfig->nActiveMinChnTime;
6907 smeConfig->csrConfig.nPassiveMaxChnTime = pConfig->nPassiveMaxChnTime;
6908 smeConfig->csrConfig.nPassiveMinChnTime = pConfig->nPassiveMinChnTime;
6909#ifdef WLAN_AP_STA_CONCURRENCY
6910 smeConfig->csrConfig.nActiveMaxChnTimeConc =
6911 pConfig->nActiveMaxChnTimeConc;
6912 smeConfig->csrConfig.nActiveMinChnTimeConc =
6913 pConfig->nActiveMinChnTimeConc;
6914 smeConfig->csrConfig.nPassiveMaxChnTimeConc =
6915 pConfig->nPassiveMaxChnTimeConc;
6916 smeConfig->csrConfig.nPassiveMinChnTimeConc =
6917 pConfig->nPassiveMinChnTimeConc;
6918 smeConfig->csrConfig.nRestTimeConc = pConfig->nRestTimeConc;
Agrawal Ashish17bb3902016-05-05 13:29:40 +05306919 smeConfig->csrConfig.min_rest_time_conc = pConfig->min_rest_time_conc;
6920 smeConfig->csrConfig.idle_time_conc = pConfig->idle_time_conc;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006921 smeConfig->csrConfig.nNumStaChanCombinedConc =
6922 pConfig->nNumStaChanCombinedConc;
6923 smeConfig->csrConfig.nNumP2PChanCombinedConc =
6924 pConfig->nNumP2PChanCombinedConc;
6925
6926#endif
6927 smeConfig->csrConfig.Is11eSupportEnabled = pConfig->b80211eIsEnabled;
6928 smeConfig->csrConfig.WMMSupportMode = pConfig->WmmMode;
6929
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -08006930 smeConfig->rrmConfig.rrm_enabled = pConfig->fRrmEnable;
6931 smeConfig->rrmConfig.max_randn_interval = pConfig->nRrmRandnIntvl;
6932 hdd_hex_string_to_u8_array(pConfig->rm_capability,
6933 smeConfig->rrmConfig.rm_capability, &rrm_capab_len,
6934 DOT11F_IE_RRMENABLEDCAP_MAX_LEN);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006935 /* Remaining config params not obtained from registry
6936 * On RF EVB beacon using channel 1.
6937 */
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006938 smeConfig->csrConfig.nVhtChannelWidth = pConfig->vhtChannelWidth;
6939 smeConfig->csrConfig.enableTxBF = pConfig->enableTxBF;
Kiran Kumar Lokere5302ab62015-12-16 16:03:16 -08006940 smeConfig->csrConfig.enable_txbf_sap_mode =
6941 pConfig->enable_txbf_sap_mode;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006942 smeConfig->csrConfig.enable2x2 = pConfig->enable2x2;
6943 smeConfig->csrConfig.enableVhtFor24GHz = pConfig->enableVhtFor24GHzBand;
Kapil Gupta4b2efbb2016-10-03 13:07:20 +05306944 smeConfig->csrConfig.vendor_vht_sap =
6945 pConfig->enable_sap_vendor_vht;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006946 smeConfig->csrConfig.enableMuBformee = pConfig->enableMuBformee;
6947 smeConfig->csrConfig.enableVhtpAid = pConfig->enableVhtpAid;
6948 smeConfig->csrConfig.enableVhtGid = pConfig->enableVhtGid;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006949 smeConfig->csrConfig.enableAmpduPs = pConfig->enableAmpduPs;
6950 smeConfig->csrConfig.enableHtSmps = pConfig->enableHtSmps;
6951 smeConfig->csrConfig.htSmps = pConfig->htSmps;
Archana Ramachandranfec24812016-02-16 16:31:56 -08006952 /* This param cannot be configured from INI */
6953 smeConfig->csrConfig.send_smps_action = true;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006954 smeConfig->csrConfig.AdHocChannel5G = pConfig->AdHocChannel5G;
6955 smeConfig->csrConfig.AdHocChannel24 = pConfig->AdHocChannel24G;
6956 smeConfig->csrConfig.ProprietaryRatesEnabled = 0;
6957 smeConfig->csrConfig.HeartbeatThresh50 = 40;
6958 smeConfig->csrConfig.bandCapability = pConfig->nBandCapability;
6959 if (pConfig->nBandCapability == eCSR_BAND_24) {
6960 smeConfig->csrConfig.Is11hSupportEnabled = 0;
6961 } else {
6962 smeConfig->csrConfig.Is11hSupportEnabled =
6963 pConfig->Is11hSupportEnabled;
6964 }
6965 smeConfig->csrConfig.cbChoice = 0;
6966 smeConfig->csrConfig.eBand = pConfig->nBandCapability;
6967 smeConfig->csrConfig.nTxPowerCap = pConfig->nTxPowerCap;
Padma, Santhosh Kumar29df3622016-08-16 19:15:16 +05306968 smeConfig->csrConfig.allow_tpc_from_ap = pConfig->allow_tpc_from_ap;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006969 smeConfig->csrConfig.fEnableBypass11d = pConfig->enableBypass11d;
6970 smeConfig->csrConfig.fEnableDFSChnlScan = pConfig->enableDFSChnlScan;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006971 smeConfig->csrConfig.nRoamPrefer5GHz = pConfig->nRoamPrefer5GHz;
6972 smeConfig->csrConfig.nRoamIntraBand = pConfig->nRoamIntraBand;
6973 smeConfig->csrConfig.nProbes = pConfig->nProbes;
6974
6975 smeConfig->csrConfig.nRoamScanHomeAwayTime =
6976 pConfig->nRoamScanHomeAwayTime;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006977 smeConfig->csrConfig.fFirstScanOnly2GChnl =
6978 pConfig->enableFirstScan2GOnly;
6979
Peng Xuf5d60c82015-10-02 17:17:03 -07006980 smeConfig->csrConfig.Csr11dinfo.Channels.numChannels = 0;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006981
6982 hdd_set_power_save_offload_config(pHddCtx);
6983
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006984 smeConfig->csrConfig.csr11rConfig.IsFTResourceReqSupported =
6985 pConfig->fFTResourceReqSupported;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006986 smeConfig->csrConfig.isFastRoamIniFeatureEnabled =
6987 pConfig->isFastRoamIniFeatureEnabled;
6988 smeConfig->csrConfig.MAWCEnabled = pConfig->MAWCEnabled;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006989#ifdef FEATURE_WLAN_ESE
6990 smeConfig->csrConfig.isEseIniFeatureEnabled =
6991 pConfig->isEseIniFeatureEnabled;
6992 if (pConfig->isEseIniFeatureEnabled) {
6993 pConfig->isFastTransitionEnabled = true;
6994 }
6995#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08006996 smeConfig->csrConfig.isFastTransitionEnabled =
6997 pConfig->isFastTransitionEnabled;
6998 smeConfig->csrConfig.RoamRssiDiff = pConfig->RoamRssiDiff;
6999 smeConfig->csrConfig.isWESModeEnabled = pConfig->isWESModeEnabled;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007000 smeConfig->csrConfig.isRoamOffloadScanEnabled =
7001 pConfig->isRoamOffloadScanEnabled;
7002 smeConfig->csrConfig.bFastRoamInConIniFeatureEnabled =
7003 pConfig->bFastRoamInConIniFeatureEnabled;
7004
7005 if (0 == smeConfig->csrConfig.isRoamOffloadScanEnabled) {
7006 /* Disable roaming in concurrency if roam scan offload is disabled */
7007 smeConfig->csrConfig.bFastRoamInConIniFeatureEnabled = 0;
7008 }
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007009 smeConfig->csrConfig.neighborRoamConfig.nNeighborLookupRssiThreshold =
7010 pConfig->nNeighborLookupRssiThreshold;
7011 smeConfig->csrConfig.neighborRoamConfig.delay_before_vdev_stop =
7012 pConfig->delay_before_vdev_stop;
7013 smeConfig->csrConfig.neighborRoamConfig.nOpportunisticThresholdDiff =
7014 pConfig->nOpportunisticThresholdDiff;
7015 smeConfig->csrConfig.neighborRoamConfig.nRoamRescanRssiDiff =
7016 pConfig->nRoamRescanRssiDiff;
7017 smeConfig->csrConfig.neighborRoamConfig.nNeighborScanMaxChanTime =
7018 pConfig->nNeighborScanMaxChanTime;
7019 smeConfig->csrConfig.neighborRoamConfig.nNeighborScanMinChanTime =
7020 pConfig->nNeighborScanMinChanTime;
7021 smeConfig->csrConfig.neighborRoamConfig.nNeighborScanTimerPeriod =
7022 pConfig->nNeighborScanPeriod;
7023 smeConfig->csrConfig.neighborRoamConfig.nMaxNeighborRetries =
7024 pConfig->nMaxNeighborReqTries;
7025 smeConfig->csrConfig.neighborRoamConfig.nNeighborResultsRefreshPeriod =
7026 pConfig->nNeighborResultsRefreshPeriod;
7027 smeConfig->csrConfig.neighborRoamConfig.nEmptyScanRefreshPeriod =
7028 pConfig->nEmptyScanRefreshPeriod;
7029 hdd_string_to_u8_array(pConfig->neighborScanChanList,
7030 smeConfig->csrConfig.neighborRoamConfig.
7031 neighborScanChanList.channelList,
7032 &smeConfig->csrConfig.neighborRoamConfig.
7033 neighborScanChanList.numChannels,
7034 WNI_CFG_VALID_CHANNEL_LIST_LEN);
7035 smeConfig->csrConfig.neighborRoamConfig.nRoamBmissFirstBcnt =
7036 pConfig->nRoamBmissFirstBcnt;
7037 smeConfig->csrConfig.neighborRoamConfig.nRoamBmissFinalBcnt =
7038 pConfig->nRoamBmissFinalBcnt;
7039 smeConfig->csrConfig.neighborRoamConfig.nRoamBeaconRssiWeight =
7040 pConfig->nRoamBeaconRssiWeight;
7041 smeConfig->csrConfig.neighborRoamConfig.nhi_rssi_scan_max_count =
7042 pConfig->nhi_rssi_scan_max_count;
7043 smeConfig->csrConfig.neighborRoamConfig.nhi_rssi_scan_rssi_delta =
7044 pConfig->nhi_rssi_scan_rssi_delta;
7045 smeConfig->csrConfig.neighborRoamConfig.nhi_rssi_scan_delay =
7046 pConfig->nhi_rssi_scan_delay;
7047 smeConfig->csrConfig.neighborRoamConfig.nhi_rssi_scan_rssi_ub =
7048 pConfig->nhi_rssi_scan_rssi_ub;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007049 smeConfig->csrConfig.addTSWhenACMIsOff = pConfig->AddTSWhenACMIsOff;
7050 smeConfig->csrConfig.fValidateList = pConfig->fValidateScanList;
7051 smeConfig->csrConfig.allowDFSChannelRoam = pConfig->allowDFSChannelRoam;
7052
7053 /* Enable/Disable MCC */
7054 smeConfig->csrConfig.fEnableMCCMode = pConfig->enableMCC;
7055 smeConfig->csrConfig.mcc_rts_cts_prot_enable =
7056 pConfig->mcc_rts_cts_prot_enable;
7057 smeConfig->csrConfig.mcc_bcast_prob_resp_enable =
7058 pConfig->mcc_bcast_prob_resp_enable;
7059 smeConfig->csrConfig.fAllowMCCGODiffBI = pConfig->allowMCCGODiffBI;
7060
7061 /* Scan Results Aging Time out value */
7062 smeConfig->csrConfig.scanCfgAgingTime = pConfig->scanAgingTimeout;
7063
7064 smeConfig->csrConfig.enableTxLdpc = pConfig->enableTxLdpc;
Krunal Soni0193b6f2016-08-15 15:53:43 -07007065 smeConfig->csrConfig.enableRxLDPC = pConfig->enableRxLDPC;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007066#ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
7067 smeConfig->csrConfig.cc_switch_mode = pConfig->WlanMccToSccSwitchMode;
7068#endif
7069
7070 smeConfig->csrConfig.isAmsduSupportInAMPDU =
7071 pConfig->isAmsduSupportInAMPDU;
7072 smeConfig->csrConfig.nSelect5GHzMargin = pConfig->nSelect5GHzMargin;
7073
7074 smeConfig->csrConfig.isCoalesingInIBSSAllowed =
7075 pHddCtx->config->isCoalesingInIBSSAllowed;
7076 smeConfig->csrConfig.ignore_peer_erp_info =
7077 pConfig->ignore_peer_erp_info;
7078 /* update SSR config */
7079 sme_update_enable_ssr((tHalHandle) (pHddCtx->hHal),
7080 pHddCtx->config->enableSSR);
7081
7082#ifdef FEATURE_WLAN_SCAN_PNO
7083 /* Update PNO offoad status */
Krunal Soni1878d3a2016-01-14 13:00:44 -08007084 smeConfig->csrConfig.pnoOffload = pHddCtx->config->PnoOffload;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007085#endif
7086
7087 /* Update maximum interfaces information */
Krunal Soni1878d3a2016-01-14 13:00:44 -08007088 smeConfig->csrConfig.max_intf_count = pHddCtx->max_intf_count;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007089
Krunal Soni1878d3a2016-01-14 13:00:44 -08007090 smeConfig->csrConfig.fEnableDebugLog = pHddCtx->config->gEnableDebugLog;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007091
Krunal Soni1878d3a2016-01-14 13:00:44 -08007092 smeConfig->csrConfig.enable5gEBT = pHddCtx->config->enable5gEBT;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007093
Krunal Soni1878d3a2016-01-14 13:00:44 -08007094 smeConfig->csrConfig.enableSelfRecovery =
7095 pHddCtx->config->enableSelfRecovery;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007096#ifdef WLAN_FEATURE_ROAM_OFFLOAD
7097 smeConfig->csrConfig.isRoamOffloadEnabled =
7098 pHddCtx->config->isRoamOffloadEnabled;
7099#endif
7100 smeConfig->csrConfig.conc_custom_rule1 =
7101 pHddCtx->config->conc_custom_rule1;
7102 smeConfig->csrConfig.conc_custom_rule2 =
7103 pHddCtx->config->conc_custom_rule2;
7104 smeConfig->csrConfig.is_sta_connection_in_5gz_enabled =
7105 pHddCtx->config->is_sta_connection_in_5gz_enabled;
7106
Krunal Soni1878d3a2016-01-14 13:00:44 -08007107 smeConfig->csrConfig.f_sta_miracast_mcc_rest_time_val =
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007108 pHddCtx->config->sta_miracast_mcc_rest_time_val;
7109
7110#ifdef FEATURE_AP_MCC_CH_AVOIDANCE
Krunal Soni1878d3a2016-01-14 13:00:44 -08007111 smeConfig->csrConfig.sap_channel_avoidance =
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007112 pHddCtx->config->sap_channel_avoidance;
7113#endif /* FEATURE_AP_MCC_CH_AVOIDANCE */
7114
Krunal Soni1878d3a2016-01-14 13:00:44 -08007115 smeConfig->csrConfig.f_prefer_non_dfs_on_radar =
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007116 pHddCtx->config->prefer_non_dfs_on_radar;
7117
Krunal Soni1878d3a2016-01-14 13:00:44 -08007118 smeConfig->csrConfig.is_ps_enabled = pHddCtx->config->is_ps_enabled;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007119 hdd_set_fine_time_meas_cap(pHddCtx, smeConfig);
7120
7121 cds_set_multicast_logging(pHddCtx->config->multicast_host_fw_msgs);
7122
7123 smeConfig->csrConfig.sendDeauthBeforeCon = pConfig->sendDeauthBeforeCon;
7124
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007125 smeConfig->csrConfig.max_scan_count =
7126 pHddCtx->config->max_scan_count;
7127
7128 /* Update 802.11p config */
7129 smeConfig->csrConfig.enable_dot11p =
7130 (pHddCtx->config->dot11p_mode != WLAN_HDD_11P_DISABLED);
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -07007131 hdd_set_pno_channel_prediction_config(smeConfig, pHddCtx);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007132
Krunal Soni1878d3a2016-01-14 13:00:44 -08007133 smeConfig->csrConfig.early_stop_scan_enable =
Varun Reddy Yeturu05186292015-09-28 17:12:33 -07007134 pHddCtx->config->early_stop_scan_enable;
Krunal Soni1878d3a2016-01-14 13:00:44 -08007135 smeConfig->csrConfig.early_stop_scan_min_threshold =
Varun Reddy Yeturu05186292015-09-28 17:12:33 -07007136 pHddCtx->config->early_stop_scan_min_threshold;
Krunal Soni1878d3a2016-01-14 13:00:44 -08007137 smeConfig->csrConfig.early_stop_scan_max_threshold =
Varun Reddy Yeturu05186292015-09-28 17:12:33 -07007138 pHddCtx->config->early_stop_scan_max_threshold;
Varun Reddy Yeturu044bda22015-11-21 22:03:40 -08007139 smeConfig->csrConfig.first_scan_bucket_threshold =
7140 pHddCtx->config->first_scan_bucket_threshold;
Gupta, Kapilc68ad462016-02-01 19:17:23 +05307141
7142 smeConfig->csrConfig.roam_dense_rssi_thresh_offset =
7143 pHddCtx->config->roam_dense_rssi_thresh_offset;
7144 smeConfig->csrConfig.roam_dense_min_aps =
7145 pHddCtx->config->roam_dense_min_aps;
7146 smeConfig->csrConfig.roam_dense_traffic_thresh =
7147 pHddCtx->config->roam_dense_traffic_thresh;
Sandeep Puligilla93a29ec2016-02-12 16:10:56 -08007148 smeConfig->csrConfig.obss_width_interval =
7149 pHddCtx->config->obss_width_trigger_interval;
7150 smeConfig->csrConfig.obss_active_dwelltime =
7151 pHddCtx->config->obss_active_dwelltime;
7152 smeConfig->csrConfig.obss_passive_dwelltime =
7153 pHddCtx->config->obss_passive_dwelltime;
Abhishek Singh165bc602016-03-21 12:43:00 +05307154 smeConfig->csrConfig.ignore_peer_ht_opmode =
7155 pConfig->ignore_peer_ht_opmode;
Abhishek Singh5ea86532016-04-27 14:10:53 +05307156 smeConfig->csrConfig.enable_fatal_event =
7157 pConfig->enable_fatal_event;
Gupta, Kapil96c7f2f2016-04-25 19:13:41 +05307158 smeConfig->csrConfig.scan_adaptive_dwell_mode =
7159 pHddCtx->config->scan_adaptive_dwell_mode;
7160 smeConfig->csrConfig.roamscan_adaptive_dwell_mode =
7161 pHddCtx->config->roamscan_adaptive_dwell_mode;
Gupta, Kapilc68ad462016-02-01 19:17:23 +05307162
Abhishek Singh10ecf582016-05-04 17:48:59 +05307163 smeConfig->csrConfig.enable_edca_params =
7164 pConfig->enable_edca_params;
7165
7166 smeConfig->csrConfig.edca_vo_cwmin =
7167 pConfig->edca_vo_cwmin;
7168 smeConfig->csrConfig.edca_vi_cwmin =
7169 pConfig->edca_vi_cwmin;
7170 smeConfig->csrConfig.edca_bk_cwmin =
7171 pConfig->edca_bk_cwmin;
7172 smeConfig->csrConfig.edca_be_cwmin =
7173 pConfig->edca_be_cwmin;
7174
7175 smeConfig->csrConfig.edca_vo_cwmax =
7176 pConfig->edca_vo_cwmax;
7177 smeConfig->csrConfig.edca_vi_cwmax =
7178 pConfig->edca_vi_cwmax;
7179 smeConfig->csrConfig.edca_bk_cwmax =
7180 pConfig->edca_bk_cwmax;
7181 smeConfig->csrConfig.edca_be_cwmax =
7182 pConfig->edca_be_cwmax;
7183
7184 smeConfig->csrConfig.edca_vo_aifs =
7185 pConfig->edca_vo_aifs;
7186 smeConfig->csrConfig.edca_vi_aifs =
7187 pConfig->edca_vi_aifs;
7188 smeConfig->csrConfig.edca_bk_aifs =
7189 pConfig->edca_bk_aifs;
7190 smeConfig->csrConfig.edca_be_aifs =
7191 pConfig->edca_be_aifs;
Agrawal Ashish21ba2572016-09-03 16:40:10 +05307192 smeConfig->csrConfig.sta_roam_policy_params.dfs_mode =
7193 CSR_STA_ROAM_POLICY_DFS_ENABLED;
7194 smeConfig->csrConfig.sta_roam_policy_params.skip_unsafe_channels = 0;
Abhishek Singh10ecf582016-05-04 17:48:59 +05307195
Padma, Santhosh Kumara7119672016-08-16 16:05:14 +05307196 smeConfig->csrConfig.tx_aggregation_size =
7197 pHddCtx->config->tx_aggregation_size;
7198 smeConfig->csrConfig.rx_aggregation_size =
7199 pHddCtx->config->rx_aggregation_size;
7200
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007201 status = sme_update_config(pHddCtx->hHal, smeConfig);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307202 if (!QDF_IS_STATUS_SUCCESS(status)) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007203 hddLog(LOGE, "sme_update_config() return failure %d",
7204 status);
7205 }
7206
Anurag Chouhan600c3a02016-03-01 10:33:54 +05307207 qdf_mem_free(smeConfig);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007208 return status;
7209}
7210
7211/**
7212 * hdd_execute_global_config_command() - execute the global config command
7213 * @pHddCtx: the pointer to hdd context
7214 * @command: the command to run
7215 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307216 * Return: the QDF_STATUS return from hdd_execute_config_command
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007217 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307218QDF_STATUS hdd_execute_global_config_command(hdd_context_t *pHddCtx,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007219 char *command)
7220{
7221 return hdd_execute_config_command(g_registry_table,
7222 ARRAY_SIZE(g_registry_table),
7223 (uint8_t *) pHddCtx->config,
7224 pHddCtx, command);
7225}
7226
7227/**
7228 * hdd_cfg_get_global_config() - get the configuration table
7229 * @pHddCtx: pointer to hdd context
7230 * @pBuf: buffer to store the configuration
7231 * @buflen: size of the buffer
7232 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307233 * Return: QDF_STATUS_SUCCESS if the configuration and buffer size can carry
7234 * the content, otherwise QDF_STATUS_E_RESOURCES
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007235 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307236QDF_STATUS hdd_cfg_get_global_config(hdd_context_t *pHddCtx, char *pBuf,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007237 int buflen)
7238{
7239 return hdd_cfg_get_config(g_registry_table,
7240 ARRAY_SIZE(g_registry_table),
7241 (uint8_t *) pHddCtx->config, pHddCtx, pBuf,
7242 buflen);
7243}
7244
7245/**
7246 * hdd_is_okc_mode_enabled() - returns whether OKC mode is enabled or not
7247 * @pHddCtx: the pointer to hdd context
7248 *
7249 * Return: true if OKC is enabled, otherwise false
7250 */
7251bool hdd_is_okc_mode_enabled(hdd_context_t *pHddCtx)
7252{
7253 if (NULL == pHddCtx) {
Anurag Chouhanb2dc16f2016-02-25 11:47:37 +05307254 hddLog(QDF_TRACE_LEVEL_FATAL, "%s: pHddCtx is NULL", __func__);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007255 return -EINVAL;
7256 }
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007257 return pHddCtx->config->isOkcIniFeatureEnabled;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007258}
7259
7260/**
7261 * hdd_update_nss() - Update the number of spatial streams supported.
7262 * Ensure that nss is either 1 or 2 before calling this.
7263 *
7264 * @hdd_ctx: the pointer to hdd context
7265 * @nss: the number of spatial streams to be updated
7266 *
7267 * This function is used to modify the number of spatial streams
7268 * supported when not in connected state.
7269 *
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307270 * Return: QDF_STATUS_SUCCESS if nss is correctly updated,
7271 * otherwise QDF_STATUS_E_FAILURE would be returned
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007272 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307273QDF_STATUS hdd_update_nss(hdd_context_t *hdd_ctx, uint8_t nss)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007274{
7275 struct hdd_config *hdd_config = hdd_ctx->config;
7276 uint32_t temp = 0;
7277 uint32_t rx_supp_data_rate, tx_supp_data_rate;
7278 bool status = true;
7279 tSirMacHTCapabilityInfo *ht_cap_info;
7280 uint8_t mcs_set[SIZE_OF_SUPPORTED_MCS_SET] = {0};
7281 uint8_t mcs_set_temp[SIZE_OF_SUPPORTED_MCS_SET];
Sandeep Puligilla98917432016-06-10 13:50:28 -07007282 uint32_t val, val32;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007283 uint16_t val16;
7284 uint8_t enable2x2;
7285
7286 if ((nss == 2) && (hdd_ctx->num_rf_chains != 2)) {
7287 hddLog(LOGE, "No support for 2 spatial streams");
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307288 return QDF_STATUS_E_INVAL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007289 }
7290
7291 enable2x2 = (nss == 1) ? 0 : 1;
7292
7293 if (hdd_config->enable2x2 == enable2x2) {
7294 hddLog(LOGE, "NSS same as requested");
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307295 return QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007296 }
7297
7298 if (true == sme_is_any_session_in_connected_state(hdd_ctx->hHal)) {
7299 hddLog(LOGE, "Connected sessions present, Do not change NSS");
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307300 return QDF_STATUS_E_INVAL;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007301 }
7302
7303 hdd_config->enable2x2 = enable2x2;
7304
7305 if (!hdd_config->enable2x2) {
7306 /* 1x1 */
Kiran Kumar Lokere666bf852016-05-02 12:23:02 -07007307 rx_supp_data_rate = VHT_RX_HIGHEST_SUPPORTED_DATA_RATE_1_1;
7308 tx_supp_data_rate = VHT_TX_HIGHEST_SUPPORTED_DATA_RATE_1_1;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007309 } else {
7310 /* 2x2 */
Kiran Kumar Lokere666bf852016-05-02 12:23:02 -07007311 rx_supp_data_rate = VHT_RX_HIGHEST_SUPPORTED_DATA_RATE_2_2;
7312 tx_supp_data_rate = VHT_TX_HIGHEST_SUPPORTED_DATA_RATE_2_2;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007313 }
7314
7315 /* Update Rx Highest Long GI data Rate */
7316 if (sme_cfg_set_int(hdd_ctx->hHal,
7317 WNI_CFG_VHT_RX_HIGHEST_SUPPORTED_DATA_RATE,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307318 rx_supp_data_rate) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007319 status = false;
7320 hddLog(LOGE,
7321 "Could not pass on WNI_CFG_VHT_RX_HIGHEST_SUPPORTED_DATA_RATE to CFG");
7322 }
7323
7324 /* Update Tx Highest Long GI data Rate */
7325 if (sme_cfg_set_int(hdd_ctx->hHal,
7326 WNI_CFG_VHT_TX_HIGHEST_SUPPORTED_DATA_RATE,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307327 tx_supp_data_rate) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007328 status = false;
7329 hddLog(LOGE,
7330 "Could not pass on WNI_CFG_VHT_TX_HIGHEST_SUPPORTED_DATA_RATE to CFG");
7331 }
7332
7333 sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_HT_CAP_INFO, &temp);
7334 val16 = (uint16_t)temp;
7335 ht_cap_info = (tSirMacHTCapabilityInfo *)&val16;
Sandeep Puligilla98917432016-06-10 13:50:28 -07007336 if (!(hdd_ctx->ht_tx_stbc_supported && hdd_config->enable2x2)) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007337 ht_cap_info->txSTBC = 0;
Sandeep Puligilla98917432016-06-10 13:50:28 -07007338 } else {
7339 sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_VHT_TXSTBC, &val32);
7340 hddLog(LOG1, FL("STBC %d"), val32);
7341 ht_cap_info->txSTBC = val32;
7342 }
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007343 temp = val16;
7344 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_HT_CAP_INFO,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307345 temp) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007346 status = false;
7347 hddLog(LOGE, "Could not pass on WNI_CFG_HT_CAP_INFO to CFG");
7348 }
7349
7350 sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_VHT_BASIC_MCS_SET, &temp);
7351 temp = (temp & 0xFFFC) | hdd_config->vhtRxMCS;
7352 if (hdd_config->enable2x2)
7353 temp = (temp & 0xFFF3) | (hdd_config->vhtRxMCS2x2 << 2);
7354 else
7355 temp |= 0x000C;
7356
7357 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_BASIC_MCS_SET,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307358 temp) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007359 status = false;
7360 hddLog(LOGE,
7361 "Could not pass on WNI_CFG_VHT_BASIC_MCS_SET to CFG");
7362 }
7363
7364 sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_VHT_RX_MCS_MAP, &temp);
7365 temp = (temp & 0xFFFC) | hdd_config->vhtRxMCS;
7366 if (hdd_config->enable2x2)
7367 temp = (temp & 0xFFF3) | (hdd_config->vhtRxMCS2x2 << 2);
7368 else
7369 temp |= 0x000C;
7370
7371 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_RX_MCS_MAP,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307372 temp) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007373 status = false;
7374 hddLog(LOGE, "Could not pass on WNI_CFG_VHT_RX_MCS_MAP to CFG");
7375 }
7376
7377 sme_cfg_get_int(hdd_ctx->hHal, WNI_CFG_VHT_TX_MCS_MAP, &temp);
7378 temp = (temp & 0xFFFC) | hdd_config->vhtTxMCS;
7379 if (hdd_config->enable2x2)
7380 temp = (temp & 0xFFF3) | (hdd_config->vhtTxMCS2x2 << 2);
7381 else
7382 temp |= 0x000C;
7383
7384 if (sme_cfg_set_int(hdd_ctx->hHal, WNI_CFG_VHT_TX_MCS_MAP,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307385 temp) == QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007386 status = false;
7387 hddLog(LOGE, "Could not pass on WNI_CFG_VHT_TX_MCS_MAP to CFG");
7388 }
7389
7390#define WLAN_HDD_RX_MCS_ALL_NSTREAM_RATES 0xff
7391 val = SIZE_OF_SUPPORTED_MCS_SET;
7392 sme_cfg_get_str(hdd_ctx->hHal, WNI_CFG_SUPPORTED_MCS_SET,
7393 mcs_set_temp, &val);
7394
7395 mcs_set[0] = mcs_set_temp[0];
7396 if (hdd_config->enable2x2)
7397 for (val = 0; val < nss; val++)
7398 mcs_set[val] = WLAN_HDD_RX_MCS_ALL_NSTREAM_RATES;
7399
7400 if (sme_cfg_set_str(hdd_ctx->hHal, WNI_CFG_SUPPORTED_MCS_SET,
7401 mcs_set,
7402 SIZE_OF_SUPPORTED_MCS_SET) ==
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307403 QDF_STATUS_E_FAILURE) {
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007404 status = false;
7405 hddLog(LOGE, "Could not pass on MCS SET to CFG");
7406 }
7407#undef WLAN_HDD_RX_MCS_ALL_NSTREAM_RATES
7408
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307409 if (QDF_STATUS_SUCCESS != sme_update_nss(hdd_ctx->hHal, nss))
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007410 status = false;
7411
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05307412 return (status == false) ? QDF_STATUS_E_FAILURE : QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08007413}