wmi_unified_ap_api.h 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781
  1. /*
  2. * Copyright (c) 2013-2018,2020 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. * This file contains the API definitions for the generic AP WMIs
  20. */
  21. #ifndef _WMI_UNIFIED_AP_API_H_
  22. #define _WMI_UNIFIED_AP_API_H_
  23. #include "wmi_unified_param.h"
  24. /**
  25. * wmi_unified_beacon_send_cmd() - WMI beacon send function
  26. * @wmi_handle: handle to WMI.
  27. * @macaddr: MAC address
  28. * @param: pointer to hold beacon send cmd parameter
  29. *
  30. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  31. */
  32. QDF_STATUS wmi_unified_beacon_send_cmd(wmi_unified_t wmi_handle,
  33. struct beacon_params *param);
  34. /**
  35. * wmi_unified_pdev_get_tpc_config_cmd_send() - WMI get tpc config function
  36. * @wmi_handle: handle to WMI.
  37. * @param: tpc config param
  38. *
  39. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  40. */
  41. QDF_STATUS wmi_unified_pdev_get_tpc_config_cmd_send(wmi_unified_t wmi_handle,
  42. uint32_t param);
  43. /**
  44. * wmi_send_pdev_caldata_version_check_cmd() - send reset peer mumimo
  45. * tx count to fw
  46. * @wmi_handle: wmi handle
  47. * @value: value
  48. *
  49. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  50. */
  51. QDF_STATUS wmi_send_pdev_caldata_version_check_cmd(wmi_unified_t wmi_handle,
  52. uint32_t value);
  53. /**
  54. * wmi_unified_set_ht_ie_cmd_send() - WMI set channel cmd function
  55. * @wmi_handle: handle to WMI.
  56. * @param: pointer to hold channel param
  57. *
  58. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  59. */
  60. QDF_STATUS wmi_unified_set_ht_ie_cmd_send(wmi_unified_t wmi_handle,
  61. struct ht_ie_params *param);
  62. /**
  63. * wmi_unified_set_vht_ie_cmd_send() - WMI set channel cmd function
  64. * @wmi_handle: handle to WMI.
  65. * @param: pointer to hold channel param
  66. *
  67. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  68. */
  69. QDF_STATUS wmi_unified_set_vht_ie_cmd_send(wmi_unified_t wmi_handle,
  70. struct vht_ie_params *param);
  71. /**
  72. * wmi_unified_set_ctl_table_cmd_send() - WMI ctl table cmd function
  73. * @wmi_handle: handle to WMI.
  74. * @param: pointer to hold ctl table param
  75. *
  76. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  77. */
  78. QDF_STATUS wmi_unified_set_ctl_table_cmd_send(wmi_unified_t wmi_handle,
  79. struct ctl_table_params *param);
  80. /**
  81. * wmi_unified_set_mimogain_table_cmd_send() - WMI set mimogain cmd function
  82. * @wmi_handle: handle to WMI.
  83. * @param: pointer to hold mimogain param
  84. *
  85. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  86. */
  87. QDF_STATUS wmi_unified_set_mimogain_table_cmd_send(
  88. wmi_unified_t wmi_handle,
  89. struct mimogain_table_params *param);
  90. /**
  91. * wmi_unified_peer_add_wds_entry_cmd_send() - WMI add wds entry cmd function
  92. * @wmi_handle: handle to WMI.
  93. * @param: pointer to hold wds entry param
  94. *
  95. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  96. */
  97. QDF_STATUS wmi_unified_peer_add_wds_entry_cmd_send(
  98. wmi_unified_t wmi_handle,
  99. struct peer_add_wds_entry_params *param);
  100. /**
  101. * wmi_unified_peer_del_wds_entry_cmd_send() - WMI del wds entry cmd function
  102. * @wmi_handle: handle to WMI.
  103. * @param: pointer to hold wds entry param
  104. *
  105. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  106. */
  107. QDF_STATUS wmi_unified_peer_del_wds_entry_cmd_send(
  108. wmi_unified_t wmi_handle,
  109. struct peer_del_wds_entry_params *param);
  110. /**
  111. * wmi_unified_peer_update_wds_entry_cmd_send() - WMI update wds entry
  112. * cmd function
  113. * @wmi_handle: handle to WMI.
  114. * @param: pointer to hold wds entry param
  115. *
  116. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  117. */
  118. QDF_STATUS wmi_unified_peer_update_wds_entry_cmd_send(
  119. wmi_unified_t wmi_handle,
  120. struct peer_update_wds_entry_params *param);
  121. /**
  122. * wmi_unified_peer_ft_roam_send() - reset BA window in fw
  123. * @wmi_handle: wmi handle
  124. * @peer_addr: peer mac address
  125. * @vdev_id: vdev id
  126. *
  127. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  128. */
  129. QDF_STATUS
  130. wmi_unified_peer_ft_roam_send(wmi_unified_t wmi_handle,
  131. uint8_t peer_addr[QDF_MAC_ADDR_SIZE],
  132. uint8_t vdev_id);
  133. /**
  134. * wmi_unified_vdev_set_neighbour_rx_cmd_send() - WMI set neighbour rx function
  135. * @wmi_handle: handle to WMI.
  136. * @macaddr: MAC address
  137. * @param: pointer to hold neighbour rx parameter
  138. *
  139. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  140. */
  141. QDF_STATUS wmi_unified_vdev_set_neighbour_rx_cmd_send(
  142. wmi_unified_t wmi_handle,
  143. uint8_t macaddr[QDF_MAC_ADDR_SIZE],
  144. struct set_neighbour_rx_params *param);
  145. /**
  146. * wmi_unified_vdev_config_ratemask_cmd_send() - WMI config ratemask function
  147. * @wmi_handle: handle to WMI.
  148. * @param: pointer to hold config ratemask param
  149. *
  150. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  151. */
  152. QDF_STATUS wmi_unified_vdev_config_ratemask_cmd_send(
  153. wmi_unified_t wmi_handle,
  154. struct config_ratemask_params *param);
  155. /**
  156. * wmi_unified_set_quiet_mode_cmd_send() - WMI set quiet mode function
  157. * @wmi_handle: handle to WMI.
  158. * @param: pointer to hold quiet mode param
  159. *
  160. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  161. */
  162. QDF_STATUS wmi_unified_set_quiet_mode_cmd_send(
  163. wmi_unified_t wmi_handle,
  164. struct set_quiet_mode_params *param);
  165. /**
  166. * wmi_unified_set_bcn_offload_quiet_mode_cmd_send - WMI set quiet mode
  167. * function in beacon offload case
  168. * @wmi_handle: handle to WMI.
  169. * @param: pointer to hold quiet mode param in bcn offload
  170. *
  171. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  172. */
  173. QDF_STATUS wmi_unified_set_bcn_offload_quiet_mode_cmd_send(
  174. wmi_unified_t wmi_handle,
  175. struct set_bcn_offload_quiet_mode_params *param);
  176. /**
  177. * wmi_unified_nf_dbr_dbm_info_get_cmd_send() - WMI request nf info function
  178. * @wmi_handle: handle to WMI.
  179. * @mac_id: mac_id
  180. *
  181. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  182. */
  183. QDF_STATUS wmi_unified_nf_dbr_dbm_info_get_cmd_send(wmi_unified_t wmi_handle,
  184. uint8_t mac_id);
  185. /**
  186. * wmi_unified_packet_power_info_get_cmd_send() - WMI get packet power
  187. * info function
  188. * @wmi_handle: handle to WMI.
  189. * @param: pointer to hold packet power info param
  190. *
  191. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  192. */
  193. QDF_STATUS wmi_unified_packet_power_info_get_cmd_send(
  194. wmi_unified_t wmi_handle,
  195. struct packet_power_info_params *param);
  196. /**
  197. * wmi_extract_wds_addr_event - Extract WDS addr WMI event
  198. * @wmi_handle: handle to WMI.
  199. * @evt_buf: pointer to event buffer
  200. * @len: length of the event buffer
  201. * @wds_ev: pointer to strct to extract
  202. *
  203. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  204. */
  205. QDF_STATUS wmi_extract_wds_addr_event(
  206. wmi_unified_t wmi_handle,
  207. void *evt_buf, uint16_t len, wds_addr_event_t *wds_ev);
  208. /**
  209. * wmi_extract_dcs_interference_type() - extract dcs interference type
  210. * @wmi_handle: wmi handle
  211. * @evt_buf: pointer to event buffer
  212. * @param: Pointer to hold dcs interference param
  213. *
  214. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  215. */
  216. QDF_STATUS wmi_extract_dcs_interference_type(
  217. wmi_unified_t wmi_handle,
  218. void *evt_buf, struct wmi_host_dcs_interference_param *param);
  219. /*
  220. * wmi_extract_dcs_cw_int() - extract dcs cw interference from event
  221. * @wmi_handle: wmi handle
  222. * @evt_buf: pointer to event buffer
  223. * @cw_int: Pointer to hold cw interference
  224. *
  225. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  226. */
  227. QDF_STATUS wmi_extract_dcs_cw_int(wmi_unified_t wmi_handle, void *evt_buf,
  228. wmi_host_ath_dcs_cw_int *cw_int);
  229. /**
  230. * wmi_extract_dcs_im_tgt_stats() - extract dcs im target stats from event
  231. * @wmi_handle: wmi handle
  232. * @evt_buf: pointer to event buffer
  233. * @wlan_stat: Pointer to hold wlan stats
  234. *
  235. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  236. */
  237. QDF_STATUS wmi_extract_dcs_im_tgt_stats(
  238. wmi_unified_t wmi_handle, void *evt_buf,
  239. wmi_host_dcs_im_tgt_stats_t *wlan_stat);
  240. /**
  241. * wmi_extract_tbttoffset_update_params() - extract tbtt offset update param
  242. * @wmi_handle: wmi handle
  243. * @evt_buf: pointer to event buffer
  244. * @idx: Index referring to a vdev
  245. * @tbtt_param: Pointer to tbttoffset event param
  246. *
  247. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  248. */
  249. QDF_STATUS wmi_extract_tbttoffset_update_params(
  250. wmi_unified_t wmi_handle, void *evt_buf,
  251. uint8_t idx, struct tbttoffset_params *tbtt_param);
  252. /**
  253. * wmi_extract_ext_tbttoffset_update_params() - extract tbtt offset update param
  254. * @wmi_handle: wmi handle
  255. * @evt_buf: pointer to event buffer
  256. * @idx: Index referring to a vdev
  257. * @tbtt_param: Pointer to tbttoffset event param
  258. *
  259. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  260. */
  261. QDF_STATUS wmi_extract_ext_tbttoffset_update_params(
  262. wmi_unified_t wmi_handle,
  263. void *evt_buf, uint8_t idx,
  264. struct tbttoffset_params *tbtt_param);
  265. /**
  266. * wmi_extract_tbttoffset_num_vdevs() - extract tbtt offset num vdev
  267. * @wmi_handle: wmi handle
  268. * @evt_buf: pointer to event buffer
  269. * @vdev_map: Pointer to hold num vdev
  270. *
  271. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  272. */
  273. QDF_STATUS wmi_extract_tbttoffset_num_vdevs(wmi_unified_t wmi_handle,
  274. void *evt_buf,
  275. uint32_t *num_vdevs);
  276. /**
  277. * wmi_extract_ext_tbttoffset_num_vdevs() - extract ext tbtt offset num vdev
  278. * @wmi_handle: wmi handle
  279. * @evt_buf: pointer to event buffer
  280. * @vdev_map: Pointer to hold num vdev
  281. *
  282. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  283. */
  284. QDF_STATUS wmi_extract_ext_tbttoffset_num_vdevs(wmi_unified_t wmi_handle,
  285. void *evt_buf,
  286. uint32_t *num_vdevs);
  287. /**
  288. * wmi_extract_pdev_caldata_version_check_ev_param() - extract caldata
  289. * from event
  290. * @wmi_handle: wmi handle
  291. * @evt_buf: pointer to event buffer
  292. * @param: Pointer to hold caldata version data
  293. *
  294. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  295. */
  296. QDF_STATUS wmi_extract_pdev_caldata_version_check_ev_param(
  297. wmi_unified_t wmi_handle,
  298. void *evt_buf, wmi_host_pdev_check_cal_version_event *param);
  299. /**
  300. * wmi_extract_pdev_tpc_config_ev_param() - extract pdev tpc configuration
  301. * param from event
  302. * @wmi_handle: wmi handle
  303. * @evt_buf: pointer to event buffer
  304. * @param: Pointer to hold tpc configuration
  305. *
  306. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  307. */
  308. QDF_STATUS wmi_extract_pdev_tpc_config_ev_param(
  309. wmi_unified_t wmi_handle, void *evt_buf,
  310. wmi_host_pdev_tpc_config_event *param);
  311. /**
  312. * wmi_extract_nfcal_power_ev_param() - extract noise floor calibration
  313. * power param from event
  314. * @wmi_handle: wmi handle
  315. * @evt_buf: pointer to event buffer
  316. * @param: Pointer to hold nf cal power param
  317. *
  318. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  319. */
  320. QDF_STATUS wmi_extract_nfcal_power_ev_param(
  321. wmi_unified_t wmi_handle, void *evt_buf,
  322. wmi_host_pdev_nfcal_power_all_channels_event *param);
  323. /**
  324. * wmi_extract_pdev_tpc_ev_param() - extract tpc param from event
  325. * @wmi_handle: wmi handle
  326. * @evt_buf: pointer to event buffer
  327. * @param: Pointer to hold tpc param
  328. *
  329. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  330. */
  331. QDF_STATUS wmi_extract_pdev_tpc_ev_param(
  332. wmi_unified_t wmi_handle, void *evt_buf,
  333. wmi_host_pdev_tpc_event *param);
  334. /**
  335. * wmi_extract_offchan_data_tx_compl_param() -
  336. * extract offchan data tx completion param from event
  337. * @wmi_hdl: wmi handle
  338. * @evt_buf: pointer to event buffer
  339. * @param: Pointer to offchan data tx completion param
  340. *
  341. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  342. */
  343. QDF_STATUS wmi_extract_offchan_data_tx_compl_param(
  344. wmi_unified_t wmi_handle, void *evt_buf,
  345. struct wmi_host_offchan_data_tx_compl_event *param);
  346. /**
  347. * wmi_extract_pdev_csa_switch_count_status() - extract CSA switch count status
  348. * from event
  349. * @wmi_handle: wmi handle
  350. * @evt_buf: pointer to event buffer
  351. * @param: Pointer to CSA switch count status param
  352. *
  353. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  354. */
  355. QDF_STATUS wmi_extract_pdev_csa_switch_count_status(
  356. wmi_unified_t wmi_handle,
  357. void *evt_buf,
  358. struct pdev_csa_switch_count_status *param);
  359. /**
  360. * wmi_extract_swba_num_vdevs() - extract swba num vdevs from event
  361. * @wmi_handle: wmi handle
  362. * @evt_buf: pointer to event buffer
  363. * @num_vdevs: Pointer to hold num vdevs
  364. *
  365. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  366. */
  367. QDF_STATUS wmi_extract_swba_num_vdevs(wmi_unified_t wmi_handle, void *evt_buf,
  368. uint32_t *num_vdevs);
  369. /**
  370. * wmi_extract_swba_tim_info() - extract swba tim info from event
  371. * @wmi_handle: wmi handle
  372. * @evt_buf: pointer to event buffer
  373. * @idx: Index to bcn info
  374. * @tim_info: Pointer to hold tim info
  375. *
  376. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  377. */
  378. QDF_STATUS wmi_extract_swba_tim_info(
  379. wmi_unified_t wmi_handle, void *evt_buf,
  380. uint32_t idx, wmi_host_tim_info *tim_info);
  381. /**
  382. * wmi_extract_swba_quiet_info() - extract swba quiet info from event
  383. * @wmi_handle: wmi handle
  384. * @evt_buf: pointer to event buffer
  385. * @idx: Index to bcn info
  386. * @quiet_info: Pointer to hold quiet info
  387. *
  388. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  389. */
  390. QDF_STATUS wmi_extract_swba_quiet_info(wmi_unified_t wmi_handle, void *evt_buf,
  391. uint32_t idx,
  392. wmi_host_quiet_info *quiet_info);
  393. /**
  394. * wmi_extract_swba_noa_info() - extract swba NoA information from event
  395. * @wmi_handle: wmi handle
  396. * @evt_buf: pointer to event buffer
  397. * @idx: Index to bcn info
  398. * @p2p_desc: Pointer to hold p2p NoA info
  399. *
  400. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  401. */
  402. QDF_STATUS wmi_extract_swba_noa_info(wmi_unified_t wmi_handle, void *evt_buf,
  403. uint32_t idx,
  404. wmi_host_p2p_noa_info *p2p_desc);
  405. /**
  406. * wmi_extract_peer_sta_ps_statechange_ev() - extract peer sta ps state
  407. * from event
  408. * @wmi_handle: wmi handle
  409. * @evt_buf: pointer to event buffer
  410. * @ev: Pointer to hold peer param and ps state
  411. *
  412. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  413. */
  414. QDF_STATUS wmi_extract_peer_sta_ps_statechange_ev(
  415. wmi_unified_t wmi_handle,
  416. void *evt_buf, wmi_host_peer_sta_ps_statechange_event *ev);
  417. /**
  418. * wmi_extract_peer_sta_kickout_ev() - extract peer sta kickout event
  419. * @wmi_handle: wmi handle
  420. * @evt_buf: pointer to event buffer
  421. * @ev: Pointer to hold peer param
  422. *
  423. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  424. */
  425. QDF_STATUS wmi_extract_peer_sta_kickout_ev(
  426. wmi_unified_t wmi_handle, void *evt_buf,
  427. wmi_host_peer_sta_kickout_event *ev);
  428. /**
  429. * wmi_extract_inst_rssi_stats_event() - extract inst rssi stats from event
  430. * @wmi_handle: wmi handle
  431. * @evt_buf: pointer to event buffer
  432. * @inst_rssi_resp: Pointer to hold inst rssi response
  433. *
  434. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  435. */
  436. QDF_STATUS wmi_extract_inst_rssi_stats_event(
  437. wmi_unified_t wmi_handle, void *evt_buf,
  438. wmi_host_inst_stats_resp *inst_rssi_resp);
  439. /**
  440. * wmi_unified_send_multiple_vdev_restart_req_cmd() - send multiple vdev restart
  441. * @wmi_handle: wmi handle
  442. * @param: multiple vdev restart parameter
  443. *
  444. * Send WMI_PDEV_MULTIPLE_VDEV_RESTART_REQUEST_CMDID parameters to fw.
  445. *
  446. * Return: QDF_STATUS_SUCCESS on success, QDF_STATUS_E_** on error
  447. */
  448. QDF_STATUS wmi_unified_send_multiple_vdev_restart_req_cmd(
  449. wmi_unified_t wmi_handle,
  450. struct multiple_vdev_restart_params *param);
  451. /**
  452. * wmi_extract_peer_delete_response_event() -
  453. * extract vdev id and peer mac addresse from peer delete response event
  454. * @wmi_handle: wmi handle
  455. * @evt_buf: pointer to event buffer
  456. * @param: Pointer to hold evt buf
  457. *
  458. * Return: QDF_STATUS_SUCCESS for success or error code
  459. */
  460. QDF_STATUS wmi_extract_peer_delete_response_event(
  461. wmi_unified_t wmi_handle,
  462. uint8_t *evt_buf,
  463. struct wmi_host_peer_delete_response_event *param);
  464. /**
  465. * wmi_send_bcn_offload_control_cmd - send beacon ofload control cmd to fw
  466. * @wmi_hdl: wmi handle
  467. * @bcn_ctrl_param: pointer to bcn_offload_control param
  468. *
  469. * Return: QDF_STATUS_SUCCESS for success or error code
  470. */
  471. QDF_STATUS wmi_send_bcn_offload_control_cmd(
  472. wmi_unified_t wmi_handle,
  473. struct bcn_offload_control *bcn_ctrl_param);
  474. #ifdef WLAN_SUPPORT_FILS
  475. /**
  476. * wmi_unified_fils_vdev_config_send_cmd() - send FILS config cmd to fw
  477. * @wmi_hdl: wmi handle
  478. * @param: fils config params
  479. *
  480. * Return: QDF_STATUS_SUCCESS for success or error code
  481. */
  482. QDF_STATUS
  483. wmi_unified_fils_vdev_config_send_cmd(wmi_unified_t wmi_handle,
  484. struct config_fils_params *param);
  485. /**
  486. * wmi_extract_swfda_vdev_id() - api to extract vdev id
  487. * @wmi_hdl: wmi handle
  488. * @evt_buf: pointer to event buffer
  489. * @vdev_id: pointer to vdev id
  490. *
  491. * Return: QDF_STATUS_SUCCESS for success or error code
  492. */
  493. QDF_STATUS wmi_extract_swfda_vdev_id(wmi_unified_t wmi_handle, void *evt_buf,
  494. uint32_t *vdev_id);
  495. /**
  496. * wmi_unified_fils_discovery_send_cmd() - send FILS discovery cmd to fw
  497. * @wmi_hdl: wmi handle
  498. * @param: fils discovery params
  499. *
  500. * Return: QDF_STATUS_SUCCESS for success or error code
  501. */
  502. QDF_STATUS wmi_unified_fils_discovery_send_cmd(wmi_unified_t wmi_handle,
  503. struct fd_params *param);
  504. #endif /* WLAN_SUPPORT_FILS */
  505. /**
  506. * wmi_unified_set_qboost_param_cmd_send() - WMI set_qboost function
  507. * @wmi_handle: handle to WMI.
  508. * @macaddr: MAC address
  509. * @param: pointer to hold set_qboost parameter
  510. *
  511. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  512. */
  513. QDF_STATUS
  514. wmi_unified_set_qboost_param_cmd_send(wmi_unified_t wmi_handle,
  515. uint8_t macaddr[QDF_MAC_ADDR_SIZE],
  516. struct set_qboost_params *param);
  517. /**
  518. * wmi_unified_gpio_config_cmd_send() - WMI gpio config function
  519. * @wmi_handle: handle to WMI.
  520. * @param: pointer to hold gpio config param
  521. *
  522. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  523. */
  524. QDF_STATUS wmi_unified_gpio_config_cmd_send(wmi_unified_t wmi_handle,
  525. struct gpio_config_params *param);
  526. /**
  527. * wmi_unified_gpio_output_cmd_send() - WMI gpio config function
  528. * @wmi_handle: handle to WMI.
  529. * @param param: pointer to hold gpio config param
  530. *
  531. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  532. */
  533. QDF_STATUS wmi_unified_gpio_output_cmd_send(wmi_unified_t wmi_handle,
  534. struct gpio_output_params *param);
  535. /**
  536. * wmi_unified_mcast_group_update_cmd_send() - WMI mcast grp update cmd function
  537. * @wmi_handle: handle to WMI.
  538. * @param: pointer to hold mcast grp param
  539. *
  540. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  541. */
  542. QDF_STATUS
  543. wmi_unified_mcast_group_update_cmd_send(wmi_unified_t wmi_handle,
  544. struct mcast_group_update_params *param);
  545. /**
  546. * wmi_unified_pdev_qvit_cmd_send() - WMI pdev qvit cmd function
  547. * @wmi_handle: handle to WMI.
  548. * @param: pointer to hold qvit param
  549. *
  550. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  551. */
  552. QDF_STATUS wmi_unified_pdev_qvit_cmd_send(wmi_unified_t wmi_handle,
  553. struct pdev_qvit_params *param);
  554. /**
  555. * wmi_unified_wmm_update_cmd_send() - WMI wmm update cmd function
  556. * @wmi_handle: handle to WMI.
  557. * @param: pointer to hold wmm param
  558. *
  559. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  560. */
  561. QDF_STATUS wmi_unified_wmm_update_cmd_send(wmi_unified_t wmi_handle,
  562. struct wmm_update_params *param);
  563. /**
  564. * wmi_extract_vdev_start_resp() - extract vdev start response
  565. * @wmi_handle: wmi handle
  566. * @evt_buf: pointer to event buffer
  567. * @vdev_rsp: Pointer to hold vdev response
  568. *
  569. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  570. */
  571. QDF_STATUS wmi_extract_vdev_start_resp(
  572. wmi_unified_t wmi_handle, void *evt_buf,
  573. wmi_host_vdev_start_resp *vdev_rsp);
  574. /**
  575. * wmi_extract_vdev_delete_resp - api to extract vdev delete
  576. * response event params
  577. * @wmi_handle: wma handle
  578. * @evt_buf: pointer to event buffer
  579. * @delele_rsp: pointer to hold delete response from firmware
  580. *
  581. * Return: QDF_STATUS_SUCCESS for successful event parse
  582. * else QDF_STATUS_E_INVAL or QDF_STATUS_E_FAILURE
  583. */
  584. QDF_STATUS wmi_extract_vdev_delete_resp(
  585. wmi_unified_t wmi_handle, void *evt_buf,
  586. struct wmi_host_vdev_delete_resp *delele_rsp);
  587. /**
  588. * wmi_extract_vdev_stopped_param() - extract vdev stop param from event
  589. * @wmi_handle: wmi handle
  590. * @evt_buf: pointer to event buffer
  591. * @vdev_id: Pointer to hold vdev identifier
  592. *
  593. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  594. */
  595. QDF_STATUS wmi_extract_vdev_stopped_param(wmi_unified_t wmi_handle,
  596. void *evt_buf,
  597. uint32_t *vdev_id);
  598. /**
  599. * wmi_extract_mgmt_tx_compl_param() - extract mgmt tx completion param
  600. * from event
  601. * @wmi_hdl: wmi handle
  602. * @evt_buf: pointer to event buffer
  603. * @param: Pointer to mgmt tx completion param
  604. *
  605. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  606. */
  607. QDF_STATUS wmi_extract_mgmt_tx_compl_param(
  608. wmi_unified_t wmi_handle, void *evt_buf,
  609. wmi_host_mgmt_tx_compl_event *param);
  610. /**
  611. * wmi_extract_chan_info_event() - extract chan information from event
  612. * @wmi_handle: wmi handle
  613. * @evt_buf: pointer to event buffer
  614. * @chan_info: Pointer to hold chan information
  615. *
  616. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  617. */
  618. QDF_STATUS wmi_extract_chan_info_event(
  619. wmi_unified_t wmi_handle, void *evt_buf,
  620. wmi_host_chan_info_event *chan_info);
  621. /**
  622. * wmi_extract_channel_hopping_event() - extract channel hopping param
  623. * from event
  624. * @wmi_handle: wmi handle
  625. * @evt_buf: pointer to event buffer
  626. * @ch_hopping: Pointer to hold channel hopping param
  627. *
  628. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  629. */
  630. QDF_STATUS wmi_extract_channel_hopping_event(
  631. wmi_unified_t wmi_handle, void *evt_buf,
  632. wmi_host_pdev_channel_hopping_event *ch_hopping);
  633. /**
  634. * wmi_unified_peer_chan_width_switch_cmd_send() - WMI send peer chan width
  635. * @wmi_hdl: handle to WMI
  636. * @param: pointer to hold peer capability param
  637. *
  638. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  639. */
  640. QDF_STATUS wmi_unified_peer_chan_width_switch_cmd_send(
  641. wmi_unified_t wmi_handle,
  642. struct peer_chan_width_switch_params *param);
  643. /**
  644. * wmi_unified_peer_del_all_wds_entries_cmd_send() - send delete
  645. * all wds entries cmd to fw
  646. * @wmi_hdl: wmi handle
  647. * @param: delete all wds entries params
  648. *
  649. * Return: QDF_STATUS_SUCCESS for success or error code
  650. */
  651. QDF_STATUS wmi_unified_peer_del_all_wds_entries_cmd_send(
  652. wmi_unified_t wmi_handle,
  653. struct peer_del_all_wds_entries_params *param);
  654. /**
  655. * wmi_unified_vdev_pcp_tid_map_cmd_send() - WMI set vap pcp
  656. * tid map cmd function
  657. * @wmi_handle: handle to WMI.
  658. * @param: pointer to hold pcp param
  659. *
  660. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  661. */
  662. QDF_STATUS wmi_unified_vdev_pcp_tid_map_cmd_send(
  663. wmi_unified_t wmi_handle,
  664. struct vap_pcp_tid_map_params *param);
  665. /**
  666. * wmi_unified_vdev_tidmap_prec_cmd_send() - WMI set vap tidmap precedence
  667. * cmd function
  668. * @wmi_handle: handle to WMI.
  669. * @param: pointer to hold precedence param
  670. *
  671. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  672. */
  673. QDF_STATUS wmi_unified_vdev_tidmap_prec_cmd_send(
  674. wmi_unified_t wmi_handle,
  675. struct vap_tidmap_prec_params *param);
  676. #ifdef WLAN_SUPPORT_RX_PROTOCOL_TYPE_TAG
  677. /**
  678. * wmi_unified_set_rx_pkt_type_routing_tag() - api to add/delete
  679. * the protocols to be tagged by CCE
  680. * @wmi_hdl: wmi handle
  681. * @param: Packet routing/tagging info
  682. *
  683. * Return: QDF_STATUS_SUCCESS for success or error code
  684. */
  685. QDF_STATUS wmi_unified_set_rx_pkt_type_routing_tag(
  686. wmi_unified_t wmi_handle,
  687. struct wmi_rx_pkt_protocol_routing_info *param);
  688. #endif /* WLAN_SUPPORT_RX_PROTOCOL_TYPE_TAG */
  689. /**
  690. * wmi_unified_peer_vlan_config_send() - WMI function to send vlan command
  691. *
  692. * @wmi_hdl: WMI handle
  693. * @peer_addr: Peer mac address
  694. * @param: struct peer_vlan_config_param *
  695. *
  696. * Return: QDF_STATUS_SUCCESS if success, else returns proper error code.
  697. */
  698. QDF_STATUS wmi_unified_peer_vlan_config_send(wmi_unified_t wmi_handle,
  699. uint8_t peer_addr[QDF_MAC_ADDR_SIZE],
  700. struct peer_vlan_config_param *param);
  701. /**
  702. * wmi_extract_muedca_params_handler() - WMI function to extract Muedca params
  703. *
  704. * @wmi_handle: WMI handle
  705. * @evt_buf: Event data buffer
  706. * @muedca_param_list: struct muedca_params
  707. *
  708. * Return: QDF_STATUS_SUCCESS if success, else returns proper error code.
  709. */
  710. QDF_STATUS wmi_extract_muedca_params_handler(wmi_unified_t wmi_handle,
  711. void *evt_buf, struct muedca_params *muedca_param_list);
  712. #endif /* _WMI_UNIFIED_AP_API_H_ */