wlan_mlme_ucfg_api.h 55 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169
  1. /*
  2. * Copyright (c) 2018 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: declare UCFG APIs exposed by the mlme component
  20. */
  21. #ifndef _WLAN_MLME_UCFG_API_H_
  22. #define _WLAN_MLME_UCFG_API_H_
  23. #include <wlan_mlme_public_struct.h>
  24. #include <wlan_objmgr_psoc_obj.h>
  25. #include <wlan_objmgr_global_obj.h>
  26. #include <wlan_cmn.h>
  27. #include <wlan_mlme_api.h>
  28. /**
  29. * ucfg_mlme_init() - initialize mlme_ctx context.
  30. *
  31. * This function initializes the mlme context.
  32. *
  33. * Return: QDF_STATUS_SUCCESS - in case of success else return error
  34. */
  35. QDF_STATUS ucfg_mlme_init(void);
  36. /**
  37. * ucfg_mlme_deinit() - De initialize mlme_ctx context.
  38. *
  39. * This function De initializes mlme contex.
  40. *
  41. * Return: QDF_STATUS_SUCCESS - in case of success else return error
  42. */
  43. QDF_STATUS ucfg_mlme_deinit(void);
  44. /**
  45. * ucfg_mlme_psoc_open() - MLME component Open
  46. * @psoc: pointer to psoc object
  47. *
  48. * Open the MLME component and initialize the MLME strucutre
  49. *
  50. * Return: QDF Status
  51. */
  52. QDF_STATUS ucfg_mlme_psoc_open(struct wlan_objmgr_psoc *psoc);
  53. /**
  54. * ucfg_mlme_psoc_close() - MLME component close
  55. * @psoc: pointer to psoc object
  56. *
  57. * Close the MLME component and clear the MLME structures
  58. *
  59. * Return: None
  60. */
  61. void ucfg_mlme_psoc_close(struct wlan_objmgr_psoc *psoc);
  62. #ifdef CONFIG_VDEV_SM
  63. /**
  64. * ucfg_mlme_pdev_open() - MLME component pdev Open
  65. * @pdev: pointer to pdev object
  66. *
  67. * Open the MLME component and initialize the MLME pdev strucutre
  68. *
  69. * Return: QDF Status
  70. */
  71. QDF_STATUS ucfg_mlme_pdev_open(struct wlan_objmgr_pdev *pdev);
  72. /**
  73. * ucfg_mlme_pdev_close() - MLME component pdev close
  74. * @pdev: pointer to pdev object
  75. *
  76. * close the MLME pdev information
  77. *
  78. * Return: QDF Status
  79. */
  80. QDF_STATUS ucfg_mlme_pdev_close(struct wlan_objmgr_pdev *pdev);
  81. #else
  82. /**
  83. * ucfg_mlme_pdev_open() - MLME component pdev Open
  84. * @pdev: pointer to pdev object
  85. *
  86. * Open the MLME component and initialize the MLME pdev strucutre
  87. *
  88. * Return: QDF Status
  89. */
  90. static inline QDF_STATUS ucfg_mlme_pdev_open(struct wlan_objmgr_pdev *pdev)
  91. {
  92. return QDF_STATUS_SUCCESS;
  93. }
  94. /**
  95. * ucfg_mlme_pdev_close() - MLME component pdev close
  96. * @pdev: pointer to pdev object
  97. *
  98. * close the MLME pdev information
  99. *
  100. * Return: QDF Status
  101. */
  102. static inline QDF_STATUS ucfg_mlme_pdev_close(struct wlan_objmgr_pdev *pdev)
  103. {
  104. return QDF_STATUS_SUCCESS;
  105. }
  106. #endif
  107. /**
  108. * ucfg_mlme_get_ht_cap_info() - Get the HT cap info config
  109. * @psoc: pointer to psoc object
  110. * @value: pointer to the value which will be filled for the caller
  111. *
  112. * Inline UCFG API to be used by HDD/OSIF callers
  113. *
  114. * Return: QDF Status
  115. */
  116. static inline
  117. QDF_STATUS ucfg_mlme_get_ht_cap_info(struct wlan_objmgr_psoc *psoc,
  118. struct mlme_ht_capabilities_info
  119. *ht_cap_info)
  120. {
  121. return wlan_mlme_get_ht_cap_info(psoc, ht_cap_info);
  122. }
  123. /**
  124. * ucfg_mlme_set_ht_cap_info() - Set the HT cap info config
  125. * @psoc: pointer to psoc object
  126. * @value: Value that needs to be set from the caller
  127. *
  128. * Inline UCFG API to be used by HDD/OSIF callers
  129. *
  130. * Return: QDF Status
  131. */
  132. static inline
  133. QDF_STATUS ucfg_mlme_set_ht_cap_info(struct wlan_objmgr_psoc *psoc,
  134. struct mlme_ht_capabilities_info
  135. ht_cap_info)
  136. {
  137. return wlan_mlme_set_ht_cap_info(psoc, ht_cap_info);
  138. }
  139. /**
  140. * ucfg_mlme_get_max_amsdu_num() - get the max amsdu num
  141. * @psoc: pointer to psoc object
  142. * @value: pointer to the value where the max_amsdu num is to be filled
  143. *
  144. * Return: QDF_STATUS
  145. */
  146. static inline
  147. QDF_STATUS ucfg_mlme_get_max_amsdu_num(struct wlan_objmgr_psoc *psoc,
  148. uint8_t *value)
  149. {
  150. return wlan_mlme_get_max_amsdu_num(psoc, value);
  151. }
  152. /**
  153. * ucfg_mlme_set_max_amsdu_num() - set the max amsdu num
  154. * @psoc: pointer to psoc object
  155. * @value: value to be set for max_amsdu_num
  156. *
  157. * Return: QDF_STATUS
  158. */
  159. static inline
  160. QDF_STATUS ucfg_mlme_set_max_amsdu_num(struct wlan_objmgr_psoc *psoc,
  161. uint8_t value)
  162. {
  163. return wlan_mlme_set_max_amsdu_num(psoc, value);
  164. }
  165. /**
  166. * ucfg_mlme_get_ht_mpdu_density() - get the ht mpdu density
  167. * @psoc: pointer to psoc object
  168. * @value: pointer to the value where the ht mpdu density is to be filled
  169. *
  170. * Return: QDF_STATUS
  171. */
  172. static inline
  173. QDF_STATUS ucfg_mlme_get_ht_mpdu_density(struct wlan_objmgr_psoc *psoc,
  174. uint8_t *value)
  175. {
  176. return wlan_mlme_get_ht_mpdu_density(psoc, value);
  177. }
  178. /**
  179. * ucfg_mlme_set_ht_mpdu_density() - set the ht mpdu density
  180. * @psoc: pointer to psoc object
  181. * @value: value to be set for ht mpdu density
  182. *
  183. * Return: QDF_STATUS
  184. */
  185. static inline
  186. QDF_STATUS ucfg_mlme_set_ht_mpdu_density(struct wlan_objmgr_psoc *psoc,
  187. uint8_t value)
  188. {
  189. return wlan_mlme_set_ht_mpdu_density(psoc, value);
  190. }
  191. /**
  192. * ucfg_mlme_get_band_capability() - Get the Band capability config
  193. * @psoc: pointer to psoc object
  194. * @band_capability: Pointer to the variable from caller
  195. *
  196. * Return: QDF Status
  197. */
  198. static inline
  199. QDF_STATUS ucfg_mlme_get_band_capability(struct wlan_objmgr_psoc *psoc,
  200. uint8_t *band_capability)
  201. {
  202. return wlan_mlme_get_band_capability(psoc, band_capability);
  203. }
  204. /**
  205. * ucfg_mlme_set_band_capability() - Set the Band capability config
  206. * @psoc: pointer to psoc object
  207. * @band_capability: Value to be set from the caller
  208. *
  209. * Return: QDF Status
  210. */
  211. static inline
  212. QDF_STATUS ucfg_mlme_set_band_capability(struct wlan_objmgr_psoc *psoc,
  213. uint8_t band_capability)
  214. {
  215. return wlan_mlme_set_band_capability(psoc, band_capability);
  216. }
  217. /**
  218. * ucfg_mlme_get_prevent_link_down() - Get the prevent link down config
  219. * @psoc: pointer to psoc object
  220. * @prevent_link_down: Pointer to the variable from caller
  221. *
  222. * Return: QDF Status
  223. */
  224. static inline
  225. QDF_STATUS ucfg_mlme_get_prevent_link_down(struct wlan_objmgr_psoc *psoc,
  226. bool *prevent_link_down)
  227. {
  228. return wlan_mlme_get_prevent_link_down(psoc, prevent_link_down);
  229. }
  230. /**
  231. * ucfg_mlme_get_select_5ghz_margin() - Get the select 5Ghz margin config
  232. * @psoc: pointer to psoc object
  233. * @select_5ghz_margin: Pointer to the variable from caller
  234. *
  235. * Return: QDF Status
  236. */
  237. static inline
  238. QDF_STATUS ucfg_mlme_get_select_5ghz_margin(struct wlan_objmgr_psoc *psoc,
  239. uint8_t *select_5ghz_margin)
  240. {
  241. return wlan_mlme_get_select_5ghz_margin(psoc, select_5ghz_margin);
  242. }
  243. /**
  244. * ucfg_mlme_get_crash_inject() - Get the crash inject config
  245. * @psoc: pointer to psoc object
  246. * @crash_inject: Pointer to the variable from caller
  247. *
  248. * Return: QDF Status
  249. */
  250. static inline
  251. QDF_STATUS ucfg_mlme_get_crash_inject(struct wlan_objmgr_psoc *psoc,
  252. bool *crash_inject)
  253. {
  254. return wlan_mlme_get_crash_inject(psoc, crash_inject);
  255. }
  256. /**
  257. * ucfg_mlme_get_lpass_support() - Get the LPASS Support config
  258. * @psoc: pointer to psoc object
  259. * @lpass_support: Pointer to the variable from caller
  260. *
  261. * Return: QDF Status
  262. */
  263. static inline
  264. QDF_STATUS ucfg_mlme_get_lpass_support(struct wlan_objmgr_psoc *psoc,
  265. bool *lpass_support)
  266. {
  267. return wlan_mlme_get_lpass_support(psoc, lpass_support);
  268. }
  269. /**
  270. * ucfg_mlme_get_self_recovery() - Get the self recovery config
  271. * @psoc: pointer to psoc object
  272. * @self_recovery: Pointer to the variable from caller
  273. *
  274. * Return: QDF Status
  275. */
  276. static inline
  277. QDF_STATUS ucfg_mlme_get_self_recovery(struct wlan_objmgr_psoc *psoc,
  278. bool *self_recovery)
  279. {
  280. return wlan_mlme_get_self_recovery(psoc, self_recovery);
  281. }
  282. /**
  283. * ucfg_mlme_get_sub_20_chan_width() - Get the sub 20 chan width config
  284. * @psoc: pointer to psoc object
  285. * @sub_20_chan_width: Pointer to the variable from caller
  286. *
  287. * Return: QDF Status
  288. */
  289. static inline
  290. QDF_STATUS ucfg_mlme_get_sub_20_chan_width(struct wlan_objmgr_psoc *psoc,
  291. uint8_t *sub_20_chan_width)
  292. {
  293. return wlan_mlme_get_sub_20_chan_width(psoc, sub_20_chan_width);
  294. }
  295. /**
  296. * ucfg_mlme_get_fw_timeout_crash() - Get the fw timeout crash config
  297. * @psoc: pointer to psoc object
  298. * @fw_timeout_crash: Pointer to the variable from caller
  299. *
  300. * Return: QDF Status
  301. */
  302. static inline
  303. QDF_STATUS ucfg_mlme_get_fw_timeout_crash(struct wlan_objmgr_psoc *psoc,
  304. bool *fw_timeout_crash)
  305. {
  306. return wlan_mlme_get_fw_timeout_crash(psoc, fw_timeout_crash);
  307. }
  308. /**
  309. * ucfg_mlme_get_ito_repeat_count() - Get the fw timeout crash config
  310. * @psoc: pointer to psoc object
  311. * @ito_repeat_count: Pointer to the variable from caller
  312. *
  313. * Return: QDF Status
  314. */
  315. static inline
  316. QDF_STATUS ucfg_mlme_get_ito_repeat_count(struct wlan_objmgr_psoc *psoc,
  317. uint8_t *ito_repeat_count)
  318. {
  319. return wlan_mlme_get_ito_repeat_count(psoc, ito_repeat_count);
  320. }
  321. /**
  322. * ucfg_mlme_get_acs_with_more_param() - Get the flag for acs with
  323. * more param
  324. * @psoc: pointer to psoc object
  325. * @value: Value that needs to be set from the caller
  326. *
  327. * Inline UCFG API to be used by HDD/OSIF callers
  328. *
  329. * Return: QDF Status
  330. */
  331. static inline
  332. QDF_STATUS ucfg_mlme_get_acs_with_more_param(struct wlan_objmgr_psoc *psoc,
  333. bool *value)
  334. {
  335. return wlan_mlme_get_acs_with_more_param(psoc, value);
  336. }
  337. /**
  338. * ucfg_mlme_get_auto_channel_weight() - Get the auto channel select weight
  339. * @psoc: pointer to psoc object
  340. * @value: Value that needs to be set from the caller
  341. *
  342. * Inline UCFG API to be used by HDD/OSIF callers
  343. *
  344. * Return: QDF Status
  345. */
  346. static inline
  347. QDF_STATUS ucfg_mlme_get_auto_channel_weight(struct wlan_objmgr_psoc *psoc,
  348. uint32_t *value)
  349. {
  350. return wlan_mlme_get_auto_channel_weight(psoc, value);
  351. }
  352. /**
  353. * ucfg_mlme_get_vendor_acs_support() - Get the flag for
  354. * vendor acs support
  355. * @psoc: pointer to psoc object
  356. * @value: Value that needs to be set from the caller
  357. *
  358. * Inline UCFG API to be used by HDD/OSIF callers
  359. *
  360. * Return: QDF Status
  361. */
  362. static inline
  363. QDF_STATUS ucfg_mlme_get_vendor_acs_support(struct wlan_objmgr_psoc *psoc,
  364. bool *value)
  365. {
  366. return wlan_mlme_get_vendor_acs_support(psoc, value);
  367. }
  368. /**
  369. * ucfg_mlme_get_external_acs_policy() - Get flag for external control
  370. * acs policy
  371. * @psoc: pointer to psoc object
  372. * @value: Value that needs to be set from the caller
  373. *
  374. * Inline UCFG API to be used by HDD/OSIF callers
  375. *
  376. * Return: QDF Status
  377. */
  378. static inline QDF_STATUS
  379. ucfg_mlme_get_external_acs_policy(struct wlan_objmgr_psoc *psoc,
  380. bool *value)
  381. {
  382. return wlan_mlme_get_external_acs_policy(psoc, value);
  383. }
  384. /**
  385. * ucfg_mlme_set_ht_cap_info() - Set the HT cap info config
  386. * @psoc: pointer to psoc object
  387. * @value: Value that needs to be set from the caller
  388. *
  389. * Inline UCFG API to be used by HDD/OSIF callers
  390. *
  391. * Return: QDF Status
  392. */
  393. static inline
  394. QDF_STATUS
  395. ucfg_mlme_get_acs_support_for_dfs_ltecoex(struct wlan_objmgr_psoc *psoc,
  396. bool *value)
  397. {
  398. return wlan_mlme_get_acs_support_for_dfs_ltecoex(psoc, value);
  399. }
  400. /**
  401. * ucfg_mlme_get_wmm_dir_ac_vo() - Get TSPEC direction for VO
  402. * @psoc: pointer to psoc object
  403. * @value: Value that needs to be set from the caller
  404. *
  405. * Inline UCFG API to be used by HDD/OSIF callers
  406. *
  407. * Return: QDF Status
  408. */
  409. static inline QDF_STATUS
  410. ucfg_mlme_get_wmm_dir_ac_vo(struct wlan_objmgr_psoc *psoc,
  411. uint8_t *value)
  412. {
  413. return wlan_mlme_get_wmm_dir_ac_vo(psoc, value);
  414. }
  415. /**
  416. * ucfg_mlme_get_wmm_nom_msdu_size_ac_vo() - Get normal
  417. * MSDU size for VO
  418. * @psoc: pointer to psoc object
  419. * @value: Value that needs to be set from the caller
  420. *
  421. * Inline UCFG API to be used by HDD/OSIF callers
  422. *
  423. * Return: QDF Status
  424. */
  425. static inline QDF_STATUS
  426. ucfg_mlme_get_wmm_nom_msdu_size_ac_vo(struct wlan_objmgr_psoc *psoc,
  427. uint16_t *value)
  428. {
  429. return wlan_mlme_get_wmm_nom_msdu_size_ac_vo(psoc, value);
  430. }
  431. /**
  432. * ucfg_mlme_get_wmm_mean_data_rate_ac_vo() - mean data rate for VO
  433. * @psoc: pointer to psoc object
  434. * @value: Value that needs to be set from the caller
  435. *
  436. * Inline UCFG API to be used by HDD/OSIF callers
  437. *
  438. * Return: QDF Status
  439. */
  440. static inline QDF_STATUS
  441. ucfg_mlme_get_wmm_mean_data_rate_ac_vo(struct wlan_objmgr_psoc *psoc,
  442. uint32_t *value)
  443. {
  444. return wlan_mlme_get_wmm_mean_data_rate_ac_vo(psoc, value);
  445. }
  446. /**
  447. * ucfg_mlme_get_wmm_min_phy_rate_ac_vo() - min PHY
  448. * rate for VO
  449. * @psoc: pointer to psoc object
  450. * @value: Value that needs to be set from the caller
  451. *
  452. * Inline UCFG API to be used by HDD/OSIF callers
  453. *
  454. * Return: QDF Status
  455. */
  456. static inline QDF_STATUS
  457. ucfg_mlme_get_wmm_min_phy_rate_ac_vo(struct wlan_objmgr_psoc *psoc,
  458. uint32_t *value)
  459. {
  460. return wlan_mlme_get_wmm_min_phy_rate_ac_vo(psoc, value);
  461. }
  462. /**
  463. * ucfg_mlme_get_wmm_sba_ac_vo() - surplus bandwidth
  464. * allowance for VO
  465. * @psoc: pointer to psoc object
  466. * @value: Value that needs to be set from the caller
  467. *
  468. * Inline UCFG API to be used by HDD/OSIF callers
  469. *
  470. * Return: QDF Status
  471. */
  472. static inline QDF_STATUS
  473. ucfg_mlme_get_wmm_sba_ac_vo(struct wlan_objmgr_psoc *psoc,
  474. uint16_t *value)
  475. {
  476. return wlan_mlme_get_wmm_sba_ac_vo(psoc, value);
  477. }
  478. /**
  479. * ucfg_mlme_get_wmm_uapsd_vo_srv_intv() - Get Uapsd service
  480. * interval for voice
  481. * @psoc: pointer to psoc object
  482. * @value: pointer to the value which will be filled for the caller
  483. *
  484. * Inline UCFG API to be used by HDD/OSIF callers
  485. *
  486. * Return: QDF Status
  487. */
  488. static inline QDF_STATUS
  489. ucfg_mlme_get_wmm_uapsd_vo_srv_intv(struct wlan_objmgr_psoc *psoc,
  490. uint32_t *value)
  491. {
  492. return wlan_mlme_get_wmm_uapsd_vo_srv_intv(psoc, value);
  493. }
  494. /**
  495. * ucfg_mlme_get_wmm_uapsd_vo_sus_intv() - Get Uapsd suspension
  496. * interval for voice
  497. * @psoc: pointer to psoc object
  498. * @value: Value that needs to be set from the caller
  499. *
  500. * Inline UCFG API to be used by HDD/OSIF callers
  501. *
  502. * Return: QDF Status
  503. */
  504. static inline QDF_STATUS
  505. ucfg_mlme_get_wmm_uapsd_vo_sus_intv(struct wlan_objmgr_psoc *psoc,
  506. uint32_t *value)
  507. {
  508. return wlan_mlme_get_wmm_uapsd_vo_sus_intv(psoc, value);
  509. }
  510. /**
  511. *
  512. * ucfg_mlme_get_sap_inactivity_override() - Check if sap max inactivity
  513. * override flag is set.
  514. * @psoc: pointer to psoc object
  515. * @sme_config - Sme config struct
  516. *
  517. * Inline UCFG API to be used by HDD/OSIF callers to call
  518. * the mlme function wlan_mlme_get_sap_inactivity_override
  519. *
  520. * Return: QDF Status
  521. */
  522. static inline
  523. void ucfg_mlme_get_sap_inactivity_override(struct wlan_objmgr_psoc *psoc,
  524. bool *value)
  525. {
  526. wlan_mlme_get_sap_inactivity_override(psoc, value);
  527. }
  528. /**
  529. * ucfg_mlme_get_tx_chainmask_1ss() - Get the tx_chainmask_1ss value
  530. *
  531. * @psoc: pointer to psoc object
  532. * @value: Value that needs to be set from the caller
  533. *
  534. * Return: QDF_STATUS_FAILURE or QDF_STATUS_SUCCESS
  535. */
  536. static inline
  537. QDF_STATUS ucfg_mlme_get_tx_chainmask_1ss(struct wlan_objmgr_psoc *psoc,
  538. uint8_t *value)
  539. {
  540. return wlan_mlme_get_tx_chainmask_1ss(psoc, value);
  541. }
  542. /**
  543. * ucfg_mlme_get_num_11b_tx_chains() - Get the number of 11b only tx chains
  544. *
  545. * @psoc: pointer to psoc object
  546. * @value: Value that needs to be set from the caller
  547. *
  548. * Return: QDF_STATUS_FAILURE or QDF_STATUS_SUCCESS
  549. */
  550. static inline
  551. QDF_STATUS ucfg_mlme_get_num_11b_tx_chains(struct wlan_objmgr_psoc *psoc,
  552. uint16_t *value)
  553. {
  554. return wlan_mlme_get_num_11b_tx_chains(psoc, value);
  555. }
  556. /**
  557. * ucfg_mlme_get_num_11ag_tx_chains() - get the total number of 11a/g tx chains
  558. *
  559. * @psoc: pointer to psoc object
  560. * @value: Value that needs to be set from the caller
  561. *
  562. * Return: QDF_STATUS_FAILURE or QDF_STATUS_SUCCESS
  563. */
  564. static inline
  565. QDF_STATUS ucfg_mlme_get_num_11ag_tx_chains(struct wlan_objmgr_psoc *psoc,
  566. uint16_t *value)
  567. {
  568. return wlan_mlme_get_num_11ag_tx_chains(psoc, value);
  569. }
  570. /**
  571. * ucfg_mlme_configure_chain_mask() - configure chainmask parameters
  572. *
  573. * @psoc: pointer to psoc object
  574. * @session_id: vdev_id
  575. *
  576. * Return: QDF_STATUS_FAILURE or QDF_STATUS_SUCCESS
  577. */
  578. static inline
  579. QDF_STATUS ucfg_mlme_configure_chain_mask(struct wlan_objmgr_psoc *psoc,
  580. uint8_t session_id)
  581. {
  582. return wlan_mlme_configure_chain_mask(psoc, session_id);
  583. }
  584. /*
  585. * ucfg_mlme_get_sta_keep_alive_period() - Get the sta keep alive period
  586. * @psoc: pointer to psoc object
  587. * @val: Pointer to the value which will be filled for the caller
  588. *
  589. * Return: QDF Status
  590. */
  591. QDF_STATUS
  592. ucfg_mlme_get_sta_keep_alive_period(struct wlan_objmgr_psoc *psoc,
  593. uint32_t *val);
  594. /*
  595. * ucfg_mlme_get_dfs_master_capability() - Get the dfs master capability
  596. * @psoc: pointer to psoc object
  597. * @val: Pointer to the value which will be filled for the caller
  598. *
  599. * Return: QDF Status
  600. */
  601. QDF_STATUS
  602. ucfg_mlme_get_dfs_master_capability(struct wlan_objmgr_psoc *psoc,
  603. bool *val);
  604. /**
  605. * ucfg_mlme_get_pmkid_modes() - Get PMKID modes
  606. * @psoc: pointer to psoc object
  607. * @val: Pointer to the value which will be filled for the caller
  608. *
  609. * Return: QDF Status
  610. */
  611. QDF_STATUS
  612. ucfg_mlme_get_pmkid_modes(struct wlan_objmgr_psoc *psoc,
  613. uint32_t *val);
  614. /**
  615. * ucfg_mlme_set_pmkid_modes() - Set PMKID modes
  616. * @psoc: pointer to psoc object
  617. * @val: Pointer to the value which will be filled for the caller
  618. *
  619. * Return: QDF Status
  620. */
  621. QDF_STATUS
  622. ucfg_mlme_set_pmkid_modes(struct wlan_objmgr_psoc *psoc,
  623. uint32_t val);
  624. /**
  625. * ucfg_mlme_get_dot11p_mode() - Get the setting about 802.11p mode
  626. * @psoc: pointer to psoc object
  627. * @out_mode: Pointer to the mode which will be filled for the caller
  628. *
  629. * Return: QDF Status
  630. */
  631. QDF_STATUS
  632. ucfg_mlme_get_dot11p_mode(struct wlan_objmgr_psoc *psoc,
  633. enum dot11p_mode *out_mode);
  634. /**
  635. * ucfg_mlme_get_go_cts2self_for_sta() - Stop NOA and start using cts2self
  636. * @psoc: pointer to psoc object
  637. * @val: Pointer to the value which will be filled for the caller
  638. *
  639. * Return: QDF Status
  640. */
  641. QDF_STATUS
  642. ucfg_mlme_get_go_cts2self_for_sta(struct wlan_objmgr_psoc *psoc,
  643. bool *val);
  644. /**
  645. * ucfg_mlme_get_force_rsne_override() - Force rsnie override from user
  646. * @psoc: pointer to psoc object
  647. * @val: Pointer to the value which will be filled for the caller
  648. *
  649. * Return: QDF Status
  650. */
  651. QDF_STATUS
  652. ucfg_mlme_get_force_rsne_override(struct wlan_objmgr_psoc *psoc,
  653. bool *val);
  654. /**
  655. * ucfg_mlme_get_qcn_ie_support() - QCN IE support or not
  656. * @psoc: pointer to psoc object
  657. * @val: Pointer to the value which will be filled for the caller
  658. *
  659. * Return: QDF Status
  660. */
  661. QDF_STATUS
  662. ucfg_mlme_get_qcn_ie_support(struct wlan_objmgr_psoc *psoc,
  663. bool *val);
  664. /**
  665. * ucfg_mlme_get_tgt_gtx_usr_cfg() - Get the target gtx user config
  666. * @psoc: pointer to psoc object
  667. * @val: Pointer to the value which will be filled for the caller
  668. *
  669. * Return: QDF Status
  670. */
  671. QDF_STATUS
  672. ucfg_mlme_get_tgt_gtx_usr_cfg(struct wlan_objmgr_psoc *psoc,
  673. uint32_t *val);
  674. /**
  675. * ucfg_mlme_get_roaming_offload() - Get roaming offload setting
  676. * @psoc: pointer to psoc object
  677. * @val: Pointer to enable/disable roaming offload
  678. *
  679. * Return: QDF Status
  680. */
  681. QDF_STATUS
  682. ucfg_mlme_get_roaming_offload(struct wlan_objmgr_psoc *psoc,
  683. bool *val);
  684. /**
  685. * ucfg_mlme_set_roaming_offload() - Enable/disable roaming offload
  686. * @psoc: pointer to psoc object
  687. * @val: enable/disable roaming offload
  688. *
  689. * Return: QDF Status
  690. */
  691. QDF_STATUS
  692. ucfg_mlme_set_roaming_offload(struct wlan_objmgr_psoc *psoc,
  693. bool val);
  694. /**
  695. * ucfg_mlme_get_first_scan_bucket_threshold() - Get first scan bucket thre
  696. * @psoc: pointer to psoc object
  697. * @val: first scan bucket threshold
  698. *
  699. * Return: QDF Status
  700. */
  701. QDF_STATUS
  702. ucfg_mlme_get_first_scan_bucket_threshold(struct wlan_objmgr_psoc *psoc,
  703. uint8_t *val);
  704. /**
  705. * ucfg_mlme_set_sap_listen_interval() - Set the Sap listen interval
  706. * @psoc: pointer to psoc object
  707. * @value: Value that needs to be set from the caller
  708. *
  709. * Inline UCFG API to be used by HDD/OSIF callers
  710. *
  711. * Return: QDF Status
  712. */
  713. static inline
  714. QDF_STATUS ucfg_mlme_set_sap_listen_interval(struct wlan_objmgr_psoc *psoc,
  715. int value)
  716. {
  717. return wlan_mlme_set_sap_listen_interval(psoc, value);
  718. }
  719. /**
  720. * ucfg_mlme_set_assoc_sta_limit() - Set the assoc sta limit
  721. * @psoc: pointer to psoc object
  722. * @value: Value that needs to be set from the caller
  723. *
  724. * Inline UCFG API to be used by HDD/OSIF callers
  725. *
  726. * Return: QDF Status
  727. */
  728. static inline
  729. QDF_STATUS ucfg_mlme_set_assoc_sta_limit(struct wlan_objmgr_psoc *psoc,
  730. int value)
  731. {
  732. return wlan_mlme_set_assoc_sta_limit(psoc, value);
  733. }
  734. /**
  735. * ucfg_mlme_set_rmc_action_period_freq() - Set the rmc action period frequency
  736. * @psoc: pointer to psoc object
  737. * @value: Value that needs to be set from the caller
  738. *
  739. * Inline UCFG API to be used by HDD/OSIF callers
  740. *
  741. * Return: QDF Status
  742. */
  743. static inline
  744. QDF_STATUS ucfg_mlme_set_rmc_action_period_freq(struct wlan_objmgr_psoc *psoc,
  745. int value)
  746. {
  747. return wlan_mlme_set_rmc_action_period_freq(psoc, value);
  748. }
  749. /**
  750. * ucfg_mlme_get_sap_get_peer_info() - get the sap get peer info
  751. * @psoc: pointer to psoc object
  752. * @value: Value that needs to be set from the caller
  753. *
  754. * Inline UCFG API to be used by HDD/OSIF callers
  755. *
  756. * Return: QDF Status
  757. */
  758. static inline
  759. QDF_STATUS ucfg_mlme_get_sap_get_peer_info(struct wlan_objmgr_psoc *psoc,
  760. bool *value)
  761. {
  762. return wlan_mlme_get_sap_get_peer_info(psoc, value);
  763. }
  764. /**
  765. * ucfg_mlme_get_sap_allow_all_channels() - get the sap allow all channels
  766. * @psoc: pointer to psoc object
  767. * @value: Value that needs to be set from the caller
  768. *
  769. * Inline UCFG API to be used by HDD/OSIF callers
  770. *
  771. * Return: QDF Status
  772. */
  773. static inline
  774. QDF_STATUS ucfg_mlme_get_sap_allow_all_channels(struct wlan_objmgr_psoc *psoc,
  775. bool *value)
  776. {
  777. return wlan_mlme_get_sap_allow_all_channels(psoc, value);
  778. }
  779. /**
  780. * ucfg_mlme_get_sap_max_peers() - get the sap max peers
  781. * @psoc: pointer to psoc object
  782. * @value: Value that needs to be set from the caller
  783. *
  784. * Inline UCFG API to be used by HDD/OSIF callers
  785. *
  786. * Return: QDF Status
  787. */
  788. static inline
  789. QDF_STATUS ucfg_mlme_get_sap_max_peers(struct wlan_objmgr_psoc *psoc,
  790. int *value)
  791. {
  792. return wlan_mlme_get_sap_max_peers(psoc, value);
  793. }
  794. /**
  795. * ucfg_mlme_set_sap_max_peers() - Set the sap max peers
  796. * @psoc: pointer to psoc object
  797. * @value: Value that needs to be set from the caller
  798. *
  799. * Inline UCFG API to be used by HDD/OSIF callers
  800. *
  801. * Return: QDF Status
  802. */
  803. static inline
  804. QDF_STATUS ucfg_mlme_set_sap_max_peers(struct wlan_objmgr_psoc *psoc, int value)
  805. {
  806. return wlan_mlme_set_sap_max_peers(psoc, value);
  807. }
  808. /**
  809. * ucfg_mlme_get_sap_max_offload_peers() - get the sap max offload peers
  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
  814. *
  815. * Return: QDF Status
  816. */
  817. static inline
  818. QDF_STATUS ucfg_mlme_get_sap_max_offload_peers(struct wlan_objmgr_psoc *psoc,
  819. int *value)
  820. {
  821. return wlan_mlme_get_sap_max_offload_peers(psoc, value);
  822. }
  823. /**
  824. * ucfg_mlme_get_sap_max_offload_reorder_buffs() - get the sap max offload
  825. * reorder buffs
  826. * @psoc: pointer to psoc object
  827. * @value: Value that needs to be set from the caller
  828. *
  829. * Inline UCFG API to be used by HDD/OSIF callers
  830. *
  831. * Return: QDF Status
  832. */
  833. static inline
  834. QDF_STATUS ucfg_mlme_get_sap_max_offload_reorder_buffs(struct wlan_objmgr_psoc
  835. *psoc, int *value)
  836. {
  837. return wlan_mlme_get_sap_max_offload_reorder_buffs(psoc, value);
  838. }
  839. /**
  840. * ucfg_mlme_get_sap_chn_switch_bcn_count() - get the sap channel
  841. * switch beacon count
  842. * @psoc: pointer to psoc object
  843. * @value: Value that needs to be set from the caller
  844. *
  845. * Inline UCFG API to be used by HDD/OSIF callers
  846. *
  847. * Return: QDF Status
  848. */
  849. static inline
  850. QDF_STATUS ucfg_mlme_get_sap_chn_switch_bcn_count(struct wlan_objmgr_psoc *psoc,
  851. int *value)
  852. {
  853. return wlan_mlme_get_sap_chn_switch_bcn_count(psoc, value);
  854. }
  855. /**
  856. * ucfg_mlme_get_sap_channel_switch_mode() - get the sap channel switch mode
  857. * @psoc: pointer to psoc object
  858. * @value: Value that needs to be set from the caller
  859. *
  860. * Inline UCFG API to be used by HDD/OSIF callers
  861. *
  862. * Return: QDF Status
  863. */
  864. static inline
  865. QDF_STATUS ucfg_mlme_get_sap_channel_switch_mode(struct wlan_objmgr_psoc *psoc,
  866. bool *value)
  867. {
  868. return wlan_mlme_get_sap_chn_switch_mode(psoc, value);
  869. }
  870. /**
  871. * ucfg_mlme_get_sap_internal_restart() - get sap internal restart value
  872. * @psoc: pointer to psoc object
  873. * @value: Value that needs to be set from the caller
  874. *
  875. * Inline UCFG API to be used by HDD/OSIF callers
  876. *
  877. * Return: QDF Status
  878. */
  879. static inline
  880. QDF_STATUS ucfg_mlme_get_sap_internal_restart(struct wlan_objmgr_psoc *psoc,
  881. bool *value)
  882. {
  883. return wlan_mlme_get_sap_internal_restart(psoc, value);
  884. }
  885. /**
  886. * ucfg_mlme_get_sap_reduces_beacon_interval() - get the sap reduces beacon
  887. * interval
  888. * @psoc: pointer to psoc object
  889. * @value: Value that needs to be set from the caller
  890. *
  891. * Inline UCFG API to be used by HDD/OSIF callers
  892. *
  893. * Return: QDF Status
  894. */
  895. static inline
  896. QDF_STATUS ucfg_mlme_get_sap_reduces_beacon_interval(struct wlan_objmgr_psoc
  897. *psoc, int *value)
  898. {
  899. return wlan_mlme_get_sap_reduced_beacon_interval(psoc, value);
  900. }
  901. /**
  902. * ucfg_mlme_get_sap_chan_switch_rate_enabled() - get the sap channel
  903. * switch rate enabled.
  904. * @psoc: pointer to psoc object
  905. * @value: Value that needs to be set from the caller
  906. *
  907. * Inline UCFG API to be used by HDD/OSIF callers
  908. *
  909. * Return: QDF Status
  910. */
  911. static inline
  912. QDF_STATUS ucfg_mlme_get_sap_chan_switch_rate_enabled(struct wlan_objmgr_psoc
  913. *psoc, bool *value)
  914. {
  915. return wlan_mlme_get_sap_chan_switch_rate_enabled(psoc, value);
  916. }
  917. /**
  918. * ucfg_mlme_get_oce_sta_enabled_info() - Get OCE feature enable/disable
  919. * info for STA
  920. *
  921. * @psoc: pointer to psoc object
  922. * @value: pointer to the value which will be filled for the caller
  923. *
  924. * Inline UCFG API to be used by HDD/OSIF callers to get the
  925. * OCE STA feature enable value
  926. *
  927. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  928. */
  929. static inline
  930. QDF_STATUS ucfg_mlme_get_oce_sta_enabled_info(struct wlan_objmgr_psoc *psoc,
  931. bool *value)
  932. {
  933. return wlan_mlme_get_oce_sta_enabled_info(psoc, value);
  934. }
  935. /**
  936. * ucfg_mlme_get_oce_sap_enabled_info() - Get OCE feature enable/disable
  937. * info for SAP
  938. *
  939. * @psoc: pointer to psoc object
  940. * @value: pointer to the value which will be filled for the caller
  941. *
  942. * Inline UCFG API to be used by HDD/OSIF callers to get the
  943. * OCE SAP feature enable value
  944. *
  945. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  946. */
  947. static inline
  948. QDF_STATUS ucfg_mlme_get_oce_sap_enabled_info(struct wlan_objmgr_psoc *psoc,
  949. bool *value)
  950. {
  951. return wlan_mlme_get_oce_sap_enabled_info(psoc, value);
  952. }
  953. /**
  954. * ucfg_mlme_get_rts_threshold() - Get the rts threshold config
  955. * @psoc: pointer to psoc object
  956. * @value: pointer to the value which will be filled for the caller
  957. *
  958. * Inline UCFG API to be used by HDD/OSIF callers
  959. *
  960. * Return: QDF Status
  961. */
  962. static inline
  963. QDF_STATUS ucfg_mlme_get_rts_threshold(struct wlan_objmgr_psoc *psoc,
  964. uint32_t *value)
  965. {
  966. return wlan_mlme_get_rts_threshold(psoc, value);
  967. }
  968. /**
  969. * ucfg_mlme_set_rts_threshold() - Set the rts threshold config
  970. * @psoc: pointer to psoc object
  971. * @value: pointer to the value which will be filled for the caller
  972. *
  973. * Inline UCFG API to be used by HDD/OSIF callers
  974. *
  975. * Return: QDF Status
  976. */
  977. static inline
  978. QDF_STATUS ucfg_mlme_set_rts_threshold(struct wlan_objmgr_psoc *psoc,
  979. uint32_t value)
  980. {
  981. return wlan_mlme_set_rts_threshold(psoc, value);
  982. }
  983. /**
  984. * ucfg_mlme_get_frag_threshold() - Get the fragmentation threshold
  985. * config
  986. * @psoc: pointer to psoc object
  987. * @value: Value that needs to be set from the caller
  988. *
  989. * Inline UCFG API to be used by HDD/OSIF callers
  990. *
  991. * Return: QDF Status
  992. */
  993. static inline
  994. QDF_STATUS ucfg_mlme_get_frag_threshold(struct wlan_objmgr_psoc *psoc,
  995. uint32_t *value)
  996. {
  997. return wlan_mlme_get_frag_threshold(psoc, value);
  998. }
  999. /**
  1000. * ucfg_mlme_set_frag_threshold() - set the frag threshold config
  1001. * @psoc: pointer to psoc object
  1002. * @value: pointer to the value which will be filled for the caller
  1003. *
  1004. * Inline UCFG API to be used by HDD/OSIF callers
  1005. *
  1006. * Return: QDF Status
  1007. */
  1008. static inline
  1009. QDF_STATUS ucfg_mlme_set_frag_threshold(struct wlan_objmgr_psoc *psoc,
  1010. uint32_t value)
  1011. {
  1012. return wlan_mlme_set_frag_threshold(psoc, value);
  1013. }
  1014. /**
  1015. * ucfg_mlme_get_fils_enabled_info() - Get fils enable/disable info
  1016. *
  1017. * @psoc: pointer to psoc object
  1018. * @value: pointer to the value which will be filled for the caller
  1019. *
  1020. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1021. * fils enable value
  1022. *
  1023. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1024. */
  1025. static inline
  1026. QDF_STATUS ucfg_mlme_get_fils_enabled_info(struct wlan_objmgr_psoc *psoc,
  1027. bool *value)
  1028. {
  1029. return wlan_mlme_get_fils_enabled_info(psoc, value);
  1030. }
  1031. /**
  1032. * ucfg_mlme_set_fils_enabled_info() - Set fils enable info
  1033. *
  1034. * @psoc: pointer to psoc object
  1035. * @value: value that needs to be set from the caller
  1036. *
  1037. * Inline UCFG API to be used by HDD/OSIF callers to set the
  1038. * fils enable value
  1039. *
  1040. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1041. */
  1042. static inline
  1043. QDF_STATUS ucfg_mlme_set_fils_enabled_info(struct wlan_objmgr_psoc *psoc,
  1044. bool value)
  1045. {
  1046. return wlan_mlme_set_fils_enabled_info(psoc, value);
  1047. }
  1048. /**
  1049. * ucfg_mlme_set_enable_bcast_probe_rsp() - Set enable bcast probe resp info
  1050. * @psoc: pointer to psoc object
  1051. * @value: value that needs to be set from the caller
  1052. *
  1053. * Inline UCFG API to be used by HDD/OSIF callers to set the
  1054. * enable bcast probe resp info
  1055. *
  1056. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1057. */
  1058. static inline
  1059. QDF_STATUS ucfg_mlme_set_enable_bcast_probe_rsp(struct wlan_objmgr_psoc *psoc,
  1060. bool value)
  1061. {
  1062. return wlan_mlme_set_enable_bcast_probe_rsp(psoc, value);
  1063. }
  1064. /**
  1065. * ucfg_mlme_set_vht_ch_width() - set the vht supported channel width cfg
  1066. * @psoc: psoc context
  1067. * @value: data to be set
  1068. *
  1069. * Inline UCFG API to be used by HDD/OSIF callers
  1070. *
  1071. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1072. */
  1073. static inline
  1074. QDF_STATUS ucfg_mlme_set_vht_ch_width(struct wlan_objmgr_psoc *psoc,
  1075. uint8_t value)
  1076. {
  1077. return wlan_mlme_cfg_set_vht_chan_width(psoc, value);
  1078. }
  1079. /**
  1080. * ucfg_mlme_cfg_get_vht_chan_width() - gets vht supported channel width into
  1081. * cfg item
  1082. * @psoc: psoc context
  1083. * @value: data to be set
  1084. *
  1085. * Inline UCFG API to be used by HDD/OSIF callers
  1086. *
  1087. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1088. */
  1089. static inline
  1090. QDF_STATUS ucfg_mlme_cfg_get_vht_chan_width(struct wlan_objmgr_psoc *psoc,
  1091. uint8_t *value)
  1092. {
  1093. return wlan_mlme_cfg_get_vht_chan_width(psoc, value);
  1094. }
  1095. /**
  1096. * ucfg_mlme_cfg_set_vht_ldpc_coding_cap() - sets vht ldpc coding cap into
  1097. * cfg item
  1098. * @psoc: psoc context
  1099. * @value: data to be set
  1100. *
  1101. * Inline UCFG API to be used by HDD/OSIF callers
  1102. *
  1103. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1104. */
  1105. static inline QDF_STATUS
  1106. ucfg_mlme_cfg_set_vht_ldpc_coding_cap(struct wlan_objmgr_psoc *psoc,
  1107. bool value)
  1108. {
  1109. return wlan_mlme_cfg_set_vht_ldpc_coding_cap(psoc, value);
  1110. }
  1111. /**
  1112. * ucfg_mlme_cfg_get_short_gi_160_mhz() - Get SHORT GI 160MHZ from cfg item
  1113. * @psoc: psoc context
  1114. * @value: data to be set
  1115. *
  1116. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1117. * ignore_peer_ht_opmode flag value
  1118. *
  1119. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1120. */
  1121. static inline QDF_STATUS
  1122. ucfg_mlme_cfg_get_short_gi_160_mhz(struct wlan_objmgr_psoc *psoc,
  1123. bool *value)
  1124. {
  1125. return wlan_mlme_cfg_get_short_gi_160_mhz(psoc, value);
  1126. }
  1127. /**
  1128. * ucfg_mlme_cfg_set_short_gi_160_mhz() - sets basic set SHORT GI 160MHZ into
  1129. * cfg item
  1130. * @psoc: psoc context
  1131. * @value: data to be set
  1132. *
  1133. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1134. * ignore_peer_ht_opmode flag value
  1135. *
  1136. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1137. */
  1138. static inline QDF_STATUS
  1139. ucfg_mlme_cfg_set_short_gi_160_mhz(struct wlan_objmgr_psoc *psoc,
  1140. bool value)
  1141. {
  1142. return wlan_mlme_cfg_set_short_gi_160_mhz(psoc, value);
  1143. }
  1144. /**
  1145. * ucfg_mlme_cfg_get_vht_tx_stbc() - gets vht tx stbc from
  1146. * cfg item
  1147. * @psoc: psoc context
  1148. * @value: pointer to get required data
  1149. *
  1150. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1151. * ignore_peer_ht_opmode flag value
  1152. *
  1153. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1154. */
  1155. static inline QDF_STATUS
  1156. ucfg_mlme_cfg_get_vht_tx_stbc(struct wlan_objmgr_psoc *psoc,
  1157. bool *value)
  1158. {
  1159. return wlan_mlme_cfg_get_vht_tx_stbc(psoc, value);
  1160. }
  1161. /**
  1162. * ucfg_mlme_cfg_get_vht_rx_stbc() - gets vht rx stbc from
  1163. * cfg item
  1164. * @psoc: psoc context
  1165. * @value: pointer to get required data
  1166. *
  1167. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1168. * ignore_peer_ht_opmode flag value
  1169. *
  1170. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1171. */
  1172. static inline QDF_STATUS
  1173. ucfg_mlme_cfg_get_vht_rx_stbc(struct wlan_objmgr_psoc *psoc,
  1174. bool *value)
  1175. {
  1176. return wlan_mlme_cfg_get_vht_rx_stbc(psoc, value);
  1177. }
  1178. /**
  1179. * ucfg_mlme_cfg_set_vht_tx_bfee_ant_supp() - sets vht Beamformee antenna
  1180. * support cap into cfg item
  1181. * @psoc: psoc context
  1182. * @value: data to be set
  1183. *
  1184. * Inline UCFG API to be used by HDD/OSIF callers
  1185. *
  1186. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1187. */
  1188. static inline QDF_STATUS
  1189. ucfg_mlme_cfg_set_vht_tx_bfee_ant_supp(struct wlan_objmgr_psoc *psoc,
  1190. uint8_t value)
  1191. {
  1192. return wlan_mlme_cfg_set_vht_tx_bfee_ant_supp(psoc, value);
  1193. }
  1194. /**
  1195. * ucfg_mlme_cfg_get_vht_tx_bfee_ant_supp() - gets vht Beamformee antenna
  1196. * support cap into cfg item
  1197. * @psoc: psoc context
  1198. * @value: data to be set
  1199. *
  1200. * Inline UCFG API to be used by HDD/OSIF callers
  1201. *
  1202. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1203. */
  1204. static inline QDF_STATUS
  1205. ucfg_mlme_cfg_get_vht_tx_bfee_ant_supp(struct wlan_objmgr_psoc *psoc,
  1206. uint8_t *value)
  1207. {
  1208. return wlan_mlme_cfg_get_vht_tx_bfee_ant_supp(psoc, value);
  1209. }
  1210. /**
  1211. * ucfg_mlme_cfg_get_vht_rx_mcs_map() - gets vht rx mcs map from
  1212. * cfg item
  1213. * @psoc: psoc context
  1214. * @value: pointer to get required data
  1215. *
  1216. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1217. * ignore_peer_ht_opmode flag value
  1218. *
  1219. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1220. */
  1221. static inline QDF_STATUS
  1222. ucfg_mlme_cfg_get_vht_rx_mcs_map(struct wlan_objmgr_psoc *psoc,
  1223. uint32_t *value)
  1224. {
  1225. return wlan_mlme_cfg_get_vht_rx_mcs_map(psoc, value);
  1226. }
  1227. /**
  1228. * ucfg_mlme_cfg_set_vht_rx_mcs_map() - sets rx mcs map into
  1229. * cfg item
  1230. * @psoc: psoc context
  1231. * @value: data to be set
  1232. *
  1233. * Inline UCFG API to be used by HDD/OSIF callers
  1234. *
  1235. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1236. */
  1237. static inline QDF_STATUS
  1238. ucfg_mlme_cfg_set_vht_rx_mcs_map(struct wlan_objmgr_psoc *psoc,
  1239. uint32_t value)
  1240. {
  1241. return wlan_mlme_cfg_set_vht_rx_mcs_map(psoc, value);
  1242. }
  1243. /**
  1244. * ucfg_mlme_cfg_get_vht_tx_mcs_map() - gets vht tx mcs map from
  1245. * cfg item
  1246. * @psoc: psoc context
  1247. * @value: pointer to get required data
  1248. *
  1249. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1250. * ignore_peer_ht_opmode flag value
  1251. *
  1252. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1253. */
  1254. static inline QDF_STATUS
  1255. ucfg_mlme_cfg_get_vht_tx_mcs_map(struct wlan_objmgr_psoc *psoc,
  1256. uint32_t *value)
  1257. {
  1258. return wlan_mlme_cfg_get_vht_tx_mcs_map(psoc, value);
  1259. }
  1260. /**
  1261. * ucfg_mlme_cfg_set_vht_tx_mcs_map() - sets tx mcs map into
  1262. * cfg item
  1263. * @psoc: psoc context
  1264. * @value: data to be set
  1265. *
  1266. * Inline UCFG API to be used by HDD/OSIF callers
  1267. *
  1268. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1269. */
  1270. static inline QDF_STATUS
  1271. ucfg_mlme_cfg_set_vht_tx_mcs_map(struct wlan_objmgr_psoc *psoc,
  1272. uint32_t value)
  1273. {
  1274. return wlan_mlme_cfg_set_vht_tx_mcs_map(psoc, value);
  1275. }
  1276. /**
  1277. * ucfg_mlme_cfg_set_vht_rx_supp_data_rate() - sets rx supported data
  1278. * rate into cfg item
  1279. * @psoc: psoc context
  1280. * @value: data to be set
  1281. *
  1282. * Inline UCFG API to be used by HDD/OSIF callers
  1283. *
  1284. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1285. */
  1286. static inline QDF_STATUS
  1287. ucfg_mlme_cfg_set_vht_rx_supp_data_rate(struct wlan_objmgr_psoc *psoc,
  1288. uint32_t value)
  1289. {
  1290. return wlan_mlme_cfg_set_vht_rx_supp_data_rate(psoc, value);
  1291. }
  1292. /**
  1293. * ucfg_mlme_cfg_set_vht_tx_supp_data_rate() - sets tx supported data rate into
  1294. * cfg item
  1295. * @psoc: psoc context
  1296. * @value: data to be set
  1297. *
  1298. * Inline UCFG API to be used by HDD/OSIF callers
  1299. *
  1300. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1301. */
  1302. static inline QDF_STATUS
  1303. ucfg_mlme_cfg_set_vht_tx_supp_data_rate(struct wlan_objmgr_psoc *psoc,
  1304. uint32_t value)
  1305. {
  1306. return wlan_mlme_cfg_set_vht_tx_supp_data_rate(psoc, value);
  1307. }
  1308. /**
  1309. * ucfg_mlme_cfg_get_vht_basic_mcs_set() - gets basic mcs set from
  1310. * cfg item
  1311. * @psoc: psoc context
  1312. * @value: data to be set
  1313. *
  1314. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1315. * ignore_peer_ht_opmode flag value
  1316. *
  1317. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1318. */
  1319. static inline QDF_STATUS
  1320. ucfg_mlme_cfg_get_vht_basic_mcs_set(struct wlan_objmgr_psoc *psoc,
  1321. uint32_t *value)
  1322. {
  1323. return wlan_mlme_cfg_get_vht_basic_mcs_set(psoc, value);
  1324. }
  1325. /**
  1326. * ucfg_mlme_cfg_set_vht_basic_mcs_set() - sets basic mcs set into
  1327. * cfg item
  1328. * @psoc: psoc context
  1329. * @value: data to be set
  1330. *
  1331. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1332. * ignore_peer_ht_opmode flag value
  1333. *
  1334. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1335. */
  1336. static inline QDF_STATUS
  1337. ucfg_mlme_cfg_set_vht_basic_mcs_set(struct wlan_objmgr_psoc *psoc,
  1338. uint32_t value)
  1339. {
  1340. return wlan_mlme_cfg_set_vht_basic_mcs_set(psoc, value);
  1341. }
  1342. /**
  1343. * ucfg_mlme_get_vht_enable_tx_bf() - gets enable TXBF for 20MHZ
  1344. * for 11ac
  1345. * @psoc: psoc context
  1346. * @value: data to be set
  1347. *
  1348. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1349. * ignore_peer_ht_opmode flag value
  1350. *
  1351. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1352. */
  1353. static inline QDF_STATUS
  1354. ucfg_mlme_get_vht_enable_tx_bf(struct wlan_objmgr_psoc *psoc, bool *value)
  1355. {
  1356. return wlan_mlme_get_vht_enable_tx_bf(psoc, value);
  1357. }
  1358. /**
  1359. * ucfg_mlme_get_vht_tx_su_beamformer() - gets enable tx_su_beamformer
  1360. * for 11ac
  1361. * @psoc: psoc context
  1362. * @value: data to be set
  1363. *
  1364. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1365. * ignore_peer_ht_opmode flag value
  1366. *
  1367. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1368. */
  1369. static inline QDF_STATUS
  1370. ucfg_mlme_get_vht_tx_su_beamformer(struct wlan_objmgr_psoc *psoc, bool *value)
  1371. {
  1372. return wlan_mlme_get_vht_tx_su_beamformer(psoc, value);
  1373. }
  1374. /**
  1375. * ucfg_mlme_get_vht_channel_width() - gets Channel width capability
  1376. * for 11ac
  1377. * @psoc: psoc context
  1378. * @value: data to be set
  1379. *
  1380. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1381. * ignore_peer_ht_opmode flag value
  1382. *
  1383. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1384. */
  1385. static inline QDF_STATUS
  1386. ucfg_mlme_get_vht_channel_width(struct wlan_objmgr_psoc *psoc, uint8_t *value)
  1387. {
  1388. return wlan_mlme_get_vht_channel_width(psoc, value);
  1389. }
  1390. /**
  1391. * ucfg_mlme_get_vht_rx_mcs_8_9() - VHT Rx MCS capability for 1x1 mode
  1392. * for 11ac
  1393. * @psoc: psoc context
  1394. * @value: data to be set
  1395. *
  1396. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1397. * ignore_peer_ht_opmode flag value
  1398. *
  1399. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1400. */
  1401. static inline QDF_STATUS
  1402. ucfg_mlme_get_vht_rx_mcs_8_9(struct wlan_objmgr_psoc *psoc, uint8_t *value)
  1403. {
  1404. return wlan_mlme_get_vht_rx_mcs_8_9(psoc, value);
  1405. }
  1406. /**
  1407. * ucfg_mlme_get_vht_tx_mcs_8_9() - VHT Tx MCS capability for 1x1 mode
  1408. * for 11ac
  1409. * @psoc: psoc context
  1410. * @value: data to be set
  1411. *
  1412. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1413. * ignore_peer_ht_opmode flag value
  1414. *
  1415. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1416. */
  1417. static inline QDF_STATUS
  1418. ucfg_mlme_get_vht_tx_mcs_8_9(struct wlan_objmgr_psoc *psoc, uint8_t *value)
  1419. {
  1420. return wlan_mlme_get_vht_tx_mcs_8_9(psoc, value);
  1421. }
  1422. /**
  1423. * ucfg_mlme_get_vht_rx_mcs_2x2() - VHT Rx MCS capability for 2x2 mode
  1424. * for 11ac
  1425. * @psoc: psoc context
  1426. * @value: data to be set
  1427. *
  1428. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1429. * ignore_peer_ht_opmode flag value
  1430. *
  1431. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1432. */
  1433. static inline QDF_STATUS
  1434. ucfg_mlme_get_vht_rx_mcs_2x2(struct wlan_objmgr_psoc *psoc, uint8_t *value)
  1435. {
  1436. return wlan_mlme_get_vht_rx_mcs_2x2(psoc, value);
  1437. }
  1438. /**
  1439. * ucfg_mlme_get_vht_tx_mcs_2x2() - VHT Tx MCS capability for 2x2 mode
  1440. * for 11ac
  1441. * @psoc: psoc context
  1442. * @value: data to be set
  1443. *
  1444. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1445. * ignore_peer_ht_opmode flag value
  1446. *
  1447. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1448. */
  1449. static inline QDF_STATUS
  1450. ucfg_mlme_get_vht_tx_mcs_2x2(struct wlan_objmgr_psoc *psoc, uint8_t *value)
  1451. {
  1452. return wlan_mlme_get_vht_tx_mcs_2x2(psoc, value);
  1453. }
  1454. /**
  1455. * ucfg_mlme_get_vht20_mcs9() - Enables VHT MCS9 in 20M BW operation
  1456. * @psoc: psoc context
  1457. * @value: data to be set
  1458. *
  1459. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1460. * ignore_peer_ht_opmode flag value
  1461. *
  1462. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1463. */
  1464. static inline QDF_STATUS
  1465. ucfg_mlme_get_vht20_mcs9(struct wlan_objmgr_psoc *psoc, bool *value)
  1466. {
  1467. return wlan_mlme_get_vht20_mcs9(psoc, value);
  1468. }
  1469. /**
  1470. * ucfg_mlme_get_vht_enable2x2() - Enables/disables VHT Tx/Rx MCS values for 2x2
  1471. * @psoc: psoc context
  1472. * @value: data to be set
  1473. *
  1474. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1475. * ignore_peer_ht_opmode flag value
  1476. *
  1477. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1478. */
  1479. static inline QDF_STATUS
  1480. ucfg_mlme_get_vht_enable2x2(struct wlan_objmgr_psoc *psoc, bool *value)
  1481. {
  1482. return wlan_mlme_get_vht_enable2x2(psoc, value);
  1483. }
  1484. /**
  1485. * ucfg_mlme_set_vht_enable2x2() - Enables/disables VHT Tx/Rx MCS values for 2x2
  1486. * @psoc: psoc context
  1487. * @value: data to be set
  1488. *
  1489. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1490. * ignore_peer_ht_opmode flag value
  1491. *
  1492. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1493. */
  1494. static inline QDF_STATUS
  1495. ucfg_mlme_set_vht_enable2x2(struct wlan_objmgr_psoc *psoc, bool value)
  1496. {
  1497. return wlan_mlme_set_vht_enable2x2(psoc, value);
  1498. }
  1499. /**
  1500. * ucfg_mlme_get_vht_enable_paid() - Enables/disables paid feature
  1501. * @psoc: psoc context
  1502. * @value: data to be set
  1503. *
  1504. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1505. * ignore_peer_ht_opmode flag value
  1506. *
  1507. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1508. */
  1509. static inline QDF_STATUS
  1510. ucfg_mlme_get_vht_enable_paid(struct wlan_objmgr_psoc *psoc, bool *value)
  1511. {
  1512. return wlan_mlme_get_vht_enable_paid(psoc, value);
  1513. }
  1514. /**
  1515. * ucfg_mlme_get_vht_enable_gid() - Enables/disables gid feature
  1516. * @psoc: psoc context
  1517. * @value: data to be set
  1518. *
  1519. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1520. * ignore_peer_ht_opmode flag value
  1521. *
  1522. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1523. */
  1524. static inline QDF_STATUS
  1525. ucfg_mlme_get_vht_enable_gid(struct wlan_objmgr_psoc *psoc, bool *value)
  1526. {
  1527. return wlan_mlme_get_vht_enable_gid(psoc, value);
  1528. }
  1529. /**
  1530. * ucfg_mlme_get_vht_for_24ghz() - Enables/disables vht for 24ghz
  1531. * @psoc: psoc context
  1532. * @value: data to be set
  1533. *
  1534. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1535. * ignore_peer_ht_opmode flag value
  1536. *
  1537. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1538. */
  1539. static inline QDF_STATUS
  1540. ucfg_mlme_get_vht_for_24ghz(struct wlan_objmgr_psoc *psoc, bool *value)
  1541. {
  1542. return wlan_mlme_get_vht_for_24ghz(psoc, value);
  1543. }
  1544. /**
  1545. * ucfg_mlme_get_vendor_vht_for_24ghz() - Enables/disables vendor vht for 24ghz
  1546. * @psoc: psoc context
  1547. * @value: data to be set
  1548. *
  1549. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1550. * ignore_peer_ht_opmode flag value
  1551. *
  1552. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1553. */
  1554. static inline QDF_STATUS
  1555. ucfg_mlme_get_vendor_vht_for_24ghz(struct wlan_objmgr_psoc *psoc, bool *value)
  1556. {
  1557. return wlan_mlme_get_vendor_vht_for_24ghz(psoc, value);
  1558. }
  1559. /**
  1560. * ucfg_mlme_update_vht_cap() - Update vht capabilities
  1561. * @psoc: psoc context
  1562. * @value: data to be set
  1563. *
  1564. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1565. * ignore_peer_ht_opmode flag value
  1566. *
  1567. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1568. */
  1569. static inline QDF_STATUS
  1570. ucfg_mlme_update_vht_cap(struct wlan_objmgr_psoc *psoc,
  1571. struct wma_tgt_vht_cap *cfg)
  1572. {
  1573. return mlme_update_vht_cap(psoc, cfg);
  1574. }
  1575. /**
  1576. * ucfg_mlme_update_nss_vht_cap() -Update the number of spatial
  1577. * streams supported for vht
  1578. * @psoc: psoc context
  1579. * @value: data to be set
  1580. *
  1581. * Inline UCFG API to be used by HDD/OSIF callers to get the
  1582. * ignore_peer_ht_opmode flag value
  1583. *
  1584. * Return: QDF_STATUS_SUCCESS or QDF_STATUS_FAILURE
  1585. */
  1586. static inline QDF_STATUS
  1587. ucfg_mlme_update_nss_vht_cap(struct wlan_objmgr_psoc *psoc)
  1588. {
  1589. return mlme_update_nss_vht_cap(psoc);
  1590. }
  1591. /**
  1592. * ucfg_mlme_get_opr_rate_set() - Get operational rate set
  1593. * @psoc: pointer to psoc object
  1594. * @buf: buffer to get rates set
  1595. * @len: length of the buffer
  1596. * Return: QDF Status
  1597. */
  1598. QDF_STATUS
  1599. ucfg_mlme_get_opr_rate_set(struct wlan_objmgr_psoc *psoc, uint8_t *buf,
  1600. qdf_size_t *len);
  1601. /**
  1602. * ucfg_mlme_get_ext_opr_rate_set() - Get operational rate set
  1603. * @psoc: pointer to psoc object
  1604. * @buf: buffer to get rates set
  1605. * @len: length of the buffer
  1606. * Return: QDF Status
  1607. */
  1608. QDF_STATUS
  1609. ucfg_mlme_get_ext_opr_rate_set(struct wlan_objmgr_psoc *psoc, uint8_t *buf,
  1610. qdf_size_t *len);
  1611. /**
  1612. * ucfg_mlme_get_supported_mcs_set() - Get Supported MCS set
  1613. * @psoc: pointer to psoc object
  1614. * @buf: caller buffer to copy mcs set info
  1615. * @len: length of the buffer
  1616. * Return: QDF Status
  1617. */
  1618. QDF_STATUS
  1619. ucfg_mlme_get_supported_mcs_set(struct wlan_objmgr_psoc *psoc, uint8_t *buf,
  1620. qdf_size_t *len);
  1621. /**
  1622. * ucfg_mlme_set_supported_mcs_set() - Get Supported MCS set
  1623. * @psoc: pointer to psoc object
  1624. * @buf: caller buffer having mcs set info
  1625. * @len: length of the buffer
  1626. * Return: QDF Status
  1627. */
  1628. QDF_STATUS
  1629. ucfg_mlme_set_supported_mcs_set(struct wlan_objmgr_psoc *psoc, uint8_t *buf,
  1630. qdf_size_t len);
  1631. /**
  1632. * ucfg_mlme_get_current_mcs_set() - Get current MCS set
  1633. * @psoc: pointer to psoc object
  1634. * @buf: caller buffer to copy mcs set info
  1635. * @len: length of the buffer
  1636. * Return: QDF Status
  1637. */
  1638. QDF_STATUS
  1639. ucfg_mlme_get_current_mcs_set(struct wlan_objmgr_psoc *psoc, uint8_t *buf,
  1640. qdf_size_t *len);
  1641. /**
  1642. * ucfg_mlme_get_wmm_dir_ac_vi() - Get TSPEC direction
  1643. * for VI
  1644. * @psoc: pointer to psoc object
  1645. * @value: Value that needs to be set from the caller
  1646. *
  1647. * Inline UCFG API to be used by HDD/OSIF callers
  1648. *
  1649. * Return: QDF Status
  1650. */
  1651. static inline QDF_STATUS
  1652. ucfg_mlme_get_wmm_dir_ac_vi(struct wlan_objmgr_psoc *psoc,
  1653. uint8_t *value)
  1654. {
  1655. return wlan_mlme_get_wmm_dir_ac_vi(psoc, value);
  1656. }
  1657. /**
  1658. * ucfg_mlme_get_wmm_nom_msdu_size_ac_vi() - Get normal
  1659. * MSDU size for VI
  1660. * @psoc: pointer to psoc object
  1661. * @value: Value that needs to be set from the caller
  1662. *
  1663. * Inline UCFG API to be used by HDD/OSIF callers
  1664. *
  1665. * Return: QDF Status
  1666. */
  1667. static inline QDF_STATUS
  1668. ucfg_mlme_get_wmm_nom_msdu_size_ac_vi(struct wlan_objmgr_psoc *psoc,
  1669. uint16_t *value)
  1670. {
  1671. return wlan_mlme_get_wmm_nom_msdu_size_ac_vi(psoc, value);
  1672. }
  1673. /**
  1674. * ucfg_mlme_get_wmm_mean_data_rate_ac_vi() - mean data
  1675. * rate for VI
  1676. * @psoc: pointer to psoc object
  1677. * @value: Value that needs to be set from the caller
  1678. *
  1679. * Inline UCFG API to be used by HDD/OSIF callers
  1680. *
  1681. * Return: QDF Status
  1682. */
  1683. static inline QDF_STATUS
  1684. ucfg_mlme_get_wmm_mean_data_rate_ac_vi(struct wlan_objmgr_psoc *psoc,
  1685. uint32_t *value)
  1686. {
  1687. return wlan_mlme_get_wmm_mean_data_rate_ac_vi(psoc, value);
  1688. }
  1689. /**
  1690. * ucfg_mlme_get_wmm_min_phy_rate_ac_vi() - min PHY
  1691. * rate for VI
  1692. * @psoc: pointer to psoc object
  1693. * @value: Value that needs to be set from the caller
  1694. *
  1695. * Inline UCFG API to be used by HDD/OSIF callers
  1696. *
  1697. * Return: QDF Status
  1698. */
  1699. static inline QDF_STATUS
  1700. ucfg_mlme_get_wmm_min_phy_rate_ac_vi(struct wlan_objmgr_psoc *psoc,
  1701. uint32_t *value)
  1702. {
  1703. return wlan_mlme_get_wmm_min_phy_rate_ac_vi(psoc, value);
  1704. }
  1705. /**
  1706. * ucfg_mlme_get_wmm_sba_ac_vi() - surplus bandwidth
  1707. * allowance for VI
  1708. * @psoc: pointer to psoc object
  1709. * @value: Value that needs to be set from the caller
  1710. *
  1711. * Inline UCFG API to be used by HDD/OSIF callers
  1712. *
  1713. * Return: QDF Status
  1714. */
  1715. static inline QDF_STATUS
  1716. ucfg_mlme_get_wmm_sba_ac_vi(struct wlan_objmgr_psoc *psoc, uint16_t *value)
  1717. {
  1718. return wlan_mlme_get_wmm_sba_ac_vi(psoc, value);
  1719. }
  1720. /**
  1721. * ucfg_mlme_get_wmm_uapsd_vi_srv_intv() - Get Uapsd service
  1722. * interval for video
  1723. * @psoc: pointer to psoc object
  1724. * @value: pointer to the value which will be filled for the caller
  1725. *
  1726. * Inline UCFG API to be used by HDD/OSIF callers
  1727. *
  1728. * Return: QDF Status
  1729. */
  1730. static inline QDF_STATUS
  1731. ucfg_mlme_get_wmm_uapsd_vi_srv_intv(struct wlan_objmgr_psoc *psoc,
  1732. uint32_t *value)
  1733. {
  1734. return wlan_mlme_get_wmm_uapsd_vi_srv_intv(psoc, value);
  1735. }
  1736. /**
  1737. * ucfg_mlme_get_wmm_uapsd_vi_sus_intv() - Get Uapsd suspension
  1738. * interval for video
  1739. * @psoc: pointer to psoc object
  1740. * @value: Value that needs to be set from the caller
  1741. *
  1742. * Inline UCFG API to be used by HDD/OSIF callers
  1743. *
  1744. * Return: QDF Status
  1745. */
  1746. static inline QDF_STATUS
  1747. ucfg_mlme_get_wmm_uapsd_vi_sus_intv(struct wlan_objmgr_psoc *psoc,
  1748. uint32_t *value)
  1749. {
  1750. return wlan_mlme_get_wmm_uapsd_vi_sus_intv(psoc, value);
  1751. }
  1752. /**
  1753. * ucfg_mlme_get_wmm_dir_ac_be() - Get TSPEC direction
  1754. * for BE
  1755. * @psoc: pointer to psoc object
  1756. * @value: Value that needs to be set from the caller
  1757. *
  1758. * Inline UCFG API to be used by HDD/OSIF callers
  1759. *
  1760. * Return: QDF Status
  1761. */
  1762. static inline QDF_STATUS
  1763. ucfg_mlme_get_wmm_dir_ac_be(struct wlan_objmgr_psoc *psoc, uint8_t *value)
  1764. {
  1765. return wlan_mlme_get_wmm_dir_ac_be(psoc, value);
  1766. }
  1767. /**
  1768. * ucfg_mlme_get_wmm_nom_msdu_size_ac_be() - Get normal
  1769. * MSDU size for BE
  1770. * @psoc: pointer to psoc object
  1771. * @value: Value that needs to be set from the caller
  1772. *
  1773. * Inline UCFG API to be used by HDD/OSIF callers
  1774. *
  1775. * Return: QDF Status
  1776. */
  1777. static inline QDF_STATUS
  1778. ucfg_mlme_get_wmm_nom_msdu_size_ac_be(struct wlan_objmgr_psoc *psoc,
  1779. uint16_t *value)
  1780. {
  1781. return wlan_mlme_get_wmm_nom_msdu_size_ac_be(psoc, value);
  1782. }
  1783. /**
  1784. * ucfg_mlme_get_wmm_mean_data_rate_ac_be() - mean data
  1785. * rate for BE
  1786. * @psoc: pointer to psoc object
  1787. * @value: Value that needs to be set from the caller
  1788. *
  1789. * Inline UCFG API to be used by HDD/OSIF callers
  1790. *
  1791. * Return: QDF Status
  1792. */
  1793. static inline QDF_STATUS
  1794. ucfg_mlme_get_wmm_mean_data_rate_ac_be(struct wlan_objmgr_psoc *psoc,
  1795. uint32_t *value)
  1796. {
  1797. return wlan_mlme_get_wmm_mean_data_rate_ac_be(psoc, value);
  1798. }
  1799. /**
  1800. * ucfg_mlme_get_wmm_min_phy_rate_ac_be() - min PHY
  1801. * rate for BE
  1802. * @psoc: pointer to psoc object
  1803. * @value: Value that needs to be set from the caller
  1804. *
  1805. * Inline UCFG API to be used by HDD/OSIF callers
  1806. *
  1807. * Return: QDF Status
  1808. */
  1809. static inline QDF_STATUS
  1810. ucfg_mlme_get_wmm_min_phy_rate_ac_be(struct wlan_objmgr_psoc *psoc,
  1811. uint32_t *value)
  1812. {
  1813. return wlan_mlme_get_wmm_min_phy_rate_ac_be(psoc, value);
  1814. }
  1815. /**
  1816. * ucfg_mlme_get_wmm_sba_ac_be() - surplus bandwidth
  1817. * allowance for BE
  1818. * @psoc: pointer to psoc object
  1819. * @value: Value that needs to be set from the caller
  1820. *
  1821. * Inline UCFG API to be used by HDD/OSIF callers
  1822. *
  1823. * Return: QDF Status
  1824. */
  1825. static inline QDF_STATUS
  1826. ucfg_mlme_get_wmm_sba_ac_be(struct wlan_objmgr_psoc *psoc, uint16_t *value)
  1827. {
  1828. return wlan_mlme_get_wmm_sba_ac_be(psoc, value);
  1829. }
  1830. /**
  1831. * ucfg_mlme_get_wmm_uapsd_be_srv_intv() - Get Uapsd service
  1832. * interval for BE
  1833. * @psoc: pointer to psoc object
  1834. * @value: pointer to the value which will be filled for the caller
  1835. *
  1836. * Inline UCFG API to be used by HDD/OSIF callers
  1837. *
  1838. * Return: QDF Status
  1839. */
  1840. static inline QDF_STATUS
  1841. ucfg_mlme_get_wmm_uapsd_be_srv_intv(struct wlan_objmgr_psoc *psoc,
  1842. uint32_t *value)
  1843. {
  1844. return wlan_mlme_get_wmm_uapsd_be_srv_intv(psoc, value);
  1845. }
  1846. /**
  1847. * ucfg_mlme_get_wmm_uapsd_be_sus_intv() - Get Uapsd suspension
  1848. * interval for BE
  1849. * @psoc: pointer to psoc object
  1850. * @value: Value that needs to be set from the caller
  1851. *
  1852. * Inline UCFG API to be used by HDD/OSIF callers
  1853. *
  1854. * Return: QDF Status
  1855. */
  1856. static inline QDF_STATUS
  1857. ucfg_mlme_get_wmm_uapsd_be_sus_intv(struct wlan_objmgr_psoc *psoc,
  1858. uint32_t *value)
  1859. {
  1860. return wlan_mlme_get_wmm_uapsd_be_sus_intv(psoc, value);
  1861. }
  1862. /**
  1863. * ucfg_mlme_get_wmm_dir_ac_bk() - Get TSPEC direction
  1864. * for BK
  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 QDF_STATUS
  1873. ucfg_mlme_get_wmm_dir_ac_bk(struct wlan_objmgr_psoc *psoc, uint8_t *value)
  1874. {
  1875. return wlan_mlme_get_wmm_dir_ac_bk(psoc, value);
  1876. }
  1877. /**
  1878. * ucfg_mlme_get_wmm_nom_msdu_size_ac_be() - Get normal
  1879. * MSDU size for BE
  1880. * @psoc: pointer to psoc object
  1881. * @value: Value that needs to be set from the caller
  1882. *
  1883. * Inline UCFG API to be used by HDD/OSIF callers
  1884. *
  1885. * Return: QDF Status
  1886. */
  1887. static inline QDF_STATUS
  1888. ucfg_mlme_get_wmm_nom_msdu_size_ac_bk(struct wlan_objmgr_psoc *psoc,
  1889. uint16_t *value)
  1890. {
  1891. return wlan_mlme_get_wmm_nom_msdu_size_ac_bk(psoc, value);
  1892. }
  1893. /**
  1894. * ucfg_mlme_get_wmm_mean_data_rate_ac_bk() - mean data
  1895. * rate for BK
  1896. * @psoc: pointer to psoc object
  1897. * @value: Value that needs to be set from the caller
  1898. *
  1899. * Inline UCFG API to be used by HDD/OSIF callers
  1900. *
  1901. * Return: QDF Status
  1902. */
  1903. static inline QDF_STATUS
  1904. ucfg_mlme_get_wmm_mean_data_rate_ac_bk(struct wlan_objmgr_psoc *psoc,
  1905. uint32_t *value)
  1906. {
  1907. return wlan_mlme_get_wmm_mean_data_rate_ac_bk(psoc, value);
  1908. }
  1909. /**
  1910. * ucfg_mlme_get_wmm_min_phy_rate_ac_bk() - min PHY
  1911. * rate for BE
  1912. * @psoc: pointer to psoc object
  1913. * @value: Value that needs to be set from the caller
  1914. *
  1915. * Inline UCFG API to be used by HDD/OSIF callers
  1916. *
  1917. * Return: QDF Status
  1918. */
  1919. static inline QDF_STATUS
  1920. ucfg_mlme_get_wmm_min_phy_rate_ac_bk(struct wlan_objmgr_psoc *psoc,
  1921. uint32_t *value)
  1922. {
  1923. return wlan_mlme_get_wmm_min_phy_rate_ac_bk(psoc, value);
  1924. }
  1925. /**
  1926. * ucfg_mlme_get_wmm_sba_ac_bk() - surplus bandwidth
  1927. * allowance for BE
  1928. * @psoc: pointer to psoc object
  1929. * @value: Value that needs to be set from the caller
  1930. *
  1931. * Inline UCFG API to be used by HDD/OSIF callers
  1932. *
  1933. * Return: QDF Status
  1934. */
  1935. static inline QDF_STATUS
  1936. ucfg_mlme_get_wmm_sba_ac_bk(struct wlan_objmgr_psoc *psoc, uint16_t *value)
  1937. {
  1938. return wlan_mlme_get_wmm_sba_ac_bk(psoc, value);
  1939. }
  1940. /**
  1941. * ucfg_mlme_get_wmm_uapsd_bk_srv_intv() - Get Uapsd service
  1942. * interval for BK
  1943. * @psoc: pointer to psoc object
  1944. * @value: pointer to the value which will be filled for the caller
  1945. *
  1946. * Inline UCFG API to be used by HDD/OSIF callers
  1947. *
  1948. * Return: QDF Status
  1949. */
  1950. static inline QDF_STATUS
  1951. ucfg_mlme_get_wmm_uapsd_bk_srv_intv(struct wlan_objmgr_psoc *psoc,
  1952. uint32_t *value)
  1953. {
  1954. return wlan_mlme_get_wmm_uapsd_bk_srv_intv(psoc, value);
  1955. }
  1956. /**
  1957. * ucfg_mlme_get_wmm_uapsd_bk_sus_intv() - Get Uapsd suspension
  1958. * interval for BK
  1959. * @psoc: pointer to psoc object
  1960. * @value: Value that needs to be set from the caller
  1961. *
  1962. * Inline UCFG API to be used by HDD/OSIF callers
  1963. *
  1964. * Return: QDF Status
  1965. */
  1966. static inline QDF_STATUS
  1967. ucfg_mlme_get_wmm_uapsd_bk_sus_intv(struct wlan_objmgr_psoc *psoc,
  1968. uint32_t *value)
  1969. {
  1970. return wlan_mlme_get_wmm_uapsd_bk_sus_intv(psoc, value);
  1971. }
  1972. /**
  1973. * ucfg_mlme_get_wmm_mode() - Enable WMM feature
  1974. * @psoc: pointer to psoc object
  1975. * @value: Value that needs to be set from the caller
  1976. *
  1977. * Inline UCFG API to be used by HDD/OSIF callers
  1978. *
  1979. * Return: QDF Status
  1980. */
  1981. static inline QDF_STATUS
  1982. ucfg_mlme_get_wmm_mode(struct wlan_objmgr_psoc *psoc, uint8_t *value)
  1983. {
  1984. return wlan_mlme_get_wmm_mode(psoc, value);
  1985. }
  1986. /**
  1987. * ucfg_mlme_get_80211e_is_enabled() - Enable 802.11e feature
  1988. * @psoc: pointer to psoc object
  1989. * @value: Value that needs to be set from the caller
  1990. *
  1991. * Inline UCFG API to be used by HDD/OSIF callers
  1992. *
  1993. * Return: QDF Status
  1994. */
  1995. static inline QDF_STATUS
  1996. ucfg_mlme_get_80211e_is_enabled(struct wlan_objmgr_psoc *psoc, bool *value)
  1997. {
  1998. return wlan_mlme_get_80211e_is_enabled(psoc, value);
  1999. }
  2000. /**
  2001. * ucfg_mlme_get_wmm_uapsd_mask() - setup U-APSD mask for ACs
  2002. * @psoc: pointer to psoc object
  2003. * @value: Value that needs to be set from the caller
  2004. *
  2005. * Inline UCFG API to be used by HDD/OSIF callers
  2006. *
  2007. * Return: QDF Status
  2008. */
  2009. static inline QDF_STATUS
  2010. ucfg_mlme_get_wmm_uapsd_mask(struct wlan_objmgr_psoc *psoc, uint8_t *value)
  2011. {
  2012. return wlan_mlme_get_wmm_uapsd_mask(psoc, value);
  2013. }
  2014. /**
  2015. * ucfg_mlme_get_implicit_qos_is_enabled() - Enable implicit QOS
  2016. * @psoc: pointer to psoc object
  2017. * @value: Value that needs to be set from the caller
  2018. *
  2019. * Inline UCFG API to be used by HDD/OSIF callers
  2020. *
  2021. * Return: QDF Status
  2022. */
  2023. static inline QDF_STATUS
  2024. ucfg_mlme_get_implicit_qos_is_enabled(struct wlan_objmgr_psoc *psoc,
  2025. bool *value)
  2026. {
  2027. return wlan_mlme_get_implicit_qos_is_enabled(psoc, value);
  2028. }
  2029. #endif /* _WLAN_MLME_UCFG_API_H_ */