wmi_unified_ap_api.h 25 KB

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