wmi_unified_ap_api.h 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773
  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_swba_num_vdevs() - extract swba num vdevs from event
  348. * @wmi_handle: wmi handle
  349. * @evt_buf: pointer to event buffer
  350. * @num_vdevs: Pointer to hold num vdevs
  351. *
  352. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  353. */
  354. QDF_STATUS wmi_extract_swba_num_vdevs(wmi_unified_t wmi_handle, void *evt_buf,
  355. uint32_t *num_vdevs);
  356. /**
  357. * wmi_extract_swba_tim_info() - extract swba tim info from event
  358. * @wmi_handle: wmi handle
  359. * @evt_buf: pointer to event buffer
  360. * @idx: Index to bcn info
  361. * @tim_info: Pointer to hold tim info
  362. *
  363. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  364. */
  365. QDF_STATUS wmi_extract_swba_tim_info(
  366. wmi_unified_t wmi_handle, void *evt_buf,
  367. uint32_t idx, wmi_host_tim_info *tim_info);
  368. /**
  369. * wmi_extract_swba_quiet_info() - extract swba quiet info from event
  370. * @wmi_handle: wmi handle
  371. * @evt_buf: pointer to event buffer
  372. * @idx: Index to bcn info
  373. * @quiet_info: Pointer to hold quiet info
  374. *
  375. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  376. */
  377. QDF_STATUS wmi_extract_swba_quiet_info(wmi_unified_t wmi_handle, void *evt_buf,
  378. uint32_t idx,
  379. wmi_host_quiet_info *quiet_info);
  380. /**
  381. * wmi_extract_swba_noa_info() - extract swba NoA information from event
  382. * @wmi_handle: wmi handle
  383. * @evt_buf: pointer to event buffer
  384. * @idx: Index to bcn info
  385. * @p2p_desc: Pointer to hold p2p NoA info
  386. *
  387. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  388. */
  389. QDF_STATUS wmi_extract_swba_noa_info(wmi_unified_t wmi_handle, void *evt_buf,
  390. uint32_t idx,
  391. wmi_host_p2p_noa_info *p2p_desc);
  392. /**
  393. * wmi_extract_peer_sta_ps_statechange_ev() - extract peer sta ps state
  394. * from event
  395. * @wmi_handle: wmi handle
  396. * @evt_buf: pointer to event buffer
  397. * @ev: Pointer to hold peer param and ps state
  398. *
  399. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  400. */
  401. QDF_STATUS wmi_extract_peer_sta_ps_statechange_ev(
  402. wmi_unified_t wmi_handle,
  403. void *evt_buf, wmi_host_peer_sta_ps_statechange_event *ev);
  404. /**
  405. * wmi_extract_peer_sta_kickout_ev() - extract peer sta kickout event
  406. * @wmi_handle: wmi handle
  407. * @evt_buf: pointer to event buffer
  408. * @ev: Pointer to hold peer param
  409. *
  410. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  411. */
  412. QDF_STATUS wmi_extract_peer_sta_kickout_ev(
  413. wmi_unified_t wmi_handle, void *evt_buf,
  414. wmi_host_peer_sta_kickout_event *ev);
  415. /**
  416. * wmi_extract_inst_rssi_stats_event() - extract inst rssi stats from event
  417. * @wmi_handle: wmi handle
  418. * @evt_buf: pointer to event buffer
  419. * @inst_rssi_resp: Pointer to hold inst rssi response
  420. *
  421. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  422. */
  423. QDF_STATUS wmi_extract_inst_rssi_stats_event(
  424. wmi_unified_t wmi_handle, void *evt_buf,
  425. wmi_host_inst_stats_resp *inst_rssi_resp);
  426. /**
  427. * wmi_unified_send_multiple_vdev_restart_req_cmd() - send multiple vdev restart
  428. * @wmi_handle: wmi handle
  429. * @param: multiple vdev restart parameter
  430. *
  431. * Send WMI_PDEV_MULTIPLE_VDEV_RESTART_REQUEST_CMDID parameters to fw.
  432. *
  433. * Return: QDF_STATUS_SUCCESS on success, QDF_STATUS_E_** on error
  434. */
  435. QDF_STATUS wmi_unified_send_multiple_vdev_restart_req_cmd(
  436. wmi_unified_t wmi_handle,
  437. struct multiple_vdev_restart_params *param);
  438. /**
  439. * wmi_extract_peer_create_response_event() -
  440. * extract vdev id and peer mac address and status from peer create
  441. * 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_create_response_event(
  449. wmi_unified_t wmi_handle,
  450. uint8_t *evt_buf,
  451. struct wmi_host_peer_create_response_event *param);
  452. /**
  453. * wmi_extract_peer_delete_response_event() -
  454. * extract vdev id and peer mac addresse from peer delete 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_peer_delete_response_event(
  462. wmi_unified_t wmi_handle,
  463. uint8_t *evt_buf,
  464. struct wmi_host_peer_delete_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_mcast_group_update_cmd_send() - WMI mcast grp update cmd function
  520. * @wmi_handle: handle to WMI.
  521. * @param: pointer to hold mcast grp param
  522. *
  523. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  524. */
  525. QDF_STATUS
  526. wmi_unified_mcast_group_update_cmd_send(wmi_unified_t wmi_handle,
  527. struct mcast_group_update_params *param);
  528. /**
  529. * wmi_unified_pdev_qvit_cmd_send() - WMI pdev qvit cmd function
  530. * @wmi_handle: handle to WMI.
  531. * @param: pointer to hold qvit param
  532. *
  533. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  534. */
  535. QDF_STATUS wmi_unified_pdev_qvit_cmd_send(wmi_unified_t wmi_handle,
  536. struct pdev_qvit_params *param);
  537. /**
  538. * wmi_unified_wmm_update_cmd_send() - WMI wmm update cmd function
  539. * @wmi_handle: handle to WMI.
  540. * @param: pointer to hold wmm param
  541. *
  542. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  543. */
  544. QDF_STATUS wmi_unified_wmm_update_cmd_send(wmi_unified_t wmi_handle,
  545. struct wmm_update_params *param);
  546. /**
  547. * wmi_extract_vdev_start_resp() - extract vdev start response
  548. * @wmi_handle: wmi handle
  549. * @evt_buf: pointer to event buffer
  550. * @vdev_rsp: Pointer to hold vdev response
  551. *
  552. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  553. */
  554. QDF_STATUS wmi_extract_vdev_start_resp(
  555. wmi_unified_t wmi_handle, void *evt_buf,
  556. struct vdev_start_response *vdev_rsp);
  557. /**
  558. * wmi_extract_vdev_delete_resp - api to extract vdev delete
  559. * response event params
  560. * @wmi_handle: wma handle
  561. * @evt_buf: pointer to event buffer
  562. * @delele_rsp: pointer to hold delete response from firmware
  563. *
  564. * Return: QDF_STATUS_SUCCESS for successful event parse
  565. * else QDF_STATUS_E_INVAL or QDF_STATUS_E_FAILURE
  566. */
  567. QDF_STATUS wmi_extract_vdev_delete_resp(
  568. wmi_unified_t wmi_handle, void *evt_buf,
  569. struct vdev_delete_response *delele_rsp);
  570. /**
  571. * wmi_extract_vdev_stopped_param() - extract vdev stop param from event
  572. * @wmi_handle: wmi handle
  573. * @evt_buf: pointer to event buffer
  574. * @vdev_id: Pointer to hold vdev identifier
  575. *
  576. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  577. */
  578. QDF_STATUS wmi_extract_vdev_stopped_param(wmi_unified_t wmi_handle,
  579. void *evt_buf,
  580. uint32_t *vdev_id);
  581. /**
  582. * wmi_extract_mgmt_tx_compl_param() - extract mgmt tx completion param
  583. * from event
  584. * @wmi_hdl: wmi handle
  585. * @evt_buf: pointer to event buffer
  586. * @param: Pointer to mgmt tx completion param
  587. *
  588. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  589. */
  590. QDF_STATUS wmi_extract_mgmt_tx_compl_param(
  591. wmi_unified_t wmi_handle, void *evt_buf,
  592. wmi_host_mgmt_tx_compl_event *param);
  593. /**
  594. * wmi_extract_chan_info_event() - extract chan information from event
  595. * @wmi_handle: wmi handle
  596. * @evt_buf: pointer to event buffer
  597. * @chan_info: Pointer to hold chan information
  598. *
  599. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  600. */
  601. QDF_STATUS wmi_extract_chan_info_event(
  602. wmi_unified_t wmi_handle, void *evt_buf,
  603. wmi_host_chan_info_event *chan_info);
  604. /**
  605. * wmi_extract_channel_hopping_event() - extract channel hopping param
  606. * from event
  607. * @wmi_handle: wmi handle
  608. * @evt_buf: pointer to event buffer
  609. * @ch_hopping: Pointer to hold channel hopping param
  610. *
  611. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  612. */
  613. QDF_STATUS wmi_extract_channel_hopping_event(
  614. wmi_unified_t wmi_handle, void *evt_buf,
  615. wmi_host_pdev_channel_hopping_event *ch_hopping);
  616. /**
  617. * wmi_unified_peer_chan_width_switch_cmd_send() - WMI send peer chan width
  618. * @wmi_hdl: handle to WMI
  619. * @param: pointer to hold peer capability param
  620. *
  621. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  622. */
  623. QDF_STATUS wmi_unified_peer_chan_width_switch_cmd_send(
  624. wmi_unified_t wmi_handle,
  625. struct peer_chan_width_switch_params *param);
  626. /**
  627. * wmi_unified_peer_del_all_wds_entries_cmd_send() - send delete
  628. * all wds entries cmd to fw
  629. * @wmi_hdl: wmi handle
  630. * @param: delete all wds entries params
  631. *
  632. * Return: QDF_STATUS_SUCCESS for success or error code
  633. */
  634. QDF_STATUS wmi_unified_peer_del_all_wds_entries_cmd_send(
  635. wmi_unified_t wmi_handle,
  636. struct peer_del_all_wds_entries_params *param);
  637. /**
  638. * wmi_unified_vdev_pcp_tid_map_cmd_send() - WMI set vap pcp
  639. * tid map cmd function
  640. * @wmi_handle: handle to WMI.
  641. * @param: pointer to hold pcp param
  642. *
  643. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  644. */
  645. QDF_STATUS wmi_unified_vdev_pcp_tid_map_cmd_send(
  646. wmi_unified_t wmi_handle,
  647. struct vap_pcp_tid_map_params *param);
  648. /**
  649. * wmi_unified_vdev_tidmap_prec_cmd_send() - WMI set vap tidmap precedence
  650. * cmd function
  651. * @wmi_handle: handle to WMI.
  652. * @param: pointer to hold precedence param
  653. *
  654. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  655. */
  656. QDF_STATUS wmi_unified_vdev_tidmap_prec_cmd_send(
  657. wmi_unified_t wmi_handle,
  658. struct vap_tidmap_prec_params *param);
  659. #ifdef WLAN_SUPPORT_RX_PROTOCOL_TYPE_TAG
  660. /**
  661. * wmi_unified_set_rx_pkt_type_routing_tag() - api to add/delete
  662. * the protocols to be tagged by CCE
  663. * @wmi_hdl: wmi handle
  664. * @param: Packet routing/tagging info
  665. *
  666. * Return: QDF_STATUS_SUCCESS for success or error code
  667. */
  668. QDF_STATUS wmi_unified_set_rx_pkt_type_routing_tag(
  669. wmi_unified_t wmi_handle,
  670. struct wmi_rx_pkt_protocol_routing_info *param);
  671. #endif /* WLAN_SUPPORT_RX_PROTOCOL_TYPE_TAG */
  672. /**
  673. * wmi_unified_peer_vlan_config_send() - WMI function to send vlan command
  674. *
  675. * @wmi_hdl: WMI handle
  676. * @peer_addr: Peer mac address
  677. * @param: struct peer_vlan_config_param *
  678. *
  679. * Return: QDF_STATUS_SUCCESS if success, else returns proper error code.
  680. */
  681. QDF_STATUS wmi_unified_peer_vlan_config_send(wmi_unified_t wmi_handle,
  682. uint8_t peer_addr[QDF_MAC_ADDR_SIZE],
  683. struct peer_vlan_config_param *param);
  684. /**
  685. * wmi_extract_muedca_params_handler() - WMI function to extract Muedca params
  686. *
  687. * @wmi_handle: WMI handle
  688. * @evt_buf: Event data buffer
  689. * @muedca_param_list: struct muedca_params
  690. *
  691. * Return: QDF_STATUS_SUCCESS if success, else returns proper error code.
  692. */
  693. QDF_STATUS wmi_extract_muedca_params_handler(wmi_unified_t wmi_handle,
  694. void *evt_buf, struct muedca_params *muedca_param_list);
  695. /**
  696. * wmi_unified_set_radio_tx_mode_select_cmd_send() - WMI ant switch tbl cmd function
  697. * @wmi_handle: handle to WMI.
  698. * @param: pointer to hold tx mode selection param
  699. *
  700. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  701. */
  702. QDF_STATUS wmi_unified_set_radio_tx_mode_select_cmd_send(
  703. wmi_unified_t wmi_handle,
  704. struct wmi_pdev_enable_tx_mode_selection *tx_mode_select_param);
  705. #endif /* _WMI_UNIFIED_AP_API_H_ */