cdp_txrx_mlo.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. /*
  2. * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for any
  5. * purpose with or without fee is hereby granted, provided that the above
  6. * copyright notice and this permission notice appear in all copies.
  7. *
  8. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  9. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  11. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  13. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  14. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #ifndef _CDP_TXRX_MLO_H_
  17. #define _CDP_TXRX_MLO_H_
  18. #include "cdp_txrx_ops.h"
  19. struct cdp_mlo_ctxt;
  20. static inline
  21. struct cdp_mlo_ctxt *cdp_mlo_ctxt_attach(ol_txrx_soc_handle soc,
  22. struct cdp_ctrl_mlo_mgr *ctrl_ctxt)
  23. {
  24. if (!soc || !soc->ops) {
  25. QDF_BUG(0);
  26. return NULL;
  27. }
  28. if (!soc->ops->mlo_ops ||
  29. !soc->ops->mlo_ops->mlo_ctxt_attach)
  30. return NULL;
  31. return soc->ops->mlo_ops->mlo_ctxt_attach(ctrl_ctxt);
  32. }
  33. static inline
  34. void cdp_mlo_ctxt_detach(ol_txrx_soc_handle soc,
  35. struct cdp_mlo_ctxt *ml_ctxt)
  36. {
  37. if (!soc || !soc->ops) {
  38. QDF_BUG(0);
  39. return;
  40. }
  41. if (!soc->ops->mlo_ops ||
  42. !soc->ops->mlo_ops->mlo_ctxt_detach)
  43. return;
  44. soc->ops->mlo_ops->mlo_ctxt_detach(ml_ctxt);
  45. }
  46. static inline void cdp_soc_mlo_soc_setup(ol_txrx_soc_handle soc,
  47. struct cdp_mlo_ctxt *mlo_ctx)
  48. {
  49. if (!soc || !soc->ops) {
  50. QDF_BUG(0);
  51. return;
  52. }
  53. if (!soc->ops->mlo_ops ||
  54. !soc->ops->mlo_ops->mlo_soc_setup)
  55. return;
  56. soc->ops->mlo_ops->mlo_soc_setup(soc, mlo_ctx);
  57. }
  58. static inline void cdp_soc_mlo_soc_teardown(ol_txrx_soc_handle soc,
  59. struct cdp_mlo_ctxt *mlo_ctx,
  60. bool is_force_down)
  61. {
  62. if (!soc || !soc->ops) {
  63. QDF_BUG(0);
  64. return;
  65. }
  66. if (!soc->ops->mlo_ops ||
  67. !soc->ops->mlo_ops->mlo_soc_teardown)
  68. return;
  69. soc->ops->mlo_ops->mlo_soc_teardown(soc, mlo_ctx, is_force_down);
  70. }
  71. /*
  72. * cdp_update_mlo_ptnr_list - Add vdev to MLO partner list
  73. * @soc: soc handle
  74. * @vdev_ids: list of partner vdevs
  75. * @num_vdevs: number of items in list
  76. * @vdev_id: caller's vdev id
  77. *
  78. * return: QDF_STATUS
  79. */
  80. static inline QDF_STATUS
  81. cdp_update_mlo_ptnr_list(ol_txrx_soc_handle soc, int8_t vdev_ids[],
  82. uint8_t num_vdevs, uint8_t vdev_id)
  83. {
  84. if (!soc || !soc->ops || !soc->ops->mlo_ops)
  85. return QDF_STATUS_E_INVAL;
  86. if (soc->ops->mlo_ops->update_mlo_ptnr_list)
  87. return soc->ops->mlo_ops->update_mlo_ptnr_list(soc, vdev_ids,
  88. num_vdevs, vdev_id);
  89. return QDF_STATUS_SUCCESS;
  90. }
  91. /*
  92. * cdp_clear_mlo_ptnr_list - Remove vdev from MLO partner list
  93. * @soc: soc handle
  94. * @vdev_id: caller's vdev id
  95. *
  96. * return: QDF_STATUS
  97. */
  98. static inline QDF_STATUS
  99. cdp_clear_mlo_ptnr_list(ol_txrx_soc_handle soc, uint8_t vdev_id)
  100. {
  101. if (!soc || !soc->ops || !soc->ops->mlo_ops)
  102. return QDF_STATUS_E_INVAL;
  103. if (soc->ops->mlo_ops->update_mlo_ptnr_list)
  104. return soc->ops->mlo_ops->clear_mlo_ptnr_list(soc, vdev_id);
  105. return QDF_STATUS_SUCCESS;
  106. }
  107. static inline void cdp_mlo_setup_complete(ol_txrx_soc_handle soc,
  108. struct cdp_mlo_ctxt *mlo_ctx)
  109. {
  110. if (!soc || !soc->ops) {
  111. QDF_BUG(0);
  112. return;
  113. }
  114. if (!soc->ops->mlo_ops ||
  115. !soc->ops->mlo_ops->mlo_setup_complete)
  116. return;
  117. soc->ops->mlo_ops->mlo_setup_complete(mlo_ctx);
  118. }
  119. /*
  120. * cdp_mlo_update_delta_tsf2 - Update delta_tsf2
  121. * @soc: soc handle
  122. * @pdev_id: pdev id
  123. * @delta_tsf2: delta_tsf2
  124. *
  125. * return: none
  126. */
  127. static inline void cdp_mlo_update_delta_tsf2(ol_txrx_soc_handle soc,
  128. uint8_t pdev_id,
  129. uint64_t delta_tsf2)
  130. {
  131. if (!soc || !soc->ops) {
  132. QDF_BUG(0);
  133. return;
  134. }
  135. if (!soc->ops->mlo_ops ||
  136. !soc->ops->mlo_ops->mlo_update_delta_tsf2)
  137. return;
  138. soc->ops->mlo_ops->mlo_update_delta_tsf2(soc, pdev_id, delta_tsf2);
  139. }
  140. /*
  141. * cdp_mlo_update_delta_tqm - Update delta_tqm
  142. * @soc: soc handle
  143. * @delta_tqm: delta_tqm
  144. *
  145. * return: none
  146. */
  147. static inline void cdp_mlo_update_delta_tqm(ol_txrx_soc_handle soc,
  148. uint64_t delta_tqm)
  149. {
  150. if (!soc || !soc->ops) {
  151. QDF_BUG(0);
  152. return;
  153. }
  154. if (!soc->ops->mlo_ops ||
  155. !soc->ops->mlo_ops->mlo_update_delta_tqm)
  156. return;
  157. soc->ops->mlo_ops->mlo_update_delta_tqm(soc, delta_tqm);
  158. }
  159. /*
  160. * cdp_mlo_get_mld_vdev_stats - Get MLD vdev stats
  161. * @soc: soc handle
  162. * @vdev_id: vdev_id of one of the vdev's of the MLD group
  163. * @buf: buffer to hold vdev_stats
  164. * @link_vdev_only: flag to indicate if stats are required for specific vdev
  165. *
  166. * return: QDF_STATUS
  167. */
  168. static inline QDF_STATUS
  169. cdp_mlo_get_mld_vdev_stats(ol_txrx_soc_handle soc,
  170. uint8_t vdev_id, struct cdp_vdev_stats *buf,
  171. bool link_vdev_only)
  172. {
  173. if (!soc || !soc->ops) {
  174. QDF_BUG(0);
  175. return QDF_STATUS_E_FAILURE;
  176. }
  177. if (!soc->ops->mlo_ops || !soc->ops->mlo_ops->mlo_get_mld_vdev_stats)
  178. return QDF_STATUS_E_FAILURE;
  179. return soc->ops->mlo_ops->mlo_get_mld_vdev_stats(soc,
  180. vdev_id,
  181. buf,
  182. link_vdev_only);
  183. }
  184. #endif /*_CDP_TXRX_MLO_H_*/