123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725 |
- /*
- * Copyright (c) 2017-2021, The Linux Foundation. All rights reserved.
- * Copyright (c) 2022-2023 Qualcomm Innovation Center, Inc. All rights reserved.
- *
- * Permission to use, copy, modify, and/or distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
- #ifndef _QDF_IPA_H
- #define _QDF_IPA_H
- #include <linux/types.h>
- #ifdef IPA_OFFLOAD
- #include <i_qdf_ipa.h>
- /**
- * enum qdf_ipa_wlan_event - QDF IPA events
- * @QDF_IPA_CLIENT_CONNECT: Client Connects
- * @QDF_IPA_CLIENT_DISCONNECT: Client Disconnects
- * @QDF_IPA_AP_CONNECT: SoftAP is started
- * @QDF_IPA_AP_DISCONNECT: SoftAP is stopped
- * @QDF_IPA_STA_CONNECT: STA associates to AP
- * @QDF_IPA_STA_DISCONNECT: STA dissociates from AP
- * @QDF_IPA_CLIENT_CONNECT_EX: Peer associates/re-associates to softap
- * @QDF_SWITCH_TO_SCC: WLAN interfaces in scc mode
- * @QDF_SWITCH_TO_MCC: WLAN interfaces in mcc mode
- * @QDF_WDI_ENABLE: WDI enable complete
- * @QDF_WDI_DISABLE: WDI teardown
- * @QDF_FWR_SSR_BEFORE_SHUTDOWN: WLAN FW recovery
- * @QDF_IPA_WLAN_EVENT_MAX: Max value for the enum
- */
- typedef enum {
- QDF_IPA_CLIENT_CONNECT,
- QDF_IPA_CLIENT_DISCONNECT,
- QDF_IPA_AP_CONNECT,
- QDF_IPA_AP_DISCONNECT,
- QDF_IPA_STA_CONNECT,
- QDF_IPA_STA_DISCONNECT,
- QDF_IPA_CLIENT_CONNECT_EX,
- QDF_SWITCH_TO_SCC,
- QDF_SWITCH_TO_MCC,
- QDF_WDI_ENABLE,
- QDF_WDI_DISABLE,
- QDF_FWR_SSR_BEFORE_SHUTDOWN,
- QDF_IPA_WLAN_EVENT_MAX
- } qdf_ipa_wlan_event;
- /**
- * qdf_ipa_wdi_meter_evt_type_t - type of event client callback is
- * for AP+STA mode metering
- * @IPA_GET_WDI_SAP_STATS: get IPA_stats between SAP and STA -
- * use ipa_get_wdi_sap_stats structure
- * @IPA_SET_WIFI_QUOTA: set quota limit on STA -
- * use ipa_set_wifi_quota structure
- */
- typedef __qdf_ipa_wdi_meter_evt_type_t qdf_ipa_wdi_meter_evt_type_t;
- typedef __qdf_ipa_get_wdi_sap_stats_t qdf_ipa_get_wdi_sap_stats_t;
- /**
- * qdf_ipa_set_wifi_quota_t - structure used for
- * IPA_SET_WIFI_QUOTA.
- */
- typedef __qdf_ipa_set_wifi_quota_t qdf_ipa_set_wifi_quota_t;
- /**
- * qdf_ipa_connect_params_t - low-level client connect input parameters. Either
- * client allocates the data and desc FIFO and specifies that in data+desc OR
- * specifies sizes and pipe_mem pref and IPA does the allocation.
- */
- typedef __qdf_ipa_connect_params_t qdf_ipa_connect_params_t;
- /**
- * qdf_ipa_tx_meta_t - meta-data for the TX packet
- */
- typedef __qdf_ipa_tx_meta_t qdf_ipa_tx_meta_t;
- /**
- * __qdf_ipa_sps_params_t - SPS related output parameters resulting from
- */
- typedef __qdf_ipa_sps_params_t qdf_ipa_sps_params_t;
- /**
- * qdf_ipa_tx_intf_t - interface tx properties
- */
- typedef __qdf_ipa_tx_intf_t qdf_ipa_tx_intf_t;
- /**
- * qdf_ipa_rx_intf_t - interface rx properties
- */
- typedef __qdf_ipa_rx_intf_t qdf_ipa_rx_intf_t;
- /**
- * qdf_ipa_ext_intf_t - interface ext properties
- */
- typedef __qdf_ipa_ext_intf_t qdf_ipa_ext_intf_t;
- /**
- * qdf_ipa_sys_connect_params_t - information needed to setup an IPA end-point
- * in system-BAM mode
- */
- typedef __qdf_ipa_sys_connect_params_t qdf_ipa_sys_connect_params_t;
- /**
- * __qdf_pa_rm_event_t - IPA RM events
- *
- * Indicate the resource state change
- */
- typedef __qdf_ipa_rm_event_t qdf_ipa_rm_event_t;
- /**
- * struct qdf_ipa_rm_register_params_t - information needed to
- * register IPA RM client with IPA RM
- */
- typedef __qdf_ipa_rm_register_params_t qdf_ipa_rm_register_params_t;
- /**
- * struct qdf_ipa_rm_create_params_t - information needed to initialize
- * the resource
- *
- * IPA RM client is expected to perform non blocking operations only
- * in request_resource and release_resource functions and
- * release notification context as soon as possible.
- */
- typedef __qdf_ipa_rm_create_params_t qdf_ipa_rm_create_params_t;
- /**
- * qdf_ipa_rm_perf_profile_t - information regarding IPA RM client performance
- * profile
- */
- typedef __qdf_ipa_rm_perf_profile_t qdf_ipa_rm_perf_profile_t;
- /**
- * qdf_ipa_tx_data_desc_t - information needed
- * to send data packet to HW link: link to data descriptors
- * priv: client specific private data
- */
- typedef __qdf_ipa_tx_data_desc_t qdf_ipa_tx_data_desc_t;
- /**
- * qdf_ipa_rx_data_t - information needed
- * to send to wlan driver on receiving data from ipa hw
- */
- typedef __qdf_ipa_rx_data_t qdf_ipa_rx_data_t;
- /**
- * qdf_ipa_wdi_ul_params_t - WDI_RX configuration
- */
- typedef __qdf_ipa_wdi_ul_params_t qdf_ipa_wdi_ul_params_t;
- /**
- * qdf_ipa_wdi_ul_params_smmu_t - WDI_RX configuration (with WLAN SMMU)
- */
- typedef __qdf_ipa_wdi_ul_params_smmu_t qdf_ipa_wdi_ul_params_smmu_t;
- /**
- * qdf_ipa_wdi_dl_params_t - WDI_TX configuration
- */
- typedef __qdf_ipa_wdi_dl_params_t qdf_ipa_wdi_dl_params_t;
- /**
- * qdf_ipa_wdi_dl_params_smmu_t - WDI_TX configuration (with WLAN SMMU)
- */
- typedef __qdf_ipa_wdi_dl_params_smmu_t qdf_ipa_wdi_dl_params_smmu_t;
- /**
- * qdf_ipa_wdi_in_params_t - information provided by WDI client
- */
- typedef __qdf_ipa_wdi_in_params_t qdf_ipa_wdi_in_params_t;
- /**
- * qdf_ipa_wdi_out_params_t - information provided to WDI client
- */
- typedef __qdf_ipa_wdi_out_params_t qdf_ipa_wdi_out_params_t;
- /**
- * qdf_ipa_wdi_db_params_t - information provided to retrieve
- * physical address of uC doorbell
- */
- typedef __qdf_ipa_wdi_db_params_t qdf_ipa_wdi_db_params_t;
- /**
- * qdf_ipa_wdi_uc_ready_params_t - uC ready CB parameters
- */
- typedef void (*qdf_ipa_uc_ready_cb)(void *priv);
- typedef __qdf_ipa_wdi_uc_ready_params_t qdf_ipa_wdi_uc_ready_params_t;
- /**
- * qdf_ipa_wdi_buffer_info_t - address info of a WLAN allocated buffer
- *
- * IPA driver will create/release IOMMU mapping in IPA SMMU from iova->pa
- */
- typedef __qdf_ipa_wdi_buffer_info_t qdf_ipa_wdi_buffer_info_t;
- /**
- * qdf_ipa_gsi_ep_config_t - IPA GSI endpoint configurations
- */
- typedef __qdf_ipa_gsi_ep_config_t qdf_ipa_gsi_ep_config_t;
- /**
- * qdf_ipa_dp_evt_type_t - type of event client callback is
- * invoked for on data path
- * @IPA_RECEIVE: data is struct sk_buff
- * @IPA_WRITE_DONE: data is struct sk_buff
- */
- typedef __qdf_ipa_dp_evt_type_t qdf_ipa_dp_evt_type_t;
- #ifdef WDI3_STATS_UPDATE
- /**
- * qdf_ipa_wdi_tx_info_t - WLAN embedded TX bytes information
- *
- * WLAN host fills this structure to update IPA driver about
- * embedded TX information.
- */
- typedef __qdf_ipa_wdi_tx_info_t qdf_ipa_wdi_tx_info_t;
- /**
- * qdf_ipa_wdi_bw_info_t - BW threshold levels to be monitored
- * by IPA uC
- */
- typedef __qdf_ipa_wdi_bw_info_t qdf_ipa_wdi_bw_info_t;
- /**
- * qdf_ipa_inform_wlan_bw_t - BW information given by IPA driver
- * whenever uC detects threshold level reached
- */
- typedef __qdf_ipa_inform_wlan_bw_t qdf_ipa_inform_wlan_bw_t;
- #endif
- typedef __qdf_ipa_hdr_add_t qdf_ipa_hdr_add_t;
- typedef __qdf_ipa_hdr_del_t qdf_ipa_hdr_del_t;
- typedef __qdf_ipa_ioc_add_hdr_t qdf_ipa_ioc_add_hdr_t;
- typedef __qdf_ipa_ioc_del_hdr_t qdf_ipa_ioc_del_hdr_t;
- typedef __qdf_ipa_ioc_get_hdr_t qdf_ipa_ioc_get_hdr_t;
- typedef __qdf_ipa_ioc_copy_hdr_t qdf_ipa_ioc_copy_hdr_t;
- typedef __qdf_ipa_ioc_add_hdr_proc_ctx_t qdf_ipa_ioc_add_hdr_proc_ctx_t;
- typedef __qdf_ipa_ioc_del_hdr_proc_ctx_t qdf_ipa_ioc_del_hdr_proc_ctx_t;
- typedef __qdf_ipa_msg_meta_t qdf_ipa_msg_meta_t;
- typedef __qdf_ipa_client_type_t qdf_ipa_client_type_t;
- typedef __qdf_ipa_hw_stats_wdi_info_data_t qdf_ipa_hw_stats_wdi_info_data_t;
- typedef __qdf_ipa_rm_resource_name_t qdf_ipa_rm_resource_name_t;
- typedef __qdf_ipa_wlan_event_t qdf_ipa_wlan_event_t;
- typedef __qdf_ipa_wlan_msg_t qdf_ipa_wlan_msg_t;
- typedef __qdf_ipa_wlan_msg_ex_t qdf_ipa_wlan_msg_ex_t;
- typedef __qdf_ipa_ioc_tx_intf_prop_t qdf_ipa_ioc_tx_intf_prop_t;
- typedef __qdf_ipa_ioc_rx_intf_prop_t qdf_ipa_ioc_rx_intf_prop_t;
- typedef __qdf_ipa_wlan_hdr_attrib_val_t qdf_ipa_wlan_hdr_attrib_val_t;
- typedef int (*qdf_ipa_msg_pull_fn)(void *buff, u32 len, u32 type);
- typedef void (*qdf_ipa_ready_cb)(void *user_data);
- #ifdef IPA_WDS_EASYMESH_FEATURE
- /**
- * __qdf_ipa_ast_info_type_t - AST entry create/update information
- */
- typedef __qdf_ipa_ast_info_type_t qdf_ipa_ast_info_type_t;
- #endif
- #define QDF_IPA_SET_META_MSG_TYPE(meta, msg_type) \
- __QDF_IPA_SET_META_MSG_TYPE(meta, msg_type)
- #define QDF_IPA_RM_RESOURCE_GRANTED __QDF_IPA_RM_RESOURCE_GRANTED
- #define QDF_IPA_RM_RESOURCE_RELEASED __QDF_IPA_RM_RESOURCE_RELEASED
- #define QDF_IPA_VOLTAGE_LEVEL __QDF_IPA_VOLTAGE_LEVEL
- #define QDF_IPA_RM_RESOURCE_WLAN_PROD __QDF_IPA_RM_RESOURCE_WLAN_PROD
- #define QDF_IPA_RM_RESOURCE_WLAN_CONS __QDF_IPA_RM_RESOURCE_WLAN_CONS
- #define QDF_IPA_RM_RESOURCE_APPS_CONS __QDF_IPA_RM_RESOURCE_APPS_CONS
- #define QDF_IPA_CLIENT_WLAN1_PROD __QDF_IPA_CLIENT_WLAN1_PROD
- #define QDF_IPA_CLIENT_WLAN3_PROD __QDF_IPA_CLIENT_WLAN3_PROD
- #define QDF_IPA_CLIENT_WLAN1_CONS __QDF_IPA_CLIENT_WLAN1_CONS
- #define QDF_IPA_CLIENT_WLAN2_CONS __QDF_IPA_CLIENT_WLAN2_CONS
- #define QDF_IPA_CLIENT_WLAN3_CONS __QDF_IPA_CLIENT_WLAN3_CONS
- #define QDF_IPA_CLIENT_WLAN4_CONS __QDF_IPA_CLIENT_WLAN4_CONS
- #define QDF_IPA_CLIENT_WLAN4_PROD __QDF_IPA_CLIENT_WLAN4_PROD
- #ifdef FEATURE_IPA_PIPE_CHANGE_WDI1
- #define QDF_IPA_CLIENT_WLAN_LEGACY_CONS QDF_IPA_CLIENT_WLAN3_CONS
- #define QDF_IPA_CLIENT_WLAN_LEGACY_PROD QDF_IPA_CLIENT_WLAN3_PROD
- #define QDF_IPA_CLIENT_MCC2_CONS QDF_IPA_CLIENT_WLAN4_CONS
- #else
- #define QDF_IPA_CLIENT_WLAN_LEGACY_CONS QDF_IPA_CLIENT_WLAN1_CONS
- #define QDF_IPA_CLIENT_WLAN_LEGACY_PROD QDF_IPA_CLIENT_WLAN1_PROD
- #define QDF_IPA_CLIENT_MCC2_CONS QDF_IPA_CLIENT_WLAN3_CONS
- #endif
- #ifdef QCN7605_SUPPORT
- #define QDF_IPA_CLIENT_WLAN_WDI2_CONS __QDF_IPA_CLIENT_WLAN_WDI2_CONS
- #define QDF_IPA_CLIENT_WLAN_WDI2_PROD __QDF_IPA_CLIENT_WLAN_WDI2_PROD
- #else
- #define QDF_IPA_CLIENT_WLAN_WDI2_CONS QDF_IPA_CLIENT_WLAN1_CONS
- #define QDF_IPA_CLIENT_WLAN_WDI2_PROD QDF_IPA_CLIENT_WLAN1_PROD
- #endif
- /*
- * Resume / Suspend
- */
- #if (LINUX_VERSION_CODE < KERNEL_VERSION(5, 10, 0))
- static inline int qdf_ipa_reset_endpoint(u32 clnt_hdl)
- {
- return __qdf_ipa_reset_endpoint(clnt_hdl);
- }
- /*
- * Remove ep delay
- */
- static inline int qdf_ipa_clear_endpoint_delay(u32 clnt_hdl)
- {
- return __qdf_ipa_clear_endpoint_delay(clnt_hdl);
- }
- /*
- * Header removal / addition
- */
- static inline int qdf_ipa_add_hdr(qdf_ipa_ioc_add_hdr_t *hdrs)
- {
- return __qdf_ipa_add_hdr(hdrs);
- }
- static inline int qdf_ipa_del_hdr(qdf_ipa_ioc_del_hdr_t *hdls)
- {
- return __qdf_ipa_del_hdr(hdls);
- }
- static inline int qdf_ipa_commit_hdr(void)
- {
- return __qdf_ipa_commit_hdr();
- }
- static inline int qdf_ipa_get_hdr(qdf_ipa_ioc_get_hdr_t *lookup)
- {
- return __qdf_ipa_get_hdr(lookup);
- }
- static inline int qdf_ipa_put_hdr(u32 hdr_hdl)
- {
- return __qdf_ipa_put_hdr(hdr_hdl);
- }
- static inline int qdf_ipa_copy_hdr(qdf_ipa_ioc_copy_hdr_t *copy)
- {
- return __qdf_ipa_copy_hdr(copy);
- }
- static inline int qdf_ipa_register_pull_msg(qdf_ipa_msg_meta_t *meta,
- qdf_ipa_msg_pull_fn callback)
- {
- return __qdf_ipa_register_pull_msg(meta, callback);
- }
- static inline int qdf_ipa_deregister_pull_msg(qdf_ipa_msg_meta_t *meta)
- {
- return __qdf_ipa_deregister_pull_msg(meta);
- }
- /*
- * Interface
- */
- static inline int qdf_ipa_register_intf(const char *name,
- const qdf_ipa_tx_intf_t *tx,
- const qdf_ipa_rx_intf_t *rx)
- {
- return __qdf_ipa_register_intf(name, tx, rx);
- }
- static inline int qdf_ipa_register_intf_ext(const char *name,
- const qdf_ipa_tx_intf_t *tx,
- const qdf_ipa_rx_intf_t *rx,
- const qdf_ipa_ext_intf_t *ext)
- {
- return __qdf_ipa_register_intf_ext(name, tx, rx, ext);
- }
- static inline int qdf_ipa_deregister_intf(const char *name)
- {
- return __qdf_ipa_deregister_intf(name);
- }
- /*
- * Data path
- */
- static inline int qdf_ipa_tx_dp(qdf_ipa_client_type_t dst, struct sk_buff *skb,
- qdf_ipa_tx_meta_t *metadata)
- {
- return __qdf_ipa_tx_dp(dst, skb, metadata);
- }
- /*
- * To transfer multiple data packets
- */
- static inline int qdf_ipa_tx_dp_mul(
- qdf_ipa_client_type_t dst,
- qdf_ipa_tx_data_desc_t *data_desc)
- {
- return __qdf_ipa_tx_dp_mul(dst, data_desc);
- }
- /*
- * System pipes
- */
- static inline u16 qdf_ipa_get_smem_restr_bytes(void)
- {
- return __qdf_ipa_get_smem_restr_bytes();
- }
- static inline int qdf_ipa_connect_wdi_pipe(qdf_ipa_wdi_in_params_t *in,
- qdf_ipa_wdi_out_params_t *out)
- {
- return __qdf_ipa_connect_wdi_pipe(in, out);
- }
- static inline int qdf_ipa_disconnect_wdi_pipe(u32 clnt_hdl)
- {
- return __qdf_ipa_disconnect_wdi_pipe(clnt_hdl);
- }
- static inline int qdf_ipa_enable_wdi_pipe(u32 clnt_hdl)
- {
- return __qdf_ipa_enable_wdi_pipe(clnt_hdl);
- }
- static inline int qdf_ipa_disable_wdi_pipe(u32 clnt_hdl)
- {
- return __qdf_ipa_disable_wdi_pipe(clnt_hdl);
- }
- static inline int qdf_ipa_resume_wdi_pipe(u32 clnt_hdl)
- {
- return __qdf_ipa_resume_wdi_pipe(clnt_hdl);
- }
- static inline int qdf_ipa_suspend_wdi_pipe(u32 clnt_hdl)
- {
- return __qdf_ipa_suspend_wdi_pipe(clnt_hdl);
- }
- static inline int qdf_ipa_uc_wdi_get_dbpa(
- qdf_ipa_wdi_db_params_t *out)
- {
- return __qdf_ipa_uc_wdi_get_dbpa(out);
- }
- /*
- * Resource manager
- */
- static inline int qdf_ipa_rm_create_resource(
- qdf_ipa_rm_create_params_t *create_params)
- {
- return __qdf_ipa_rm_create_resource(create_params);
- }
- static inline int qdf_ipa_rm_delete_resource(
- qdf_ipa_rm_resource_name_t resource_name)
- {
- return __qdf_ipa_rm_delete_resource(resource_name);
- }
- static inline int qdf_ipa_rm_register(qdf_ipa_rm_resource_name_t resource_name,
- qdf_ipa_rm_register_params_t *reg_params)
- {
- return __qdf_ipa_rm_register(resource_name, reg_params);
- }
- static inline int qdf_ipa_rm_set_perf_profile(
- qdf_ipa_rm_resource_name_t resource_name,
- qdf_ipa_rm_perf_profile_t *profile)
- {
- return __qdf_ipa_rm_set_perf_profile(resource_name, profile);
- }
- static inline int qdf_ipa_rm_deregister(qdf_ipa_rm_resource_name_t resource_name,
- qdf_ipa_rm_register_params_t *reg_params)
- {
- return __qdf_ipa_rm_deregister(resource_name, reg_params);
- }
- static inline int qdf_ipa_rm_add_dependency(
- qdf_ipa_rm_resource_name_t resource_name,
- qdf_ipa_rm_resource_name_t depends_on_name)
- {
- return __qdf_ipa_rm_add_dependency(resource_name, depends_on_name);
- }
- static inline int qdf_ipa_rm_add_dependency_sync(
- qdf_ipa_rm_resource_name_t resource_name,
- qdf_ipa_rm_resource_name_t depends_on_name)
- {
- return __qdf_ipa_rm_add_dependency_sync(resource_name, depends_on_name);
- }
- static inline int qdf_ipa_rm_delete_dependency(
- qdf_ipa_rm_resource_name_t resource_name,
- qdf_ipa_rm_resource_name_t depends_on_name)
- {
- return __qdf_ipa_rm_delete_dependency(resource_name, depends_on_name);
- }
- static inline int qdf_ipa_rm_request_resource(
- qdf_ipa_rm_resource_name_t resource_name)
- {
- return __qdf_ipa_rm_request_resource(resource_name);
- }
- static inline int qdf_ipa_rm_release_resource(
- qdf_ipa_rm_resource_name_t resource_name)
- {
- return __qdf_ipa_rm_release_resource(resource_name);
- }
- static inline int qdf_ipa_rm_notify_completion(qdf_ipa_rm_event_t event,
- qdf_ipa_rm_resource_name_t resource_name)
- {
- return __qdf_ipa_rm_notify_completion(event, resource_name);
- }
- static inline int qdf_ipa_rm_inactivity_timer_init(
- qdf_ipa_rm_resource_name_t resource_name,
- unsigned long msecs)
- {
- return __qdf_ipa_rm_inactivity_timer_init(resource_name, msecs);
- }
- static inline int qdf_ipa_rm_inactivity_timer_destroy(
- qdf_ipa_rm_resource_name_t resource_name)
- {
- return __qdf_ipa_rm_inactivity_timer_destroy(resource_name);
- }
- static inline int qdf_ipa_rm_inactivity_timer_request_resource(
- qdf_ipa_rm_resource_name_t resource_name)
- {
- return __qdf_ipa_rm_inactivity_timer_request_resource(resource_name);
- }
- static inline int qdf_ipa_rm_inactivity_timer_release_resource(
- qdf_ipa_rm_resource_name_t resource_name)
- {
- return __qdf_ipa_rm_inactivity_timer_release_resource(resource_name);
- }
- /*
- * Miscellaneous
- */
- static inline void qdf_ipa_bam_reg_dump(void)
- {
- return __qdf_ipa_bam_reg_dump();
- }
- static inline int qdf_ipa_get_ep_mapping(qdf_ipa_client_type_t client)
- {
- return __qdf_ipa_get_ep_mapping(client);
- }
- static inline void qdf_ipa_proxy_clk_vote(void)
- {
- return __qdf_ipa_proxy_clk_vote();
- }
- static inline void qdf_ipa_proxy_clk_unvote(void)
- {
- return __qdf_ipa_proxy_clk_unvote();
- }
- static inline bool qdf_ipa_is_client_handle_valid(u32 clnt_hdl)
- {
- return __qdf_ipa_is_client_handle_valid(clnt_hdl);
- }
- static inline qdf_ipa_client_type_t qdf_ipa_get_client_mapping(int pipe_idx)
- {
- return __qdf_ipa_get_client_mapping(pipe_idx);
- }
- static inline qdf_ipa_rm_resource_name_t qdf_ipa_get_rm_resource_from_ep(
- int pipe_idx)
- {
- return __qdf_ipa_get_rm_resource_from_ep(pipe_idx);
- }
- static inline bool qdf_ipa_get_modem_cfg_emb_pipe_flt(void)
- {
- return __qdf_ipa_get_modem_cfg_emb_pipe_flt();
- }
- static inline int qdf_ipa_create_wdi_mapping(u32 num_buffers,
- __qdf_ipa_wdi_buffer_info_t *info)
- {
- return __qdf_ipa_create_wdi_mapping(num_buffers, info);
- }
- static inline int qdf_ipa_release_wdi_mapping(u32 num_buffers,
- qdf_ipa_wdi_buffer_info_t *info)
- {
- return __qdf_ipa_release_wdi_mapping(num_buffers, info);
- }
- static inline int qdf_ipa_disable_apps_wan_cons_deaggr(uint32_t agg_size,
- uint32_t agg_count)
- {
- return __qdf_ipa_disable_apps_wan_cons_deaggr(agg_size, agg_count);
- }
- static inline const qdf_ipa_gsi_ep_config_t *qdf_ipa_get_gsi_ep_info(qdf_ipa_client_type_t client)
- {
- return __qdf_ipa_get_gsi_ep_info(client);
- }
- static inline int qdf_ipa_stop_gsi_channel(u32 clnt_hdl)
- {
- return __qdf_ipa_stop_gsi_channel(clnt_hdl);
- }
- #endif
- static inline void qdf_ipa_free_skb(qdf_ipa_rx_data_t *rx_in)
- {
- return __qdf_ipa_free_skb(rx_in);
- }
- static inline int qdf_ipa_uc_reg_rdyCB(
- qdf_ipa_wdi_uc_ready_params_t *param)
- {
- return __qdf_ipa_uc_reg_rdyCB(param);
- }
- static inline int qdf_ipa_uc_dereg_rdyCB(void)
- {
- return __qdf_ipa_uc_dereg_rdyCB();
- }
- static inline int qdf_ipa_get_wdi_stats(qdf_ipa_hw_stats_wdi_info_data_t *stats)
- {
- return __qdf_ipa_get_wdi_stats(stats);
- }
- static inline int qdf_ipa_register_ipa_ready_cb(
- void (*qdf_ipa_ready_cb)(void *user_data),
- void *user_data)
- {
- return __qdf_ipa_register_ipa_ready_cb(qdf_ipa_ready_cb, user_data);
- }
- static inline int qdf_ipa_setup_sys_pipe(qdf_ipa_sys_connect_params_t *sys_in,
- u32 *clnt_hdl)
- {
- return __qdf_ipa_setup_sys_pipe(sys_in, clnt_hdl);
- }
- static inline int qdf_ipa_teardown_sys_pipe(u32 clnt_hdl)
- {
- return __qdf_ipa_teardown_sys_pipe(clnt_hdl);
- }
- /*
- * Messaging
- */
- static inline int qdf_ipa_send_msg(qdf_ipa_msg_meta_t *meta, void *buff,
- ipa_msg_free_fn callback)
- {
- return __qdf_ipa_send_msg(meta, buff, callback);
- }
- static inline bool qdf_ipa_is_ready(void)
- {
- return __qdf_ipa_is_ready();
- }
- #ifdef FEATURE_METERING
- static inline int qdf_ipa_broadcast_wdi_quota_reach_ind(uint32_t index,
- uint64_t quota_bytes)
- {
- return __qdf_ipa_broadcast_wdi_quota_reach_ind(index, quota_bytes);
- }
- #endif
- #ifdef ENABLE_SMMU_S1_TRANSLATION
- /**
- * qdf_get_ipa_smmu_enabled() - to get IPA SMMU enable status
- *
- * Return: true when IPA SMMU enabled, otherwise false
- */
- static inline bool qdf_get_ipa_smmu_enabled(void)
- {
- return __qdf_get_ipa_smmu_enabled();
- }
- #endif
- #ifdef IPA_LAN_RX_NAPI_SUPPORT
- /**
- * qdf_ipa_get_lan_rx_napi() - Check if NAPI is enabled in LAN
- * RX DP
- *
- * Returns: true if enabled, false otherwise
- */
- static inline bool qdf_ipa_get_lan_rx_napi(void)
- {
- return __qdf_ipa_get_lan_rx_napi();
- }
- #else
- static inline bool qdf_ipa_get_lan_rx_napi(void)
- {
- return false;
- }
- #endif /* IPA_LAN_RX_NAPI_SUPPORT */
- #else
- #ifdef ENABLE_SMMU_S1_TRANSLATION
- static inline bool qdf_get_ipa_smmu_enabled(void)
- {
- return false;
- }
- #endif
- #endif /* IPA_OFFLOAD */
- #endif /* _QDF_IPA_H */
|