cdp_txrx_cmn_reg.h 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. /*
  2. * Copyright (c) 2011-2021 The Linux Foundation. All rights reserved.
  3. * Copyright (c) 2021-2023 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. * @file cdp_txrx_cmn.h
  21. * @brief Define the host data path converged API functions
  22. * called by the host control SW and the OS interface module
  23. */
  24. #ifndef _CDP_TXRX_CMN_REG_H_
  25. #define _CDP_TXRX_CMN_REG_H_
  26. #include "hif_main.h"
  27. #include "cdp_txrx_cmn_struct.h"
  28. #define MOB_DRV_LEGACY_DP 0xdeed
  29. /* Lithium device IDs */
  30. #define LITHIUM_DP 0xfffd
  31. /* Beryllium device IDs */
  32. #define BERYLLIUM_DP 0xaffe
  33. /* RHINE device IDs */
  34. #define RHINE_DP 0xbff0
  35. /* Use device IDs for attach in future */
  36. /* enum cdp_arch_type - enum for DP arch type
  37. * CDP_ARCH_TYPE_LI - for lithium
  38. * CDP_ARCH_TYPE_BE - for beryllium
  39. * CDP_ARCH_TYPE_NONE - not supported
  40. */
  41. enum cdp_arch_type {
  42. CDP_ARCH_TYPE_NONE = -1,
  43. CDP_ARCH_TYPE_LI,
  44. CDP_ARCH_TYPE_BE,
  45. CDP_ARCH_TYPE_RH,
  46. };
  47. #if defined(DP_TXRX_SOC_ATTACH)
  48. static inline ol_txrx_soc_handle
  49. ol_txrx_soc_attach(void *scn_handle, struct ol_if_ops *dp_ol_if_ops)
  50. {
  51. return NULL;
  52. }
  53. #else
  54. ol_txrx_soc_handle
  55. ol_txrx_soc_attach(void *scn_handle, struct ol_if_ops *dp_ol_if_ops);
  56. #endif
  57. #if defined(QCA_WIFI_QCA8074) || defined(QCA_WIFI_QCA6018) || \
  58. defined(QCA_WIFI_QCA5018) || defined(QCA_WIFI_QCA9574) || \
  59. defined(QCA_WIFI_QCA5332)
  60. /**
  61. * dp_soc_attach_wifi3() - Attach txrx SOC
  62. * @ctrl_psoc: Opaque SOC handle from Ctrl plane
  63. * @params: soc attach params
  64. *
  65. * Return: DP SOC handle on success, NULL on failure
  66. */
  67. struct cdp_soc_t *
  68. dp_soc_attach_wifi3(struct cdp_ctrl_objmgr_psoc *ctrl_psoc,
  69. struct cdp_soc_attach_params *params);
  70. /**
  71. * dp_soc_init_wifi3() - Initialize txrx SOC
  72. * @soc: Opaque DP SOC handle
  73. * @ctrl_psoc: Opaque SOC handle from control plane
  74. * @hif_handle: Opaque HIF handle
  75. * @htc_handle: Opaque HTC handle
  76. * @qdf_osdev: QDF device
  77. * @ol_ops: Offload Operations
  78. * @device_id: Device ID
  79. *
  80. * Return: DP SOC handle on success, NULL on failure
  81. */
  82. void *dp_soc_init_wifi3(struct cdp_soc_t *soc,
  83. struct cdp_ctrl_objmgr_psoc *ctrl_psoc,
  84. struct hif_opaque_softc *hif_handle,
  85. HTC_HANDLE htc_handle, qdf_device_t qdf_osdev,
  86. struct ol_if_ops *ol_ops, uint16_t device_id);
  87. #else
  88. static inline struct cdp_soc_t *
  89. dp_soc_attach_wifi3(struct cdp_ctrl_objmgr_psoc *ctrl_psoc,
  90. struct cdp_soc_attach_params *params)
  91. {
  92. return NULL;
  93. }
  94. static inline
  95. void *dp_soc_init_wifi3(struct cdp_soc_t *soc,
  96. struct cdp_ctrl_objmgr_psoc *ctrl_psoc,
  97. struct hif_opaque_softc *hif_handle,
  98. HTC_HANDLE htc_handle, qdf_device_t qdf_osdev,
  99. struct ol_if_ops *ol_ops, uint16_t device_id)
  100. {
  101. return NULL;
  102. }
  103. #endif /* QCA_WIFI_QCA8074 */
  104. static inline int cdp_get_arch_type_from_devid(uint16_t devid)
  105. {
  106. switch (devid) {
  107. case LITHIUM_DP: /*FIXME Add lithium device IDs */
  108. case QCA8074_DEVICE_ID: /* Hawekeye */
  109. case QCA8074V2_DEVICE_ID: /* Hawekeye V2*/
  110. case QCA9574_DEVICE_ID:
  111. case QCA5018_DEVICE_ID:
  112. case QCA6290_DEVICE_ID:
  113. case QCN9000_DEVICE_ID:
  114. case QCN6122_DEVICE_ID:
  115. case QCN9160_DEVICE_ID:
  116. case QCA6390_DEVICE_ID:
  117. case QCA6490_DEVICE_ID:
  118. case QCA6750_DEVICE_ID:
  119. case QCA6390_EMULATION_DEVICE_ID:
  120. case RUMIM2M_DEVICE_ID_NODE0: /*lithium emulation */
  121. case RUMIM2M_DEVICE_ID_NODE1: /*lithium emulation */
  122. case RUMIM2M_DEVICE_ID_NODE2: /*lithium emulation */
  123. case RUMIM2M_DEVICE_ID_NODE3: /*lithium emulation */
  124. case RUMIM2M_DEVICE_ID_NODE4: /*lithium emulation */
  125. case RUMIM2M_DEVICE_ID_NODE5: /*lithium emulation */
  126. return CDP_ARCH_TYPE_LI;
  127. case BERYLLIUM_DP:
  128. case KIWI_DEVICE_ID:
  129. case QCN9224_DEVICE_ID:
  130. case QCA5332_DEVICE_ID:
  131. case MANGO_DEVICE_ID:
  132. case PEACH_DEVICE_ID:
  133. case QCN6432_DEVICE_ID:
  134. return CDP_ARCH_TYPE_BE;
  135. case RHINE_DP:
  136. return CDP_ARCH_TYPE_RH;
  137. default:
  138. return CDP_ARCH_TYPE_NONE;
  139. }
  140. }
  141. static inline
  142. ol_txrx_soc_handle cdp_soc_attach(u_int16_t devid,
  143. struct hif_opaque_softc *hif_handle,
  144. struct cdp_ctrl_objmgr_psoc *psoc,
  145. HTC_HANDLE htc_handle,
  146. qdf_device_t qdf_dev,
  147. struct ol_if_ops *dp_ol_if_ops)
  148. {
  149. struct cdp_soc_attach_params params = {0};
  150. params.hif_handle = hif_handle;
  151. params.device_id = devid;
  152. params.htc_handle = htc_handle;
  153. params.qdf_osdev = qdf_dev;
  154. params.ol_ops = dp_ol_if_ops;
  155. switch (devid) {
  156. case LITHIUM_DP: /*FIXME Add lithium device IDs */
  157. case BERYLLIUM_DP:
  158. case RHINE_DP:
  159. case QCA8074_DEVICE_ID: /* Hawekeye */
  160. case QCA8074V2_DEVICE_ID: /* Hawekeye V2*/
  161. case QCA5018_DEVICE_ID:
  162. case QCA6290_DEVICE_ID:
  163. case QCN9000_DEVICE_ID:
  164. case QCN6122_DEVICE_ID:
  165. case QCN9160_DEVICE_ID:
  166. case QCN6432_DEVICE_ID:
  167. case QCA6390_DEVICE_ID:
  168. case QCA6490_DEVICE_ID:
  169. case QCA6750_DEVICE_ID:
  170. case QCA6390_EMULATION_DEVICE_ID:
  171. case RUMIM2M_DEVICE_ID_NODE0: /*lithium emulation */
  172. case RUMIM2M_DEVICE_ID_NODE1: /*lithium emulation */
  173. case RUMIM2M_DEVICE_ID_NODE2: /*lithium emulation */
  174. case RUMIM2M_DEVICE_ID_NODE3: /*lithium emulation */
  175. case RUMIM2M_DEVICE_ID_NODE4: /*lithium emulation */
  176. case RUMIM2M_DEVICE_ID_NODE5: /*lithium emulation */
  177. case KIWI_DEVICE_ID:
  178. case QCN9224_DEVICE_ID:
  179. case MANGO_DEVICE_ID:
  180. case PEACH_DEVICE_ID:
  181. case QCA5332_DEVICE_ID:
  182. return dp_soc_attach_wifi3(psoc, &params);
  183. break;
  184. default:
  185. return ol_txrx_soc_attach(psoc, dp_ol_if_ops);
  186. }
  187. return NULL;
  188. }
  189. #endif /*_CDP_TXRX_CMN_REG_H_ */