wmi_unified_vdev_api.c 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. /*
  2. * Copyright (c) 2016-2021 The Linux Foundation. All rights reserved.
  3. * Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for
  6. * any purpose with or without fee is hereby granted, provided that the
  7. * above copyright notice and this permission notice appear in all
  8. * copies.
  9. *
  10. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  11. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  12. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  13. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  14. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  15. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  16. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  17. * PERFORMANCE OF THIS SOFTWARE.
  18. */
  19. /*
  20. * This file contains the API definitions for the Unified Wireless Module
  21. * Interface (WMI).
  22. */
  23. #include <htc_api.h>
  24. #include <htc_api.h>
  25. #include <wmi_unified_priv.h>
  26. #include <wmi_unified_api.h>
  27. #include <qdf_module.h>
  28. #include <qdf_list.h>
  29. #include <qdf_platform.h>
  30. #ifdef WMI_EXT_DBG
  31. #include <qdf_list.h>
  32. #endif
  33. #include <linux/debugfs.h>
  34. #include <wmi_unified_param.h>
  35. #include <cdp_txrx_cmn_struct.h>
  36. #include <wmi_unified_vdev_api.h>
  37. QDF_STATUS
  38. wmi_extract_tbttoffset_num_vdevs(struct wmi_unified *wmi_handle, void *evt_buf,
  39. uint32_t *num_vdevs)
  40. {
  41. if (wmi_handle->ops->extract_tbttoffset_num_vdevs)
  42. return wmi_handle->ops->extract_tbttoffset_num_vdevs(wmi_handle,
  43. evt_buf,
  44. num_vdevs);
  45. return QDF_STATUS_E_FAILURE;
  46. }
  47. QDF_STATUS wmi_unified_send_multiple_vdev_restart_req_cmd(
  48. struct wmi_unified *wmi_handle,
  49. struct multiple_vdev_restart_params *param)
  50. {
  51. if (wmi_handle->ops->send_multiple_vdev_restart_req_cmd)
  52. return wmi_handle->ops->send_multiple_vdev_restart_req_cmd(
  53. wmi_handle, param);
  54. return QDF_STATUS_E_FAILURE;
  55. }
  56. QDF_STATUS wmi_unified_send_multiple_vdev_set_param_cmd(
  57. struct wmi_unified *wmi_handle,
  58. struct multiple_vdev_set_param *param)
  59. {
  60. if (wmi_handle->ops->send_multiple_vdev_set_param_cmd)
  61. return wmi_handle->ops->send_multiple_vdev_set_param_cmd(
  62. wmi_handle, param);
  63. return QDF_STATUS_E_FAILURE;
  64. }
  65. QDF_STATUS wmi_unified_beacon_send_cmd(struct wmi_unified *wmi_handle,
  66. struct beacon_params *param)
  67. {
  68. if (wmi_handle->ops->send_beacon_send_cmd)
  69. return wmi_handle->ops->send_beacon_send_cmd(wmi_handle,
  70. param);
  71. return QDF_STATUS_E_FAILURE;
  72. }
  73. QDF_STATUS
  74. wmi_extract_vdev_start_resp(struct wmi_unified *wmi_handle, void *evt_buf,
  75. struct vdev_start_response *vdev_rsp)
  76. {
  77. if (wmi_handle->ops->extract_vdev_start_resp)
  78. return wmi_handle->ops->extract_vdev_start_resp(wmi_handle,
  79. evt_buf,
  80. vdev_rsp);
  81. return QDF_STATUS_E_FAILURE;
  82. }
  83. QDF_STATUS
  84. wmi_extract_vdev_delete_resp(struct wmi_unified *wmi_handle, void *evt_buf,
  85. struct vdev_delete_response *delete_rsp)
  86. {
  87. if (wmi_handle->ops->extract_vdev_delete_resp)
  88. return wmi_handle->ops->extract_vdev_delete_resp(wmi_handle,
  89. evt_buf,
  90. delete_rsp);
  91. return QDF_STATUS_E_FAILURE;
  92. }
  93. QDF_STATUS wmi_extract_vdev_peer_delete_all_response_event(
  94. struct wmi_unified *wmi_handle,
  95. void *evt_buf,
  96. struct peer_delete_all_response *delete_rsp)
  97. {
  98. if (wmi_handle->ops->extract_vdev_peer_delete_all_response_event)
  99. return
  100. wmi_handle->ops->extract_vdev_peer_delete_all_response_event(
  101. wmi_handle,
  102. evt_buf,
  103. delete_rsp);
  104. return QDF_STATUS_E_FAILURE;
  105. }
  106. QDF_STATUS
  107. wmi_extract_vdev_stopped_param(struct wmi_unified *wmi_handle, void *evt_buf,
  108. uint32_t *vdev_id)
  109. {
  110. if (wmi_handle->ops->extract_vdev_stopped_param)
  111. return wmi_handle->ops->extract_vdev_stopped_param(wmi_handle,
  112. evt_buf,
  113. vdev_id);
  114. return QDF_STATUS_E_FAILURE;
  115. }
  116. QDF_STATUS
  117. wmi_extract_ext_tbttoffset_num_vdevs(struct wmi_unified *wmi_handle,
  118. void *evt_buf, uint32_t *num_vdevs)
  119. {
  120. if (wmi_handle->ops->extract_ext_tbttoffset_num_vdevs)
  121. return wmi_handle->ops->extract_ext_tbttoffset_num_vdevs(
  122. wmi_handle,
  123. evt_buf, num_vdevs);
  124. return QDF_STATUS_E_FAILURE;
  125. }
  126. QDF_STATUS
  127. wmi_unified_vdev_config_ratemask_cmd_send(struct wmi_unified *wmi_handle,
  128. struct config_ratemask_params *param)
  129. {
  130. if (wmi_handle->ops->send_vdev_config_ratemask_cmd)
  131. return wmi_handle->ops->send_vdev_config_ratemask_cmd(
  132. wmi_handle, param);
  133. return QDF_STATUS_E_FAILURE;
  134. }
  135. QDF_STATUS
  136. wmi_unified_peer_filter_set_tx_cmd_send(struct wmi_unified *wmi_handle,
  137. uint8_t macaddr[],
  138. struct set_tx_peer_filter *param)
  139. {
  140. struct wmi_ops *ops = wmi_handle->ops;
  141. if (ops->send_peer_filter_set_tx_cmd)
  142. return ops->send_peer_filter_set_tx_cmd(wmi_handle, macaddr,
  143. param);
  144. return QDF_STATUS_E_FAILURE;
  145. }
  146. QDF_STATUS wmi_unified_vdev_set_neighbour_rx_cmd_send(
  147. struct wmi_unified *wmi_handle,
  148. uint8_t macaddr[QDF_MAC_ADDR_SIZE],
  149. struct set_neighbour_rx_params *param)
  150. {
  151. if (wmi_handle->ops->send_vdev_set_neighbour_rx_cmd)
  152. return wmi_handle->ops->send_vdev_set_neighbour_rx_cmd(
  153. wmi_handle,
  154. macaddr, param);
  155. return QDF_STATUS_E_FAILURE;
  156. }
  157. qdf_export_symbol(wmi_unified_vdev_set_neighbour_rx_cmd_send);
  158. QDF_STATUS wmi_extract_multi_vdev_restart_resp_event(
  159. struct wmi_unified *wmi_handle,
  160. void *evt_buf,
  161. struct multi_vdev_restart_resp *restart_rsp)
  162. {
  163. if (wmi_handle->ops->extract_multi_vdev_restart_resp_event)
  164. return wmi_handle->ops->extract_multi_vdev_restart_resp_event(
  165. wmi_handle, evt_buf, restart_rsp);
  166. return QDF_STATUS_E_FAILURE;
  167. }
  168. QDF_STATUS wmi_unified_multisoc_tbtt_sync_cmd(wmi_unified_t wmi_handle,
  169. struct rnr_tbtt_multisoc_sync_param *param)
  170. {
  171. if (wmi_handle->ops->multisoc_tbtt_sync_cmd)
  172. return wmi_handle->ops->multisoc_tbtt_sync_cmd(wmi_handle,
  173. param);
  174. return QDF_STATUS_E_FAILURE;
  175. }