wmi_unified_ap_api.h 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769
  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_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_extract_vdev_peer_delete_all_response_event() -
  466. * extract vdev id from peer delete all response event
  467. * @wmi_handle: wmi handle
  468. * @evt_buf: pointer to event buffer
  469. * @param: Pointer to hold evt buf
  470. *
  471. * Return: QDF_STATUS_SUCCESS for success or error code
  472. */
  473. QDF_STATUS wmi_extract_vdev_peer_delete_all_response_event(
  474. wmi_unified_t wmi_handle,
  475. uint8_t *evt_buf,
  476. struct wmi_host_vdev_peer_delete_all_response_event *param);
  477. /**
  478. * wmi_send_bcn_offload_control_cmd - send beacon ofload control cmd to fw
  479. * @wmi_hdl: wmi handle
  480. * @bcn_ctrl_param: pointer to bcn_offload_control param
  481. *
  482. * Return: QDF_STATUS_SUCCESS for success or error code
  483. */
  484. QDF_STATUS wmi_send_bcn_offload_control_cmd(
  485. wmi_unified_t wmi_handle,
  486. struct bcn_offload_control *bcn_ctrl_param);
  487. #ifdef WLAN_SUPPORT_FILS
  488. /**
  489. * wmi_unified_fils_vdev_config_send_cmd() - send FILS config cmd to fw
  490. * @wmi_hdl: wmi handle
  491. * @param: fils config params
  492. *
  493. * Return: QDF_STATUS_SUCCESS for success or error code
  494. */
  495. QDF_STATUS
  496. wmi_unified_fils_vdev_config_send_cmd(wmi_unified_t wmi_handle,
  497. struct config_fils_params *param);
  498. /**
  499. * wmi_extract_swfda_vdev_id() - api to extract vdev id
  500. * @wmi_hdl: wmi handle
  501. * @evt_buf: pointer to event buffer
  502. * @vdev_id: pointer to vdev id
  503. *
  504. * Return: QDF_STATUS_SUCCESS for success or error code
  505. */
  506. QDF_STATUS wmi_extract_swfda_vdev_id(wmi_unified_t wmi_handle, void *evt_buf,
  507. uint32_t *vdev_id);
  508. /**
  509. * wmi_unified_fils_discovery_send_cmd() - send FILS discovery cmd to fw
  510. * @wmi_hdl: wmi handle
  511. * @param: fils discovery params
  512. *
  513. * Return: QDF_STATUS_SUCCESS for success or error code
  514. */
  515. QDF_STATUS wmi_unified_fils_discovery_send_cmd(wmi_unified_t wmi_handle,
  516. struct fd_params *param);
  517. #endif /* WLAN_SUPPORT_FILS */
  518. /**
  519. * wmi_unified_set_qboost_param_cmd_send() - WMI set_qboost function
  520. * @wmi_handle: handle to WMI.
  521. * @macaddr: MAC address
  522. * @param: pointer to hold set_qboost parameter
  523. *
  524. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  525. */
  526. QDF_STATUS
  527. wmi_unified_set_qboost_param_cmd_send(wmi_unified_t wmi_handle,
  528. uint8_t macaddr[QDF_MAC_ADDR_SIZE],
  529. struct set_qboost_params *param);
  530. /**
  531. * wmi_unified_gpio_config_cmd_send() - WMI gpio config function
  532. * @wmi_handle: handle to WMI.
  533. * @param: pointer to hold gpio config param
  534. *
  535. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  536. */
  537. QDF_STATUS wmi_unified_gpio_config_cmd_send(wmi_unified_t wmi_handle,
  538. struct gpio_config_params *param);
  539. /**
  540. * wmi_unified_gpio_output_cmd_send() - WMI gpio config function
  541. * @wmi_handle: handle to WMI.
  542. * @param param: pointer to hold gpio config param
  543. *
  544. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  545. */
  546. QDF_STATUS wmi_unified_gpio_output_cmd_send(wmi_unified_t wmi_handle,
  547. struct gpio_output_params *param);
  548. /**
  549. * wmi_unified_mcast_group_update_cmd_send() - WMI mcast grp update cmd function
  550. * @wmi_handle: handle to WMI.
  551. * @param: pointer to hold mcast grp param
  552. *
  553. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  554. */
  555. QDF_STATUS
  556. wmi_unified_mcast_group_update_cmd_send(wmi_unified_t wmi_handle,
  557. struct mcast_group_update_params *param);
  558. /**
  559. * wmi_unified_pdev_qvit_cmd_send() - WMI pdev qvit cmd function
  560. * @wmi_handle: handle to WMI.
  561. * @param: pointer to hold qvit param
  562. *
  563. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  564. */
  565. QDF_STATUS wmi_unified_pdev_qvit_cmd_send(wmi_unified_t wmi_handle,
  566. struct pdev_qvit_params *param);
  567. /**
  568. * wmi_unified_wmm_update_cmd_send() - WMI wmm update cmd function
  569. * @wmi_handle: handle to WMI.
  570. * @param: pointer to hold wmm param
  571. *
  572. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  573. */
  574. QDF_STATUS wmi_unified_wmm_update_cmd_send(wmi_unified_t wmi_handle,
  575. struct wmm_update_params *param);
  576. /**
  577. * wmi_extract_vdev_start_resp() - extract vdev start response
  578. * @wmi_handle: wmi handle
  579. * @evt_buf: pointer to event buffer
  580. * @vdev_rsp: Pointer to hold vdev response
  581. *
  582. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  583. */
  584. QDF_STATUS wmi_extract_vdev_start_resp(
  585. wmi_unified_t wmi_handle, void *evt_buf,
  586. wmi_host_vdev_start_resp *vdev_rsp);
  587. /**
  588. * wmi_extract_vdev_delete_resp - api to extract vdev delete
  589. * response event params
  590. * @wmi_handle: wma handle
  591. * @evt_buf: pointer to event buffer
  592. * @delele_rsp: pointer to hold delete response from firmware
  593. *
  594. * Return: QDF_STATUS_SUCCESS for successful event parse
  595. * else QDF_STATUS_E_INVAL or QDF_STATUS_E_FAILURE
  596. */
  597. QDF_STATUS wmi_extract_vdev_delete_resp(
  598. wmi_unified_t wmi_handle, void *evt_buf,
  599. struct wmi_host_vdev_delete_resp *delele_rsp);
  600. /**
  601. * wmi_extract_vdev_stopped_param() - extract vdev stop param from event
  602. * @wmi_handle: wmi handle
  603. * @evt_buf: pointer to event buffer
  604. * @vdev_id: Pointer to hold vdev identifier
  605. *
  606. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  607. */
  608. QDF_STATUS wmi_extract_vdev_stopped_param(wmi_unified_t wmi_handle,
  609. void *evt_buf,
  610. uint32_t *vdev_id);
  611. /**
  612. * wmi_extract_mgmt_tx_compl_param() - extract mgmt tx completion param
  613. * from event
  614. * @wmi_hdl: wmi handle
  615. * @evt_buf: pointer to event buffer
  616. * @param: Pointer to mgmt tx completion param
  617. *
  618. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  619. */
  620. QDF_STATUS wmi_extract_mgmt_tx_compl_param(
  621. wmi_unified_t wmi_handle, void *evt_buf,
  622. wmi_host_mgmt_tx_compl_event *param);
  623. /**
  624. * wmi_extract_chan_info_event() - extract chan information from event
  625. * @wmi_handle: wmi handle
  626. * @evt_buf: pointer to event buffer
  627. * @chan_info: Pointer to hold chan information
  628. *
  629. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  630. */
  631. QDF_STATUS wmi_extract_chan_info_event(
  632. wmi_unified_t wmi_handle, void *evt_buf,
  633. wmi_host_chan_info_event *chan_info);
  634. /**
  635. * wmi_extract_channel_hopping_event() - extract channel hopping param
  636. * from event
  637. * @wmi_handle: wmi handle
  638. * @evt_buf: pointer to event buffer
  639. * @ch_hopping: Pointer to hold channel hopping param
  640. *
  641. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  642. */
  643. QDF_STATUS wmi_extract_channel_hopping_event(
  644. wmi_unified_t wmi_handle, void *evt_buf,
  645. wmi_host_pdev_channel_hopping_event *ch_hopping);
  646. /**
  647. * wmi_unified_peer_chan_width_switch_cmd_send() - WMI send peer chan width
  648. * @wmi_hdl: handle to WMI
  649. * @param: pointer to hold peer capability param
  650. *
  651. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  652. */
  653. QDF_STATUS wmi_unified_peer_chan_width_switch_cmd_send(
  654. wmi_unified_t wmi_handle,
  655. struct peer_chan_width_switch_params *param);
  656. /**
  657. * wmi_unified_peer_del_all_wds_entries_cmd_send() - send delete
  658. * all wds entries cmd to fw
  659. * @wmi_hdl: wmi handle
  660. * @param: delete all wds entries params
  661. *
  662. * Return: QDF_STATUS_SUCCESS for success or error code
  663. */
  664. QDF_STATUS wmi_unified_peer_del_all_wds_entries_cmd_send(
  665. wmi_unified_t wmi_handle,
  666. struct peer_del_all_wds_entries_params *param);
  667. /**
  668. * wmi_unified_vdev_pcp_tid_map_cmd_send() - WMI set vap pcp
  669. * tid map cmd function
  670. * @wmi_handle: handle to WMI.
  671. * @param: pointer to hold pcp param
  672. *
  673. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  674. */
  675. QDF_STATUS wmi_unified_vdev_pcp_tid_map_cmd_send(
  676. wmi_unified_t wmi_handle,
  677. struct vap_pcp_tid_map_params *param);
  678. /**
  679. * wmi_unified_vdev_tidmap_prec_cmd_send() - WMI set vap tidmap precedence
  680. * cmd function
  681. * @wmi_handle: handle to WMI.
  682. * @param: pointer to hold precedence param
  683. *
  684. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  685. */
  686. QDF_STATUS wmi_unified_vdev_tidmap_prec_cmd_send(
  687. wmi_unified_t wmi_handle,
  688. struct vap_tidmap_prec_params *param);
  689. #ifdef WLAN_SUPPORT_RX_PROTOCOL_TYPE_TAG
  690. /**
  691. * wmi_unified_set_rx_pkt_type_routing_tag() - api to add/delete
  692. * the protocols to be tagged by CCE
  693. * @wmi_hdl: wmi handle
  694. * @param: Packet routing/tagging info
  695. *
  696. * Return: QDF_STATUS_SUCCESS for success or error code
  697. */
  698. QDF_STATUS wmi_unified_set_rx_pkt_type_routing_tag(
  699. wmi_unified_t wmi_handle,
  700. struct wmi_rx_pkt_protocol_routing_info *param);
  701. #endif /* WLAN_SUPPORT_RX_PROTOCOL_TYPE_TAG */
  702. #endif /* _WMI_UNIFIED_AP_API_H_ */