wlan_pmo_ucfg_api.h 42 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756
  1. /*
  2. * Copyright (c) 2017-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 public API related to the pmo called by north bound HDD/OSIF
  20. */
  21. #ifndef _WLAN_PMO_UCFG_API_H_
  22. #define _WLAN_PMO_UCFG_API_H_
  23. #include "wlan_pmo_arp_public_struct.h"
  24. #include "wlan_pmo_ns_public_struct.h"
  25. #include "wlan_pmo_gtk_public_struct.h"
  26. #include "wlan_pmo_mc_addr_filtering.h"
  27. #include "wlan_pmo_mc_addr_filtering_public_struct.h"
  28. #include "wlan_pmo_wow_public_struct.h"
  29. #include "wlan_pmo_common_public_struct.h"
  30. #include "wlan_pmo_obj_mgmt_api.h"
  31. #include "wlan_pmo_pkt_filter_public_struct.h"
  32. #include "wlan_pmo_hw_filter_public_struct.h"
  33. #ifdef WLAN_POWER_MANAGEMENT_OFFLOAD
  34. /**
  35. * ucfg_pmo_psoc_open() - pmo psoc object open
  36. * @psoc: objmgr vdev
  37. *.
  38. * This function used to open pmo psoc object by user space
  39. *
  40. * Return: true in case success else false
  41. */
  42. QDF_STATUS ucfg_pmo_psoc_open(struct wlan_objmgr_psoc *psoc);
  43. /**
  44. * ucfg_pmo_psoc_open() - pmo psoc object close
  45. * @psoc: objmgr vdev
  46. *.
  47. * This function used to close pmo psoc object by user space
  48. *
  49. * Return: true in case success else false
  50. */
  51. QDF_STATUS ucfg_pmo_psoc_close(struct wlan_objmgr_psoc *psoc);
  52. /**
  53. * ucfg_pmo_get_apf_instruction_size() - get the current APF instruction size
  54. * @psoc: the psoc to query
  55. *
  56. * Return: APF instruction size
  57. */
  58. uint32_t ucfg_pmo_get_apf_instruction_size(struct wlan_objmgr_psoc *psoc);
  59. /**
  60. * ucfg_pmo_get_num_wow_filters() - get the supported number of WoW filters
  61. * @psoc: the psoc to query
  62. *
  63. * Return: number of WoW filters supported
  64. */
  65. uint8_t ucfg_pmo_get_num_wow_filters(struct wlan_objmgr_psoc *psoc);
  66. /**
  67. * ucfg_pmo_is_ap_mode_supports_arp_ns() - Check ap mode support arp&ns offload
  68. * @psoc: objmgr psoc
  69. * @vdev_opmode: vdev opmode
  70. *
  71. * Return: true in case support else false
  72. */
  73. bool ucfg_pmo_is_ap_mode_supports_arp_ns(struct wlan_objmgr_psoc *psoc,
  74. enum QDF_OPMODE vdev_opmode);
  75. /**
  76. * ucfg_pmo_is_vdev_connected() - to check whether peer is associated or not
  77. * @vdev: objmgr vdev
  78. *
  79. * Return: true in case success else false
  80. */
  81. bool ucfg_pmo_is_vdev_connected(struct wlan_objmgr_vdev *vdev);
  82. /**
  83. * ucfg_pmo_is_vdev_supports_offload() - check offload is supported on vdev
  84. * @vdev: objmgr vdev
  85. *
  86. * Return: true in case success else false
  87. */
  88. bool ucfg_pmo_is_vdev_supports_offload(struct wlan_objmgr_vdev *vdev);
  89. /**
  90. * ucfg_pmo_get_psoc_config(): API to get the psoc user configurations of pmo
  91. * @psoc: objmgr psoc handle
  92. * @psoc_cfg: fill the current psoc user configurations.
  93. *
  94. * Return pmo psoc configurations
  95. */
  96. QDF_STATUS ucfg_pmo_get_psoc_config(struct wlan_objmgr_psoc *psoc,
  97. struct pmo_psoc_cfg *psoc_cfg);
  98. /**
  99. * ucfg_pmo_update_psoc_config(): API to update the psoc user configurations
  100. * @psoc: objmgr psoc handle
  101. * @psoc_cfg: pmo psoc configurations
  102. *
  103. * This api shall be used for soc config initialization as well update.
  104. * In case of update caller must first call pmo_get_psoc_cfg to get
  105. * current config and then apply changes on top of current config.
  106. *
  107. * Return QDF_STATUS -in case of success else return error
  108. */
  109. QDF_STATUS ucfg_pmo_update_psoc_config(struct wlan_objmgr_psoc *psoc,
  110. struct pmo_psoc_cfg *psoc_cfg);
  111. /**
  112. * ucfg_pmo_psoc_set_caps() - overwrite configured device capability flags
  113. * @psoc: the psoc for which the capabilities apply
  114. * @caps: the cabability information to configure
  115. *
  116. * Return: QDF_STATUS
  117. */
  118. QDF_STATUS ucfg_pmo_psoc_set_caps(struct wlan_objmgr_psoc *psoc,
  119. struct pmo_device_caps *caps);
  120. /**
  121. * ucfg_pmo_is_arp_offload_enabled() - Get arp offload enable or not
  122. * @psoc: pointer to psoc object
  123. *
  124. * Return: arp offload enable or not
  125. */
  126. bool
  127. ucfg_pmo_is_arp_offload_enabled(struct wlan_objmgr_psoc *psoc);
  128. /**
  129. * ucfg_pmo_set_arp_offload_enabled() - Set arp offload enable or not
  130. * @psoc: pointer to psoc object
  131. * @val: enable/disable arp offload
  132. *
  133. * Return: None
  134. */
  135. void
  136. ucfg_pmo_set_arp_offload_enabled(struct wlan_objmgr_psoc *psoc,
  137. bool val);
  138. /**
  139. * ucfg_pmo_is_ssdp_enabled() - Get ssdp enable or not
  140. * @psoc: pointer to psoc object
  141. *
  142. * Return: enable/disable ssdp
  143. */
  144. bool
  145. ucfg_pmo_is_ssdp_enabled(struct wlan_objmgr_psoc *psoc);
  146. /**
  147. * ucfg_pmo_is_ns_offloaded() - Get ns offload support or not
  148. * @psoc: pointer to psoc object
  149. *
  150. * Return: ns offload or not
  151. */
  152. bool
  153. ucfg_pmo_is_ns_offloaded(struct wlan_objmgr_psoc *psoc);
  154. /**
  155. * ucfg_pmo_get_sta_dynamic_dtim() - Get dynamic dtim
  156. * @psoc: pointer to psoc object
  157. *
  158. * Return: dynamic dtim
  159. */
  160. uint8_t
  161. ucfg_pmo_get_sta_dynamic_dtim(struct wlan_objmgr_psoc *psoc);
  162. /**
  163. * ucfg_pmo_get_sta_mod_dtim() - Get modulated dtim
  164. * @psoc: pointer to psoc object
  165. *
  166. * Return: modulated dtim
  167. */
  168. uint8_t
  169. ucfg_pmo_get_sta_mod_dtim(struct wlan_objmgr_psoc *psoc);
  170. /**
  171. * ucfg_pmo_set_sta_mod_dtim() - Set modulated dtim
  172. * @psoc: pointer to psoc object
  173. * @val: modulated dtim
  174. *
  175. * Return: None
  176. */
  177. void
  178. ucfg_pmo_set_sta_mod_dtim(struct wlan_objmgr_psoc *psoc,
  179. uint8_t val);
  180. /**
  181. * ucfg_pmo_is_mc_addr_list_enabled() - Get multicast address list enable or not
  182. * @psoc: pointer to psoc object
  183. *
  184. * Return: multicast address list enable or not
  185. */
  186. bool
  187. ucfg_pmo_is_mc_addr_list_enabled(struct wlan_objmgr_psoc *psoc);
  188. /**
  189. * ucfg_pmo_get_power_save_mode() - Get power save mode
  190. * @psoc: pointer to psoc object
  191. *
  192. * Return: power save mode
  193. */
  194. enum powersave_mode
  195. ucfg_pmo_get_power_save_mode(struct wlan_objmgr_psoc *psoc);
  196. /**
  197. * ucfg_pmo_set_power_save_mode() - Set power save mode
  198. * @psoc: pointer to psoc object
  199. * @val: power save mode
  200. *
  201. * Return: None
  202. */
  203. void
  204. ucfg_pmo_set_power_save_mode(struct wlan_objmgr_psoc *psoc,
  205. enum powersave_mode val);
  206. /**
  207. * ucfg_pmo_get_max_ps_poll() - Get max power save poll
  208. * @psoc: pointer to psoc object
  209. *
  210. * Return: power save poll
  211. */
  212. uint8_t
  213. ucfg_pmo_get_max_ps_poll(struct wlan_objmgr_psoc *psoc);
  214. /**
  215. * ucfg_pmo_power_save_offload_enabled() - Get power save offload enabled type
  216. * @psoc: pointer to psoc object
  217. *
  218. * Return: power save offload enabled type
  219. */
  220. uint8_t
  221. ucfg_pmo_power_save_offload_enabled(struct wlan_objmgr_psoc *psoc);
  222. /**
  223. * pmo_ucfg_enable_wakeup_event() - enable wow wakeup events
  224. * @psoc: objmgr psoc
  225. * @vdev_id: vdev id
  226. * @wow_event: wow event to enable
  227. *
  228. * Return: none
  229. */
  230. void pmo_ucfg_enable_wakeup_event(struct wlan_objmgr_psoc *psoc,
  231. uint32_t vdev_id,
  232. WOW_WAKE_EVENT_TYPE wow_event);
  233. /**
  234. * pmo_ucfg_disable_wakeup_event() - disable wow wakeup events
  235. * @psoc: objmgr psoc
  236. * @vdev_id: vdev id
  237. * @wow_event: wow event to disable
  238. *
  239. * Return: none
  240. */
  241. void pmo_ucfg_disable_wakeup_event(struct wlan_objmgr_psoc *psoc,
  242. uint32_t vdev_id,
  243. WOW_WAKE_EVENT_TYPE wow_event);
  244. /**
  245. * pmo_ucfg_cache_arp_offload_req(): API to cache arp req in pmo vdev priv ctx
  246. * @arp_req: pmo arp req param
  247. *
  248. * Return QDF_STATUS -in case of success else return error
  249. */
  250. QDF_STATUS pmo_ucfg_cache_arp_offload_req(struct pmo_arp_req *arp_req);
  251. /**
  252. * pmo_ucfg_flush_arp_offload_req(): API to flush arp req from pmo vdev priv ctx
  253. * @vdev: objmgr vdev param
  254. *
  255. * Return QDF_STATUS -in case of success else return error
  256. */
  257. QDF_STATUS pmo_ucfg_flush_arp_offload_req(struct wlan_objmgr_vdev *vdev);
  258. /**
  259. * pmo_ucfg_enable_arp_offload_in_fwr(): API to enable arp req in fwr
  260. * @vdev: objmgr vdev param
  261. * @trigger: triger reason for enable arp offload
  262. *
  263. * API to enable cache arp req in fwr from pmo vdev priv ctx
  264. *
  265. * Return QDF_STATUS -in case of success else return error
  266. */
  267. QDF_STATUS pmo_ucfg_enable_arp_offload_in_fwr(struct wlan_objmgr_vdev *vdev,
  268. enum pmo_offload_trigger trigger);
  269. /**
  270. * pmo_ucfg_disable_arp_offload_in_fwr(): API to disable arp req in fwr
  271. * @vdev: objmgr vdev param
  272. * @trigger: triger reason for disable arp offload
  273. * API to disable cache arp req in fwr
  274. *
  275. * Return QDF_STATUS -in case of success else return error
  276. */
  277. QDF_STATUS pmo_ucfg_disable_arp_offload_in_fwr(struct wlan_objmgr_vdev *vdev,
  278. enum pmo_offload_trigger trigger);
  279. /**
  280. * pmo_ucfg_get_arp_offload_params() - API to get arp offload params
  281. * @vdev: objmgr vdev
  282. * @params: output pointer to hold offload params
  283. *
  284. * Return: QDF_STATUS_SUCCESS in case of success else return error
  285. */
  286. QDF_STATUS
  287. pmo_ucfg_get_arp_offload_params(struct wlan_objmgr_vdev *vdev,
  288. struct pmo_arp_offload_params *params);
  289. /**
  290. * pmo_ucfg_cache_ns_offload_req(): API to cache ns req in pmo vdev priv ctx
  291. * @ns_req: pmo ns req param
  292. *
  293. * Return QDF_STATUS -in case of success else return error
  294. */
  295. QDF_STATUS pmo_ucfg_cache_ns_offload_req(struct pmo_ns_req *ns_req);
  296. /**
  297. * pmo_ucfg_flush_ns_offload_req(): API to flush ns req from pmo vdev priv ctx
  298. * @vdev: vdev ojbmgr handle
  299. *
  300. * Return QDF_STATUS -in case of success else return error
  301. */
  302. QDF_STATUS pmo_ucfg_flush_ns_offload_req(struct wlan_objmgr_vdev *vdev);
  303. /**
  304. * pmo_ucfg_enable_ns_offload_in_fwr(): API to enable ns req in fwr
  305. * @arp_req: pmo arp req param
  306. * @trigger: trigger reason to enable ns offload
  307. *
  308. * API to enable cache ns req in fwr from pmo vdev priv ctx
  309. *
  310. * Return QDF_STATUS -in case of success else return error
  311. */
  312. QDF_STATUS pmo_ucfg_enable_ns_offload_in_fwr(struct wlan_objmgr_vdev *vdev,
  313. enum pmo_offload_trigger trigger);
  314. /**
  315. * pmo_ucfg_disable_ns_offload_in_fwr(): API to disable ns req in fwr
  316. * @arp_req: pmo arp req param
  317. * @trigger: trigger reason to disable ns offload
  318. *
  319. * API to disable ns req in fwr
  320. *
  321. * Return QDF_STATUS -in case of success else return error
  322. */
  323. QDF_STATUS pmo_ucfg_disable_ns_offload_in_fwr(struct wlan_objmgr_vdev *vdev,
  324. enum pmo_offload_trigger trigger);
  325. /**
  326. * pmo_ucfg_get_ns_offload_params() - API to get ns offload params
  327. * @vdev: objmgr vdev
  328. * @params: output pointer to hold offload params
  329. *
  330. * Return: QDF_STATUS_SUCCESS in case of success else return error
  331. */
  332. QDF_STATUS
  333. pmo_ucfg_get_ns_offload_params(struct wlan_objmgr_vdev *vdev,
  334. struct pmo_ns_offload_params *params);
  335. /**
  336. * pmo_ucfg_ns_addr_scope() - Convert linux specific IPv6 addr scope to
  337. * WLAN driver specific value
  338. * @scope: linux specific IPv6 addr scope
  339. *
  340. * Return: PMO identifier of linux IPv6 addr scope
  341. */
  342. enum pmo_ns_addr_scope
  343. pmo_ucfg_ns_addr_scope(uint32_t ipv6_scope);
  344. /**
  345. * pmo_ucfg_enable_hw_filter_in_fwr() - enable previously configured hw filter
  346. * @vdev: objmgr vdev to configure
  347. *
  348. * Return: QDF_STATUS
  349. */
  350. QDF_STATUS pmo_ucfg_enable_hw_filter_in_fwr(struct wlan_objmgr_vdev *vdev);
  351. /**
  352. * pmo_ucfg_disable_hw_filter_in_fwr() - disable previously configured hw filter
  353. * @vdev: objmgr vdev to configure
  354. *
  355. * Return: QDF_STATUS
  356. */
  357. QDF_STATUS pmo_ucfg_disable_hw_filter_in_fwr(struct wlan_objmgr_vdev *vdev);
  358. /**
  359. * pmo_ucfg_max_mc_addr_supported() - to get max support mc address
  360. * @psoc: objmgr psoc
  361. *
  362. * Return: max mc addr supported count for all vdev in corresponding psoc
  363. */
  364. uint8_t pmo_ucfg_max_mc_addr_supported(struct wlan_objmgr_psoc *psoc);
  365. /**
  366. * pmo_ucfg_cache_mc_addr_list(): API to cache mc addr list in pmo vdev priv obj
  367. * @psoc: objmgr psoc handle
  368. * @vdev_id: vdev id
  369. * @gtk_req: pmo gtk req param
  370. *
  371. * Return QDF_STATUS_SUCCESS -in case of success else return error
  372. */
  373. QDF_STATUS pmo_ucfg_cache_mc_addr_list(
  374. struct pmo_mc_addr_list_params *mc_list_config);
  375. /**
  376. * pmo_ucfg_flush_mc_addr_list(): API to flush mc addr list in pmo vdev priv obj
  377. * @psoc: objmgr psoc handle
  378. * @vdev_id: vdev id
  379. *
  380. * Return QDF_STATUS_SUCCESS -in case of success else return error
  381. */
  382. QDF_STATUS pmo_ucfg_flush_mc_addr_list(struct wlan_objmgr_psoc *psoc,
  383. uint8_t vdev_id);
  384. /**
  385. * pmo_ucfg_enhance_mc_filter_enable() - enable enhanced multicast filtering
  386. * @vdev: the vdev to enable enhanced multicast filtering for
  387. *
  388. * Return: QDF_STATUS
  389. */
  390. static inline QDF_STATUS
  391. pmo_ucfg_enhanced_mc_filter_enable(struct wlan_objmgr_vdev *vdev)
  392. {
  393. return pmo_core_enhanced_mc_filter_enable(vdev);
  394. }
  395. /**
  396. * pmo_ucfg_enhance_mc_filter_disable() - disable enhanced multicast filtering
  397. * @vdev: the vdev to disable enhanced multicast filtering for
  398. *
  399. * Return: QDF_STATUS
  400. */
  401. static inline QDF_STATUS
  402. pmo_ucfg_enhanced_mc_filter_disable(struct wlan_objmgr_vdev *vdev)
  403. {
  404. return pmo_core_enhanced_mc_filter_disable(vdev);
  405. }
  406. /**
  407. * pmo_ucfg_enable_mc_addr_filtering_in_fwr(): Enable cached mc add list in fwr
  408. * @psoc: objmgr psoc handle
  409. * @vdev_id: vdev id
  410. * @gtk_req: pmo gtk req param
  411. * @action: true for enable els false
  412. *
  413. * API to enable cached mc add list in fwr
  414. *
  415. * Return QDF_STATUS_SUCCESS -in case of success else return error
  416. */
  417. QDF_STATUS pmo_ucfg_enable_mc_addr_filtering_in_fwr(
  418. struct wlan_objmgr_psoc *psoc,
  419. uint8_t vdev_id,
  420. enum pmo_offload_trigger trigger);
  421. /**
  422. * pmo_ucfg_disable_mc_addr_filtering_in_fwr(): Disable cached mc addr list
  423. * @psoc: objmgr psoc handle
  424. * @vdev_id: vdev id
  425. * @gtk_req: pmo gtk req param
  426. * @action: true for enable els false
  427. *
  428. * API to disable cached mc add list in fwr
  429. *
  430. * Return QDF_STATUS_SUCCESS -in case of success else return error
  431. */
  432. QDF_STATUS pmo_ucfg_disable_mc_addr_filtering_in_fwr(
  433. struct wlan_objmgr_psoc *psoc,
  434. uint8_t vdev_id,
  435. enum pmo_offload_trigger trigger);
  436. /**
  437. * pmo_ucfg_get_mc_addr_list() - API to get mc addr list configured
  438. * @psoc: objmgr psoc
  439. * @vdev_id: vdev identifier
  440. * @mc_list_req: output pointer to hold mc addr list params
  441. *
  442. * Return: QDF_STATUS_SUCCESS in case of success else return error
  443. */
  444. QDF_STATUS
  445. pmo_ucfg_get_mc_addr_list(struct wlan_objmgr_psoc *psoc,
  446. uint8_t vdev_id,
  447. struct pmo_mc_addr_list *mc_list_req);
  448. /**
  449. * pmo_ucfg_cache_gtk_offload_req(): API to cache gtk req in pmo vdev priv obj
  450. * @vdev: objmgr vdev handle
  451. * @gtk_req: pmo gtk req param
  452. *
  453. * Return QDF_STATUS_SUCCESS -in case of success else return error
  454. */
  455. QDF_STATUS pmo_ucfg_cache_gtk_offload_req(struct wlan_objmgr_vdev *vdev,
  456. struct pmo_gtk_req *gtk_req);
  457. /**
  458. * pmo_ucfg_flush_gtk_offload_req(): Flush saved gtk req from pmo vdev priv obj
  459. * @vdev: objmgr vdev handle
  460. *
  461. * Return QDF_STATUS_SUCCESS -in case of success else return error
  462. */
  463. QDF_STATUS pmo_ucfg_flush_gtk_offload_req(struct wlan_objmgr_vdev *vdev);
  464. /**
  465. * pmo_ucfg_enable_gtk_offload_in_fwr(): enable cached gtk request in fwr
  466. * @vdev: objmgr vdev handle
  467. *
  468. * Return QDF_STATUS_SUCCESS -in case of success else return error
  469. */
  470. QDF_STATUS pmo_ucfg_enable_gtk_offload_in_fwr(struct wlan_objmgr_vdev *vdev);
  471. /**
  472. * pmo_ucfg_disable_gtk_offload_in_fwr(): disable cached gtk request in fwr
  473. * @vdev: objmgr vdev handle
  474. *
  475. * Return QDF_STATUS_SUCCESS -in case of success else return error
  476. */
  477. QDF_STATUS pmo_ucfg_disable_gtk_offload_in_fwr(struct wlan_objmgr_vdev *vdev);
  478. #ifdef WLAN_FEATURE_PACKET_FILTERING
  479. /**
  480. * ucfg_pmo_get_pkt_filter_bitmap() - get default packet filters bitmap
  481. * @psoc: the psoc to query
  482. *
  483. * Return: retrieve packet filter bitmap configuration
  484. */
  485. uint8_t ucfg_pmo_get_pkt_filter_bitmap(struct wlan_objmgr_psoc *psoc);
  486. /**
  487. * ucfg_pmo_get_num_packet_filters() - get the number of packet filters
  488. * @psoc: the psoc to query
  489. *
  490. * Return: number of packet filters
  491. */
  492. uint32_t ucfg_pmo_get_num_packet_filters(struct wlan_objmgr_psoc *psoc);
  493. /**
  494. * pmo_ucfg_set_pkt_filter() - Set packet filter
  495. * @psoc: objmgr psoc handle
  496. * @pmo_set_pkt_fltr_req:
  497. * @vdev_id: vdev id
  498. *
  499. * Return QDF_STATUS_SUCCESS -in case of success else return error
  500. */
  501. QDF_STATUS pmo_ucfg_set_pkt_filter(struct wlan_objmgr_psoc *psoc,
  502. struct pmo_rcv_pkt_fltr_cfg *pmo_set_pkt_fltr_req,
  503. uint8_t vdev_id);
  504. /**
  505. * pmo_ucfg_clear_pkt_filter() - Clear packet filter
  506. * @psoc: objmgr psoc handle
  507. * @pmo_clr_pkt_fltr_req:
  508. * @vdev_id: vdev id
  509. *
  510. * Return QDF_STATUS_SUCCESS -in case of success else return error
  511. */
  512. QDF_STATUS pmo_ucfg_clear_pkt_filter(struct wlan_objmgr_psoc *psoc,
  513. struct pmo_rcv_pkt_fltr_clear_param *pmo_clr_pkt_fltr_param,
  514. uint8_t vdev_id);
  515. #else
  516. static inline uint8_t
  517. ucfg_pmo_get_pkt_filter_bitmap(struct wlan_objmgr_psoc *psoc)
  518. {
  519. return 0;
  520. }
  521. static inline uint32_t
  522. ucfg_pmo_get_num_packet_filters(struct wlan_objmgr_psoc *psoc)
  523. {
  524. return 0;
  525. }
  526. static inline QDF_STATUS
  527. pmo_ucfg_set_pkt_filter(
  528. struct wlan_objmgr_psoc *psoc,
  529. struct pmo_rcv_pkt_fltr_cfg *pmo_set_pkt_fltr_req,
  530. uint8_t vdev_id)
  531. {
  532. return QDF_STATUS_SUCCESS;
  533. }
  534. static inline QDF_STATUS
  535. pmo_ucfg_clear_pkt_filter(
  536. struct wlan_objmgr_psoc *psoc,
  537. struct pmo_rcv_pkt_fltr_clear_param *pmo_clr_pkt_fltr_param,
  538. uint8_t vdev_id)
  539. {
  540. return QDF_STATUS_SUCCESS;
  541. }
  542. #endif
  543. /**
  544. * ucfg_pmo_get_wow_enable() - Get wow enable type
  545. * @psoc: pointer to psoc object
  546. *
  547. * Return: wow enable type
  548. */
  549. enum pmo_wow_enable_type
  550. ucfg_pmo_get_wow_enable(struct wlan_objmgr_psoc *psoc);
  551. /**
  552. * ucfg_pmo_set_wow_enable() - Set wow enable type
  553. * @psoc: pointer to psoc object
  554. * @val: wow enalbe value
  555. *
  556. * Return: None
  557. */
  558. void
  559. ucfg_pmo_set_wow_enable(struct wlan_objmgr_psoc *psoc,
  560. enum pmo_wow_enable_type val);
  561. /**
  562. * ucfg_pmo_is_wowlan_deauth_enabled() - Get wowlan deauth enable
  563. * @psoc: pointer to psoc object
  564. *
  565. * Return: wowlan deauth enable or not
  566. */
  567. bool
  568. ucfg_pmo_is_wowlan_deauth_enabled(struct wlan_objmgr_psoc *psoc);
  569. /**
  570. * ucfg_pmo_is_wowlan_disassoc_enabled() - Get wowlan disassoc enable
  571. * @psoc: pointer to psoc object
  572. *
  573. * Return: wowlan disassoc enable
  574. */
  575. bool
  576. ucfg_pmo_is_wowlan_disassoc_enabled(struct wlan_objmgr_psoc *psoc);
  577. /**
  578. * pmo_ucfg_get_gtk_rsp(): API to send gtk response request to fwr
  579. * @vdev: objmgr vdev handle
  580. * @gtk_rsp: pmo gtk response request
  581. *
  582. * This api will send gtk response request to fwr
  583. *
  584. * Return QDF_STATUS_SUCCESS -in case of success else return error
  585. */
  586. QDF_STATUS pmo_ucfg_get_gtk_rsp(struct wlan_objmgr_vdev *vdev,
  587. struct pmo_gtk_rsp_req *gtk_rsp_req);
  588. /**
  589. * pmo_ucfg_update_extscan_in_progress(): update extscan is in progress flags
  590. * @vdev: objmgr vdev handle
  591. * @value:true if extscan is in progress else false
  592. *
  593. * Return: TRUE/FALSE
  594. */
  595. void pmo_ucfg_update_extscan_in_progress(struct wlan_objmgr_vdev *vdev,
  596. bool value);
  597. /**
  598. * pmo_ucfg_update_p2plo_in_progress(): update p2plo is in progress flags
  599. * @vdev: objmgr vdev handle
  600. * @value:true if p2plo is in progress else false
  601. *
  602. * Return: TRUE/FALSE
  603. */
  604. void pmo_ucfg_update_p2plo_in_progress(struct wlan_objmgr_vdev *vdev,
  605. bool value);
  606. /**
  607. * pmo_ucfg_lphb_config_req() - Handles lphb config request for psoc
  608. * @psoc: objmgr psoc handle
  609. * @lphb_req: low power heart beat request
  610. * @lphb_cb_ctx: Context which needs to pass to soif when lphb callback called
  611. * @callback: upon receiving of lphb indication from fwr call lphb callback
  612. *
  613. * Return: QDF status
  614. */
  615. QDF_STATUS pmo_ucfg_lphb_config_req(struct wlan_objmgr_psoc *psoc,
  616. struct pmo_lphb_req *lphb_req, void *lphb_cb_ctx,
  617. pmo_lphb_callback callback);
  618. /**
  619. * pmo_ucfg_psoc_update_power_save_mode() - update power save mode
  620. * @vdev: objmgr vdev handle
  621. * @value:vdev power save mode
  622. *
  623. * Return: None
  624. */
  625. void pmo_ucfg_psoc_update_power_save_mode(struct wlan_objmgr_psoc *psoc,
  626. uint8_t value);
  627. /**
  628. * pmo_ucfg_psoc_update_dp_handle() - update psoc data path handle
  629. * @psoc: objmgr psoc handle
  630. * @dp_hdl: psoc data path handle
  631. *
  632. * Return: None
  633. */
  634. void pmo_ucfg_psoc_update_dp_handle(struct wlan_objmgr_psoc *psoc,
  635. void *dp_hdl);
  636. /**
  637. * pmo_ucfg_psoc_update_htc_handle() - update psoc htc layer handle
  638. * @psoc: objmgr psoc handle
  639. * @htc_handle: psoc host-to-tagret layer (htc) handle
  640. *
  641. * Return: None
  642. */
  643. void pmo_ucfg_psoc_update_htc_handle(struct wlan_objmgr_psoc *psoc,
  644. void *htc_handle);
  645. /**
  646. * pmo_ucfg_psoc_set_hif_handle() - Set psoc hif layer handle
  647. * @psoc: objmgr psoc handle
  648. * @hif_handle: hif context handle
  649. *
  650. * Return: None
  651. */
  652. void pmo_ucfg_psoc_set_hif_handle(struct wlan_objmgr_psoc *psoc,
  653. void *hif_handle);
  654. /**
  655. * pmo_ucfg_psoc_set_txrx_handle() - Set psoc pdev txrx layer handle
  656. * @psoc: objmgr psoc handle
  657. * @txrx_handle: pdev txrx context handle
  658. *
  659. * Return: None
  660. */
  661. void pmo_ucfg_psoc_set_txrx_handle(struct wlan_objmgr_psoc *psoc,
  662. void *txrx_handle);
  663. /**
  664. * pmo_ucfg_psoc_user_space_suspend_req() - Handles user space suspend req
  665. * @psoc: objmgr psoc handle
  666. * @type: type of suspend
  667. *
  668. * Handles user space suspend indication for psoc
  669. *
  670. * Return: QDF status
  671. */
  672. QDF_STATUS pmo_ucfg_psoc_user_space_suspend_req(struct wlan_objmgr_psoc *psoc,
  673. enum qdf_suspend_type type);
  674. /**
  675. * pmo_ucfg_psoc_user_space_resume_req() - Handles user space resume req
  676. * @psoc: objmgr psoc handle
  677. * @type: type of suspend from which resume needed
  678. *
  679. * Handles user space resume indication for psoc
  680. *
  681. * Return: QDF status
  682. */
  683. QDF_STATUS pmo_ucfg_psoc_user_space_resume_req(struct wlan_objmgr_psoc *psoc,
  684. enum qdf_suspend_type type);
  685. /**
  686. * pmo_ucfg_psoc_bus_suspend_req(): handles bus suspend for psoc
  687. * @psoc: objmgr psoc
  688. * @type: is this suspend part of runtime suspend or system suspend?
  689. * @wow_params: collection of wow enable override parameters
  690. *
  691. * Bails if a scan is in progress.
  692. * Calls the appropriate handlers based on configuration and event.
  693. *
  694. * Return: QDF_STATUS_SUCCESS for success or error code
  695. */
  696. QDF_STATUS pmo_ucfg_psoc_bus_suspend_req(struct wlan_objmgr_psoc *psoc,
  697. enum qdf_suspend_type type,
  698. struct pmo_wow_enable_params *wow_params);
  699. #ifdef FEATURE_RUNTIME_PM
  700. /**
  701. * pmo_ucfg_psoc_bus_runtime_suspend(): handles bus runtime suspend for psoc
  702. * @psoc: objmgr psoc
  703. * @pld_cb: callback to call link auto suspend
  704. *
  705. * Return: QDF_STATUS_SUCCESS for success or error code
  706. */
  707. QDF_STATUS pmo_ucfg_psoc_bus_runtime_suspend(struct wlan_objmgr_psoc *psoc,
  708. pmo_pld_auto_suspend_cb pld_cb);
  709. /**
  710. * pmo_ucfg_psoc_bus_runtime_resume(): handles bus runtime resume for psoc
  711. * @psoc: objmgr psoc
  712. * @pld_cb: callback to call link auto resume
  713. *
  714. * Return: QDF_STATUS_SUCCESS for success or error code
  715. */
  716. QDF_STATUS pmo_ucfg_psoc_bus_runtime_resume(struct wlan_objmgr_psoc *psoc,
  717. pmo_pld_auto_resume_cb pld_cb);
  718. #endif
  719. /**
  720. * pmo_ucfg_psoc_suspend_target() -Send suspend target command
  721. * @psoc: objmgr psoc handle
  722. * @disable_target_intr: disable target interrupt
  723. *
  724. * Return: QDF_STATUS_SUCCESS for success or error code
  725. */
  726. QDF_STATUS pmo_ucfg_psoc_suspend_target(struct wlan_objmgr_psoc *psoc,
  727. int disable_target_intr);
  728. QDF_STATUS pmo_ucfg_add_wow_user_pattern(struct wlan_objmgr_vdev *vdev,
  729. struct pmo_wow_add_pattern *ptrn);
  730. QDF_STATUS pmo_ucfg_del_wow_user_pattern(struct wlan_objmgr_vdev *vdev,
  731. uint8_t pattern_id);
  732. /**
  733. * pmo_ucfg_psoc_bus_resume() -handle bus resume request for psoc
  734. * @psoc: objmgr psoc handle
  735. * @type: is this suspend part of runtime suspend or system suspend?
  736. *
  737. * Return:QDF_STATUS_SUCCESS on success else error code
  738. */
  739. QDF_STATUS pmo_ucfg_psoc_bus_resume_req(struct wlan_objmgr_psoc *psoc,
  740. enum qdf_suspend_type type);
  741. /**
  742. * pmo_ucfg_get_wow_bus_suspend(): API to check if wow bus is suspended or not
  743. * @psoc: objmgr psoc handle
  744. *
  745. * Return: True if bus suspende else false
  746. */
  747. bool pmo_ucfg_get_wow_bus_suspend(struct wlan_objmgr_psoc *psoc);
  748. /**
  749. * pmo_ucfg_psoc_handle_initial_wake_up() - update initial wake up
  750. * @cb_ctx: objmgr psoc handle as void * due to htc layer is not aware psoc
  751. *
  752. * Return: None
  753. */
  754. void pmo_ucfg_psoc_handle_initial_wake_up(void *cb_ctx);
  755. /**
  756. * pmo_ucfg_psoc_is_target_wake_up_received() - Get initial wake up status
  757. * @psoc: objmgr psoc handle
  758. *
  759. * Return: 0 on success else error code
  760. */
  761. int pmo_ucfg_psoc_is_target_wake_up_received(struct wlan_objmgr_psoc *psoc);
  762. /**
  763. * pmo_ucfg_psoc_is_target_wake_up_received() - Clear initial wake up status
  764. * @psoc: objmgr psoc handle
  765. *
  766. * Return: 0 on success else error code
  767. */
  768. int pmo_ucfg_psoc_clear_target_wake_up(struct wlan_objmgr_psoc *psoc);
  769. /**
  770. * pmo_ucfg_psoc_target_suspend_acknowledge() - Clear initial wake up status
  771. * @psoc: objmgr psoc handle
  772. *
  773. * Return: None
  774. */
  775. void pmo_ucfg_psoc_target_suspend_acknowledge(void *context, bool wow_nack);
  776. /**
  777. * pmo_ucfg_psoc_wakeup_host_event_received() - got host wake up evennt from fwr
  778. * @psoc: objmgr psoc handle
  779. *
  780. * Return: None
  781. */
  782. void pmo_ucfg_psoc_wakeup_host_event_received(struct wlan_objmgr_psoc *psoc);
  783. /**
  784. * pmo_ucfg_config_listen_interval() - function to configure listen interval
  785. * @vdev: objmgr vdev
  786. * @listen_interval: new listen interval passed by user
  787. *
  788. * This function allows user to configure listen interval dynamically
  789. *
  790. * Return: QDF_STATUS
  791. */
  792. QDF_STATUS pmo_ucfg_config_listen_interval(struct wlan_objmgr_vdev *vdev,
  793. uint32_t listen_interval);
  794. /**
  795. * pmo_ucfg_config_modulated_dtim() - function to configure modulated dtim
  796. * @vdev: objmgr vdev handle
  797. * @param_value: New modulated dtim value passed by user
  798. *
  799. * This function configures the modulated dtim in firmware
  800. *
  801. * Return: QDF_STATUS
  802. */
  803. QDF_STATUS pmo_ucfg_config_modulated_dtim(struct wlan_objmgr_vdev *vdev,
  804. uint32_t mod_dtim);
  805. #ifdef WLAN_FEATURE_WOW_PULSE
  806. /**
  807. * ucfg_pmo_is_wow_pulse_enabled() - to get wow pulse enable configuration
  808. * @psoc: objmgr psoc handle
  809. *
  810. * Return: wow pulse enable configuration
  811. */
  812. bool ucfg_pmo_is_wow_pulse_enabled(struct wlan_objmgr_psoc *psoc);
  813. /**
  814. * ucfg_pmo_get_wow_pulse_pin() - to get wow pulse pin configuration
  815. * @psoc: objmgr psoc handle
  816. *
  817. * Return: wow pulse pin configuration
  818. */
  819. uint8_t ucfg_pmo_get_wow_pulse_pin(struct wlan_objmgr_psoc *psoc);
  820. /**
  821. * ucfg_pmo_get_wow_pulse_interval_high() - to get wow pulse interval high
  822. * @psoc: objmgr psoc handle
  823. *
  824. * Return: wow pulse interval high configuration
  825. */
  826. uint16_t ucfg_pmo_get_wow_pulse_interval_high(struct wlan_objmgr_psoc *psoc);
  827. /**
  828. * ucfg_pmo_get_wow_pulse_interval_low() - to get wow pulse interval low
  829. * @psoc: objmgr psoc handle
  830. *
  831. * Return: wow pulse interval high configuration
  832. */
  833. uint16_t ucfg_pmo_get_wow_pulse_interval_low(struct wlan_objmgr_psoc *psoc);
  834. #else
  835. static inline bool
  836. ucfg_pmo_is_wow_pulse_enabled(struct wlan_objmgr_psoc *psoc)
  837. {
  838. return false;
  839. }
  840. static inline uint8_t
  841. ucfg_pmo_get_wow_pulse_pin(struct wlan_objmgr_psoc *psoc)
  842. {
  843. return 0;
  844. }
  845. static inline uint16_t
  846. ucfg_pmo_get_wow_pulse_interval_high(struct wlan_objmgr_psoc *psoc)
  847. {
  848. return 0;
  849. }
  850. #endif
  851. /**
  852. * ucfg_pmo_is_active_mode_offloaded() - get active mode offload configuration
  853. * @psoc: objmgr psoc handle
  854. *
  855. * Return: retrieve active mode offload configuration
  856. */
  857. bool ucfg_pmo_is_active_mode_offloaded(struct wlan_objmgr_psoc *psoc);
  858. /**
  859. * ucfg_pmo_get_auto_power_fail_mode() - to get auto power save failure mode
  860. * @psoc: objmgr psoc handle
  861. *
  862. * Return: auto power save failure mode configuration
  863. */
  864. enum pmo_auto_pwr_detect_failure_mode
  865. ucfg_pmo_get_auto_power_fail_mode(struct wlan_objmgr_psoc *psoc);
  866. #ifdef FEATURE_WLAN_APF
  867. /**
  868. * ucfg_pmo_is_apf_enabled() - to get apf configuration
  869. * @psoc: objmgr psoc handle
  870. *
  871. * Return: true if enabled, it is intersection of ini and target cap
  872. */
  873. bool ucfg_pmo_is_apf_enabled(struct wlan_objmgr_psoc *psoc);
  874. #else
  875. static inline bool ucfg_pmo_is_apf_enabled(struct wlan_objmgr_psoc *psoc)
  876. {
  877. return false;
  878. }
  879. #endif
  880. #else /* WLAN_POWER_MANAGEMENT_OFFLOAD */
  881. static inline QDF_STATUS
  882. ucfg_pmo_psoc_open(struct wlan_objmgr_psoc *psoc)
  883. {
  884. return QDF_STATUS_SUCCESS;
  885. }
  886. static inline QDF_STATUS
  887. ucfg_pmo_psoc_close(struct wlan_objmgr_psoc *psoc)
  888. {
  889. return QDF_STATUS_SUCCESS;
  890. }
  891. static inline uint32_t
  892. ucfg_pmo_get_apf_instruction_size(struct wlan_objmgr_psoc *psoc)
  893. {
  894. return 0;
  895. }
  896. static inline uint8_t
  897. ucfg_pmo_get_pkt_filter_bitmap(struct wlan_objmgr_psoc *psoc)
  898. {
  899. return 0;
  900. }
  901. static inline uint32_t
  902. ucfg_pmo_get_num_packet_filters(struct wlan_objmgr_psoc *psoc)
  903. {
  904. return 0;
  905. }
  906. static inline uint8_t
  907. ucfg_pmo_get_num_wow_filters(struct wlan_objmgr_psoc *psoc)
  908. {
  909. return 0;
  910. }
  911. static inline QDF_STATUS
  912. ucfg_pmo_get_psoc_config(
  913. struct wlan_objmgr_psoc *psoc,
  914. struct pmo_psoc_cfg *psoc_cfg)
  915. {
  916. return QDF_STATUS_SUCCESS;
  917. }
  918. static inline QDF_STATUS
  919. ucfg_pmo_update_psoc_config(
  920. struct wlan_objmgr_psoc *psoc,
  921. struct pmo_psoc_cfg *psoc_cfg)
  922. {
  923. return QDF_STATUS_SUCCESS;
  924. }
  925. static inline QDF_STATUS
  926. ucfg_pmo_psoc_set_caps(
  927. struct wlan_objmgr_psoc *psoc,
  928. struct pmo_device_caps *caps)
  929. {
  930. return QDF_STATUS_SUCCESS;
  931. }
  932. static inline bool
  933. ucfg_pmo_is_ap_mode_supports_arp_ns(
  934. struct wlan_objmgr_psoc *psoc,
  935. enum QDF_OPMODE vdev_opmode)
  936. {
  937. return true;
  938. }
  939. static inline bool
  940. ucfg_pmo_is_vdev_connected(struct wlan_objmgr_vdev *vdev)
  941. {
  942. return true;
  943. }
  944. static inline bool
  945. ucfg_pmo_is_vdev_supports_offload(struct wlan_objmgr_vdev *vdev)
  946. {
  947. return true;
  948. }
  949. static inline void
  950. pmo_ucfg_enable_wakeup_event(
  951. struct wlan_objmgr_psoc *psoc,
  952. uint32_t vdev_id, uint32_t *bitmap)
  953. {
  954. }
  955. static inline void
  956. pmo_ucfg_disable_wakeup_event(
  957. struct wlan_objmgr_psoc *psoc,
  958. uint32_t vdev_id, uint32_t bitmap)
  959. {
  960. }
  961. static inline QDF_STATUS
  962. pmo_ucfg_cache_arp_offload_req(struct pmo_arp_req *arp_req)
  963. {
  964. return QDF_STATUS_SUCCESS;
  965. }
  966. static inline QDF_STATUS
  967. pmo_ucfg_flush_arp_offload_req(struct wlan_objmgr_vdev *vdev)
  968. {
  969. return QDF_STATUS_SUCCESS;
  970. }
  971. static inline QDF_STATUS
  972. pmo_ucfg_enable_arp_offload_in_fwr(
  973. struct wlan_objmgr_vdev *vdev,
  974. enum pmo_offload_trigger trigger)
  975. {
  976. return QDF_STATUS_SUCCESS;
  977. }
  978. static inline QDF_STATUS
  979. pmo_ucfg_disable_arp_offload_in_fwr(
  980. struct wlan_objmgr_vdev *vdev,
  981. enum pmo_offload_trigger trigger)
  982. {
  983. return QDF_STATUS_SUCCESS;
  984. }
  985. static inline QDF_STATUS
  986. pmo_ucfg_get_arp_offload_params(struct wlan_objmgr_vdev *vdev,
  987. struct pmo_arp_offload_params *params)
  988. {
  989. return QDF_STATUS_SUCCESS;
  990. }
  991. static inline QDF_STATUS
  992. pmo_ucfg_cache_ns_offload_req(struct pmo_ns_req *ns_req)
  993. {
  994. return QDF_STATUS_SUCCESS;
  995. }
  996. static inline QDF_STATUS
  997. pmo_ucfg_flush_ns_offload_req(struct wlan_objmgr_vdev *vdev)
  998. {
  999. return QDF_STATUS_SUCCESS;
  1000. }
  1001. static inline QDF_STATUS
  1002. pmo_ucfg_enable_ns_offload_in_fwr(
  1003. struct wlan_objmgr_vdev *vdev,
  1004. enum pmo_offload_trigger trigger)
  1005. {
  1006. return QDF_STATUS_SUCCESS;
  1007. }
  1008. static inline QDF_STATUS
  1009. pmo_ucfg_disable_ns_offload_in_fwr(
  1010. struct wlan_objmgr_vdev *vdev,
  1011. enum pmo_offload_trigger trigger)
  1012. {
  1013. return QDF_STATUS_SUCCESS;
  1014. }
  1015. static inline QDF_STATUS
  1016. pmo_ucfg_get_ns_offload_params(struct wlan_objmgr_vdev *vdev,
  1017. struct pmo_ns_offload_params *params)
  1018. {
  1019. return QDF_STATUS_SUCCESS;
  1020. }
  1021. static inline enum pmo_ns_addr_scope
  1022. pmo_ucfg_ns_addr_scope(uint32_t ipv6_scope)
  1023. {
  1024. return PMO_NS_ADDR_SCOPE_INVALID;
  1025. }
  1026. static inline QDF_STATUS
  1027. pmo_ucfg_cache_mc_addr_list(
  1028. struct pmo_mc_addr_list_params *mc_list_config)
  1029. {
  1030. return QDF_STATUS_SUCCESS;
  1031. }
  1032. static inline QDF_STATUS
  1033. pmo_ucfg_flush_mc_addr_list(
  1034. struct wlan_objmgr_psoc *psoc,
  1035. uint8_t vdev_id)
  1036. {
  1037. return QDF_STATUS_SUCCESS;
  1038. }
  1039. static inline QDF_STATUS
  1040. pmo_ucfg_enable_mc_addr_filtering_in_fwr(
  1041. struct wlan_objmgr_psoc *psoc,
  1042. uint8_t vdev_id,
  1043. enum pmo_offload_trigger trigger)
  1044. {
  1045. return QDF_STATUS_SUCCESS;
  1046. }
  1047. static inline QDF_STATUS
  1048. pmo_ucfg_disable_mc_addr_filtering_in_fwr(
  1049. struct wlan_objmgr_psoc *psoc,
  1050. uint8_t vdev_id,
  1051. enum pmo_offload_trigger trigger)
  1052. {
  1053. return QDF_STATUS_SUCCESS;
  1054. }
  1055. static inline uint8_t
  1056. pmo_ucfg_max_mc_addr_supported(struct wlan_objmgr_psoc *psoc)
  1057. {
  1058. return 0;
  1059. }
  1060. static inline QDF_STATUS
  1061. pmo_ucfg_get_mc_addr_list(struct wlan_objmgr_psoc *psoc,
  1062. uint8_t vdev_id,
  1063. struct pmo_mc_addr_list *mc_list_req)
  1064. {
  1065. return QDF_STATUS_SUCCESS;
  1066. }
  1067. static inline QDF_STATUS
  1068. pmo_ucfg_cache_gtk_offload_req(
  1069. struct wlan_objmgr_vdev *vdev,
  1070. struct pmo_gtk_req *gtk_req)
  1071. {
  1072. return QDF_STATUS_SUCCESS;
  1073. }
  1074. static inline QDF_STATUS
  1075. pmo_ucfg_flush_gtk_offload_req(struct wlan_objmgr_vdev *vdev)
  1076. {
  1077. return QDF_STATUS_SUCCESS;
  1078. }
  1079. static inline QDF_STATUS
  1080. pmo_ucfg_enable_gtk_offload_in_fwr(struct wlan_objmgr_vdev *vdev)
  1081. {
  1082. return QDF_STATUS_SUCCESS;
  1083. }
  1084. static inline QDF_STATUS
  1085. pmo_ucfg_disable_gtk_offload_in_fwr(struct wlan_objmgr_vdev *vdev)
  1086. {
  1087. return QDF_STATUS_SUCCESS;
  1088. }
  1089. static inline QDF_STATUS
  1090. pmo_ucfg_set_pkt_filter(
  1091. struct wlan_objmgr_psoc *psoc,
  1092. struct pmo_rcv_pkt_fltr_cfg *pmo_set_pkt_fltr_req,
  1093. uint8_t vdev_id)
  1094. {
  1095. return QDF_STATUS_SUCCESS;
  1096. }
  1097. static inline QDF_STATUS
  1098. pmo_ucfg_clear_pkt_filter(
  1099. struct wlan_objmgr_psoc *psoc,
  1100. struct pmo_rcv_pkt_fltr_clear_param *pmo_clr_pkt_fltr_param,
  1101. uint8_t vdev_id)
  1102. {
  1103. return QDF_STATUS_SUCCESS;
  1104. }
  1105. static inline QDF_STATUS
  1106. pmo_ucfg_get_gtk_rsp(
  1107. struct wlan_objmgr_vdev *vdev,
  1108. struct pmo_gtk_rsp_req *gtk_rsp_req)
  1109. {
  1110. return QDF_STATUS_SUCCESS;
  1111. }
  1112. static inline void
  1113. pmo_ucfg_update_extscan_in_progress(
  1114. struct wlan_objmgr_vdev *vdev,
  1115. bool value)
  1116. {
  1117. }
  1118. static inline void
  1119. pmo_ucfg_update_p2plo_in_progress(
  1120. struct wlan_objmgr_vdev *vdev,
  1121. bool value)
  1122. {
  1123. }
  1124. static inline QDF_STATUS
  1125. pmo_ucfg_lphb_config_req(
  1126. struct wlan_objmgr_psoc *psoc,
  1127. struct pmo_lphb_req *lphb_req, void *lphb_cb_ctx,
  1128. pmo_lphb_callback callback)
  1129. {
  1130. return QDF_STATUS_SUCCESS;
  1131. }
  1132. static inline void
  1133. pmo_ucfg_psoc_update_power_save_mode(
  1134. struct wlan_objmgr_psoc *psoc,
  1135. uint8_t value)
  1136. {
  1137. }
  1138. static inline void
  1139. pmo_ucfg_psoc_update_dp_handle(
  1140. struct wlan_objmgr_psoc *psoc,
  1141. void *dp_handle)
  1142. {
  1143. }
  1144. static inline void
  1145. pmo_ucfg_vdev_update_dp_handle(
  1146. struct wlan_objmgr_vdev *vdev,
  1147. void *dp_handle)
  1148. {
  1149. }
  1150. static inline void
  1151. pmo_ucfg_psoc_update_htc_handle(
  1152. struct wlan_objmgr_psoc *psoc,
  1153. void *htc_handle)
  1154. {
  1155. }
  1156. static inline void
  1157. pmo_ucfg_psoc_set_hif_handle(
  1158. struct wlan_objmgr_psoc *psoc,
  1159. void *hif_handle)
  1160. {
  1161. }
  1162. static inline void
  1163. pmo_ucfg_psoc_set_txrx_handle(
  1164. struct wlan_objmgr_psoc *psoc,
  1165. void *txrx_handle)
  1166. {
  1167. }
  1168. static inline void
  1169. pmo_ucfg_psoc_handle_initial_wake_up(void *cb_ctx)
  1170. {
  1171. }
  1172. static inline QDF_STATUS
  1173. pmo_ucfg_psoc_user_space_suspend_req(
  1174. struct wlan_objmgr_psoc *psoc,
  1175. enum qdf_suspend_type type)
  1176. {
  1177. return QDF_STATUS_SUCCESS;
  1178. }
  1179. static inline QDF_STATUS
  1180. pmo_ucfg_psoc_user_space_resume_req(
  1181. struct wlan_objmgr_psoc *psoc,
  1182. enum qdf_suspend_type type)
  1183. {
  1184. return QDF_STATUS_SUCCESS;
  1185. }
  1186. static inline QDF_STATUS
  1187. pmo_ucfg_psoc_bus_suspend_req(
  1188. struct wlan_objmgr_psoc *psoc,
  1189. enum qdf_suspend_type type,
  1190. struct pmo_wow_enable_params *wow_params)
  1191. {
  1192. return QDF_STATUS_SUCCESS;
  1193. }
  1194. #ifdef FEATURE_RUNTIME_PM
  1195. static inline QDF_STATUS
  1196. pmo_ucfg_psoc_bus_runtime_suspend(
  1197. struct wlan_objmgr_psoc *psoc,
  1198. pmo_pld_auto_suspend_cb pld_cb)
  1199. {
  1200. return QDF_STATUS_SUCCESS;
  1201. }
  1202. static inline QDF_STATUS
  1203. pmo_ucfg_psoc_bus_runtime_resume(
  1204. struct wlan_objmgr_psoc *psoc,
  1205. pmo_pld_auto_suspend_cb pld_cb)
  1206. {
  1207. return QDF_STATUS_SUCCESS;
  1208. }
  1209. #endif
  1210. static inline QDF_STATUS
  1211. pmo_ucfg_psoc_suspend_target(
  1212. struct wlan_objmgr_psoc *psoc,
  1213. int disable_target_intr)
  1214. {
  1215. return QDF_STATUS_SUCCESS;
  1216. }
  1217. static inline QDF_STATUS
  1218. pmo_ucfg_add_wow_user_pattern(
  1219. struct wlan_objmgr_vdev *vdev,
  1220. struct pmo_wow_add_pattern *ptrn)
  1221. {
  1222. return QDF_STATUS_SUCCESS;
  1223. }
  1224. static inline QDF_STATUS
  1225. pmo_ucfg_del_wow_user_pattern(
  1226. struct wlan_objmgr_vdev *vdev,
  1227. uint8_t pattern_id)
  1228. {
  1229. return QDF_STATUS_SUCCESS;
  1230. }
  1231. static inline QDF_STATUS
  1232. pmo_ucfg_psoc_bus_resume_req(
  1233. struct wlan_objmgr_psoc *psoc,
  1234. enum qdf_suspend_type type)
  1235. {
  1236. return QDF_STATUS_SUCCESS;
  1237. }
  1238. static inline bool
  1239. pmo_ucfg_get_wow_bus_suspend(struct wlan_objmgr_psoc *psoc)
  1240. {
  1241. return true;
  1242. }
  1243. static inline int
  1244. pmo_ucfg_psoc_is_target_wake_up_received(struct wlan_objmgr_psoc *psoc)
  1245. {
  1246. return 0;
  1247. }
  1248. static inline int
  1249. pmo_ucfg_psoc_clear_target_wake_up(struct wlan_objmgr_psoc *psoc)
  1250. {
  1251. return 0;
  1252. }
  1253. static inline void
  1254. pmo_ucfg_psoc_target_suspend_acknowledge(void *context, bool wow_nack)
  1255. {
  1256. }
  1257. static inline void
  1258. pmo_ucfg_psoc_wakeup_host_event_received(struct wlan_objmgr_psoc *psoc)
  1259. {
  1260. }
  1261. static inline QDF_STATUS
  1262. pmo_ucfg_enable_hw_filter_in_fwr(struct wlan_objmgr_vdev *vdev)
  1263. {
  1264. return QDF_STATUS_SUCCESS;
  1265. }
  1266. static inline QDF_STATUS
  1267. pmo_ucfg_disable_hw_filter_in_fwr(struct wlan_objmgr_vdev *vdev)
  1268. {
  1269. return QDF_STATUS_SUCCESS;
  1270. }
  1271. static inline QDF_STATUS
  1272. pmo_ucfg_enhanced_mc_filter_enable(struct wlan_objmgr_vdev *vdev)
  1273. {
  1274. return QDF_STATUS_SUCCESS;
  1275. }
  1276. static inline QDF_STATUS
  1277. pmo_ucfg_enhanced_mc_filter_disable(struct wlan_objmgr_vdev *vdev)
  1278. {
  1279. return QDF_STATUS_SUCCESS;
  1280. }
  1281. static inline QDF_STATUS
  1282. pmo_ucfg_config_listen_interval(struct wlan_objmgr_vdev *vdev,
  1283. uint32_t listen_interval)
  1284. {
  1285. return QDF_STATUS_SUCCESS;
  1286. }
  1287. static inline QDF_STATUS
  1288. pmo_ucfg_config_modulated_dtim(struct wlan_objmgr_vdev *vdev,
  1289. uint32_t mod_dtim)
  1290. {
  1291. return QDF_STATUS_SUCCESS;
  1292. }
  1293. static inline bool
  1294. ucfg_pmo_is_arp_offload_enabled(struct wlan_objmgr_psoc *psoc)
  1295. {
  1296. return false;
  1297. }
  1298. static inline void
  1299. ucfg_pmo_set_arp_offload_enabled(struct wlan_objmgr_psoc *psoc,
  1300. bool val)
  1301. {
  1302. }
  1303. static inline bool
  1304. ucfg_pmo_is_wow_pulse_enabled(struct wlan_objmgr_psoc *psoc)
  1305. {
  1306. return false;
  1307. }
  1308. static inline uint8_t
  1309. ucfg_pmo_get_wow_pulse_pin(struct wlan_objmgr_psoc *psoc)
  1310. {
  1311. return 0;
  1312. }
  1313. static inline uint16_t
  1314. ucfg_pmo_get_wow_pulse_interval_high(struct wlan_objmgr_psoc *psoc)
  1315. {
  1316. return 0;
  1317. }
  1318. static inline uint16_t
  1319. ucfg_pmo_get_wow_pulse_interval_low(struct wlan_objmgr_psoc *psoc)
  1320. {
  1321. return 0;
  1322. }
  1323. static inline bool
  1324. ucfg_pmo_is_active_mode_offloaded(struct wlan_objmgr_psoc *psoc)
  1325. {
  1326. return true;
  1327. }
  1328. static inline enum pmo_auto_pwr_detect_failure_mode
  1329. ucfg_pmo_get_auto_power_fail_mode(struct wlan_objmgr_psoc *psoc)
  1330. {
  1331. return PMO_FW_TO_CRASH_ON_PWR_FAILURE;
  1332. }
  1333. static inline bool ucfg_pmo_is_apf_enabled(struct wlan_objmgr_psoc *psoc)
  1334. {
  1335. return false;
  1336. }
  1337. static inline bool ucfg_pmo_is_ssdp_enabled(struct wlan_objmgr_psoc *psoc)
  1338. {
  1339. return false;
  1340. }
  1341. static inline bool ucfg_pmo_is_ns_offloaded(struct wlan_objmgr_psoc *psoc)
  1342. {
  1343. return false;
  1344. }
  1345. static inline uint8_t
  1346. ucfg_pmo_get_sta_dynamic_dtim(struct wlan_objmgr_psoc *psoc)
  1347. {
  1348. return 0;
  1349. }
  1350. static inline uint8_t
  1351. ucfg_pmo_get_sta_mod_dtim(struct wlan_objmgr_psoc *psoc)
  1352. {
  1353. return 0;
  1354. }
  1355. static inline void
  1356. ucfg_pmo_set_sta_mod_dtim(struct wlan_objmgr_psoc *psoc,
  1357. uint8_t val)
  1358. {
  1359. }
  1360. static inline bool
  1361. ucfg_pmo_is_mc_addr_list_enabled(struct wlan_objmgr_psoc *psoc)
  1362. {
  1363. return false;
  1364. }
  1365. static inline enum powersave_mode
  1366. ucfg_pmo_get_power_save_mode(struct wlan_objmgr_psoc *psoc)
  1367. {
  1368. return 0;
  1369. }
  1370. static inline void
  1371. ucfg_pmo_set_power_save_mode(struct wlan_objmgr_psoc *psoc,
  1372. enum powersave_mode val)
  1373. {
  1374. }
  1375. static inline uint8_t
  1376. ucfg_pmo_get_max_ps_poll(struct wlan_objmgr_psoc *psoc)
  1377. {
  1378. return 0;
  1379. }
  1380. static inline uint8_t
  1381. ucfg_pmo_power_save_offload_enabled(struct wlan_objmgr_psoc *psoc)
  1382. {
  1383. return 0;
  1384. }
  1385. #endif /* WLAN_POWER_MANAGEMENT_OFFLOAD */
  1386. #ifdef WLAN_FEATURE_EXTWOW_SUPPORT
  1387. /**
  1388. * ucfg_pmo_extwow_is_goto_suspend_enabled() - Get extwow goto suspend enable
  1389. * @psoc: pointer to psoc object
  1390. *
  1391. * Return: extend wow goto suspend enable or not
  1392. */
  1393. bool
  1394. ucfg_pmo_extwow_is_goto_suspend_enabled(struct wlan_objmgr_psoc *psoc);
  1395. /**
  1396. * ucfg_pmo_extwow_app1_wakeup_pin_num() - Get wakeup1 PIN number
  1397. * @psoc: pointer to psoc object
  1398. *
  1399. * Return: wakeup1 PIN number
  1400. */
  1401. uint8_t
  1402. ucfg_pmo_extwow_app1_wakeup_pin_num(struct wlan_objmgr_psoc *psoc);
  1403. /**
  1404. * ucfg_pmo_extwow_app2_wakeup_pin_num() - Get wakeup2 PIN number
  1405. * @psoc: pointer to psoc object
  1406. *
  1407. * Return: wakeup2 PIN number
  1408. */
  1409. uint8_t
  1410. ucfg_pmo_extwow_app2_wakeup_pin_num(struct wlan_objmgr_psoc *psoc);
  1411. /**
  1412. * ucfg_pmo_extwow_app2_init_ping_interval() - Get keep alive init ping interval
  1413. * @psoc: pointer to psoc object
  1414. *
  1415. * Return: keep alive init ping interval
  1416. */
  1417. uint32_t
  1418. ucfg_pmo_extwow_app2_init_ping_interval(struct wlan_objmgr_psoc *psoc);
  1419. /**
  1420. * ucfg_pmo_extwow_app2_min_ping_interval() - Get keep alive min ping interval
  1421. * @psoc: pointer to psoc object
  1422. *
  1423. * Return: keep alive min ping interval
  1424. */
  1425. uint32_t
  1426. ucfg_pmo_extwow_app2_min_ping_interval(struct wlan_objmgr_psoc *psoc);
  1427. /**
  1428. * ucfg_pmo_extwow_app2_max_ping_interval() - Get keep alive max ping interval
  1429. * @psoc: pointer to psoc object
  1430. *
  1431. * Return: keep alive max ping interval
  1432. */
  1433. uint32_t
  1434. ucfg_pmo_extwow_app2_max_ping_interval(struct wlan_objmgr_psoc *psoc);
  1435. /**
  1436. * ucfg_pmo_extwow_app2_inc_ping_interval() - Get keep alive inc ping interval
  1437. * @psoc: pointer to psoc object
  1438. *
  1439. * Return: keep alive inc ping interval
  1440. */
  1441. uint32_t
  1442. ucfg_pmo_extwow_app2_inc_ping_interval(struct wlan_objmgr_psoc *psoc);
  1443. /**
  1444. * ucfg_pmo_extwow_app2_tcp_src_port() - Get TCP source port
  1445. * @psoc: pointer to psoc object
  1446. *
  1447. * Return: TCP source port
  1448. */
  1449. uint16_t
  1450. ucfg_pmo_extwow_app2_tcp_src_port(struct wlan_objmgr_psoc *psoc);
  1451. /**
  1452. * ucfg_pmo_extwow_app2_tcp_dst_port() - Get TCP Destination port
  1453. * @psoc: pointer to psoc object
  1454. *
  1455. * Return: TCP Destination port
  1456. */
  1457. uint16_t
  1458. ucfg_pmo_extwow_app2_tcp_dst_port(struct wlan_objmgr_psoc *psoc);
  1459. /**
  1460. * ucfg_pmo_extwow_app2_tcp_tx_timeout() - Get TCP Tx timeout
  1461. * @psoc: pointer to psoc object
  1462. *
  1463. * Return: TCP Tx timeout
  1464. */
  1465. uint32_t
  1466. ucfg_pmo_extwow_app2_tcp_tx_timeout(struct wlan_objmgr_psoc *psoc);
  1467. /**
  1468. * ucfg_pmo_extwow_app2_tcp_rx_timeout() - to get extwow tcp rx timeout
  1469. * @psoc: objmgr psoc handle
  1470. *
  1471. * Return: retrieve extwow app2 tcp rx timeout configuration
  1472. */
  1473. uint32_t
  1474. ucfg_pmo_extwow_app2_tcp_rx_timeout(struct wlan_objmgr_psoc *psoc);
  1475. #else
  1476. static inline bool
  1477. ucfg_pmo_extwow_is_goto_suspend_enabled(struct wlan_objmgr_psoc *psoc)
  1478. {
  1479. return false;
  1480. }
  1481. static inline uint32_t
  1482. ucfg_pmo_extwow_app1_wakeup_pin_num(struct wlan_objmgr_psoc *psoc)
  1483. {
  1484. return 0;
  1485. }
  1486. static inline uint32_t
  1487. ucfg_pmo_extwow_app2_wakeup_pin_num(struct wlan_objmgr_psoc *psoc)
  1488. {
  1489. return 0;
  1490. }
  1491. static inline uint32_t
  1492. ucfg_pmo_extwow_app2_init_ping_interval(struct wlan_objmgr_psoc *psoc)
  1493. {
  1494. return 0;
  1495. }
  1496. static inline uint32_t
  1497. ucfg_pmo_extwow_app2_min_ping_interval(struct wlan_objmgr_psoc *psoc)
  1498. {
  1499. return 0;
  1500. }
  1501. static inline uint32_t
  1502. ucfg_pmo_extwow_app2_max_ping_interval(struct wlan_objmgr_psoc *psoc)
  1503. {
  1504. return 0;
  1505. }
  1506. static inline uint32_t
  1507. ucfg_pmo_extwow_app2_inc_ping_interval(struct wlan_objmgr_psoc *psoc)
  1508. {
  1509. return 0;
  1510. }
  1511. static inline uint16_t
  1512. ucfg_pmo_extwow_app2_tcp_src_port(struct wlan_objmgr_psoc *psoc)
  1513. {
  1514. return 0;
  1515. }
  1516. static inline uint16_t
  1517. ucfg_pmo_extwow_app2_tcp_dst_port(struct wlan_objmgr_psoc *psoc)
  1518. {
  1519. return 0;
  1520. }
  1521. static inline uint32_t
  1522. ucfg_pmo_extwow_app2_tcp_tx_timeout(struct wlan_objmgr_psoc *psoc)
  1523. {
  1524. return 0;
  1525. }
  1526. static inline uint32_t
  1527. ucfg_pmo_extwow_app2_tcp_rx_timeout(struct wlan_objmgr_psoc *psoc)
  1528. {
  1529. return 0;
  1530. }
  1531. #endif
  1532. #ifdef FEATURE_RUNTIME_PM
  1533. /**
  1534. * ucfg_pmo_get_runtime_pm_delay() - Get runtime pm's inactivity timer
  1535. * @psoc: pointer to psoc object
  1536. *
  1537. * Return: runtime pm's inactivity timer
  1538. */
  1539. uint32_t
  1540. ucfg_pmo_get_runtime_pm_delay(struct wlan_objmgr_psoc *psoc);
  1541. #else
  1542. static inline uint32_t
  1543. ucfg_pmo_get_runtime_pm_delay(struct wlan_objmgr_psoc *psoc)
  1544. {
  1545. return 0;
  1546. }
  1547. #endif /* FEATURE_RUNTIME_PM */
  1548. #endif /* end of _WLAN_PMO_UCFG_API_H_ */