wmi_unified_11be_api.c 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. /*
  2. * Copyright (c) 2021, The Linux Foundation. All rights reserved.
  3. * Copyright (c) 2021-2022 Qualcomm Innovation Center, Inc. All rights reserved.
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for any
  6. * purpose with or without fee is hereby granted, provided that the above
  7. * copyright notice and this permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  10. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  11. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  12. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  13. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  14. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  15. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  16. */
  17. /**
  18. * DOC: Implement API's specific to 11be.
  19. */
  20. #include "wmi_unified_11be_api.h"
  21. /**
  22. * wmi_extract_mlo_link_set_active_resp() - extract mlo link set active resp
  23. * from event
  24. * @wmi: WMI handle for this pdev
  25. * @evt_buf: pointer to event buffer
  26. * @resp: Pointer to hold mlo link set active resp
  27. *
  28. * Return: QDF_STATUS code
  29. */
  30. QDF_STATUS
  31. wmi_extract_mlo_link_set_active_resp(wmi_unified_t wmi,
  32. void *evt_buf,
  33. struct mlo_link_set_active_resp *resp)
  34. {
  35. if (wmi->ops->extract_mlo_link_set_active_resp) {
  36. return wmi->ops->extract_mlo_link_set_active_resp(wmi,
  37. evt_buf,
  38. resp);
  39. }
  40. return QDF_STATUS_E_FAILURE;
  41. }
  42. /**
  43. * wmi_send_mlo_link_set_active_cmd() - send mlo link set active command
  44. * @wmi: WMI handle for this pdev
  45. * @param: Pointer to mlo link set active param
  46. *
  47. * Return: QDF_STATUS code
  48. */
  49. QDF_STATUS
  50. wmi_send_mlo_link_set_active_cmd(wmi_unified_t wmi,
  51. struct mlo_link_set_active_param *param)
  52. {
  53. if (wmi->ops->send_mlo_link_set_active_cmd)
  54. return wmi->ops->send_mlo_link_set_active_cmd(wmi, param);
  55. return QDF_STATUS_E_FAILURE;
  56. }
  57. #ifdef WLAN_FEATURE_11BE
  58. QDF_STATUS wmi_send_mlo_peer_tid_to_link_map_cmd(
  59. wmi_unified_t wmi,
  60. struct wmi_host_tid_to_link_map_params *params)
  61. {
  62. if (wmi->ops->send_mlo_peer_tid_to_link_map)
  63. return wmi->ops->send_mlo_peer_tid_to_link_map(wmi, params);
  64. return QDF_STATUS_E_FAILURE;
  65. }
  66. QDF_STATUS wmi_send_mlo_vdev_tid_to_link_map_cmd(
  67. wmi_unified_t wmi,
  68. struct wmi_host_tid_to_link_map_ap_params *params)
  69. {
  70. if (wmi->ops->send_mlo_vdev_tid_to_link_map)
  71. return wmi->ops->send_mlo_vdev_tid_to_link_map(wmi, params);
  72. return QDF_STATUS_E_FAILURE;
  73. }
  74. QDF_STATUS
  75. wmi_extract_mlo_vdev_tid_to_link_map_event(
  76. wmi_unified_t wmi, void *evt_buf,
  77. struct mlo_vdev_host_tid_to_link_map_resp *resp)
  78. {
  79. if (wmi->ops->extract_mlo_vdev_tid_to_link_map_event) {
  80. return wmi->ops->extract_mlo_vdev_tid_to_link_map_event(wmi,
  81. evt_buf,
  82. resp);
  83. }
  84. return QDF_STATUS_E_FAILURE;
  85. }
  86. QDF_STATUS
  87. wmi_extract_mlo_vdev_bcast_tid_to_link_map_event(
  88. wmi_unified_t wmi,
  89. void *evt_buf,
  90. struct mlo_bcast_t2lm_info *bcast)
  91. {
  92. if (wmi->ops->extract_mlo_vdev_bcast_tid_to_link_map_event) {
  93. return wmi->ops->extract_mlo_vdev_bcast_tid_to_link_map_event(
  94. wmi,
  95. evt_buf,
  96. bcast);
  97. }
  98. return QDF_STATUS_E_FAILURE;
  99. }
  100. #endif /* WLAN_FEATURE_11BE */
  101. QDF_STATUS
  102. wmi_extract_mgmt_rx_ml_cu_params(wmi_unified_t wmi, void *evt_buf,
  103. struct mlo_mgmt_ml_info *cu_params)
  104. {
  105. if (wmi->ops->extract_mgmt_rx_ml_cu_params)
  106. return wmi->ops->extract_mgmt_rx_ml_cu_params(
  107. wmi, evt_buf, cu_params);
  108. return QDF_STATUS_E_FAILURE;
  109. }
  110. QDF_STATUS wmi_send_mlo_link_removal_cmd(
  111. wmi_unified_t wmi,
  112. const struct mlo_link_removal_cmd_params *param)
  113. {
  114. if (wmi->ops->send_mlo_link_removal_cmd)
  115. return wmi->ops->send_mlo_link_removal_cmd(wmi, param);
  116. return QDF_STATUS_E_FAILURE;
  117. }
  118. QDF_STATUS wmi_extract_mlo_link_removal_evt_fixed_param(
  119. struct wmi_unified *wmi,
  120. void *buf,
  121. struct mlo_link_removal_evt_params *params)
  122. {
  123. if (wmi->ops->extract_mlo_link_removal_evt_fixed_param)
  124. return wmi->ops->extract_mlo_link_removal_evt_fixed_param(
  125. wmi, buf, params);
  126. return QDF_STATUS_E_FAILURE;
  127. }
  128. QDF_STATUS wmi_extract_mlo_link_removal_tbtt_update(
  129. struct wmi_unified *wmi,
  130. void *buf,
  131. struct mlo_link_removal_tbtt_info *tbtt_info)
  132. {
  133. if (wmi->ops->extract_mlo_link_removal_tbtt_update)
  134. return wmi->ops->extract_mlo_link_removal_tbtt_update(
  135. wmi, buf, tbtt_info);
  136. return QDF_STATUS_E_FAILURE;
  137. }
  138. QDF_STATUS wmi_extract_mgmt_rx_mlo_link_removal_info(
  139. struct wmi_unified *wmi,
  140. void *buf,
  141. struct mgmt_rx_mlo_link_removal_info *link_removal_info,
  142. int num_link_removal_info)
  143. {
  144. if (wmi->ops->extract_mgmt_rx_mlo_link_removal_info)
  145. return wmi->ops->extract_mgmt_rx_mlo_link_removal_info(
  146. wmi, buf,
  147. link_removal_info,
  148. num_link_removal_info);
  149. return QDF_STATUS_E_FAILURE;
  150. }