wlan_mlme_ucfg_api.c 38 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700
  1. /*
  2. * Copyright (c) 2018-2019 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. /**
  19. * DOC: define UCFG APIs exposed by the mlme component
  20. */
  21. #include "cfg_ucfg_api.h"
  22. #include "cfg_mlme_sta.h"
  23. #include "wlan_mlme_main.h"
  24. #include "wlan_mlme_api.h"
  25. #include "wlan_mlme_ucfg_api.h"
  26. #include "wlan_objmgr_pdev_obj.h"
  27. #include "wlan_mlme_vdev_mgr_interface.h"
  28. #include <include/wlan_pdev_mlme.h>
  29. #include "wlan_pdev_mlme_api.h"
  30. QDF_STATUS ucfg_mlme_global_init(void)
  31. {
  32. mlme_register_mlme_ext_ops();
  33. return QDF_STATUS_SUCCESS;
  34. }
  35. QDF_STATUS ucfg_mlme_global_deinit(void)
  36. {
  37. return QDF_STATUS_SUCCESS;
  38. }
  39. QDF_STATUS ucfg_mlme_init(void)
  40. {
  41. QDF_STATUS status;
  42. status = wlan_objmgr_register_psoc_create_handler(
  43. WLAN_UMAC_COMP_MLME,
  44. mlme_psoc_object_created_notification,
  45. NULL);
  46. if (status != QDF_STATUS_SUCCESS) {
  47. mlme_legacy_err("unable to register psoc create handle");
  48. return status;
  49. }
  50. status = wlan_objmgr_register_psoc_destroy_handler(
  51. WLAN_UMAC_COMP_MLME,
  52. mlme_psoc_object_destroyed_notification,
  53. NULL);
  54. if (status != QDF_STATUS_SUCCESS) {
  55. mlme_legacy_err("unable to register psoc create handle");
  56. return status;
  57. }
  58. status = wlan_objmgr_register_peer_create_handler(
  59. WLAN_UMAC_COMP_MLME,
  60. mlme_peer_object_created_notification,
  61. NULL);
  62. if (QDF_IS_STATUS_ERROR(status)) {
  63. mlme_legacy_err("peer create register notification failed");
  64. return QDF_STATUS_E_FAILURE;
  65. }
  66. status = wlan_objmgr_register_peer_destroy_handler(
  67. WLAN_UMAC_COMP_MLME,
  68. mlme_peer_object_destroyed_notification,
  69. NULL);
  70. if (QDF_IS_STATUS_ERROR(status)) {
  71. mlme_legacy_err("peer destroy register notification failed");
  72. return QDF_STATUS_E_FAILURE;
  73. }
  74. return status;
  75. }
  76. QDF_STATUS ucfg_mlme_deinit(void)
  77. {
  78. QDF_STATUS status;
  79. status = wlan_objmgr_unregister_peer_destroy_handler(
  80. WLAN_UMAC_COMP_MLME,
  81. mlme_peer_object_destroyed_notification,
  82. NULL);
  83. if (QDF_IS_STATUS_ERROR(status))
  84. mlme_legacy_err("unable to unregister peer destroy handle");
  85. status = wlan_objmgr_unregister_peer_create_handler(
  86. WLAN_UMAC_COMP_MLME,
  87. mlme_peer_object_created_notification,
  88. NULL);
  89. if (QDF_IS_STATUS_ERROR(status))
  90. mlme_legacy_err("unable to unregister peer create handle");
  91. status = wlan_objmgr_unregister_psoc_destroy_handler(
  92. WLAN_UMAC_COMP_MLME,
  93. mlme_psoc_object_destroyed_notification,
  94. NULL);
  95. if (QDF_IS_STATUS_ERROR(status))
  96. mlme_legacy_err("unable to unregister psoc destroy handle");
  97. status = wlan_objmgr_unregister_psoc_create_handler(
  98. WLAN_UMAC_COMP_MLME,
  99. mlme_psoc_object_created_notification,
  100. NULL);
  101. if (status != QDF_STATUS_SUCCESS)
  102. mlme_legacy_err("unable to unregister psoc create handle");
  103. return status;
  104. }
  105. QDF_STATUS ucfg_mlme_psoc_open(struct wlan_objmgr_psoc *psoc)
  106. {
  107. QDF_STATUS status;
  108. status = mlme_cfg_on_psoc_enable(psoc);
  109. if (!QDF_IS_STATUS_SUCCESS(status))
  110. mlme_legacy_err("Failed to initialize MLME CFG");
  111. return status;
  112. }
  113. void ucfg_mlme_psoc_close(struct wlan_objmgr_psoc *psoc)
  114. {
  115. /* Clear the MLME CFG Structure */
  116. }
  117. QDF_STATUS ucfg_mlme_pdev_open(struct wlan_objmgr_pdev *pdev)
  118. {
  119. struct pdev_mlme_obj *pdev_mlme;
  120. pdev_mlme = wlan_pdev_mlme_get_cmpt_obj(pdev);
  121. if (!pdev_mlme) {
  122. mlme_legacy_err(" PDEV MLME is NULL");
  123. return QDF_STATUS_E_FAILURE;
  124. }
  125. pdev_mlme->mlme_register_ops = mlme_register_vdev_mgr_ops;
  126. return QDF_STATUS_SUCCESS;
  127. }
  128. QDF_STATUS ucfg_mlme_pdev_close(struct wlan_objmgr_pdev *pdev)
  129. {
  130. return QDF_STATUS_SUCCESS;
  131. }
  132. QDF_STATUS
  133. ucfg_mlme_get_sta_keep_alive_period(struct wlan_objmgr_psoc *psoc,
  134. uint32_t *val)
  135. {
  136. struct wlan_mlme_psoc_obj *mlme_obj;
  137. mlme_obj = mlme_get_psoc_obj(psoc);
  138. if (!mlme_obj) {
  139. *val = cfg_default(CFG_INFRA_STA_KEEP_ALIVE_PERIOD);
  140. return QDF_STATUS_E_INVAL;
  141. }
  142. *val = mlme_obj->cfg.sta.sta_keep_alive_period;
  143. return QDF_STATUS_SUCCESS;
  144. }
  145. QDF_STATUS
  146. ucfg_mlme_get_dfs_master_capability(struct wlan_objmgr_psoc *psoc,
  147. bool *val)
  148. {
  149. struct wlan_mlme_psoc_obj *mlme_obj;
  150. mlme_obj = mlme_get_psoc_obj(psoc);
  151. if (!mlme_obj) {
  152. *val = cfg_default(CFG_ENABLE_DFS_MASTER_CAPABILITY);
  153. return QDF_STATUS_E_INVAL;
  154. }
  155. *val = mlme_obj->cfg.dfs_cfg.dfs_master_capable;
  156. return QDF_STATUS_SUCCESS;
  157. }
  158. QDF_STATUS
  159. ucfg_mlme_get_fine_time_meas_cap(struct wlan_objmgr_psoc *psoc,
  160. uint32_t *fine_time_meas_cap)
  161. {
  162. struct wlan_mlme_psoc_obj *mlme_obj;
  163. mlme_obj = mlme_get_psoc_obj(psoc);
  164. if (!mlme_obj) {
  165. *fine_time_meas_cap =
  166. cfg_default(CFG_FINE_TIME_MEAS_CAPABILITY);
  167. return QDF_STATUS_E_INVAL;
  168. }
  169. *fine_time_meas_cap = mlme_obj->cfg.wifi_pos_cfg.fine_time_meas_cap;
  170. return QDF_STATUS_SUCCESS;
  171. }
  172. QDF_STATUS
  173. ucfg_mlme_set_fine_time_meas_cap(struct wlan_objmgr_psoc *psoc,
  174. uint32_t fine_time_meas_cap)
  175. {
  176. struct wlan_mlme_psoc_obj *mlme_obj;
  177. mlme_obj = mlme_get_psoc_obj(psoc);
  178. if (!mlme_obj)
  179. return QDF_STATUS_E_INVAL;
  180. mlme_obj->cfg.wifi_pos_cfg.fine_time_meas_cap = fine_time_meas_cap;
  181. return QDF_STATUS_SUCCESS;
  182. }
  183. QDF_STATUS
  184. ucfg_mlme_get_dfs_disable_channel_switch(struct wlan_objmgr_psoc *psoc,
  185. bool *dfs_disable_channel_switch)
  186. {
  187. struct wlan_mlme_psoc_obj *mlme_obj;
  188. mlme_obj = mlme_get_psoc_obj(psoc);
  189. if (!mlme_obj) {
  190. *dfs_disable_channel_switch =
  191. cfg_default(CFG_DISABLE_DFS_CH_SWITCH);
  192. return QDF_STATUS_E_INVAL;
  193. }
  194. *dfs_disable_channel_switch =
  195. mlme_obj->cfg.dfs_cfg.dfs_disable_channel_switch;
  196. return QDF_STATUS_SUCCESS;
  197. }
  198. QDF_STATUS
  199. ucfg_mlme_set_dfs_disable_channel_switch(struct wlan_objmgr_psoc *psoc,
  200. bool dfs_disable_channel_switch)
  201. {
  202. struct wlan_mlme_psoc_obj *mlme_obj;
  203. mlme_obj = mlme_get_psoc_obj(psoc);
  204. if (!mlme_obj) {
  205. return QDF_STATUS_E_INVAL;
  206. }
  207. mlme_obj->cfg.dfs_cfg.dfs_disable_channel_switch =
  208. dfs_disable_channel_switch;
  209. return QDF_STATUS_SUCCESS;
  210. }
  211. QDF_STATUS
  212. ucfg_mlme_get_dfs_ignore_cac(struct wlan_objmgr_psoc *psoc,
  213. bool *dfs_ignore_cac)
  214. {
  215. struct wlan_mlme_psoc_obj *mlme_obj;
  216. mlme_obj = mlme_get_psoc_obj(psoc);
  217. if (!mlme_obj) {
  218. *dfs_ignore_cac = cfg_default(CFG_IGNORE_CAC);
  219. return QDF_STATUS_E_INVAL;
  220. }
  221. *dfs_ignore_cac = mlme_obj->cfg.dfs_cfg.dfs_ignore_cac;
  222. return QDF_STATUS_SUCCESS;
  223. }
  224. QDF_STATUS
  225. ucfg_mlme_set_dfs_ignore_cac(struct wlan_objmgr_psoc *psoc,
  226. bool dfs_ignore_cac)
  227. {
  228. struct wlan_mlme_psoc_obj *mlme_obj;
  229. mlme_obj = mlme_get_psoc_obj(psoc);
  230. if (!mlme_obj)
  231. return QDF_STATUS_E_INVAL;
  232. mlme_obj->cfg.dfs_cfg.dfs_ignore_cac = dfs_ignore_cac;
  233. return QDF_STATUS_SUCCESS;
  234. }
  235. QDF_STATUS
  236. ucfg_mlme_get_sap_tx_leakage_threshold(struct wlan_objmgr_psoc *psoc,
  237. uint32_t *sap_tx_leakage_threshold)
  238. {
  239. struct wlan_mlme_psoc_obj *mlme_obj;
  240. mlme_obj = mlme_get_psoc_obj(psoc);
  241. if (!mlme_obj) {
  242. *sap_tx_leakage_threshold =
  243. cfg_default(CFG_SAP_TX_LEAKAGE_THRESHOLD);
  244. return QDF_STATUS_E_INVAL;
  245. }
  246. *sap_tx_leakage_threshold =
  247. mlme_obj->cfg.dfs_cfg.sap_tx_leakage_threshold;
  248. return QDF_STATUS_SUCCESS;
  249. }
  250. QDF_STATUS
  251. ucfg_mlme_set_sap_tx_leakage_threshold(struct wlan_objmgr_psoc *psoc,
  252. uint32_t sap_tx_leakage_threshold)
  253. {
  254. struct wlan_mlme_psoc_obj *mlme_obj;
  255. mlme_obj = mlme_get_psoc_obj(psoc);
  256. if (!mlme_obj)
  257. return QDF_STATUS_E_INVAL;
  258. mlme_obj->cfg.dfs_cfg.sap_tx_leakage_threshold =
  259. sap_tx_leakage_threshold;
  260. return QDF_STATUS_SUCCESS;
  261. }
  262. QDF_STATUS
  263. ucfg_mlme_get_dfs_filter_offload(struct wlan_objmgr_psoc *psoc,
  264. bool *dfs_filter_offload)
  265. {
  266. struct wlan_mlme_psoc_obj *mlme_obj;
  267. mlme_obj = mlme_get_psoc_obj(psoc);
  268. if (!mlme_obj) {
  269. *dfs_filter_offload =
  270. cfg_default(CFG_ENABLE_DFS_PHYERR_FILTEROFFLOAD);
  271. return QDF_STATUS_E_INVAL;
  272. }
  273. *dfs_filter_offload = mlme_obj->cfg.dfs_cfg.dfs_filter_offload;
  274. return QDF_STATUS_SUCCESS;
  275. }
  276. QDF_STATUS
  277. ucfg_mlme_set_dfs_filter_offload(struct wlan_objmgr_psoc *psoc,
  278. bool dfs_filter_offload)
  279. {
  280. struct wlan_mlme_psoc_obj *mlme_obj;
  281. mlme_obj = mlme_get_psoc_obj(psoc);
  282. if (!mlme_obj)
  283. return QDF_STATUS_E_INVAL;
  284. mlme_obj->cfg.dfs_cfg.dfs_filter_offload = dfs_filter_offload;
  285. return QDF_STATUS_SUCCESS;
  286. }
  287. QDF_STATUS
  288. ucfg_mlme_get_pmkid_modes(struct wlan_objmgr_psoc *psoc,
  289. uint32_t *val)
  290. {
  291. struct wlan_mlme_psoc_obj *mlme_obj;
  292. mlme_obj = mlme_get_psoc_obj(psoc);
  293. if (!mlme_obj) {
  294. *val = cfg_default(CFG_PMKID_MODES);
  295. return QDF_STATUS_E_INVAL;
  296. }
  297. *val = mlme_obj->cfg.sta.pmkid_modes;
  298. return QDF_STATUS_SUCCESS;
  299. }
  300. QDF_STATUS
  301. ucfg_mlme_set_pmkid_modes(struct wlan_objmgr_psoc *psoc,
  302. uint32_t val)
  303. {
  304. struct wlan_mlme_psoc_obj *mlme_obj;
  305. mlme_obj = mlme_get_psoc_obj(psoc);
  306. if (!mlme_obj)
  307. return QDF_STATUS_E_INVAL;
  308. mlme_obj->cfg.sta.pmkid_modes = val;
  309. return QDF_STATUS_SUCCESS;
  310. }
  311. QDF_STATUS
  312. ucfg_mlme_get_twt_requestor(struct wlan_objmgr_psoc *psoc,
  313. bool *val)
  314. {
  315. struct wlan_mlme_psoc_obj *mlme_obj;
  316. mlme_obj = mlme_get_psoc_obj(psoc);
  317. if (!mlme_obj) {
  318. *val = cfg_default(CFG_TWT_REQUESTOR);
  319. return QDF_STATUS_E_INVAL;
  320. }
  321. *val = mlme_obj->cfg.twt_cfg.is_twt_requestor_enabled;
  322. return QDF_STATUS_SUCCESS;
  323. }
  324. QDF_STATUS
  325. ucfg_mlme_set_twt_requestor(struct wlan_objmgr_psoc *psoc,
  326. bool val)
  327. {
  328. struct wlan_mlme_psoc_obj *mlme_obj;
  329. mlme_obj = mlme_get_psoc_obj(psoc);
  330. if (!mlme_obj)
  331. return QDF_STATUS_E_INVAL;
  332. mlme_obj->cfg.twt_cfg.is_twt_requestor_enabled = val;
  333. return QDF_STATUS_SUCCESS;
  334. }
  335. QDF_STATUS
  336. ucfg_mlme_get_twt_responder(struct wlan_objmgr_psoc *psoc,
  337. bool *val)
  338. {
  339. struct wlan_mlme_psoc_obj *mlme_obj;
  340. mlme_obj = mlme_get_psoc_obj(psoc);
  341. if (!mlme_obj) {
  342. *val = cfg_default(CFG_TWT_RESPONDER);
  343. return QDF_STATUS_E_INVAL;
  344. }
  345. *val = mlme_obj->cfg.twt_cfg.is_twt_responder_enabled;
  346. return QDF_STATUS_SUCCESS;
  347. }
  348. QDF_STATUS
  349. ucfg_mlme_set_twt_responder(struct wlan_objmgr_psoc *psoc,
  350. bool val)
  351. {
  352. struct wlan_mlme_psoc_obj *mlme_obj;
  353. mlme_obj = mlme_get_psoc_obj(psoc);
  354. if (!mlme_obj)
  355. return QDF_STATUS_E_INVAL;
  356. mlme_obj->cfg.twt_cfg.is_twt_responder_enabled = val;
  357. return QDF_STATUS_SUCCESS;
  358. }
  359. QDF_STATUS
  360. ucfg_mlme_get_bcast_twt(struct wlan_objmgr_psoc *psoc,
  361. bool *val)
  362. {
  363. struct wlan_mlme_psoc_obj *mlme_obj;
  364. mlme_obj = mlme_get_psoc_obj(psoc);
  365. if (!mlme_obj) {
  366. *val = cfg_default(CFG_BCAST_TWT);
  367. return QDF_STATUS_E_INVAL;
  368. }
  369. *val = mlme_obj->cfg.twt_cfg.is_twt_bcast_enabled;
  370. return QDF_STATUS_SUCCESS;
  371. }
  372. QDF_STATUS
  373. ucfg_mlme_set_bcast_twt(struct wlan_objmgr_psoc *psoc,
  374. bool val)
  375. {
  376. struct wlan_mlme_psoc_obj *mlme_obj;
  377. mlme_obj = mlme_get_psoc_obj(psoc);
  378. if (!mlme_obj)
  379. return QDF_STATUS_E_INVAL;
  380. mlme_obj->cfg.twt_cfg.is_twt_bcast_enabled = val;
  381. return QDF_STATUS_SUCCESS;
  382. }
  383. QDF_STATUS
  384. ucfg_mlme_get_twt_congestion_timeout(struct wlan_objmgr_psoc *psoc,
  385. uint32_t *val)
  386. {
  387. struct wlan_mlme_psoc_obj *mlme_obj;
  388. mlme_obj = mlme_get_psoc_obj(psoc);
  389. if (!mlme_obj) {
  390. *val = cfg_default(CFG_TWT_CONGESTION_TIMEOUT);
  391. return QDF_STATUS_E_INVAL;
  392. }
  393. *val = mlme_obj->cfg.twt_cfg.twt_congestion_timeout;
  394. return QDF_STATUS_SUCCESS;
  395. }
  396. QDF_STATUS
  397. ucfg_mlme_set_twt_congestion_timeout(struct wlan_objmgr_psoc *psoc,
  398. uint32_t val)
  399. {
  400. struct wlan_mlme_psoc_obj *mlme_obj;
  401. mlme_obj = mlme_get_psoc_obj(psoc);
  402. if (!mlme_obj)
  403. return QDF_STATUS_E_INVAL;
  404. mlme_obj->cfg.twt_cfg.twt_congestion_timeout = val;
  405. return QDF_STATUS_SUCCESS;
  406. }
  407. QDF_STATUS
  408. ucfg_mlme_get_enable_twt(struct wlan_objmgr_psoc *psoc,
  409. bool *val)
  410. {
  411. struct wlan_mlme_psoc_obj *mlme_obj;
  412. mlme_obj = mlme_get_psoc_obj(psoc);
  413. if (!mlme_obj) {
  414. *val = cfg_default(CFG_ENABLE_TWT);
  415. return QDF_STATUS_E_INVAL;
  416. }
  417. *val = mlme_obj->cfg.twt_cfg.is_twt_enabled;
  418. return QDF_STATUS_SUCCESS;
  419. }
  420. QDF_STATUS
  421. ucfg_mlme_set_enable_twt(struct wlan_objmgr_psoc *psoc,
  422. bool val)
  423. {
  424. struct wlan_mlme_psoc_obj *mlme_obj;
  425. mlme_obj = mlme_get_psoc_obj(psoc);
  426. if (!mlme_obj)
  427. return QDF_STATUS_E_INVAL;
  428. mlme_obj->cfg.twt_cfg.is_twt_enabled = val;
  429. return QDF_STATUS_SUCCESS;
  430. }
  431. QDF_STATUS
  432. ucfg_mlme_get_dot11p_mode(struct wlan_objmgr_psoc *psoc,
  433. enum dot11p_mode *out_mode)
  434. {
  435. struct wlan_mlme_psoc_obj *mlme_obj;
  436. mlme_obj = mlme_get_psoc_obj(psoc);
  437. if (!mlme_obj) {
  438. *out_mode = cfg_default(CFG_DOT11P_MODE);
  439. return QDF_STATUS_E_INVAL;
  440. }
  441. *out_mode = mlme_obj->cfg.sta.dot11p_mode;
  442. return QDF_STATUS_SUCCESS;
  443. }
  444. QDF_STATUS
  445. ucfg_mlme_get_go_cts2self_for_sta(struct wlan_objmgr_psoc *psoc,
  446. bool *val)
  447. {
  448. struct wlan_mlme_psoc_obj *mlme_obj;
  449. mlme_obj = mlme_get_psoc_obj(psoc);
  450. if (!mlme_obj) {
  451. *val = cfg_default(CFG_ENABLE_GO_CTS2SELF_FOR_STA);
  452. return QDF_STATUS_E_INVAL;
  453. }
  454. *val = mlme_obj->cfg.sta.enable_go_cts2self_for_sta;
  455. return QDF_STATUS_SUCCESS;
  456. }
  457. QDF_STATUS
  458. ucfg_mlme_get_force_rsne_override(struct wlan_objmgr_psoc *psoc,
  459. bool *val)
  460. {
  461. struct wlan_mlme_psoc_obj *mlme_obj;
  462. mlme_obj = mlme_get_psoc_obj(psoc);
  463. if (!mlme_obj) {
  464. *val = cfg_default(CFG_FORCE_RSNE_OVERRIDE);
  465. return QDF_STATUS_E_INVAL;
  466. }
  467. *val = mlme_obj->cfg.sta.force_rsne_override;
  468. return QDF_STATUS_SUCCESS;
  469. }
  470. QDF_STATUS
  471. ucfg_mlme_get_qcn_ie_support(struct wlan_objmgr_psoc *psoc,
  472. bool *val)
  473. {
  474. struct wlan_mlme_psoc_obj *mlme_obj;
  475. mlme_obj = mlme_get_psoc_obj(psoc);
  476. if (!mlme_obj) {
  477. *val = cfg_default(CFG_QCN_IE_SUPPORT);
  478. return QDF_STATUS_E_INVAL;
  479. }
  480. *val = mlme_obj->cfg.sta.qcn_ie_support;
  481. return QDF_STATUS_SUCCESS;
  482. }
  483. QDF_STATUS
  484. ucfg_mlme_get_tgt_gtx_usr_cfg(struct wlan_objmgr_psoc *psoc,
  485. uint32_t *val)
  486. {
  487. struct wlan_mlme_psoc_obj *mlme_obj;
  488. mlme_obj = mlme_get_psoc_obj(psoc);
  489. if (!mlme_obj) {
  490. *val = cfg_default(CFG_TGT_GTX_USR_CFG);
  491. return QDF_STATUS_E_INVAL;
  492. }
  493. *val = mlme_obj->cfg.sta.tgt_gtx_usr_cfg;
  494. return QDF_STATUS_SUCCESS;
  495. }
  496. QDF_STATUS
  497. ucfg_mlme_is_override_ht20_40_24g(struct wlan_objmgr_psoc *psoc, bool *val)
  498. {
  499. struct wlan_mlme_psoc_obj *mlme_obj;
  500. mlme_obj = mlme_get_psoc_obj(psoc);
  501. if (!mlme_obj) {
  502. *val = cfg_default(CFG_OBSS_HT40_OVERRIDE_HT40_20_24GHZ);
  503. return QDF_STATUS_E_INVAL;
  504. }
  505. *val = mlme_obj->cfg.obss_ht40.is_override_ht20_40_24g;
  506. return QDF_STATUS_SUCCESS;
  507. }
  508. #ifdef WLAN_FEATURE_ROAM_OFFLOAD
  509. QDF_STATUS
  510. ucfg_mlme_get_roaming_offload(struct wlan_objmgr_psoc *psoc,
  511. bool *val)
  512. {
  513. struct wlan_mlme_psoc_obj *mlme_obj;
  514. mlme_obj = mlme_get_psoc_obj(psoc);
  515. if (!mlme_obj) {
  516. *val = cfg_default(CFG_LFR3_ROAMING_OFFLOAD);
  517. return QDF_STATUS_E_INVAL;
  518. }
  519. *val = mlme_obj->cfg.lfr.lfr3_roaming_offload;
  520. return QDF_STATUS_SUCCESS;
  521. }
  522. QDF_STATUS
  523. ucfg_mlme_set_roaming_offload(struct wlan_objmgr_psoc *psoc,
  524. bool val)
  525. {
  526. struct wlan_mlme_psoc_obj *mlme_obj;
  527. mlme_obj = mlme_get_psoc_obj(psoc);
  528. if (!mlme_obj)
  529. return QDF_STATUS_E_INVAL;
  530. mlme_obj->cfg.lfr.lfr3_roaming_offload = val;
  531. return QDF_STATUS_SUCCESS;
  532. }
  533. #endif
  534. QDF_STATUS
  535. ucfg_mlme_get_first_scan_bucket_threshold(struct wlan_objmgr_psoc *psoc,
  536. uint8_t *val)
  537. {
  538. struct wlan_mlme_psoc_obj *mlme_obj;
  539. mlme_obj = mlme_get_psoc_obj(psoc);
  540. if (!mlme_obj) {
  541. *val = cfg_default(CFG_LFR_FIRST_SCAN_BUCKET_THRESHOLD);
  542. return QDF_STATUS_E_INVAL;
  543. }
  544. *val = mlme_obj->cfg.lfr.first_scan_bucket_threshold;
  545. return QDF_STATUS_SUCCESS;
  546. }
  547. QDF_STATUS
  548. ucfg_mlme_is_mawc_enabled(struct wlan_objmgr_psoc *psoc, bool *val)
  549. {
  550. struct wlan_mlme_psoc_obj *mlme_obj;
  551. mlme_obj = mlme_get_psoc_obj(psoc);
  552. if (!mlme_obj) {
  553. *val = cfg_default(CFG_LFR_MAWC_FEATURE_ENABLED);
  554. return QDF_STATUS_E_INVAL;
  555. }
  556. *val = mlme_obj->cfg.lfr.mawc_enabled;
  557. return QDF_STATUS_SUCCESS;
  558. }
  559. QDF_STATUS
  560. ucfg_mlme_set_mawc_enabled(struct wlan_objmgr_psoc *psoc, bool val)
  561. {
  562. struct wlan_mlme_psoc_obj *mlme_obj;
  563. mlme_obj = mlme_get_psoc_obj(psoc);
  564. if (!mlme_obj)
  565. return QDF_STATUS_E_INVAL;
  566. mlme_obj->cfg.lfr.mawc_enabled = val;
  567. return QDF_STATUS_SUCCESS;
  568. }
  569. QDF_STATUS
  570. ucfg_mlme_is_fast_transition_enabled(struct wlan_objmgr_psoc *psoc,
  571. bool *val)
  572. {
  573. struct wlan_mlme_psoc_obj *mlme_obj;
  574. mlme_obj = mlme_get_psoc_obj(psoc);
  575. if (!mlme_obj) {
  576. *val = cfg_default(CFG_LFR_FAST_TRANSITION_ENABLED);
  577. return QDF_STATUS_E_INVAL;
  578. }
  579. *val = mlme_obj->cfg.lfr.fast_transition_enabled;
  580. return QDF_STATUS_SUCCESS;
  581. }
  582. QDF_STATUS
  583. ucfg_mlme_set_fast_transition_enabled(struct wlan_objmgr_psoc *psoc,
  584. bool val)
  585. {
  586. struct wlan_mlme_psoc_obj *mlme_obj;
  587. mlme_obj = mlme_get_psoc_obj(psoc);
  588. if (!mlme_obj)
  589. return QDF_STATUS_E_INVAL;
  590. mlme_obj->cfg.lfr.fast_transition_enabled = val;
  591. return QDF_STATUS_SUCCESS;
  592. }
  593. #ifdef WLAN_ADAPTIVE_11R
  594. QDF_STATUS
  595. ucfg_mlme_set_tgt_adaptive_11r_cap(struct wlan_objmgr_psoc *psoc,
  596. bool val)
  597. {
  598. struct wlan_mlme_psoc_obj *mlme_obj;
  599. mlme_obj = mlme_get_psoc_obj(psoc);
  600. if (!mlme_obj)
  601. return QDF_STATUS_E_INVAL;
  602. mlme_obj->cfg.lfr.tgt_adaptive_11r_cap = val;
  603. return QDF_STATUS_SUCCESS;
  604. }
  605. #endif
  606. QDF_STATUS
  607. ucfg_mlme_is_roam_scan_offload_enabled(struct wlan_objmgr_psoc *psoc,
  608. bool *val)
  609. {
  610. struct wlan_mlme_psoc_obj *mlme_obj;
  611. mlme_obj = mlme_get_psoc_obj(psoc);
  612. if (!mlme_obj) {
  613. *val = cfg_default(CFG_LFR_ROAM_SCAN_OFFLOAD_ENABLED);
  614. return QDF_STATUS_E_INVAL;
  615. }
  616. *val = mlme_obj->cfg.lfr.roam_scan_offload_enabled;
  617. return QDF_STATUS_SUCCESS;
  618. }
  619. QDF_STATUS
  620. ucfg_mlme_set_roam_scan_offload_enabled(struct wlan_objmgr_psoc *psoc,
  621. bool val)
  622. {
  623. struct wlan_mlme_psoc_obj *mlme_obj;
  624. mlme_obj = mlme_get_psoc_obj(psoc);
  625. if (!mlme_obj)
  626. return QDF_STATUS_E_INVAL;
  627. mlme_obj->cfg.lfr.roam_scan_offload_enabled = val;
  628. return QDF_STATUS_SUCCESS;
  629. }
  630. QDF_STATUS
  631. ucfg_mlme_get_neighbor_scan_max_chan_time(struct wlan_objmgr_psoc *psoc,
  632. uint16_t *val)
  633. {
  634. struct wlan_mlme_psoc_obj *mlme_obj;
  635. mlme_obj = mlme_get_psoc_obj(psoc);
  636. if (!mlme_obj) {
  637. *val = cfg_default(CFG_LFR_NEIGHBOR_SCAN_MAX_CHAN_TIME);
  638. return QDF_STATUS_E_INVAL;
  639. }
  640. *val = mlme_obj->cfg.lfr.neighbor_scan_max_chan_time;
  641. return QDF_STATUS_SUCCESS;
  642. }
  643. QDF_STATUS
  644. ucfg_mlme_get_neighbor_scan_min_chan_time(struct wlan_objmgr_psoc *psoc,
  645. uint16_t *val)
  646. {
  647. struct wlan_mlme_psoc_obj *mlme_obj;
  648. mlme_obj = mlme_get_psoc_obj(psoc);
  649. if (!mlme_obj) {
  650. *val = cfg_default(CFG_LFR_NEIGHBOR_SCAN_MIN_CHAN_TIME);
  651. return QDF_STATUS_E_INVAL;
  652. }
  653. *val = mlme_obj->cfg.lfr.neighbor_scan_min_chan_time;
  654. return QDF_STATUS_SUCCESS;
  655. }
  656. QDF_STATUS
  657. ucfg_mlme_get_delay_before_vdev_stop(struct wlan_objmgr_psoc *psoc,
  658. uint8_t *val)
  659. {
  660. struct wlan_mlme_psoc_obj *mlme_obj;
  661. mlme_obj = mlme_get_psoc_obj(psoc);
  662. if (!mlme_obj) {
  663. *val = cfg_default(CFG_LFR_DELAY_BEFORE_VDEV_STOP);
  664. return QDF_STATUS_E_INVAL;
  665. }
  666. *val = mlme_obj->cfg.lfr.delay_before_vdev_stop;
  667. return QDF_STATUS_SUCCESS;
  668. }
  669. QDF_STATUS
  670. ucfg_mlme_get_roam_bmiss_final_bcnt(struct wlan_objmgr_psoc *psoc,
  671. uint8_t *val)
  672. {
  673. struct wlan_mlme_psoc_obj *mlme_obj;
  674. mlme_obj = mlme_get_psoc_obj(psoc);
  675. if (!mlme_obj) {
  676. *val = cfg_default(CFG_LFR_ROAM_BMISS_FINAL_BCNT);
  677. return QDF_STATUS_E_INVAL;
  678. }
  679. *val = mlme_obj->cfg.lfr.roam_bmiss_final_bcnt;
  680. return QDF_STATUS_SUCCESS;
  681. }
  682. QDF_STATUS
  683. ucfg_mlme_get_roam_bmiss_first_bcnt(struct wlan_objmgr_psoc *psoc,
  684. uint8_t *val)
  685. {
  686. struct wlan_mlme_psoc_obj *mlme_obj;
  687. mlme_obj = mlme_get_psoc_obj(psoc);
  688. if (!mlme_obj) {
  689. *val = cfg_default(CFG_LFR_ROAM_BMISS_FIRST_BCNT);
  690. return QDF_STATUS_E_INVAL;
  691. }
  692. *val = mlme_obj->cfg.lfr.roam_bmiss_first_bcnt;
  693. return QDF_STATUS_SUCCESS;
  694. }
  695. QDF_STATUS
  696. ucfg_mlme_is_lfr_enabled(struct wlan_objmgr_psoc *psoc, bool *val)
  697. {
  698. struct wlan_mlme_psoc_obj *mlme_obj;
  699. mlme_obj = mlme_get_psoc_obj(psoc);
  700. if (!mlme_obj) {
  701. *val = cfg_default(CFG_LFR_FEATURE_ENABLED);
  702. return QDF_STATUS_E_INVAL;
  703. }
  704. *val = mlme_obj->cfg.lfr.lfr_enabled;
  705. return QDF_STATUS_SUCCESS;
  706. }
  707. QDF_STATUS
  708. ucfg_mlme_set_lfr_enabled(struct wlan_objmgr_psoc *psoc, bool val)
  709. {
  710. struct wlan_mlme_psoc_obj *mlme_obj;
  711. mlme_obj = mlme_get_psoc_obj(psoc);
  712. if (!mlme_obj)
  713. return QDF_STATUS_E_INVAL;
  714. mlme_obj->cfg.lfr.lfr_enabled = val;
  715. return QDF_STATUS_SUCCESS;
  716. }
  717. QDF_STATUS
  718. ucfg_mlme_is_roam_prefer_5ghz(struct wlan_objmgr_psoc *psoc, bool *val)
  719. {
  720. struct wlan_mlme_psoc_obj *mlme_obj;
  721. mlme_obj = mlme_get_psoc_obj(psoc);
  722. if (!mlme_obj) {
  723. *val = cfg_default(CFG_LFR_ROAM_PREFER_5GHZ);
  724. return QDF_STATUS_E_INVAL;
  725. }
  726. *val = mlme_obj->cfg.lfr.roam_prefer_5ghz;
  727. return QDF_STATUS_SUCCESS;
  728. }
  729. QDF_STATUS
  730. ucfg_mlme_set_roam_intra_band(struct wlan_objmgr_psoc *psoc, bool val)
  731. {
  732. struct wlan_mlme_psoc_obj *mlme_obj;
  733. mlme_obj = mlme_get_psoc_obj(psoc);
  734. if (!mlme_obj)
  735. return QDF_STATUS_E_INVAL;
  736. mlme_obj->cfg.lfr.roam_intra_band = val;
  737. return QDF_STATUS_SUCCESS;
  738. }
  739. QDF_STATUS
  740. ucfg_mlme_get_home_away_time(struct wlan_objmgr_psoc *psoc, uint16_t *val)
  741. {
  742. struct wlan_mlme_psoc_obj *mlme_obj;
  743. mlme_obj = mlme_get_psoc_obj(psoc);
  744. if (!mlme_obj) {
  745. *val = cfg_default(CFG_LFR_ROAM_SCAN_HOME_AWAY_TIME);
  746. return QDF_STATUS_E_INVAL;
  747. }
  748. *val = mlme_obj->cfg.lfr.roam_scan_home_away_time;
  749. return QDF_STATUS_SUCCESS;
  750. }
  751. QDF_STATUS
  752. ucfg_mlme_set_fast_roam_in_concurrency_enabled(struct wlan_objmgr_psoc *psoc,
  753. bool val)
  754. {
  755. struct wlan_mlme_psoc_obj *mlme_obj;
  756. mlme_obj = mlme_get_psoc_obj(psoc);
  757. if (!mlme_obj)
  758. return QDF_STATUS_E_INVAL;
  759. mlme_obj->cfg.lfr.enable_fast_roam_in_concurrency = val;
  760. return QDF_STATUS_SUCCESS;
  761. }
  762. #ifdef FEATURE_WLAN_ESE
  763. QDF_STATUS
  764. ucfg_mlme_is_ese_enabled(struct wlan_objmgr_psoc *psoc, bool *val)
  765. {
  766. struct wlan_mlme_psoc_obj *mlme_obj;
  767. mlme_obj = mlme_get_psoc_obj(psoc);
  768. if (!mlme_obj) {
  769. *val = cfg_default(CFG_LFR_ESE_FEATURE_ENABLED);
  770. return QDF_STATUS_E_INVAL;
  771. }
  772. *val = mlme_obj->cfg.lfr.ese_enabled;
  773. return QDF_STATUS_SUCCESS;
  774. }
  775. #endif /* FEATURE_WLAN_ESE */
  776. QDF_STATUS
  777. ucfg_mlme_get_opr_rate_set(struct wlan_objmgr_psoc *psoc,
  778. uint8_t *buf, qdf_size_t *len)
  779. {
  780. struct wlan_mlme_psoc_obj *mlme_obj;
  781. mlme_obj = mlme_get_psoc_obj(psoc);
  782. if (!mlme_obj)
  783. return QDF_STATUS_E_INVAL;
  784. return wlan_mlme_get_cfg_str(buf, &mlme_obj->cfg.rates.opr_rate_set,
  785. len);
  786. }
  787. QDF_STATUS
  788. ucfg_mlme_get_ext_opr_rate_set(struct wlan_objmgr_psoc *psoc,
  789. uint8_t *buf, qdf_size_t *len)
  790. {
  791. struct wlan_mlme_psoc_obj *mlme_obj;
  792. mlme_obj = mlme_get_psoc_obj(psoc);
  793. if (!mlme_obj)
  794. return QDF_STATUS_E_INVAL;
  795. return wlan_mlme_get_cfg_str(buf, &mlme_obj->cfg.rates.ext_opr_rate_set,
  796. len);
  797. }
  798. QDF_STATUS
  799. ucfg_mlme_get_supported_mcs_set(struct wlan_objmgr_psoc *psoc,
  800. uint8_t *buf, qdf_size_t *len)
  801. {
  802. struct wlan_mlme_psoc_obj *mlme_obj;
  803. mlme_obj = mlme_get_psoc_obj(psoc);
  804. if (!mlme_obj)
  805. return QDF_STATUS_E_INVAL;
  806. return wlan_mlme_get_cfg_str(buf,
  807. &mlme_obj->cfg.rates.supported_mcs_set,
  808. len);
  809. }
  810. QDF_STATUS
  811. ucfg_mlme_set_supported_mcs_set(struct wlan_objmgr_psoc *psoc,
  812. uint8_t *buf, qdf_size_t len)
  813. {
  814. struct wlan_mlme_psoc_obj *mlme_obj;
  815. mlme_obj = mlme_get_psoc_obj(psoc);
  816. if (!mlme_obj)
  817. return QDF_STATUS_E_INVAL;
  818. return wlan_mlme_set_cfg_str(buf,
  819. &mlme_obj->cfg.rates.supported_mcs_set,
  820. len);
  821. }
  822. QDF_STATUS
  823. ucfg_mlme_get_current_mcs_set(struct wlan_objmgr_psoc *psoc,
  824. uint8_t *buf, qdf_size_t *len)
  825. {
  826. struct wlan_mlme_psoc_obj *mlme_obj;
  827. mlme_obj = mlme_get_psoc_obj(psoc);
  828. if (!mlme_obj)
  829. return QDF_STATUS_E_INVAL;
  830. return wlan_mlme_get_cfg_str(buf,
  831. &mlme_obj->cfg.rates.current_mcs_set,
  832. len);
  833. }
  834. QDF_STATUS
  835. ucfg_mlme_get_wmi_wq_watchdog_timeout(struct wlan_objmgr_psoc *psoc,
  836. uint32_t *wmi_wq_watchdog_timeout)
  837. {
  838. struct wlan_mlme_psoc_obj *mlme_obj;
  839. mlme_obj = mlme_get_psoc_obj(psoc);
  840. if (!mlme_obj) {
  841. *wmi_wq_watchdog_timeout = cfg_default(CFG_WMI_WQ_WATCHDOG);
  842. return QDF_STATUS_E_INVAL;
  843. }
  844. *wmi_wq_watchdog_timeout =
  845. mlme_obj->cfg.timeouts.wmi_wq_watchdog_timeout;
  846. return QDF_STATUS_SUCCESS;
  847. }
  848. QDF_STATUS
  849. ucfg_mlme_set_wmi_wq_watchdog_timeout(struct wlan_objmgr_psoc *psoc,
  850. uint32_t wmi_wq_watchdog_timeout)
  851. {
  852. struct wlan_mlme_psoc_obj *mlme_obj;
  853. mlme_obj = mlme_get_psoc_obj(psoc);
  854. if (!mlme_obj)
  855. return QDF_STATUS_E_INVAL;
  856. if (!cfg_in_range(CFG_WMI_WQ_WATCHDOG, wmi_wq_watchdog_timeout)) {
  857. mlme_legacy_err("wmi watchdog bite timeout is invalid %d",
  858. wmi_wq_watchdog_timeout);
  859. return QDF_STATUS_E_INVAL;
  860. }
  861. mlme_obj->cfg.timeouts.wmi_wq_watchdog_timeout =
  862. wmi_wq_watchdog_timeout;
  863. return QDF_STATUS_SUCCESS;
  864. }
  865. QDF_STATUS
  866. ucfg_mlme_stats_get_periodic_display_time(struct wlan_objmgr_psoc *psoc,
  867. uint32_t *periodic_display_time)
  868. {
  869. struct wlan_mlme_psoc_obj *mlme_obj;
  870. mlme_obj = mlme_get_psoc_obj(psoc);
  871. if (!mlme_obj) {
  872. *periodic_display_time =
  873. cfg_default(CFG_PERIODIC_STATS_DISPLAY_TIME);
  874. return QDF_STATUS_E_INVAL;
  875. }
  876. *periodic_display_time =
  877. mlme_obj->cfg.stats.stats_periodic_display_time;
  878. return QDF_STATUS_SUCCESS;
  879. }
  880. QDF_STATUS
  881. ucfg_mlme_stats_get_cfg_values(struct wlan_objmgr_psoc *psoc,
  882. int *link_speed_rssi_high,
  883. int *link_speed_rssi_mid,
  884. int *link_speed_rssi_low,
  885. uint32_t *link_speed_rssi_report)
  886. {
  887. struct wlan_mlme_psoc_obj *mlme_obj;
  888. mlme_obj = mlme_get_psoc_obj(psoc);
  889. if (!mlme_obj) {
  890. *link_speed_rssi_high =
  891. cfg_default(CFG_LINK_SPEED_RSSI_HIGH);
  892. *link_speed_rssi_mid =
  893. cfg_default(CFG_LINK_SPEED_RSSI_MID);
  894. *link_speed_rssi_low =
  895. cfg_default(CFG_LINK_SPEED_RSSI_LOW);
  896. *link_speed_rssi_report =
  897. cfg_default(CFG_REPORT_MAX_LINK_SPEED);
  898. return QDF_STATUS_E_INVAL;
  899. }
  900. *link_speed_rssi_high =
  901. mlme_obj->cfg.stats.stats_link_speed_rssi_high;
  902. *link_speed_rssi_mid =
  903. mlme_obj->cfg.stats.stats_link_speed_rssi_med;
  904. *link_speed_rssi_low =
  905. mlme_obj->cfg.stats.stats_link_speed_rssi_low;
  906. *link_speed_rssi_report =
  907. mlme_obj->cfg.stats.stats_report_max_link_speed_rssi;
  908. return QDF_STATUS_SUCCESS;
  909. }
  910. bool ucfg_mlme_stats_is_link_speed_report_actual(struct wlan_objmgr_psoc *psoc)
  911. {
  912. struct wlan_mlme_psoc_obj *mlme_obj;
  913. int report_link_speed = 0;
  914. mlme_obj = mlme_get_psoc_obj(psoc);
  915. if (!mlme_obj)
  916. report_link_speed = cfg_default(CFG_REPORT_MAX_LINK_SPEED);
  917. else
  918. report_link_speed =
  919. mlme_obj->cfg.stats.stats_report_max_link_speed_rssi;
  920. return (report_link_speed == CFG_STATS_LINK_SPEED_REPORT_ACTUAL);
  921. }
  922. bool ucfg_mlme_stats_is_link_speed_report_max(struct wlan_objmgr_psoc *psoc)
  923. {
  924. struct wlan_mlme_psoc_obj *mlme_obj;
  925. int report_link_speed = 0;
  926. mlme_obj = mlme_get_psoc_obj(psoc);
  927. if (!mlme_obj)
  928. report_link_speed = cfg_default(CFG_REPORT_MAX_LINK_SPEED);
  929. else
  930. report_link_speed =
  931. mlme_obj->cfg.stats.stats_report_max_link_speed_rssi;
  932. return (report_link_speed == CFG_STATS_LINK_SPEED_REPORT_MAX);
  933. }
  934. bool
  935. ucfg_mlme_stats_is_link_speed_report_max_scaled(struct wlan_objmgr_psoc *psoc)
  936. {
  937. struct wlan_mlme_psoc_obj *mlme_obj;
  938. int report_link_speed = 0;
  939. mlme_obj = mlme_get_psoc_obj(psoc);
  940. if (!mlme_obj)
  941. report_link_speed = cfg_default(CFG_REPORT_MAX_LINK_SPEED);
  942. else
  943. report_link_speed =
  944. mlme_obj->cfg.stats.stats_report_max_link_speed_rssi;
  945. return (report_link_speed == CFG_STATS_LINK_SPEED_REPORT_MAX_SCALED);
  946. }
  947. QDF_STATUS
  948. ucfg_mlme_get_ps_data_inactivity_timeout(struct wlan_objmgr_psoc *psoc,
  949. uint32_t *inactivity_timeout)
  950. {
  951. struct wlan_mlme_psoc_obj *mlme_obj;
  952. mlme_obj = mlme_get_psoc_obj(psoc);
  953. if (!mlme_obj) {
  954. *inactivity_timeout =
  955. cfg_default(CFG_PS_DATA_INACTIVITY_TIMEOUT);
  956. return QDF_STATUS_E_FAILURE;
  957. }
  958. *inactivity_timeout = mlme_obj->cfg.timeouts.ps_data_inactivity_timeout;
  959. return QDF_STATUS_SUCCESS;
  960. }
  961. QDF_STATUS
  962. ucfg_mlme_set_ps_data_inactivity_timeout(struct wlan_objmgr_psoc *psoc,
  963. uint32_t inactivity_timeout)
  964. {
  965. struct wlan_mlme_psoc_obj *mlme_obj;
  966. mlme_obj = mlme_get_psoc_obj(psoc);
  967. if (!mlme_obj)
  968. return QDF_STATUS_E_INVAL;
  969. if (!cfg_in_range(CFG_PS_DATA_INACTIVITY_TIMEOUT, inactivity_timeout)) {
  970. mlme_legacy_err("inactivity timeout set value is invalid %d",
  971. inactivity_timeout);
  972. return QDF_STATUS_E_INVAL;
  973. }
  974. mlme_obj->cfg.timeouts.ps_data_inactivity_timeout = inactivity_timeout;
  975. return QDF_STATUS_SUCCESS;
  976. }
  977. QDF_STATUS
  978. ucfg_mlme_get_sta_keepalive_method(struct wlan_objmgr_psoc *psoc,
  979. enum station_keepalive_method *val)
  980. {
  981. struct wlan_mlme_psoc_obj *mlme_obj;
  982. mlme_obj = mlme_get_psoc_obj(psoc);
  983. if (!mlme_obj)
  984. return QDF_STATUS_E_INVAL;
  985. *val = mlme_obj->cfg.sta.sta_keepalive_method;
  986. return QDF_STATUS_SUCCESS;
  987. }
  988. QDF_STATUS
  989. ucfg_mlme_get_enable_deauth_to_disassoc_map(struct wlan_objmgr_psoc *psoc,
  990. bool *value)
  991. {
  992. struct wlan_mlme_psoc_obj *mlme_obj;
  993. mlme_obj = mlme_get_psoc_obj(psoc);
  994. if (!mlme_obj)
  995. return QDF_STATUS_E_INVAL;
  996. *value = mlme_obj->cfg.gen.enable_deauth_to_disassoc_map;
  997. return QDF_STATUS_SUCCESS;
  998. }
  999. QDF_STATUS
  1000. ucfg_mlme_get_ap_random_bssid_enable(struct wlan_objmgr_psoc *psoc,
  1001. bool *value)
  1002. {
  1003. struct wlan_mlme_psoc_obj *mlme_obj;
  1004. mlme_obj = mlme_get_psoc_obj(psoc);
  1005. if (!mlme_obj)
  1006. return QDF_STATUS_E_INVAL;
  1007. *value = mlme_obj->cfg.sap_cfg.ap_random_bssid_enable;
  1008. return QDF_STATUS_SUCCESS;
  1009. }
  1010. QDF_STATUS
  1011. ucfg_mlme_get_latency_enable(struct wlan_objmgr_psoc *psoc, bool *value)
  1012. {
  1013. struct wlan_mlme_psoc_obj *mlme_obj;
  1014. mlme_obj = mlme_get_psoc_obj(psoc);
  1015. if (!mlme_obj) {
  1016. mlme_legacy_err("mlme obj null");
  1017. return QDF_STATUS_E_INVAL;
  1018. }
  1019. *value = mlme_obj->cfg.wlm_config.latency_enable;
  1020. return QDF_STATUS_SUCCESS;
  1021. }
  1022. QDF_STATUS ucfg_mlme_get_ibss_cfg(struct wlan_objmgr_psoc *psoc,
  1023. struct wlan_mlme_ibss_cfg *ibss_cfg)
  1024. {
  1025. struct wlan_mlme_psoc_obj *mlme_obj;
  1026. if (!ibss_cfg)
  1027. return QDF_STATUS_E_FAILURE;
  1028. mlme_obj = mlme_get_psoc_obj(psoc);
  1029. if (!mlme_obj) {
  1030. mlme_legacy_err("MLME Obj null on get IBSS config");
  1031. mlme_init_ibss_cfg(psoc, ibss_cfg);
  1032. return QDF_STATUS_E_INVAL;
  1033. }
  1034. *ibss_cfg = mlme_obj->cfg.ibss;
  1035. return QDF_STATUS_SUCCESS;
  1036. }
  1037. QDF_STATUS ucfg_mlme_set_ibss_auto_bssid(struct wlan_objmgr_psoc *psoc,
  1038. uint32_t auto_bssid)
  1039. {
  1040. struct wlan_mlme_psoc_obj *mlme_obj;
  1041. mlme_obj = mlme_get_psoc_obj(psoc);
  1042. if (!mlme_obj) {
  1043. mlme_legacy_err("MLME Obj null on get IBSS config");
  1044. return QDF_STATUS_E_INVAL;
  1045. }
  1046. mlme_obj->cfg.ibss.auto_bssid = auto_bssid;
  1047. return QDF_STATUS_SUCCESS;
  1048. }
  1049. #ifdef MWS_COEX
  1050. QDF_STATUS
  1051. ucfg_mlme_get_mws_coex_4g_quick_tdm(struct wlan_objmgr_psoc *psoc,
  1052. uint32_t *val)
  1053. {
  1054. struct wlan_mlme_psoc_obj *mlme_obj;
  1055. mlme_obj = mlme_get_psoc_obj(psoc);
  1056. if (!mlme_obj) {
  1057. *val = cfg_default(CFG_MWS_COEX_4G_QUICK_FTDM);
  1058. mlme_legacy_err("mlme obj null");
  1059. return QDF_STATUS_E_INVAL;
  1060. }
  1061. *val = mlme_obj->cfg.mwc.mws_coex_4g_quick_tdm;
  1062. return QDF_STATUS_SUCCESS;
  1063. }
  1064. QDF_STATUS
  1065. ucfg_mlme_get_mws_coex_5g_nr_pwr_limit(struct wlan_objmgr_psoc *psoc,
  1066. uint32_t *val)
  1067. {
  1068. struct wlan_mlme_psoc_obj *mlme_obj;
  1069. mlme_obj = mlme_get_psoc_obj(psoc);
  1070. if (!mlme_obj) {
  1071. *val = cfg_default(CFG_MWS_COEX_5G_NR_PWR_LIMIT);
  1072. mlme_legacy_err("mlme obj null");
  1073. return QDF_STATUS_E_INVAL;
  1074. }
  1075. *val = mlme_obj->cfg.mwc.mws_coex_5g_nr_pwr_limit;
  1076. return QDF_STATUS_SUCCESS;
  1077. }
  1078. #endif
  1079. QDF_STATUS
  1080. ucfg_mlme_get_etsi13_srd_chan_in_master_mode(struct wlan_objmgr_psoc *psoc,
  1081. bool *value)
  1082. {
  1083. struct wlan_mlme_psoc_obj *mlme_obj;
  1084. mlme_obj = mlme_get_psoc_obj(psoc);
  1085. if (!mlme_obj) {
  1086. *value = cfg_default(CFG_ETSI13_SRD_CHAN_IN_MASTER_MODE);
  1087. mlme_legacy_err("Failed to get MLME Obj");
  1088. return QDF_STATUS_E_INVAL;
  1089. }
  1090. *value = mlme_obj->cfg.reg.etsi13_srd_chan_in_master_mode;
  1091. return QDF_STATUS_SUCCESS;
  1092. }
  1093. #ifdef SAP_AVOID_ACS_FREQ_LIST
  1094. QDF_STATUS
  1095. ucfg_mlme_get_acs_avoid_freq_list(struct wlan_objmgr_psoc *psoc,
  1096. uint16_t *freq_list, uint8_t *freq_list_num)
  1097. {
  1098. struct wlan_mlme_psoc_obj *mlme_obj;
  1099. qdf_size_t avoid_acs_freq_list_num;
  1100. mlme_obj = mlme_get_psoc_obj(psoc);
  1101. if (!mlme_obj) {
  1102. qdf_uint16_array_parse(
  1103. cfg_default(CFG_SAP_AVOID_ACS_FREQ_LIST),
  1104. freq_list, CFG_VALID_CHANNEL_LIST_LEN,
  1105. &avoid_acs_freq_list_num);
  1106. *freq_list_num = avoid_acs_freq_list_num;
  1107. mlme_legacy_err("Failed to get MLME Obj");
  1108. return QDF_STATUS_E_INVAL;
  1109. }
  1110. *freq_list_num = mlme_obj->cfg.reg.avoid_acs_freq_list_num;
  1111. qdf_mem_copy(freq_list, mlme_obj->cfg.reg.avoid_acs_freq_list,
  1112. *freq_list_num * sizeof(uint16_t));
  1113. return QDF_STATUS_SUCCESS;
  1114. }
  1115. #endif
  1116. QDF_STATUS
  1117. ucfg_mlme_get_11d_in_world_mode(struct wlan_objmgr_psoc *psoc,
  1118. bool *value)
  1119. {
  1120. struct wlan_mlme_psoc_obj *mlme_obj;
  1121. mlme_obj = mlme_get_psoc_obj(psoc);
  1122. if (!mlme_obj) {
  1123. *value = cfg_default(CFG_ENABLE_11D_IN_WORLD_MODE);
  1124. mlme_legacy_err("Failed to get MLME Obj");
  1125. return QDF_STATUS_E_INVAL;
  1126. }
  1127. *value = mlme_obj->cfg.reg.enable_11d_in_world_mode;
  1128. return QDF_STATUS_SUCCESS;
  1129. }
  1130. QDF_STATUS
  1131. ucfg_mlme_get_restart_beaconing_on_ch_avoid(struct wlan_objmgr_psoc *psoc,
  1132. uint32_t *value)
  1133. {
  1134. struct wlan_mlme_psoc_obj *mlme_obj;
  1135. mlme_obj = mlme_get_psoc_obj(psoc);
  1136. if (!mlme_obj) {
  1137. *value = cfg_default(CFG_RESTART_BEACONING_ON_CH_AVOID);
  1138. mlme_legacy_err("Failed to get MLME Obj");
  1139. return QDF_STATUS_E_INVAL;
  1140. }
  1141. *value = mlme_obj->cfg.reg.restart_beaconing_on_ch_avoid;
  1142. return QDF_STATUS_SUCCESS;
  1143. }
  1144. QDF_STATUS
  1145. ucfg_mlme_get_indoor_channel_support(struct wlan_objmgr_psoc *psoc,
  1146. bool *value)
  1147. {
  1148. struct wlan_mlme_psoc_obj *mlme_obj;
  1149. mlme_obj = mlme_get_psoc_obj(psoc);
  1150. if (!mlme_obj) {
  1151. *value = cfg_default(CFG_INDOOR_CHANNEL_SUPPORT);
  1152. mlme_legacy_err("Failed to get MLME Obj");
  1153. return QDF_STATUS_E_INVAL;
  1154. }
  1155. *value = mlme_obj->cfg.reg.indoor_channel_support;
  1156. return QDF_STATUS_SUCCESS;
  1157. }
  1158. QDF_STATUS
  1159. ucfg_mlme_get_scan_11d_interval(struct wlan_objmgr_psoc *psoc,
  1160. uint32_t *value)
  1161. {
  1162. struct wlan_mlme_psoc_obj *mlme_obj;
  1163. mlme_obj = mlme_get_psoc_obj(psoc);
  1164. if (!mlme_obj) {
  1165. *value = cfg_default(CFG_SCAN_11D_INTERVAL);
  1166. mlme_legacy_err("Failed to get MLME Obj");
  1167. return QDF_STATUS_E_INVAL;
  1168. }
  1169. *value = mlme_obj->cfg.reg.scan_11d_interval;
  1170. return QDF_STATUS_SUCCESS;
  1171. }
  1172. QDF_STATUS
  1173. ucfg_mlme_get_valid_channel_list(struct wlan_objmgr_psoc *psoc,
  1174. uint8_t *channel_list,
  1175. uint32_t *channel_list_num)
  1176. {
  1177. struct wlan_mlme_psoc_obj *mlme_obj;
  1178. qdf_size_t valid_channel_list_num = 0;
  1179. mlme_obj = mlme_get_psoc_obj(psoc);
  1180. if (!mlme_obj) {
  1181. qdf_uint8_array_parse(cfg_default(CFG_VALID_CHANNEL_LIST),
  1182. channel_list,
  1183. CFG_VALID_CHANNEL_LIST_LEN,
  1184. &valid_channel_list_num);
  1185. *channel_list_num = (uint8_t)valid_channel_list_num;
  1186. mlme_legacy_err("Failed to get MLME Obj");
  1187. return QDF_STATUS_E_INVAL;
  1188. }
  1189. *channel_list_num = (uint32_t)mlme_obj->cfg.reg.valid_channel_list_num;
  1190. qdf_mem_copy(channel_list, mlme_obj->cfg.reg.valid_channel_list,
  1191. *channel_list_num);
  1192. return QDF_STATUS_SUCCESS;
  1193. }
  1194. #ifdef FEATURE_LFR_SUBNET_DETECTION
  1195. QDF_STATUS
  1196. ucfg_mlme_is_subnet_detection_enabled(struct wlan_objmgr_psoc *psoc, bool *val)
  1197. {
  1198. struct wlan_mlme_psoc_obj *mlme_obj;
  1199. mlme_obj = mlme_get_psoc_obj(psoc);
  1200. if (!mlme_obj) {
  1201. *val = cfg_default(CFG_LFR3_ENABLE_SUBNET_DETECTION);
  1202. return QDF_STATUS_E_INVAL;
  1203. }
  1204. *val = mlme_obj->cfg.lfr.enable_lfr_subnet_detection;
  1205. return QDF_STATUS_SUCCESS;
  1206. }
  1207. #endif
  1208. QDF_STATUS
  1209. ucfg_mlme_set_current_tx_power_level(struct wlan_objmgr_psoc *psoc,
  1210. uint8_t value)
  1211. {
  1212. struct wlan_mlme_psoc_obj *mlme_obj;
  1213. mlme_obj = mlme_get_psoc_obj(psoc);
  1214. if (!mlme_obj)
  1215. return QDF_STATUS_E_INVAL;
  1216. mlme_obj->cfg.power.current_tx_power_level = value;
  1217. return QDF_STATUS_SUCCESS;
  1218. }
  1219. QDF_STATUS
  1220. ucfg_mlme_get_current_tx_power_level(struct wlan_objmgr_psoc *psoc,
  1221. uint8_t *value)
  1222. {
  1223. struct wlan_mlme_psoc_obj *mlme_obj;
  1224. mlme_obj = mlme_get_psoc_obj(psoc);
  1225. if (!mlme_obj) {
  1226. *value = cfg_default(CFG_CURRENT_TX_POWER_LEVEL);
  1227. return QDF_STATUS_E_INVAL;
  1228. }
  1229. *value = mlme_obj->cfg.power.current_tx_power_level;
  1230. return QDF_STATUS_SUCCESS;
  1231. }
  1232. QDF_STATUS
  1233. ucfg_mlme_set_obss_detection_offload_enabled(struct wlan_objmgr_psoc *psoc,
  1234. uint8_t value)
  1235. {
  1236. struct wlan_mlme_psoc_obj *mlme_obj;
  1237. mlme_obj = mlme_get_psoc_obj(psoc);
  1238. if (!mlme_obj)
  1239. return QDF_STATUS_E_INVAL;
  1240. mlme_obj->cfg.obss_ht40.obss_detection_offload_enabled = value;
  1241. return QDF_STATUS_SUCCESS;
  1242. }
  1243. QDF_STATUS
  1244. ucfg_mlme_set_obss_color_collision_offload_enabled(
  1245. struct wlan_objmgr_psoc *psoc, uint8_t value)
  1246. {
  1247. struct wlan_mlme_psoc_obj *mlme_obj;
  1248. mlme_obj = mlme_get_psoc_obj(psoc);
  1249. if (!mlme_obj)
  1250. return QDF_STATUS_E_INVAL;
  1251. mlme_obj->cfg.obss_ht40.obss_color_collision_offload_enabled = value;
  1252. return QDF_STATUS_SUCCESS;
  1253. }
  1254. QDF_STATUS
  1255. ucfg_mlme_get_channel_bonding_24ghz(struct wlan_objmgr_psoc *psoc,
  1256. uint32_t *val)
  1257. {
  1258. struct wlan_mlme_psoc_obj *mlme_obj;
  1259. mlme_obj = mlme_get_psoc_obj(psoc);
  1260. if (!mlme_obj) {
  1261. *val = cfg_default(CFG_CHANNEL_BONDING_MODE_24GHZ);
  1262. return QDF_STATUS_E_INVAL;
  1263. }
  1264. *val = mlme_obj->cfg.feature_flags.channel_bonding_mode_24ghz;
  1265. return QDF_STATUS_SUCCESS;
  1266. }
  1267. QDF_STATUS
  1268. ucfg_mlme_set_channel_bonding_24ghz(struct wlan_objmgr_psoc *psoc,
  1269. uint32_t value)
  1270. {
  1271. struct wlan_mlme_psoc_obj *mlme_obj;
  1272. mlme_obj = mlme_get_psoc_obj(psoc);
  1273. if (!mlme_obj)
  1274. return QDF_STATUS_E_INVAL;
  1275. mlme_obj->cfg.feature_flags.channel_bonding_mode_24ghz = value;
  1276. return QDF_STATUS_SUCCESS;
  1277. }
  1278. QDF_STATUS
  1279. ucfg_mlme_get_channel_bonding_5ghz(struct wlan_objmgr_psoc *psoc,
  1280. uint32_t *value)
  1281. {
  1282. struct wlan_mlme_psoc_obj *mlme_obj;
  1283. mlme_obj = mlme_get_psoc_obj(psoc);
  1284. if (!mlme_obj) {
  1285. *value = cfg_default(CFG_CHANNEL_BONDING_MODE_5GHZ);
  1286. return QDF_STATUS_E_INVAL;
  1287. }
  1288. *value = mlme_obj->cfg.feature_flags.channel_bonding_mode_5ghz;
  1289. return QDF_STATUS_SUCCESS;
  1290. }
  1291. QDF_STATUS
  1292. ucfg_mlme_set_channel_bonding_5ghz(struct wlan_objmgr_psoc *psoc,
  1293. uint32_t value)
  1294. {
  1295. struct wlan_mlme_psoc_obj *mlme_obj;
  1296. mlme_obj = mlme_get_psoc_obj(psoc);
  1297. if (!mlme_obj)
  1298. return QDF_STATUS_E_INVAL;
  1299. mlme_obj->cfg.feature_flags.channel_bonding_mode_5ghz = value;
  1300. return QDF_STATUS_SUCCESS;
  1301. }
  1302. bool ucfg_mlme_validate_full_roam_scan_period(uint32_t full_roam_scan_period)
  1303. {
  1304. bool is_valid = true;
  1305. uint32_t min, max;
  1306. if (!cfg_in_range(CFG_LFR_FULL_ROAM_SCAN_REFRESH_PERIOD,
  1307. full_roam_scan_period)) {
  1308. min = (cfg_min(CFG_LFR_FULL_ROAM_SCAN_REFRESH_PERIOD));
  1309. max = (cfg_max(CFG_LFR_FULL_ROAM_SCAN_REFRESH_PERIOD));
  1310. mlme_legacy_err("Full roam scan period value %d is out of range (Min: %d Max: %d)",
  1311. full_roam_scan_period, min, max);
  1312. is_valid = false;
  1313. }
  1314. return is_valid;
  1315. }
  1316. bool ucfg_mlme_validate_scan_period(uint32_t roam_scan_period)
  1317. {
  1318. bool is_valid = true;
  1319. if (!cfg_in_range(CFG_LFR_EMPTY_SCAN_REFRESH_PERIOD,
  1320. roam_scan_period)) {
  1321. mlme_legacy_err("Roam scan period value %d msec is out of range (Min: %d msec Max: %d msec)",
  1322. roam_scan_period,
  1323. cfg_min(CFG_LFR_EMPTY_SCAN_REFRESH_PERIOD),
  1324. cfg_max(CFG_LFR_EMPTY_SCAN_REFRESH_PERIOD));
  1325. is_valid = false;
  1326. }
  1327. return is_valid;
  1328. }