wmi_unified_vdev_api.h 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. /*
  2. * Copyright (c) 2016-2021 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 declarations for the Unified Wireless Module
  20. * Interface (WMI).
  21. */
  22. #ifndef _WMI_UNIFIED_VDEV_API_H_
  23. #define _WMI_UNIFIED_VDEV_API_H_
  24. #include <wmi_unified_api.h>
  25. /**
  26. * wmi_unified_vdev_set_neighbour_rx_cmd_send() - WMI set neighbour rx function
  27. * @param wmi_handle: handle to WMI.
  28. * @param macaddr: MAC address
  29. * @param param: pointer to hold neighbour rx parameter
  30. *
  31. * @return QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  32. */
  33. QDF_STATUS wmi_unified_vdev_set_neighbour_rx_cmd_send(
  34. struct wmi_unified *wmi_handle,
  35. uint8_t macaddr[QDF_MAC_ADDR_SIZE],
  36. struct set_neighbour_rx_params *param);
  37. /**
  38. * wmi_unified_vdev_config_ratemask_cmd_send() - WMI config ratemask function
  39. * @param wmi_handle: handle to WMI.
  40. * @param param: pointer to hold config ratemask param
  41. *
  42. * @return QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  43. */
  44. QDF_STATUS
  45. wmi_unified_vdev_config_ratemask_cmd_send(struct wmi_unified *wmi_handle,
  46. struct config_ratemask_params *param);
  47. /**
  48. * wmi_unified_send_multiple_vdev_restart_req_cmd() - send multiple vdev restart
  49. * @wmi_handle: wmi handle
  50. * @param: multiple vdev restart parameter
  51. *
  52. * Send WMI_PDEV_MULTIPLE_VDEV_RESTART_REQUEST_CMDID parameters to fw.
  53. *
  54. * Return: QDF_STATUS_SUCCESS on success, QDF_STATUS_E_** on error
  55. */
  56. QDF_STATUS wmi_unified_send_multiple_vdev_restart_req_cmd(
  57. struct wmi_unified *wmi_handle,
  58. struct multiple_vdev_restart_params *param);
  59. /**
  60. * wmi_unified_send_multiple_vdev_set_param_cmd() - Send multiple vdev set param
  61. * command
  62. * @wmi_handle: wmi handle
  63. * @param: multiple vdev restart parameter
  64. *
  65. * Send WMI_PDEV_MULTIPLE_VDEV_SET_PARAM_CMDID parameters to fw.
  66. *
  67. * Return: QDF_STATUS_SUCCESS on success, QDF_STATUS_E_** on error
  68. */
  69. QDF_STATUS wmi_unified_send_multiple_vdev_set_param_cmd(
  70. struct wmi_unified *wmi_handle,
  71. struct multiple_vdev_set_param *param);
  72. /**
  73. * wmi_unified_beacon_send_cmd() - WMI beacon send function
  74. * @param wmi_handle: handle to WMI.
  75. * @param macaddr: MAC address
  76. * @param param: pointer to hold beacon send cmd parameter
  77. *
  78. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  79. */
  80. QDF_STATUS wmi_unified_beacon_send_cmd(struct wmi_unified *wmi_handle,
  81. struct beacon_params *param);
  82. /**
  83. * wmi_extract_vdev_start_resp() - extract vdev start response
  84. * @wmi_handle: wmi handle
  85. * @param evt_buf: pointer to event buffer
  86. * @param vdev_rsp: Pointer to hold vdev response
  87. *
  88. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  89. */
  90. QDF_STATUS
  91. wmi_extract_vdev_start_resp(struct wmi_unified *wmi_handle, void *evt_buf,
  92. struct vdev_start_response *vdev_rsp);
  93. /**
  94. * wmi_extract_vdev_stopped_param() - extract vdev stop param from event
  95. * @wmi_handle: wmi handle
  96. * @param evt_buf: pointer to event buffer
  97. * @param vdev_id: Pointer to hold vdev identifier
  98. *
  99. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  100. */
  101. QDF_STATUS
  102. wmi_extract_vdev_stopped_param(struct wmi_unified *wmi_handle, void *evt_buf,
  103. uint32_t *vdev_id);
  104. /**
  105. * wmi_extract_vdev_delete_resp() - extract vdev delete response
  106. * @wmi_handle: wmi handle
  107. * @param evt_buf: pointer to event buffer
  108. * @param delete_rsp: Pointer to hold vdev delete response
  109. *
  110. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  111. */
  112. QDF_STATUS
  113. wmi_extract_vdev_delete_resp(struct wmi_unified *wmi_handle, void *evt_buf,
  114. struct vdev_delete_response *vdev_del_resp);
  115. /**
  116. * wmi_extract_vdev_peer_delete_all_response_event() - extract peer delete all
  117. * response
  118. * @wmi_handle: wmi handle
  119. * @param evt_buf: pointer to event buffer
  120. * @param delete_rsp: Pointer to hold peer delete all response
  121. *
  122. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  123. */
  124. QDF_STATUS wmi_extract_vdev_peer_delete_all_response_event(
  125. struct wmi_unified *wmi_handle,
  126. void *evt_buf,
  127. struct peer_delete_all_response *delete_rsp);
  128. /**
  129. * wmi_extract_ext_tbttoffset_num_vdevs() - extract ext tbtt offset num vdev
  130. * @wmi_handle: wmi handle
  131. * @param evt_buf: pointer to event buffer
  132. * @param vdev_map: Pointer to hold num vdev
  133. *
  134. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  135. */
  136. QDF_STATUS
  137. wmi_extract_ext_tbttoffset_num_vdevs(struct wmi_unified *wmi_handle,
  138. void *evt_buf, uint32_t *num_vdevs);
  139. /**
  140. * wmi_extract_tbttoffset_num_vdevs() - extract tbtt offset num vdev
  141. * @wmi_handle: wmi handle
  142. * @param evt_buf: pointer to event buffer
  143. * @param vdev_map: Pointer to hold num vdev
  144. *
  145. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  146. */
  147. QDF_STATUS
  148. wmi_extract_tbttoffset_num_vdevs(struct wmi_unified *wmi_handle, void *evt_buf,
  149. uint32_t *num_vdevs);
  150. /**
  151. * wmi_extract_multi_vdev_restart_resp_event() - extract multi vdev restart
  152. * response
  153. * @wmi_handle: wmi handle
  154. * @evt_buf: pointer to event buffer
  155. * @restart_rsp: Pointer to hold multi vdev restart response
  156. *
  157. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  158. */
  159. QDF_STATUS wmi_extract_multi_vdev_restart_resp_event(
  160. struct wmi_unified *wmi_handle,
  161. void *evt_buf,
  162. struct multi_vdev_restart_resp *restart_rsp);
  163. /**
  164. * wmi_unified_multisoc_tbtt_sync_cmd() - Send cmd to sync tbtt in multisoc case
  165. * @wmi_handle: wmi handle
  166. * @param: params received in rnr_tbtt_multisoc_sync_param
  167. *
  168. * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
  169. */
  170. QDF_STATUS
  171. wmi_unified_multisoc_tbtt_sync_cmd(wmi_unified_t wmi_handle,
  172. struct rnr_tbtt_multisoc_sync_param *param);
  173. #endif