wlan_spectral_tgt_api.h 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  1. /*
  2. * Copyright (c) 2017-2020 The Linux Foundation. All rights reserved.
  3. * Copyright (c) 2022-2023 Qualcomm Innovation Center, Inc. All rights reserved.
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for
  6. * any purpose with or without fee is hereby granted, provided that the
  7. * above copyright notice and this permission notice appear in all
  8. * copies.
  9. *
  10. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  11. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  12. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  13. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  14. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  15. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  16. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  17. * PERFORMANCE OF THIS SOFTWARE.
  18. */
  19. #ifndef _WLAN_SPECTRAL_TGT_API_H_
  20. #define _WLAN_SPECTRAL_TGT_API_H_
  21. #include <wlan_objmgr_cmn.h>
  22. #include <qdf_types.h>
  23. #include "../../core/spectral_cmn_api_i.h"
  24. /**
  25. * tgt_get_pdev_target_handle() - Get pdev target_if handle
  26. * @pdev: Pointer to pdev
  27. *
  28. * Get handle to pdev target_if internal Spectral data
  29. *
  30. * Return: Handle to pdev target_if internal Spectral data on success, NULL on
  31. * failure
  32. */
  33. void *tgt_get_pdev_target_handle(struct wlan_objmgr_pdev *pdev);
  34. /**
  35. * tgt_get_psoc_target_handle() - Get psoc target_if handle
  36. * @psoc: Pointer to psoc
  37. *
  38. * Get handle to psoc target_if internal Spectral data
  39. *
  40. * Return: Handle to psoc target_if internal Spectral data on success, NULL on
  41. * failure
  42. */
  43. void *tgt_get_psoc_target_handle(struct wlan_objmgr_psoc *psoc);
  44. /**
  45. * tgt_spectral_control()- handler for demultiplexing requests from higher layer
  46. * @pdev: Reference to global pdev object
  47. * @sscan_req: pointer to Spectral scan request
  48. *
  49. * This function processes the spectral config command
  50. * and appropriate handlers are invoked.
  51. *
  52. * Return: QDF_STATUS_SUCCESS/QDF_STATUS_E_FAILURE
  53. */
  54. QDF_STATUS tgt_spectral_control(struct wlan_objmgr_pdev *pdev,
  55. struct spectral_cp_request *sscan_req);
  56. /**
  57. * tgt_pdev_spectral_init() - implementation for spectral init
  58. * @pdev: Pointer to pdev
  59. *
  60. * Return: On success, pointer to Spectral target_if internal private data, on
  61. * failure, NULL
  62. */
  63. void *tgt_pdev_spectral_init(struct wlan_objmgr_pdev *pdev);
  64. /**
  65. * tgt_pdev_spectral_deinit() - implementation for spectral de-init
  66. * @pdev: Pointer to pdev
  67. *
  68. * Return: None
  69. */
  70. void tgt_pdev_spectral_deinit(struct wlan_objmgr_pdev *pdev);
  71. /**
  72. * tgt_psoc_spectral_init() - implementation for spectral init
  73. * @psoc: Pointer to psoc
  74. *
  75. * Return: On success, pointer to Spectral psoc target_if internal private data,
  76. * on failure, NULL
  77. */
  78. void *tgt_psoc_spectral_init(struct wlan_objmgr_psoc *psoc);
  79. /**
  80. * tgt_psoc_spectral_deinit() - implementation for spectral de-init
  81. * @psoc: Pointer to psoc
  82. *
  83. * Return: None
  84. */
  85. void tgt_psoc_spectral_deinit(struct wlan_objmgr_psoc *psoc);
  86. /**
  87. * tgt_set_spectral_config() - Set spectral config
  88. * @pdev: Pointer to pdev object
  89. * @param: Pointer object describing Spectral parameter
  90. * @smode: Spectral scan mode
  91. * @err: Spectral control path error code
  92. *
  93. * Implementation for setting spectral config
  94. *
  95. * Return: QDF_STATUS_SUCCESS on success, else QDF_STATUS_E_FAILURE
  96. */
  97. QDF_STATUS tgt_set_spectral_config(struct wlan_objmgr_pdev *pdev,
  98. const struct spectral_cp_param *param,
  99. const enum spectral_scan_mode smode,
  100. enum spectral_cp_error_code *err);
  101. /**
  102. * tgt_get_spectral_config() - Get spectral configuration
  103. * @pdev: Pointer to pdev object
  104. * @sptrl_config: Pointer to spectral_config structure in which the
  105. * configuration should be returned
  106. * @smode: Spectral scan mode
  107. *
  108. * Implementation for getting the current spectral configuration
  109. *
  110. * Return: QDF_STATUS_SUCCESS on success, else QDF_STATUS_E_FAILURE
  111. */
  112. QDF_STATUS tgt_get_spectral_config(struct wlan_objmgr_pdev *pdev,
  113. struct spectral_config *sptrl_config,
  114. const enum spectral_scan_mode smode);
  115. /**
  116. * tgt_start_spectral_scan() - Start spectral scan
  117. * @pdev: Pointer to pdev object
  118. * @vdev_id: VDEV id
  119. * @smode: Spectral scan mode
  120. * @err: Spectral control path error code
  121. *
  122. * Implementation for starting spectral scan
  123. *
  124. * Return: QDF_STATUS_SUCCESS on success, else QDF_STATUS_E_FAILURE
  125. */
  126. QDF_STATUS tgt_start_spectral_scan(struct wlan_objmgr_pdev *pdev,
  127. uint8_t vdev_id,
  128. enum spectral_scan_mode smode,
  129. enum spectral_cp_error_code *err);
  130. /**
  131. * tgt_stop_spectral_scan() - Stop spectral scan
  132. * @pdev: Pointer to pdev object
  133. * @smode: Spectral scan mode
  134. * @err: Spectral control path error code
  135. *
  136. * Implementation for stop spectral scan
  137. *
  138. * Return: QDF_STATUS_SUCCESS on success, else QDF_STATUS_E_FAILURE
  139. */
  140. QDF_STATUS tgt_stop_spectral_scan(struct wlan_objmgr_pdev *pdev,
  141. enum spectral_scan_mode smode,
  142. enum spectral_cp_error_code *err);
  143. /**
  144. * tgt_is_spectral_active() - Get whether Spectral is active
  145. * @pdev: Pointer to pdev object
  146. * @smode: Spectral scan mode
  147. *
  148. * Implementation to get whether Spectral is active
  149. *
  150. * Return: True if Spectral is active, false if Spectral is not active
  151. */
  152. bool tgt_is_spectral_active(struct wlan_objmgr_pdev *pdev,
  153. enum spectral_scan_mode smode);
  154. /**
  155. * tgt_is_spectral_enabled() - Get whether Spectral is active
  156. * @pdev: Pointer to pdev object
  157. * @smode: Spectral scan mode
  158. *
  159. * Implementation to get whether Spectral is active
  160. *
  161. * Return: True if Spectral is active, false if Spectral is not active
  162. */
  163. bool tgt_is_spectral_enabled(struct wlan_objmgr_pdev *pdev,
  164. enum spectral_scan_mode smode);
  165. /**
  166. * tgt_set_debug_level() - Set debug level for Spectral
  167. * @pdev: Pointer to pdev object
  168. * @debug_level: Debug level
  169. *
  170. * Implementation to set the debug level for Spectral
  171. *
  172. * Return: QDF_STATUS_SUCCESS on success, else QDF_STATUS_E_FAILURE
  173. */
  174. QDF_STATUS tgt_set_debug_level(struct wlan_objmgr_pdev *pdev,
  175. u_int32_t debug_level);
  176. /**
  177. * tgt_get_debug_level() - Get debug level for Spectral
  178. * @pdev: Pointer to pdev object
  179. *
  180. * Implementation to get the debug level for Spectral
  181. *
  182. * Return: Current debug level
  183. */
  184. uint32_t tgt_get_debug_level(struct wlan_objmgr_pdev *pdev);
  185. /**
  186. * tgt_get_spectral_capinfo() - Get Spectral capability information
  187. * @pdev: Pointer to pdev object
  188. * @scaps: Buffer into which data should be copied
  189. *
  190. * Implementation to get the spectral capability information
  191. *
  192. * Return: QDF_STATUS_SUCCESS on success, else QDF_STATUS_E_FAILURE
  193. */
  194. QDF_STATUS tgt_get_spectral_capinfo(struct wlan_objmgr_pdev *pdev,
  195. struct spectral_caps *scaps);
  196. /**
  197. * tgt_get_spectral_diagstats() - Get Spectral diagnostic statistics
  198. * @pdev: Pointer to pdev object
  199. * @stats: Buffer into which data should be copied
  200. *
  201. * Implementation to get the spectral diagnostic statistics
  202. *
  203. * Return: QDF_STATUS_SUCCESS on success, else QDF_STATUS_E_FAILURE
  204. */
  205. QDF_STATUS tgt_get_spectral_diagstats(struct wlan_objmgr_pdev *pdev,
  206. struct spectral_diag_stats *stats);
  207. /**
  208. * tgt_register_spectral_wmi_ops() - Register Spectral WMI operations
  209. * @psoc: Pointer to psoc object
  210. * @wmi_ops: Pointer to the structure having Spectral WMI operations
  211. *
  212. * Implementation to register Spectral WMI operations in spectral
  213. * internal data structure
  214. *
  215. * Return: QDF_STATUS
  216. */
  217. QDF_STATUS tgt_register_spectral_wmi_ops(struct wlan_objmgr_psoc *psoc,
  218. struct spectral_wmi_ops *wmi_ops);
  219. /**
  220. * tgt_register_spectral_tgt_ops() - Register Spectral target operations
  221. * @psoc: Pointer to psoc object
  222. * @tgt_ops: Pointer to the structure having Spectral target operations
  223. *
  224. * Implementation to register Spectral target operations in spectral
  225. * internal data structure
  226. *
  227. * Return: QDF_STATUS
  228. */
  229. QDF_STATUS tgt_register_spectral_tgt_ops(struct wlan_objmgr_psoc *psoc,
  230. struct spectral_tgt_ops *tgt_ops);
  231. /**
  232. * tgt_spectral_register_nl_cb() - Register Netlink callbacks
  233. * @pdev: Pointer to pdev object
  234. * @nl_cb: Netlink callbacks to register
  235. *
  236. * Return: void
  237. */
  238. void tgt_spectral_register_nl_cb(struct wlan_objmgr_pdev *pdev,
  239. struct spectral_nl_cb *nl_cb);
  240. /**
  241. * tgt_spectral_use_nl_bcast() - Get whether to use broadcast/unicast while
  242. * sending Netlink messages to the application layer
  243. * @pdev: Pointer to pdev object
  244. *
  245. * Return: true for broadcast, false for unicast
  246. */
  247. bool tgt_spectral_use_nl_bcast(struct wlan_objmgr_pdev *pdev);
  248. /**
  249. * tgt_spectral_deregister_nl_cb() - De-register Netlink callbacks
  250. * @pdev: Pointer to pdev object
  251. *
  252. * Return: void
  253. */
  254. void tgt_spectral_deregister_nl_cb(struct wlan_objmgr_pdev *pdev);
  255. /**
  256. * tgt_spectral_process_report() - Process spectral report
  257. * @pdev: Pointer to pdev object
  258. * @payload: Pointer to spectral report buffer
  259. *
  260. * Return: status
  261. */
  262. int
  263. tgt_spectral_process_report(struct wlan_objmgr_pdev *pdev,
  264. void *payload);
  265. /**
  266. * tgt_spectral_register_to_dbr() - Register to direct DMA
  267. * @pdev: Pointer to pdev object
  268. *
  269. * Return: QDF_STATUS
  270. */
  271. QDF_STATUS
  272. tgt_spectral_register_to_dbr(struct wlan_objmgr_pdev *pdev);
  273. /**
  274. * tgt_spectral_unregister_to_dbr() - Register to direct DMA
  275. * @pdev: Pointer to pdev object
  276. *
  277. * Return: QDF_STATUS
  278. */
  279. QDF_STATUS
  280. tgt_spectral_unregister_to_dbr(struct wlan_objmgr_pdev *pdev);
  281. /**
  282. * tgt_spectral_get_target_type() - Get target type
  283. * @psoc: Pointer to psoc object
  284. *
  285. * Return: target type
  286. */
  287. uint32_t
  288. tgt_spectral_get_target_type(struct wlan_objmgr_psoc *psoc);
  289. /**
  290. * tgt_set_spectral_dma_debug() - Set DMA debug for Spectral
  291. * @pdev: Pointer to pdev object
  292. * @dma_debug_type: Type of Spectral DMA debug i.e., ring or buffer debug
  293. * @dma_debug_enable: Value to be set for @dma_debug_type
  294. *
  295. * Return: QDF_STATUS of operation
  296. */
  297. QDF_STATUS tgt_set_spectral_dma_debug(struct wlan_objmgr_pdev *pdev,
  298. enum spectral_dma_debug dma_debug_type,
  299. bool dma_debug_enable);
  300. /**
  301. * tgt_spectral_register_events() - Register Spectral WMI event handlers
  302. * @psoc: Pointer to psoc object
  303. *
  304. * Return: QDF_STATUS of operation
  305. */
  306. QDF_STATUS
  307. tgt_spectral_register_events(struct wlan_objmgr_psoc *psoc);
  308. /**
  309. * tgt_spectral_unregister_events() - Unregister Spectral WMI event handlers
  310. * @psoc: Pointer to psoc object
  311. *
  312. * Return: QDF_STATUS of operation
  313. */
  314. QDF_STATUS
  315. tgt_spectral_unregister_events(struct wlan_objmgr_psoc *psoc);
  316. /**
  317. * tgt_spectral_init_pdev_feature_caps() - Init pdev spectral feature caps
  318. * @pdev: pdev handle
  319. *
  320. * Return: QDF_STATUS
  321. */
  322. QDF_STATUS
  323. tgt_spectral_init_pdev_feature_caps(struct wlan_objmgr_pdev *pdev);
  324. #endif /* _WLAN_SPECTRAL_TGT_API_H_ */