1 /* 2 * Copyright (c) 2019-2021 The Linux Foundation. All rights reserved. 3 * Copyright (c) 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 * DOC: Implement API's specific to fw offload component. 21 */ 22 23 #ifndef _WMI_UNIFIED_FWOL_API_H_ 24 #define _WMI_UNIFIED_FWOL_API_H_ 25 #include "wlan_fwol_public_structs.h" 26 27 #ifdef WLAN_FEATURE_ELNA 28 /** 29 * wmi_unified_send_set_elna_bypass_cmd() - Send WMI set eLNA bypass cmd 30 * @wmi_handle: wmi handle 31 * @req: set eLNA bypass request 32 * 33 * Send WMI set eLNA bypass command to firmware. 34 * 35 * Return: QDF_STATUS 36 */ 37 QDF_STATUS 38 wmi_unified_send_set_elna_bypass_cmd(struct wmi_unified *wmi_handle, 39 struct set_elna_bypass_request *req); 40 41 /** 42 * wmi_unified_send_get_elna_bypass_cmd() - Send WMI get eLNA bypass cmd 43 * @wmi_handle: wmi handle 44 * @req: get eLNA bypass request 45 * 46 * Send WMI get eLNA bypass command to firmware. 47 * 48 * Return: QDF_STATUS 49 */ 50 QDF_STATUS 51 wmi_unified_send_get_elna_bypass_cmd(struct wmi_unified *wmi_handle, 52 struct get_elna_bypass_request *req); 53 54 /** 55 * wmi_extract_get_elna_bypass_resp() - Extract WMI get eLNA bypass response 56 * @wmi_handle: wmi handle 57 * @resp_buf: response buffer 58 * @resp: get eLNA bypass response 59 * 60 * Extract WMI get eLNA bypass response from firmware. 61 * 62 * Return: QDF_STATUS 63 */ 64 QDF_STATUS 65 wmi_extract_get_elna_bypass_resp(struct wmi_unified *wmi_handle, void *resp_buf, 66 struct get_elna_bypass_response *resp); 67 #endif /* WLAN_FEATURE_ELNA */ 68 69 #ifdef WLAN_SEND_DSCP_UP_MAP_TO_FW 70 /** 71 * wmi_unified_send_dscp_tip_map_cmd() - Send dscp-to-tid map values cmd 72 * @wmi_handle: wmi handle 73 * @dscp_to_tid_map: array of dscp_tid map values 74 * 75 * Send dscp-to-tid map values to FW. 76 * 77 * Return: QDF_STATUS 78 */ 79 QDF_STATUS 80 wmi_unified_send_dscp_tip_map_cmd(struct wmi_unified *wmi_handle, 81 uint32_t *dscp_to_tid_map); 82 #else 83 static inline QDF_STATUS 84 wmi_unified_send_dscp_tip_map_cmd(struct wmi_unified *wmi_handle, 85 uint32_t *dscp_to_tid_map) 86 { 87 return QDF_STATUS_SUCCESS; 88 } 89 #endif /* WLAN_SEND_DSCP_UP_MAP_TO_FW */ 90 91 #ifdef WLAN_FEATURE_MDNS_OFFLOAD 92 /** 93 * wmi_unified_send_set_mdns_config_cmd() - Send WMI set mDNS config cmd 94 * @wmi_handle: wmi handle 95 * @mdns_info: mdns config info 96 * 97 * Send WMI set mDNS config command to firmware. 98 * 99 * Return: QDF_STATUS 100 */ 101 QDF_STATUS 102 wmi_unified_send_set_mdns_config_cmd(struct wmi_unified *wmi_handle, 103 struct mdns_config_info *mdns_info); 104 #endif /* WLAN_FEATURE_MDNS_OFFLOAD */ 105 106 /** 107 * wmi_unified_send_get_thermal_stats_cmd() - Send WMI get thermal stats req 108 * @wmi_handle: wmi handle 109 * @req_type: Request type 110 * @temp_offset: temperature offset for setting the range for thermal stats 111 * 112 * Send WMI get thermal stats req command to firmware. 113 * 114 * Return: QDF_STATUS 115 */ 116 #ifdef THERMAL_STATS_SUPPORT 117 QDF_STATUS 118 wmi_unified_send_get_thermal_stats_cmd(struct wmi_unified *wmi_handle, 119 enum thermal_stats_request_type req_type, 120 uint8_t temp_offset); 121 #endif /* THERMAL_STATS_SUPPORT */ 122 123 #endif /* _WMI_UNIFIED_FWOL_API_H_ */ 124