qdf_ipa.h 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709
  1. /*
  2. * Copyright (c) 2017-2021, The Linux Foundation. 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 _QDF_IPA_H
  17. #define _QDF_IPA_H
  18. #ifdef IPA_OFFLOAD
  19. #include <i_qdf_ipa.h>
  20. /**
  21. * enum qdf_ipa_wlan_event - QDF IPA events
  22. * @QDF_IPA_CLIENT_CONNECT: Client Connects
  23. * @QDF_IPA_CLIENT_DISCONNECT: Client Disconnects
  24. * @QDF_IPA_AP_CONNECT: SoftAP is started
  25. * @QDF_IPA_AP_DISCONNECT: SoftAP is stopped
  26. * @QDF_IPA_STA_CONNECT: STA associates to AP
  27. * @QDF_IPA_STA_DISCONNECT: STA dissociates from AP
  28. * @QDF_IPA_CLIENT_CONNECT_EX: Peer associates/re-associates to softap
  29. * @QDF_SWITCH_TO_SCC: WLAN interfaces in scc mode
  30. * @QDF_SWITCH_TO_MCC: WLAN interfaces in mcc mode
  31. * @QDF_WDI_ENABLE: WDI enable complete
  32. * @QDF_WDI_DISABLE: WDI teardown
  33. * @QDF_FWR_SSR_BEFORE_SHUTDOWN: WLAN FW recovery
  34. * @QDF_IPA_WLAN_EVENT_MAX: Max value for the enum
  35. */
  36. typedef enum {
  37. QDF_IPA_CLIENT_CONNECT,
  38. QDF_IPA_CLIENT_DISCONNECT,
  39. QDF_IPA_AP_CONNECT,
  40. QDF_IPA_AP_DISCONNECT,
  41. QDF_IPA_STA_CONNECT,
  42. QDF_IPA_STA_DISCONNECT,
  43. QDF_IPA_CLIENT_CONNECT_EX,
  44. QDF_SWITCH_TO_SCC,
  45. QDF_SWITCH_TO_MCC,
  46. QDF_WDI_ENABLE,
  47. QDF_WDI_DISABLE,
  48. QDF_FWR_SSR_BEFORE_SHUTDOWN,
  49. QDF_IPA_WLAN_EVENT_MAX
  50. } qdf_ipa_wlan_event;
  51. /**
  52. * qdf_ipa_wdi_meter_evt_type_t - type of event client callback is
  53. * for AP+STA mode metering
  54. * @IPA_GET_WDI_SAP_STATS: get IPA_stats betwen SAP and STA -
  55. * use ipa_get_wdi_sap_stats structure
  56. * @IPA_SET_WIFI_QUOTA: set quota limit on STA -
  57. * use ipa_set_wifi_quota structure
  58. */
  59. typedef __qdf_ipa_wdi_meter_evt_type_t qdf_ipa_wdi_meter_evt_type_t;
  60. typedef __qdf_ipa_get_wdi_sap_stats_t qdf_ipa_get_wdi_sap_stats_t;
  61. /**
  62. * qdf_ipa_set_wifi_quota_t - structure used for
  63. * IPA_SET_WIFI_QUOTA.
  64. */
  65. typedef __qdf_ipa_set_wifi_quota_t qdf_ipa_set_wifi_quota_t;
  66. /**
  67. * qdf_ipa_connect_params_t - low-level client connect input parameters. Either
  68. * client allocates the data and desc FIFO and specifies that in data+desc OR
  69. * specifies sizes and pipe_mem pref and IPA does the allocation.
  70. */
  71. typedef __qdf_ipa_connect_params_t qdf_ipa_connect_params_t;
  72. /**
  73. * qdf_ipa_tx_meta_t - meta-data for the TX packet
  74. */
  75. typedef __qdf_ipa_tx_meta_t qdf_ipa_tx_meta_t;
  76. /**
  77. * __qdf_ipa_sps_params_t - SPS related output parameters resulting from
  78. */
  79. typedef __qdf_ipa_sps_params_t qdf_ipa_sps_params_t;
  80. /**
  81. * qdf_ipa_tx_intf_t - interface tx properties
  82. */
  83. typedef __qdf_ipa_tx_intf_t qdf_ipa_tx_intf_t;
  84. /**
  85. * qdf_ipa_rx_intf_t - interface rx properties
  86. */
  87. typedef __qdf_ipa_rx_intf_t qdf_ipa_rx_intf_t;
  88. /**
  89. * qdf_ipa_ext_intf_t - interface ext properties
  90. */
  91. typedef __qdf_ipa_ext_intf_t qdf_ipa_ext_intf_t;
  92. /**
  93. * qdf_ipa_sys_connect_params_t - information needed to setup an IPA end-point
  94. * in system-BAM mode
  95. */
  96. typedef __qdf_ipa_sys_connect_params_t qdf_ipa_sys_connect_params_t;
  97. /**
  98. * __qdf_pa_rm_event_t - IPA RM events
  99. *
  100. * Indicate the resource state change
  101. */
  102. typedef __qdf_ipa_rm_event_t qdf_ipa_rm_event_t;
  103. /**
  104. * struct qdf_ipa_rm_register_params_t - information needed to
  105. * register IPA RM client with IPA RM
  106. */
  107. typedef __qdf_ipa_rm_register_params_t qdf_ipa_rm_register_params_t;
  108. /**
  109. * struct qdf_ipa_rm_create_params_t - information needed to initialize
  110. * the resource
  111. *
  112. * IPA RM client is expected to perform non blocking operations only
  113. * in request_resource and release_resource functions and
  114. * release notification context as soon as possible.
  115. */
  116. typedef __qdf_ipa_rm_create_params_t qdf_ipa_rm_create_params_t;
  117. /**
  118. * qdf_ipa_rm_perf_profile_t - information regarding IPA RM client performance
  119. * profile
  120. */
  121. typedef __qdf_ipa_rm_perf_profile_t qdf_ipa_rm_perf_profile_t;
  122. /**
  123. * qdf_ipa_tx_data_desc_t - information needed
  124. * to send data packet to HW link: link to data descriptors
  125. * priv: client specific private data
  126. */
  127. typedef __qdf_ipa_tx_data_desc_t qdf_ipa_tx_data_desc_t;
  128. /**
  129. * qdf_ipa_rx_data_t - information needed
  130. * to send to wlan driver on receiving data from ipa hw
  131. */
  132. typedef __qdf_ipa_rx_data_t qdf_ipa_rx_data_t;
  133. /**
  134. * qdf_ipa_wdi_ul_params_t - WDI_RX configuration
  135. */
  136. typedef __qdf_ipa_wdi_ul_params_t qdf_ipa_wdi_ul_params_t;
  137. /**
  138. * qdf_ipa_wdi_ul_params_smmu_t - WDI_RX configuration (with WLAN SMMU)
  139. */
  140. typedef __qdf_ipa_wdi_ul_params_smmu_t qdf_ipa_wdi_ul_params_smmu_t;
  141. /**
  142. * qdf_ipa_wdi_dl_params_t - WDI_TX configuration
  143. */
  144. typedef __qdf_ipa_wdi_dl_params_t qdf_ipa_wdi_dl_params_t;
  145. /**
  146. * qdf_ipa_wdi_dl_params_smmu_t - WDI_TX configuration (with WLAN SMMU)
  147. */
  148. typedef __qdf_ipa_wdi_dl_params_smmu_t qdf_ipa_wdi_dl_params_smmu_t;
  149. /**
  150. * qdf_ipa_wdi_in_params_t - information provided by WDI client
  151. */
  152. typedef __qdf_ipa_wdi_in_params_t qdf_ipa_wdi_in_params_t;
  153. /**
  154. * qdf_ipa_wdi_out_params_t - information provided to WDI client
  155. */
  156. typedef __qdf_ipa_wdi_out_params_t qdf_ipa_wdi_out_params_t;
  157. /**
  158. * qdf_ipa_wdi_db_params_t - information provided to retrieve
  159. * physical address of uC doorbell
  160. */
  161. typedef __qdf_ipa_wdi_db_params_t qdf_ipa_wdi_db_params_t;
  162. /**
  163. * qdf_ipa_wdi_uc_ready_params_t - uC ready CB parameters
  164. */
  165. typedef void (*qdf_ipa_uc_ready_cb)(void *priv);
  166. typedef __qdf_ipa_wdi_uc_ready_params_t qdf_ipa_wdi_uc_ready_params_t;
  167. /**
  168. * qdf_ipa_wdi_buffer_info_t - address info of a WLAN allocated buffer
  169. *
  170. * IPA driver will create/release IOMMU mapping in IPA SMMU from iova->pa
  171. */
  172. typedef __qdf_ipa_wdi_buffer_info_t qdf_ipa_wdi_buffer_info_t;
  173. /**
  174. * qdf_ipa_gsi_ep_config_t - IPA GSI endpoint configurations
  175. */
  176. typedef __qdf_ipa_gsi_ep_config_t qdf_ipa_gsi_ep_config_t;
  177. /**
  178. * qdf_ipa_dp_evt_type_t - type of event client callback is
  179. * invoked for on data path
  180. * @IPA_RECEIVE: data is struct sk_buff
  181. * @IPA_WRITE_DONE: data is struct sk_buff
  182. */
  183. typedef __qdf_ipa_dp_evt_type_t qdf_ipa_dp_evt_type_t;
  184. #ifdef WDI3_STATS_UPDATE
  185. /**
  186. * qdf_ipa_wdi_tx_info_t - WLAN embedded TX bytes information
  187. *
  188. * WLAN host fills this structure to update IPA driver about
  189. * embedded TX information.
  190. */
  191. typedef __qdf_ipa_wdi_tx_info_t qdf_ipa_wdi_tx_info_t;
  192. /**
  193. * qdf_ipa_wdi_bw_info_t - BW threshold levels to be monitored
  194. * by IPA uC
  195. */
  196. typedef __qdf_ipa_wdi_bw_info_t qdf_ipa_wdi_bw_info_t;
  197. /**
  198. * qdf_ipa_inform_wlan_bw_t - BW information given by IPA driver
  199. * whenever uC detects threshold level reached
  200. */
  201. typedef __qdf_ipa_inform_wlan_bw_t qdf_ipa_inform_wlan_bw_t;
  202. #endif
  203. typedef __qdf_ipa_hdr_add_t qdf_ipa_hdr_add_t;
  204. typedef __qdf_ipa_hdr_del_t qdf_ipa_hdr_del_t;
  205. typedef __qdf_ipa_ioc_add_hdr_t qdf_ipa_ioc_add_hdr_t;
  206. typedef __qdf_ipa_ioc_del_hdr_t qdf_ipa_ioc_del_hdr_t;
  207. typedef __qdf_ipa_ioc_get_hdr_t qdf_ipa_ioc_get_hdr_t;
  208. typedef __qdf_ipa_ioc_copy_hdr_t qdf_ipa_ioc_copy_hdr_t;
  209. typedef __qdf_ipa_ioc_add_hdr_proc_ctx_t qdf_ipa_ioc_add_hdr_proc_ctx_t;
  210. typedef __qdf_ipa_ioc_del_hdr_proc_ctx_t qdf_ipa_ioc_del_hdr_proc_ctx_t;
  211. typedef __qdf_ipa_msg_meta_t qdf_ipa_msg_meta_t;
  212. typedef __qdf_ipa_client_type_t qdf_ipa_client_type_t;
  213. typedef __qdf_ipa_hw_stats_wdi_info_data_t qdf_ipa_hw_stats_wdi_info_data_t;
  214. typedef __qdf_ipa_rm_resource_name_t qdf_ipa_rm_resource_name_t;
  215. typedef __qdf_ipa_wlan_event_t qdf_ipa_wlan_event_t;
  216. typedef __qdf_ipa_wlan_msg_t qdf_ipa_wlan_msg_t;
  217. typedef __qdf_ipa_wlan_msg_ex_t qdf_ipa_wlan_msg_ex_t;
  218. typedef __qdf_ipa_ioc_tx_intf_prop_t qdf_ipa_ioc_tx_intf_prop_t;
  219. typedef __qdf_ipa_ioc_rx_intf_prop_t qdf_ipa_ioc_rx_intf_prop_t;
  220. typedef __qdf_ipa_wlan_hdr_attrib_val_t qdf_ipa_wlan_hdr_attrib_val_t;
  221. typedef int (*qdf_ipa_msg_pull_fn)(void *buff, u32 len, u32 type);
  222. typedef void (*qdf_ipa_ready_cb)(void *user_data);
  223. #define QDF_IPA_SET_META_MSG_TYPE(meta, msg_type) \
  224. __QDF_IPA_SET_META_MSG_TYPE(meta, msg_type)
  225. #define QDF_IPA_RM_RESOURCE_GRANTED __QDF_IPA_RM_RESOURCE_GRANTED
  226. #define QDF_IPA_RM_RESOURCE_RELEASED __QDF_IPA_RM_RESOURCE_RELEASED
  227. #define QDF_IPA_VOLTAGE_LEVEL __QDF_IPA_VOLTAGE_LEVEL
  228. #define QDF_IPA_RM_RESOURCE_WLAN_PROD __QDF_IPA_RM_RESOURCE_WLAN_PROD
  229. #define QDF_IPA_RM_RESOURCE_WLAN_CONS __QDF_IPA_RM_RESOURCE_WLAN_CONS
  230. #define QDF_IPA_RM_RESOURCE_APPS_CONS __QDF_IPA_RM_RESOURCE_APPS_CONS
  231. #define QDF_IPA_CLIENT_WLAN1_PROD __QDF_IPA_CLIENT_WLAN1_PROD
  232. #define QDF_IPA_CLIENT_WLAN3_PROD __QDF_IPA_CLIENT_WLAN3_PROD
  233. #define QDF_IPA_CLIENT_WLAN1_CONS __QDF_IPA_CLIENT_WLAN1_CONS
  234. #define QDF_IPA_CLIENT_WLAN2_CONS __QDF_IPA_CLIENT_WLAN2_CONS
  235. #define QDF_IPA_CLIENT_WLAN3_CONS __QDF_IPA_CLIENT_WLAN3_CONS
  236. #define QDF_IPA_CLIENT_WLAN4_CONS __QDF_IPA_CLIENT_WLAN4_CONS
  237. #define QDF_IPA_CLIENT_WLAN4_PROD __QDF_IPA_CLIENT_WLAN4_PROD
  238. #ifdef FEATURE_IPA_PIPE_CHANGE_WDI1
  239. #define QDF_IPA_CLIENT_WLAN_LEGACY_CONS QDF_IPA_CLIENT_WLAN3_CONS
  240. #define QDF_IPA_CLIENT_WLAN_LEGACY_PROD QDF_IPA_CLIENT_WLAN3_PROD
  241. #define QDF_IPA_CLIENT_MCC2_CONS QDF_IPA_CLIENT_WLAN4_CONS
  242. #else
  243. #define QDF_IPA_CLIENT_WLAN_LEGACY_CONS QDF_IPA_CLIENT_WLAN1_CONS
  244. #define QDF_IPA_CLIENT_WLAN_LEGACY_PROD QDF_IPA_CLIENT_WLAN1_PROD
  245. #define QDF_IPA_CLIENT_MCC2_CONS QDF_IPA_CLIENT_WLAN3_CONS
  246. #endif
  247. #if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 14, 0)) && \
  248. (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 9, 0))
  249. #define QDF_IPA_CLIENT_WLAN_WDI2_CONS QDF_IPA_CLIENT_WLAN4_CONS
  250. #define QDF_IPA_CLIENT_WLAN_WDI2_PROD QDF_IPA_CLIENT_WLAN4_PROD
  251. #else
  252. #define QDF_IPA_CLIENT_WLAN_WDI2_CONS QDF_IPA_CLIENT_WLAN1_CONS
  253. #define QDF_IPA_CLIENT_WLAN_WDI2_PROD QDF_IPA_CLIENT_WLAN1_PROD
  254. #endif
  255. /*
  256. * Resume / Suspend
  257. */
  258. #if (LINUX_VERSION_CODE < KERNEL_VERSION(5, 10, 0))
  259. static inline int qdf_ipa_reset_endpoint(u32 clnt_hdl)
  260. {
  261. return __qdf_ipa_reset_endpoint(clnt_hdl);
  262. }
  263. /*
  264. * Remove ep delay
  265. */
  266. static inline int qdf_ipa_clear_endpoint_delay(u32 clnt_hdl)
  267. {
  268. return __qdf_ipa_clear_endpoint_delay(clnt_hdl);
  269. }
  270. /*
  271. * Header removal / addition
  272. */
  273. static inline int qdf_ipa_add_hdr(qdf_ipa_ioc_add_hdr_t *hdrs)
  274. {
  275. return __qdf_ipa_add_hdr(hdrs);
  276. }
  277. static inline int qdf_ipa_del_hdr(qdf_ipa_ioc_del_hdr_t *hdls)
  278. {
  279. return __qdf_ipa_del_hdr(hdls);
  280. }
  281. static inline int qdf_ipa_commit_hdr(void)
  282. {
  283. return __qdf_ipa_commit_hdr();
  284. }
  285. static inline int qdf_ipa_get_hdr(qdf_ipa_ioc_get_hdr_t *lookup)
  286. {
  287. return __qdf_ipa_get_hdr(lookup);
  288. }
  289. static inline int qdf_ipa_put_hdr(u32 hdr_hdl)
  290. {
  291. return __qdf_ipa_put_hdr(hdr_hdl);
  292. }
  293. static inline int qdf_ipa_copy_hdr(qdf_ipa_ioc_copy_hdr_t *copy)
  294. {
  295. return __qdf_ipa_copy_hdr(copy);
  296. }
  297. static inline int qdf_ipa_register_pull_msg(qdf_ipa_msg_meta_t *meta,
  298. qdf_ipa_msg_pull_fn callback)
  299. {
  300. return __qdf_ipa_register_pull_msg(meta, callback);
  301. }
  302. static inline int qdf_ipa_deregister_pull_msg(qdf_ipa_msg_meta_t *meta)
  303. {
  304. return __qdf_ipa_deregister_pull_msg(meta);
  305. }
  306. /*
  307. * Interface
  308. */
  309. static inline int qdf_ipa_register_intf(const char *name,
  310. const qdf_ipa_tx_intf_t *tx,
  311. const qdf_ipa_rx_intf_t *rx)
  312. {
  313. return __qdf_ipa_register_intf(name, tx, rx);
  314. }
  315. static inline int qdf_ipa_register_intf_ext(const char *name,
  316. const qdf_ipa_tx_intf_t *tx,
  317. const qdf_ipa_rx_intf_t *rx,
  318. const qdf_ipa_ext_intf_t *ext)
  319. {
  320. return __qdf_ipa_register_intf_ext(name, tx, rx, ext);
  321. }
  322. static inline int qdf_ipa_deregister_intf(const char *name)
  323. {
  324. return __qdf_ipa_deregister_intf(name);
  325. }
  326. /*
  327. * Data path
  328. */
  329. static inline int qdf_ipa_tx_dp(qdf_ipa_client_type_t dst, struct sk_buff *skb,
  330. qdf_ipa_tx_meta_t *metadata)
  331. {
  332. return __qdf_ipa_tx_dp(dst, skb, metadata);
  333. }
  334. /*
  335. * To transfer multiple data packets
  336. */
  337. static inline int qdf_ipa_tx_dp_mul(
  338. qdf_ipa_client_type_t dst,
  339. qdf_ipa_tx_data_desc_t *data_desc)
  340. {
  341. return __qdf_ipa_tx_dp_mul(dst, data_desc);
  342. }
  343. /*
  344. * System pipes
  345. */
  346. static inline u16 qdf_ipa_get_smem_restr_bytes(void)
  347. {
  348. return __qdf_ipa_get_smem_restr_bytes();
  349. }
  350. static inline int qdf_ipa_connect_wdi_pipe(qdf_ipa_wdi_in_params_t *in,
  351. qdf_ipa_wdi_out_params_t *out)
  352. {
  353. return __qdf_ipa_connect_wdi_pipe(in, out);
  354. }
  355. static inline int qdf_ipa_disconnect_wdi_pipe(u32 clnt_hdl)
  356. {
  357. return __qdf_ipa_disconnect_wdi_pipe(clnt_hdl);
  358. }
  359. static inline int qdf_ipa_enable_wdi_pipe(u32 clnt_hdl)
  360. {
  361. return __qdf_ipa_enable_wdi_pipe(clnt_hdl);
  362. }
  363. static inline int qdf_ipa_disable_wdi_pipe(u32 clnt_hdl)
  364. {
  365. return __qdf_ipa_disable_wdi_pipe(clnt_hdl);
  366. }
  367. static inline int qdf_ipa_resume_wdi_pipe(u32 clnt_hdl)
  368. {
  369. return __qdf_ipa_resume_wdi_pipe(clnt_hdl);
  370. }
  371. static inline int qdf_ipa_suspend_wdi_pipe(u32 clnt_hdl)
  372. {
  373. return __qdf_ipa_suspend_wdi_pipe(clnt_hdl);
  374. }
  375. static inline int qdf_ipa_uc_wdi_get_dbpa(
  376. qdf_ipa_wdi_db_params_t *out)
  377. {
  378. return __qdf_ipa_uc_wdi_get_dbpa(out);
  379. }
  380. /*
  381. * Resource manager
  382. */
  383. static inline int qdf_ipa_rm_create_resource(
  384. qdf_ipa_rm_create_params_t *create_params)
  385. {
  386. return __qdf_ipa_rm_create_resource(create_params);
  387. }
  388. static inline int qdf_ipa_rm_delete_resource(
  389. qdf_ipa_rm_resource_name_t resource_name)
  390. {
  391. return __qdf_ipa_rm_delete_resource(resource_name);
  392. }
  393. static inline int qdf_ipa_rm_register(qdf_ipa_rm_resource_name_t resource_name,
  394. qdf_ipa_rm_register_params_t *reg_params)
  395. {
  396. return __qdf_ipa_rm_register(resource_name, reg_params);
  397. }
  398. static inline int qdf_ipa_rm_set_perf_profile(
  399. qdf_ipa_rm_resource_name_t resource_name,
  400. qdf_ipa_rm_perf_profile_t *profile)
  401. {
  402. return __qdf_ipa_rm_set_perf_profile(resource_name, profile);
  403. }
  404. static inline int qdf_ipa_rm_deregister(qdf_ipa_rm_resource_name_t resource_name,
  405. qdf_ipa_rm_register_params_t *reg_params)
  406. {
  407. return __qdf_ipa_rm_deregister(resource_name, reg_params);
  408. }
  409. static inline int qdf_ipa_rm_add_dependency(
  410. qdf_ipa_rm_resource_name_t resource_name,
  411. qdf_ipa_rm_resource_name_t depends_on_name)
  412. {
  413. return __qdf_ipa_rm_add_dependency(resource_name, depends_on_name);
  414. }
  415. static inline int qdf_ipa_rm_add_dependency_sync(
  416. qdf_ipa_rm_resource_name_t resource_name,
  417. qdf_ipa_rm_resource_name_t depends_on_name)
  418. {
  419. return __qdf_ipa_rm_add_dependency_sync(resource_name, depends_on_name);
  420. }
  421. static inline int qdf_ipa_rm_delete_dependency(
  422. qdf_ipa_rm_resource_name_t resource_name,
  423. qdf_ipa_rm_resource_name_t depends_on_name)
  424. {
  425. return __qdf_ipa_rm_delete_dependency(resource_name, depends_on_name);
  426. }
  427. static inline int qdf_ipa_rm_request_resource(
  428. qdf_ipa_rm_resource_name_t resource_name)
  429. {
  430. return __qdf_ipa_rm_request_resource(resource_name);
  431. }
  432. static inline int qdf_ipa_rm_release_resource(
  433. qdf_ipa_rm_resource_name_t resource_name)
  434. {
  435. return __qdf_ipa_rm_release_resource(resource_name);
  436. }
  437. static inline int qdf_ipa_rm_notify_completion(qdf_ipa_rm_event_t event,
  438. qdf_ipa_rm_resource_name_t resource_name)
  439. {
  440. return __qdf_ipa_rm_notify_completion(event, resource_name);
  441. }
  442. static inline int qdf_ipa_rm_inactivity_timer_init(
  443. qdf_ipa_rm_resource_name_t resource_name,
  444. unsigned long msecs)
  445. {
  446. return __qdf_ipa_rm_inactivity_timer_init(resource_name, msecs);
  447. }
  448. static inline int qdf_ipa_rm_inactivity_timer_destroy(
  449. qdf_ipa_rm_resource_name_t resource_name)
  450. {
  451. return __qdf_ipa_rm_inactivity_timer_destroy(resource_name);
  452. }
  453. static inline int qdf_ipa_rm_inactivity_timer_request_resource(
  454. qdf_ipa_rm_resource_name_t resource_name)
  455. {
  456. return __qdf_ipa_rm_inactivity_timer_request_resource(resource_name);
  457. }
  458. static inline int qdf_ipa_rm_inactivity_timer_release_resource(
  459. qdf_ipa_rm_resource_name_t resource_name)
  460. {
  461. return __qdf_ipa_rm_inactivity_timer_release_resource(resource_name);
  462. }
  463. /*
  464. * Miscellaneous
  465. */
  466. static inline void qdf_ipa_bam_reg_dump(void)
  467. {
  468. return __qdf_ipa_bam_reg_dump();
  469. }
  470. static inline int qdf_ipa_get_ep_mapping(qdf_ipa_client_type_t client)
  471. {
  472. return __qdf_ipa_get_ep_mapping(client);
  473. }
  474. static inline void qdf_ipa_proxy_clk_vote(void)
  475. {
  476. return __qdf_ipa_proxy_clk_vote();
  477. }
  478. static inline void qdf_ipa_proxy_clk_unvote(void)
  479. {
  480. return __qdf_ipa_proxy_clk_unvote();
  481. }
  482. static inline bool qdf_ipa_is_client_handle_valid(u32 clnt_hdl)
  483. {
  484. return __qdf_ipa_is_client_handle_valid(clnt_hdl);
  485. }
  486. static inline qdf_ipa_client_type_t qdf_ipa_get_client_mapping(int pipe_idx)
  487. {
  488. return __qdf_ipa_get_client_mapping(pipe_idx);
  489. }
  490. static inline qdf_ipa_rm_resource_name_t qdf_ipa_get_rm_resource_from_ep(
  491. int pipe_idx)
  492. {
  493. return __qdf_ipa_get_rm_resource_from_ep(pipe_idx);
  494. }
  495. static inline bool qdf_ipa_get_modem_cfg_emb_pipe_flt(void)
  496. {
  497. return __qdf_ipa_get_modem_cfg_emb_pipe_flt();
  498. }
  499. static inline int qdf_ipa_create_wdi_mapping(u32 num_buffers,
  500. __qdf_ipa_wdi_buffer_info_t *info)
  501. {
  502. return __qdf_ipa_create_wdi_mapping(num_buffers, info);
  503. }
  504. static inline int qdf_ipa_release_wdi_mapping(u32 num_buffers,
  505. qdf_ipa_wdi_buffer_info_t *info)
  506. {
  507. return __qdf_ipa_release_wdi_mapping(num_buffers, info);
  508. }
  509. static inline int qdf_ipa_disable_apps_wan_cons_deaggr(uint32_t agg_size,
  510. uint32_t agg_count)
  511. {
  512. return __qdf_ipa_disable_apps_wan_cons_deaggr(agg_size, agg_count);
  513. }
  514. static inline const qdf_ipa_gsi_ep_config_t *qdf_ipa_get_gsi_ep_info(qdf_ipa_client_type_t client)
  515. {
  516. return __qdf_ipa_get_gsi_ep_info(client);
  517. }
  518. static inline int qdf_ipa_stop_gsi_channel(u32 clnt_hdl)
  519. {
  520. return __qdf_ipa_stop_gsi_channel(clnt_hdl);
  521. }
  522. #endif
  523. static inline void qdf_ipa_free_skb(qdf_ipa_rx_data_t *rx_in)
  524. {
  525. return __qdf_ipa_free_skb(rx_in);
  526. }
  527. static inline int qdf_ipa_uc_reg_rdyCB(
  528. qdf_ipa_wdi_uc_ready_params_t *param)
  529. {
  530. return __qdf_ipa_uc_reg_rdyCB(param);
  531. }
  532. static inline int qdf_ipa_uc_dereg_rdyCB(void)
  533. {
  534. return __qdf_ipa_uc_dereg_rdyCB();
  535. }
  536. static inline int qdf_ipa_get_wdi_stats(qdf_ipa_hw_stats_wdi_info_data_t *stats)
  537. {
  538. return __qdf_ipa_get_wdi_stats(stats);
  539. }
  540. static inline int qdf_ipa_register_ipa_ready_cb(
  541. void (*qdf_ipa_ready_cb)(void *user_data),
  542. void *user_data)
  543. {
  544. return __qdf_ipa_register_ipa_ready_cb(qdf_ipa_ready_cb, user_data);
  545. }
  546. static inline int qdf_ipa_setup_sys_pipe(qdf_ipa_sys_connect_params_t *sys_in,
  547. u32 *clnt_hdl)
  548. {
  549. return __qdf_ipa_setup_sys_pipe(sys_in, clnt_hdl);
  550. }
  551. static inline int qdf_ipa_teardown_sys_pipe(u32 clnt_hdl)
  552. {
  553. return __qdf_ipa_teardown_sys_pipe(clnt_hdl);
  554. }
  555. /*
  556. * Messaging
  557. */
  558. static inline int qdf_ipa_send_msg(qdf_ipa_msg_meta_t *meta, void *buff,
  559. ipa_msg_free_fn callback)
  560. {
  561. return __qdf_ipa_send_msg(meta, buff, callback);
  562. }
  563. static inline bool qdf_ipa_is_ready(void)
  564. {
  565. return __qdf_ipa_is_ready();
  566. }
  567. #ifdef FEATURE_METERING
  568. static inline int qdf_ipa_broadcast_wdi_quota_reach_ind(uint32_t index,
  569. uint64_t quota_bytes)
  570. {
  571. return __qdf_ipa_broadcast_wdi_quota_reach_ind(index, quota_bytes);
  572. }
  573. #endif
  574. #ifdef ENABLE_SMMU_S1_TRANSLATION
  575. /**
  576. * qdf_get_ipa_smmu_enabled() - to get IPA SMMU enable status
  577. *
  578. * Return: true when IPA SMMU enabled, otherwise false
  579. */
  580. static inline bool qdf_get_ipa_smmu_enabled(void)
  581. {
  582. return __qdf_get_ipa_smmu_enabled();
  583. }
  584. #endif
  585. #ifdef IPA_LAN_RX_NAPI_SUPPORT
  586. /**
  587. * qdf_ipa_get_lan_rx_napi() - Check if NAPI is enabled in LAN
  588. * RX DP
  589. *
  590. * Returns: true if enabled, false otherwise
  591. */
  592. static inline bool qdf_ipa_get_lan_rx_napi(void)
  593. {
  594. return __qdf_ipa_get_lan_rx_napi();
  595. }
  596. #else
  597. static inline bool qdf_ipa_get_lan_rx_napi(void)
  598. {
  599. return false;
  600. }
  601. #endif /* IPA_LAN_RX_NAPI_SUPPORT */
  602. #endif /* IPA_OFFLOAD */
  603. #endif /* _QDF_IPA_H */