blob: 6501ee72689fe44c51eb0e5dd18c53f66f4ca288 [file] [log] [blame]
/*
* Copyright (c) 2013-2020 The Linux Foundation. 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 WMA_INTERNAL_H
#define WMA_INTERNAL_H
#include <cdp_txrx_handle.h>
#if !defined(REMOVE_PKT_LOG)
#include "pktlog_ac.h"
#endif
/* ################### defines ################### */
/*
* TODO: Following constant should be shared by firwmare in
* wmi_unified.h. This will be done once wmi_unified.h is updated.
*/
#define WMI_PEER_STATE_AUTHORIZED 0x2
#define WMA_2_4_GHZ_MAX_FREQ 3000
/*AR9888/AR6320 noise floor approx value
* similar to the mentioned the WMA
*/
#define WMA_TGT_NOISE_FLOOR_DBM (-96)
#define WMA_INVALID_PER_CHAIN_SNR (0x80)
#define WMA_INVALID_PER_CHAIN_RSSI (0xFF)
/*
* Make sure that link monitor and keep alive
* default values should be in sync with CFG.
*/
#define WMA_LINK_MONITOR_DEFAULT_TIME_SECS 10
#define WMA_KEEP_ALIVE_DEFAULT_TIME_SECS 5
/* The maximum number of patterns that can be transmitted by the firmware
* and maximum patterns size.
*/
#ifndef WMA_MAXNUM_PERIODIC_TX_PTRNS
#define WMA_MAXNUM_PERIODIC_TX_PTRNS 6
#endif
#define WMA_WMM_EXPO_TO_VAL(val) ((1 << (val)) - 1)
#define MAX_HT_MCS_IDX 8
#define MAX_VHT_MCS_IDX 10
#ifdef WLAN_FEATURE_11AX
#define MAX_HE_MCS_IDX 12
#endif
#define INVALID_MCS_IDX 255
#define IS_MCS_HAS_DCM_RATE(val) \
((val) == 0 || (val) == 1 || \
(val) == 3 || (val) == 4)
#define LINK_STATUS_LEGACY 0
#define LINK_STATUS_VHT 0x1
#define LINK_STATUS_MIMO 0x2
#define LINK_SUPPORT_VHT 0x4
#define LINK_SUPPORT_MIMO 0x8
#define LINK_RATE_VHT 0x3
#define MAX_ENTRY_HOLD_REQ_QUEUE 2
#define MAX_ENTRY_VDEV_RESP_QUEUE 10
/**
* struct index_data_rate_type - non vht data rate type
* @mcs_index: mcs rate index
* @ht20_rate: HT20 supported rate table
* @ht40_rate: HT40 supported rate table
*/
struct index_data_rate_type {
uint8_t mcs_index;
uint16_t ht20_rate[2];
uint16_t ht40_rate[2];
};
/**
* struct index_vht_data_rate_type - vht data rate type
* @mcs_index: mcs rate index
* @ht20_rate: VHT20 supported rate table
* @ht40_rate: VHT40 supported rate table
* @ht80_rate: VHT80 supported rate table
* @ht160_rate: VHT160 supported rate table
*/
struct index_vht_data_rate_type {
uint8_t mcs_index;
uint16_t ht20_rate[2];
uint16_t ht40_rate[2];
uint16_t ht80_rate[2];
uint16_t ht160_rate[2];
};
#ifdef WLAN_FEATURE_11AX
#define MAX_HE_DCM_INDEX 2
/**
* struct index_he_data_rate_type - he data rate type
* @beacon_rate_index: Beacon rate index
* @supported_he80_rate: he80 rate
* @supported_he40_rate: he40 rate
* @supported_he20_rate: he20 rate
* @supported_he160_rate: he160 rate
*/
struct index_he_data_rate_type {
uint8_t beacon_rate_index;
uint16_t supported_he20_rate[MAX_HE_DCM_INDEX][3];
uint16_t supported_he40_rate[MAX_HE_DCM_INDEX][3];
uint16_t supported_he80_rate[MAX_HE_DCM_INDEX][3];
uint16_t supported_he160_rate[MAX_HE_DCM_INDEX][3];
};
#endif
struct wifi_scan_cmd_req_params;
/*
* wma_main.c functions declarations
*/
/**
* wma_send_msg_by_priority() - Send wma message to PE with priority.
* @wma_handle: wma handle
* @msg_type: message type
* @body_ptr: message body ptr
* @body_val: message body value
* @is_high_priority: if msg is high priority
*
* Return: none
*/
void wma_send_msg_by_priority(tp_wma_handle wma_handle, uint16_t msg_type,
void *body_ptr, uint32_t body_val, bool is_high_priority);
/**
* wma_send_msg() - Send wma message to PE.
* @wma_handle: wma handle
* @msg_type: message type
* @body_ptr: message body ptr
* @body_val: message body value
*
* Return: none
*/
void wma_send_msg(tp_wma_handle wma_handle, uint16_t msg_type,
void *body_ptr, uint32_t body_val);
/**
* wma_send_msg_high_priority() - Send wma message to PE with high priority.
* @wma_handle: wma handle
* @msg_type: message type
* @body_ptr: message body ptr
* @body_val: message body value
*
* Return: none
*/
void wma_send_msg_high_priority(tp_wma_handle wma_handle, uint16_t msg_type,
void *body_ptr, uint32_t body_val);
void wma_data_tx_ack_comp_hdlr(void *wma_context,
qdf_nbuf_t netbuf, int32_t status);
QDF_STATUS wma_set_ppsconfig(uint8_t vdev_id, uint16_t pps_param,
int value);
/*
* wma_scan_roam.c functions declarations
*/
#ifdef WLAN_FEATURE_ROAM_OFFLOAD
void wma_process_roam_invoke(WMA_HANDLE handle,
struct wma_roam_invoke_cmd *roaminvoke);
void wma_process_roam_synch_fail(WMA_HANDLE handle,
struct roam_offload_synch_fail *synch_fail);
int wma_roam_synch_event_handler(void *handle, uint8_t *event,
uint32_t len);
#ifdef WLAN_FEATURE_FIPS
/**
* wma_register_pmkid_req_event_handler() - Register pmkid request event handler
* @wma_handle: wma_handle
*
* This function register pmkid request event handler.
*/
void wma_register_pmkid_req_event_handler(tp_wma_handle wma_handle);
/**
* wma_roam_pmkid_request_event_handler() - Handles roam pmkid request event
* @handle: wma_handle
* @event: pmkid request event data pointer
* @len: length of the data
*
* Handles pmkid request event from firmware which is triggered after roam
* candidate selection.
*/
int wma_roam_pmkid_request_event_handler(void *handle,
uint8_t *event,
uint32_t len);
#else
static inline void
wma_register_pmkid_req_event_handler(tp_wma_handle wma_handle)
{
}
static inline int
wma_roam_pmkid_request_event_handler(void *handle,
uint8_t *event,
uint32_t len)
{
return 0;
}
#endif /* WLAN_FEATURE_FIPS */
/**
* wma_roam_auth_offload_event_handler() - Handle LFR-3.0 Roam authentication
* offload event.
* @handle: wma_handle
* @event: rso auth offload event data pointer
* @len: length of the data
*
* Handles roam authentication offload event from firmware which is triggered
* after roam candidate selection.
*/
int wma_roam_auth_offload_event_handler(WMA_HANDLE handle, uint8_t *event,
uint32_t len);
/**
* wma_roam_stats_event_handler() - Handle the WMI_ROAM_STATS_EVENTID
* from target
* @handle: wma_handle
* @event: roam debug stats event data pointer
* @len: length of the data
*
* This function handles the roam debug stats from the target and logs it
* to kmsg. This WMI_ROAM_STATS_EVENTID event is received whenever roam
* scan trigger happens or when neighbor report is sent by the firmware.
*
* Return: Success or Failure status
*/
int wma_roam_stats_event_handler(WMA_HANDLE handle, uint8_t *event,
uint32_t len);
/**
* wma_mlme_roam_synch_event_handler_cb() - roam synch event handler
* @handle: wma handle
* @event: event data
* @len: length of data
*
* This function is roam synch event handler. It sends roam
* indication for upper layer.
*
* Return: Success or Failure status
*/
int wma_mlme_roam_synch_event_handler_cb(void *handle, uint8_t *event,
uint32_t len);
/**
* wma_roam_synch_frame_event_handler() - roam synch frame event handler
* @handle: wma handle
* @event: event data
* @len: length of data
*
* This function is roam synch frame event handler.
*
* Return: Success or Failure status
*/
int wma_roam_synch_frame_event_handler(void *handle, uint8_t *event,
uint32_t len);
#else
static inline int wma_mlme_roam_synch_event_handler_cb(void *handle,
uint8_t *event,
uint32_t len)
{
return 0;
}
static inline int
wma_roam_stats_event_handler(WMA_HANDLE handle, uint8_t *event,
uint32_t len)
{
return 0;
}
static inline int
wma_roam_pmkid_request_event_handler(void *handle,
uint8_t *event,
uint32_t len)
{
return 0;
}
#endif
#ifdef WLAN_FEATURE_ROAM_OFFLOAD
/**
* wma_roam_scan_chan_list_event_handler() - roam scan chan list event handler
* @handle: wma handle
* @event: pointer to fw event
* @len: length of event
*
* Return: Success or Failure status
*/
int wma_roam_scan_chan_list_event_handler(WMA_HANDLE handle,
uint8_t *event,
uint32_t len);
#else
static inline int
wma_roam_scan_chan_list_event_handler(WMA_HANDLE handle, uint8_t *event,
uint32_t len)
{
return 0;
}
#endif
/**
* wma_update_per_roam_config() -per roam config parameter updation to FW
* @handle: wma handle
* @req_buf: per roam config parameters
*
* Return: none
*/
void wma_update_per_roam_config(WMA_HANDLE handle,
struct wmi_per_roam_config_req *req_buf);
QDF_STATUS wma_update_channel_list(WMA_HANDLE handle,
tSirUpdateChanList *chan_list);
#ifdef WLAN_FEATURE_ROAM_OFFLOAD
QDF_STATUS wma_roam_scan_fill_self_caps(tp_wma_handle wma_handle,
roam_offload_param *
roam_offload_params,
struct roam_offload_scan_req *roam_req);
#endif
QDF_STATUS wma_roam_scan_offload_mode(tp_wma_handle wma_handle,
wmi_start_scan_cmd_fixed_param *
scan_cmd_fp,
struct roam_offload_scan_req *roam_req,
uint32_t mode, uint32_t vdev_id);
/**
* wma_roam_scan_mawc_params() - send roam scan mode request to fw
* @wma_handle: wma handle
* @roam_req: roam request param
*
* Fill the MAWC roaming parameters and send
* WMI_ROAM_CONFIGURE_MAWC_CMDID TLV to firmware.
*
* Return: QDF status
*/
QDF_STATUS wma_roam_scan_mawc_params(tp_wma_handle wma_handle,
struct roam_offload_scan_req *roam_req);
/**
* wma_roam_scan_offload_rssi_threshold() - set scan offload rssi threashold
* @wma_handle: wma handle
* @roam_req: Roaming request buffer
*
* Send WMI_ROAM_SCAN_RSSI_THRESHOLD TLV to firmware
*
* Return: QDF status
*/
QDF_STATUS
wma_roam_scan_offload_rssi_thresh(tp_wma_handle wma_handle,
struct roam_offload_scan_req *roam_req);
QDF_STATUS
wma_roam_scan_offload_scan_period(tp_wma_handle wma_handle,
struct roam_offload_scan_req *roam_req);
QDF_STATUS wma_roam_scan_offload_rssi_change(tp_wma_handle wma_handle,
uint32_t vdev_id,
int32_t rssi_change_thresh,
uint32_t bcn_rssi_weight,
uint32_t hirssi_delay_btw_scans);
QDF_STATUS wma_roam_scan_offload_chan_list(tp_wma_handle wma_handle,
uint8_t chan_count,
uint32_t *chan_freq_list,
uint8_t list_type, uint32_t vdev_id);
A_UINT32 e_csr_auth_type_to_rsn_authmode(enum csr_akm_type authtype,
eCsrEncryptionType encr);
A_UINT32 e_csr_encryption_type_to_rsn_cipherset(eCsrEncryptionType encr);
void wma_roam_scan_fill_scan_params(tp_wma_handle wma_handle,
struct mac_context *mac,
struct roam_offload_scan_req *roam_req,
wmi_start_scan_cmd_fixed_param *
scan_params);
QDF_STATUS wma_roam_scan_bmiss_cnt(tp_wma_handle wma_handle,
A_INT32 first_bcnt,
A_UINT32 final_bcnt, uint32_t vdev_id);
QDF_STATUS wma_roam_scan_offload_command(tp_wma_handle wma_handle,
uint32_t command, uint32_t vdev_id);
#ifdef WLAN_FEATURE_ROAM_OFFLOAD
void wma_set_ric_req(tp_wma_handle wma, void *msg, uint8_t is_add_ts);
#endif
#ifdef FEATURE_WLAN_EXTSCAN
int wma_extscan_start_stop_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
int wma_extscan_operations_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
int wma_extscan_table_usage_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
int wma_extscan_capabilities_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
int wma_extscan_hotlist_match_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
int wma_extscan_cached_results_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
int wma_extscan_change_results_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
int wma_passpoint_match_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
#endif
int wma_handle_btm_blacklist_event(void *handle, uint8_t *cmd_param_info,
uint32_t len);
#ifdef FEATURE_WLAN_EXTSCAN
int wma_extscan_wow_event_callback(void *handle, void *event, uint32_t len);
void wma_register_extscan_event_handler(tp_wma_handle wma_handle);
/**
* wma_start_extscan() - start extscan command to fw.
* @wma: wma handle
* @params: extscan command request params
*
* This function sends start extscan request to fw.
*
* Return: QDF Status.
*/
QDF_STATUS wma_start_extscan(tp_wma_handle wma,
struct wifi_scan_cmd_req_params *pstart);
/**
* wma_stop_extscan() - stop extscan command to fw.
* @wma: wma handle
* @params: stop scan command request params
*
* This function sends stop extscan request to fw.
*
* Return: QDF Status.
*/
QDF_STATUS wma_stop_extscan(tp_wma_handle wma,
struct extscan_stop_req_params *params);
/**
* wma_extscan_start_hotlist_monitor() - start hotlist monitor
* @wma: wma handle
* @params: hotlist request params
*
* This function configures hotlist monitor in fw.
*
* Return: QDF status
*/
QDF_STATUS wma_extscan_start_hotlist_monitor(tp_wma_handle wma,
struct extscan_bssid_hotlist_set_params *params);
/**
* wma_extscan_stop_hotlist_monitor() - stop hotlist monitor
* @wma: wma handle
* @params: hotlist request params
*
* This function configures hotlist monitor to stop in fw.
*
* Return: QDF status
*/
QDF_STATUS wma_extscan_stop_hotlist_monitor(tp_wma_handle wma,
struct extscan_bssid_hotlist_reset_params *params);
/**
* wma_extscan_start_change_monitor() - send start change monitor cmd
* @wma: wma handle
* @params: change monitor request params
*
* This function sends start change monitor request to fw.
*
* Return: QDF status
*/
QDF_STATUS
wma_extscan_start_change_monitor(tp_wma_handle wma,
struct extscan_set_sig_changereq_params *params);
/**
* wma_extscan_stop_change_monitor() - send stop change monitor cmd
* @wma: wma handle
* @params: change monitor request params
*
* This function sends stop change monitor request to fw.
*
* Return: QDF status
*/
QDF_STATUS
wma_extscan_stop_change_monitor(tp_wma_handle wma,
struct extscan_capabilities_reset_params *params);
/**
* wma_extscan_get_cached_results() - extscan get cached results
* @wma: wma handle
* @params: cached results parameters
*
* This function send request to fw to get cached results.
*
* Return: QDF status
*/
QDF_STATUS
wma_extscan_get_cached_results(tp_wma_handle wma,
struct extscan_cached_result_params *params);
/**
* wma_extscan_get_capabilities() - extscan get capabilities
* @wma: wma handle
* @params: get capabilities params
*
* This function sends request to fw to get extscan capabilities.
*
* Return: QDF status
*/
QDF_STATUS
wma_extscan_get_capabilities(tp_wma_handle wma,
struct extscan_capabilities_params *params);
/**
* wma_set_epno_network_list() - set epno network list
* @wma: WMA handle
* @req: epno config params request structure
*
* This function reads the incoming epno config request structure
* and constructs the WMI message to the firmware.
*
* Return: 0 on success, error number otherwise
*/
QDF_STATUS wma_set_epno_network_list(tp_wma_handle wma,
struct wifi_enhanced_pno_params *req);
/**
* wma_set_passpoint_network_list() - set passpoint network list
* @wma: WMA handle
* @params: passpoint network request structure
*
* This function sends the passpoint configs down to the firmware
*
* Return: QDF_STATUS enumeration
*/
QDF_STATUS
wma_set_passpoint_network_list(tp_wma_handle wma,
struct wifi_passpoint_req_param *params);
/**
* wma_reset_passpoint_network_list() - reset passpoint network list
* @wma: WMA handle
* @params: passpoint network request structure
*
* This function sends down WMI command with network id set to wildcard id.
* firmware shall clear all the config entries
*
* Return: QDF_STATUS enumeration
*/
QDF_STATUS
wma_reset_passpoint_network_list(tp_wma_handle wma,
struct wifi_passpoint_req_param *params);
#endif
/**
* wma_scan_probe_setoui() - set scan probe OUI
* @wma: wma handle
* @set_oui: OUI parameters
*
* set scan probe OUI parameters in firmware
*
* Return: QDF status
*/
QDF_STATUS wma_scan_probe_setoui(tp_wma_handle wma,
struct scan_mac_oui *set_oui);
void wma_roam_better_ap_handler(tp_wma_handle wma, uint32_t vdev_id);
int wma_roam_event_callback(WMA_HANDLE handle, uint8_t *event_buf,
uint32_t len);
#ifdef WLAN_FEATURE_ROAM_OFFLOAD
void wma_process_roam_synch_complete(WMA_HANDLE handle, uint8_t vdev_id);
static inline bool wma_is_roam_synch_in_progress(tp_wma_handle wma,
uint8_t vdev_id)
{
return wma->interfaces[vdev_id].roam_synch_in_progress;
}
#else
static inline bool wma_is_roam_synch_in_progress(tp_wma_handle wma,
uint8_t vdev_id)
{
return false;
}
#endif
/*
* wma_dev_if.c functions declarations
*/
/**
* wma_find_vdev_id_by_addr() - find vdev_id from mac address
* @wma: wma handle
* @addr: mac address
* @vdev_id: return vdev_id
*
* Return: SUCCESS or FAILURE
*/
QDF_STATUS wma_find_vdev_id_by_addr(tp_wma_handle wma, uint8_t *addr,
uint8_t *vdev_id);
bool wma_is_vdev_in_ap_mode(tp_wma_handle wma, uint8_t vdev_id);
#ifdef QCA_IBSS_SUPPORT
/**
* wma_is_vdev_in_ibss_mode() - check that vdev is in ibss mode or not
* @wma: wma handle
* @vdev_id: vdev id
*
* Helper function to know whether given vdev id
* is in IBSS mode or not.
*
* Return: True/False
*/
bool wma_is_vdev_in_ibss_mode(tp_wma_handle wma, uint8_t vdev_id);
/**
* wma_adjust_ibss_heart_beat_timer() - set ibss heart beat timer in fw.
* @wma: wma handle
* @vdev_id: vdev id
* @peer_num_delta: peer number delta value
*
* Return: none
*/
void wma_adjust_ibss_heart_beat_timer(tp_wma_handle wma,
uint8_t vdev_id,
int8_t peer_num_delta);
/**
* wma_set_ibss_pwrsave_params() - set ibss power save parameter to fw
* @wma: wma handle
* @vdev_id: vdev id
*
* Return: 0 for success or error code.
*/
QDF_STATUS
wma_set_ibss_pwrsave_params(tp_wma_handle wma, uint8_t vdev_id);
/**
* wma_ibss_peer_info_event_handler() - IBSS peer info event handler
* @handle: wma handle
* @data: event data
* @len: length of data
*
* This function handles IBSS peer info event from FW.
*
* Return: 0 for success or error code
*/
int wma_ibss_peer_info_event_handler(void *handle, uint8_t *data,
uint32_t len);
#else
/**
* wma_is_vdev_in_ibss_mode(): dummy function
* @wma: wma handle
* @vdev_id: vdev id
*
* Return false since no vdev can be in ibss mode without ibss support
*/
static inline
bool wma_is_vdev_in_ibss_mode(tp_wma_handle wma, uint8_t vdev_id)
{
return false;
}
/**
* wma_adjust_ibss_heart_beat_timer() - set ibss heart beat timer in fw.
* @wma: wma handle
* @vdev_id: vdev id
* @peer_num_delta: peer number delta value
*
* This function is dummy
*
* Return: none
*/
static inline void
wma_adjust_ibss_heart_beat_timer(tp_wma_handle wma,
uint8_t vdev_id,
int8_t peer_num_delta)
{
}
/**
* wma_ibss_peer_info_event_handler() - IBSS peer info event handler
* @handle: wma handle
* @data: event data
* @len: length of data
*
* This function is dummy
*
* Return: 0 for success or error code
*/
static inline int
wma_ibss_peer_info_event_handler(void *handle, uint8_t *data,
uint32_t len)
{
return 0;
}
/**
* wma_set_ibss_pwrsave_params() - set ibss power save parameter to fw
* @wma: wma handle
* @vdev_id: vdev id
*
* This function is dummy
*
* Return: 0 for success or error code.
*/
static inline QDF_STATUS
wma_set_ibss_pwrsave_params(tp_wma_handle wma, uint8_t vdev_id)
{
return QDF_STATUS_SUCCESS;
}
#endif /* QCA_IBSS_SUPPORT */
/**
* wma_get_vdev_bssid() - Get BSSID from mlme_obj
* @vdev - pointer to vdev
*
* This API is used to get BSSID stored in vdev mlme object.
*
* Return: pointer to bssid on success else NULL.
*/
uint8_t *wma_get_vdev_bssid(struct wlan_objmgr_vdev *vdev);
/**
* wma_find_bssid_by_vdev_id() - Get the BSS ID corresponding to the vdev ID
* @wma - wma handle
* @vdev_id - vdev ID
*
* Return: Returns pointer to bssid on success,
* otherwise returns NULL.
*/
static inline uint8_t *wma_find_bssid_by_vdev_id(tp_wma_handle wma,
uint8_t vdev_id)
{
if (vdev_id >= wma->max_bssid)
return NULL;
return wma_get_vdev_bssid(wma->interfaces[vdev_id].vdev);
}
/**
* wma_find_vdev_id_by_bssid() - Get the corresponding vdev_id from BSSID
* @wma - wma handle
* @bssid - bssid address
* @vdev_id - vdev ID
*
* Return: SUCCESS or FAILURE.
*/
QDF_STATUS wma_find_vdev_id_by_bssid(tp_wma_handle wma, uint8_t *bssid,
uint8_t *vdev_id);
/**
* wma_vdev_detach() - send vdev delete command to fw
* @wma_handle: wma handle
* @pdel_vdev_req_param: del vdev params
*
* Return: QDF status
*/
QDF_STATUS wma_vdev_detach(tp_wma_handle wma_handle,
struct del_vdev_params *pdel_vdev_req_param);
QDF_STATUS wma_vdev_set_param(wmi_unified_t wmi_handle, uint32_t if_id,
uint32_t param_id, uint32_t param_value);
QDF_STATUS wma_remove_peer(tp_wma_handle wma, uint8_t *mac_addr,
uint8_t vdev_id, bool roam_synch_in_progress);
QDF_STATUS wma_peer_unmap_conf_send(tp_wma_handle wma,
struct send_peer_unmap_conf_params *msg);
QDF_STATUS wma_create_peer(tp_wma_handle wma,
uint8_t peer_addr[QDF_MAC_ADDR_SIZE],
uint32_t peer_type, uint8_t vdev_id,
bool roam_synch_in_progress);
/**
* wma_send_del_bss_response() - send delete bss resp
* @wma: wma handle
* @resp: pointer to del bss response
*
* Return: none
*/
void wma_send_del_bss_response(tp_wma_handle wma, struct del_bss_resp *resp);
/**
* __wma_handle_vdev_stop_rsp() - vdev stop response handler
* @resp_event: pointer to response received
*
* Return: QDF_STATUS_SUCCESS for success or QDF_ERROR code
*/
QDF_STATUS
__wma_handle_vdev_stop_rsp(struct vdev_stop_response *resp_event);
void wma_hold_req_timer(void *data);
struct wma_target_req *wma_fill_hold_req(tp_wma_handle wma,
uint8_t vdev_id, uint32_t msg_type,
uint8_t type, void *params,
uint32_t timeout);
/**
* wma_add_bss() - Add BSS request to fw as per opmode
* @wma: wma handle
* @params: add bss params
*
* Return: none
*/
void wma_add_bss(tp_wma_handle wma, struct bss_params *params);
/**
* wma_add_sta() - process add sta request as per opmode
* @wma: wma handle
* @add_Sta: add sta params
*
* Return: none
*/
void wma_add_sta(tp_wma_handle wma, tpAddStaParams add_sta);
/**
* wma_delete_sta() - process del sta request as per opmode
* @wma: wma handle
* @del_sta: delete sta params
*
* Return: none
*/
void wma_delete_sta(tp_wma_handle wma, tpDeleteStaParams del_sta);
/**
* wma_delete_bss() - process delete bss request from upper layer
* @wma: wma handle
* @vdev_id: vdev id
*
* Return: none
*/
void wma_delete_bss(tp_wma_handle wma, uint8_t vdev_id);
int32_t wma_find_vdev_by_type(tp_wma_handle wma, int32_t type);
/**
* wma_set_vdev_intrabss_fwd() - set intra_fwd value to wni_in.
* @wma_handle: wma handle
* @pdis_intra_fwd: Pointer to DisableIntraBssFwd struct
*
* Return: none
*/
void wma_set_vdev_intrabss_fwd(tp_wma_handle wma_handle,
tpDisableIntraBssFwd pdis_intra_fwd);
/**
* wma_delete_bss_ho_fail() - process delete bss request for handoff failure
* @wma: wma handle
* @vdev_id: vdev id
*
* Delete BSS in case of ROAM_HO_FAIL processing is handled separately in
* this routine. It needs to be done without sending any commands to firmware
* because firmware has already stopped and deleted peer and vdev is down.
* Relevant logic is aggregated from other routines. It changes the host
* data structures without sending VDEV_STOP, PEER_FLUSH_TIDS, PEER_DELETE
* and VDEV_DOWN commands to firmware.
*
* Return: none
*/
void wma_delete_bss_ho_fail(tp_wma_handle wma, uint8_t vdev_id);
uint32_t wma_get_bcn_rate_code(uint16_t rate);
/*
* wma_mgmt.c functions declarations
*/
#ifdef WLAN_WMI_BCN
int wma_beacon_swba_handler(void *handle, uint8_t *event, uint32_t len);
#endif
/**
* wma_peer_sta_kickout_event_handler() - kickout event handler
* @handle: wma handle
* @event: event data
* @len: data length
*
* Kickout event is received from firmware on observing beacon miss
* It handles kickout event for different modes and indicate to
* upper layers.
*
* Return: 0 for success or error code
*/
int wma_peer_sta_kickout_event_handler(void *handle, uint8_t *event,
uint32_t len);
/**
* wma_unified_bcntx_status_event_handler() - beacon tx status event handler
* @handle: wma handle
* @cmd_param_info: event data
* @len: data length
*
* WMI Handler for WMI_OFFLOAD_BCN_TX_STATUS_EVENTID event from firmware.
* This event is generated by FW when the beacon transmission is offloaded
* and the host performs beacon template modification using WMI_BCN_TMPL_CMDID
* The FW generates this event when the first successful beacon transmission
* after template update
*
* Return: 0 for success or error code
*/
int wma_unified_bcntx_status_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
void wma_set_sta_sa_query_param(tp_wma_handle wma,
uint8_t vdev_id);
void wma_set_sta_keep_alive(tp_wma_handle wma, uint8_t vdev_id,
uint32_t method, uint32_t timeperiod,
uint8_t *hostv4addr, uint8_t *destv4addr,
uint8_t *destmac);
int wma_vdev_install_key_complete_event_handler(void *handle,
uint8_t *event,
uint32_t len);
/**
* wma_objmgr_set_peer_mlme_phymode() - set phymode to peer object
* @wma: wma handle
* @mac_addr: mac addr of peer
* @phymode: phymode value to set
*
* Return: None
*/
void wma_objmgr_set_peer_mlme_phymode(tp_wma_handle wma, uint8_t *mac_addr,
enum wlan_phymode phymode);
QDF_STATUS wma_send_peer_assoc(tp_wma_handle wma,
tSirNwType nw_type,
tpAddStaParams params);
QDF_STATUS wmi_unified_vdev_set_gtx_cfg_send(wmi_unified_t wmi_handle,
uint32_t if_id,
gtx_config_t *gtx_info);
void wma_update_protection_mode(tp_wma_handle wma, uint8_t vdev_id,
uint8_t llbcoexist);
void wma_process_update_beacon_params(tp_wma_handle wma,
tUpdateBeaconParams *bcn_params);
/**
* wma_update_rts_params() - update cfg parameters to target
* @wma: wma handle
* @value: rts_threshold
*
* Return: none
*/
void wma_update_rts_params(tp_wma_handle wma, uint32_t value);
/**
* wma_update_frag_params() - update cfg parameters to target
* @wma: wma handle
* @value: frag_threshold
*
* Return: none
*/
void wma_update_frag_params(tp_wma_handle wma, uint32_t value);
QDF_STATUS wma_process_update_edca_param_req(WMA_HANDLE handle,
tEdcaParams *edca_params);
/**
* wma_tbttoffset_update_event_handler() - tbtt offset update handler
* @handle: wma handle
* @event: event buffer
* @len: data length
*
* Return: 0 for success or error code
*/
int wma_tbttoffset_update_event_handler(void *handle, uint8_t *event,
uint32_t len);
void wma_send_probe_rsp_tmpl(tp_wma_handle wma,
tpSendProbeRespParams probe_rsp_info);
/**
* wma_set_ap_vdev_up() - send vdev up req
* @wma: wma handle
* @vdev_id: vdev id
*
* Return: QDF_STATUS
*/
QDF_STATUS wma_set_ap_vdev_up(tp_wma_handle wma, uint8_t vdev_id);
void wma_send_beacon(tp_wma_handle wma, tpSendbeaconParams bcn_info);
void wma_set_keepalive_req(tp_wma_handle wma,
struct keep_alive_req *keepalive);
void wma_beacon_miss_handler(tp_wma_handle wma, uint32_t vdev_id,
int32_t rssi);
void wma_process_update_opmode(tp_wma_handle wma_handle,
tUpdateVHTOpMode *update_vht_opmode);
void wma_process_update_rx_nss(tp_wma_handle wma_handle,
tUpdateRxNss *update_rx_nss);
void wma_process_update_membership(tp_wma_handle wma_handle,
tUpdateMembership *membership);
void wma_process_update_userpos(tp_wma_handle wma_handle,
tUpdateUserPos *userpos);
/*
* wma_power.c functions declarations
*/
/**
* wma_enable_sta_ps_mode() - enable sta powersave params in fw
* @ps_req: power save request
*
* Return: none
*/
void wma_enable_sta_ps_mode(tpEnablePsParams ps_req);
QDF_STATUS wma_unified_set_sta_ps_param(wmi_unified_t wmi_handle,
uint32_t vdev_id, uint32_t param,
uint32_t value);
QDF_STATUS wma_set_ap_peer_uapsd(tp_wma_handle wma, uint32_t vdev_id,
uint8_t *peer_addr, uint8_t uapsd_value,
uint8_t max_sp);
void wma_update_edca_params_for_ac(tSirMacEdcaParamRecord *edca_param,
struct wmi_host_wme_vparams *wmm_param,
int ac, bool mu_edca_param);
void wma_set_tx_power(WMA_HANDLE handle,
tMaxTxPowerParams *tx_pwr_params);
void wma_set_max_tx_power(WMA_HANDLE handle,
tMaxTxPowerParams *tx_pwr_params);
void wma_disable_sta_ps_mode(tpDisablePsParams ps_req);
/**
* wma_send_max_tx_pwrlmt() - send max tx power limit to fw
* @handle: wma handle
* @vdev_id: vdev id
*
* Return: none
*/
void wma_send_max_tx_pwrlmt(WMA_HANDLE handle, uint8_t vdev_id);
/**
* wma_enable_uapsd_mode() - enable uapsd mode in fw
* @wma: wma handle
* @ps_req: power save request
*
* Return: none
*/
void wma_enable_uapsd_mode(tp_wma_handle wma, tpEnableUapsdParams ps_req);
void wma_disable_uapsd_mode(tp_wma_handle wma, tpDisableUapsdParams ps_req);
QDF_STATUS wma_get_temperature(tp_wma_handle wma_handle);
int wma_pdev_temperature_evt_handler(void *handle, uint8_t *event,
uint32_t len);
QDF_STATUS wma_process_tx_power_limits(WMA_HANDLE handle,
struct tx_power_limit *ptxlim);
void wma_update_noa(struct beacon_info *beacon,
struct p2p_sub_element_noa *noa_ie);
void wma_update_probe_resp_noa(tp_wma_handle wma_handle,
struct p2p_sub_element_noa *noa_ie);
void wma_process_set_mimops_req(tp_wma_handle wma_handle,
tSetMIMOPS *mimops);
QDF_STATUS wma_set_mimops(tp_wma_handle wma, uint8_t vdev_id, int value);
QDF_STATUS wma_notify_modem_power_state(void *wma_ptr,
tSirModemPowerStateInd *pReq);
QDF_STATUS wma_set_smps_params(tp_wma_handle wma, uint8_t vdev_id,
int value);
/*
* wma_data.c functions declarations
*/
/**
* wma_set_bss_rate_flags() - set rate flags based on BSS capability
* @wma: pointer to wma handle
* @vdev_id: vdev id
* @add_bss: pointer to bss params
*
* Return: none
*/
void wma_set_bss_rate_flags(tp_wma_handle wma, uint8_t vdev_id,
struct bss_params *add_bss);
int32_t wmi_unified_send_txbf(tp_wma_handle wma, tpAddStaParams params);
/**
* wma_check_txrx_chainmask() - check txrx chainmask
* @num_rf_chains: number of rf chains
* @cmd_value: command value
*
* Return: QDF_STATUS_SUCCESS for success or error code
*/
QDF_STATUS wma_check_txrx_chainmask(int num_rf_chains, int cmd_value);
int wma_peer_state_change_event_handler(void *handle,
uint8_t *event_buff,
uint32_t len);
QDF_STATUS wma_set_enable_disable_mcc_adaptive_scheduler(uint32_t
mcc_adaptive_scheduler);
QDF_STATUS wma_set_mcc_channel_time_latency
(tp_wma_handle wma,
uint32_t mcc_channel, uint32_t mcc_channel_time_latency);
QDF_STATUS wma_set_mcc_channel_time_quota
(tp_wma_handle wma,
uint32_t adapter_1_chan_number,
uint32_t adapter_1_quota, uint32_t adapter_2_chan_number);
/**
* wma_process_rate_update_indate() - rate update indication
* @wma: wma handle
* @pRateUpdateParams: Rate update params
*
* This function update rate & short GI interval to fw based on params
* send by SME.
*
* Return: QDF status
*/
QDF_STATUS wma_process_rate_update_indicate(tp_wma_handle wma,
tSirRateUpdateInd *
pRateUpdateParams);
QDF_STATUS wma_tx_attach(tp_wma_handle wma_handle);
QDF_STATUS wma_tx_detach(tp_wma_handle wma_handle);
#if defined(QCA_LL_LEGACY_TX_FLOW_CONTROL) || \
defined(QCA_LL_TX_FLOW_CONTROL_V2) || defined(CONFIG_HL_SUPPORT)
/**
* wma_mcc_vdev_tx_pause_evt_handler() - pause event handler
* @handle: wma handle
* @event: event buffer
* @len: data length
*
* This function handle pause event from fw and pause/unpause
* vdev.
*
* Return: 0 for success or error code.
*/
int wma_mcc_vdev_tx_pause_evt_handler(void *handle, uint8_t *event,
uint32_t len);
#endif
#if defined(CONFIG_HL_SUPPORT) && defined(QCA_BAD_PEER_TX_FLOW_CL)
QDF_STATUS wma_process_init_bad_peer_tx_ctl_info(tp_wma_handle wma,
struct t_bad_peer_txtcl_config *config);
#else
static inline QDF_STATUS
wma_process_init_bad_peer_tx_ctl_info(tp_wma_handle wma,
struct t_bad_peer_txtcl_config *config)
{
return QDF_STATUS_E_FAILURE;
}
#endif
QDF_STATUS wma_process_init_thermal_info(tp_wma_handle wma,
t_thermal_mgmt *pThermalParams);
QDF_STATUS wma_process_set_thermal_level(tp_wma_handle wma,
uint8_t thermal_level);
QDF_STATUS wma_set_thermal_mgmt(tp_wma_handle wma_handle,
t_thermal_cmd_params thermal_info);
int wma_thermal_mgmt_evt_handler(void *handle, uint8_t *event,
uint32_t len);
int wma_fast_tx_fail_event_handler(void *handle, uint8_t *data,
uint32_t len);
/*
* wma_utils.c functions declarations
*/
#ifdef WLAN_FEATURE_STATS_EXT
/**
* wma_stats_ext_event_handler() - extended stats event handler
* @handle: wma handle
* @event_buf: event buffer received from fw
* @len: length of data
*
* Return: 0 for success or error code
*/
int wma_stats_ext_event_handler(void *handle, uint8_t *event_buf,
uint32_t len);
#endif
enum eSmpsModeValue host_map_smps_mode(A_UINT32 fw_smps_mode);
int wma_smps_mode_to_force_mode_param(uint8_t smps_mode);
#ifdef WLAN_FEATURE_LINK_LAYER_STATS
void wma_register_ll_stats_event_handler(tp_wma_handle wma_handle);
/**
* wma_process_ll_stats_clear_req() - clear link layer stats
* @wma: wma handle
* @clearReq: ll stats clear request command params
*
* Return: QDF_STATUS_SUCCESS for success or error code
*/
QDF_STATUS wma_process_ll_stats_clear_req
(tp_wma_handle wma, const tpSirLLStatsClearReq clearReq);
QDF_STATUS wma_process_ll_stats_set_req
(tp_wma_handle wma, const tpSirLLStatsSetReq setReq);
/**
* wma_process_ll_stats_get_req() - link layer stats get request
* @wma:wma handle
* @getReq:ll stats get request command params
*
* Return: QDF_STATUS_SUCCESS for success or error code
*/
QDF_STATUS wma_process_ll_stats_get_req
(tp_wma_handle wma, const tpSirLLStatsGetReq getReq);
int wma_unified_link_iface_stats_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
void wma_config_stats_ext_threshold(tp_wma_handle wma,
struct sir_ll_ext_stats_threshold *thresh);
#endif
void wma_post_link_status(tAniGetLinkStatus *pGetLinkStatus,
uint8_t link_status);
/**
* wma_link_status_event_handler() - link status event handler
* @handle: wma handle
* @cmd_param_info: data from event
* @len: length
*
* Return: 0 for success or error code
*/
int wma_link_status_event_handler(void *handle, uint8_t *cmd_param_info,
uint32_t len);
/**
* wma_rso_cmd_status_event_handler() - RSO Command status event handler
* @wmi_event: WMI event
*
* This function is used to send RSO command status to upper layer
*
* Return: 0 for success
*/
int wma_rso_cmd_status_event_handler(wmi_roam_event_fixed_param *wmi_event);
int wma_stats_event_handler(void *handle, uint8_t *cmd_param_info,
uint32_t len);
QDF_STATUS wma_send_link_speed(uint32_t link_speed);
int wma_link_speed_event_handler(void *handle, uint8_t *cmd_param_info,
uint32_t len);
QDF_STATUS wma_wni_cfg_dnld(tp_wma_handle wma_handle);
int wma_unified_debug_print_event_handler(void *handle, uint8_t *datap,
uint32_t len);
/**
* wma_peer_phymode() - get phymode
* @nw_type: nw type
* @sta_type: sta type
* @is_ht: is ht supported
* @ch_width: supported channel width
* @is_vht: is vht supported
* @is_he: is HE supported
*
* Return: host phymode
*/
enum wlan_phymode
wma_peer_phymode(tSirNwType nw_type, uint8_t sta_type,
uint8_t is_ht, uint8_t ch_width,
uint8_t is_vht, bool is_he);
int32_t wma_txrx_fw_stats_reset(tp_wma_handle wma_handle,
uint8_t vdev_id, uint32_t value);
int32_t wma_set_txrx_fw_stats_level(tp_wma_handle wma_handle,
uint8_t vdev_id, uint32_t value);
/*
* wma_features.c functions declarations
*/
/**
* wma_sar_register_event_handlers() - Register SAR event handlers
* @handle: WMA Handle
*
* Function to be called during WMA initialization to register SAR
* event handlers with WMI
*
* Return: QDF_STATUS_SUCCESS if registration is successful, otherwise
* an error enumeration
*/
QDF_STATUS wma_sar_register_event_handlers(WMA_HANDLE handle);
void wma_process_link_status_req(tp_wma_handle wma,
tAniGetLinkStatus *pGetLinkStatus);
/**
* wma_get_peer_info_ext() - get peer info
* @handle: wma interface
* @peer_info_req: get peer info request information
*
* This function will send WMI_REQUEST_PEER_STATS_INFO_CMDID to FW
*
* Return: 0 on success, otherwise error value
*/
QDF_STATUS wma_get_peer_info_ext(WMA_HANDLE handle,
struct sir_peer_info_ext_req *peer_info_req);
/**
* wma_get_isolation() - get antenna isolation
* @handle: wma interface
*
* This function will send WMI_COEX_GET_ANTENNA_ISOLATION_CMDID to FW
*
* Return: 0 on success, otherwise error value
*/
QDF_STATUS wma_get_isolation(tp_wma_handle wma);
/**
* wma_peer_info_event_handler() - Handler for WMI_PEER_STATS_INFO_EVENTID
* @handle: WMA global handle
* @cmd_param_info: Command event data
* @len: Length of cmd_param_info
*
* This function will handle WMI_PEER_STATS_INFO_EVENTID
*
* Return: 0 on success, error code otherwise
*/
int wma_peer_info_event_handler(void *handle, u_int8_t *cmd_param_info,
u_int32_t len);
int wma_profile_data_report_event_handler(void *handle, uint8_t *event_buf,
uint32_t len);
QDF_STATUS wma_unified_fw_profiling_cmd(wmi_unified_t wmi_handle,
uint32_t cmd, uint32_t value1, uint32_t value2);
int wma_unified_csa_offload_enable(tp_wma_handle wma, uint8_t vdev_id);
#ifdef FEATURE_WLAN_TDLS
int wma_tdls_event_handler(void *handle, uint8_t *event, uint32_t len);
#endif
int wma_csa_offload_handler(void *handle, uint8_t *event, uint32_t len);
#ifdef FEATURE_OEM_DATA_SUPPORT
int wma_oem_data_response_handler(void *handle, uint8_t *datap,
uint32_t len);
#endif
#if !defined(REMOVE_PKT_LOG)
QDF_STATUS wma_pktlog_wmi_send_cmd(WMA_HANDLE handle,
struct ath_pktlog_wmi_params *params);
#endif
int wma_wow_wakeup_host_event(void *handle, uint8_t *event,
uint32_t len);
int wma_d0_wow_disable_ack_event(void *handle, uint8_t *event, uint32_t len);
int wma_pdev_resume_event_handler(void *handle, uint8_t *event, uint32_t len);
void wma_del_ts_req(tp_wma_handle wma, struct del_ts_params *msg);
/**
* wma_aggr_qos_req() - send aggr qos request to fw
* @wma: handle to wma
* @pAggrQosRspMsg - combined struct for all ADD_TS requests.
*
* A function to handle WMA_AGGR_QOS_REQ. This will send out
* ADD_TS requestes to firmware in loop for all the ACs with
* active flow.
*
* Return: none
*/
void wma_aggr_qos_req(tp_wma_handle wma,
struct aggr_add_ts_param *pAggrQosRspMsg);
void wma_add_ts_req(tp_wma_handle wma, struct add_ts_param *msg);
#ifdef FEATURE_WLAN_ESE
QDF_STATUS wma_process_tsm_stats_req(tp_wma_handle wma_handler,
void *pTsmStatsMsg);
void wma_config_plm(tp_wma_handle wma, struct plm_req_params *plm);
#endif
QDF_STATUS wma_process_mcbc_set_filter_req(tp_wma_handle wma_handle,
tSirRcvFltMcAddrList * mcbc_param);
QDF_STATUS wma_process_cesium_enable_ind(tp_wma_handle wma);
QDF_STATUS wma_process_get_peer_info_req
(tp_wma_handle wma, tSirIbssGetPeerInfoReqParams *pReq);
QDF_STATUS wma_process_tx_fail_monitor_ind
(tp_wma_handle wma, tAniTXFailMonitorInd *pReq);
#ifdef FEATURE_WLAN_RMC
QDF_STATUS wma_process_rmc_enable_ind(tp_wma_handle wma);
QDF_STATUS wma_process_rmc_disable_ind(tp_wma_handle wma);
QDF_STATUS wma_process_rmc_action_period_ind(tp_wma_handle wma);
#else
static inline
QDF_STATUS wma_process_rmc_enable_ind(tp_wma_handle wma)
{
return QDF_STATUS_SUCCESS;
}
static inline
QDF_STATUS wma_process_rmc_disable_ind(tp_wma_handle wma)
{
return QDF_STATUS_SUCCESS;
}
static inline
QDF_STATUS wma_process_rmc_action_period_ind(tp_wma_handle wma)
{
return QDF_STATUS_SUCCESS;
}
#endif
QDF_STATUS wma_process_add_periodic_tx_ptrn_ind(WMA_HANDLE handle,
tSirAddPeriodicTxPtrn *pattern);
QDF_STATUS wma_process_del_periodic_tx_ptrn_ind(WMA_HANDLE handle,
tSirDelPeriodicTxPtrn *
pDelPeriodicTxPtrnParams);
#ifdef WLAN_FEATURE_STATS_EXT
/**
* wma_stats_ext_req() - request ext stats from fw
* @wma_ptr: wma handle
* @preq: stats ext params
*
* Return: QDF status
*/
QDF_STATUS wma_stats_ext_req(void *wma_ptr, tpStatsExtRequest preq);
#endif
#ifdef WLAN_FEATURE_EXTWOW_SUPPORT
QDF_STATUS wma_enable_ext_wow(tp_wma_handle wma, tpSirExtWoWParams params);
int wma_set_app_type1_params_in_fw(tp_wma_handle wma,
tpSirAppType1Params appType1Params);
QDF_STATUS wma_set_app_type2_params_in_fw(tp_wma_handle wma,
tpSirAppType2Params appType2Params);
#endif
#ifdef FEATURE_WLAN_AUTO_SHUTDOWN
int wma_auto_shutdown_event_handler(void *handle, uint8_t *event,
uint32_t len);
/**
* wma_set_auto_shutdown_timer_req() - sets auto shutdown timer in firmware
* @wma_handle: wma handle
* @auto_sh_cmd: auto shutdown timer params
*
* Return: QDF status
*/
QDF_STATUS
wma_set_auto_shutdown_timer_req(tp_wma_handle wma_handle,
struct auto_shutdown_cmd *auto_sh_cmd);
#endif
#ifdef WLAN_FEATURE_TSF
int wma_vdev_tsf_handler(void *handle, uint8_t *data, uint32_t data_len);
QDF_STATUS wma_capture_tsf(tp_wma_handle wma_handle, uint32_t vdev_id);
QDF_STATUS wma_reset_tsf_gpio(tp_wma_handle wma_handle, uint32_t vdev_id);
QDF_STATUS wma_set_tsf_gpio_pin(WMA_HANDLE handle, uint32_t pin);
#else
static inline QDF_STATUS wma_capture_tsf(tp_wma_handle wma_handle,
uint32_t vdev_id)
{
return QDF_STATUS_SUCCESS;
}
static inline QDF_STATUS wma_reset_tsf_gpio(tp_wma_handle wma_handle,
uint32_t vdev_id)
{
return QDF_STATUS_SUCCESS;
}
static inline int wma_vdev_tsf_handler(void *handle, uint8_t *data,
uint32_t data_len)
{
return 0;
}
static inline QDF_STATUS wma_set_tsf_gpio_pin(WMA_HANDLE handle, uint32_t pin)
{
return QDF_STATUS_E_INVAL;
}
#endif
QDF_STATUS wma_set_wisa_params(tp_wma_handle wma, struct sir_wisa_params *wisa);
#ifdef DHCP_SERVER_OFFLOAD
/**
* wma_process_dhcpserver_offload() - enable DHCP server offload
* @wma_handle: wma handle
* @params: DHCP server offload information
*
* Return: QDF_STATUS_SUCCESS for success or error code
*/
QDF_STATUS
wma_process_dhcpserver_offload(tp_wma_handle wma_handle,
struct dhcp_offload_info_params *params);
#endif
#ifdef WLAN_FEATURE_GPIO_LED_FLASHING
QDF_STATUS wma_set_led_flashing(tp_wma_handle wma_handle,
struct flashing_req_params *flashing);
#endif
/**
* wma_sar_rsp_evt_handler() - process sar response event from FW.
* @handle: ol scn handle
* @event: event buffer
* @len: buffer length
*
* Return: 0 for success or error code
*/
int wma_sar_rsp_evt_handler(ol_scn_t handle, uint8_t *event, uint32_t len);
#ifdef FEATURE_WLAN_CH_AVOID
QDF_STATUS wma_process_ch_avoid_update_req(tp_wma_handle wma_handle,
tSirChAvoidUpdateReq *
ch_avoid_update_req);
#endif
#ifdef FEATURE_WLAN_TDLS
int wma_update_tdls_peer_state(WMA_HANDLE handle,
struct tdls_peer_update_state *peer_state);
#endif
void wma_set_vdev_mgmt_rate(tp_wma_handle wma, uint8_t vdev_id);
void wma_set_sap_keepalive(tp_wma_handle wma, uint8_t vdev_id);
#ifdef FEATURE_RSSI_MONITOR
int wma_rssi_breached_event_handler(void *handle,
u_int8_t *cmd_param_info, u_int32_t len);
#else /* FEATURE_RSSI_MONITOR */
static inline
int wma_rssi_breached_event_handler(void *handle,
u_int8_t *cmd_param_info, u_int32_t len)
{
return 0;
}
#endif /* FEATURE_RSSI_MONITOR */
QDF_STATUS wma_process_cfg_action_frm_tb_ppdu(tp_wma_handle wma,
struct cfg_action_frm_tb_ppdu *cfg_info);
QDF_STATUS wma_process_set_ie_info(tp_wma_handle wma,
struct vdev_ie_info *ie_info);
int wma_peer_assoc_conf_handler(void *handle, uint8_t *cmd_param_info,
uint32_t len);
int wma_peer_delete_handler(void *handle, uint8_t *cmd_param_info,
uint32_t len);
void wma_remove_req(tp_wma_handle wma, uint8_t vdev_id,
uint8_t type);
QDF_STATUS wma_process_hal_pwr_dbg_cmd(WMA_HANDLE handle,
struct sir_mac_pwr_dbg_cmd *
sir_pwr_dbg_params);
/**
* wma_lost_link_info_handler() - collect lost link information and inform SME
* @wma: WMA handle
* @vdev_id: vdev ID
* @rssi: rssi at disconnection time
*
* Return: none
*/
void wma_lost_link_info_handler(tp_wma_handle wma, uint32_t vdev_id,
int32_t rssi);
int wma_unified_power_debug_stats_event_handler(void *handle,
uint8_t *cmd_param_info, uint32_t len);
/**
* wma_unified_beacon_debug_stats_event_handler() - collect beacon debug stats
* @handle: WMA handle
* @cmd_param_info: data from event
* @len: length
*
* Return: 0 for success or error code
*/
int wma_unified_beacon_debug_stats_event_handler(void *handle,
uint8_t *cmd_param_info,
uint32_t len);
#ifdef FEATURE_WLAN_DIAG_SUPPORT
/**
* wma_sta_kickout_event()- send sta kickout event
* @kickout_reason - reasoncode for kickout
* @macaddr[QDF_MAC_ADDR_SIZE]: Peer mac address
* @vdev_id: Unique id for identifying the VDEV
*
* This function sends sta kickout diag event
*
* Return: void.
*/
void wma_sta_kickout_event(uint32_t kickout_reason, uint8_t vdev_id,
uint8_t *macaddr);
#else
static inline void wma_sta_kickout_event(uint32_t kickout_reason,
uint8_t vdev_id, uint8_t *macaddr)
{
};
#endif /* FEATURE_WLAN_DIAG_SUPPORT */
/**
* wma_get_rcpi_req() - get rcpi request
* @handle: wma handle
* @rcpi_request: rcpi params
*
* Return: none
*/
QDF_STATUS wma_get_rcpi_req(WMA_HANDLE handle,
struct sme_rcpi_req *rcpi_request);
/**
* wma_rcpi_event_handler() - rcpi event handler
* @handle: wma handle
* @cmd_param_info: data from event
* @len: length
*
* Return: 0 for success or error code
*/
int wma_rcpi_event_handler(void *handle, uint8_t *cmd_param_info,
uint32_t len);
/**
* wma_acquire_wakelock() - acquire the given wakelock
* @wl: the wakelock to acquire
* @msec: the wakelock duration in milliseconds
*
* This also acquires the wma runtime pm lock.
*
* Return: None
*/
void wma_acquire_wakelock(qdf_wake_lock_t *wl, uint32_t msec);
/**
* wma_release_wakelock() - release the given wakelock
* @wl: the wakelock to release
*
* This also releases the wma runtime pm lock.
*
* Return: None
*/
void wma_release_wakelock(qdf_wake_lock_t *wl);
/**
* wma_send_vdev_stop_to_fw() - send the vdev stop command to firmware
* @wma: a reference to the global WMA handle
* @vdev_id: the Id of the vdev to stop
*
* Consumers should call wma_release_wakelock() upon receipt of the vdev stop
* response from firmware to avoid power penalties.
*
* Return: QDF_STATUS
*/
QDF_STATUS wma_send_vdev_stop_to_fw(t_wma_handle *wma, uint8_t vdev_id);
int wma_get_arp_stats_handler(void *handle, uint8_t *data, uint32_t data_len);
/**
* wma_send_vdev_down_to_fw() - send the vdev down command to firmware
* @wma: a reference to the global WMA handle
* @vdev_id: the Id of the vdev to down
*
* This also releases the vdev start wakelock.
*
* Return: QDF_STATUS
*/
QDF_STATUS wma_send_vdev_down_to_fw(t_wma_handle *wma, uint8_t vdev_id);
/*
* wma_rx_aggr_failure_event_handler - event handler to handle rx aggr failure
* @handle: the wma handle
* @event_buf: buffer with event
* @len: buffer length
*
* This function receives rx aggregation failure event and then pass to upper
* layer
*
* Return: 0 on success
*/
int wma_rx_aggr_failure_event_handler(void *handle, u_int8_t *event_buf,
u_int32_t len);
/**
* wma_wlan_bt_activity_evt_handler - event handler to handle bt activity
* @handle: the WMA handle
* @event: buffer with the event parameters
* @len: length of the buffer
*
* This function receives BT activity event from firmware and passes the event
* information to upper layers
*
* Return: 0 on success
*/
int wma_wlan_bt_activity_evt_handler(void *handle, uint8_t *event,
uint32_t len);
/**
* wma_pdev_div_info_evt_handler - event handler to handle antenna info
* @handle: the wma handle
* @event_buf: buffer with event
* @len: buffer length
*
* This function receives antenna info from firmware and passes the event
* to upper layer
*
* Return: 0 on success
*/
int wma_pdev_div_info_evt_handler(void *handle, u_int8_t *event_buf,
u_int32_t len);
/**
* wma_update_beacon_interval() - update beacon interval in fw
* @wma: wma handle
* @vdev_id: vdev id
* @beaconInterval: becon interval
*
* Return: none
*/
void
wma_update_beacon_interval(tp_wma_handle wma, uint8_t vdev_id,
uint16_t beaconInterval);
#define RESET_BEACON_INTERVAL_TIMEOUT 200
struct wma_beacon_interval_reset_req {
qdf_timer_t event_timeout;
uint8_t vdev_id;
uint16_t interval;
};
/**
* wma_fill_beacon_interval_reset_req() - req to reset beacon interval
* @wma: wma handle
* @vdev_id: vdev id
* @beacon_interval: beacon interval
* @timeout: timeout val
*
* Return: status
*/
int wma_fill_beacon_interval_reset_req(tp_wma_handle wma, uint8_t vdev_id,
uint16_t beacon_interval, uint32_t timeout);
/*
* wma_is_vdev_valid() - check the vdev status
* @vdev_id: vdev identifier
*
* This function verifies the vdev validity
*
* Return: 'true' on valid vdev else 'false'
*/
bool wma_is_vdev_valid(uint32_t vdev_id);
/**
* wma_vdev_obss_detection_info_handler - event handler to handle obss detection
* @handle: the wma handle
* @event: buffer with event
* @len: buffer length
*
* This function receives obss detection info from firmware which is used to
* decide obss protection.
*
* Return: 0 on success
*/
int wma_vdev_obss_detection_info_handler(void *handle, uint8_t *event,
uint32_t len);
/**
* wma_vdev_bss_color_collision_info_handler - event handler to
* handle obss color collision detection.
* @handle: the wma handle
* @event: buffer with event
* @len: buffer length
*
* This function receives obss color collision detection info from firmware
* which is used to select new bss color.
*
* Return: 0 on success
*/
int wma_vdev_bss_color_collision_info_handler(void *handle,
uint8_t *event,
uint32_t len);
#ifdef WLAN_SUPPORT_TWT
/**
* wma_twt_en_complete_event_handler - TWT enable complete event handler
* @handle: wma handle
* @event: buffer with event
* @len: buffer length
*
* Return: 0 on success
*/
int wma_twt_en_complete_event_handler(void *handle,
uint8_t *event, uint32_t len);
/**
* wma_twt_disable_comp_event_handler- TWT disable complete event handler
* @handle: wma handle
* @event: buffer with event
* @len: buffer length
*
* Return: 0 on success
*/
int wma_twt_disable_comp_event_handler(void *handle, uint8_t *event,
uint32_t len);
#else
static inline int wma_twt_en_complete_event_handler(void *handle,
uint8_t *event,
uint32_t len)
{
return 0;
}
static inline int wma_twt_disable_comp_event_handler(void *handle,
uint8_t *event,
uint32_t len)
{
return 0;
}
#endif
/**
* wma_get_roam_scan_stats() - Get roam scan stats request
* @handle: wma handle
* @req: request details
*
* Return: QDF_STATUS
*/
QDF_STATUS wma_get_roam_scan_stats(WMA_HANDLE handle,
struct sir_roam_scan_stats *req);
/**
* wma_roam_scan_stats_event_handler() - roam scan stats event handler
* @handle: wma handle
* @event: event data
* @len: length of data
*
* Return: Success or Failure status
*/
int wma_roam_scan_stats_event_handler(void *handle, uint8_t *event,
uint32_t len);
/**
* wma_send_vdev_down() - send del bss req to firmware
* @wma: wma handle.
* @req: pointer to del bss response
*
* This function sends del bss resp to upper layer
*
* Return: none
*/
void wma_send_vdev_down(tp_wma_handle wma, struct del_bss_resp *req);
/**
* wma_cold_boot_cal_event_handler() - Cold boot cal event handler
* @wma_ctx: wma handle
* @event_buff: event data
* @len: length of data
*
* Return: Success or Failure status
*/
int wma_cold_boot_cal_event_handler(void *wma_ctx, uint8_t *event_buff,
uint32_t len);
#ifdef FEATURE_OEM_DATA
/**
* wma_oem_event_handler() - oem data event handler
* @wma_ctx: wma handle
* @event_buff: event data
* @len: length of event buffer
*
* Return: Success or Failure status
*/
int wma_oem_event_handler(void *wma_ctx, uint8_t *event_buff, uint32_t len);
#endif
/**
* wma_set_roam_triggers() - Send roam trigger bitmap to WMI
* @wma_handle: wma handle
* @triggers: Carries vdev id and roam trigger bitmap.
*
* Return: Success or Failure status
*/
QDF_STATUS wma_set_roam_triggers(tp_wma_handle wma_handle,
struct roam_triggers *triggers);
/**
* wma_get_ani_level_evt_handler - event handler to fetch ani level
* @handle: the wma handle
* @event_buf: buffer with event
* @len: buffer length
*
* This function receives ani level from firmware and passes the event
* to upper layer
*
* Return: 0 on success
*/
int wma_get_ani_level_evt_handler(void *handle, uint8_t *event_buf,
uint32_t len);
#endif