wmi_unified_vdev_api.c 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  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 definitions for the Unified Wireless Module
  20. * Interface (WMI).
  21. */
  22. #include <htc_api.h>
  23. #include <htc_api.h>
  24. #include <wmi_unified_priv.h>
  25. #include <wmi_unified_api.h>
  26. #include <qdf_module.h>
  27. #include <qdf_list.h>
  28. #include <qdf_platform.h>
  29. #ifdef WMI_EXT_DBG
  30. #include <qdf_list.h>
  31. #endif
  32. #include <linux/debugfs.h>
  33. #include <wmi_unified_param.h>
  34. #include <cdp_txrx_cmn_struct.h>
  35. #include <wmi_unified_vdev_api.h>
  36. QDF_STATUS
  37. wmi_extract_tbttoffset_num_vdevs(struct wmi_unified *wmi_handle, void *evt_buf,
  38. uint32_t *num_vdevs)
  39. {
  40. if (wmi_handle->ops->extract_tbttoffset_num_vdevs)
  41. return wmi_handle->ops->extract_tbttoffset_num_vdevs(wmi_handle,
  42. evt_buf,
  43. num_vdevs);
  44. return QDF_STATUS_E_FAILURE;
  45. }
  46. QDF_STATUS wmi_unified_send_multiple_vdev_restart_req_cmd(
  47. struct wmi_unified *wmi_handle,
  48. struct multiple_vdev_restart_params *param)
  49. {
  50. if (wmi_handle->ops->send_multiple_vdev_restart_req_cmd)
  51. return wmi_handle->ops->send_multiple_vdev_restart_req_cmd(
  52. wmi_handle, param);
  53. return QDF_STATUS_E_FAILURE;
  54. }
  55. QDF_STATUS wmi_unified_send_multiple_vdev_set_param_cmd(
  56. struct wmi_unified *wmi_handle,
  57. struct multiple_vdev_set_param *param)
  58. {
  59. if (wmi_handle->ops->send_multiple_vdev_set_param_cmd)
  60. return wmi_handle->ops->send_multiple_vdev_set_param_cmd(
  61. wmi_handle, param);
  62. return QDF_STATUS_E_FAILURE;
  63. }
  64. QDF_STATUS wmi_unified_beacon_send_cmd(struct wmi_unified *wmi_handle,
  65. struct beacon_params *param)
  66. {
  67. if (wmi_handle->ops->send_beacon_send_cmd)
  68. return wmi_handle->ops->send_beacon_send_cmd(wmi_handle,
  69. param);
  70. return QDF_STATUS_E_FAILURE;
  71. }
  72. QDF_STATUS
  73. wmi_extract_vdev_start_resp(struct wmi_unified *wmi_handle, void *evt_buf,
  74. struct vdev_start_response *vdev_rsp)
  75. {
  76. if (wmi_handle->ops->extract_vdev_start_resp)
  77. return wmi_handle->ops->extract_vdev_start_resp(wmi_handle,
  78. evt_buf,
  79. vdev_rsp);
  80. return QDF_STATUS_E_FAILURE;
  81. }
  82. QDF_STATUS
  83. wmi_extract_vdev_delete_resp(struct wmi_unified *wmi_handle, void *evt_buf,
  84. struct vdev_delete_response *delete_rsp)
  85. {
  86. if (wmi_handle->ops->extract_vdev_delete_resp)
  87. return wmi_handle->ops->extract_vdev_delete_resp(wmi_handle,
  88. evt_buf,
  89. delete_rsp);
  90. return QDF_STATUS_E_FAILURE;
  91. }
  92. QDF_STATUS wmi_extract_vdev_peer_delete_all_response_event(
  93. struct wmi_unified *wmi_handle,
  94. void *evt_buf,
  95. struct peer_delete_all_response *delete_rsp)
  96. {
  97. if (wmi_handle->ops->extract_vdev_peer_delete_all_response_event)
  98. return
  99. wmi_handle->ops->extract_vdev_peer_delete_all_response_event(
  100. wmi_handle,
  101. evt_buf,
  102. delete_rsp);
  103. return QDF_STATUS_E_FAILURE;
  104. }
  105. QDF_STATUS
  106. wmi_extract_vdev_stopped_param(struct wmi_unified *wmi_handle, void *evt_buf,
  107. uint32_t *vdev_id)
  108. {
  109. if (wmi_handle->ops->extract_vdev_stopped_param)
  110. return wmi_handle->ops->extract_vdev_stopped_param(wmi_handle,
  111. evt_buf,
  112. vdev_id);
  113. return QDF_STATUS_E_FAILURE;
  114. }
  115. QDF_STATUS
  116. wmi_extract_ext_tbttoffset_num_vdevs(struct wmi_unified *wmi_handle,
  117. void *evt_buf, uint32_t *num_vdevs)
  118. {
  119. if (wmi_handle->ops->extract_ext_tbttoffset_num_vdevs)
  120. return wmi_handle->ops->extract_ext_tbttoffset_num_vdevs(
  121. wmi_handle,
  122. evt_buf, num_vdevs);
  123. return QDF_STATUS_E_FAILURE;
  124. }
  125. QDF_STATUS
  126. wmi_unified_vdev_config_ratemask_cmd_send(struct wmi_unified *wmi_handle,
  127. struct config_ratemask_params *param)
  128. {
  129. if (wmi_handle->ops->send_vdev_config_ratemask_cmd)
  130. return wmi_handle->ops->send_vdev_config_ratemask_cmd(
  131. wmi_handle, param);
  132. return QDF_STATUS_E_FAILURE;
  133. }
  134. QDF_STATUS wmi_unified_vdev_set_neighbour_rx_cmd_send(
  135. struct wmi_unified *wmi_handle,
  136. uint8_t macaddr[QDF_MAC_ADDR_SIZE],
  137. struct set_neighbour_rx_params *param)
  138. {
  139. if (wmi_handle->ops->send_vdev_set_neighbour_rx_cmd)
  140. return wmi_handle->ops->send_vdev_set_neighbour_rx_cmd(
  141. wmi_handle,
  142. macaddr, param);
  143. return QDF_STATUS_E_FAILURE;
  144. }
  145. QDF_STATUS wmi_extract_multi_vdev_restart_resp_event(
  146. struct wmi_unified *wmi_handle,
  147. void *evt_buf,
  148. struct multi_vdev_restart_resp *restart_rsp)
  149. {
  150. if (wmi_handle->ops->extract_multi_vdev_restart_resp_event)
  151. return wmi_handle->ops->extract_multi_vdev_restart_resp_event(
  152. wmi_handle, evt_buf, restart_rsp);
  153. return QDF_STATUS_E_FAILURE;
  154. }
  155. QDF_STATUS wmi_unified_multisoc_tbtt_sync_cmd(wmi_unified_t wmi_handle,
  156. struct rnr_tbtt_multisoc_sync_param *param)
  157. {
  158. if (wmi_handle->ops->multisoc_tbtt_sync_cmd)
  159. return wmi_handle->ops->multisoc_tbtt_sync_cmd(wmi_handle,
  160. param);
  161. return QDF_STATUS_E_FAILURE;
  162. }