1 /* 2 * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved. 3 * Copyright (c) 2022-2024 Qualcomm Innovation Center, Inc. All rights reserved. 4 * 5 * Permission to use, copy, modify, and/or distribute this software for 6 * any purpose with or without fee is hereby granted, provided that the 7 * above copyright notice and this permission notice appear in all 8 * copies. 9 * 10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL 11 * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED 12 * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE 13 * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL 14 * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR 15 * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER 16 * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR 17 * PERFORMANCE OF THIS SOFTWARE. 18 */ 19 /** 20 * DOC: declare UCFG APIs exposed by the mlme component 21 */ 22 23 #ifndef _WLAN_MLME_UCFG_API_H_ 24 #define _WLAN_MLME_UCFG_API_H_ 25 26 #include <wlan_mlme_public_struct.h> 27 #include <wlan_objmgr_psoc_obj.h> 28 #include <wlan_objmgr_global_obj.h> 29 #include <wlan_cmn.h> 30 #include <wlan_mlme_api.h> 31 #include <wlan_mlme_main.h> 32 #include "wma_tgt_cfg.h" 33 #include "wlan_mlme_vdev_mgr_interface.h" 34 35 /** 36 * ucfg_mlme_init() - initialize mlme_ctx context. 37 * 38 * This function initializes the mlme context. 39 * 40 * Return: QDF_STATUS_SUCCESS - in case of success else return error 41 */ 42 QDF_STATUS ucfg_mlme_init(void); 43 44 /** 45 * ucfg_mlme_deinit() - De initialize mlme_ctx context. 46 * 47 * This function De initializes mlme context. 48 * 49 * Return: QDF_STATUS_SUCCESS - in case of success else return error 50 */ 51 QDF_STATUS ucfg_mlme_deinit(void); 52 53 /** 54 * ucfg_mlme_psoc_open() - MLME component Open 55 * @psoc: pointer to psoc object 56 * 57 * Open the MLME component and initialize the MLME structure 58 * 59 * Return: QDF Status 60 */ 61 QDF_STATUS ucfg_mlme_psoc_open(struct wlan_objmgr_psoc *psoc); 62 63 /** 64 * ucfg_mlme_psoc_close() - MLME component close 65 * @psoc: pointer to psoc object 66 * 67 * Close the MLME component and clear the MLME structures 68 * 69 * Return: None 70 */ 71 void ucfg_mlme_psoc_close(struct wlan_objmgr_psoc *psoc); 72 73 /** 74 * ucfg_mlme_pdev_open() - MLME component pdev Open 75 * @pdev: pointer to pdev object 76 * 77 * Open the MLME component and initialize the MLME pdev structure 78 * 79 * Return: QDF Status 80 */ 81 QDF_STATUS ucfg_mlme_pdev_open(struct wlan_objmgr_pdev *pdev); 82 83 /** 84 * ucfg_mlme_set_ml_link_control_mode() - set ml_link_control_mode 85 * @psoc: pointer to psoc object 86 * @vdev_id: vdev id 87 * @value: value to set 88 * 89 * API get call when host receives vendor command 90 * QCA_NL80211_VENDOR_SUBCMD_MLO_LINK_STATE to configure link control mode. 91 * 92 * Return: none 93 */ 94 void ucfg_mlme_set_ml_link_control_mode(struct wlan_objmgr_psoc *psoc, 95 uint8_t vdev_id, uint8_t value); 96 97 /** 98 * ucfg_mlme_set_bt_profile_con() - set Bluetooth connection profile 99 * @psoc: Pointer to psoc object 100 * @bt_profile_con: Bluetooth connection profile indicator 101 * 102 * Return: None 103 */ 104 void ucfg_mlme_set_bt_profile_con(struct wlan_objmgr_psoc *psoc, 105 bool bt_profile_con); 106 /** 107 * ucfg_mlme_get_ml_link_control_mode() - get ml_link_control_mode 108 * @psoc: pointer to psoc object 109 * @vdev_id: vdev id 110 * 111 * Return: value of ml_link_control_mode in success 112 */ 113 uint8_t ucfg_mlme_get_ml_link_control_mode(struct wlan_objmgr_psoc *psoc, 114 uint8_t vdev_id); 115 116 /** 117 * ucfg_mlme_pdev_close() - MLME component pdev close 118 * @pdev: pointer to pdev object 119 * 120 * close the MLME pdev information 121 * 122 * Return: QDF Status 123 */ 124 QDF_STATUS ucfg_mlme_pdev_close(struct wlan_objmgr_pdev *pdev); 125 126 /** 127 * ucfg_mlme_global_init() - initialize global mlme ops and structure 128 * 129 * Return: QDF Status 130 */ 131 QDF_STATUS ucfg_mlme_global_init(void); 132 /** 133 * ucfg_mlme_global_deinit() - deinitialize global mlme ops and structure 134 * 135 * Return: QDF Status 136 */ 137 QDF_STATUS ucfg_mlme_global_deinit(void); 138 139 /** 140 * ucfg_mlme_cfg_chan_to_freq() - convert channel numbers to frequencies 141 * @pdev: pointer to pdev object 142 * 143 * convert the channels numbers received as part of cfg items to 144 * frequencies. 145 * 146 * Return: None 147 */ 148 void ucfg_mlme_cfg_chan_to_freq(struct wlan_objmgr_pdev *pdev); 149 150 /** 151 * ucfg_mlme_get_power_usage() - Get the power usage info 152 * @psoc: pointer to psoc object 153 * 154 * Return: pointer to character array of power usage 155 */ 156 static inline ucfg_mlme_get_power_usage(struct wlan_objmgr_psoc * psoc)157 char *ucfg_mlme_get_power_usage(struct wlan_objmgr_psoc *psoc) 158 { 159 return wlan_mlme_get_power_usage(psoc); 160 } 161 162 /** 163 * ucfg_get_tx_power() - Get the max tx power in particular band 164 * @psoc: pointer to psoc object 165 * @band: 2ghz/5ghz band 166 * 167 * Return: value of tx power in the respective band 168 */ 169 static inline ucfg_get_tx_power(struct wlan_objmgr_psoc * psoc,uint8_t band)170 uint8_t ucfg_get_tx_power(struct wlan_objmgr_psoc *psoc, uint8_t band) 171 { 172 return wlan_mlme_get_tx_power(psoc, band); 173 } 174 175 /** 176 * ucfg_mlme_get_phy_max_freq_range() - Get phy supported max channel 177 * frequency range 178 * @psoc: psoc for country information 179 * @low_2ghz_chan: 2.4 GHz low channel frequency 180 * @high_2ghz_chan: 2.4 GHz high channel frequency 181 * @low_5ghz_chan: 5 GHz low channel frequency 182 * @high_5ghz_chan: 5 GHz high channel frequency 183 * 184 * Return: QDF status 185 */ 186 static inline ucfg_mlme_get_phy_max_freq_range(struct wlan_objmgr_psoc * psoc,uint32_t * low_2ghz_chan,uint32_t * high_2ghz_chan,uint32_t * low_5ghz_chan,uint32_t * high_5ghz_chan)187 QDF_STATUS ucfg_mlme_get_phy_max_freq_range(struct wlan_objmgr_psoc *psoc, 188 uint32_t *low_2ghz_chan, 189 uint32_t *high_2ghz_chan, 190 uint32_t *low_5ghz_chan, 191 uint32_t *high_5ghz_chan) 192 { 193 return wlan_mlme_get_phy_max_freq_range(psoc, 194 low_2ghz_chan, 195 high_2ghz_chan, 196 low_5ghz_chan, 197 high_5ghz_chan); 198 } 199 200 /** 201 * ucfg_mlme_get_ht_cap_info() - Get the HT cap info config 202 * @psoc: pointer to psoc object 203 * @ht_cap_info: pointer to the value which will be filled for the caller 204 * 205 * Inline UCFG API to be used by HDD/OSIF callers 206 * 207 * Return: QDF Status 208 */ 209 static inline ucfg_mlme_get_ht_cap_info(struct wlan_objmgr_psoc * psoc,struct mlme_ht_capabilities_info * ht_cap_info)210 QDF_STATUS ucfg_mlme_get_ht_cap_info(struct wlan_objmgr_psoc *psoc, 211 struct mlme_ht_capabilities_info 212 *ht_cap_info) 213 { 214 return wlan_mlme_get_ht_cap_info(psoc, ht_cap_info); 215 } 216 217 /** 218 * ucfg_mlme_set_ht_cap_info() - Set the HT cap info config 219 * @psoc: pointer to psoc object 220 * @ht_cap_info: Value that needs to be set from the caller 221 * 222 * Inline UCFG API to be used by HDD/OSIF callers 223 * 224 * Return: QDF Status 225 */ 226 static inline ucfg_mlme_set_ht_cap_info(struct wlan_objmgr_psoc * psoc,struct mlme_ht_capabilities_info ht_cap_info)227 QDF_STATUS ucfg_mlme_set_ht_cap_info(struct wlan_objmgr_psoc *psoc, 228 struct mlme_ht_capabilities_info 229 ht_cap_info) 230 { 231 return wlan_mlme_set_ht_cap_info(psoc, ht_cap_info); 232 } 233 234 /** 235 * ucfg_mlme_get_max_amsdu_num() - get the max amsdu num 236 * @psoc: pointer to psoc object 237 * @value: pointer to the value where the max_amsdu num is to be filled 238 * 239 * Return: QDF_STATUS 240 */ 241 static inline ucfg_mlme_get_max_amsdu_num(struct wlan_objmgr_psoc * psoc,uint8_t * value)242 QDF_STATUS ucfg_mlme_get_max_amsdu_num(struct wlan_objmgr_psoc *psoc, 243 uint8_t *value) 244 { 245 return wlan_mlme_get_max_amsdu_num(psoc, value); 246 } 247 248 /** 249 * ucfg_mlme_set_max_amsdu_num() - set the max amsdu num 250 * @psoc: pointer to psoc object 251 * @value: value to be set for max_amsdu_num 252 * 253 * Return: QDF_STATUS 254 */ 255 static inline ucfg_mlme_set_max_amsdu_num(struct wlan_objmgr_psoc * psoc,uint8_t value)256 QDF_STATUS ucfg_mlme_set_max_amsdu_num(struct wlan_objmgr_psoc *psoc, 257 uint8_t value) 258 { 259 return wlan_mlme_set_max_amsdu_num(psoc, value); 260 } 261 262 /** 263 * ucfg_mlme_get_ht_mpdu_density() - get the ht mpdu density 264 * @psoc: pointer to psoc object 265 * @value: pointer to the value where the ht mpdu density is to be filled 266 * 267 * Return: QDF_STATUS 268 */ 269 static inline ucfg_mlme_get_ht_mpdu_density(struct wlan_objmgr_psoc * psoc,uint8_t * value)270 QDF_STATUS ucfg_mlme_get_ht_mpdu_density(struct wlan_objmgr_psoc *psoc, 271 uint8_t *value) 272 { 273 return wlan_mlme_get_ht_mpdu_density(psoc, value); 274 } 275 276 /** 277 * ucfg_mlme_set_ht_mpdu_density() - set the ht mpdu density 278 * @psoc: pointer to psoc object 279 * @value: value to be set for ht mpdu density 280 * 281 * Return: QDF_STATUS 282 */ 283 static inline ucfg_mlme_set_ht_mpdu_density(struct wlan_objmgr_psoc * psoc,uint8_t value)284 QDF_STATUS ucfg_mlme_set_ht_mpdu_density(struct wlan_objmgr_psoc *psoc, 285 uint8_t value) 286 { 287 return wlan_mlme_set_ht_mpdu_density(psoc, value); 288 } 289 290 /** 291 * ucfg_mlme_get_band_capability() - Get the Band capability config 292 * @psoc: pointer to psoc object 293 * @band_capability: Pointer to the variable from caller 294 * 295 * Return: QDF Status 296 */ 297 static inline ucfg_mlme_get_band_capability(struct wlan_objmgr_psoc * psoc,uint32_t * band_capability)298 QDF_STATUS ucfg_mlme_get_band_capability(struct wlan_objmgr_psoc *psoc, 299 uint32_t *band_capability) 300 { 301 return wlan_mlme_get_band_capability(psoc, band_capability); 302 } 303 304 /** 305 * ucfg_mlme_peer_config_vlan() - Send VLAN id to FW for 306 * RX packet 307 * @vdev: vdev pointer 308 * @macaddr: Peer mac address 309 * 310 * Return: QDF_STATUS 311 */ 312 static inline QDF_STATUS ucfg_mlme_peer_config_vlan(struct wlan_objmgr_vdev * vdev,uint8_t * macaddr)313 ucfg_mlme_peer_config_vlan(struct wlan_objmgr_vdev *vdev, 314 uint8_t *macaddr) 315 { 316 return wlan_mlme_peer_config_vlan(vdev, macaddr); 317 } 318 319 /** 320 * ucfg_mlme_get_tdls_prohibited() - get if TDLS prohibited is advertised by 321 * the connected AP. 322 * @vdev: vdev pointer 323 * 324 * Return: bool 325 */ 326 static inline ucfg_mlme_get_tdls_prohibited(struct wlan_objmgr_vdev * vdev)327 bool ucfg_mlme_get_tdls_prohibited(struct wlan_objmgr_vdev *vdev) 328 { 329 return mlme_get_tdls_prohibited(vdev); 330 } 331 332 /** 333 * ucfg_mlme_get_tdls_chan_switch_prohibited() - get tdls chan switch prohibited 334 * @vdev: vdev pointer 335 * 336 * Return: bool 337 */ 338 static inline ucfg_mlme_get_tdls_chan_switch_prohibited(struct wlan_objmgr_vdev * vdev)339 bool ucfg_mlme_get_tdls_chan_switch_prohibited(struct wlan_objmgr_vdev *vdev) 340 { 341 return mlme_get_tdls_chan_switch_prohibited(vdev); 342 } 343 #ifdef MULTI_CLIENT_LL_SUPPORT 344 /** 345 * ucfg_mlme_get_wlm_multi_client_ll_caps() - Get multi client latency level 346 * capability of FW 347 * @psoc: pointer to psoc object 348 * 349 * Return: true if multi client feature supported 350 */ 351 bool ucfg_mlme_get_wlm_multi_client_ll_caps(struct wlan_objmgr_psoc *psoc); 352 353 /** 354 * ucfg_mlme_cfg_get_multi_client_ll_ini_support() - Get multi client latency 355 * level ini support value 356 * @psoc: pointer to psoc object 357 * @multi_client_ll_support: parameter that needs to be filled 358 * 359 * Return: QDF Status 360 */ 361 QDF_STATUS 362 ucfg_mlme_cfg_get_multi_client_ll_ini_support(struct wlan_objmgr_psoc *psoc, 363 bool *multi_client_ll_support); 364 #else 365 static inline ucfg_mlme_get_wlm_multi_client_ll_caps(struct wlan_objmgr_psoc * psoc)366 bool ucfg_mlme_get_wlm_multi_client_ll_caps(struct wlan_objmgr_psoc *psoc) 367 { 368 return false; 369 } 370 371 static inline QDF_STATUS ucfg_mlme_cfg_get_multi_client_ll_ini_support(struct wlan_objmgr_psoc * psoc,bool * multi_client_ll_support)372 ucfg_mlme_cfg_get_multi_client_ll_ini_support(struct wlan_objmgr_psoc *psoc, 373 bool *multi_client_ll_support) 374 { 375 return QDF_STATUS_E_FAILURE; 376 } 377 #endif 378 379 /** 380 * ucfg_mlme_set_band_capability() - Set the Band capability config 381 * @psoc: pointer to psoc object 382 * @band_capability: Value to be set from the caller 383 * 384 * Return: QDF Status 385 */ 386 static inline ucfg_mlme_set_band_capability(struct wlan_objmgr_psoc * psoc,uint32_t band_capability)387 QDF_STATUS ucfg_mlme_set_band_capability(struct wlan_objmgr_psoc *psoc, 388 uint32_t band_capability) 389 { 390 return wlan_mlme_set_band_capability(psoc, band_capability); 391 } 392 393 #ifdef WLAN_VENDOR_HANDOFF_CONTROL 394 /** 395 * ucfg_mlme_get_vendor_handoff_control_caps() - Get vendor handoff control 396 * capability of FW 397 * @psoc: pointer to psoc object 398 * 399 * Return: true if vendor handoff feature supported 400 */ 401 bool ucfg_mlme_get_vendor_handoff_control_caps(struct wlan_objmgr_psoc *psoc); 402 #else 403 static inline ucfg_mlme_get_vendor_handoff_control_caps(struct wlan_objmgr_psoc * psoc)404 bool ucfg_mlme_get_vendor_handoff_control_caps(struct wlan_objmgr_psoc *psoc) 405 { 406 return false; 407 } 408 #endif 409 410 /** 411 * ucfg_mlme_set_dual_sta_policy() - Configures the Concurrent STA policy 412 * value 413 * @psoc: pointer to psoc object 414 * @dual_sta_config: Concurrent STA policy configuration value 415 * 416 * Return: QDF Status 417 */ 418 static inline ucfg_mlme_set_dual_sta_policy(struct wlan_objmgr_psoc * psoc,uint8_t dual_sta_config)419 QDF_STATUS ucfg_mlme_set_dual_sta_policy(struct wlan_objmgr_psoc *psoc, 420 uint8_t dual_sta_config) 421 { 422 return wlan_mlme_set_dual_sta_policy(psoc, dual_sta_config); 423 } 424 425 /** 426 * ucfg_mlme_get_dual_sta_policy() - Get the Concurrent STA policy value 427 * @psoc: pointer to psoc object 428 * @dual_sta_config: Pointer to the variable from caller 429 * 430 * Return: QDF Status 431 */ 432 static inline ucfg_mlme_get_dual_sta_policy(struct wlan_objmgr_psoc * psoc,uint8_t * dual_sta_config)433 QDF_STATUS ucfg_mlme_get_dual_sta_policy(struct wlan_objmgr_psoc *psoc, 434 uint8_t *dual_sta_config) 435 { 436 return wlan_mlme_get_dual_sta_policy(psoc, dual_sta_config); 437 } 438 439 /** 440 * ucfg_mlme_set_ap_policy() - Configures the AP policy value 441 * @vdev: pointer to vdev object 442 * @ap_cfg_policy: AP policy configuration value 443 * 444 * Return: QDF Status 445 */ 446 static inline ucfg_mlme_set_ap_policy(struct wlan_objmgr_vdev * vdev,enum host_concurrent_ap_policy ap_cfg_policy)447 QDF_STATUS ucfg_mlme_set_ap_policy(struct wlan_objmgr_vdev *vdev, 448 enum host_concurrent_ap_policy ap_cfg_policy) 449 { 450 return wlan_mlme_set_ap_policy(vdev, ap_cfg_policy); 451 } 452 453 /** 454 * ucfg_mlme_get_ap_policy() - Get the AP policy value 455 * @vdev: pointer to vdev object 456 * 457 * Return: enum host_concurrent_ap_policy 458 */ 459 static inline enum host_concurrent_ap_policy ucfg_mlme_get_ap_policy(struct wlan_objmgr_vdev * vdev)460 ucfg_mlme_get_ap_policy(struct wlan_objmgr_vdev *vdev) 461 { 462 return wlan_mlme_get_ap_policy(vdev); 463 } 464 465 /** 466 * ucfg_mlme_get_prevent_link_down() - Get the prevent link down config 467 * @psoc: pointer to psoc object 468 * @prevent_link_down: Pointer to the variable from caller 469 * 470 * Return: QDF Status 471 */ 472 static inline ucfg_mlme_get_prevent_link_down(struct wlan_objmgr_psoc * psoc,bool * prevent_link_down)473 QDF_STATUS ucfg_mlme_get_prevent_link_down(struct wlan_objmgr_psoc *psoc, 474 bool *prevent_link_down) 475 { 476 return wlan_mlme_get_prevent_link_down(psoc, prevent_link_down); 477 } 478 479 /** 480 * ucfg_mlme_get_select_5ghz_margin() - Get the select 5Ghz margin config 481 * @psoc: pointer to psoc object 482 * @select_5ghz_margin: Pointer to the variable from caller 483 * 484 * Return: QDF Status 485 */ 486 static inline ucfg_mlme_get_select_5ghz_margin(struct wlan_objmgr_psoc * psoc,uint8_t * select_5ghz_margin)487 QDF_STATUS ucfg_mlme_get_select_5ghz_margin(struct wlan_objmgr_psoc *psoc, 488 uint8_t *select_5ghz_margin) 489 { 490 return wlan_mlme_get_select_5ghz_margin(psoc, select_5ghz_margin); 491 } 492 493 /** 494 * ucfg_mlme_get_rtt_mac_randomization() - Get the RTT MAC randomization config 495 * @psoc: pointer to psoc object 496 * @rtt_mac_randomization: Pointer to the variable from caller 497 * 498 * Return: QDF Status 499 */ 500 static inline ucfg_mlme_get_rtt_mac_randomization(struct wlan_objmgr_psoc * psoc,bool * rtt_mac_randomization)501 QDF_STATUS ucfg_mlme_get_rtt_mac_randomization(struct wlan_objmgr_psoc *psoc, 502 bool *rtt_mac_randomization) 503 { 504 return wlan_mlme_get_rtt_mac_randomization(psoc, rtt_mac_randomization); 505 } 506 507 /** 508 * ucfg_mlme_get_crash_inject() - Get the crash inject config 509 * @psoc: pointer to psoc object 510 * @crash_inject: Pointer to the variable from caller 511 * 512 * Return: QDF Status 513 */ 514 static inline ucfg_mlme_get_crash_inject(struct wlan_objmgr_psoc * psoc,bool * crash_inject)515 QDF_STATUS ucfg_mlme_get_crash_inject(struct wlan_objmgr_psoc *psoc, 516 bool *crash_inject) 517 { 518 return wlan_mlme_get_crash_inject(psoc, crash_inject); 519 } 520 521 /** 522 * ucfg_mlme_get_lpass_support() - Get the LPASS Support config 523 * @psoc: pointer to psoc object 524 * @lpass_support: Pointer to the variable from caller 525 * 526 * Return: QDF Status 527 */ 528 static inline ucfg_mlme_get_lpass_support(struct wlan_objmgr_psoc * psoc,bool * lpass_support)529 QDF_STATUS ucfg_mlme_get_lpass_support(struct wlan_objmgr_psoc *psoc, 530 bool *lpass_support) 531 { 532 return wlan_mlme_get_lpass_support(psoc, lpass_support); 533 } 534 535 /** 536 * ucfg_mlme_get_wls_6ghz_cap() - Get the WiFi Location Service(WLS) 537 * 6ghz capability 538 * @psoc: pointer to psoc object 539 * @wls_6ghz_capable: Pointer to the variable from caller 540 * 541 * Return: void 542 */ 543 static inline ucfg_mlme_get_wls_6ghz_cap(struct wlan_objmgr_psoc * psoc,bool * wls_6ghz_capable)544 void ucfg_mlme_get_wls_6ghz_cap(struct wlan_objmgr_psoc *psoc, 545 bool *wls_6ghz_capable) 546 { 547 wlan_mlme_get_wls_6ghz_cap(psoc, wls_6ghz_capable); 548 } 549 550 /** 551 * ucfg_mlme_get_self_recovery() - Get the self recovery config 552 * @psoc: pointer to psoc object 553 * @self_recovery: Pointer to the variable from caller 554 * 555 * Return: QDF Status 556 */ 557 static inline ucfg_mlme_get_self_recovery(struct wlan_objmgr_psoc * psoc,bool * self_recovery)558 QDF_STATUS ucfg_mlme_get_self_recovery(struct wlan_objmgr_psoc *psoc, 559 bool *self_recovery) 560 { 561 return wlan_mlme_get_self_recovery(psoc, self_recovery); 562 } 563 564 /** 565 * ucfg_mlme_get_sub_20_chan_width() - Get the sub 20 chan width config 566 * @psoc: pointer to psoc object 567 * @sub_20_chan_width: Pointer to the variable from caller 568 * 569 * Return: QDF Status 570 */ 571 static inline ucfg_mlme_get_sub_20_chan_width(struct wlan_objmgr_psoc * psoc,uint8_t * sub_20_chan_width)572 QDF_STATUS ucfg_mlme_get_sub_20_chan_width(struct wlan_objmgr_psoc *psoc, 573 uint8_t *sub_20_chan_width) 574 { 575 return wlan_mlme_get_sub_20_chan_width(psoc, sub_20_chan_width); 576 } 577 578 /** 579 * ucfg_mlme_get_fw_timeout_crash() - Get the fw timeout crash config 580 * @psoc: pointer to psoc object 581 * @fw_timeout_crash: Pointer to the variable from caller 582 * 583 * Return: QDF Status 584 */ 585 static inline ucfg_mlme_get_fw_timeout_crash(struct wlan_objmgr_psoc * psoc,bool * fw_timeout_crash)586 QDF_STATUS ucfg_mlme_get_fw_timeout_crash(struct wlan_objmgr_psoc *psoc, 587 bool *fw_timeout_crash) 588 { 589 return wlan_mlme_get_fw_timeout_crash(psoc, fw_timeout_crash); 590 } 591 592 /** 593 * ucfg_mlme_get_ito_repeat_count() - Get the fw timeout crash config 594 * @psoc: pointer to psoc object 595 * @ito_repeat_count: Pointer to the variable from caller 596 * 597 * Return: QDF Status 598 */ 599 static inline ucfg_mlme_get_ito_repeat_count(struct wlan_objmgr_psoc * psoc,uint8_t * ito_repeat_count)600 QDF_STATUS ucfg_mlme_get_ito_repeat_count(struct wlan_objmgr_psoc *psoc, 601 uint8_t *ito_repeat_count) 602 { 603 return wlan_mlme_get_ito_repeat_count(psoc, ito_repeat_count); 604 } 605 606 /** 607 * ucfg_mlme_get_acs_with_more_param() - Get the flag for acs with 608 * more param 609 * @psoc: pointer to psoc object 610 * @value: Value that needs to be set from the caller 611 * 612 * Inline UCFG API to be used by HDD/OSIF callers 613 * 614 * Return: QDF Status 615 */ 616 static inline ucfg_mlme_get_acs_with_more_param(struct wlan_objmgr_psoc * psoc,bool * value)617 QDF_STATUS ucfg_mlme_get_acs_with_more_param(struct wlan_objmgr_psoc *psoc, 618 bool *value) 619 { 620 return wlan_mlme_get_acs_with_more_param(psoc, value); 621 } 622 623 /** 624 * ucfg_mlme_get_auto_channel_weight() - Get the auto channel select weight 625 * @psoc: pointer to psoc object 626 * @value: Value that needs to be set from the caller 627 * 628 * Inline UCFG API to be used by HDD/OSIF callers 629 * 630 * Return: QDF Status 631 */ 632 static inline ucfg_mlme_get_auto_channel_weight(struct wlan_objmgr_psoc * psoc,uint32_t * value)633 QDF_STATUS ucfg_mlme_get_auto_channel_weight(struct wlan_objmgr_psoc *psoc, 634 uint32_t *value) 635 { 636 return wlan_mlme_get_auto_channel_weight(psoc, value); 637 } 638 639 /** 640 * ucfg_mlme_get_vendor_acs_support() - Get the flag for 641 * vendor acs support 642 * @psoc: pointer to psoc object 643 * @value: Value that needs to be set from the caller 644 * 645 * Inline UCFG API to be used by HDD/OSIF callers 646 * 647 * Return: QDF Status 648 */ 649 static inline ucfg_mlme_get_vendor_acs_support(struct wlan_objmgr_psoc * psoc,bool * value)650 QDF_STATUS ucfg_mlme_get_vendor_acs_support(struct wlan_objmgr_psoc *psoc, 651 bool *value) 652 { 653 return wlan_mlme_get_vendor_acs_support(psoc, value); 654 } 655 656 /** 657 * ucfg_mlme_get_external_acs_policy() - Get flag for external control 658 * acs policy 659 * @psoc: pointer to psoc object 660 * @value: Value that needs to be set from the caller 661 * 662 * Inline UCFG API to be used by HDD/OSIF callers 663 * 664 * Return: QDF Status 665 */ 666 static inline QDF_STATUS ucfg_mlme_get_external_acs_policy(struct wlan_objmgr_psoc * psoc,bool * value)667 ucfg_mlme_get_external_acs_policy(struct wlan_objmgr_psoc *psoc, 668 bool *value) 669 { 670 return wlan_mlme_get_external_acs_policy(psoc, value); 671 } 672 673 /** 674 * ucfg_mlme_get_acs_support_for_dfs_ltecoex() - Is DFS LTE CoEx ACS supported 675 * @psoc: pointer to psoc object 676 * @value: Value that needs to be set from the caller 677 * 678 * Inline UCFG API to be used by HDD/OSIF callers 679 * 680 * Return: QDF Status 681 */ 682 static inline 683 QDF_STATUS ucfg_mlme_get_acs_support_for_dfs_ltecoex(struct wlan_objmgr_psoc * psoc,bool * value)684 ucfg_mlme_get_acs_support_for_dfs_ltecoex(struct wlan_objmgr_psoc *psoc, 685 bool *value) 686 { 687 return wlan_mlme_get_acs_support_for_dfs_ltecoex(psoc, value); 688 } 689 690 /** 691 * ucfg_mlme_get_wmm_dir_ac_vo() - Get TSPEC direction for VO 692 * @psoc: pointer to psoc object 693 * @value: Value that needs to be set from the caller 694 * 695 * Inline UCFG API to be used by HDD/OSIF callers 696 * 697 * Return: QDF Status 698 */ 699 static inline QDF_STATUS ucfg_mlme_get_wmm_dir_ac_vo(struct wlan_objmgr_psoc * psoc,uint8_t * value)700 ucfg_mlme_get_wmm_dir_ac_vo(struct wlan_objmgr_psoc *psoc, 701 uint8_t *value) 702 { 703 return wlan_mlme_get_wmm_dir_ac_vo(psoc, value); 704 } 705 706 /** 707 * ucfg_mlme_get_wmm_nom_msdu_size_ac_vo() - Get normal 708 * MSDU size for VO 709 * @psoc: pointer to psoc object 710 * @value: Value that needs to be set from the caller 711 * 712 * Inline UCFG API to be used by HDD/OSIF callers 713 * 714 * Return: QDF Status 715 */ 716 static inline QDF_STATUS ucfg_mlme_get_wmm_nom_msdu_size_ac_vo(struct wlan_objmgr_psoc * psoc,uint16_t * value)717 ucfg_mlme_get_wmm_nom_msdu_size_ac_vo(struct wlan_objmgr_psoc *psoc, 718 uint16_t *value) 719 { 720 return wlan_mlme_get_wmm_nom_msdu_size_ac_vo(psoc, value); 721 } 722 723 /** 724 * ucfg_mlme_get_wmm_mean_data_rate_ac_vo() - mean data rate for VO 725 * @psoc: pointer to psoc object 726 * @value: Value that needs to be set from the caller 727 * 728 * Inline UCFG API to be used by HDD/OSIF callers 729 * 730 * Return: QDF Status 731 */ 732 static inline QDF_STATUS ucfg_mlme_get_wmm_mean_data_rate_ac_vo(struct wlan_objmgr_psoc * psoc,uint32_t * value)733 ucfg_mlme_get_wmm_mean_data_rate_ac_vo(struct wlan_objmgr_psoc *psoc, 734 uint32_t *value) 735 { 736 return wlan_mlme_get_wmm_mean_data_rate_ac_vo(psoc, value); 737 } 738 739 /** 740 * ucfg_mlme_get_wmm_min_phy_rate_ac_vo() - min PHY 741 * rate for VO 742 * @psoc: pointer to psoc object 743 * @value: Value that needs to be set from the caller 744 * 745 * Inline UCFG API to be used by HDD/OSIF callers 746 * 747 * Return: QDF Status 748 */ 749 static inline QDF_STATUS ucfg_mlme_get_wmm_min_phy_rate_ac_vo(struct wlan_objmgr_psoc * psoc,uint32_t * value)750 ucfg_mlme_get_wmm_min_phy_rate_ac_vo(struct wlan_objmgr_psoc *psoc, 751 uint32_t *value) 752 { 753 return wlan_mlme_get_wmm_min_phy_rate_ac_vo(psoc, value); 754 } 755 756 /** 757 * ucfg_mlme_get_wmm_sba_ac_vo() - surplus bandwidth 758 * allowance for VO 759 * @psoc: pointer to psoc object 760 * @value: Value that needs to be set from the caller 761 * 762 * Inline UCFG API to be used by HDD/OSIF callers 763 * 764 * Return: QDF Status 765 */ 766 static inline QDF_STATUS ucfg_mlme_get_wmm_sba_ac_vo(struct wlan_objmgr_psoc * psoc,uint16_t * value)767 ucfg_mlme_get_wmm_sba_ac_vo(struct wlan_objmgr_psoc *psoc, 768 uint16_t *value) 769 { 770 return wlan_mlme_get_wmm_sba_ac_vo(psoc, value); 771 } 772 773 /** 774 * ucfg_mlme_get_wmm_uapsd_vo_srv_intv() - Get Uapsd service 775 * interval for voice 776 * @psoc: pointer to psoc object 777 * @value: pointer to the value which will be filled for the caller 778 * 779 * Inline UCFG API to be used by HDD/OSIF callers 780 * 781 * Return: QDF Status 782 */ 783 static inline QDF_STATUS ucfg_mlme_get_wmm_uapsd_vo_srv_intv(struct wlan_objmgr_psoc * psoc,uint32_t * value)784 ucfg_mlme_get_wmm_uapsd_vo_srv_intv(struct wlan_objmgr_psoc *psoc, 785 uint32_t *value) 786 { 787 return wlan_mlme_get_wmm_uapsd_vo_srv_intv(psoc, value); 788 } 789 790 /** 791 * ucfg_mlme_get_wmm_uapsd_vo_sus_intv() - Get Uapsd suspension 792 * interval for voice 793 * @psoc: pointer to psoc object 794 * @value: Value that needs to be set from the caller 795 * 796 * Inline UCFG API to be used by HDD/OSIF callers 797 * 798 * Return: QDF Status 799 */ 800 static inline QDF_STATUS ucfg_mlme_get_wmm_uapsd_vo_sus_intv(struct wlan_objmgr_psoc * psoc,uint32_t * value)801 ucfg_mlme_get_wmm_uapsd_vo_sus_intv(struct wlan_objmgr_psoc *psoc, 802 uint32_t *value) 803 { 804 return wlan_mlme_get_wmm_uapsd_vo_sus_intv(psoc, value); 805 } 806 807 /** 808 * ucfg_mlme_get_sap_inactivity_override() - Check if sap max inactivity 809 * override flag is set. 810 * @psoc: pointer to psoc object 811 * @value: Value that needs to be set from the caller 812 * 813 * Inline UCFG API to be used by HDD/OSIF callers to call 814 * the mlme function wlan_mlme_get_sap_inactivity_override 815 * 816 * Return: QDF Status 817 */ 818 static inline ucfg_mlme_get_sap_inactivity_override(struct wlan_objmgr_psoc * psoc,bool * value)819 void ucfg_mlme_get_sap_inactivity_override(struct wlan_objmgr_psoc *psoc, 820 bool *value) 821 { 822 wlan_mlme_get_sap_inactivity_override(psoc, value); 823 } 824 825 /** 826 * ucfg_mlme_get_tx_chainmask_1ss() - Get the tx_chainmask_1ss value 827 * 828 * @psoc: pointer to psoc object 829 * @value: Value that needs to be set from the caller 830 * 831 * Return: QDF_STATUS_FAILURE or QDF_STATUS_SUCCESS 832 */ 833 static inline ucfg_mlme_get_tx_chainmask_1ss(struct wlan_objmgr_psoc * psoc,uint8_t * value)834 QDF_STATUS ucfg_mlme_get_tx_chainmask_1ss(struct wlan_objmgr_psoc *psoc, 835 uint8_t *value) 836 { 837 return wlan_mlme_get_tx_chainmask_1ss(psoc, value); 838 } 839 840 /** 841 * ucfg_mlme_get_num_11b_tx_chains() - Get the number of 11b only tx chains 842 * 843 * @psoc: pointer to psoc object 844 * @value: Value that needs to be set from the caller 845 * 846 * Return: QDF_STATUS_FAILURE or QDF_STATUS_SUCCESS 847 */ 848 static inline ucfg_mlme_get_num_11b_tx_chains(struct wlan_objmgr_psoc * psoc,uint16_t * value)849 QDF_STATUS ucfg_mlme_get_num_11b_tx_chains(struct wlan_objmgr_psoc *psoc, 850 uint16_t *value) 851 { 852 return wlan_mlme_get_num_11b_tx_chains(psoc, value); 853 } 854 855 /** 856 * ucfg_mlme_get_num_11ag_tx_chains() - get the total number of 11a/g tx chains 857 * 858 * @psoc: pointer to psoc object 859 * @value: Value that needs to be set from the caller 860 * 861 * Return: QDF_STATUS_FAILURE or QDF_STATUS_SUCCESS 862 */ 863 static inline ucfg_mlme_get_num_11ag_tx_chains(struct wlan_objmgr_psoc * psoc,uint16_t * value)864 QDF_STATUS ucfg_mlme_get_num_11ag_tx_chains(struct wlan_objmgr_psoc *psoc, 865 uint16_t *value) 866 { 867 return wlan_mlme_get_num_11ag_tx_chains(psoc, value); 868 } 869 870 /** 871 * ucfg_mlme_get_bt_chain_separation_flag() - bt chain separation enable/disable 872 * @psoc: pointer to psoc object 873 * @value: Value that needs to be got for the caller 874 * 875 * Return: QDF_STATUS_FAILURE or QDF_STATUS_SUCCESS 876 */ 877 static inline ucfg_mlme_get_bt_chain_separation_flag(struct wlan_objmgr_psoc * psoc,bool * value)878 QDF_STATUS ucfg_mlme_get_bt_chain_separation_flag(struct wlan_objmgr_psoc *psoc, 879 bool *value) 880 { 881 return wlan_mlme_get_bt_chain_separation_flag(psoc, value); 882 } 883 884 /** 885 * ucfg_mlme_configure_chain_mask() - configure chainmask parameters 886 * 887 * @psoc: pointer to psoc object 888 * @session_id: vdev_id 889 * 890 * Return: QDF_STATUS_FAILURE or QDF_STATUS_SUCCESS 891 */ 892 static inline ucfg_mlme_configure_chain_mask(struct wlan_objmgr_psoc * psoc,uint8_t session_id)893 QDF_STATUS ucfg_mlme_configure_chain_mask(struct wlan_objmgr_psoc *psoc, 894 uint8_t session_id) 895 { 896 return wlan_mlme_configure_chain_mask(psoc, session_id); 897 } 898 899 /** 900 * ucfg_mlme_is_chain_mask_supported() - check if configure chainmask can 901 * be supported 902 * @psoc: pointer to psoc object 903 * 904 * Return: true if supported else false 905 */ 906 static inline ucfg_mlme_is_chain_mask_supported(struct wlan_objmgr_psoc * psoc)907 bool ucfg_mlme_is_chain_mask_supported(struct wlan_objmgr_psoc *psoc) 908 { 909 return wlan_mlme_is_chain_mask_supported(psoc); 910 } 911 912 /* 913 * ucfg_mlme_get_sta_keep_alive_period() - Get the sta keep alive period 914 * @psoc: pointer to psoc object 915 * @val: Pointer to the value which will be filled for the caller 916 * 917 * Return: QDF Status 918 */ 919 QDF_STATUS 920 ucfg_mlme_get_sta_keep_alive_period(struct wlan_objmgr_psoc *psoc, 921 uint32_t *val); 922 923 /* 924 * ucfg_mlme_get_dfs_master_capability() - Get the dfs master capability 925 * @psoc: pointer to psoc object 926 * @val: Pointer to the value which will be filled for the caller 927 * 928 * Return: QDF Status 929 */ 930 QDF_STATUS 931 ucfg_mlme_get_dfs_master_capability(struct wlan_objmgr_psoc *psoc, 932 bool *val); 933 934 /* 935 * ucfg_mlme_get_dfs_disable_channel_switch() - Get the dfs channel switch 936 * @psoc: pointer to psoc object 937 * @dfs_disable_channel_switch: Pointer to the value which will be filled 938 * 939 * Return: QDF Status 940 */ 941 QDF_STATUS 942 ucfg_mlme_get_dfs_disable_channel_switch(struct wlan_objmgr_psoc *psoc, 943 bool *dfs_disable_channel_switch); 944 945 /* 946 * ucfg_mlme_set_dfs_disable_channel_switch() - Set the dfs channel switch 947 * @psoc: pointer to psoc object 948 * @dfs_disable_channel_switch: Value that needs to be set. 949 * 950 * Return: QDF Status 951 */ 952 QDF_STATUS 953 ucfg_mlme_set_dfs_disable_channel_switch(struct wlan_objmgr_psoc *psoc, 954 bool dfs_disable_channel_switch); 955 /* 956 * ucfg_mlme_get_dfs_ignore_cac() - GSet the dfs ignore cac 957 * @psoc: pointer to psoc object 958 * @dfs_ignore_cac: Pointer to the value which will be filled for the caller 959 * 960 * Return: QDF Status 961 */ 962 QDF_STATUS 963 ucfg_mlme_get_dfs_ignore_cac(struct wlan_objmgr_psoc *psoc, 964 bool *dfs_ignore_cac); 965 966 /* 967 * ucfg_mlme_set_dfs_ignore_cac() - Set the dfs ignore cac 968 * @psoc: pointer to psoc object 969 * @dfs_ignore_cac: Value that needs to be set. 970 * 971 * Return: QDF Status 972 */ 973 QDF_STATUS 974 ucfg_mlme_set_dfs_ignore_cac(struct wlan_objmgr_psoc *psoc, 975 bool dfs_ignore_cac); 976 977 /* 978 * ucfg_mlme_get_sap_tx_leakage_threshold() - Get sap tx leakage threshold 979 * @psoc: pointer to psoc object 980 * @sap_tx_leakage_threshold: Pointer to the value which will be filled 981 * 982 * Return: QDF Status 983 */ 984 QDF_STATUS 985 ucfg_mlme_get_sap_tx_leakage_threshold(struct wlan_objmgr_psoc *psoc, 986 uint32_t *sap_tx_leakage_threshold); 987 988 /* 989 * ucfg_mlme_set_sap_tx_leakage_threshold() - Set sap tx leakage threshold 990 * @psoc: pointer to psoc object 991 * @sap_tx_leakage_threshold: Value that needs to be set. 992 * 993 * Return: QDF Status 994 */ 995 QDF_STATUS 996 ucfg_mlme_set_sap_tx_leakage_threshold(struct wlan_objmgr_psoc *psoc, 997 uint32_t sap_tx_leakage_threshold); 998 999 /* 1000 * ucfg_mlme_get_dfs_pri_multiplier() - Get dfs pri multiplier 1001 * @psoc: pointer to psoc object 1002 * @dfs_pri_multiplier: Pointer to the value which will be filled 1003 * 1004 * Return: QDF Status 1005 */ 1006 QDF_STATUS 1007 ucfg_mlme_get_dfs_pri_multiplier(struct wlan_objmgr_psoc *psoc, 1008 uint32_t *dfs_pri_multiplier); 1009 1010 /* 1011 * ucfg_mlme_set_dfs_pri_multiplier() - Set dfs pri multiplier 1012 * @psoc: pointer to psoc object 1013 * @dfs_pri_multiplier: Value that needs to be set. 1014 * 1015 * Return: QDF Status 1016 */ 1017 QDF_STATUS 1018 ucfg_mlme_set_dfs_pri_multiplier(struct wlan_objmgr_psoc *psoc, 1019 uint32_t dfs_pri_multiplier); 1020 1021 /* 1022 * ucfg_mlme_get_dfs_filter_offload() - Get the dfs filter offload 1023 * @psoc: pointer to psoc object 1024 * @dfs_filter_offload: Pointer to the value which will be filled 1025 * 1026 * Return: QDF Status 1027 */ 1028 QDF_STATUS 1029 ucfg_mlme_get_dfs_filter_offload(struct wlan_objmgr_psoc *psoc, 1030 bool *dfs_filter_offload); 1031 1032 /* 1033 * ucfg_mlme_set_dfs_filter_offload() - Set the dfs filter offload 1034 * @psoc: pointer to psoc object 1035 * @dfs_filter_offload: Value that needs to be set. 1036 * 1037 * Return: QDF Status 1038 */ 1039 QDF_STATUS 1040 ucfg_mlme_set_dfs_filter_offload(struct wlan_objmgr_psoc *psoc, 1041 bool dfs_filter_offload); 1042 1043 /** 1044 * ucfg_mlme_get_oem_6g_supported() - Get oem 6Ghz supported 1045 * @psoc: pointer to psoc object 1046 * @oem_6g_supported: Pointer to the value which will be filled for the caller 1047 * 1048 * Return: QDF Status 1049 */ 1050 QDF_STATUS 1051 ucfg_mlme_get_oem_6g_supported(struct wlan_objmgr_psoc *psoc, 1052 bool *oem_6g_supported); 1053 1054 /** 1055 * ucfg_mlme_get_fine_time_meas_cap() - Get fine timing measurement capability 1056 * @psoc: pointer to psoc object 1057 * @fine_time_meas_cap: Pointer to the value which will be filled for the caller 1058 * 1059 * Return: QDF Status 1060 */ 1061 QDF_STATUS 1062 ucfg_mlme_get_fine_time_meas_cap(struct wlan_objmgr_psoc *psoc, 1063 uint32_t *fine_time_meas_cap); 1064 1065 /** 1066 * ucfg_mlme_set_fine_time_meas_cap() - Set fine timing measurement capability 1067 * @psoc: pointer to psoc object 1068 * @fine_time_meas_cap: Value to be set 1069 * 1070 * Return: QDF Status 1071 */ 1072 QDF_STATUS 1073 ucfg_mlme_set_fine_time_meas_cap(struct wlan_objmgr_psoc *psoc, 1074 uint32_t fine_time_meas_cap); 1075 1076 /** 1077 * ucfg_mlme_get_pmkid_modes() - Get PMKID modes 1078 * @psoc: pointer to psoc object 1079 * @val: Pointer to the value which will be filled for the caller 1080 * 1081 * Return: QDF Status 1082 */ 1083 QDF_STATUS 1084 ucfg_mlme_get_pmkid_modes(struct wlan_objmgr_psoc *psoc, 1085 uint32_t *val); 1086 1087 /** 1088 * ucfg_mlme_set_pmkid_modes() - Set PMKID modes 1089 * @psoc: pointer to psoc object 1090 * @val: Pointer to the value which will be filled for the caller 1091 * 1092 * Return: QDF Status 1093 */ 1094 QDF_STATUS 1095 ucfg_mlme_set_pmkid_modes(struct wlan_objmgr_psoc *psoc, 1096 uint32_t val); 1097 1098 /** 1099 * ucfg_mlme_get_dot11p_mode() - Get the setting about 802.11p mode 1100 * @psoc: pointer to psoc object 1101 * @out_mode: Pointer to the mode which will be filled for the caller 1102 * 1103 * Return: QDF Status 1104 */ 1105 QDF_STATUS 1106 ucfg_mlme_get_dot11p_mode(struct wlan_objmgr_psoc *psoc, 1107 enum dot11p_mode *out_mode); 1108 1109 /** 1110 * ucfg_mlme_get_go_cts2self_for_sta() - Stop NOA and start using cts2self 1111 * @psoc: pointer to psoc object 1112 * @val: Pointer to the value which will be filled for the caller 1113 * 1114 * Return: QDF Status 1115 */ 1116 QDF_STATUS 1117 ucfg_mlme_get_go_cts2self_for_sta(struct wlan_objmgr_psoc *psoc, 1118 bool *val); 1119 1120 /** 1121 * ucfg_mlme_get_qcn_ie_support() - QCN IE support or not 1122 * @psoc: pointer to psoc object 1123 * @val: Pointer to the value which will be filled for the caller 1124 * 1125 * Return: QDF Status 1126 */ 1127 QDF_STATUS 1128 ucfg_mlme_get_qcn_ie_support(struct wlan_objmgr_psoc *psoc, 1129 bool *val); 1130 1131 /** 1132 * ucfg_mlme_get_tgt_gtx_usr_cfg() - Get the target gtx user config 1133 * @psoc: pointer to psoc object 1134 * @val: Pointer to the value which will be filled for the caller 1135 * 1136 * Return: QDF Status 1137 */ 1138 QDF_STATUS 1139 ucfg_mlme_get_tgt_gtx_usr_cfg(struct wlan_objmgr_psoc *psoc, 1140 uint32_t *val); 1141 1142 /** 1143 * ucfg_mlme_is_override_ht20_40_24g() - use channel bonding in 2.4 GHz or not 1144 * @psoc: pointer to psoc object 1145 * @val: Pointer to the value which will be filled for the caller 1146 * 1147 * Return: QDF Status 1148 */ 1149 QDF_STATUS 1150 ucfg_mlme_is_override_ht20_40_24g(struct wlan_objmgr_psoc *psoc, bool *val); 1151 1152 #ifdef WLAN_FEATURE_ROAM_OFFLOAD 1153 /** 1154 * ucfg_mlme_get_roam_disable_config() - Get sta roam disable value 1155 * @psoc: pointer to psoc object 1156 * @val: Pointer to bitmap of interfaces for those sta roaming is disabled 1157 * 1158 * Return: QDF Status 1159 */ 1160 QDF_STATUS 1161 ucfg_mlme_get_roam_disable_config(struct wlan_objmgr_psoc *psoc, 1162 uint32_t *val); 1163 1164 /** 1165 * ucfg_mlme_get_roaming_offload() - Get roaming offload setting 1166 * @psoc: pointer to psoc object 1167 * @val: Pointer to enable/disable roaming offload 1168 * 1169 * Return: QDF Status 1170 */ 1171 QDF_STATUS 1172 ucfg_mlme_get_roaming_offload(struct wlan_objmgr_psoc *psoc, 1173 bool *val); 1174 1175 /** 1176 * ucfg_mlme_set_roaming_offload() - Enable/disable roaming offload 1177 * @psoc: pointer to psoc object 1178 * @val: enable/disable roaming offload 1179 * 1180 * Return: QDF Status 1181 */ 1182 QDF_STATUS 1183 ucfg_mlme_set_roaming_offload(struct wlan_objmgr_psoc *psoc, 1184 bool val); 1185 1186 /** 1187 * ucfg_mlme_get_roaming_triggers() - Get roaming triggers bitmap 1188 * value 1189 * @psoc: pointer to psoc object 1190 * 1191 * Return: Roaming triggers value 1192 */ 1193 static inline uint32_t ucfg_mlme_get_roaming_triggers(struct wlan_objmgr_psoc * psoc)1194 ucfg_mlme_get_roaming_triggers(struct wlan_objmgr_psoc *psoc) 1195 { 1196 return wlan_mlme_get_roaming_triggers(psoc); 1197 } 1198 1199 /** 1200 * ucfg_mlme_set_roaming_triggers() - Set roaming triggers bitmap 1201 * value 1202 * @psoc: pointer to psoc object 1203 * @trigger_bitmap: Roaming triggers bitmap to set 1204 * 1205 * Return: void 1206 */ 1207 static inline void ucfg_mlme_set_roaming_triggers(struct wlan_objmgr_psoc * psoc,uint32_t trigger_bitmap)1208 ucfg_mlme_set_roaming_triggers(struct wlan_objmgr_psoc *psoc, 1209 uint32_t trigger_bitmap) 1210 { 1211 wlan_mlme_set_roaming_triggers(psoc, trigger_bitmap); 1212 } 1213 #else 1214 static inline QDF_STATUS ucfg_mlme_get_roam_disable_config(struct wlan_objmgr_psoc * psoc,uint32_t * val)1215 ucfg_mlme_get_roam_disable_config(struct wlan_objmgr_psoc *psoc, 1216 uint32_t *val) 1217 { 1218 return QDF_STATUS_E_FAILURE; 1219 } 1220 1221 static inline QDF_STATUS ucfg_mlme_get_roaming_offload(struct wlan_objmgr_psoc * psoc,bool * val)1222 ucfg_mlme_get_roaming_offload(struct wlan_objmgr_psoc *psoc, 1223 bool *val) 1224 { 1225 *val = false; 1226 1227 return QDF_STATUS_SUCCESS; 1228 } 1229 1230 static inline QDF_STATUS ucfg_mlme_set_roaming_offload(struct wlan_objmgr_psoc * psoc,bool val)1231 ucfg_mlme_set_roaming_offload(struct wlan_objmgr_psoc *psoc, 1232 bool val) 1233 { 1234 return QDF_STATUS_SUCCESS; 1235 } 1236 1237 static inline uint32_t ucfg_mlme_get_roaming_triggers(struct wlan_objmgr_psoc * psoc)1238 ucfg_mlme_get_roaming_triggers(struct wlan_objmgr_psoc *psoc) 1239 { 1240 return 0xffff; 1241 } 1242 1243 static inline void ucfg_mlme_set_roaming_triggers(struct wlan_objmgr_psoc * psoc,uint32_t trigger_bitmap)1244 ucfg_mlme_set_roaming_triggers(struct wlan_objmgr_psoc *psoc, 1245 uint32_t trigger_bitmap) 1246 { 1247 } 1248 #endif 1249 1250 /** 1251 * ucfg_mlme_is_mawc_enabled() - MAWC enabled or not 1252 * @psoc: pointer to psoc object 1253 * @val: Pointer to the value which will be filled for the caller 1254 * 1255 * Return: QDF Status 1256 */ 1257 QDF_STATUS 1258 ucfg_mlme_is_mawc_enabled(struct wlan_objmgr_psoc *psoc, bool *val); 1259 1260 /** 1261 * ucfg_mlme_set_mawc_enabled() - Set MAWC enable or disable 1262 * @psoc: pointer to psoc object 1263 * @val: enable or disable MAWC 1264 * 1265 * Return: QDF Status 1266 */ 1267 QDF_STATUS 1268 ucfg_mlme_set_mawc_enabled(struct wlan_objmgr_psoc *psoc, bool val); 1269 1270 /** 1271 * ucfg_mlme_is_fast_transition_enabled() - Fast transition enable or not 1272 * @psoc: pointer to psoc object 1273 * @val: Pointer to the value which will be filled for the caller 1274 * 1275 * Return: QDF Status 1276 */ 1277 QDF_STATUS 1278 ucfg_mlme_is_fast_transition_enabled(struct wlan_objmgr_psoc *psoc, 1279 bool *val); 1280 1281 /** 1282 * ucfg_mlme_set_fast_transition_enabled() - Set fast transition enable 1283 * @psoc: pointer to psoc object 1284 * @val: Fast transition enable or disable 1285 * 1286 * Return: QDF Status 1287 */ 1288 QDF_STATUS 1289 ucfg_mlme_set_fast_transition_enabled(struct wlan_objmgr_psoc *psoc, 1290 bool val); 1291 1292 /** 1293 * ucfg_mlme_is_roam_scan_offload_enabled() - Roam scan offload enable or not 1294 * @psoc: pointer to psoc object 1295 * @val: Pointer to the value which will be filled for the caller 1296 * 1297 * Return: QDF Status 1298 */ 1299 QDF_STATUS 1300 ucfg_mlme_is_roam_scan_offload_enabled(struct wlan_objmgr_psoc *psoc, 1301 bool *val); 1302 1303 #ifdef WLAN_ADAPTIVE_11R 1304 /** 1305 * ucfg_mlme_set_tgt_adaptive_11r_cap() - Set adaptive 11r target service 1306 * capability 1307 * @psoc: pointer to psoc object 1308 * @val: Target capability of adaptive 11r 1309 * 1310 * Return: QDF Status 1311 */ 1312 QDF_STATUS 1313 ucfg_mlme_set_tgt_adaptive_11r_cap(struct wlan_objmgr_psoc *psoc, 1314 bool val); 1315 /** 1316 * ucfg_mlme_get_adaptive11r_enabled() - get adaptive 11R enabled status 1317 * @psoc: pointer to psoc object 1318 * @value: pointer to the value which will be filled for the caller 1319 * 1320 * Return: QDF Status 1321 */ 1322 QDF_STATUS 1323 ucfg_mlme_get_adaptive11r_enabled(struct wlan_objmgr_psoc *psoc, 1324 bool *value); 1325 #else 1326 static inline QDF_STATUS ucfg_mlme_set_tgt_adaptive_11r_cap(struct wlan_objmgr_psoc * psoc,bool val)1327 ucfg_mlme_set_tgt_adaptive_11r_cap(struct wlan_objmgr_psoc *psoc, 1328 bool val) 1329 { 1330 return QDF_STATUS_SUCCESS; 1331 } 1332 1333 static inline QDF_STATUS ucfg_mlme_get_adaptive11r_enabled(struct wlan_objmgr_psoc * psoc,bool * value)1334 ucfg_mlme_get_adaptive11r_enabled(struct wlan_objmgr_psoc *psoc, 1335 bool *value) 1336 { 1337 *value = false; 1338 return QDF_STATUS_SUCCESS; 1339 } 1340 #endif 1341 1342 /** 1343 * ucfg_mlme_set_roam_scan_offload_enabled() - Set roam scan offload enable 1344 * @psoc: pointer to psoc object 1345 * @val: Roam scan offload enable or disable 1346 * 1347 * Return: QDF Status 1348 */ 1349 QDF_STATUS 1350 ucfg_mlme_set_roam_scan_offload_enabled(struct wlan_objmgr_psoc *psoc, 1351 bool val); 1352 1353 /** 1354 * ucfg_mlme_get_neighbor_scan_max_chan_time() - Get neighbor scan max 1355 * channel time 1356 * @psoc: pointer to psoc object 1357 * @val: Pointer to the value which will be filled for the caller 1358 * 1359 * Return: QDF Status 1360 */ 1361 QDF_STATUS 1362 ucfg_mlme_get_neighbor_scan_max_chan_time(struct wlan_objmgr_psoc *psoc, 1363 uint16_t *val); 1364 1365 /** 1366 * ucfg_mlme_get_neighbor_scan_min_chan_time() - Get neighbor scan min 1367 * channel time 1368 * @psoc: pointer to psoc object 1369 * @val: Pointer to the value which will be filled for the caller 1370 * 1371 * Return: QDF Status 1372 */ 1373 QDF_STATUS 1374 ucfg_mlme_get_neighbor_scan_min_chan_time(struct wlan_objmgr_psoc *psoc, 1375 uint16_t *val); 1376 1377 /** 1378 * ucfg_mlme_get_delay_before_vdev_stop() - Get the delay before vdev stop 1379 * @psoc: pointer to psoc object 1380 * @val: Pointer to the value which will be filled for the caller 1381 * 1382 * Return: QDF Status 1383 */ 1384 QDF_STATUS 1385 ucfg_mlme_get_delay_before_vdev_stop(struct wlan_objmgr_psoc *psoc, 1386 uint8_t *val); 1387 1388 /** 1389 * ucfg_mlme_get_roam_bmiss_final_bcnt() - Get roam bmiss first count 1390 * @psoc: pointer to psoc object 1391 * @val: Pointer to the value which will be filled for the caller 1392 * 1393 * Return: QDF Status 1394 */ 1395 QDF_STATUS 1396 ucfg_mlme_get_roam_bmiss_final_bcnt(struct wlan_objmgr_psoc *psoc, 1397 uint8_t *val); 1398 1399 /** 1400 * ucfg_mlme_validate_roam_bmiss_final_bcnt() - Validate roam bmiss final bcnt 1401 * @bmiss_final_bcnt: Roam bmiss final bcnt 1402 * 1403 * Return: True if bmiss_final_bcnt is in expected range, false otherwise. 1404 */ 1405 bool 1406 ucfg_mlme_validate_roam_bmiss_final_bcnt(uint32_t bmiss_final_bcnt); 1407 1408 /** 1409 * ucfg_mlme_get_dual_sta_roaming_enabled() - Get dual sta roaming enable flag 1410 * @psoc: pointer to psoc object 1411 * 1412 * Return: true if dual sta roaming allowed in fw 1413 */ 1414 bool 1415 ucfg_mlme_get_dual_sta_roaming_enabled(struct wlan_objmgr_psoc *psoc); 1416 1417 /** 1418 * ucfg_mlme_get_roam_bmiss_first_bcnt() - Get roam bmiss final count 1419 * @psoc: pointer to psoc object 1420 * @val: Pointer to the value which will be filled for the caller 1421 * 1422 * Return: QDF Status 1423 */ 1424 QDF_STATUS 1425 ucfg_mlme_get_roam_bmiss_first_bcnt(struct wlan_objmgr_psoc *psoc, 1426 uint8_t *val); 1427 1428 /** 1429 * ucfg_mlme_is_lfr_enabled() - LFR enable or not 1430 * @psoc: pointer to psoc object 1431 * @val: Pointer to the value which will be filled for the caller 1432 * 1433 * Return: QDF Status 1434 */ 1435 QDF_STATUS 1436 ucfg_mlme_is_lfr_enabled(struct wlan_objmgr_psoc *psoc, bool *val); 1437 1438 /** 1439 * ucfg_mlme_set_lfr_enabled() - Enable or disable LFR 1440 * @psoc: pointer to psoc object 1441 * @val: Enable or disable LFR 1442 * 1443 * Return: QDF Status 1444 */ 1445 QDF_STATUS 1446 ucfg_mlme_set_lfr_enabled(struct wlan_objmgr_psoc *psoc, bool val); 1447 1448 /** 1449 * ucfg_mlme_is_roam_prefer_5ghz() - prefer 5ghz or not 1450 * @psoc: pointer to psoc object 1451 * @val: Pointer to the value which will be filled for the caller 1452 * 1453 * Return: QDF Status 1454 */ 1455 QDF_STATUS 1456 ucfg_mlme_is_roam_prefer_5ghz(struct wlan_objmgr_psoc *psoc, bool *val); 1457 1458 /** 1459 * ucfg_mlme_is_roam_intra_band() - Get the preference to roam within band 1460 * @psoc: pointer to psoc object 1461 * 1462 * Return: True if vdev should roam within band, false otherwise 1463 */ 1464 bool ucfg_mlme_is_roam_intra_band(struct wlan_objmgr_psoc *psoc); 1465 1466 /** 1467 * ucfg_mlme_set_roam_intra_band() - Set roam intra modes 1468 * @psoc: pointer to psoc object 1469 * @val: roam intra modes or not 1470 * 1471 * Return: QDF Status 1472 */ 1473 QDF_STATUS 1474 ucfg_mlme_set_roam_intra_band(struct wlan_objmgr_psoc *psoc, bool val); 1475 1476 /** 1477 * ucfg_mlme_get_home_away_time() - Get home away time 1478 * @psoc: pointer to psoc object 1479 * @val: Pointer to the value which will be filled for the caller 1480 * 1481 * Return: QDF Status 1482 */ 1483 QDF_STATUS 1484 ucfg_mlme_get_home_away_time(struct wlan_objmgr_psoc *psoc, uint16_t *val); 1485 1486 /** 1487 * ucfg_mlme_set_fast_roam_in_concurrency_enabled() - Enable fast roam in 1488 * concurrency 1489 * @psoc: pointer to psoc object 1490 * @val: Enable or disable fast roam in concurrency 1491 * 1492 * Return: QDF Status 1493 */ 1494 QDF_STATUS 1495 ucfg_mlme_set_fast_roam_in_concurrency_enabled(struct wlan_objmgr_psoc *psoc, 1496 bool val); 1497 1498 /** 1499 * ucfg_mlme_get_wmi_wq_watchdog_timeout() - Get timeout for wmi watchdog bite 1500 * @psoc: pointer to psoc object 1501 * @wmi_wq_watchdog_timeout: buffer to hold value 1502 * 1503 * Return: QDF Status 1504 */ 1505 QDF_STATUS 1506 ucfg_mlme_get_wmi_wq_watchdog_timeout(struct wlan_objmgr_psoc *psoc, 1507 uint32_t *wmi_wq_watchdog_timeout); 1508 1509 /** 1510 * ucfg_mlme_set_wmi_wq_watchdog_timeout() - Set timeout for wmi watchdog bite 1511 * @psoc: pointer to psoc object 1512 * @wmi_wq_watchdog_timeout: value to be set 1513 * 1514 * Return: QDF Status 1515 */ 1516 QDF_STATUS 1517 ucfg_mlme_set_wmi_wq_watchdog_timeout(struct wlan_objmgr_psoc *psoc, 1518 uint32_t wmi_wq_watchdog_timeout); 1519 1520 /** 1521 * ucfg_mlme_set_sap_listen_interval() - Set the Sap listen interval 1522 * @psoc: pointer to psoc object 1523 * @value: Value that needs to be set from the caller 1524 * 1525 * Inline UCFG API to be used by HDD/OSIF callers 1526 * 1527 * Return: QDF Status 1528 */ 1529 static inline ucfg_mlme_set_sap_listen_interval(struct wlan_objmgr_psoc * psoc,int value)1530 QDF_STATUS ucfg_mlme_set_sap_listen_interval(struct wlan_objmgr_psoc *psoc, 1531 int value) 1532 { 1533 return wlan_mlme_set_sap_listen_interval(psoc, value); 1534 } 1535 1536 /** 1537 * ucfg_mlme_set_assoc_sta_limit() - Set the assoc sta limit 1538 * @psoc: pointer to psoc object 1539 * @value: Value that needs to be set from the caller 1540 * 1541 * Inline UCFG API to be used by HDD/OSIF callers 1542 * 1543 * Return: QDF Status 1544 */ 1545 static inline ucfg_mlme_set_assoc_sta_limit(struct wlan_objmgr_psoc * psoc,int value)1546 QDF_STATUS ucfg_mlme_set_assoc_sta_limit(struct wlan_objmgr_psoc *psoc, 1547 int value) 1548 { 1549 return wlan_mlme_set_assoc_sta_limit(psoc, value); 1550 } 1551 1552 /** 1553 * ucfg_mlme_get_assoc_sta_limit() - Get the assoc sta limit 1554 * @psoc: pointer to psoc object 1555 * @value: Pointer to variable that needs to be filled by MLME 1556 * 1557 * Inline UCFG API to be used by HDD/OSIF callers 1558 * 1559 * Return: QDF Status 1560 */ 1561 static inline ucfg_mlme_get_assoc_sta_limit(struct wlan_objmgr_psoc * psoc,int * value)1562 QDF_STATUS ucfg_mlme_get_assoc_sta_limit(struct wlan_objmgr_psoc *psoc, 1563 int *value) 1564 { 1565 return wlan_mlme_get_assoc_sta_limit(psoc, value); 1566 } 1567 1568 /** 1569 * ucfg_mlme_get_listen_interval() - Get listen interval 1570 * @psoc: pointer to psoc object 1571 * @value: Pointer to variable that needs to be filled by MLME 1572 * 1573 * Inline UCFG API to be used by HDD/OSIF callers 1574 * 1575 * Return: QDF Status 1576 */ 1577 static inline ucfg_mlme_get_listen_interval(struct wlan_objmgr_psoc * psoc,int * value)1578 QDF_STATUS ucfg_mlme_get_listen_interval(struct wlan_objmgr_psoc *psoc, 1579 int *value) 1580 { 1581 return wlan_mlme_get_listen_interval(psoc, value); 1582 } 1583 1584 1585 /** 1586 * ucfg_mlme_get_sap_get_peer_info() - get the sap get peer info 1587 * @psoc: pointer to psoc object 1588 * @value: Value that needs to be set from the caller 1589 * 1590 * Inline UCFG API to be used by HDD/OSIF callers 1591 * 1592 * Return: QDF Status 1593 */ 1594 static inline ucfg_mlme_get_sap_get_peer_info(struct wlan_objmgr_psoc * psoc,bool * value)1595 QDF_STATUS ucfg_mlme_get_sap_get_peer_info(struct wlan_objmgr_psoc *psoc, 1596 bool *value) 1597 { 1598 return wlan_mlme_get_sap_get_peer_info(psoc, value); 1599 } 1600 1601 /** 1602 * ucfg_mlme_set_sap_get_peer_info() - set the sap get peer info 1603 * @psoc: pointer to psoc object 1604 * @value: value to overwrite the sap get peer info 1605 * 1606 * Inline UCFG API to be used by HDD/OSIF callers 1607 * 1608 * Return: QDF Status 1609 */ 1610 static inline ucfg_mlme_set_sap_get_peer_info(struct wlan_objmgr_psoc * psoc,bool value)1611 QDF_STATUS ucfg_mlme_set_sap_get_peer_info(struct wlan_objmgr_psoc *psoc, 1612 bool value) 1613 { 1614 return wlan_mlme_set_sap_get_peer_info(psoc, value); 1615 } 1616 1617 /** 1618 * ucfg_mlme_get_sap_bcast_deauth_enabled() - get the sap bcast deauth 1619 * enabled value 1620 * @psoc: pointer to psoc object 1621 * @value: Value that needs to be get from the caller 1622 * 1623 * Inline UCFG API to be used by HDD/OSIF callers 1624 * 1625 * Return: QDF Status 1626 */ 1627 static inline QDF_STATUS ucfg_mlme_get_sap_bcast_deauth_enabled(struct wlan_objmgr_psoc * psoc,bool * value)1628 ucfg_mlme_get_sap_bcast_deauth_enabled(struct wlan_objmgr_psoc *psoc, 1629 bool *value) 1630 { 1631 return wlan_mlme_get_sap_bcast_deauth_enabled(psoc, value); 1632 } 1633 1634 /** 1635 * ucfg_mlme_is_6g_sap_fd_enabled() - get the sap fils discovery 1636 * enabled value 1637 * @psoc: pointer to psoc object 1638 * @value: Value that needs to be get from the caller 1639 * 1640 * Inline UCFG API to be used by HDD/OSIF callers 1641 * 1642 * Return: QDF Status 1643 */ 1644 static inline QDF_STATUS ucfg_mlme_is_6g_sap_fd_enabled(struct wlan_objmgr_psoc * psoc,bool * value)1645 ucfg_mlme_is_6g_sap_fd_enabled(struct wlan_objmgr_psoc *psoc, 1646 bool *value) 1647 { 1648 return wlan_mlme_is_6g_sap_fd_enabled(psoc, value); 1649 } 1650 1651 /** 1652 * ucfg_mlme_get_sap_allow_all_channels() - get the sap allow all channels 1653 * @psoc: pointer to psoc object 1654 * @value: Value that needs to be set from the caller 1655 * 1656 * Inline UCFG API to be used by HDD/OSIF callers 1657 * 1658 * Return: QDF Status 1659 */ 1660 static inline ucfg_mlme_get_sap_allow_all_channels(struct wlan_objmgr_psoc * psoc,bool * value)1661 QDF_STATUS ucfg_mlme_get_sap_allow_all_channels(struct wlan_objmgr_psoc *psoc, 1662 bool *value) 1663 { 1664 return wlan_mlme_get_sap_allow_all_channels(psoc, value); 1665 } 1666 1667 /** 1668 * ucfg_mlme_get_sap_max_peers() - get the sap max peers 1669 * @psoc: pointer to psoc object 1670 * @value: Value that needs to be set from the caller 1671 * 1672 * Inline UCFG API to be used by HDD/OSIF callers 1673 * 1674 * Return: QDF Status 1675 */ 1676 static inline ucfg_mlme_get_sap_max_peers(struct wlan_objmgr_psoc * psoc,int * value)1677 QDF_STATUS ucfg_mlme_get_sap_max_peers(struct wlan_objmgr_psoc *psoc, 1678 int *value) 1679 { 1680 return wlan_mlme_get_sap_max_peers(psoc, value); 1681 } 1682 1683 /** 1684 * ucfg_mlme_set_sap_max_peers() - Set the sap max peers 1685 * @psoc: pointer to psoc object 1686 * @value: Value that needs to be set from the caller 1687 * 1688 * Inline UCFG API to be used by HDD/OSIF callers 1689 * 1690 * Return: QDF Status 1691 */ 1692 static inline ucfg_mlme_set_sap_max_peers(struct wlan_objmgr_psoc * psoc,int value)1693 QDF_STATUS ucfg_mlme_set_sap_max_peers(struct wlan_objmgr_psoc *psoc, int value) 1694 { 1695 return wlan_mlme_set_sap_max_peers(psoc, value); 1696 } 1697 1698 /** 1699 * ucfg_mlme_get_sap_max_offload_peers() - get the sap max offload peers 1700 * @psoc: pointer to psoc object 1701 * @value: Value that needs to be set from the caller 1702 * 1703 * Inline UCFG API to be used by HDD/OSIF callers 1704 * 1705 * Return: QDF Status 1706 */ 1707 static inline ucfg_mlme_get_sap_max_offload_peers(struct wlan_objmgr_psoc * psoc,int * value)1708 QDF_STATUS ucfg_mlme_get_sap_max_offload_peers(struct wlan_objmgr_psoc *psoc, 1709 int *value) 1710 { 1711 return wlan_mlme_get_sap_max_offload_peers(psoc, value); 1712 } 1713 1714 /** 1715 * ucfg_mlme_get_sap_max_offload_reorder_buffs() - get the sap max offload 1716 * reorder buffs 1717 * @psoc: pointer to psoc object 1718 * @value: Value that needs to be set from the caller 1719 * 1720 * Inline UCFG API to be used by HDD/OSIF callers 1721 * 1722 * Return: QDF Status 1723 */ 1724 static inline ucfg_mlme_get_sap_max_offload_reorder_buffs(struct wlan_objmgr_psoc * psoc,int * value)1725 QDF_STATUS ucfg_mlme_get_sap_max_offload_reorder_buffs(struct wlan_objmgr_psoc 1726 *psoc, int *value) 1727 { 1728 return wlan_mlme_get_sap_max_offload_reorder_buffs(psoc, value); 1729 } 1730 1731 /** 1732 * ucfg_mlme_get_sap_chn_switch_bcn_count() - get the sap channel 1733 * switch beacon count 1734 * @psoc: pointer to psoc object 1735 * @value: Value that needs to be set from the caller 1736 * 1737 * Inline UCFG API to be used by HDD/OSIF callers 1738 * 1739 * Return: QDF Status 1740 */ 1741 static inline ucfg_mlme_get_sap_chn_switch_bcn_count(struct wlan_objmgr_psoc * psoc,int * value)1742 QDF_STATUS ucfg_mlme_get_sap_chn_switch_bcn_count(struct wlan_objmgr_psoc *psoc, 1743 int *value) 1744 { 1745 return wlan_mlme_get_sap_chn_switch_bcn_count(psoc, value); 1746 } 1747 1748 /** 1749 * ucfg_mlme_get_sap_channel_switch_mode() - get the sap channel switch mode 1750 * @psoc: pointer to psoc object 1751 * @value: Value that needs to be set from the caller 1752 * 1753 * Inline UCFG API to be used by HDD/OSIF callers 1754 * 1755 * Return: QDF Status 1756 */ 1757 static inline ucfg_mlme_get_sap_channel_switch_mode(struct wlan_objmgr_psoc * psoc,bool * value)1758 QDF_STATUS ucfg_mlme_get_sap_channel_switch_mode(struct wlan_objmgr_psoc *psoc, 1759 bool *value) 1760 { 1761 return wlan_mlme_get_sap_chn_switch_mode(psoc, value); 1762 } 1763 1764 /** 1765 * ucfg_mlme_get_sap_internal_restart() - get sap internal restart value 1766 * @psoc: pointer to psoc object 1767 * @value: Value that needs to be set from the caller 1768 * 1769 * Inline UCFG API to be used by HDD/OSIF callers 1770 * 1771 * Return: QDF Status 1772 */ 1773 static inline ucfg_mlme_get_sap_internal_restart(struct wlan_objmgr_psoc * psoc,bool * value)1774 QDF_STATUS ucfg_mlme_get_sap_internal_restart(struct wlan_objmgr_psoc *psoc, 1775 bool *value) 1776 { 1777 return wlan_mlme_get_sap_internal_restart(psoc, value); 1778 } 1779 1780 /** 1781 * ucfg_mlme_get_sap_max_modulated_dtim() - get sap max modulated dtim 1782 * @psoc: pointer to psoc object 1783 * @value: Value that needs to be set from the caller 1784 * 1785 * Inline UCFG API to be used by HDD/OSIF callers 1786 * 1787 * Return: QDF Status 1788 */ 1789 static inline ucfg_mlme_get_sap_max_modulated_dtim(struct wlan_objmgr_psoc * psoc,uint8_t * value)1790 QDF_STATUS ucfg_mlme_get_sap_max_modulated_dtim(struct wlan_objmgr_psoc *psoc, 1791 uint8_t *value) 1792 { 1793 return wlan_mlme_get_sap_max_modulated_dtim(psoc, value); 1794 } 1795 1796 /** 1797 * ucfg_mlme_get_pref_chan_location() - get sap pref chan location 1798 * @psoc: pointer to psoc object 1799 * @value: Value that needs to be set from the caller 1800 * 1801 * Inline UCFG API to be used by HDD/OSIF callers 1802 * 1803 * Return: QDF Status 1804 */ 1805 static inline ucfg_mlme_get_pref_chan_location(struct wlan_objmgr_psoc * psoc,uint8_t * value)1806 QDF_STATUS ucfg_mlme_get_pref_chan_location(struct wlan_objmgr_psoc *psoc, 1807 uint8_t *value) 1808 { 1809 return wlan_mlme_get_sap_chan_pref_location(psoc, value); 1810 } 1811 1812 /** 1813 * ucfg_mlme_get_sap_country_priority() - get sap country code priority 1814 * @psoc: pointer to psoc object 1815 * @value: Value that needs to be set from the caller 1816 * 1817 * Inline UCFG API to be used by HDD/OSIF callers 1818 * 1819 * Return: QDF Status 1820 */ 1821 static inline ucfg_mlme_get_sap_country_priority(struct wlan_objmgr_psoc * psoc,bool * value)1822 QDF_STATUS ucfg_mlme_get_sap_country_priority(struct wlan_objmgr_psoc *psoc, 1823 bool *value) 1824 { 1825 return wlan_mlme_get_sap_country_priority(psoc, value); 1826 } 1827 1828 /** 1829 * ucfg_mlme_get_sap_reduces_beacon_interval() - get the sap reduces beacon 1830 * interval 1831 * @psoc: pointer to psoc object 1832 * @value: Value that needs to be set from the caller 1833 * 1834 * Inline UCFG API to be used by HDD/OSIF callers 1835 * 1836 * Return: QDF Status 1837 */ 1838 static inline ucfg_mlme_get_sap_reduces_beacon_interval(struct wlan_objmgr_psoc * psoc,int * value)1839 QDF_STATUS ucfg_mlme_get_sap_reduces_beacon_interval(struct wlan_objmgr_psoc 1840 *psoc, int *value) 1841 { 1842 return wlan_mlme_get_sap_reduced_beacon_interval(psoc, value); 1843 } 1844 1845 /** 1846 * ucfg_mlme_get_sap_chan_switch_rate_enabled() - get the sap channel 1847 * switch rate enabled. 1848 * @psoc: pointer to psoc object 1849 * @value: Value that needs to be set from the caller 1850 * 1851 * Inline UCFG API to be used by HDD/OSIF callers 1852 * 1853 * Return: QDF Status 1854 */ 1855 static inline ucfg_mlme_get_sap_chan_switch_rate_enabled(struct wlan_objmgr_psoc * psoc,bool * value)1856 QDF_STATUS ucfg_mlme_get_sap_chan_switch_rate_enabled(struct wlan_objmgr_psoc 1857 *psoc, bool *value) 1858 { 1859 return wlan_mlme_get_sap_chan_switch_rate_enabled(psoc, value); 1860 } 1861 1862 /** 1863 * ucfg_mlme_get_sap_force_11n_for_11ac() - get the sap 11n for 11ac 1864 * 1865 * @psoc: pointer to psoc object 1866 * @value: Value that needs to be set from the caller 1867 * 1868 * Inline UCFG API to be used by HDD/OSIF callers 1869 * 1870 * Return: QDF Status 1871 */ 1872 static inline ucfg_mlme_get_sap_force_11n_for_11ac(struct wlan_objmgr_psoc * psoc,bool * value)1873 QDF_STATUS ucfg_mlme_get_sap_force_11n_for_11ac(struct wlan_objmgr_psoc 1874 *psoc, bool *value) 1875 { 1876 return wlan_mlme_get_sap_force_11n_for_11ac(psoc, value); 1877 } 1878 1879 /** 1880 * ucfg_mlme_get_go_force_11n_for_11ac() - get the GO 11n for 11ac 1881 * 1882 * @psoc: pointer to psoc object 1883 * @value: Value that needs to be set from the caller 1884 * 1885 * Inline UCFG API to be used by HDD/OSIF callers 1886 * 1887 * Return: QDF Status 1888 */ 1889 static inline ucfg_mlme_get_go_force_11n_for_11ac(struct wlan_objmgr_psoc * psoc,bool * value)1890 QDF_STATUS ucfg_mlme_get_go_force_11n_for_11ac(struct wlan_objmgr_psoc 1891 *psoc, bool *value) 1892 { 1893 return wlan_mlme_get_go_force_11n_for_11ac(psoc, value); 1894 } 1895 1896 /** 1897 * ucfg_mlme_is_sap_11ac_override() - Override 11ac bandwdith for SAP 1898 * 1899 * @psoc: pointer to psoc object 1900 * @value: Value that needs to be set from the caller 1901 * 1902 * Return: QDF Status 1903 */ 1904 static inline ucfg_mlme_is_sap_11ac_override(struct wlan_objmgr_psoc * psoc,bool * value)1905 QDF_STATUS ucfg_mlme_is_sap_11ac_override(struct wlan_objmgr_psoc *psoc, 1906 bool *value) 1907 { 1908 return wlan_mlme_is_sap_11ac_override(psoc, value); 1909 } 1910 1911 /** 1912 * ucfg_mlme_is_go_11ac_override() - Override 11ac bandwdith for P2P GO 1913 * 1914 * @psoc: pointer to psoc object 1915 * @value: pointer to the value which will be filled for the caller 1916 * 1917 * Return: QDF Status 1918 */ 1919 static inline ucfg_mlme_is_go_11ac_override(struct wlan_objmgr_psoc * psoc,bool * value)1920 QDF_STATUS ucfg_mlme_is_go_11ac_override(struct wlan_objmgr_psoc *psoc, 1921 bool *value) 1922 { 1923 return wlan_mlme_is_go_11ac_override(psoc, value); 1924 } 1925 1926 /** 1927 * ucfg_mlme_set_sap_11ac_override() - Set override 11ac bandwdith for SAP 1928 * 1929 * @psoc: pointer to psoc object 1930 * @value: Value that needs to be set from the caller 1931 * 1932 * Return: QDF Status 1933 */ 1934 static inline ucfg_mlme_set_sap_11ac_override(struct wlan_objmgr_psoc * psoc,bool value)1935 QDF_STATUS ucfg_mlme_set_sap_11ac_override(struct wlan_objmgr_psoc *psoc, 1936 bool value) 1937 { 1938 return wlan_mlme_set_sap_11ac_override(psoc, value); 1939 } 1940 1941 /** 1942 * ucfg_mlme_set_go_11ac_override() - Set override 11ac bandwdith for P2P GO 1943 * 1944 * @psoc: pointer to psoc object 1945 * @value: pointer to the value which will be filled for the caller 1946 * 1947 * Return: QDF Status 1948 */ 1949 static inline ucfg_mlme_set_go_11ac_override(struct wlan_objmgr_psoc * psoc,bool value)1950 QDF_STATUS ucfg_mlme_set_go_11ac_override(struct wlan_objmgr_psoc *psoc, 1951 bool value) 1952 { 1953 return wlan_mlme_set_go_11ac_override(psoc, value); 1954 } 1955 1956 /** 1957 * ucfg_mlme_get_oce_sta_enabled_info() - Get OCE feature enable/disable 1958 * info for STA 1959 * 1960 * @psoc: pointer to psoc object 1961 * @value: pointer to the value which will be filled for the caller 1962 * 1963 * Inline UCFG API to be used by HDD/OSIF callers to get the 1964 * OCE STA feature enable value 1965 * 1966 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 1967 */ 1968 static inline ucfg_mlme_get_oce_sta_enabled_info(struct wlan_objmgr_psoc * psoc,bool * value)1969 QDF_STATUS ucfg_mlme_get_oce_sta_enabled_info(struct wlan_objmgr_psoc *psoc, 1970 bool *value) 1971 { 1972 return wlan_mlme_get_oce_sta_enabled_info(psoc, value); 1973 } 1974 1975 /** 1976 * ucfg_mlme_get_bigtk_support() - Get whether bigtk is supported or not. 1977 * 1978 * @psoc: pointer to psoc object 1979 * @value: pointer to the value which will be filled for the caller 1980 * 1981 * Inline UCFG API to be used by HDD/OSIF callers to get the BIGTK support 1982 * 1983 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 1984 */ 1985 static inline ucfg_mlme_get_bigtk_support(struct wlan_objmgr_psoc * psoc,bool * value)1986 QDF_STATUS ucfg_mlme_get_bigtk_support(struct wlan_objmgr_psoc *psoc, 1987 bool *value) 1988 { 1989 return wlan_mlme_get_bigtk_support(psoc, value); 1990 } 1991 1992 /** 1993 * ucfg_mlme_get_ocv_support() - Get whether ocv is supported or not. 1994 * 1995 * @psoc: pointer to psoc object 1996 * @value: pointer to the value which will be filled for the caller 1997 * 1998 * Inline UCFG API to be used by HDD/OSIF callers to get the OCV support 1999 * 2000 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2001 */ 2002 static inline ucfg_mlme_get_ocv_support(struct wlan_objmgr_psoc * psoc,bool * value)2003 QDF_STATUS ucfg_mlme_get_ocv_support(struct wlan_objmgr_psoc *psoc, 2004 bool *value) 2005 { 2006 return wlan_mlme_get_ocv_support(psoc, value); 2007 } 2008 2009 /** 2010 * ucfg_mlme_get_oce_sap_enabled_info() - Get OCE feature enable/disable 2011 * info for SAP 2012 * 2013 * @psoc: pointer to psoc object 2014 * @value: pointer to the value which will be filled for the caller 2015 * 2016 * Inline UCFG API to be used by HDD/OSIF callers to get the 2017 * OCE SAP feature enable value 2018 * 2019 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2020 */ 2021 static inline ucfg_mlme_get_oce_sap_enabled_info(struct wlan_objmgr_psoc * psoc,bool * value)2022 QDF_STATUS ucfg_mlme_get_oce_sap_enabled_info(struct wlan_objmgr_psoc *psoc, 2023 bool *value) 2024 { 2025 return wlan_mlme_get_oce_sap_enabled_info(psoc, value); 2026 } 2027 2028 /** 2029 * ucfg_mlme_update_oce_flags: Update the OCE flags 2030 * 2031 * @pdev: pointer to pdev object 2032 * 2033 * Inline UCFG API to be used by HDD/OSIF callers to update the 2034 * OCE feature flags 2035 * 2036 * Return: void 2037 */ 2038 static inline ucfg_mlme_update_oce_flags(struct wlan_objmgr_pdev * pdev)2039 void ucfg_mlme_update_oce_flags(struct wlan_objmgr_pdev *pdev) 2040 { 2041 wlan_mlme_update_oce_flags(pdev); 2042 } 2043 2044 /** 2045 * ucfg_mlme_is_ap_prot_enabled() - Check if sap is enabled 2046 * @psoc: pointer to psoc object 2047 * 2048 * Inline UCFG API to be used by HDD/OSIF callers to get the 2049 * sap protection enabled/disabled 2050 * 2051 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2052 */ 2053 static inline ucfg_mlme_is_ap_prot_enabled(struct wlan_objmgr_psoc * psoc)2054 bool ucfg_mlme_is_ap_prot_enabled(struct wlan_objmgr_psoc *psoc) 2055 { 2056 return wlan_mlme_is_ap_prot_enabled(psoc); 2057 } 2058 2059 /** 2060 * ucfg_mlme_get_ap_protection_mode() - Get ap protection mode info 2061 * @psoc: pointer to psoc object 2062 * @value: pointer to the value which will be filled for the caller 2063 * 2064 * Inline UCFG API to be used by HDD/OSIF callers to get the 2065 * ap protection mode value 2066 * 2067 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2068 */ 2069 static inline ucfg_mlme_get_ap_protection_mode(struct wlan_objmgr_psoc * psoc,uint16_t * value)2070 QDF_STATUS ucfg_mlme_get_ap_protection_mode(struct wlan_objmgr_psoc *psoc, 2071 uint16_t *value) 2072 { 2073 return wlan_mlme_get_ap_protection_mode(psoc, value); 2074 } 2075 2076 /** 2077 * ucfg_mlme_is_ap_obss_prot_enabled() - Get ap obss protection enable/disable 2078 * @psoc: pointer to psoc object 2079 * @value: pointer to the value which will be filled for the caller 2080 * 2081 * Inline UCFG API to be used by HDD/OSIF callers to get the 2082 * obss protection enable value 2083 * 2084 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2085 */ 2086 static inline ucfg_mlme_is_ap_obss_prot_enabled(struct wlan_objmgr_psoc * psoc,bool * value)2087 QDF_STATUS ucfg_mlme_is_ap_obss_prot_enabled(struct wlan_objmgr_psoc *psoc, 2088 bool *value) 2089 { 2090 return wlan_mlme_is_ap_obss_prot_enabled(psoc, value); 2091 } 2092 2093 /** 2094 * ucfg_mlme_get_rts_threshold() - Get the rts threshold config 2095 * @psoc: pointer to psoc object 2096 * @value: pointer to the value which will be filled for the caller 2097 * 2098 * Inline UCFG API to be used by HDD/OSIF callers 2099 * 2100 * Return: QDF Status 2101 */ 2102 static inline ucfg_mlme_get_rts_threshold(struct wlan_objmgr_psoc * psoc,uint32_t * value)2103 QDF_STATUS ucfg_mlme_get_rts_threshold(struct wlan_objmgr_psoc *psoc, 2104 uint32_t *value) 2105 { 2106 return wlan_mlme_get_rts_threshold(psoc, value); 2107 } 2108 2109 /** 2110 * ucfg_mlme_set_rts_threshold() - Set the rts threshold config 2111 * @psoc: pointer to psoc object 2112 * @value: pointer to the value which will be filled for the caller 2113 * 2114 * Inline UCFG API to be used by HDD/OSIF callers 2115 * 2116 * Return: QDF Status 2117 */ 2118 static inline ucfg_mlme_set_rts_threshold(struct wlan_objmgr_psoc * psoc,uint32_t value)2119 QDF_STATUS ucfg_mlme_set_rts_threshold(struct wlan_objmgr_psoc *psoc, 2120 uint32_t value) 2121 { 2122 return wlan_mlme_set_rts_threshold(psoc, value); 2123 } 2124 2125 /** 2126 * ucfg_mlme_get_frag_threshold() - Get the fragmentation threshold 2127 * config 2128 * @psoc: pointer to psoc object 2129 * @value: Value that needs to be set from the caller 2130 * 2131 * Inline UCFG API to be used by HDD/OSIF callers 2132 * 2133 * Return: QDF Status 2134 */ 2135 static inline ucfg_mlme_get_frag_threshold(struct wlan_objmgr_psoc * psoc,uint32_t * value)2136 QDF_STATUS ucfg_mlme_get_frag_threshold(struct wlan_objmgr_psoc *psoc, 2137 uint32_t *value) 2138 { 2139 return wlan_mlme_get_frag_threshold(psoc, value); 2140 } 2141 2142 /** 2143 * ucfg_mlme_set_frag_threshold() - set the frag threshold config 2144 * @psoc: pointer to psoc object 2145 * @value: pointer to the value which will be filled for the caller 2146 * 2147 * Inline UCFG API to be used by HDD/OSIF callers 2148 * 2149 * Return: QDF Status 2150 */ 2151 static inline ucfg_mlme_set_frag_threshold(struct wlan_objmgr_psoc * psoc,uint32_t value)2152 QDF_STATUS ucfg_mlme_set_frag_threshold(struct wlan_objmgr_psoc *psoc, 2153 uint32_t value) 2154 { 2155 return wlan_mlme_set_frag_threshold(psoc, value); 2156 } 2157 2158 /** 2159 * ucfg_mlme_get_fils_enabled_info() - Get fils enable/disable info 2160 * 2161 * @psoc: pointer to psoc object 2162 * @value: pointer to the value which will be filled for the caller 2163 * 2164 * Inline UCFG API to be used by HDD/OSIF callers to get the 2165 * fils enable value 2166 * 2167 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2168 */ 2169 static inline ucfg_mlme_get_fils_enabled_info(struct wlan_objmgr_psoc * psoc,bool * value)2170 QDF_STATUS ucfg_mlme_get_fils_enabled_info(struct wlan_objmgr_psoc *psoc, 2171 bool *value) 2172 { 2173 return wlan_mlme_get_fils_enabled_info(psoc, value); 2174 } 2175 2176 /** 2177 * ucfg_mlme_set_fils_enabled_info() - Set fils enable info 2178 * 2179 * @psoc: pointer to psoc object 2180 * @value: value that needs to be set from the caller 2181 * 2182 * Inline UCFG API to be used by HDD/OSIF callers to set the 2183 * fils enable value 2184 * 2185 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2186 */ 2187 static inline ucfg_mlme_set_fils_enabled_info(struct wlan_objmgr_psoc * psoc,bool value)2188 QDF_STATUS ucfg_mlme_set_fils_enabled_info(struct wlan_objmgr_psoc *psoc, 2189 bool value) 2190 { 2191 return wlan_mlme_set_fils_enabled_info(psoc, value); 2192 } 2193 2194 /** 2195 * ucfg_mlme_set_primary_interface() - Set primary STA iface id 2196 * 2197 * @psoc: pointer to psoc object 2198 * @value: value that needs to be set from the caller 2199 * 2200 * When a vdev is set as primary then based on the dual sta policy 2201 * "qca_wlan_concurrent_sta_policy_config" mcc preference and roaming has 2202 * to be enabled on the primary vdev 2203 * 2204 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2205 */ 2206 static inline ucfg_mlme_set_primary_interface(struct wlan_objmgr_psoc * psoc,uint8_t value)2207 QDF_STATUS ucfg_mlme_set_primary_interface(struct wlan_objmgr_psoc *psoc, 2208 uint8_t value) 2209 { 2210 return wlan_mlme_set_primary_interface(psoc, value); 2211 } 2212 2213 /** 2214 * ucfg_mlme_get_mcc_duty_cycle_percentage() - Get primary STA iface MCC 2215 * duty-cycle 2216 * @pdev: pointer to pdev object 2217 * 2218 * primary and secondary STA iface MCC duty-cycle value in below format 2219 * ****************************************************** 2220 * |bit 31-24 | bit 23-16 | bits 15-8 |bits 7-0 | 2221 * | Unused | Quota for | chan. # for |chan. # for| 2222 * | | 1st chan | 1st chan. |2nd chan. | 2223 * ***************************************************** 2224 * 2225 * Return: primary iface MCC duty-cycle value 2226 */ 2227 static inline ucfg_mlme_get_mcc_duty_cycle_percentage(struct wlan_objmgr_pdev * pdev)2228 int ucfg_mlme_get_mcc_duty_cycle_percentage(struct wlan_objmgr_pdev *pdev) 2229 { 2230 return wlan_mlme_get_mcc_duty_cycle_percentage(pdev); 2231 } 2232 2233 /** 2234 * ucfg_mlme_set_enable_bcast_probe_rsp() - Set enable bcast probe resp info 2235 * @psoc: pointer to psoc object 2236 * @value: value that needs to be set from the caller 2237 * 2238 * Inline UCFG API to be used by HDD/OSIF callers to set the 2239 * enable bcast probe resp info 2240 * 2241 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2242 */ 2243 static inline ucfg_mlme_set_enable_bcast_probe_rsp(struct wlan_objmgr_psoc * psoc,bool value)2244 QDF_STATUS ucfg_mlme_set_enable_bcast_probe_rsp(struct wlan_objmgr_psoc *psoc, 2245 bool value) 2246 { 2247 return wlan_mlme_set_enable_bcast_probe_rsp(psoc, value); 2248 } 2249 2250 /** 2251 * ucfg_mlme_set_vht_ch_width() - set the vht supported channel width cfg 2252 * @psoc: psoc context 2253 * @value: data to be set 2254 * 2255 * Inline UCFG API to be used by HDD/OSIF callers 2256 * 2257 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2258 */ 2259 static inline QDF_STATUS ucfg_mlme_set_vht_ch_width(struct wlan_objmgr_psoc * psoc,uint8_t value)2260 ucfg_mlme_set_vht_ch_width(struct wlan_objmgr_psoc *psoc, uint8_t value) 2261 { 2262 return wlan_mlme_cfg_set_vht_chan_width(psoc, value); 2263 } 2264 2265 /** 2266 * ucfg_mlme_cfg_get_vht_chan_width() - gets vht supported channel width into 2267 * cfg item 2268 * @psoc: psoc context 2269 * @value: data to be set 2270 * 2271 * Inline UCFG API to be used by HDD/OSIF callers 2272 * 2273 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2274 */ 2275 static inline QDF_STATUS ucfg_mlme_cfg_get_vht_chan_width(struct wlan_objmgr_psoc * psoc,uint8_t * value)2276 ucfg_mlme_cfg_get_vht_chan_width(struct wlan_objmgr_psoc *psoc, uint8_t *value) 2277 { 2278 return wlan_mlme_cfg_get_vht_chan_width(psoc, value); 2279 } 2280 2281 /** 2282 * ucfg_mlme_cfg_set_vht_ldpc_coding_cap() - sets vht ldpc coding cap into 2283 * cfg item 2284 * @psoc: psoc context 2285 * @value: data to be set 2286 * 2287 * Inline UCFG API to be used by HDD/OSIF callers 2288 * 2289 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2290 */ 2291 static inline QDF_STATUS ucfg_mlme_cfg_set_vht_ldpc_coding_cap(struct wlan_objmgr_psoc * psoc,bool value)2292 ucfg_mlme_cfg_set_vht_ldpc_coding_cap(struct wlan_objmgr_psoc *psoc, bool value) 2293 { 2294 return wlan_mlme_cfg_set_vht_ldpc_coding_cap(psoc, value); 2295 } 2296 2297 /** 2298 * ucfg_mlme_cfg_get_short_gi_160_mhz() - Get SHORT GI 160MHZ from cfg item 2299 * @psoc: psoc context 2300 * @value: data to be set 2301 * 2302 * Inline UCFG API to be used by HDD/OSIF callers to get the 2303 * ignore_peer_ht_opmode flag value 2304 * 2305 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2306 */ 2307 static inline QDF_STATUS ucfg_mlme_cfg_get_short_gi_160_mhz(struct wlan_objmgr_psoc * psoc,bool * value)2308 ucfg_mlme_cfg_get_short_gi_160_mhz(struct wlan_objmgr_psoc *psoc, bool *value) 2309 { 2310 return wlan_mlme_cfg_get_short_gi_160_mhz(psoc, value); 2311 } 2312 2313 /** 2314 * ucfg_mlme_cfg_set_short_gi_160_mhz() - sets basic set SHORT GI 160MHZ into 2315 * cfg item 2316 * @psoc: psoc context 2317 * @value: data to be set 2318 * 2319 * Inline UCFG API to be used by HDD/OSIF callers to get the 2320 * ignore_peer_ht_opmode flag value 2321 * 2322 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2323 */ 2324 static inline QDF_STATUS ucfg_mlme_cfg_set_short_gi_160_mhz(struct wlan_objmgr_psoc * psoc,bool value)2325 ucfg_mlme_cfg_set_short_gi_160_mhz(struct wlan_objmgr_psoc *psoc, bool value) 2326 { 2327 return wlan_mlme_cfg_set_short_gi_160_mhz(psoc, value); 2328 } 2329 2330 /** 2331 * ucfg_mlme_cfg_get_vht_tx_stbc() - gets vht tx stbc from 2332 * cfg item 2333 * @psoc: psoc context 2334 * @value: pointer to get required data 2335 * 2336 * Inline UCFG API to be used by HDD/OSIF callers to get the 2337 * ignore_peer_ht_opmode flag value 2338 * 2339 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2340 */ 2341 static inline QDF_STATUS ucfg_mlme_cfg_get_vht_tx_stbc(struct wlan_objmgr_psoc * psoc,bool * value)2342 ucfg_mlme_cfg_get_vht_tx_stbc(struct wlan_objmgr_psoc *psoc, bool *value) 2343 { 2344 return wlan_mlme_cfg_get_vht_tx_stbc(psoc, value); 2345 } 2346 2347 /** 2348 * ucfg_mlme_cfg_get_vht_rx_stbc() - gets vht rx stbc from 2349 * cfg item 2350 * @psoc: psoc context 2351 * @value: pointer to get required data 2352 * 2353 * Inline UCFG API to be used by HDD/OSIF callers to get the 2354 * ignore_peer_ht_opmode flag value 2355 * 2356 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2357 */ 2358 static inline QDF_STATUS ucfg_mlme_cfg_get_vht_rx_stbc(struct wlan_objmgr_psoc * psoc,bool * value)2359 ucfg_mlme_cfg_get_vht_rx_stbc(struct wlan_objmgr_psoc *psoc, bool *value) 2360 { 2361 return wlan_mlme_cfg_get_vht_rx_stbc(psoc, value); 2362 } 2363 2364 /** 2365 * ucfg_mlme_cfg_set_vht_tx_bfee_ant_supp() - sets vht Beamformee antenna 2366 * support cap into cfg item 2367 * @psoc: psoc context 2368 * @value: data to be set 2369 * 2370 * Inline UCFG API to be used by HDD/OSIF callers 2371 * 2372 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2373 */ 2374 static inline ucfg_mlme_cfg_set_vht_tx_bfee_ant_supp(struct wlan_objmgr_psoc * psoc,uint8_t value)2375 QDF_STATUS ucfg_mlme_cfg_set_vht_tx_bfee_ant_supp(struct wlan_objmgr_psoc *psoc, 2376 uint8_t value) 2377 { 2378 return wlan_mlme_cfg_set_vht_tx_bfee_ant_supp(psoc, value); 2379 } 2380 2381 /** 2382 * ucfg_mlme_cfg_get_vht_tx_bfee_ant_supp() - gets vht Beamformee antenna 2383 * support cap into cfg item 2384 * @psoc: psoc context 2385 * @value: data to be set 2386 * 2387 * Inline UCFG API to be used by HDD/OSIF callers 2388 * 2389 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2390 */ 2391 static inline ucfg_mlme_cfg_get_vht_tx_bfee_ant_supp(struct wlan_objmgr_psoc * psoc,uint8_t * value)2392 QDF_STATUS ucfg_mlme_cfg_get_vht_tx_bfee_ant_supp(struct wlan_objmgr_psoc *psoc, 2393 uint8_t *value) 2394 { 2395 return wlan_mlme_cfg_get_vht_tx_bfee_ant_supp(psoc, value); 2396 } 2397 2398 /** 2399 * ucfg_mlme_cfg_get_vht_rx_mcs_map() - gets vht rx mcs map from 2400 * cfg item 2401 * @psoc: psoc context 2402 * @value: pointer to get required data 2403 * 2404 * Inline UCFG API to be used by HDD/OSIF callers to get the 2405 * ignore_peer_ht_opmode flag value 2406 * 2407 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2408 */ 2409 static inline QDF_STATUS ucfg_mlme_cfg_get_vht_rx_mcs_map(struct wlan_objmgr_psoc * psoc,uint32_t * value)2410 ucfg_mlme_cfg_get_vht_rx_mcs_map(struct wlan_objmgr_psoc *psoc, uint32_t *value) 2411 { 2412 return wlan_mlme_cfg_get_vht_rx_mcs_map(psoc, value); 2413 } 2414 2415 /** 2416 * ucfg_mlme_cfg_set_vht_rx_mcs_map() - sets rx mcs map into 2417 * cfg item 2418 * @psoc: psoc context 2419 * @value: data to be set 2420 * 2421 * Inline UCFG API to be used by HDD/OSIF callers 2422 * 2423 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2424 */ 2425 static inline QDF_STATUS ucfg_mlme_cfg_set_vht_rx_mcs_map(struct wlan_objmgr_psoc * psoc,uint32_t value)2426 ucfg_mlme_cfg_set_vht_rx_mcs_map(struct wlan_objmgr_psoc *psoc, uint32_t value) 2427 { 2428 return wlan_mlme_cfg_set_vht_rx_mcs_map(psoc, value); 2429 } 2430 2431 /** 2432 * ucfg_mlme_cfg_get_vht_tx_mcs_map() - gets vht tx mcs map from 2433 * cfg item 2434 * @psoc: psoc context 2435 * @value: pointer to get required data 2436 * 2437 * Inline UCFG API to be used by HDD/OSIF callers to get the 2438 * ignore_peer_ht_opmode flag value 2439 * 2440 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2441 */ 2442 static inline QDF_STATUS ucfg_mlme_cfg_get_vht_tx_mcs_map(struct wlan_objmgr_psoc * psoc,uint32_t * value)2443 ucfg_mlme_cfg_get_vht_tx_mcs_map(struct wlan_objmgr_psoc *psoc, uint32_t *value) 2444 { 2445 return wlan_mlme_cfg_get_vht_tx_mcs_map(psoc, value); 2446 } 2447 2448 /** 2449 * ucfg_mlme_cfg_set_vht_tx_mcs_map() - sets tx mcs map into 2450 * cfg item 2451 * @psoc: psoc context 2452 * @value: data to be set 2453 * 2454 * Inline UCFG API to be used by HDD/OSIF callers 2455 * 2456 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2457 */ 2458 static inline QDF_STATUS ucfg_mlme_cfg_set_vht_tx_mcs_map(struct wlan_objmgr_psoc * psoc,uint32_t value)2459 ucfg_mlme_cfg_set_vht_tx_mcs_map(struct wlan_objmgr_psoc *psoc, uint32_t value) 2460 { 2461 return wlan_mlme_cfg_set_vht_tx_mcs_map(psoc, value); 2462 } 2463 2464 /** 2465 * ucfg_mlme_cfg_set_vht_rx_supp_data_rate() - sets rx supported data 2466 * rate into cfg item 2467 * @psoc: psoc context 2468 * @value: data to be set 2469 * 2470 * Inline UCFG API to be used by HDD/OSIF callers 2471 * 2472 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2473 */ 2474 static inline QDF_STATUS ucfg_mlme_cfg_set_vht_rx_supp_data_rate(struct wlan_objmgr_psoc * psoc,uint32_t value)2475 ucfg_mlme_cfg_set_vht_rx_supp_data_rate(struct wlan_objmgr_psoc *psoc, 2476 uint32_t value) 2477 { 2478 return wlan_mlme_cfg_set_vht_rx_supp_data_rate(psoc, value); 2479 } 2480 2481 /** 2482 * ucfg_mlme_cfg_set_vht_tx_supp_data_rate() - sets tx supported data rate into 2483 * cfg item 2484 * @psoc: psoc context 2485 * @value: data to be set 2486 * 2487 * Inline UCFG API to be used by HDD/OSIF callers 2488 * 2489 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2490 */ 2491 static inline QDF_STATUS ucfg_mlme_cfg_set_vht_tx_supp_data_rate(struct wlan_objmgr_psoc * psoc,uint32_t value)2492 ucfg_mlme_cfg_set_vht_tx_supp_data_rate(struct wlan_objmgr_psoc *psoc, 2493 uint32_t value) 2494 { 2495 return wlan_mlme_cfg_set_vht_tx_supp_data_rate(psoc, value); 2496 } 2497 2498 /** 2499 * ucfg_mlme_cfg_get_vht_basic_mcs_set() - gets basic mcs set from 2500 * cfg item 2501 * @psoc: psoc context 2502 * @value: data to be set 2503 * 2504 * Inline UCFG API to be used by HDD/OSIF callers to get the 2505 * ignore_peer_ht_opmode flag value 2506 * 2507 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2508 */ 2509 static inline QDF_STATUS ucfg_mlme_cfg_get_vht_basic_mcs_set(struct wlan_objmgr_psoc * psoc,uint32_t * value)2510 ucfg_mlme_cfg_get_vht_basic_mcs_set(struct wlan_objmgr_psoc *psoc, 2511 uint32_t *value) 2512 { 2513 return wlan_mlme_cfg_get_vht_basic_mcs_set(psoc, value); 2514 } 2515 2516 /** 2517 * ucfg_mlme_cfg_set_vht_basic_mcs_set() - sets basic mcs set into 2518 * cfg item 2519 * @psoc: psoc context 2520 * @value: data to be set 2521 * 2522 * Inline UCFG API to be used by HDD/OSIF callers to get the 2523 * ignore_peer_ht_opmode flag value 2524 * 2525 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2526 */ 2527 static inline QDF_STATUS ucfg_mlme_cfg_set_vht_basic_mcs_set(struct wlan_objmgr_psoc * psoc,uint32_t value)2528 ucfg_mlme_cfg_set_vht_basic_mcs_set(struct wlan_objmgr_psoc *psoc, 2529 uint32_t value) 2530 { 2531 return wlan_mlme_cfg_set_vht_basic_mcs_set(psoc, value); 2532 } 2533 2534 /** 2535 * ucfg_mlme_get_vht_enable_tx_bf() - gets enable TXBF for 20MHZ 2536 * for 11ac 2537 * @psoc: psoc context 2538 * @value: data to be set 2539 * 2540 * Inline UCFG API to be used by HDD/OSIF callers to get the 2541 * ignore_peer_ht_opmode flag value 2542 * 2543 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2544 */ 2545 static inline QDF_STATUS ucfg_mlme_get_vht_enable_tx_bf(struct wlan_objmgr_psoc * psoc,bool * value)2546 ucfg_mlme_get_vht_enable_tx_bf(struct wlan_objmgr_psoc *psoc, bool *value) 2547 { 2548 return wlan_mlme_get_vht_enable_tx_bf(psoc, value); 2549 } 2550 2551 /** 2552 * ucfg_mlme_get_vht_tx_su_beamformer() - gets enable tx_su_beamformer 2553 * for 11ac 2554 * @psoc: psoc context 2555 * @value: data to be set 2556 * 2557 * Inline UCFG API to be used by HDD/OSIF callers to get the 2558 * ignore_peer_ht_opmode flag value 2559 * 2560 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2561 */ 2562 static inline QDF_STATUS ucfg_mlme_get_vht_tx_su_beamformer(struct wlan_objmgr_psoc * psoc,bool * value)2563 ucfg_mlme_get_vht_tx_su_beamformer(struct wlan_objmgr_psoc *psoc, bool *value) 2564 { 2565 return wlan_mlme_get_vht_tx_su_beamformer(psoc, value); 2566 } 2567 2568 /** 2569 * ucfg_mlme_get_vht_channel_width() - gets Channel width capability 2570 * for 11ac 2571 * @psoc: psoc context 2572 * @value: data to be set 2573 * 2574 * Inline UCFG API to be used by HDD/OSIF callers to get the 2575 * ignore_peer_ht_opmode flag value 2576 * 2577 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2578 */ 2579 static inline QDF_STATUS ucfg_mlme_get_vht_channel_width(struct wlan_objmgr_psoc * psoc,uint8_t * value)2580 ucfg_mlme_get_vht_channel_width(struct wlan_objmgr_psoc *psoc, uint8_t *value) 2581 { 2582 return wlan_mlme_get_vht_channel_width(psoc, value); 2583 } 2584 2585 /** 2586 * ucfg_mlme_get_vht_rx_mcs_8_9() - VHT Rx MCS capability for 1x1 mode 2587 * for 11ac 2588 * @psoc: psoc context 2589 * @value: data to be set 2590 * 2591 * Inline UCFG API to be used by HDD/OSIF callers to get the 2592 * ignore_peer_ht_opmode flag value 2593 * 2594 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2595 */ 2596 static inline QDF_STATUS ucfg_mlme_get_vht_rx_mcs_8_9(struct wlan_objmgr_psoc * psoc,uint8_t * value)2597 ucfg_mlme_get_vht_rx_mcs_8_9(struct wlan_objmgr_psoc *psoc, uint8_t *value) 2598 { 2599 return wlan_mlme_get_vht_rx_mcs_8_9(psoc, value); 2600 } 2601 2602 /** 2603 * ucfg_mlme_get_vht_tx_mcs_8_9() - VHT Tx MCS capability for 1x1 mode 2604 * for 11ac 2605 * @psoc: psoc context 2606 * @value: data to be set 2607 * 2608 * Inline UCFG API to be used by HDD/OSIF callers to get the 2609 * ignore_peer_ht_opmode flag value 2610 * 2611 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2612 */ 2613 static inline QDF_STATUS ucfg_mlme_get_vht_tx_mcs_8_9(struct wlan_objmgr_psoc * psoc,uint8_t * value)2614 ucfg_mlme_get_vht_tx_mcs_8_9(struct wlan_objmgr_psoc *psoc, uint8_t *value) 2615 { 2616 return wlan_mlme_get_vht_tx_mcs_8_9(psoc, value); 2617 } 2618 2619 /** 2620 * ucfg_mlme_get_vht_rx_mcs_2x2() - VHT Rx MCS capability for 2x2 mode 2621 * for 11ac 2622 * @psoc: psoc context 2623 * @value: data to be set 2624 * 2625 * Inline UCFG API to be used by HDD/OSIF callers to get the 2626 * ignore_peer_ht_opmode flag value 2627 * 2628 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2629 */ 2630 static inline QDF_STATUS ucfg_mlme_get_vht_rx_mcs_2x2(struct wlan_objmgr_psoc * psoc,uint8_t * value)2631 ucfg_mlme_get_vht_rx_mcs_2x2(struct wlan_objmgr_psoc *psoc, uint8_t *value) 2632 { 2633 return wlan_mlme_get_vht_rx_mcs_2x2(psoc, value); 2634 } 2635 2636 /** 2637 * ucfg_mlme_get_vht_tx_mcs_2x2() - VHT Tx MCS capability for 2x2 mode 2638 * for 11ac 2639 * @psoc: psoc context 2640 * @value: data to be set 2641 * 2642 * Inline UCFG API to be used by HDD/OSIF callers to get the 2643 * ignore_peer_ht_opmode flag value 2644 * 2645 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2646 */ 2647 static inline QDF_STATUS ucfg_mlme_get_vht_tx_mcs_2x2(struct wlan_objmgr_psoc * psoc,uint8_t * value)2648 ucfg_mlme_get_vht_tx_mcs_2x2(struct wlan_objmgr_psoc *psoc, uint8_t *value) 2649 { 2650 return wlan_mlme_get_vht_tx_mcs_2x2(psoc, value); 2651 } 2652 2653 /** 2654 * ucfg_mlme_peer_get_assoc_rsp_ies() - Get assoc response sent to peer 2655 * @peer: WLAN peer objmgr 2656 * @ie_buf: Pointer to IE buffer 2657 * @ie_len: Length of the IE buffer 2658 * 2659 * This API is used to get the assoc response sent to peer 2660 * as part of association. 2661 * Caller to hold reference for peer. 2662 * 2663 * Return: QDF_STATUS 2664 */ 2665 static inline QDF_STATUS ucfg_mlme_peer_get_assoc_rsp_ies(struct wlan_objmgr_peer * peer,const uint8_t ** ie_buf,size_t * ie_len)2666 ucfg_mlme_peer_get_assoc_rsp_ies(struct wlan_objmgr_peer *peer, 2667 const uint8_t **ie_buf, 2668 size_t *ie_len) 2669 { 2670 return wlan_mlme_peer_get_assoc_rsp_ies(peer, ie_buf, ie_len); 2671 } 2672 2673 /** 2674 * ucfg_mlme_get_ini_vdev_config() - get the ini capability of vdev 2675 * @vdev: pointer to the vdev obj 2676 * 2677 * This API will get the ini config of the vdev related to 2678 * the nss, chains params 2679 * 2680 * Return: pointer to the nss, chain param ini cfg structure 2681 */ 2682 static inline struct wlan_mlme_nss_chains * ucfg_mlme_get_ini_vdev_config(struct wlan_objmgr_vdev * vdev)2683 ucfg_mlme_get_ini_vdev_config(struct wlan_objmgr_vdev *vdev) 2684 { 2685 return mlme_get_ini_vdev_config(vdev); 2686 } 2687 2688 /** 2689 * ucfg_mlme_get_dynamic_vdev_config() - get the dynamic capability of vdev 2690 * @vdev: pointer to the vdev obj 2691 * 2692 * This API will get the dynamic config of the vdev related to nss, 2693 * chains params 2694 * 2695 * Return: pointer to the nss, chain param dynamic cfg structure 2696 */ 2697 static inline struct wlan_mlme_nss_chains * ucfg_mlme_get_dynamic_vdev_config(struct wlan_objmgr_vdev * vdev)2698 ucfg_mlme_get_dynamic_vdev_config(struct wlan_objmgr_vdev *vdev) 2699 { 2700 return mlme_get_dynamic_vdev_config(vdev); 2701 } 2702 2703 /** 2704 * ucfg_mlme_get_vht20_mcs9() - Enables VHT MCS9 in 20M BW operation 2705 * @psoc: psoc context 2706 * @value: data to be set 2707 * 2708 * Inline UCFG API to be used by HDD/OSIF callers to get the 2709 * ignore_peer_ht_opmode flag value 2710 * 2711 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2712 */ 2713 static inline QDF_STATUS ucfg_mlme_get_vht20_mcs9(struct wlan_objmgr_psoc * psoc,bool * value)2714 ucfg_mlme_get_vht20_mcs9(struct wlan_objmgr_psoc *psoc, bool *value) 2715 { 2716 return wlan_mlme_get_vht20_mcs9(psoc, value); 2717 } 2718 2719 /** 2720 * ucfg_mlme_get_enable_dynamic_nss_chains_cfg() - API to get whether dynamic 2721 * nss and chain config is enabled or not 2722 * @psoc: psoc context 2723 * @value: data to be set 2724 * 2725 * API to get whether dynamic nss and chain config is enabled or not 2726 * 2727 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2728 */ 2729 static inline QDF_STATUS ucfg_mlme_get_enable_dynamic_nss_chains_cfg(struct wlan_objmgr_psoc * psoc,bool * value)2730 ucfg_mlme_get_enable_dynamic_nss_chains_cfg(struct wlan_objmgr_psoc *psoc, 2731 bool *value) 2732 { 2733 return wlan_mlme_get_enable_dynamic_nss_chains_cfg(psoc, value); 2734 } 2735 2736 /** 2737 * ucfg_mlme_get_restart_sap_on_dynamic_nss_chains_cfg() - API to get whether 2738 * SAP needs to be restarted or not on dynamic nss chain config 2739 * @psoc: psoc context 2740 * @value: data to be set 2741 * 2742 * API to get whether SAP needs to be restarted or not on dynamic nss chain 2743 * config 2744 * 2745 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2746 */ 2747 static inline QDF_STATUS ucfg_mlme_get_restart_sap_on_dynamic_nss_chains_cfg(struct wlan_objmgr_psoc * psoc,bool * value)2748 ucfg_mlme_get_restart_sap_on_dynamic_nss_chains_cfg( 2749 struct wlan_objmgr_psoc *psoc, 2750 bool *value) 2751 { 2752 return wlan_mlme_get_restart_sap_on_dynamic_nss_chains_cfg(psoc, value); 2753 } 2754 2755 /** 2756 * ucfg_mlme_update_dynamic_nss_chains_support() - API to update 2757 * dynamic_nss_chains_support 2758 * 2759 * @psoc: psoc context 2760 * @val: data to be set 2761 * 2762 * API is used to update dynamic_nss_chains_support flag in wlan_mlme_cfg 2763 * to maintain this value in mlme context 2764 * 2765 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2766 */ 2767 static inline QDF_STATUS ucfg_mlme_update_dynamic_nss_chains_support(struct wlan_objmgr_psoc * psoc,bool val)2768 ucfg_mlme_update_dynamic_nss_chains_support(struct wlan_objmgr_psoc *psoc, 2769 bool val) 2770 { 2771 return wlan_mlme_cfg_set_dynamic_nss_chains_support(psoc, val); 2772 } 2773 2774 /** 2775 * ucfg_mlme_get_sta_num_tx_chains() - UCFG API to get station num tx chains 2776 * 2777 * @psoc: psoc context 2778 * @vdev: pointer to vdev 2779 * @tx_chains : tx_chains out parameter 2780 * 2781 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2782 */ 2783 static inline QDF_STATUS ucfg_mlme_get_sta_num_tx_chains(struct wlan_objmgr_psoc * psoc,struct wlan_objmgr_vdev * vdev,uint8_t * tx_chains)2784 ucfg_mlme_get_sta_num_tx_chains(struct wlan_objmgr_psoc *psoc, 2785 struct wlan_objmgr_vdev *vdev, 2786 uint8_t *tx_chains) 2787 { 2788 return wlan_mlme_get_sta_num_tx_chains(psoc, vdev, tx_chains); 2789 } 2790 2791 /** 2792 * ucfg_mlme_get_sta_num_rx_chains() - UCFG API to get station num rx chains 2793 * 2794 * @psoc: psoc context 2795 * @vdev: pointer to vdev 2796 * @rx_chains : rx_chains out parameter 2797 * 2798 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2799 */ 2800 static inline QDF_STATUS ucfg_mlme_get_sta_num_rx_chains(struct wlan_objmgr_psoc * psoc,struct wlan_objmgr_vdev * vdev,uint8_t * rx_chains)2801 ucfg_mlme_get_sta_num_rx_chains(struct wlan_objmgr_psoc *psoc, 2802 struct wlan_objmgr_vdev *vdev, 2803 uint8_t *rx_chains) 2804 { 2805 return wlan_mlme_get_sta_num_rx_chains(psoc, vdev, rx_chains); 2806 } 2807 2808 /** 2809 * ucfg_mlme_get_sta_tx_nss() - UCFG API to get station tx NSS 2810 * 2811 * @psoc: psoc context 2812 * @vdev: pointer to vdev 2813 * @tx_nss : tx_nss out parameter 2814 * 2815 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2816 */ 2817 static inline QDF_STATUS ucfg_mlme_get_sta_tx_nss(struct wlan_objmgr_psoc * psoc,struct wlan_objmgr_vdev * vdev,uint8_t * tx_nss)2818 ucfg_mlme_get_sta_tx_nss(struct wlan_objmgr_psoc *psoc, 2819 struct wlan_objmgr_vdev *vdev, uint8_t *tx_nss) 2820 { 2821 return wlan_mlme_get_sta_tx_nss(psoc, vdev, tx_nss); 2822 } 2823 2824 /** 2825 * ucfg_mlme_get_sta_rx_nss() - UCFG API to get station rx NSS 2826 * 2827 * @psoc: psoc context 2828 * @vdev: pointer to vdev 2829 * @rx_nss : rx_nss out parameter 2830 * 2831 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2832 */ 2833 static inline QDF_STATUS ucfg_mlme_get_sta_rx_nss(struct wlan_objmgr_psoc * psoc,struct wlan_objmgr_vdev * vdev,uint8_t * rx_nss)2834 ucfg_mlme_get_sta_rx_nss(struct wlan_objmgr_psoc *psoc, 2835 struct wlan_objmgr_vdev *vdev, 2836 uint8_t *rx_nss) 2837 { 2838 return wlan_mlme_get_sta_rx_nss(psoc, vdev, rx_nss); 2839 } 2840 2841 /** 2842 * ucfg_mlme_get_vht_enable2x2() - Enables/disables VHT Tx/Rx MCS values for 2x2 2843 * @psoc: psoc context 2844 * @value: data to be set 2845 * 2846 * Inline UCFG API to be used by HDD/OSIF callers to get the 2847 * ignore_peer_ht_opmode flag value 2848 * 2849 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2850 */ 2851 static inline QDF_STATUS ucfg_mlme_get_vht_enable2x2(struct wlan_objmgr_psoc * psoc,bool * value)2852 ucfg_mlme_get_vht_enable2x2(struct wlan_objmgr_psoc *psoc, bool *value) 2853 { 2854 return wlan_mlme_get_vht_enable2x2(psoc, value); 2855 } 2856 2857 /** 2858 * ucfg_mlme_get_force_sap_enabled() - Get the value of force SAP enabled 2859 * @psoc: psoc context 2860 * @value: data to get 2861 * 2862 * Get the value of force SAP enabled 2863 * 2864 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2865 */ 2866 static inline QDF_STATUS ucfg_mlme_get_force_sap_enabled(struct wlan_objmgr_psoc * psoc,bool * value)2867 ucfg_mlme_get_force_sap_enabled(struct wlan_objmgr_psoc *psoc, bool *value) 2868 { 2869 return wlan_mlme_get_force_sap_enabled(psoc, value); 2870 } 2871 2872 /** 2873 * ucfg_mlme_set_vht_enable2x2() - Enables/disables VHT Tx/Rx MCS values for 2x2 2874 * @psoc: psoc context 2875 * @value: data to be set 2876 * 2877 * Inline UCFG API to be used by HDD/OSIF callers to get the 2878 * ignore_peer_ht_opmode flag value 2879 * 2880 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2881 */ 2882 static inline QDF_STATUS ucfg_mlme_set_vht_enable2x2(struct wlan_objmgr_psoc * psoc,bool value)2883 ucfg_mlme_set_vht_enable2x2(struct wlan_objmgr_psoc *psoc, bool value) 2884 { 2885 return wlan_mlme_set_vht_enable2x2(psoc, value); 2886 } 2887 2888 /** 2889 * ucfg_mlme_get_vht_enable_paid() - Enables/disables paid feature 2890 * @psoc: psoc context 2891 * @value: data to be set 2892 * 2893 * Inline UCFG API to be used by HDD/OSIF callers to get the 2894 * ignore_peer_ht_opmode flag value 2895 * 2896 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2897 */ 2898 static inline QDF_STATUS ucfg_mlme_get_vht_enable_paid(struct wlan_objmgr_psoc * psoc,bool * value)2899 ucfg_mlme_get_vht_enable_paid(struct wlan_objmgr_psoc *psoc, bool *value) 2900 { 2901 return wlan_mlme_get_vht_enable_paid(psoc, value); 2902 } 2903 2904 /** 2905 * ucfg_mlme_get_vht_enable_gid() - Enables/disables gid feature 2906 * @psoc: psoc context 2907 * @value: data to be set 2908 * 2909 * Inline UCFG API to be used by HDD/OSIF callers to get the 2910 * ignore_peer_ht_opmode flag value 2911 * 2912 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2913 */ 2914 static inline QDF_STATUS ucfg_mlme_get_vht_enable_gid(struct wlan_objmgr_psoc * psoc,bool * value)2915 ucfg_mlme_get_vht_enable_gid(struct wlan_objmgr_psoc *psoc, bool *value) 2916 { 2917 return wlan_mlme_get_vht_enable_gid(psoc, value); 2918 } 2919 2920 /** 2921 * ucfg_mlme_get_vht_for_24ghz() - Get mlme cfg of vht for 24ghz 2922 * @psoc: psoc context 2923 * @value: data to get 2924 * 2925 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2926 */ 2927 static inline QDF_STATUS ucfg_mlme_get_vht_for_24ghz(struct wlan_objmgr_psoc * psoc,bool * value)2928 ucfg_mlme_get_vht_for_24ghz(struct wlan_objmgr_psoc *psoc, bool *value) 2929 { 2930 return wlan_mlme_get_vht_for_24ghz(psoc, value); 2931 } 2932 2933 /** 2934 * ucfg_mlme_set_vht_for_24ghz() - Enables/disables vht for 24ghz 2935 * @psoc: psoc context 2936 * @value: data to be set 2937 * 2938 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2939 */ 2940 static inline QDF_STATUS ucfg_mlme_set_vht_for_24ghz(struct wlan_objmgr_psoc * psoc,bool value)2941 ucfg_mlme_set_vht_for_24ghz(struct wlan_objmgr_psoc *psoc, bool value) 2942 { 2943 return wlan_mlme_set_vht_for_24ghz(psoc, value); 2944 } 2945 2946 /** 2947 * ucfg_mlme_get_vendor_vht_for_24ghz() - Get mlme cfg of vendor vht for 24ghz 2948 * @psoc: psoc context 2949 * @value: data to be set 2950 * 2951 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2952 */ 2953 static inline QDF_STATUS ucfg_mlme_get_vendor_vht_for_24ghz(struct wlan_objmgr_psoc * psoc,bool * value)2954 ucfg_mlme_get_vendor_vht_for_24ghz(struct wlan_objmgr_psoc *psoc, bool *value) 2955 { 2956 return wlan_mlme_get_vendor_vht_for_24ghz(psoc, value); 2957 } 2958 2959 /** 2960 * ucfg_mlme_update_vht_cap() - Update vht capabilities 2961 * @psoc: psoc context 2962 * @cfg: data to be set 2963 * 2964 * Inline UCFG API to be used by HDD/OSIF callers to get the 2965 * ignore_peer_ht_opmode flag value 2966 * 2967 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2968 */ 2969 static inline ucfg_mlme_update_vht_cap(struct wlan_objmgr_psoc * psoc,struct wma_tgt_vht_cap * cfg)2970 QDF_STATUS ucfg_mlme_update_vht_cap(struct wlan_objmgr_psoc *psoc, 2971 struct wma_tgt_vht_cap *cfg) 2972 { 2973 return mlme_update_vht_cap(psoc, cfg); 2974 } 2975 2976 /** 2977 * ucfg_mlme_update_nss_vht_cap() - Update the number of spatial 2978 * streams supported for vht 2979 * @psoc: psoc context 2980 * 2981 * Inline UCFG API to be used by HDD/OSIF callers to get the 2982 * ignore_peer_ht_opmode flag value 2983 * 2984 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 2985 */ 2986 static inline QDF_STATUS ucfg_mlme_update_nss_vht_cap(struct wlan_objmgr_psoc * psoc)2987 ucfg_mlme_update_nss_vht_cap(struct wlan_objmgr_psoc *psoc) 2988 { 2989 return mlme_update_nss_vht_cap(psoc); 2990 } 2991 2992 /** 2993 * ucfg_mlme_is_11h_enabled() - Get 11h flag 2994 * @psoc: pointer to psoc object 2995 * @value: Value that needs to be set from the caller 2996 * 2997 * Inline UCFG API to be used by HDD/OSIF callers 2998 * 2999 * Return: QDF Status 3000 */ 3001 static inline QDF_STATUS ucfg_mlme_is_11h_enabled(struct wlan_objmgr_psoc * psoc,bool * value)3002 ucfg_mlme_is_11h_enabled(struct wlan_objmgr_psoc *psoc, bool *value) 3003 { 3004 return wlan_mlme_is_11h_enabled(psoc, value); 3005 } 3006 3007 /** 3008 * ucfg_mlme_set_11h_enabled() - Set 11h flag 3009 * @psoc: pointer to psoc object 3010 * @value: Value that needs to be set from the caller 3011 * 3012 * Inline UCFG API to be used by HDD/OSIF callers 3013 * 3014 * Return: QDF Status 3015 */ 3016 static inline QDF_STATUS ucfg_mlme_set_11h_enabled(struct wlan_objmgr_psoc * psoc,bool value)3017 ucfg_mlme_set_11h_enabled(struct wlan_objmgr_psoc *psoc, bool value) 3018 { 3019 return wlan_mlme_set_11h_enabled(psoc, value); 3020 } 3021 3022 /** 3023 * ucfg_mlme_is_11d_enabled() - Get 11d flag 3024 * @psoc: pointer to psoc object 3025 * @value: Value that needs to be set from the caller 3026 * 3027 * Inline UCFG API to be used by HDD/OSIF callers 3028 * 3029 * Return: QDF Status 3030 */ 3031 static inline QDF_STATUS ucfg_mlme_is_11d_enabled(struct wlan_objmgr_psoc * psoc,bool * value)3032 ucfg_mlme_is_11d_enabled(struct wlan_objmgr_psoc *psoc, bool *value) 3033 { 3034 return wlan_mlme_is_11d_enabled(psoc, value); 3035 } 3036 3037 /** 3038 * ucfg_mlme_set_11d_enabled() - Set 11d flag 3039 * @psoc: pointer to psoc object 3040 * @value: Value that needs to be set from the caller 3041 * 3042 * Inline UCFG API to be used by HDD/OSIF callers 3043 * 3044 * Return: QDF Status 3045 */ 3046 static inline QDF_STATUS ucfg_mlme_set_11d_enabled(struct wlan_objmgr_psoc * psoc,bool value)3047 ucfg_mlme_set_11d_enabled(struct wlan_objmgr_psoc *psoc, bool value) 3048 { 3049 return wlan_mlme_set_11d_enabled(psoc, value); 3050 } 3051 3052 /** 3053 * ucfg_mlme_is_rf_test_mode_enabled() - Get rf test mode flag 3054 * @psoc: pointer to psoc object 3055 * @value: Value that needs to be set from the caller 3056 * 3057 * Inline UCFG API to be used by HDD/OSIF callers 3058 * 3059 * Return: QDF Status 3060 */ 3061 static inline QDF_STATUS ucfg_mlme_is_rf_test_mode_enabled(struct wlan_objmgr_psoc * psoc,bool * value)3062 ucfg_mlme_is_rf_test_mode_enabled(struct wlan_objmgr_psoc *psoc, bool *value) 3063 { 3064 return wlan_mlme_is_rf_test_mode_enabled(psoc, value); 3065 } 3066 3067 /** 3068 * ucfg_mlme_set_rf_test_mode_enabled() - Set rf test mode flag 3069 * @psoc: pointer to psoc object 3070 * @value: Value that needs to be set from the caller 3071 * 3072 * Inline UCFG API to be used by HDD/OSIF callers 3073 * 3074 * Return: QDF Status 3075 */ 3076 static inline QDF_STATUS ucfg_mlme_set_rf_test_mode_enabled(struct wlan_objmgr_psoc * psoc,bool value)3077 ucfg_mlme_set_rf_test_mode_enabled(struct wlan_objmgr_psoc *psoc, bool value) 3078 { 3079 return wlan_mlme_set_rf_test_mode_enabled(psoc, value); 3080 } 3081 3082 /** 3083 * ucfg_mlme_is_disable_vlp_sta_conn_to_sp_ap_enabled() - Get disable vlp sta 3084 * conn to sp ap flag 3085 * @psoc: pointer to psoc object 3086 * @value: pointer to hold the value of flag 3087 * 3088 * Inline UCFG API to be used by HDD/OSIF callers 3089 * 3090 * Return: QDF Status 3091 */ 3092 static inline QDF_STATUS ucfg_mlme_is_disable_vlp_sta_conn_to_sp_ap_enabled(struct wlan_objmgr_psoc * psoc,bool * value)3093 ucfg_mlme_is_disable_vlp_sta_conn_to_sp_ap_enabled( 3094 struct wlan_objmgr_psoc *psoc, 3095 bool *value) 3096 { 3097 return wlan_mlme_is_disable_vlp_sta_conn_to_sp_ap_enabled(psoc, value); 3098 } 3099 3100 /** 3101 * ucfg_mlme_is_standard_6ghz_conn_policy_enabled() - Get 6ghz standard 3102 * connection policy flag 3103 * @psoc: pointer to psoc object 3104 * @value: pointer to hold the value of flag 3105 * 3106 * Inline UCFG API to be used by HDD/OSIF callers 3107 * 3108 * Return: QDF Status 3109 */ 3110 static inline QDF_STATUS ucfg_mlme_is_standard_6ghz_conn_policy_enabled(struct wlan_objmgr_psoc * psoc,bool * value)3111 ucfg_mlme_is_standard_6ghz_conn_policy_enabled(struct wlan_objmgr_psoc *psoc, 3112 bool *value) 3113 { 3114 return wlan_mlme_is_standard_6ghz_conn_policy_enabled(psoc, value); 3115 } 3116 3117 /** 3118 * ucfg_mlme_set_eht_mode() - Set EHT mode of operation 3119 * @psoc: pointer to psoc object 3120 * @value: EHT mode value that needs to be set from the caller 3121 * 3122 * Inline UCFG API to be used by HDD/OSIF callers 3123 * 3124 * Return: QDF Status 3125 */ 3126 static inline QDF_STATUS ucfg_mlme_set_eht_mode(struct wlan_objmgr_psoc * psoc,enum wlan_eht_mode value)3127 ucfg_mlme_set_eht_mode(struct wlan_objmgr_psoc *psoc, enum wlan_eht_mode value) 3128 { 3129 return wlan_mlme_set_eht_mode(psoc, value); 3130 } 3131 3132 /** 3133 * ucfg_mlme_get_eht_mode() - Get EHT mode of operation 3134 * @psoc: pointer to psoc object 3135 * @value: EHT mode value that is set by the user 3136 * 3137 * Inline UCFG API to be used by HDD/OSIF callers 3138 * 3139 * Return: QDF Status 3140 */ 3141 static inline QDF_STATUS ucfg_mlme_get_eht_mode(struct wlan_objmgr_psoc * psoc,enum wlan_eht_mode * value)3142 ucfg_mlme_get_eht_mode(struct wlan_objmgr_psoc *psoc, enum wlan_eht_mode *value) 3143 { 3144 return wlan_mlme_get_eht_mode(psoc, value); 3145 } 3146 3147 /** 3148 * ucfg_mlme_is_multipass_sap() - check whether FW supports 3149 * multipass sap capabilities 3150 * @psoc: pointer to psoc object 3151 * 3152 * Inline UCFG API to be used by HDD/OSIF callers 3153 * 3154 * Return: True if FW support mulitpass sap 3155 */ 3156 static inline bool ucfg_mlme_is_multipass_sap(struct wlan_objmgr_psoc * psoc)3157 ucfg_mlme_is_multipass_sap(struct wlan_objmgr_psoc *psoc) 3158 { 3159 return wlan_mlme_is_multipass_sap(psoc); 3160 } 3161 3162 /** 3163 * ucfg_mlme_set_emlsr_mode_enabled() - Set eMLSR mode flag 3164 * @psoc: pointer to psoc object 3165 * @value: Value that needs to be set from the caller 3166 * 3167 * Inline UCFG API to be used by HDD/OSIF callers 3168 * 3169 * Return: QDF Status 3170 */ 3171 static inline QDF_STATUS ucfg_mlme_set_emlsr_mode_enabled(struct wlan_objmgr_psoc * psoc,bool value)3172 ucfg_mlme_set_emlsr_mode_enabled(struct wlan_objmgr_psoc *psoc, bool value) 3173 { 3174 return wlan_mlme_set_emlsr_mode_enabled(psoc, value); 3175 } 3176 3177 /** 3178 * ucfg_mlme_get_emlsr_mode_enabled() - Get eMLSR mode flag 3179 * @psoc: pointer to psoc object 3180 * @value: Value that is set by the user 3181 * 3182 * Inline UCFG API to be used by HDD/OSIF callers 3183 * 3184 * Return: QDF Status 3185 */ 3186 static inline QDF_STATUS ucfg_mlme_get_emlsr_mode_enabled(struct wlan_objmgr_psoc * psoc,bool * value)3187 ucfg_mlme_get_emlsr_mode_enabled(struct wlan_objmgr_psoc *psoc, bool *value) 3188 { 3189 return wlan_mlme_get_emlsr_mode_enabled(psoc, value); 3190 } 3191 3192 /** 3193 * ucfg_mlme_set_t2lm_negotiation_supported() - Enables/disables t2lm 3194 * negotiation support value 3195 * @psoc: psoc context 3196 * @value: data to be set 3197 * 3198 * Inline UCFG API to be used by HDD/OSIF callers to set the 3199 * t2lm negotiation supported value 3200 * 3201 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 3202 */ 3203 static inline QDF_STATUS ucfg_mlme_set_t2lm_negotiation_supported(struct wlan_objmgr_psoc * psoc,bool value)3204 ucfg_mlme_set_t2lm_negotiation_supported(struct wlan_objmgr_psoc *psoc, 3205 bool value) 3206 { 3207 return wlan_mlme_set_t2lm_negotiation_supported(psoc, value); 3208 } 3209 3210 /** 3211 * ucfg_mlme_get_opr_rate() - Get operational rate set 3212 * @vdev: pointer to vdev object 3213 * @buf: buffer to get rates set 3214 * @len: length of the buffer 3215 * 3216 * Return: length of the rates set 3217 */ 3218 static inline qdf_size_t ucfg_mlme_get_opr_rate(struct wlan_objmgr_vdev * vdev,uint8_t * buf,qdf_size_t len)3219 ucfg_mlme_get_opr_rate(struct wlan_objmgr_vdev *vdev, uint8_t *buf, 3220 qdf_size_t len) 3221 { 3222 return mlme_get_opr_rate(vdev, buf, len); 3223 } 3224 3225 /** 3226 * ucfg_mlme_get_ext_opr_rate() - Get extended operational rate set 3227 * @vdev: pointer to vdev object 3228 * @buf: buffer to get rates set 3229 * @len: length of the buffer 3230 * 3231 * Return: length of the rates set 3232 */ 3233 static inline qdf_size_t ucfg_mlme_get_ext_opr_rate(struct wlan_objmgr_vdev * vdev,uint8_t * buf,qdf_size_t len)3234 ucfg_mlme_get_ext_opr_rate(struct wlan_objmgr_vdev *vdev, uint8_t *buf, 3235 qdf_size_t len) 3236 { 3237 return mlme_get_ext_opr_rate(vdev, buf, len); 3238 } 3239 3240 /** 3241 * ucfg_mlme_get_mcs_rate() - Get MCS based rate set 3242 * @vdev: pointer to vdev object 3243 * @buf: buffer to get rates set 3244 * @len: length of the buffer 3245 * 3246 * Return: length of the rates set 3247 */ 3248 static inline qdf_size_t ucfg_mlme_get_mcs_rate(struct wlan_objmgr_vdev * vdev,uint8_t * buf,qdf_size_t len)3249 ucfg_mlme_get_mcs_rate(struct wlan_objmgr_vdev *vdev, uint8_t *buf, 3250 qdf_size_t len) 3251 { 3252 return mlme_get_mcs_rate(vdev, buf, len); 3253 } 3254 3255 /** 3256 * ucfg_mlme_get_supported_mcs_set() - Get Supported MCS set 3257 * @psoc: pointer to psoc object 3258 * @buf: caller buffer to copy mcs set info 3259 * @len: length of the buffer 3260 * Return: QDF Status 3261 */ 3262 QDF_STATUS 3263 ucfg_mlme_get_supported_mcs_set(struct wlan_objmgr_psoc *psoc, uint8_t *buf, 3264 qdf_size_t *len); 3265 3266 /** 3267 * ucfg_mlme_set_supported_mcs_set() - Get Supported MCS set 3268 * @psoc: pointer to psoc object 3269 * @buf: caller buffer having mcs set info 3270 * @len: length of the buffer 3271 * Return: QDF Status 3272 */ 3273 QDF_STATUS 3274 ucfg_mlme_set_supported_mcs_set(struct wlan_objmgr_psoc *psoc, uint8_t *buf, 3275 qdf_size_t len); 3276 3277 /** 3278 * ucfg_mlme_get_current_mcs_set() - Get current MCS set 3279 * @psoc: pointer to psoc object 3280 * @buf: caller buffer to copy mcs set info 3281 * @len: length of the buffer 3282 * Return: QDF Status 3283 */ 3284 QDF_STATUS 3285 ucfg_mlme_get_current_mcs_set(struct wlan_objmgr_psoc *psoc, uint8_t *buf, 3286 qdf_size_t *len); 3287 3288 /** 3289 * ucfg_mlme_get_sta_keepalive_method() - Get sta_keepalive_method 3290 * @psoc: pointer to psoc object 3291 * @val: Value to pass to the caller 3292 * 3293 * Return: QDF Status 3294 */ 3295 QDF_STATUS 3296 ucfg_mlme_get_sta_keepalive_method(struct wlan_objmgr_psoc *psoc, 3297 enum station_keepalive_method *val); 3298 3299 /** 3300 * ucfg_mlme_stats_get_periodic_display_time() - get display time 3301 * @psoc: pointer to psoc object 3302 * @periodic_display_time: buffer to hold value 3303 * 3304 * Return: QDF Status 3305 */ 3306 QDF_STATUS 3307 ucfg_mlme_stats_get_periodic_display_time(struct wlan_objmgr_psoc *psoc, 3308 uint32_t *periodic_display_time); 3309 3310 /** 3311 * ucfg_mlme_stats_get_cfg_values() - get stats cfg values 3312 * @psoc: pointer to psoc object 3313 * @link_speed_rssi_high: link speed high limit 3314 * @link_speed_rssi_mid: link speed high mid 3315 * @link_speed_rssi_low: link speed high low 3316 * @link_speed_rssi_report: link speed report limit 3317 * 3318 * Return: QDF Status 3319 */ 3320 QDF_STATUS 3321 ucfg_mlme_stats_get_cfg_values(struct wlan_objmgr_psoc *psoc, 3322 int *link_speed_rssi_high, 3323 int *link_speed_rssi_mid, 3324 int *link_speed_rssi_low, 3325 uint32_t *link_speed_rssi_report); 3326 3327 /** 3328 * ucfg_mlme_stats_is_link_speed_report_actual() - is link speed report set 3329 * actual 3330 * @psoc: pointer to psoc object 3331 * 3332 * Return: True is report set to actual 3333 */ 3334 bool 3335 ucfg_mlme_stats_is_link_speed_report_actual(struct wlan_objmgr_psoc *psoc); 3336 3337 /** 3338 * ucfg_mlme_stats_is_link_speed_report_max() - is link speed report set max 3339 * @psoc: pointer to psoc object 3340 * 3341 * Return: True is report set to max 3342 */ 3343 bool 3344 ucfg_mlme_stats_is_link_speed_report_max(struct wlan_objmgr_psoc *psoc); 3345 3346 /** 3347 * ucfg_mlme_stats_is_link_speed_report_max_scaled() - is link speed report set 3348 * max scaled 3349 * @psoc: pointer to psoc object 3350 * 3351 * Return: True is report set to max scaled 3352 */ 3353 bool 3354 ucfg_mlme_stats_is_link_speed_report_max_scaled(struct wlan_objmgr_psoc *psoc); 3355 3356 /** 3357 * ucfg_mlme_get_tl_delayed_trgr_frm_int() - Get delay interval(in ms) 3358 * of UAPSD auto trigger. 3359 * @psoc: pointer to psoc object 3360 * @value: Value that needs to be set from the caller 3361 * 3362 * Inline UCFG API to be used by HDD/OSIF callers 3363 * 3364 * Return: None 3365 */ 3366 static inline ucfg_mlme_get_tl_delayed_trgr_frm_int(struct wlan_objmgr_psoc * psoc,uint32_t * value)3367 void ucfg_mlme_get_tl_delayed_trgr_frm_int(struct wlan_objmgr_psoc *psoc, 3368 uint32_t *value) 3369 { 3370 wlan_mlme_get_tl_delayed_trgr_frm_int(psoc, value); 3371 } 3372 3373 /** 3374 * ucfg_mlme_get_wmm_dir_ac_vi() - Get TSPEC direction for VI 3375 * @psoc: pointer to psoc object 3376 * @value: Value that needs to be set from the caller 3377 * 3378 * Inline UCFG API to be used by HDD/OSIF callers 3379 * 3380 * Return: QDF Status 3381 */ 3382 static inline QDF_STATUS ucfg_mlme_get_wmm_dir_ac_vi(struct wlan_objmgr_psoc * psoc,uint8_t * value)3383 ucfg_mlme_get_wmm_dir_ac_vi(struct wlan_objmgr_psoc *psoc, uint8_t *value) 3384 { 3385 return wlan_mlme_get_wmm_dir_ac_vi(psoc, value); 3386 } 3387 3388 /** 3389 * ucfg_mlme_get_wmm_nom_msdu_size_ac_vi() - Get normal MSDU size for VI 3390 * @psoc: pointer to psoc object 3391 * @value: Value that needs to be set from the caller 3392 * 3393 * Inline UCFG API to be used by HDD/OSIF callers 3394 * 3395 * Return: QDF Status 3396 */ 3397 static inline ucfg_mlme_get_wmm_nom_msdu_size_ac_vi(struct wlan_objmgr_psoc * psoc,uint16_t * value)3398 QDF_STATUS ucfg_mlme_get_wmm_nom_msdu_size_ac_vi(struct wlan_objmgr_psoc *psoc, 3399 uint16_t *value) 3400 { 3401 return wlan_mlme_get_wmm_nom_msdu_size_ac_vi(psoc, value); 3402 } 3403 3404 /** 3405 * ucfg_mlme_get_wmm_mean_data_rate_ac_vi() - mean data rate for VI 3406 * @psoc: pointer to psoc object 3407 * @value: Value that needs to be set from the caller 3408 * 3409 * Inline UCFG API to be used by HDD/OSIF callers 3410 * 3411 * Return: QDF Status 3412 */ 3413 static inline ucfg_mlme_get_wmm_mean_data_rate_ac_vi(struct wlan_objmgr_psoc * psoc,uint32_t * value)3414 QDF_STATUS ucfg_mlme_get_wmm_mean_data_rate_ac_vi(struct wlan_objmgr_psoc *psoc, 3415 uint32_t *value) 3416 { 3417 return wlan_mlme_get_wmm_mean_data_rate_ac_vi(psoc, value); 3418 } 3419 3420 /** 3421 * ucfg_mlme_get_wmm_min_phy_rate_ac_vi() - min PHY rate for VI 3422 * @psoc: pointer to psoc object 3423 * @value: Value that needs to be set from the caller 3424 * 3425 * Inline UCFG API to be used by HDD/OSIF callers 3426 * 3427 * Return: QDF Status 3428 */ 3429 static inline ucfg_mlme_get_wmm_min_phy_rate_ac_vi(struct wlan_objmgr_psoc * psoc,uint32_t * value)3430 QDF_STATUS ucfg_mlme_get_wmm_min_phy_rate_ac_vi(struct wlan_objmgr_psoc *psoc, 3431 uint32_t *value) 3432 { 3433 return wlan_mlme_get_wmm_min_phy_rate_ac_vi(psoc, value); 3434 } 3435 3436 /** 3437 * ucfg_mlme_get_wmm_sba_ac_vi() - surplus bandwidth allowance for VI 3438 * @psoc: pointer to psoc object 3439 * @value: Value that needs to be set from the caller 3440 * 3441 * Inline UCFG API to be used by HDD/OSIF callers 3442 * 3443 * Return: QDF Status 3444 */ 3445 static inline QDF_STATUS ucfg_mlme_get_wmm_sba_ac_vi(struct wlan_objmgr_psoc * psoc,uint16_t * value)3446 ucfg_mlme_get_wmm_sba_ac_vi(struct wlan_objmgr_psoc *psoc, uint16_t *value) 3447 { 3448 return wlan_mlme_get_wmm_sba_ac_vi(psoc, value); 3449 } 3450 3451 /** 3452 * ucfg_mlme_get_wmm_uapsd_vi_srv_intv() - Get Uapsd service 3453 * interval for video 3454 * @psoc: pointer to psoc object 3455 * @value: pointer to the value which will be filled for the caller 3456 * 3457 * Inline UCFG API to be used by HDD/OSIF callers 3458 * 3459 * Return: QDF Status 3460 */ 3461 static inline QDF_STATUS ucfg_mlme_get_wmm_uapsd_vi_srv_intv(struct wlan_objmgr_psoc * psoc,uint32_t * value)3462 ucfg_mlme_get_wmm_uapsd_vi_srv_intv(struct wlan_objmgr_psoc *psoc, 3463 uint32_t *value) 3464 { 3465 return wlan_mlme_get_wmm_uapsd_vi_srv_intv(psoc, value); 3466 } 3467 3468 /** 3469 * ucfg_mlme_get_wmm_uapsd_vi_sus_intv() - Get Uapsd suspension 3470 * interval for video 3471 * @psoc: pointer to psoc object 3472 * @value: Value that needs to be set from the caller 3473 * 3474 * Inline UCFG API to be used by HDD/OSIF callers 3475 * 3476 * Return: QDF Status 3477 */ 3478 static inline QDF_STATUS ucfg_mlme_get_wmm_uapsd_vi_sus_intv(struct wlan_objmgr_psoc * psoc,uint32_t * value)3479 ucfg_mlme_get_wmm_uapsd_vi_sus_intv(struct wlan_objmgr_psoc *psoc, 3480 uint32_t *value) 3481 { 3482 return wlan_mlme_get_wmm_uapsd_vi_sus_intv(psoc, value); 3483 } 3484 3485 /** 3486 * ucfg_mlme_get_wmm_dir_ac_be() - Get TSPEC direction for BE 3487 * @psoc: pointer to psoc object 3488 * @value: Value that needs to be set from the caller 3489 * 3490 * Inline UCFG API to be used by HDD/OSIF callers 3491 * 3492 * Return: QDF Status 3493 */ 3494 static inline QDF_STATUS ucfg_mlme_get_wmm_dir_ac_be(struct wlan_objmgr_psoc * psoc,uint8_t * value)3495 ucfg_mlme_get_wmm_dir_ac_be(struct wlan_objmgr_psoc *psoc, uint8_t *value) 3496 { 3497 return wlan_mlme_get_wmm_dir_ac_be(psoc, value); 3498 } 3499 3500 /** 3501 * ucfg_mlme_get_wmm_nom_msdu_size_ac_be() - Get normal MSDU size for BE 3502 * @psoc: pointer to psoc object 3503 * @value: Value that needs to be set from the caller 3504 * 3505 * Inline UCFG API to be used by HDD/OSIF callers 3506 * 3507 * Return: QDF Status 3508 */ 3509 static inline ucfg_mlme_get_wmm_nom_msdu_size_ac_be(struct wlan_objmgr_psoc * psoc,uint16_t * value)3510 QDF_STATUS ucfg_mlme_get_wmm_nom_msdu_size_ac_be(struct wlan_objmgr_psoc *psoc, 3511 uint16_t *value) 3512 { 3513 return wlan_mlme_get_wmm_nom_msdu_size_ac_be(psoc, value); 3514 } 3515 3516 /** 3517 * ucfg_mlme_get_wmm_mean_data_rate_ac_be() - mean data rate for BE 3518 * @psoc: pointer to psoc object 3519 * @value: Value that needs to be set from the caller 3520 * 3521 * Inline UCFG API to be used by HDD/OSIF callers 3522 * 3523 * Return: QDF Status 3524 */ 3525 static inline ucfg_mlme_get_wmm_mean_data_rate_ac_be(struct wlan_objmgr_psoc * psoc,uint32_t * value)3526 QDF_STATUS ucfg_mlme_get_wmm_mean_data_rate_ac_be(struct wlan_objmgr_psoc *psoc, 3527 uint32_t *value) 3528 { 3529 return wlan_mlme_get_wmm_mean_data_rate_ac_be(psoc, value); 3530 } 3531 3532 /** 3533 * ucfg_mlme_get_wmm_min_phy_rate_ac_be() - min PHY rate for BE 3534 * @psoc: pointer to psoc object 3535 * @value: Value that needs to be set from the caller 3536 * 3537 * Inline UCFG API to be used by HDD/OSIF callers 3538 * 3539 * Return: QDF Status 3540 */ 3541 static inline ucfg_mlme_get_wmm_min_phy_rate_ac_be(struct wlan_objmgr_psoc * psoc,uint32_t * value)3542 QDF_STATUS ucfg_mlme_get_wmm_min_phy_rate_ac_be(struct wlan_objmgr_psoc *psoc, 3543 uint32_t *value) 3544 { 3545 return wlan_mlme_get_wmm_min_phy_rate_ac_be(psoc, value); 3546 } 3547 3548 /** 3549 * ucfg_mlme_get_wmm_sba_ac_be() - surplus bandwidth allowance for BE 3550 * @psoc: pointer to psoc object 3551 * @value: Value that needs to be set from the caller 3552 * 3553 * Inline UCFG API to be used by HDD/OSIF callers 3554 * 3555 * Return: QDF Status 3556 */ 3557 static inline QDF_STATUS ucfg_mlme_get_wmm_sba_ac_be(struct wlan_objmgr_psoc * psoc,uint16_t * value)3558 ucfg_mlme_get_wmm_sba_ac_be(struct wlan_objmgr_psoc *psoc, uint16_t *value) 3559 { 3560 return wlan_mlme_get_wmm_sba_ac_be(psoc, value); 3561 } 3562 3563 /** 3564 * ucfg_mlme_get_wmm_uapsd_be_srv_intv() - Get Uapsd service interval for BE 3565 * @psoc: pointer to psoc object 3566 * @value: pointer to the value which will be filled for the caller 3567 * 3568 * Inline UCFG API to be used by HDD/OSIF callers 3569 * 3570 * Return: QDF Status 3571 */ 3572 static inline QDF_STATUS ucfg_mlme_get_wmm_uapsd_be_srv_intv(struct wlan_objmgr_psoc * psoc,uint32_t * value)3573 ucfg_mlme_get_wmm_uapsd_be_srv_intv(struct wlan_objmgr_psoc *psoc, 3574 uint32_t *value) 3575 { 3576 return wlan_mlme_get_wmm_uapsd_be_srv_intv(psoc, value); 3577 } 3578 3579 /** 3580 * ucfg_mlme_get_wmm_uapsd_be_sus_intv() - Get Uapsd suspension interval for BE 3581 * @psoc: pointer to psoc object 3582 * @value: Value that needs to be set from the caller 3583 * 3584 * Inline UCFG API to be used by HDD/OSIF callers 3585 * 3586 * Return: QDF Status 3587 */ 3588 static inline QDF_STATUS ucfg_mlme_get_wmm_uapsd_be_sus_intv(struct wlan_objmgr_psoc * psoc,uint32_t * value)3589 ucfg_mlme_get_wmm_uapsd_be_sus_intv(struct wlan_objmgr_psoc *psoc, 3590 uint32_t *value) 3591 { 3592 return wlan_mlme_get_wmm_uapsd_be_sus_intv(psoc, value); 3593 } 3594 3595 /** 3596 * ucfg_mlme_get_wmm_dir_ac_bk() - Get TSPEC direction for BK 3597 * @psoc: pointer to psoc object 3598 * @value: Value that needs to be set from the caller 3599 * 3600 * Inline UCFG API to be used by HDD/OSIF callers 3601 * 3602 * Return: QDF Status 3603 */ 3604 static inline QDF_STATUS ucfg_mlme_get_wmm_dir_ac_bk(struct wlan_objmgr_psoc * psoc,uint8_t * value)3605 ucfg_mlme_get_wmm_dir_ac_bk(struct wlan_objmgr_psoc *psoc, uint8_t *value) 3606 { 3607 return wlan_mlme_get_wmm_dir_ac_bk(psoc, value); 3608 } 3609 3610 /** 3611 * ucfg_mlme_get_wmm_nom_msdu_size_ac_bk() - Get normal MSDU size for BK 3612 * @psoc: pointer to psoc object 3613 * @value: Value that needs to be set from the caller 3614 * 3615 * Inline UCFG API to be used by HDD/OSIF callers 3616 * 3617 * Return: QDF Status 3618 */ 3619 static inline ucfg_mlme_get_wmm_nom_msdu_size_ac_bk(struct wlan_objmgr_psoc * psoc,uint16_t * value)3620 QDF_STATUS ucfg_mlme_get_wmm_nom_msdu_size_ac_bk(struct wlan_objmgr_psoc *psoc, 3621 uint16_t *value) 3622 { 3623 return wlan_mlme_get_wmm_nom_msdu_size_ac_bk(psoc, value); 3624 } 3625 3626 /** 3627 * ucfg_mlme_get_wmm_mean_data_rate_ac_bk() - mean data rate for BK 3628 * @psoc: pointer to psoc object 3629 * @value: Value that needs to be set from the caller 3630 * 3631 * Inline UCFG API to be used by HDD/OSIF callers 3632 * 3633 * Return: QDF Status 3634 */ 3635 static inline ucfg_mlme_get_wmm_mean_data_rate_ac_bk(struct wlan_objmgr_psoc * psoc,uint32_t * value)3636 QDF_STATUS ucfg_mlme_get_wmm_mean_data_rate_ac_bk(struct wlan_objmgr_psoc *psoc, 3637 uint32_t *value) 3638 { 3639 return wlan_mlme_get_wmm_mean_data_rate_ac_bk(psoc, value); 3640 } 3641 3642 /** 3643 * ucfg_mlme_get_wmm_min_phy_rate_ac_bk() - min PHY rate for BE 3644 * @psoc: pointer to psoc object 3645 * @value: Value that needs to be set from the caller 3646 * 3647 * Inline UCFG API to be used by HDD/OSIF callers 3648 * 3649 * Return: QDF Status 3650 */ 3651 static inline ucfg_mlme_get_wmm_min_phy_rate_ac_bk(struct wlan_objmgr_psoc * psoc,uint32_t * value)3652 QDF_STATUS ucfg_mlme_get_wmm_min_phy_rate_ac_bk(struct wlan_objmgr_psoc *psoc, 3653 uint32_t *value) 3654 { 3655 return wlan_mlme_get_wmm_min_phy_rate_ac_bk(psoc, value); 3656 } 3657 3658 /** 3659 * ucfg_mlme_get_wmm_sba_ac_bk() - surplus bandwidt allowance for BE 3660 * @psoc: pointer to psoc object 3661 * @value: Value that needs to be set from the caller 3662 * 3663 * Inline UCFG API to be used by HDD/OSIF callers 3664 * 3665 * Return: QDF Status 3666 */ 3667 static inline QDF_STATUS ucfg_mlme_get_wmm_sba_ac_bk(struct wlan_objmgr_psoc * psoc,uint16_t * value)3668 ucfg_mlme_get_wmm_sba_ac_bk(struct wlan_objmgr_psoc *psoc, uint16_t *value) 3669 { 3670 return wlan_mlme_get_wmm_sba_ac_bk(psoc, value); 3671 } 3672 3673 /** 3674 * ucfg_mlme_get_wmm_uapsd_bk_srv_intv() - Get Uapsd service interval for BK 3675 * @psoc: pointer to psoc object 3676 * @value: pointer to the value which will be filled for the caller 3677 * 3678 * Inline UCFG API to be used by HDD/OSIF callers 3679 * 3680 * Return: QDF Status 3681 */ 3682 static inline QDF_STATUS ucfg_mlme_get_wmm_uapsd_bk_srv_intv(struct wlan_objmgr_psoc * psoc,uint32_t * value)3683 ucfg_mlme_get_wmm_uapsd_bk_srv_intv(struct wlan_objmgr_psoc *psoc, 3684 uint32_t *value) 3685 { 3686 return wlan_mlme_get_wmm_uapsd_bk_srv_intv(psoc, value); 3687 } 3688 3689 /** 3690 * ucfg_mlme_get_wmm_uapsd_bk_sus_intv() - Get Uapsd suspension interval for BK 3691 * @psoc: pointer to psoc object 3692 * @value: Value that needs to be set from the caller 3693 * 3694 * Inline UCFG API to be used by HDD/OSIF callers 3695 * 3696 * Return: QDF Status 3697 */ 3698 static inline QDF_STATUS ucfg_mlme_get_wmm_uapsd_bk_sus_intv(struct wlan_objmgr_psoc * psoc,uint32_t * value)3699 ucfg_mlme_get_wmm_uapsd_bk_sus_intv(struct wlan_objmgr_psoc *psoc, 3700 uint32_t *value) 3701 { 3702 return wlan_mlme_get_wmm_uapsd_bk_sus_intv(psoc, value); 3703 } 3704 3705 /** 3706 * ucfg_mlme_get_wmm_mode() - Enable WMM feature 3707 * @psoc: pointer to psoc object 3708 * @value: Value that needs to be set from the caller 3709 * 3710 * Inline UCFG API to be used by HDD/OSIF callers 3711 * 3712 * Return: QDF Status 3713 */ 3714 static inline QDF_STATUS ucfg_mlme_get_wmm_mode(struct wlan_objmgr_psoc * psoc,uint8_t * value)3715 ucfg_mlme_get_wmm_mode(struct wlan_objmgr_psoc *psoc, uint8_t *value) 3716 { 3717 return wlan_mlme_get_wmm_mode(psoc, value); 3718 } 3719 3720 /** 3721 * ucfg_mlme_cfg_get_wlm_level() - Get the WLM level value 3722 * @psoc: pointer to psoc object 3723 * @level: level that needs to be filled. 3724 * 3725 * Return: QDF Status 3726 */ 3727 static inline ucfg_mlme_cfg_get_wlm_level(struct wlan_objmgr_psoc * psoc,uint8_t * level)3728 QDF_STATUS ucfg_mlme_cfg_get_wlm_level(struct wlan_objmgr_psoc *psoc, 3729 uint8_t *level) 3730 { 3731 return mlme_get_cfg_wlm_level(psoc, level); 3732 } 3733 3734 /** 3735 * ucfg_mlme_cfg_get_wlm_reset() - Get the WLM reset flag 3736 * @psoc: pointer to psoc object 3737 * @reset: reset that needs to be filled. 3738 * 3739 * Return: QDF Status 3740 */ 3741 static inline ucfg_mlme_cfg_get_wlm_reset(struct wlan_objmgr_psoc * psoc,bool * reset)3742 QDF_STATUS ucfg_mlme_cfg_get_wlm_reset(struct wlan_objmgr_psoc *psoc, 3743 bool *reset) 3744 { 3745 return mlme_get_cfg_wlm_reset(psoc, reset); 3746 } 3747 3748 #ifdef WLAN_FEATURE_11AX 3749 /** 3750 * ucfg_mlme_update_tgt_he_cap() - Update tgt he cap in mlme component 3751 * 3752 * @psoc: pointer to psoc object 3753 * @cfg: pointer to config params from target 3754 * 3755 * Inline UCFG API to be used by HDD/OSIF callers to update 3756 * he caps in mlme. 3757 * 3758 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 3759 */ 3760 static inline QDF_STATUS ucfg_mlme_update_tgt_he_cap(struct wlan_objmgr_psoc * psoc,struct wma_tgt_cfg * cfg)3761 ucfg_mlme_update_tgt_he_cap(struct wlan_objmgr_psoc *psoc, 3762 struct wma_tgt_cfg *cfg) 3763 { 3764 return mlme_update_tgt_he_caps_in_cfg(psoc, cfg); 3765 } 3766 3767 /** 3768 * ucfg_mlme_cfg_get_he_caps() - Get the HE capability info 3769 * @psoc: pointer to psoc object 3770 * @he_cap: Caps that needs to be filled. 3771 * 3772 * Return: QDF Status 3773 */ 3774 static inline ucfg_mlme_cfg_get_he_caps(struct wlan_objmgr_psoc * psoc,tDot11fIEhe_cap * he_cap)3775 QDF_STATUS ucfg_mlme_cfg_get_he_caps(struct wlan_objmgr_psoc *psoc, 3776 tDot11fIEhe_cap *he_cap) 3777 { 3778 return mlme_cfg_get_he_caps(psoc, he_cap); 3779 } 3780 3781 /** 3782 * ucfg_mlme_cfg_get_he_ul_mumimo() - Get the HE Ul Mumio 3783 * @psoc: pointer to psoc object 3784 * @value: Value that needs to be set from the caller 3785 * 3786 * Return: QDF Status 3787 */ 3788 static inline ucfg_mlme_cfg_get_he_ul_mumimo(struct wlan_objmgr_psoc * psoc,uint32_t * value)3789 QDF_STATUS ucfg_mlme_cfg_get_he_ul_mumimo(struct wlan_objmgr_psoc *psoc, 3790 uint32_t *value) 3791 { 3792 return wlan_mlme_cfg_get_he_ul_mumimo(psoc, value); 3793 } 3794 3795 /** 3796 * ucfg_mlme_cfg_set_he_ul_mumimo() - Set the HE Ul Mumio 3797 * @psoc: pointer to psoc object 3798 * @value: Value that needs to be set from the caller 3799 * 3800 * Return: QDF Status 3801 */ 3802 static inline ucfg_mlme_cfg_set_he_ul_mumimo(struct wlan_objmgr_psoc * psoc,uint32_t value)3803 QDF_STATUS ucfg_mlme_cfg_set_he_ul_mumimo(struct wlan_objmgr_psoc *psoc, 3804 uint32_t value) 3805 { 3806 return wlan_mlme_cfg_set_he_ul_mumimo(psoc, value); 3807 } 3808 3809 /** 3810 * ucfg_mlme_cfg_get_enable_ul_mimo() - Get the HE Ul mimo 3811 * @psoc: pointer to psoc object 3812 * @value: Value that needs to be set from the caller 3813 * 3814 * Return: QDF Status 3815 */ 3816 static inline ucfg_mlme_cfg_get_enable_ul_mimo(struct wlan_objmgr_psoc * psoc,uint8_t * value)3817 QDF_STATUS ucfg_mlme_cfg_get_enable_ul_mimo(struct wlan_objmgr_psoc *psoc, 3818 uint8_t *value) 3819 { 3820 return wlan_mlme_cfg_get_enable_ul_mimo(psoc, value); 3821 } 3822 3823 /** 3824 * ucfg_mlme_cfg_get_enable_ul_ofdm() - Get enable ul ofdm 3825 * @psoc: pointer to psoc object 3826 * @value: Value that needs to be set from the caller 3827 * 3828 * Return: QDF Status 3829 */ 3830 static inline ucfg_mlme_cfg_get_enable_ul_ofdm(struct wlan_objmgr_psoc * psoc,uint8_t * value)3831 QDF_STATUS ucfg_mlme_cfg_get_enable_ul_ofdm(struct wlan_objmgr_psoc *psoc, 3832 uint8_t *value) 3833 { 3834 return wlan_mlme_cfg_get_enable_ul_ofdm(psoc, value); 3835 } 3836 #endif 3837 3838 #ifdef WLAN_FEATURE_11BE 3839 /** 3840 * ucfg_mlme_update_tgt_eht_cap() - Update tgt EHT cap in mlme component 3841 * 3842 * @psoc: pointer to psoc object 3843 * @cfg: pointer to config params from target 3844 * 3845 * Inline UCFG API to be used by HDD/OSIF callers to update 3846 * EHT caps in mlme. 3847 * 3848 * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE 3849 */ 3850 static inline QDF_STATUS ucfg_mlme_update_tgt_eht_cap(struct wlan_objmgr_psoc * psoc,struct wma_tgt_cfg * cfg)3851 ucfg_mlme_update_tgt_eht_cap(struct wlan_objmgr_psoc *psoc, 3852 struct wma_tgt_cfg *cfg) 3853 { 3854 return mlme_update_tgt_eht_caps_in_cfg(psoc, cfg); 3855 } 3856 3857 static inline QDF_STATUS ucfg_mlme_update_tgt_mlo_cap(struct wlan_objmgr_psoc * psoc)3858 ucfg_mlme_update_tgt_mlo_cap(struct wlan_objmgr_psoc *psoc) 3859 { 3860 return mlme_update_tgt_mlo_caps_in_cfg(psoc); 3861 } 3862 3863 /** 3864 * ucfg_mlme_get_usr_disable_sta_eht() - Get user disable sta eht flag 3865 * @psoc: psoc object 3866 * 3867 * Return: true if user has disabled eht in connect request 3868 */ 3869 static inline ucfg_mlme_get_usr_disable_sta_eht(struct wlan_objmgr_psoc * psoc)3870 bool ucfg_mlme_get_usr_disable_sta_eht(struct wlan_objmgr_psoc *psoc) 3871 { 3872 return wlan_mlme_get_usr_disable_sta_eht(psoc); 3873 } 3874 3875 /** 3876 * ucfg_mlme_set_usr_disable_sta_eht() - Set user disable sta eht flag 3877 * @psoc: psoc object 3878 * @disable: eht disable flag 3879 * 3880 * Return: void 3881 */ 3882 static inline ucfg_mlme_set_usr_disable_sta_eht(struct wlan_objmgr_psoc * psoc,bool disable)3883 void ucfg_mlme_set_usr_disable_sta_eht(struct wlan_objmgr_psoc *psoc, 3884 bool disable) 3885 { 3886 wlan_mlme_set_usr_disable_sta_eht(psoc, disable); 3887 } 3888 #else 3889 static inline QDF_STATUS ucfg_mlme_update_tgt_mlo_cap(struct wlan_objmgr_psoc * psoc)3890 ucfg_mlme_update_tgt_mlo_cap(struct wlan_objmgr_psoc *psoc) 3891 { 3892 return QDF_STATUS_SUCCESS; 3893 } 3894 3895 static inline ucfg_mlme_get_usr_disable_sta_eht(struct wlan_objmgr_psoc * psoc)3896 bool ucfg_mlme_get_usr_disable_sta_eht(struct wlan_objmgr_psoc *psoc) 3897 { 3898 return true; 3899 } 3900 3901 static inline ucfg_mlme_set_usr_disable_sta_eht(struct wlan_objmgr_psoc * psoc,bool disable)3902 void ucfg_mlme_set_usr_disable_sta_eht(struct wlan_objmgr_psoc *psoc, 3903 bool disable) 3904 { 3905 } 3906 #endif 3907 3908 #ifdef WLAN_FEATURE_11BE_MLO 3909 /** 3910 * ucfg_mlme_get_eht_mld_id() - Get the MLD ID of the requested BSS 3911 * @psoc: pointer to psoc object 3912 * 3913 * This API gives the MLD ID of the requested BSS 3914 * 3915 * Return: MLD ID of the requested BSS 3916 */ 3917 static inline uint8_t ucfg_mlme_get_eht_mld_id(struct wlan_objmgr_psoc * psoc)3918 ucfg_mlme_get_eht_mld_id(struct wlan_objmgr_psoc *psoc) 3919 { 3920 return wlan_mlme_get_eht_mld_id(psoc); 3921 } 3922 3923 /** 3924 * ucfg_mlme_set_eht_mld_id() - Set MLD ID of the requested BSS information 3925 * @psoc: pointer to psoc object 3926 * @value: set MLD ID 3927 * 3928 * This API sets the MLD ID of the requested BSS information within the ML 3929 * probe request. 3930 * 3931 * Return: QDF_STATUS 3932 */ 3933 static inline QDF_STATUS ucfg_mlme_set_eht_mld_id(struct wlan_objmgr_psoc * psoc,uint8_t value)3934 ucfg_mlme_set_eht_mld_id(struct wlan_objmgr_psoc *psoc, 3935 uint8_t value) 3936 { 3937 return wlan_mlme_set_eht_mld_id(psoc, value); 3938 } 3939 #else 3940 static inline uint8_t ucfg_mlme_get_eht_mld_id(struct wlan_objmgr_psoc * psoc)3941 ucfg_mlme_get_eht_mld_id(struct wlan_objmgr_psoc *psoc) 3942 { 3943 return 0; 3944 } 3945 3946 static inline QDF_STATUS ucfg_mlme_set_eht_mld_id(struct wlan_objmgr_psoc * psoc,uint8_t value)3947 ucfg_mlme_set_eht_mld_id(struct wlan_objmgr_psoc *psoc, uint8_t value) 3948 { 3949 return QDF_STATUS_E_NOSUPPORT; 3950 } 3951 #endif /* WLAN_FEATURE_11BE_MLO */ 3952 3953 /** 3954 * ucfg_mlme_get_80211e_is_enabled() - Enable 802.11e feature 3955 * @psoc: pointer to psoc object 3956 * @value: Value that needs to be set from the caller 3957 * 3958 * Inline UCFG API to be used by HDD/OSIF callers 3959 * 3960 * Return: QDF Status 3961 */ 3962 static inline QDF_STATUS ucfg_mlme_get_80211e_is_enabled(struct wlan_objmgr_psoc * psoc,bool * value)3963 ucfg_mlme_get_80211e_is_enabled(struct wlan_objmgr_psoc *psoc, bool *value) 3964 { 3965 return wlan_mlme_get_80211e_is_enabled(psoc, value); 3966 } 3967 3968 /** 3969 * ucfg_mlme_get_wmm_uapsd_mask() - setup U-APSD mask for ACs 3970 * @psoc: pointer to psoc object 3971 * @value: Value that needs to be set from the caller 3972 * 3973 * Inline UCFG API to be used by HDD/OSIF callers 3974 * 3975 * Return: QDF Status 3976 */ 3977 static inline QDF_STATUS ucfg_mlme_get_wmm_uapsd_mask(struct wlan_objmgr_psoc * psoc,uint8_t * value)3978 ucfg_mlme_get_wmm_uapsd_mask(struct wlan_objmgr_psoc *psoc, uint8_t *value) 3979 { 3980 return wlan_mlme_get_wmm_uapsd_mask(psoc, value); 3981 } 3982 3983 #ifdef FEATURE_WLAN_ESE 3984 /** 3985 * ucfg_mlme_get_inactivity_interval() - Infra Inactivity Interval 3986 * @psoc: pointer to psoc object 3987 * @value: Value that needs to be get from the caller 3988 * 3989 * Inline UCFG API to be used by HDD/OSIF callers 3990 * 3991 * Return: None 3992 */ 3993 static inline void ucfg_mlme_get_inactivity_interval(struct wlan_objmgr_psoc * psoc,uint32_t * value)3994 ucfg_mlme_get_inactivity_interval(struct wlan_objmgr_psoc *psoc, 3995 uint32_t *value) 3996 { 3997 wlan_mlme_get_inactivity_interval(psoc, value); 3998 } 3999 4000 /** 4001 * ucfg_mlme_is_ese_enabled() - ese feature enable or not 4002 * @psoc: pointer to psoc object 4003 * @val: Pointer to the value which will be filled for the caller 4004 * 4005 * Return: QDF Status 4006 */ 4007 QDF_STATUS 4008 ucfg_mlme_is_ese_enabled(struct wlan_objmgr_psoc *psoc, bool *val); 4009 #endif /* FEATURE_WLAN_ESE */ 4010 4011 /** 4012 * ucfg_mlme_get_is_ts_burst_size_enable() - Get TS burst size flag 4013 * @psoc: pointer to psoc object 4014 * @value: Value that needs to be get from the caller 4015 * 4016 * Inline UCFG API to be used by HDD/OSIF callers 4017 * 4018 * Return: None 4019 */ 4020 static inline ucfg_mlme_get_is_ts_burst_size_enable(struct wlan_objmgr_psoc * psoc,bool * value)4021 void ucfg_mlme_get_is_ts_burst_size_enable(struct wlan_objmgr_psoc *psoc, 4022 bool *value) 4023 { 4024 wlan_mlme_get_is_ts_burst_size_enable(psoc, value); 4025 } 4026 4027 /** 4028 * ucfg_mlme_get_ts_info_ack_policy() - Get TS ack policy 4029 * @psoc: pointer to psoc object 4030 * @value: Value that needs to be get from the caller 4031 * 4032 * Inline UCFG API to be used by HDD/OSIF callers 4033 * 4034 * Return: None 4035 */ 4036 static inline void ucfg_mlme_get_ts_info_ack_policy(struct wlan_objmgr_psoc * psoc,enum mlme_ts_info_ack_policy * value)4037 ucfg_mlme_get_ts_info_ack_policy(struct wlan_objmgr_psoc *psoc, 4038 enum mlme_ts_info_ack_policy *value) 4039 { 4040 wlan_mlme_get_ts_info_ack_policy(psoc, value); 4041 } 4042 4043 /** 4044 * ucfg_mlme_get_ts_acm_value_for_ac() - Get ACM value for AC 4045 * @psoc: pointer to psoc object 4046 * @value: Value that needs to be get from the caller 4047 * 4048 * 4049 * Inline UCFG API to be used by HDD/OSIF callers 4050 * 4051 * Return: QDF Status 4052 */ 4053 static inline QDF_STATUS ucfg_mlme_get_ts_acm_value_for_ac(struct wlan_objmgr_psoc * psoc,bool * value)4054 ucfg_mlme_get_ts_acm_value_for_ac(struct wlan_objmgr_psoc *psoc, bool *value) 4055 { 4056 return wlan_mlme_get_ts_acm_value_for_ac(psoc, value); 4057 } 4058 4059 /* 4060 * ucfg_mlme_is_sap_uapsd_enabled() - SAP UAPSD enabled status. 4061 * @psoc: pointer to psoc object 4062 * @value: sap uapsd enabled flag value requested from the caller 4063 * 4064 * Inline UCFG API to be used by HDD/OSIF callers 4065 * 4066 * Return: QDF Status 4067 */ 4068 static inline QDF_STATUS ucfg_mlme_is_sap_uapsd_enabled(struct wlan_objmgr_psoc * psoc,bool * value)4069 ucfg_mlme_is_sap_uapsd_enabled(struct wlan_objmgr_psoc *psoc, bool *value) 4070 { 4071 return wlan_mlme_is_sap_uapsd_enabled(psoc, value); 4072 } 4073 4074 /* 4075 * ucfg_mlme_set_sap_uapsd_flag() - SAP UAPSD enabled status. 4076 * @psoc: pointer to psoc object 4077 * @value: Value that needs to be set from the caller 4078 * 4079 * Inline UCFG API to be used by HDD/OSIF callers 4080 * 4081 * Return: QDF Status 4082 */ 4083 static inline QDF_STATUS ucfg_mlme_set_sap_uapsd_flag(struct wlan_objmgr_psoc * psoc,bool value)4084 ucfg_mlme_set_sap_uapsd_flag(struct wlan_objmgr_psoc *psoc, bool value) 4085 { 4086 return wlan_mlme_set_sap_uapsd_flag(psoc, value); 4087 } 4088 4089 /** 4090 * ucfg_mlme_get_enable_deauth_to_disassoc_map() - Enable deauth_to_disassoc_map 4091 * @psoc: pointer to psoc object 4092 * @value: Value that needs to be set from the caller 4093 * 4094 * UCFG API to be used by HDD/OSIF callers 4095 * 4096 * Return: QDF Status 4097 */ 4098 QDF_STATUS 4099 ucfg_mlme_get_enable_deauth_to_disassoc_map(struct wlan_objmgr_psoc *psoc, 4100 bool *value); 4101 4102 /** 4103 * ucfg_mlme_get_ap_random_bssid_enable() - Enable random bssid 4104 * @psoc: pointer to psoc object 4105 * @value: Value that needs to be set from the caller 4106 * 4107 * UCFG API to be used by HDD/OSIF callers 4108 * 4109 * Return: QDF Status 4110 */ 4111 QDF_STATUS 4112 ucfg_mlme_get_ap_random_bssid_enable(struct wlan_objmgr_psoc *psoc, 4113 bool *value); 4114 4115 /** 4116 * ucfg_mlme_get_sta_miracast_mcc_rest_time() - Get STA/MIRACAST MCC rest time 4117 * 4118 * @psoc: pointer to psoc object 4119 * @value: value which needs to filled by API 4120 * 4121 * This API gives rest time to be used when STA and MIRACAST MCC conc happens 4122 * 4123 * Return: QDF_STATUS 4124 */ 4125 static inline QDF_STATUS ucfg_mlme_get_sta_miracast_mcc_rest_time(struct wlan_objmgr_psoc * psoc,uint32_t * value)4126 ucfg_mlme_get_sta_miracast_mcc_rest_time(struct wlan_objmgr_psoc *psoc, 4127 uint32_t *value) 4128 { 4129 return wlan_mlme_get_sta_miracast_mcc_rest_time(psoc, value); 4130 } 4131 4132 /** 4133 * ucfg_mlme_get_max_modulated_dtim_ms() - get sap max modulated dtim 4134 * @psoc: pointer to psoc object 4135 * @value: Value that needs to be set from the caller 4136 * 4137 * Inline UCFG API to be used by HDD/OSIF callers 4138 * 4139 * Return: QDF Status 4140 */ 4141 static inline QDF_STATUS ucfg_mlme_get_max_modulated_dtim_ms(struct wlan_objmgr_psoc * psoc,uint16_t * value)4142 ucfg_mlme_get_max_modulated_dtim_ms(struct wlan_objmgr_psoc *psoc, 4143 uint16_t *value) 4144 { 4145 return wlan_mlme_get_max_modulated_dtim_ms(psoc, value); 4146 } 4147 4148 /** 4149 * ucfg_mlme_get_sap_mcc_chnl_avoid() - Check if SAP MCC needs to be avoided 4150 * 4151 * @psoc: pointer to psoc object 4152 * @value: value which needs to filled by API 4153 * 4154 * This API fetches the user setting to determine if SAP MCC with other persona 4155 * to be avoided. 4156 * 4157 * Return: QDF_STATUS 4158 */ 4159 static inline QDF_STATUS ucfg_mlme_get_sap_mcc_chnl_avoid(struct wlan_objmgr_psoc * psoc,uint8_t * value)4160 ucfg_mlme_get_sap_mcc_chnl_avoid(struct wlan_objmgr_psoc *psoc, 4161 uint8_t *value) 4162 { 4163 return wlan_mlme_get_sap_mcc_chnl_avoid(psoc, value); 4164 } 4165 4166 /** 4167 * ucfg_mlme_get_mcc_bcast_prob_resp() - Get broadcast probe rsp in MCC 4168 * 4169 * @psoc: pointer to psoc object 4170 * @value: value which needs to filled by API 4171 * 4172 * To get INI value which helps to determe whether to enable/disable use of 4173 * broadcast probe response to increase the detectability of SAP in MCC mode. 4174 * 4175 * 4176 * Return: QDF_STATUS 4177 */ 4178 static inline QDF_STATUS ucfg_mlme_get_mcc_bcast_prob_resp(struct wlan_objmgr_psoc * psoc,uint8_t * value)4179 ucfg_mlme_get_mcc_bcast_prob_resp(struct wlan_objmgr_psoc *psoc, 4180 uint8_t *value) 4181 { 4182 return wlan_mlme_get_mcc_bcast_prob_resp(psoc, value); 4183 } 4184 4185 /** 4186 * ucfg_mlme_get_mcc_rts_cts_prot() - To get RTS-CTS protection in MCC. 4187 * 4188 * @psoc: pointer to psoc object 4189 * @value: value which needs to filled by API 4190 * 4191 * To get INI value which helps to determine whether to enable/disable 4192 * use of long duration RTS-CTS protection when SAP goes off 4193 * channel in MCC mode. 4194 * 4195 * Return: QDF_STATUS 4196 */ 4197 static inline QDF_STATUS ucfg_mlme_get_mcc_rts_cts_prot(struct wlan_objmgr_psoc * psoc,uint8_t * value)4198 ucfg_mlme_get_mcc_rts_cts_prot(struct wlan_objmgr_psoc *psoc, 4199 uint8_t *value) 4200 { 4201 return wlan_mlme_get_mcc_rts_cts_prot(psoc, value); 4202 } 4203 4204 /** 4205 * ucfg_mlme_get_mcc_feature() - To find out to enable/disable MCC feature 4206 * 4207 * @psoc: pointer to psoc object 4208 * @value: value which needs to filled by API 4209 * 4210 * To get INI value which helps to determine whether to enable MCC feature 4211 * 4212 * Return: QDF_STATUS 4213 */ 4214 static inline QDF_STATUS ucfg_mlme_get_mcc_feature(struct wlan_objmgr_psoc * psoc,uint8_t * value)4215 ucfg_mlme_get_mcc_feature(struct wlan_objmgr_psoc *psoc, 4216 uint8_t *value) 4217 { 4218 return wlan_mlme_get_mcc_feature(psoc, value); 4219 } 4220 4221 /** 4222 * ucfg_wlan_mlme_get_rrm_enabled() - Get the rrm enabled 4223 * @psoc: pointer to psoc object 4224 * @value: Value that needs to be get from the caller 4225 * 4226 * Return: QDF Status 4227 */ 4228 static inline ucfg_wlan_mlme_get_rrm_enabled(struct wlan_objmgr_psoc * psoc,bool * value)4229 QDF_STATUS ucfg_wlan_mlme_get_rrm_enabled(struct wlan_objmgr_psoc *psoc, 4230 bool *value) 4231 { 4232 return wlan_mlme_get_rrm_enabled(psoc, value); 4233 } 4234 4235 /** 4236 * ucfg_mlme_get_latency_enable() - Get the latency_enable 4237 * @psoc: pointer to psoc object 4238 * @value: Value that needs to be get from the caller 4239 * 4240 * Return: QDF Status 4241 */ 4242 QDF_STATUS 4243 ucfg_mlme_get_latency_enable(struct wlan_objmgr_psoc *psoc, bool *value); 4244 4245 /** 4246 * ucfg_mlme_get_latency_level() - Get the latency level 4247 * @psoc: pointer to psoc object 4248 * @value: Value that needs to be get from the caller 4249 * latency values are defined in WMI_WLM_LATENCY_LEVEL 4250 * 4251 * Return: QDF Status 4252 */ 4253 QDF_STATUS 4254 ucfg_mlme_get_latency_level(struct wlan_objmgr_psoc *psoc, uint8_t *value); 4255 4256 /** 4257 * ucfg_mlme_get_latency_host_flags() - Get host flags for latency level 4258 * @psoc: pointer to psoc object 4259 * @latency_level: latency level 4260 * @value: Value that needs to be get from the caller 4261 * 4262 * Return: QDF Status 4263 */ 4264 QDF_STATUS 4265 ucfg_mlme_get_latency_host_flags(struct wlan_objmgr_psoc *psoc, 4266 uint8_t latency_level, uint32_t *value); 4267 4268 /** 4269 * ucfg_mlme_get_dtim_selection_diversity() - get dtim selection diversity 4270 * bitmap 4271 * @psoc: pointer to psoc object 4272 * @dtim_selection_div: value that is requested by the caller 4273 * 4274 * Inline UCFG API to be used by HDD/OSIF callers 4275 * 4276 * Return: QDF_STATUS_SUCCESS - in case of success 4277 */ 4278 static inline QDF_STATUS ucfg_mlme_get_dtim_selection_diversity(struct wlan_objmgr_psoc * psoc,uint32_t * dtim_selection_div)4279 ucfg_mlme_get_dtim_selection_diversity(struct wlan_objmgr_psoc *psoc, 4280 uint32_t *dtim_selection_div) 4281 { 4282 return wlan_mlme_get_dtim_selection_diversity(psoc, dtim_selection_div); 4283 } 4284 4285 /** 4286 * ucfg_mlme_get_bmps_min_listen_interval() - get beacon mode powersave 4287 * minimum listen interval value 4288 * @psoc: pointer to psoc object 4289 * @value: value that is requested by the caller 4290 * 4291 * Inline UCFG API to be used by HDD/OSIF callers 4292 * 4293 * Return: QDF_STATUS_SUCCESS - in case of success 4294 */ 4295 static inline QDF_STATUS ucfg_mlme_get_bmps_min_listen_interval(struct wlan_objmgr_psoc * psoc,uint32_t * value)4296 ucfg_mlme_get_bmps_min_listen_interval(struct wlan_objmgr_psoc *psoc, 4297 uint32_t *value) 4298 { 4299 return wlan_mlme_get_bmps_min_listen_interval(psoc, value); 4300 } 4301 4302 /** 4303 * ucfg_mlme_get_bmps_max_listen_interval() - get beacon mode powersave 4304 * maximum listen interval value 4305 * @psoc: pointer to psoc object 4306 * @value: value that is requested by the caller 4307 * 4308 * Inline UCFG API to be used by HDD/OSIF callers 4309 * 4310 * Return: QDF_STATUS_SUCCESS - in case of success 4311 */ 4312 static inline QDF_STATUS ucfg_mlme_get_bmps_max_listen_interval(struct wlan_objmgr_psoc * psoc,uint32_t * value)4313 ucfg_mlme_get_bmps_max_listen_interval(struct wlan_objmgr_psoc *psoc, 4314 uint32_t *value) 4315 { 4316 return wlan_mlme_get_bmps_max_listen_interval(psoc, value); 4317 } 4318 4319 /** 4320 * ucfg_mlme_get_auto_bmps_timer_value() - get bmps timer value 4321 * minimum listen interval value 4322 * @psoc: pointer to psoc object 4323 * @value: value that is requested by the caller 4324 * 4325 * Inline UCFG API to be used by HDD/OSIF callers 4326 * 4327 * Return: QDF_STATUS_SUCCESS - in case of success 4328 */ 4329 static inline QDF_STATUS ucfg_mlme_get_auto_bmps_timer_value(struct wlan_objmgr_psoc * psoc,uint32_t * value)4330 ucfg_mlme_get_auto_bmps_timer_value(struct wlan_objmgr_psoc *psoc, 4331 uint32_t *value) 4332 { 4333 return wlan_mlme_get_auto_bmps_timer_value(psoc, value); 4334 } 4335 4336 /** 4337 * ucfg_mlme_is_bmps_enabled() - check if beacon mode powersave is 4338 * enabled/disabled 4339 * @psoc: pointer to psoc object 4340 * @value: value that is requested by the caller 4341 * 4342 * Inline UCFG API to be used by HDD/OSIF callers 4343 * 4344 * Return: QDF_STATUS_SUCCESS - in case of success 4345 */ 4346 static inline QDF_STATUS ucfg_mlme_is_bmps_enabled(struct wlan_objmgr_psoc * psoc,bool * value)4347 ucfg_mlme_is_bmps_enabled(struct wlan_objmgr_psoc *psoc, bool *value) 4348 { 4349 return wlan_mlme_is_bmps_enabled(psoc, value); 4350 } 4351 4352 /** 4353 * ucfg_mlme_is_imps_enabled() - check if idle mode powersave is 4354 * enabled/disabled 4355 * @psoc: pointer to psoc object 4356 * @value: value that is requested by the caller 4357 * 4358 * Inline UCFG API to be used by HDD/OSIF callers 4359 * 4360 * Return: QDF_STATUS_SUCCESS - in case of success 4361 */ 4362 static inline QDF_STATUS ucfg_mlme_is_imps_enabled(struct wlan_objmgr_psoc * psoc,bool * value)4363 ucfg_mlme_is_imps_enabled(struct wlan_objmgr_psoc *psoc, bool *value) 4364 { 4365 return wlan_mlme_is_imps_enabled(psoc, value); 4366 } 4367 4368 /** 4369 * ucfg_mlme_override_bmps_imps() - disable imps/bmps as part of 4370 * override to disable all ps features 4371 * @psoc: pointer to psoc object 4372 * Inline UCFG API to be used by HDD/OSIF callers 4373 * 4374 * Return: QDF_STATUS_SUCCESS - in case of success 4375 */ 4376 static inline QDF_STATUS ucfg_mlme_override_bmps_imps(struct wlan_objmgr_psoc * psoc)4377 ucfg_mlme_override_bmps_imps(struct wlan_objmgr_psoc *psoc) 4378 { 4379 return wlan_mlme_override_bmps_imps(psoc); 4380 } 4381 4382 #ifdef MWS_COEX 4383 /** 4384 * ucfg_mlme_get_mws_coex_4g_quick_tdm() - Get mws coex 4g quick tdm 4385 * @psoc: pointer to psoc object 4386 * @val: Pointer to the value which will be filled for the caller 4387 * 4388 * Return: QDF Status 4389 */ 4390 QDF_STATUS 4391 ucfg_mlme_get_mws_coex_4g_quick_tdm(struct wlan_objmgr_psoc *psoc, 4392 uint32_t *val); 4393 4394 /** 4395 * ucfg_mlme_get_mws_coex_5g_nr_pwr_limit() - Get mws coex 5g nr pwr limit 4396 * @psoc: pointer to psoc object 4397 * @val: Pointer to the value which will be filled for the caller 4398 * 4399 * Return: QDF Status 4400 */ 4401 QDF_STATUS 4402 ucfg_mlme_get_mws_coex_5g_nr_pwr_limit(struct wlan_objmgr_psoc *psoc, 4403 uint32_t *val); 4404 4405 /** 4406 * ucfg_mlme_get_mws_coex_pcc_channel_avoid_delay() - Get mws coex pcc 4407 * avoid channel delay 4408 * @psoc: pointer to psoc object 4409 * @val: Pointer to the value which will be filled for the caller 4410 * 4411 * Return: QDF Status 4412 */ 4413 QDF_STATUS 4414 ucfg_mlme_get_mws_coex_pcc_channel_avoid_delay(struct wlan_objmgr_psoc *psoc, 4415 uint32_t *val); 4416 4417 /** 4418 * ucfg_mlme_get_mws_coex_scc_channel_avoid_delay() - Get mws coex scc 4419 * avoidance channel delay 4420 * @psoc: pointer to psoc object 4421 * @val: Pointer to the value which will be filled for the caller 4422 * 4423 * Return: QDF Status 4424 */ 4425 QDF_STATUS 4426 ucfg_mlme_get_mws_coex_scc_channel_avoid_delay(struct wlan_objmgr_psoc *psoc, 4427 uint32_t *val); 4428 #endif 4429 4430 /** 4431 * ucfg_mlme_get_etsi_srd_chan_in_master_mode - get etsi srd chan 4432 * in master mode 4433 * @psoc: pointer to psoc object 4434 * @value: pointer to the value which will be filled for the caller 4435 * 4436 * Return: QDF Status 4437 */ 4438 QDF_STATUS 4439 ucfg_mlme_get_etsi_srd_chan_in_master_mode(struct wlan_objmgr_psoc *psoc, 4440 uint8_t *value); 4441 4442 /** 4443 * ucfg_mlme_get_5dot9_ghz_chan_in_master_mode - get fcc 5.9 GHz chan 4444 * in master mode 4445 * @psoc: pointer to psoc object 4446 * @value: pointer to the value which will be filled for the caller 4447 * 4448 * Return: QDF Status 4449 */ 4450 QDF_STATUS 4451 ucfg_mlme_get_5dot9_ghz_chan_in_master_mode(struct wlan_objmgr_psoc *psoc, 4452 bool *value); 4453 4454 /** 4455 * ucfg_mlme_get_srd_master_mode_for_vdev() - Get SRD master mode for vdev 4456 * @psoc: pointer to psoc object 4457 * @vdev_opmode: vdev opmode 4458 * @value: pointer to the value which will be filled for the caller 4459 * 4460 * Return: QDF Status 4461 */ 4462 QDF_STATUS 4463 ucfg_mlme_get_srd_master_mode_for_vdev(struct wlan_objmgr_psoc *psoc, 4464 enum QDF_OPMODE vdev_opmode, 4465 bool *value); 4466 4467 #ifdef SAP_AVOID_ACS_FREQ_LIST 4468 /** 4469 * ucfg_mlme_get_acs_avoid_freq_list - get acs avoid frequency list 4470 * @psoc: pointer to psoc object 4471 * @freq_list: Pointer to output freq list 4472 * @freq_list_num: Pointer to the output number of frequencies filled 4473 * in the freq_list 4474 * 4475 * Return: QDF Status 4476 */ 4477 QDF_STATUS 4478 ucfg_mlme_get_acs_avoid_freq_list(struct wlan_objmgr_psoc *psoc, 4479 uint16_t *freq_list, uint8_t *freq_list_num); 4480 4481 #else 4482 static inline QDF_STATUS ucfg_mlme_get_acs_avoid_freq_list(struct wlan_objmgr_psoc * psoc,uint16_t * freq_list,uint8_t * freq_list_num)4483 ucfg_mlme_get_acs_avoid_freq_list(struct wlan_objmgr_psoc *psoc, 4484 uint16_t *freq_list, uint8_t *freq_list_num) 4485 { 4486 *freq_list_num = 0; 4487 return QDF_STATUS_E_INVAL; 4488 } 4489 #endif 4490 4491 /** 4492 * ucfg_mlme_get_11d_in_world_mode - get whether 11d is enabled in world mode 4493 * in master mode 4494 * @psoc: pointer to psoc object 4495 * @value: pointer to the value which will be filled for the caller 4496 * 4497 * Return: QDF Status 4498 */ 4499 QDF_STATUS 4500 ucfg_mlme_get_11d_in_world_mode(struct wlan_objmgr_psoc *psoc, 4501 bool *value); 4502 4503 /** 4504 * ucfg_mlme_get_restart_beaconing_on_ch_avoid() - get restart beaconing on 4505 * channel avoid 4506 * @psoc: pointer to psoc object 4507 * @value: pointer to the value which will be filled for the caller 4508 * 4509 * Return: QDF Status 4510 */ 4511 QDF_STATUS 4512 ucfg_mlme_get_restart_beaconing_on_ch_avoid(struct wlan_objmgr_psoc *psoc, 4513 uint32_t *value); 4514 4515 /** 4516 * ucfg_mlme_get_indoor_channel_support() - get indoor channel support 4517 * @psoc: pointer to psoc object 4518 * @value: pointer to the value which will be filled for the caller 4519 * 4520 * Return: QDF Status 4521 */ 4522 QDF_STATUS 4523 ucfg_mlme_get_indoor_channel_support(struct wlan_objmgr_psoc *psoc, 4524 bool *value); 4525 4526 /** 4527 * ucfg_mlme_get_scan_11d_interval() - get scan 11d interval 4528 * @psoc: pointer to psoc object 4529 * @value: Pointer to the value which will be filled for the caller 4530 * 4531 * Return: QDF Status 4532 */ 4533 QDF_STATUS 4534 ucfg_mlme_get_scan_11d_interval(struct wlan_objmgr_psoc *psoc, 4535 uint32_t *value); 4536 4537 /** 4538 * ucfg_mlme_get_nol_across_regdmn() - get scan 11d interval 4539 * @psoc: pointer to psoc object 4540 * @value: Pointer to the value which will be filled for the caller 4541 * 4542 * Return: QDF Status 4543 */ 4544 4545 QDF_STATUS 4546 ucfg_mlme_get_nol_across_regdmn(struct wlan_objmgr_psoc *psoc, bool *value); 4547 4548 /** 4549 * ucfg_mlme_get_valid_channel_freq_list() - get valid channel 4550 * list 4551 * @psoc: pointer to psoc object 4552 * @channel_list: pointer to return channel list 4553 * @channel_list_num: pointer to return channel list number 4554 * 4555 * Return: QDF Status 4556 */ 4557 QDF_STATUS 4558 ucfg_mlme_get_valid_channel_freq_list(struct wlan_objmgr_psoc *psoc, 4559 uint32_t *channel_list, 4560 uint32_t *channel_list_num); 4561 4562 #ifdef FEATURE_LFR_SUBNET_DETECTION 4563 /** 4564 * ucfg_mlme_is_subnet_detection_enabled() - check if sub net detection is 4565 * enabled/disabled 4566 * @psoc: pointer to psoc object 4567 * @val: value that is requested by the caller 4568 * 4569 * Inline UCFG API to be used by HDD/OSIF callers 4570 * 4571 * Return: QDF_STATUS_SUCCESS - in case of success 4572 */ 4573 QDF_STATUS 4574 ucfg_mlme_is_subnet_detection_enabled(struct wlan_objmgr_psoc *psoc, bool *val); 4575 #else 4576 static QDF_STATUS ucfg_mlme_is_subnet_detection_enabled(struct wlan_objmgr_psoc * psoc,bool * val)4577 ucfg_mlme_is_subnet_detection_enabled(struct wlan_objmgr_psoc *psoc, bool *val) 4578 { 4579 *val = false; 4580 4581 return QDF_STATUS_SUCCESS; 4582 } 4583 #endif /* FEATURE_LFR_SUBNET_DETECTION */ 4584 4585 /** 4586 * ucfg_mlme_set_current_tx_power_level() - set current tx power level 4587 * @psoc: pointer to psoc object 4588 * @value: data to be set 4589 * 4590 * Return: QDF Status 4591 */ 4592 QDF_STATUS 4593 ucfg_mlme_set_current_tx_power_level(struct wlan_objmgr_psoc *psoc, 4594 uint8_t value); 4595 4596 /** 4597 * ucfg_mlme_get_current_tx_power_level() - get current tx power level 4598 * @psoc: pointer to psoc object 4599 * @value: pointer to the value which will be filled for the caller 4600 * 4601 * Return: QDF Status 4602 */ 4603 QDF_STATUS 4604 ucfg_mlme_get_current_tx_power_level(struct wlan_objmgr_psoc *psoc, 4605 uint8_t *value); 4606 4607 /** 4608 * ucfg_wlan_mlme_get_reg_tpc_info() - get current regulatory tpc info 4609 * @vdev: pointer to vdev object 4610 * @tpc_info: pointer to tpc info buffer 4611 * 4612 * Return: QDF Status 4613 */ 4614 QDF_STATUS 4615 ucfg_wlan_mlme_get_reg_tpc_info(struct wlan_objmgr_vdev *vdev, 4616 struct reg_tpc_power_info *tpc_info); 4617 4618 /** 4619 * ucfg_mlme_set_obss_detection_offload_enabled() - Enable obss offload 4620 * @psoc: pointer to psoc object 4621 * @value: enable or disable 4622 * 4623 * Return: QDF Status 4624 */ 4625 QDF_STATUS 4626 ucfg_mlme_set_obss_detection_offload_enabled(struct wlan_objmgr_psoc *psoc, 4627 uint8_t value); 4628 4629 /** 4630 * ucfg_mlme_set_obss_color_collision_offload_enabled() - Enable obss color 4631 * collision offload 4632 * @psoc: pointer to psoc object 4633 * @value: enable or disable 4634 * 4635 * Return: QDF Status 4636 */ 4637 QDF_STATUS 4638 ucfg_mlme_set_obss_color_collision_offload_enabled( 4639 struct wlan_objmgr_psoc *psoc, uint8_t value); 4640 4641 /** 4642 * ucfg_mlme_set_bss_color_collision_det_sta() - Enable bss color 4643 * collision detection offload for STA mode 4644 * @psoc: pointer to psoc object 4645 * @value: enable or disable 4646 * 4647 * Return: QDF Status 4648 */ 4649 QDF_STATUS 4650 ucfg_mlme_set_bss_color_collision_det_sta(struct wlan_objmgr_psoc *psoc, 4651 bool value); 4652 4653 /** 4654 * ucfg_mlme_set_bss_color_collision_det_support() - Set bss color collision 4655 * detection offload support from FW for STA mode 4656 * @psoc: pointer to psoc object 4657 * @value: enable or disable 4658 * 4659 * Return: QDF Status 4660 */ 4661 QDF_STATUS 4662 ucfg_mlme_set_bss_color_collision_det_support(struct wlan_objmgr_psoc *psoc, 4663 bool value); 4664 4665 /** 4666 * ucfg_mlme_get_bss_color_collision_det_support() - Get bss color collision 4667 * detection offload FW support for STA mode 4668 * @psoc: pointer to psoc object 4669 * @value: pointer to the value which will be filled for the caller 4670 * 4671 * Return: QDF Status 4672 */ 4673 QDF_STATUS 4674 ucfg_mlme_get_bss_color_collision_det_support(struct wlan_objmgr_psoc *psoc, 4675 bool *value); 4676 4677 /** 4678 * ucfg_mlme_set_restricted_80p80_bw_supp() - Set the restricted 80p80 support 4679 * @psoc: pointer to psoc object 4680 * @restricted_80p80_supp: Value to be set from the caller 4681 * 4682 * Return: QDF Status 4683 */ 4684 QDF_STATUS ucfg_mlme_set_restricted_80p80_bw_supp(struct wlan_objmgr_psoc *psoc, 4685 bool restricted_80p80_supp); 4686 4687 /** 4688 * ucfg_mlme_get_restricted_80p80_bw_supp() - Get the restricted 80p80 support 4689 * @psoc: pointer to psoc object 4690 * 4691 * Return: true or false 4692 */ 4693 bool ucfg_mlme_get_restricted_80p80_bw_supp(struct wlan_objmgr_psoc *psoc); 4694 4695 /** 4696 * ucfg_mlme_get_update_chan_width_allowed - Get value of INI 4697 * is_update_chan_width_allowed 4698 * @psoc: pointer to psoc object 4699 * @value: pointer to the value which will be filled for the caller 4700 * 4701 * Return: QDF Status 4702 */ 4703 QDF_STATUS 4704 ucfg_mlme_get_update_chan_width_allowed(struct wlan_objmgr_psoc *psoc, 4705 bool *value); 4706 4707 /** 4708 * ucfg_mlme_get_channel_bonding_24ghz() - get channel bonding mode of 24ghz 4709 * @psoc: pointer to psoc object 4710 * @value: pointer to the value which will be filled for the caller 4711 * 4712 * Return: QDF Status 4713 */ 4714 QDF_STATUS 4715 ucfg_mlme_get_channel_bonding_24ghz(struct wlan_objmgr_psoc *psoc, 4716 uint32_t *value); 4717 4718 /** 4719 * ucfg_mlme_set_channel_bonding_24ghz() - set channel bonding mode for 24ghz 4720 * @psoc: pointer to psoc object 4721 * @value: channel bonding mode 4722 * 4723 * Return: QDF Status 4724 */ 4725 QDF_STATUS 4726 ucfg_mlme_set_channel_bonding_24ghz(struct wlan_objmgr_psoc *psoc, 4727 uint32_t value); 4728 4729 /** 4730 * ucfg_mlme_get_channel_bonding_5ghz() - get channel bonding mode of 5ghz 4731 * @psoc: pointer to psoc object 4732 * @value: pointer to the value which will be filled for the caller 4733 * 4734 * Return: QDF Status 4735 */ 4736 QDF_STATUS 4737 ucfg_mlme_get_channel_bonding_5ghz(struct wlan_objmgr_psoc *psoc, 4738 uint32_t *value); 4739 4740 /** 4741 * ucfg_mlme_set_channel_bonding_5ghz() - set channel bonding mode for 5ghz 4742 * @psoc: pointer to psoc object 4743 * @value: channel bonding mode 4744 * 4745 * Return: QDF Status 4746 */ 4747 QDF_STATUS 4748 ucfg_mlme_set_channel_bonding_5ghz(struct wlan_objmgr_psoc *psoc, 4749 uint32_t value); 4750 4751 /** 4752 * ucfg_mlme_get_scan_probe_unicast_ra() - Get scan probe unicast RA cfg 4753 * 4754 * @psoc: pointer to psoc object 4755 * @value: value which needs to filled by API 4756 * 4757 * This API gives scan probe request with unicast RA user config 4758 * 4759 * Return: QDF_STATUS 4760 */ 4761 static inline QDF_STATUS ucfg_mlme_get_scan_probe_unicast_ra(struct wlan_objmgr_psoc * psoc,bool * value)4762 ucfg_mlme_get_scan_probe_unicast_ra(struct wlan_objmgr_psoc *psoc, 4763 bool *value) 4764 { 4765 return wlan_mlme_get_scan_probe_unicast_ra(psoc, value); 4766 } 4767 4768 /** 4769 * ucfg_mlme_set_scan_probe_unicast_ra() - Set scan probe unicast RA cfg 4770 * 4771 * @psoc: pointer to psoc object 4772 * @value: set value 4773 * 4774 * This API sets scan probe request with unicast RA user config 4775 * 4776 * Return: QDF_STATUS 4777 */ 4778 static inline QDF_STATUS ucfg_mlme_set_scan_probe_unicast_ra(struct wlan_objmgr_psoc * psoc,bool value)4779 ucfg_mlme_set_scan_probe_unicast_ra(struct wlan_objmgr_psoc *psoc, 4780 bool value) 4781 { 4782 return wlan_mlme_set_scan_probe_unicast_ra(psoc, value); 4783 } 4784 4785 /** 4786 * ucfg_mlme_get_peer_phymode() - get phymode of peer 4787 * @psoc: pointer to psoc object 4788 * @mac: Pointer to the mac addr of the peer 4789 * @peer_phymode: phymode 4790 * 4791 * Return: QDF Status 4792 */ 4793 static inline QDF_STATUS ucfg_mlme_get_peer_phymode(struct wlan_objmgr_psoc * psoc,uint8_t * mac,enum wlan_phymode * peer_phymode)4794 ucfg_mlme_get_peer_phymode(struct wlan_objmgr_psoc *psoc, uint8_t *mac, 4795 enum wlan_phymode *peer_phymode) 4796 { 4797 return mlme_get_peer_phymode(psoc, mac, peer_phymode); 4798 } 4799 4800 /** 4801 * ucfg_mlme_validate_full_roam_scan_period() - Validate full roam scan period 4802 * @full_roam_scan_period: Idle period in seconds between two successive 4803 * full channel roam scans 4804 * 4805 * Return: True if full_roam_scan_period is in expected range, false otherwise. 4806 */ 4807 bool ucfg_mlme_validate_full_roam_scan_period(uint32_t full_roam_scan_period); 4808 4809 /** 4810 * ucfg_mlme_validate_scan_period() - Validate if scan period is in valid range 4811 * @psoc: Pointer to soc 4812 * @roam_scan_period: Scan period in msec 4813 * 4814 * Return: True if roam_scan_period is in expected range, false otherwise. 4815 */ 4816 bool ucfg_mlme_validate_scan_period(struct wlan_objmgr_psoc *psoc, 4817 uint32_t roam_scan_period); 4818 /** 4819 * ucfg_mlme_get_ignore_fw_reg_offload_ind() - Get the 4820 * ignore_fw_reg_offload_ind ini 4821 * @psoc: pointer to psoc object 4822 * @disabled: output pointer to hold user config 4823 * 4824 * Return: QDF Status 4825 */ 4826 static inline QDF_STATUS ucfg_mlme_get_ignore_fw_reg_offload_ind(struct wlan_objmgr_psoc * psoc,bool * disabled)4827 ucfg_mlme_get_ignore_fw_reg_offload_ind(struct wlan_objmgr_psoc *psoc, 4828 bool *disabled) 4829 { 4830 return wlan_mlme_get_ignore_fw_reg_offload_ind(psoc, disabled); 4831 } 4832 4833 /** 4834 * ucfg_mlme_get_peer_unmap_conf() - Indicate if peer unmap confirmation 4835 * support is enabled or disabled 4836 * @psoc: pointer to psoc object 4837 * 4838 * Return: true if peer unmap confirmation support is enabled, else false 4839 */ 4840 static inline ucfg_mlme_get_peer_unmap_conf(struct wlan_objmgr_psoc * psoc)4841 QDF_STATUS ucfg_mlme_get_peer_unmap_conf(struct wlan_objmgr_psoc *psoc) 4842 { 4843 return wlan_mlme_get_peer_unmap_conf(psoc); 4844 } 4845 4846 #ifdef WLAN_FEATURE_ROAM_OFFLOAD 4847 /** 4848 * ucfg_mlme_get_roam_reason_vsie_status() - Get roam reason vsie is 4849 * enabled or disabled 4850 * @psoc: pointer to psoc object 4851 * @roam_reason_vsie_enabled: pointer to hold value of roam reason vsie 4852 * 4853 * Return: Success if able to get bcn rpt err vsie value, else failure 4854 */ 4855 static inline QDF_STATUS ucfg_mlme_get_roam_reason_vsie_status(struct wlan_objmgr_psoc * psoc,uint8_t * roam_reason_vsie_enabled)4856 ucfg_mlme_get_roam_reason_vsie_status(struct wlan_objmgr_psoc *psoc, 4857 uint8_t *roam_reason_vsie_enabled) 4858 { 4859 return wlan_mlme_get_roam_reason_vsie_status(psoc, 4860 roam_reason_vsie_enabled); 4861 } 4862 4863 /** 4864 * ucfg_mlme_set_roam_reason_vsie_status() - Update roam reason vsie status 4865 * value with user configured value 4866 * @psoc: pointer to psoc object 4867 * @roam_reason_vsie_enabled: value of roam reason vsie status 4868 * 4869 * Return: Success if able to get bcn rpt err vsie value, else failure 4870 */ 4871 static inline QDF_STATUS ucfg_mlme_set_roam_reason_vsie_status(struct wlan_objmgr_psoc * psoc,uint8_t roam_reason_vsie_enabled)4872 ucfg_mlme_set_roam_reason_vsie_status(struct wlan_objmgr_psoc *psoc, 4873 uint8_t roam_reason_vsie_enabled) 4874 { 4875 return wlan_mlme_set_roam_reason_vsie_status(psoc, 4876 roam_reason_vsie_enabled); 4877 } 4878 4879 #endif 4880 4881 /** 4882 * ucfg_mlme_set_vdev_wifi_std() - Set vdev wifi standard support 4883 * @psoc: pointer to psoc object 4884 * @vdev_id: Vdev id 4885 * @wifi_std: wifi standard version 4886 * 4887 * Return: QDF_STATUS 4888 */ 4889 QDF_STATUS 4890 ucfg_mlme_set_vdev_wifi_std(struct wlan_objmgr_psoc *psoc, uint8_t vdev_id, 4891 WMI_HOST_WIFI_STANDARD wifi_std); 4892 4893 /** 4894 * ucfg_mlme_set_vdev_traffic_low_latency() - Set/clear vdev low latency 4895 * config 4896 * @psoc: pointer to psoc object 4897 * @vdev_id: Vdev id 4898 * @set: Flag to indicate set or clear 4899 * 4900 * Return: QDF_STATUS 4901 */ 4902 QDF_STATUS 4903 ucfg_mlme_set_vdev_traffic_low_latency(struct wlan_objmgr_psoc *psoc, 4904 uint8_t vdev_id, bool set); 4905 4906 /** 4907 * ucfg_mlme_update_bss_rate_flags() - update bss rate flag as per new channel 4908 * width 4909 * @psoc: pointer to psoc object 4910 * @vdev_id: Vdev id 4911 * @ch_width: channel width to update 4912 * @eht_present: connected bss is eht capable or not 4913 * @he_present: connected bss is he capable or not 4914 * @vht_present: connected bss is vht capable or not 4915 * @ht_present: connected bss is ht capable or not 4916 * 4917 * Return: QDF_STATUS 4918 */ 4919 QDF_STATUS ucfg_mlme_update_bss_rate_flags(struct wlan_objmgr_psoc *psoc, 4920 uint8_t vdev_id, 4921 enum phy_ch_width ch_width, 4922 uint8_t eht_present, 4923 uint8_t he_present, 4924 uint8_t vht_present, 4925 uint8_t ht_present); 4926 4927 /** 4928 * ucfg_mlme_send_ch_width_update_with_notify() - Send chwidth with notify 4929 * capability of FW 4930 * @psoc: pointer to psoc object 4931 * @link_vdev: Link VDEV object 4932 * @ch_width: channel width to update 4933 * @link_vdev_id: vdev id for each link 4934 * 4935 * Return: QDF_STATUS 4936 */ 4937 QDF_STATUS 4938 ucfg_mlme_send_ch_width_update_with_notify(struct wlan_objmgr_psoc *psoc, 4939 struct wlan_objmgr_vdev *link_vdev, 4940 enum phy_ch_width ch_width, 4941 uint8_t link_vdev_id); 4942 4943 /** 4944 * ucfg_mlme_is_chwidth_with_notify_supported() - Get chwidth with notify 4945 * capability of FW 4946 * @psoc: pointer to psoc object 4947 * 4948 * Return: true if chwidth with notify feature supported 4949 */ 4950 bool 4951 ucfg_mlme_is_chwidth_with_notify_supported(struct wlan_objmgr_psoc *psoc); 4952 4953 /** 4954 * ucfg_mlme_connected_chan_stats_request() - process connected channel stats 4955 * request 4956 * @psoc: pointer to psoc object 4957 * @vdev_id: Vdev id 4958 * 4959 * Return: QDF_STATUS 4960 */ 4961 QDF_STATUS ucfg_mlme_connected_chan_stats_request(struct wlan_objmgr_psoc *psoc, 4962 uint8_t vdev_id); 4963 4964 /** 4965 * ucfg_mlme_set_vdev_traffic_high_throughput() - Set/clear vdev high 4966 * throughput config 4967 * @psoc: pointer to psoc object 4968 * @vdev_id: Vdev id 4969 * @set: Flag to indicate set or clear 4970 * 4971 * Return: QDF_STATUS 4972 */ 4973 QDF_STATUS 4974 ucfg_mlme_set_vdev_traffic_high_throughput(struct wlan_objmgr_psoc *psoc, 4975 uint8_t vdev_id, bool set); 4976 4977 /** 4978 * ucfg_mlme_set_user_ps() - Set the PS user config 4979 * @psoc: pointer to psoc object 4980 * @vdev_id: Vdev id 4981 * @ps_enable: Flag to indicate if user PS is enabled 4982 * 4983 * Return: QDF_STATUS 4984 */ 4985 static inline ucfg_mlme_set_user_ps(struct wlan_objmgr_psoc * psoc,uint8_t vdev_id,bool ps_enable)4986 QDF_STATUS ucfg_mlme_set_user_ps(struct wlan_objmgr_psoc *psoc, uint8_t vdev_id, 4987 bool ps_enable) 4988 { 4989 return mlme_set_user_ps(psoc, vdev_id, ps_enable); 4990 } 4991 4992 /** 4993 * ucfg_mlme_get_user_ps() - Get user PS flag 4994 * @psoc: pointer to psoc object 4995 * @vdev_id: Vdev id 4996 * 4997 * Return: True if user ps is enabled else false 4998 */ 4999 static inline ucfg_mlme_get_user_ps(struct wlan_objmgr_psoc * psoc,uint8_t vdev_id)5000 bool ucfg_mlme_get_user_ps(struct wlan_objmgr_psoc *psoc, uint8_t vdev_id) 5001 { 5002 return mlme_get_user_ps(psoc, vdev_id); 5003 } 5004 5005 /** 5006 * ucfg_mlme_set_ft_over_ds() - update ft_over_ds status with user configured 5007 * value 5008 * @psoc: pointer to psoc object 5009 * @ft_over_ds_enable: value of ft_over_ds 5010 * 5011 * Return: QDF Status 5012 */ 5013 static inline QDF_STATUS ucfg_mlme_set_ft_over_ds(struct wlan_objmgr_psoc * psoc,uint8_t ft_over_ds_enable)5014 ucfg_mlme_set_ft_over_ds(struct wlan_objmgr_psoc *psoc, 5015 uint8_t ft_over_ds_enable) 5016 { 5017 return wlan_mlme_set_ft_over_ds(psoc, ft_over_ds_enable); 5018 } 5019 5020 /** 5021 * ucfg_mlme_is_sta_mon_conc_supported() - Check if STA + Monitor mode 5022 * concurrency is supported 5023 * @psoc: pointer to psoc object 5024 * 5025 * Return: True if supported, else false. 5026 */ 5027 static inline bool ucfg_mlme_is_sta_mon_conc_supported(struct wlan_objmgr_psoc * psoc)5028 ucfg_mlme_is_sta_mon_conc_supported(struct wlan_objmgr_psoc *psoc) 5029 { 5030 return wlan_mlme_is_sta_mon_conc_supported(psoc); 5031 } 5032 5033 /** 5034 * ucfg_mlme_cfg_get_eht_caps() - Get the EHT capability info 5035 * @psoc: pointer to psoc object 5036 * @eht_cap: Caps that needs to be filled. 5037 * 5038 * Return: QDF Status 5039 */ 5040 static inline ucfg_mlme_cfg_get_eht_caps(struct wlan_objmgr_psoc * psoc,tDot11fIEeht_cap * eht_cap)5041 QDF_STATUS ucfg_mlme_cfg_get_eht_caps(struct wlan_objmgr_psoc *psoc, 5042 tDot11fIEeht_cap *eht_cap) 5043 { 5044 return mlme_cfg_get_eht_caps(psoc, eht_cap); 5045 } 5046 5047 static inline QDF_STATUS ucfg_mlme_cfg_get_vht_ampdu_len_exp(struct wlan_objmgr_psoc * psoc,uint8_t * value)5048 ucfg_mlme_cfg_get_vht_ampdu_len_exp(struct wlan_objmgr_psoc *psoc, 5049 uint8_t *value) 5050 { 5051 return wlan_mlme_cfg_get_vht_ampdu_len_exp(psoc, value); 5052 } 5053 5054 static inline QDF_STATUS ucfg_mlme_cfg_get_vht_max_mpdu_len(struct wlan_objmgr_psoc * psoc,uint8_t * value)5055 ucfg_mlme_cfg_get_vht_max_mpdu_len(struct wlan_objmgr_psoc *psoc, 5056 uint8_t *value) 5057 { 5058 return wlan_mlme_cfg_get_vht_max_mpdu_len(psoc, value); 5059 } 5060 5061 static inline QDF_STATUS ucfg_mlme_cfg_get_ht_smps(struct wlan_objmgr_psoc * psoc,uint8_t * value)5062 ucfg_mlme_cfg_get_ht_smps(struct wlan_objmgr_psoc *psoc, 5063 uint8_t *value) 5064 { 5065 return wlan_mlme_cfg_get_ht_smps(psoc, value); 5066 } 5067 5068 #ifdef FEATURE_WLAN_CH_AVOID_EXT 5069 /** 5070 * ucfg_mlme_get_coex_unsafe_chan_nb_user_prefer() - get coex unsafe nb 5071 * support 5072 * @psoc: pointer to psoc object 5073 * 5074 * Return: coex_unsafe_chan_nb_user_prefer 5075 */ 5076 bool ucfg_mlme_get_coex_unsafe_chan_nb_user_prefer( 5077 struct wlan_objmgr_psoc *psoc); 5078 5079 bool ucfg_mlme_get_coex_unsafe_chan_nb_user_prefer_for_sap( 5080 struct wlan_objmgr_psoc *psoc); 5081 5082 /** 5083 * ucfg_mlme_get_coex_unsafe_chan_reg_disable() - get reg disable cap for 5084 * coex unsafe channels support 5085 * @psoc: pointer to psoc object 5086 * 5087 * Return: coex_unsafe_chan_reg_disable 5088 */ 5089 bool ucfg_mlme_get_coex_unsafe_chan_reg_disable( 5090 struct wlan_objmgr_psoc *psoc); 5091 #else 5092 static inline ucfg_mlme_get_coex_unsafe_chan_nb_user_prefer(struct wlan_objmgr_psoc * psoc)5093 bool ucfg_mlme_get_coex_unsafe_chan_nb_user_prefer( 5094 struct wlan_objmgr_psoc *psoc) 5095 { 5096 return false; 5097 } 5098 5099 static inline ucfg_mlme_get_coex_unsafe_chan_nb_user_prefer_for_sap(struct wlan_objmgr_psoc * psoc)5100 bool ucfg_mlme_get_coex_unsafe_chan_nb_user_prefer_for_sap( 5101 struct wlan_objmgr_psoc *psoc) 5102 { 5103 return false; 5104 } 5105 5106 static inline ucfg_mlme_get_coex_unsafe_chan_reg_disable(struct wlan_objmgr_psoc * psoc)5107 bool ucfg_mlme_get_coex_unsafe_chan_reg_disable( 5108 struct wlan_objmgr_psoc *psoc) 5109 { 5110 return false; 5111 } 5112 #endif 5113 5114 /** 5115 * ucfg_set_ratemask_params() - Set ratemask config 5116 * @vdev: pointer to vdev object 5117 * @num_ratemask: number of ratemask params 5118 * @rate_params: ratemask params 5119 * 5120 * Return: QDF_STATUS 5121 */ 5122 static inline QDF_STATUS ucfg_set_ratemask_params(struct wlan_objmgr_vdev * vdev,uint8_t num_ratemask,struct config_ratemask_params * rate_params)5123 ucfg_set_ratemask_params(struct wlan_objmgr_vdev *vdev, 5124 uint8_t num_ratemask, 5125 struct config_ratemask_params *rate_params) 5126 { 5127 return wlan_mlme_update_ratemask_params(vdev, num_ratemask, 5128 rate_params); 5129 } 5130 5131 /* 5132 * ucfg_mlme_set_user_mcc_quota() - Set the user set mcc quota in mlme 5133 * value 5134 * @psoc: pointer to psoc object 5135 * @quota: pointer to user mcc quota object 5136 * 5137 * Return: QDF Status 5138 */ 5139 static inline ucfg_mlme_set_user_mcc_quota(struct wlan_objmgr_psoc * psoc,struct wlan_user_mcc_quota * quota)5140 QDF_STATUS ucfg_mlme_set_user_mcc_quota(struct wlan_objmgr_psoc *psoc, 5141 struct wlan_user_mcc_quota *quota) 5142 { 5143 return wlan_mlme_set_user_mcc_quota(psoc, quota); 5144 } 5145 5146 /** 5147 * ucfg_mlme_get_user_mcc_quota() - Get the user set mcc quota from mlme 5148 * value 5149 * @psoc: pointer to psoc object 5150 * @quota: pointer to user mcc quota object 5151 * 5152 * Return: QDF Status 5153 */ 5154 static inline ucfg_mlme_get_user_mcc_quota(struct wlan_objmgr_psoc * psoc,struct wlan_user_mcc_quota * quota)5155 QDF_STATUS ucfg_mlme_get_user_mcc_quota(struct wlan_objmgr_psoc *psoc, 5156 struct wlan_user_mcc_quota *quota) 5157 { 5158 return wlan_mlme_get_user_mcc_quota(psoc, quota); 5159 } 5160 5161 /** 5162 * ucfg_mlme_get_user_mcc_quota_percentage() - Get user mcc quota percentage 5163 * duty-cycle for a i/f type or mode 5164 * @psoc: pointer to psoc object 5165 * 5166 * MCC duty-cycle value in below format 5167 * ****************************************************** 5168 * |bit 31-24 | bit 23-16 | bits 15-8 |bits 7-0 | 5169 * | Unused | Quota for | chan. # for |chan. # for| 5170 * | | 1st chan | 1st chan. |2nd chan. | 5171 * ***************************************************** 5172 * 5173 * Return: primary iface MCC duty-cycle value 5174 */ 5175 static inline ucfg_mlme_get_user_mcc_quota_percentage(struct wlan_objmgr_psoc * psoc)5176 uint32_t ucfg_mlme_get_user_mcc_quota_percentage(struct wlan_objmgr_psoc *psoc) 5177 { 5178 return wlan_mlme_get_user_mcc_duty_cycle_percentage(psoc); 5179 } 5180 5181 /** 5182 * ucfg_mlme_get_wds_mode() - Get the configured WDS mode 5183 * @psoc: pointer to psoc object 5184 * 5185 * Return: supported wds mode from enum wlan_wds_mode 5186 */ 5187 static inline uint32_t ucfg_mlme_get_wds_mode(struct wlan_objmgr_psoc * psoc)5188 ucfg_mlme_get_wds_mode(struct wlan_objmgr_psoc *psoc) 5189 { 5190 return wlan_mlme_get_wds_mode(psoc); 5191 } 5192 5193 /** 5194 * ucfg_mlme_set_wds_mode() - Set the configured WDS mode 5195 * @psoc: pointer to psoc object 5196 * @mode: wds mode to set 5197 * 5198 * Return: void 5199 */ 5200 static inline void ucfg_mlme_set_wds_mode(struct wlan_objmgr_psoc * psoc,uint32_t mode)5201 ucfg_mlme_set_wds_mode(struct wlan_objmgr_psoc *psoc, uint32_t mode) 5202 { 5203 wlan_mlme_set_wds_mode(psoc, mode); 5204 } 5205 5206 #ifdef WLAN_FEATURE_SON 5207 /** 5208 * ucfg_mlme_get_vdev_max_mcs_idx() - Get max mcs idx of given vdev 5209 * @vdev: pointer to vdev object 5210 * 5211 * Return: max mcs idx of given vdev 5212 */ 5213 static inline uint8_t ucfg_mlme_get_vdev_max_mcs_idx(struct wlan_objmgr_vdev * vdev)5214 ucfg_mlme_get_vdev_max_mcs_idx(struct wlan_objmgr_vdev *vdev) 5215 { 5216 return mlme_get_vdev_max_mcs_idx(vdev); 5217 } 5218 #endif /* WLAN_FEATURE_SON */ 5219 5220 #if defined(CONFIG_AFC_SUPPORT) && defined(CONFIG_BAND_6GHZ) 5221 /** 5222 * ucfg_mlme_get_enable_6ghz_sp_mode_support() - Get 6 GHz SP mode support cfg 5223 * @psoc: pointer to psoc object 5224 * @value: value to be set 5225 * 5226 * Return: QDF Status 5227 */ 5228 QDF_STATUS 5229 ucfg_mlme_get_enable_6ghz_sp_mode_support(struct wlan_objmgr_psoc *psoc, 5230 bool *value); 5231 5232 /** 5233 * ucfg_mlme_get_afc_disable_timer_check() - Get AFC timer check cfg 5234 * @psoc: pointer to psoc object 5235 * @value: value to be set 5236 * 5237 * Return: QDF Status 5238 */ 5239 QDF_STATUS 5240 ucfg_mlme_get_afc_disable_timer_check(struct wlan_objmgr_psoc *psoc, 5241 bool *value); 5242 /** 5243 * ucfg_mlme_get_afc_disable_request_id_check() - Get AFC request id check cfg 5244 * @psoc: pointer to psoc object 5245 * @value: value to be set 5246 * 5247 * Return: QDF Status 5248 */ 5249 QDF_STATUS 5250 ucfg_mlme_get_afc_disable_request_id_check(struct wlan_objmgr_psoc *psoc, 5251 bool *value); 5252 5253 /** 5254 * ucfg_mlme_get_afc_reg_noaction() - Get AFC no action cfg 5255 * @psoc: pointer to psoc object 5256 * @value: value to be set 5257 * 5258 * Return: QDF Status 5259 */ 5260 QDF_STATUS 5261 ucfg_mlme_get_afc_reg_noaction(struct wlan_objmgr_psoc *psoc, bool *value); 5262 #else 5263 static inline QDF_STATUS ucfg_mlme_get_enable_6ghz_sp_mode_support(struct wlan_objmgr_psoc * psoc,bool * value)5264 ucfg_mlme_get_enable_6ghz_sp_mode_support(struct wlan_objmgr_psoc *psoc, 5265 bool *value) 5266 { 5267 return QDF_STATUS_E_NOSUPPORT; 5268 } 5269 5270 static inline QDF_STATUS ucfg_mlme_get_afc_disable_timer_check(struct wlan_objmgr_psoc * psoc,bool * value)5271 ucfg_mlme_get_afc_disable_timer_check(struct wlan_objmgr_psoc *psoc, 5272 bool *value) 5273 { 5274 return QDF_STATUS_E_NOSUPPORT; 5275 } 5276 5277 static inline QDF_STATUS ucfg_mlme_get_afc_disable_request_id_check(struct wlan_objmgr_psoc * psoc,bool * value)5278 ucfg_mlme_get_afc_disable_request_id_check(struct wlan_objmgr_psoc *psoc, 5279 bool *value) 5280 { 5281 return QDF_STATUS_E_NOSUPPORT; 5282 } 5283 5284 static inline QDF_STATUS ucfg_mlme_get_afc_reg_noaction(struct wlan_objmgr_psoc * psoc,bool * value)5285 ucfg_mlme_get_afc_reg_noaction(struct wlan_objmgr_psoc *psoc, bool *value) 5286 { 5287 return QDF_STATUS_E_NOSUPPORT; 5288 } 5289 #endif 5290 5291 #ifdef CONNECTION_ROAMING_CFG 5292 /** 5293 * ucfg_mlme_set_connection_roaming_ini_present() - Set connection roaming ini 5294 * present 5295 * @psoc: pointer to psoc object 5296 * @value: Value to be set 5297 * 5298 * Return: QDF Status 5299 */ 5300 QDF_STATUS 5301 ucfg_mlme_set_connection_roaming_ini_present(struct wlan_objmgr_psoc *psoc, 5302 bool value); 5303 5304 /** 5305 * ucfg_mlme_get_connection_roaming_ini_present() - Get connection roaming ini 5306 * present 5307 * @psoc: pointer to psoc object 5308 * @value: Value to be get 5309 * 5310 * Return: QDF Status 5311 */ 5312 QDF_STATUS 5313 ucfg_mlme_get_connection_roaming_ini_present(struct wlan_objmgr_psoc *psoc, 5314 bool *value); 5315 #else 5316 static inline QDF_STATUS ucfg_mlme_set_connection_roaming_ini_present(struct wlan_objmgr_psoc * psoc,bool value)5317 ucfg_mlme_set_connection_roaming_ini_present(struct wlan_objmgr_psoc *psoc, 5318 bool value) 5319 { 5320 return QDF_STATUS_E_NOSUPPORT; 5321 } 5322 5323 static inline QDF_STATUS ucfg_mlme_get_connection_roaming_ini_present(struct wlan_objmgr_psoc * psoc,bool * value)5324 ucfg_mlme_get_connection_roaming_ini_present(struct wlan_objmgr_psoc *psoc, 5325 bool *value) 5326 { 5327 return QDF_STATUS_E_NOSUPPORT; 5328 } 5329 #endif /* CONNECTION_ROAMING_CFG */ 5330 5331 /** 5332 * ucfg_mlme_get_ch_width_from_phymode() - Convert phymode to ch_width 5333 * @phy_mode: phy mode 5334 * 5335 * Return: enum phy_ch_width 5336 */ 5337 static inline enum phy_ch_width ucfg_mlme_get_ch_width_from_phymode(enum wlan_phymode phy_mode)5338 ucfg_mlme_get_ch_width_from_phymode(enum wlan_phymode phy_mode) 5339 { 5340 return wlan_mlme_get_ch_width_from_phymode(phy_mode); 5341 } 5342 5343 /** 5344 * ucfg_mlme_get_peer_ch_width() - get ch_width of the given peer 5345 * @psoc: pointer to psoc object 5346 * @mac: peer mac 5347 * 5348 * Return: enum phy_ch_width 5349 */ 5350 static inline enum phy_ch_width ucfg_mlme_get_peer_ch_width(struct wlan_objmgr_psoc * psoc,uint8_t * mac)5351 ucfg_mlme_get_peer_ch_width(struct wlan_objmgr_psoc *psoc, uint8_t *mac) 5352 { 5353 return wlan_mlme_get_peer_ch_width(psoc, mac); 5354 } 5355 5356 /** 5357 * ucfg_mlme_get_vdev_phy_mode() - Get phymode of a vdev 5358 * @psoc: pointer to psoc object 5359 * @vdev_id: vdev id 5360 * 5361 * Return: enum wlan_phymode 5362 */ 5363 enum wlan_phymode 5364 ucfg_mlme_get_vdev_phy_mode(struct wlan_objmgr_psoc *psoc, uint8_t vdev_id); 5365 5366 #if defined(WLAN_FEATURE_SR) 5367 /** 5368 * ucfg_mlme_get_sr_enable_modes() - check for which mode SR is enabled 5369 * 5370 * @psoc: pointer to psoc object 5371 * @val: SR(Spatial Reuse) enable modes 5372 * 5373 * Return: void 5374 */ 5375 static inline void ucfg_mlme_get_sr_enable_modes(struct wlan_objmgr_psoc * psoc,uint8_t * val)5376 ucfg_mlme_get_sr_enable_modes(struct wlan_objmgr_psoc *psoc, 5377 uint8_t *val) 5378 { 5379 wlan_mlme_get_sr_enable_modes(psoc, val); 5380 } 5381 #else 5382 static inline void ucfg_mlme_get_sr_enable_modes(struct wlan_objmgr_psoc * psoc,uint8_t * val)5383 ucfg_mlme_get_sr_enable_modes(struct wlan_objmgr_psoc *psoc, 5384 uint8_t *val) 5385 { 5386 *val = 0; 5387 } 5388 #endif 5389 5390 /** 5391 * ucfg_mlme_get_valid_channels - get valid channels for 5392 * current regulatory domain 5393 * @psoc: pointer to psoc object 5394 * @ch_freq_list: list of the valid channel frequencies 5395 * @list_len: length of the channel list 5396 * 5397 * This function will get valid channels for current regulatory domain 5398 * 5399 * Return: QDF_STATUS_SUCCESS or non-zero on failure 5400 */ 5401 QDF_STATUS 5402 ucfg_mlme_get_valid_channels(struct wlan_objmgr_psoc *psoc, 5403 uint32_t *ch_freq_list, uint32_t *list_len); 5404 5405 /** 5406 * ucfg_mlme_set_ul_mu_config - set ul mu config 5407 * @psoc: pointer to psoc object 5408 * @vdev_id : vdev ID 5409 * @ulmu_disable: ul mu value 5410 * 5411 * Inline UCFG API to be used by HDD/OSIF callers 5412 * 5413 * Return: QDF_STATUS_SUCCESS or non-zero on failure 5414 */ 5415 static inline ucfg_mlme_set_ul_mu_config(struct wlan_objmgr_psoc * psoc,uint8_t vdev_id,uint8_t ulmu_disable)5416 QDF_STATUS ucfg_mlme_set_ul_mu_config(struct wlan_objmgr_psoc *psoc, 5417 uint8_t vdev_id, 5418 uint8_t ulmu_disable) 5419 { 5420 return wlan_mlme_set_ul_mu_config(psoc, vdev_id, ulmu_disable); 5421 } 5422 5423 /** 5424 * ucfg_mlme_assemble_rate_code - assemble rate code to be sent to FW 5425 * @preamble: rate preamble 5426 * @nss: number of spatial streams 5427 * @rate: rate index 5428 * 5429 * Rate code assembling is different for targets which are 11ax capable. 5430 * Check for the target support and assemble the rate code accordingly. 5431 * 5432 * Return: assembled rate code 5433 */ 5434 static inline uint32_t ucfg_mlme_assemble_rate_code(uint8_t preamble,uint8_t nss,uint8_t rate)5435 ucfg_mlme_assemble_rate_code(uint8_t preamble, uint8_t nss, uint8_t rate) 5436 { 5437 return wlan_mlme_assemble_rate_code(preamble, nss, rate); 5438 } 5439 5440 /** 5441 * ucfg_mlme_get_keepalive_period() - Get keep alive period 5442 * @vdev: VDEV object 5443 * 5444 * Return: Keep alive period. 5445 */ 5446 static inline ucfg_mlme_get_keepalive_period(struct wlan_objmgr_vdev * vdev)5447 uint16_t ucfg_mlme_get_keepalive_period(struct wlan_objmgr_vdev *vdev) 5448 { 5449 return wlan_mlme_get_keepalive_period(vdev); 5450 } 5451 #endif /* _WLAN_MLME_UCFG_API_H_ */ 5452