xref: /wlan-driver/qcacld-3.0/core/sme/inc/sme_api.h (revision 5113495b16420b49004c444715d2daae2066e7dc)
1*5113495bSYour Name /*
2*5113495bSYour Name  * Copyright (c) 2012-2021 The Linux Foundation. All rights reserved.
3*5113495bSYour Name  * Copyright (c) 2021-2024 Qualcomm Innovation Center, Inc. All rights reserved.
4*5113495bSYour Name  *
5*5113495bSYour Name  * Permission to use, copy, modify, and/or distribute this software for
6*5113495bSYour Name  * any purpose with or without fee is hereby granted, provided that the
7*5113495bSYour Name  * above copyright notice and this permission notice appear in all
8*5113495bSYour Name  * copies.
9*5113495bSYour Name  *
10*5113495bSYour Name  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
11*5113495bSYour Name  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
12*5113495bSYour Name  * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
13*5113495bSYour Name  * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
14*5113495bSYour Name  * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
15*5113495bSYour Name  * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
16*5113495bSYour Name  * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*5113495bSYour Name  * PERFORMANCE OF THIS SOFTWARE.
18*5113495bSYour Name  */
19*5113495bSYour Name 
20*5113495bSYour Name #if !defined(__SME_API_H)
21*5113495bSYour Name #define __SME_API_H
22*5113495bSYour Name 
23*5113495bSYour Name /*
24*5113495bSYour Name  * file  smeApi.h
25*5113495bSYour Name  *
26*5113495bSYour Name  * brief prototype for SME APIs
27*5113495bSYour Name  */
28*5113495bSYour Name 
29*5113495bSYour Name /*--------------------------------------------------------------------------
30*5113495bSYour Name   Include Files
31*5113495bSYour Name   ------------------------------------------------------------------------*/
32*5113495bSYour Name #include "csr_api.h"
33*5113495bSYour Name #include "qdf_lock.h"
34*5113495bSYour Name #include "qdf_types.h"
35*5113495bSYour Name #include "sir_api.h"
36*5113495bSYour Name #include "cds_regdomain.h"
37*5113495bSYour Name #include "sme_internal.h"
38*5113495bSYour Name #include "wma_tgt_cfg.h"
39*5113495bSYour Name #include "wma_fips_public_structs.h"
40*5113495bSYour Name #include "wma_sar_public_structs.h"
41*5113495bSYour Name #include "wma_if.h"
42*5113495bSYour Name #include "wlan_mlme_public_struct.h"
43*5113495bSYour Name #include "sme_rrm_internal.h"
44*5113495bSYour Name #include "sir_types.h"
45*5113495bSYour Name #include "scheduler_api.h"
46*5113495bSYour Name #include "wlan_serialization_legacy_api.h"
47*5113495bSYour Name #include <qca_vendor.h>
48*5113495bSYour Name #include "wmi_unified.h"
49*5113495bSYour Name #include "wmi_unified_param.h"
50*5113495bSYour Name #include "wlan_cm_roam_public_struct.h"
51*5113495bSYour Name 
52*5113495bSYour Name /*--------------------------------------------------------------------------
53*5113495bSYour Name   Preprocessor definitions and constants
54*5113495bSYour Name   ------------------------------------------------------------------------*/
55*5113495bSYour Name 
56*5113495bSYour Name #define sme_alert(params...) QDF_TRACE_FATAL(QDF_MODULE_ID_SME, params)
57*5113495bSYour Name #define sme_err(params...) QDF_TRACE_ERROR(QDF_MODULE_ID_SME, params)
58*5113495bSYour Name #define sme_warn(params...) QDF_TRACE_WARN(QDF_MODULE_ID_SME, params)
59*5113495bSYour Name #define sme_info(params...) QDF_TRACE_INFO(QDF_MODULE_ID_SME, params)
60*5113495bSYour Name #define sme_debug(params...) QDF_TRACE_DEBUG(QDF_MODULE_ID_SME, params)
61*5113495bSYour Name 
62*5113495bSYour Name #define sme_nofl_alert(params...) \
63*5113495bSYour Name 	QDF_TRACE_FATAL_NO_FL(QDF_MODULE_ID_SME, params)
64*5113495bSYour Name #define sme_nofl_err(params...) \
65*5113495bSYour Name 	QDF_TRACE_ERROR_NO_FL(QDF_MODULE_ID_SME, params)
66*5113495bSYour Name #define sme_nofl_warn(params...) \
67*5113495bSYour Name 	QDF_TRACE_WARN_NO_FL(QDF_MODULE_ID_SME, params)
68*5113495bSYour Name #define sme_nofl_info(params...) \
69*5113495bSYour Name 	QDF_TRACE_INFO_NO_FL(QDF_MODULE_ID_SME, params)
70*5113495bSYour Name #define sme_nofl_debug(params...) \
71*5113495bSYour Name 	QDF_TRACE_DEBUG_NO_FL(QDF_MODULE_ID_SME, params)
72*5113495bSYour Name 
73*5113495bSYour Name #define sme_alert_rl(params...) QDF_TRACE_FATAL_RL(QDF_MODULE_ID_SME, params)
74*5113495bSYour Name #define sme_err_rl(params...) QDF_TRACE_ERROR_RL(QDF_MODULE_ID_SME, params)
75*5113495bSYour Name #define sme_warn_rl(params...) QDF_TRACE_WARN_RL(QDF_MODULE_ID_SME, params)
76*5113495bSYour Name #define sme_info_rl(params...) QDF_TRACE_INFO_RL(QDF_MODULE_ID_SME, params)
77*5113495bSYour Name #define sme_debug_rl(params...) QDF_TRACE_DEBUG_RL(QDF_MODULE_ID_SME, params)
78*5113495bSYour Name 
79*5113495bSYour Name #define SME_ENTER() QDF_TRACE_ENTER(QDF_MODULE_ID_SME, "enter")
80*5113495bSYour Name #define SME_EXIT() QDF_TRACE_EXIT(QDF_MODULE_ID_SME, "exit")
81*5113495bSYour Name 
82*5113495bSYour Name #define SME_SESSION_ID_ANY        50
83*5113495bSYour Name #define SME_SESSION_ID_BROADCAST  0xFF
84*5113495bSYour Name 
85*5113495bSYour Name #define SME_INVALID_COUNTRY_CODE "XX"
86*5113495bSYour Name #define INVALID_ROAM_ID 0
87*5113495bSYour Name 
88*5113495bSYour Name #define SME_SET_CHANNEL_REG_POWER(reg_info_1, val) do {	\
89*5113495bSYour Name 	reg_info_1 &= 0xff00ffff;	      \
90*5113495bSYour Name 	reg_info_1 |= ((val & 0xff) << 16);   \
91*5113495bSYour Name } while (0)
92*5113495bSYour Name 
93*5113495bSYour Name #define SME_SET_CHANNEL_MAX_TX_POWER(reg_info_2, val) do { \
94*5113495bSYour Name 	reg_info_2 &= 0xffff00ff;	      \
95*5113495bSYour Name 	reg_info_2 |= ((val & 0xff) << 8);   \
96*5113495bSYour Name } while (0)
97*5113495bSYour Name 
98*5113495bSYour Name #define SME_CONFIG_TO_ROAM_CONFIG 1
99*5113495bSYour Name #define ROAM_CONFIG_TO_SME_CONFIG 2
100*5113495bSYour Name 
101*5113495bSYour Name #define NUM_OF_BANDS 2
102*5113495bSYour Name 
103*5113495bSYour Name #define SUPPORTED_CRYPTO_CAPS 0x3FFFF
104*5113495bSYour Name 
105*5113495bSYour Name #define SME_ACTIVE_LIST_CMD_TIMEOUT_VALUE (30*1000)
106*5113495bSYour Name #define SME_CMD_TIMEOUT_VALUE (SME_ACTIVE_LIST_CMD_TIMEOUT_VALUE + 1000)
107*5113495bSYour Name 
108*5113495bSYour Name /* AP start timeout = vdev start + 2 sec */
109*5113495bSYour Name #define SME_CMD_VDEV_START_BSS_TIMEOUT (START_RESPONSE_TIMER + 2000)
110*5113495bSYour Name #define SME_CMD_START_BSS_TIMEOUT (SME_CMD_VDEV_START_BSS_TIMEOUT + 1000)
111*5113495bSYour Name 
112*5113495bSYour Name /* AP stop timeout = vdev stop + self peer delete + 1 sec */
113*5113495bSYour Name #define SME_CMD_STOP_BSS_CMD_TIMEOUT (STOP_RESPONSE_TIMER + \
114*5113495bSYour Name 				      SIR_DELETE_STA_TIMEOUT + 1000)
115*5113495bSYour Name #define SME_CMD_STOP_BSS_TIMEOUT (SME_CMD_STOP_BSS_CMD_TIMEOUT + 1000)
116*5113495bSYour Name 
117*5113495bSYour Name /* Peer disconnect timeout = peer delete + 1 sec */
118*5113495bSYour Name #define SME_CMD_PEER_DISCONNECT_TIMEOUT (SIR_DELETE_STA_TIMEOUT + 1000)
119*5113495bSYour Name #define SME_PEER_DISCONNECT_TIMEOUT (SME_CMD_PEER_DISCONNECT_TIMEOUT + 1000)
120*5113495bSYour Name 
121*5113495bSYour Name #define SME_CMD_GET_DISCONNECT_STATS_TIMEOUT 200
122*5113495bSYour Name #define SME_CMD_ADD_DEL_TS_TIMEOUT (4 * 1000)
123*5113495bSYour Name 
124*5113495bSYour Name /*
125*5113495bSYour Name  * POLICY_MGR_SER_CMD_TIMEOUT should be same as SME_CMD_POLICY_MGR_CMD_TIMEOUT
126*5113495bSYour Name  * if SME_CMD_POLICY_MGR_CMD_TIMEOUT is changed change
127*5113495bSYour Name  * POLICY_MGR_SER_CMD_TIMEOUT as well.
128*5113495bSYour Name  */
129*5113495bSYour Name #define SME_CMD_POLICY_MGR_CMD_TIMEOUT (SIR_VDEV_PLCY_MGR_TIMEOUT + 1000)
130*5113495bSYour Name #define SME_POLICY_MGR_CMD_TIMEOUT (SME_CMD_POLICY_MGR_CMD_TIMEOUT + 1000)
131*5113495bSYour Name 
132*5113495bSYour Name #define SME_VDEV_DELETE_CMD_TIMEOUT (DELETE_RESPONSE_TIMER + \
133*5113495bSYour Name 				     PEER_DELETE_ALL_RESPONSE_TIMER + 2000)
134*5113495bSYour Name #define SME_CMD_VDEV_CREATE_DELETE_TIMEOUT QDF_MAX(13000, \
135*5113495bSYour Name 						SME_VDEV_DELETE_CMD_TIMEOUT + 1)
136*5113495bSYour Name 
137*5113495bSYour Name /*--------------------------------------------------------------------------
138*5113495bSYour Name   Type declarations
139*5113495bSYour Name   ------------------------------------------------------------------------*/
140*5113495bSYour Name struct sme_config_params {
141*5113495bSYour Name 	struct csr_config_params csr_config;
142*5113495bSYour Name };
143*5113495bSYour Name 
144*5113495bSYour Name #ifdef FEATURE_WLAN_TDLS
145*5113495bSYour Name #define BW_20_OFFSET_BIT   0
146*5113495bSYour Name #define BW_40_OFFSET_BIT   1
147*5113495bSYour Name #define BW_80_OFFSET_BIT   2
148*5113495bSYour Name #define BW_160_OFFSET_BIT  3
149*5113495bSYour Name #endif /* FEATURE_WLAN_TDLS */
150*5113495bSYour Name 
151*5113495bSYour Name struct wmi_twt_add_dialog_param;
152*5113495bSYour Name struct wmi_twt_del_dialog_param;
153*5113495bSYour Name 
154*5113495bSYour Name /* Thermal Mitigation*/
155*5113495bSYour Name typedef struct {
156*5113495bSYour Name 	uint16_t smeMinTempThreshold;
157*5113495bSYour Name 	uint16_t smeMaxTempThreshold;
158*5113495bSYour Name } tSmeThermalLevelInfo;
159*5113495bSYour Name 
160*5113495bSYour Name typedef enum {
161*5113495bSYour Name 	SME_AC_BK = 0,
162*5113495bSYour Name 	SME_AC_BE = 1,
163*5113495bSYour Name 	SME_AC_VI = 2,
164*5113495bSYour Name 	SME_AC_VO = 3
165*5113495bSYour Name } sme_ac_enum_type;
166*5113495bSYour Name 
167*5113495bSYour Name /*
168*5113495bSYour Name  * Enumeration of the various TSPEC directions
169*5113495bSYour Name  * From 802.11e/WMM specifications
170*5113495bSYour Name  */
171*5113495bSYour Name enum sme_qos_wmm_dir_type {
172*5113495bSYour Name 	SME_QOS_WMM_TS_DIR_UPLINK = 0,
173*5113495bSYour Name 	SME_QOS_WMM_TS_DIR_DOWNLINK = 1,
174*5113495bSYour Name 	SME_QOS_WMM_TS_DIR_RESV = 2,    /* Reserved */
175*5113495bSYour Name 	SME_QOS_WMM_TS_DIR_BOTH = 3,
176*5113495bSYour Name };
177*5113495bSYour Name 
178*5113495bSYour Name /**
179*5113495bSYour Name  * struct sme_oem_capability - OEM capability to be exchanged between host
180*5113495bSYour Name  *                             and userspace
181*5113495bSYour Name  * @ftm_rr: FTM range report capability bit
182*5113495bSYour Name  * @lci_capability: LCI capability bit
183*5113495bSYour Name  * @reserved1: reserved
184*5113495bSYour Name  * @reserved2: reserved
185*5113495bSYour Name  */
186*5113495bSYour Name struct sme_oem_capability {
187*5113495bSYour Name 	uint32_t ftm_rr:1;
188*5113495bSYour Name 	uint32_t lci_capability:1;
189*5113495bSYour Name 	uint32_t reserved1:30;
190*5113495bSYour Name 	uint32_t reserved2;
191*5113495bSYour Name };
192*5113495bSYour Name 
193*5113495bSYour Name /**
194*5113495bSYour Name  * struct sme_5g_pref_params : 5G preference params to be read from ini
195*5113495bSYour Name  * @rssi_boost_threshold_5g: RSSI threshold above which 5 GHz is favored
196*5113495bSYour Name  * @rssi_boost_factor_5g: Factor by which 5GHz RSSI is boosted
197*5113495bSYour Name  * @max_rssi_boost_5g: Maximum boost that can be applied to 5GHz RSSI
198*5113495bSYour Name  * @rssi_penalize_threshold_5g: RSSI threshold below which 5G is not favored
199*5113495bSYour Name  * @rssi_penalize_factor_5g: Factor by which 5GHz RSSI is penalized
200*5113495bSYour Name  * @max_rssi_penalize_5g: Maximum penalty that can be applied to 5G RSSI
201*5113495bSYour Name  */
202*5113495bSYour Name struct sme_5g_band_pref_params {
203*5113495bSYour Name 	int8_t      rssi_boost_threshold_5g;
204*5113495bSYour Name 	uint8_t     rssi_boost_factor_5g;
205*5113495bSYour Name 	uint8_t     max_rssi_boost_5g;
206*5113495bSYour Name 	int8_t      rssi_penalize_threshold_5g;
207*5113495bSYour Name 	uint8_t     rssi_penalize_factor_5g;
208*5113495bSYour Name 	uint8_t     max_rssi_penalize_5g;
209*5113495bSYour Name };
210*5113495bSYour Name 
211*5113495bSYour Name #define MAX_CANDIDATE_INFO 10
212*5113495bSYour Name 
213*5113495bSYour Name /**
214*5113495bSYour Name  * struct bss_candidate_info - Candidate bss information
215*5113495bSYour Name  *
216*5113495bSYour Name  * @bssid : BSSID of candidate bss
217*5113495bSYour Name  * @status : status code for candidate bss
218*5113495bSYour Name  */
219*5113495bSYour Name struct bss_candidate_info {
220*5113495bSYour Name 	struct qdf_mac_addr bssid;
221*5113495bSYour Name 	uint32_t status;
222*5113495bSYour Name };
223*5113495bSYour Name 
224*5113495bSYour Name /*
225*5113495bSYour Name  * MBO transition reason codes
226*5113495bSYour Name  */
227*5113495bSYour Name enum {
228*5113495bSYour Name 	MBO_TRANSITION_REASON_UNSPECIFIED,
229*5113495bSYour Name 	MBO_TRANSITION_REASON_EXCESSIVE_FRAME_LOSS_RATE,
230*5113495bSYour Name 	MBO_TRANSITION_REASON_EXCESSIVE_DELAY_FOR_CURRENT_TRAFFIC,
231*5113495bSYour Name 	MBO_TRANSITION_REASON_INSUFFICIENT_BANDWIDTH_FOR_CURRENT_TRAFFIC,
232*5113495bSYour Name 	MBO_TRANSITION_REASON_LOAD_BALANCING,
233*5113495bSYour Name 	MBO_TRANSITION_REASON_LOW_RSSI,
234*5113495bSYour Name 	MBO_TRANSITION_REASON_RECEIVED_EXCESSIVE_RETRANSMISSIONS,
235*5113495bSYour Name 	MBO_TRANSITION_REASON_HIGH_INTERFERENCE,
236*5113495bSYour Name 	MBO_TRANSITION_REASON_GRAY_ZONE,
237*5113495bSYour Name 	MBO_TRANSITION_REASON_TRANSITIONING_TO_PREMIUM_AP,
238*5113495bSYour Name };
239*5113495bSYour Name 
240*5113495bSYour Name /*-------------------------------------------------------------------------
241*5113495bSYour Name   Function declarations and documentation
242*5113495bSYour Name   ------------------------------------------------------------------------*/
243*5113495bSYour Name QDF_STATUS sme_open(mac_handle_t mac_handle);
244*5113495bSYour Name QDF_STATUS sme_init_chan_list(mac_handle_t mac_handle, enum country_src cc_src);
245*5113495bSYour Name QDF_STATUS sme_close(mac_handle_t mac_handle);
246*5113495bSYour Name QDF_STATUS sme_start(mac_handle_t mac_handle);
247*5113495bSYour Name 
248*5113495bSYour Name /**
249*5113495bSYour Name  * sme_stop() - Stop all SME modules and put them at idle state
250*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
251*5113495bSYour Name  *
252*5113495bSYour Name  * The function stops each module in SME. Upon return, all modules are
253*5113495bSYour Name  * at idle state ready to start.
254*5113495bSYour Name  *
255*5113495bSYour Name  * This is a synchronous call
256*5113495bSYour Name  *
257*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS if SME is stopped.  Other status means
258*5113495bSYour Name  *         SME failed to stop one or more modules but caller should
259*5113495bSYour Name  *         still consider SME is stopped.
260*5113495bSYour Name  */
261*5113495bSYour Name QDF_STATUS sme_stop(mac_handle_t mac_handle);
262*5113495bSYour Name 
263*5113495bSYour Name /**
264*5113495bSYour Name  * sme_populate_nss_chain_params() - fill vdev nss chain params from ini
265*5113495bSYour Name  * @mac_handle: The handle returned by mac_open.
266*5113495bSYour Name  * @vdev_ini_cfg: pointer to the structure to be filled
267*5113495bSYour Name  * @device_mode: device mode (eg STA, SAP etc.)
268*5113495bSYour Name  * @rf_chains_supported: number of chains supported by fw(updated during
269*5113495bSYour Name  *                       service ready event)
270*5113495bSYour Name  *
271*5113495bSYour Name  * This API will fill the nss chain params for the particular vdev from ini
272*5113495bSYour Name  * configuration for the respective vdev.
273*5113495bSYour Name  *
274*5113495bSYour Name  * Return: none
275*5113495bSYour Name  */
276*5113495bSYour Name void sme_populate_nss_chain_params(mac_handle_t mac_handle,
277*5113495bSYour Name 			     struct wlan_mlme_nss_chains *vdev_ini_cfg,
278*5113495bSYour Name 			     enum QDF_OPMODE device_mode,
279*5113495bSYour Name 			     uint8_t rf_chains_supported);
280*5113495bSYour Name 
281*5113495bSYour Name /**
282*5113495bSYour Name  * sme_store_nss_chains_cfg_in_vdev() - fill vdev nss chain params from ini
283*5113495bSYour Name  * @vdev: Pointer to vdev obj
284*5113495bSYour Name  * @vdev_ini_cfg: pointer to the structure the values are to be filled from
285*5113495bSYour Name  *
286*5113495bSYour Name  * This API will copy the nss chain params for the particular vdev from ini
287*5113495bSYour Name  * configuration to the respective vdev's dynamic, and ini config.
288*5113495bSYour Name  *
289*5113495bSYour Name  * Return: none
290*5113495bSYour Name  */
291*5113495bSYour Name void
292*5113495bSYour Name sme_store_nss_chains_cfg_in_vdev(struct wlan_objmgr_vdev *vdev,
293*5113495bSYour Name 				 struct wlan_mlme_nss_chains *vdev_ini_cfg);
294*5113495bSYour Name 
295*5113495bSYour Name /**
296*5113495bSYour Name  * sme_modify_nss_chains_tgt_cfg() - Change the nss in ini for
297*5113495bSYour Name  * particular opmode, and band, according to the chain config supported by FW.
298*5113495bSYour Name  * @mac_handle: The handle returned by mac_open.
299*5113495bSYour Name  * @vdev_op_mode: vdev operation mode.
300*5113495bSYour Name  * @band:- band for which user wants to change nss.
301*5113495bSYour Name  *
302*5113495bSYour Name  * This API will change the nss in ini (for eg. rx_nss_2g) in the mlme cfg i.e
303*5113495bSYour Name  * the global config structure kept in mac context, according to the max
304*5113495bSYour Name  * supported chains per band which is got as part of ext service ready event.
305*5113495bSYour Name  *
306*5113495bSYour Name  * Return: none
307*5113495bSYour Name  */
308*5113495bSYour Name void
309*5113495bSYour Name sme_modify_nss_chains_tgt_cfg(mac_handle_t mac_handle,
310*5113495bSYour Name 			      enum QDF_OPMODE vdev_op_mode,
311*5113495bSYour Name 			      enum nss_chains_band_info band);
312*5113495bSYour Name 
313*5113495bSYour Name /**
314*5113495bSYour Name  * sme_update_nss_in_mlme_cfg() - Change the nss in ini(rx_nss_(band)) for
315*5113495bSYour Name  * particular opmode, and band.
316*5113495bSYour Name  * @mac_handle: The handle returned by mac_open.
317*5113495bSYour Name  * @rx_nss: new value of rx nss that user wants to change.
318*5113495bSYour Name  * @tx_nss: new value of tx nss that user wants to change.
319*5113495bSYour Name  * @vdev_op_mode: vdev operation mode.
320*5113495bSYour Name  * @band:- band for which user wants to change nss.
321*5113495bSYour Name  *
322*5113495bSYour Name  * This API will change the nss in ini (for eg. rx_nss_2g) in the mlme cfg i.e
323*5113495bSYour Name  * the global config structure kept in mac context.
324*5113495bSYour Name  *
325*5113495bSYour Name  * Return: none
326*5113495bSYour Name  */
327*5113495bSYour Name void
328*5113495bSYour Name sme_update_nss_in_mlme_cfg(mac_handle_t mac_handle,
329*5113495bSYour Name 			   uint8_t rx_nss, uint8_t tx_nss,
330*5113495bSYour Name 			   enum QDF_OPMODE vdev_op_mode,
331*5113495bSYour Name 			   enum nss_chains_band_info band);
332*5113495bSYour Name 
333*5113495bSYour Name /**
334*5113495bSYour Name  * sme_nss_chains_update() - validate and send the user params to fw
335*5113495bSYour Name  * @mac_handle: The handle returned by mac_open.
336*5113495bSYour Name  * @user_cfg: pointer to the structure to be validated and sent to fw
337*5113495bSYour Name  * @vdev_id: vdev id
338*5113495bSYour Name  *
339*5113495bSYour Name  *
340*5113495bSYour Name  * This API will validate the config, and if found correct will update the
341*5113495bSYour Name  * config in dynamic config, and send to the fw.
342*5113495bSYour Name  *
343*5113495bSYour Name  * Return: QDF_STATUS
344*5113495bSYour Name  */
345*5113495bSYour Name QDF_STATUS
346*5113495bSYour Name sme_nss_chains_update(mac_handle_t mac_handle,
347*5113495bSYour Name 		      struct wlan_mlme_nss_chains *user_cfg,
348*5113495bSYour Name 		      uint8_t vdev_id);
349*5113495bSYour Name 
350*5113495bSYour Name /**
351*5113495bSYour Name  * sme_update_bfer_caps_as_per_nss_chains() - Update beamformer caps as per nss
352*5113495bSYour Name  * chains.
353*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
354*5113495bSYour Name  * @cfg: wma target config
355*5113495bSYour Name  *
356*5113495bSYour Name  * This API will update beamformer capability as per nss chains
357*5113495bSYour Name  *
358*5113495bSYour Name  * Return: None
359*5113495bSYour Name  */
360*5113495bSYour Name void
361*5113495bSYour Name sme_update_bfer_caps_as_per_nss_chains(mac_handle_t mac_handle,
362*5113495bSYour Name 				       struct wma_tgt_cfg *cfg);
363*5113495bSYour Name 
364*5113495bSYour Name /**
365*5113495bSYour Name  * sme_vdev_create() - Create vdev for given persona
366*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
367*5113495bSYour Name  * @vdev_params: params required for vdev creation
368*5113495bSYour Name  *
369*5113495bSYour Name  * This API will create the object manager vdev and in the same
370*5113495bSYour Name  * context vdev mlme object manager notification is invoked, which
371*5113495bSYour Name  * will send the vdev create to the firmware.
372*5113495bSYour Name  *
373*5113495bSYour Name  * If the vdev creation is successful the following object is referenced
374*5113495bSYour Name  * by below modules:
375*5113495bSYour Name  * 1) WLAN_OBJMGR_ID
376*5113495bSYour Name  * 2) WLAN_LEGACY_SME_ID
377*5113495bSYour Name  *
378*5113495bSYour Name  * Return: Newly created Vdev object or NULL incase in any error
379*5113495bSYour Name  */
380*5113495bSYour Name struct wlan_objmgr_vdev *sme_vdev_create(mac_handle_t mac_handle,
381*5113495bSYour Name 				  struct wlan_vdev_create_params *vdev_params);
382*5113495bSYour Name 
383*5113495bSYour Name 
384*5113495bSYour Name /**
385*5113495bSYour Name  * sme_vdev_post_vdev_create_setup() - setup the lower layers for the new vdev
386*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
387*5113495bSYour Name  * @vdev: Object manager vdev
388*5113495bSYour Name  *
389*5113495bSYour Name  * This api will setup the csr/mlme/wma layer for the newly created vdev.
390*5113495bSYour Name  *
391*5113495bSYour Name  * If the post vdev setup is successful, we will have following vdev refs
392*5113495bSYour Name  * 1) WLAN_OBJMGR_ID  for self peer
393*5113495bSYour Name  * 2) WLAN_LEGACY_WMA_ID for vdev
394*5113495bSYour Name  *
395*5113495bSYour Name  * Return: QDF_STATUS
396*5113495bSYour Name  */
397*5113495bSYour Name QDF_STATUS sme_vdev_post_vdev_create_setup(mac_handle_t mac_handle,
398*5113495bSYour Name 					   struct wlan_objmgr_vdev *vdev);
399*5113495bSYour Name 
400*5113495bSYour Name /**
401*5113495bSYour Name  * sme_send_multi_pdev_vdev_set_params() - setup lower layers for the new vdev
402*5113495bSYour Name  * @param_type: enum of type mlme_dev_setparam
403*5113495bSYour Name  * @dev_id: stores device(pdev/vdev) id
404*5113495bSYour Name  * @param: points to an array of @n_params
405*5113495bSYour Name  * @n_params: stores number params that we are sending together with @param
406*5113495bSYour Name  * Return: QDF_STATUS
407*5113495bSYour Name  */
408*5113495bSYour Name QDF_STATUS
409*5113495bSYour Name sme_send_multi_pdev_vdev_set_params(enum mlme_dev_setparam param_type,
410*5113495bSYour Name 				    uint8_t dev_id,
411*5113495bSYour Name 				    struct dev_set_param *param,
412*5113495bSYour Name 				    uint8_t n_params);
413*5113495bSYour Name 
414*5113495bSYour Name /**
415*5113495bSYour Name  * sme_validate_txrx_chain_mask() - validates txrx chain mask
416*5113495bSYour Name  * @paramid: Rx/Tx chain mask param id
417*5113495bSYour Name  * @paramvalue: param value
418*5113495bSYour Name  *
419*5113495bSYour Name  * Return: QDF_STATUS
420*5113495bSYour Name  */
421*5113495bSYour Name QDF_STATUS
422*5113495bSYour Name sme_validate_txrx_chain_mask(uint32_t paramid, uint32_t paramvalue);
423*5113495bSYour Name 
424*5113495bSYour Name /**
425*5113495bSYour Name  * sme_vdev_set_data_tx_callback() - Set dp vdev tx callback
426*5113495bSYour Name  * @vdev: Object manager vdev
427*5113495bSYour Name  *
428*5113495bSYour Name  * This api will setup the dp vdev tx data callbaack.
429*5113495bSYour Name  *
430*5113495bSYour Name  * Return: QDF_STATUS
431*5113495bSYour Name  */
432*5113495bSYour Name QDF_STATUS sme_vdev_set_data_tx_callback(struct wlan_objmgr_vdev *vdev);
433*5113495bSYour Name 
434*5113495bSYour Name /**
435*5113495bSYour Name  * sme_vdev_delete() - Delete vdev for given id
436*5113495bSYour Name  * @mac_handle: The handle returned by mac_open.
437*5113495bSYour Name  * @vdev: VDEV Object
438*5113495bSYour Name  *
439*5113495bSYour Name  * This is a synchronous API. This API needs to be called to delete vdev
440*5113495bSYour Name  * in SME module before terminating the session completely.
441*5113495bSYour Name  *
442*5113495bSYour Name  * The following modules releases their reference to the vdev object:
443*5113495bSYour Name  * 1) WLAN_LEGACY_WMA_ID
444*5113495bSYour Name  * 2) WLAN_LEGACY_SME_ID
445*5113495bSYour Name  *
446*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - vdev is deleted.
447*5113495bSYour Name  *         QDF_STATUS_E_INVAL when failed to delete vdev.
448*5113495bSYour Name  */
449*5113495bSYour Name QDF_STATUS sme_vdev_delete(mac_handle_t mac_handle,
450*5113495bSYour Name 			   struct wlan_objmgr_vdev *vdev);
451*5113495bSYour Name 
452*5113495bSYour Name /**
453*5113495bSYour Name  * sme_cleanup_session() -  clean up sme session info for vdev
454*5113495bSYour Name  * @mac_handle: mac handle
455*5113495bSYour Name  * @vdev_id: vdev id
456*5113495bSYour Name  *
457*5113495bSYour Name  * Return: none
458*5113495bSYour Name  */
459*5113495bSYour Name void sme_cleanup_session(mac_handle_t mac_handle, uint8_t vdev_id);
460*5113495bSYour Name 
461*5113495bSYour Name /**
462*5113495bSYour Name  * sme_update_roam_params() - Store/Update the roaming params
463*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
464*5113495bSYour Name  * @vdev_id:                  vdev ID
465*5113495bSYour Name  * @src_rso_config:           The source to copy
466*5113495bSYour Name  * @src_rso_usr_cfg:          The source to copy
467*5113495bSYour Name  * @update_param:             Type of parameter to be updated
468*5113495bSYour Name  *
469*5113495bSYour Name  * Return: Return the status of the updation.
470*5113495bSYour Name  */
471*5113495bSYour Name QDF_STATUS sme_update_roam_params(mac_handle_t mac_handle,
472*5113495bSYour Name 				  uint8_t vdev_id,
473*5113495bSYour Name 				  struct rso_config_params *src_rso_config,
474*5113495bSYour Name 				  struct rso_user_config *src_rso_usr_cfg,
475*5113495bSYour Name 				  int update_param);
476*5113495bSYour Name QDF_STATUS sme_update_config(mac_handle_t mac_handle,
477*5113495bSYour Name 			     struct sme_config_params *pSmeConfigParams);
478*5113495bSYour Name 
479*5113495bSYour Name QDF_STATUS sme_set11dinfo(mac_handle_t mac_handle,
480*5113495bSYour Name 			  struct sme_config_params *pSmeConfigParams);
481*5113495bSYour Name QDF_STATUS sme_hdd_ready_ind(mac_handle_t mac_handle);
482*5113495bSYour Name 
483*5113495bSYour Name #ifdef WLAN_BCN_RECV_FEATURE
484*5113495bSYour Name /*
485*5113495bSYour Name  * sme_register_bcn_report_pe_cb() - Register SME callback
486*5113495bSYour Name  * @mac_handle: The handle returned by mac_open.
487*5113495bSYour Name  * @cb: cb of type beacon_report_cb
488*5113495bSYour Name  *
489*5113495bSYour Name  * This function Register SME callback in order to send
490*5113495bSYour Name  * beacon report to upper layer
491*5113495bSYour Name  *
492*5113495bSYour Name  * Return QDF_STATUS_SUCCESS -
493*5113495bSYour Name  */
494*5113495bSYour Name QDF_STATUS
495*5113495bSYour Name sme_register_bcn_report_pe_cb(mac_handle_t mac_handle, beacon_report_cb cb);
496*5113495bSYour Name #else
497*5113495bSYour Name static inline QDF_STATUS
sme_register_bcn_report_pe_cb(mac_handle_t mac_handle,beacon_report_cb cb)498*5113495bSYour Name sme_register_bcn_report_pe_cb(mac_handle_t mac_handle, beacon_report_cb cb)
499*5113495bSYour Name {
500*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
501*5113495bSYour Name }
502*5113495bSYour Name #endif
503*5113495bSYour Name 
504*5113495bSYour Name /**
505*5113495bSYour Name  * sme_ser_cmd_callback() - callback from serialization module
506*5113495bSYour Name  * @cmd: serialization command
507*5113495bSYour Name  * @reason: reason why serialization module has given this callback
508*5113495bSYour Name  *
509*5113495bSYour Name  * Serialization module will give callback to SME for why it triggered
510*5113495bSYour Name  * the callback
511*5113495bSYour Name  *
512*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS
513*5113495bSYour Name  */
514*5113495bSYour Name QDF_STATUS sme_ser_cmd_callback(struct wlan_serialization_command *cmd,
515*5113495bSYour Name 				enum wlan_serialization_cb_reason reason);
516*5113495bSYour Name 
517*5113495bSYour Name /*
518*5113495bSYour Name  * sme_process_msg() - The main message processor for SME.
519*5113495bSYour Name  * @mac: The global mac context
520*5113495bSYour Name  * @msg: The message to be processed.
521*5113495bSYour Name  *
522*5113495bSYour Name  * This function is called by a message dispatcher when to process a message
523*5113495bSYour Name  * targeted for SME.
524*5113495bSYour Name  * This is a synchronous call
525*5113495bSYour Name  *
526*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS - SME successfully processed the message.
527*5113495bSYour Name  * Other status means SME failed to process the message to HAL.
528*5113495bSYour Name  */
529*5113495bSYour Name QDF_STATUS sme_process_msg(struct mac_context *mac, struct scheduler_msg *pMsg);
530*5113495bSYour Name 
531*5113495bSYour Name QDF_STATUS sme_mc_process_handler(struct scheduler_msg *msg);
532*5113495bSYour Name 
533*5113495bSYour Name /**
534*5113495bSYour Name  * sme_roam_ndi_stop() - API to request stop ndi
535*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
536*5113495bSYour Name  * @vdev_id: vdev id
537*5113495bSYour Name  *
538*5113495bSYour Name  * Return: QDF Status success or failure
539*5113495bSYour Name  */
540*5113495bSYour Name QDF_STATUS sme_roam_ndi_stop(mac_handle_t mac_handle, uint8_t vdev_id);
541*5113495bSYour Name 
542*5113495bSYour Name void sme_dhcp_done_ind(mac_handle_t mac_handle, uint8_t session_id);
543*5113495bSYour Name 
544*5113495bSYour Name /*
545*5113495bSYour Name  * sme_roam_stop_bss() - To stop BSS for Soft AP. This is an asynchronous API.
546*5113495bSYour Name  * @mac_handle - Global structure
547*5113495bSYour Name  * @vdev_id - vdev id of SoftAP
548*5113495bSYour Name  *
549*5113495bSYour Name  * Return: QDF Status success or failure
550*5113495bSYour Name  */
551*5113495bSYour Name QDF_STATUS sme_roam_stop_bss(mac_handle_t mac_handle, uint8_t vdev_id);
552*5113495bSYour Name QDF_STATUS sme_roam_disconnect_sta(mac_handle_t mac_handle, uint8_t sessionId,
553*5113495bSYour Name 		struct csr_del_sta_params *p_del_sta_params);
554*5113495bSYour Name QDF_STATUS sme_roam_deauth_sta(mac_handle_t mac_handle, uint8_t sessionId,
555*5113495bSYour Name 		struct csr_del_sta_params *pDelStaParams);
556*5113495bSYour Name 
557*5113495bSYour Name #ifdef MULTI_CLIENT_LL_SUPPORT
558*5113495bSYour Name /**
559*5113495bSYour Name  * sme_multi_client_ll_rsp_register_callback() - Register multi client low
560*5113495bSYour Name  * latency callback
561*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
562*5113495bSYour Name  * @latency_level_event_handler_cb: Function to be invoked for low latency
563*5113495bSYour Name  * event
564*5113495bSYour Name  *
565*5113495bSYour Name  * Return: QDF_STATUS
566*5113495bSYour Name  */
567*5113495bSYour Name QDF_STATUS sme_multi_client_ll_rsp_register_callback(mac_handle_t mac_handle,
568*5113495bSYour Name 				void (*latency_level_event_handler_cb)
569*5113495bSYour Name 				(const struct latency_level_data *event_data,
570*5113495bSYour Name 				 uint8_t vdev_id));
571*5113495bSYour Name 
572*5113495bSYour Name /**
573*5113495bSYour Name  * sme_multi_client_ll_rsp_deregister_callback() - De Register multi client
574*5113495bSYour Name  * low latency callback
575*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
576*5113495bSYour Name  *
577*5113495bSYour Name  * Return: void
578*5113495bSYour Name  */
579*5113495bSYour Name void sme_multi_client_ll_rsp_deregister_callback(mac_handle_t mac_handle);
580*5113495bSYour Name #else
581*5113495bSYour Name static inline QDF_STATUS
sme_multi_client_ll_rsp_register_callback(mac_handle_t mac_handle,void (* latency_level_event_handler_cb)(const void * event_data,uint8_t vdev_id))582*5113495bSYour Name sme_multi_client_ll_rsp_register_callback(mac_handle_t mac_handle,
583*5113495bSYour Name 				void (*latency_level_event_handler_cb)
584*5113495bSYour Name 				(const void *event_data,
585*5113495bSYour Name 				 uint8_t vdev_id))
586*5113495bSYour Name {
587*5113495bSYour Name 	return QDF_STATUS_E_FAILURE;
588*5113495bSYour Name }
589*5113495bSYour Name 
590*5113495bSYour Name static inline
sme_multi_client_ll_rsp_deregister_callback(mac_handle_t mac_handle)591*5113495bSYour Name void sme_multi_client_ll_rsp_deregister_callback(mac_handle_t mac_handle)
592*5113495bSYour Name {}
593*5113495bSYour Name #endif
594*5113495bSYour Name 
595*5113495bSYour Name #ifdef WLAN_FEATURE_ROAM_OFFLOAD
596*5113495bSYour Name /**
597*5113495bSYour Name  * sme_set_roam_scan_ch_event_cb() - Register roam scan ch callback
598*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
599*5113495bSYour Name  * @cb: callback to be registered
600*5113495bSYour Name  *
601*5113495bSYour Name  * Return: QDF_STATUS
602*5113495bSYour Name  */
603*5113495bSYour Name QDF_STATUS
604*5113495bSYour Name sme_set_roam_scan_ch_event_cb(mac_handle_t mac_handle,
605*5113495bSYour Name 			      sme_get_raom_scan_ch_callback cb);
606*5113495bSYour Name 
607*5113495bSYour Name /**
608*5113495bSYour Name  * sme_get_roam_scan_ch() -API to get roam scan channels
609*5113495bSYour Name  * @mac_handle: Pointer to mac handle
610*5113495bSYour Name  * @sta_id: vdev id
611*5113495bSYour Name  * @pcontext: pointer to the context
612*5113495bSYour Name  *
613*5113495bSYour Name  * Extract number of frequencies and frequency list from chan_info and print
614*5113495bSYour Name  * to the logs.
615*5113495bSYour Name  *
616*5113495bSYour Name  * Return: None
617*5113495bSYour Name  */
618*5113495bSYour Name QDF_STATUS
619*5113495bSYour Name sme_get_roam_scan_ch(mac_handle_t mac_handle,
620*5113495bSYour Name 		     uint8_t vdev_id, void *pcontext);
621*5113495bSYour Name 
622*5113495bSYour Name /**
623*5113495bSYour Name  * sme_get_pmk_info(): A wrapper function to request CSR to save PMK
624*5113495bSYour Name  * @mac_handle: Global structure
625*5113495bSYour Name  * @session_id: SME session_id
626*5113495bSYour Name  * @pmk_cache: pointer to a structure of pmk
627*5113495bSYour Name  *
628*5113495bSYour Name  * Return: none
629*5113495bSYour Name  */
630*5113495bSYour Name void sme_get_pmk_info(mac_handle_t mac_handle, uint8_t session_id,
631*5113495bSYour Name 		      struct wlan_crypto_pmksa *pmk_cache);
632*5113495bSYour Name 
633*5113495bSYour Name /**
634*5113495bSYour Name  * sme_roam_set_psk_pmk  - Set the PMK to vdev cache
635*5113495bSYour Name  * @mac_handle: Opaque Mac handle
636*5113495bSYour Name  * @pmksa:   Pointer to pmksa cache
637*5113495bSYour Name  * @vdev_id: Vdev id
638*5113495bSYour Name  * @update_to_fw: Send RSO update config command to firmware to update
639*5113495bSYour Name  *
640*5113495bSYour Name  * Return: QDF_STATUS
641*5113495bSYour Name  */
642*5113495bSYour Name QDF_STATUS sme_roam_set_psk_pmk(mac_handle_t mac_handle,
643*5113495bSYour Name 				struct wlan_crypto_pmksa *pmksa,
644*5113495bSYour Name 				uint8_t vdev_id, bool update_to_fw);
645*5113495bSYour Name 
646*5113495bSYour Name /**
647*5113495bSYour Name  * sme_set_pmk_cache_ft() - a wrapper function to request CSR to save MDID
648*5113495bSYour Name  * This is a synchronous call.
649*5113495bSYour Name  * @mac_handle:  Global structure
650*5113495bSYour Name  * @session_id:   SME session id
651*5113495bSYour Name  * @pmk_cache:    pointer to pmk cache structure wlan_crypto_pmksa
652*5113495bSYour Name  *
653*5113495bSYour Name  * Return: QDF_STATUS -status whether MDID is set or not
654*5113495bSYour Name  */
655*5113495bSYour Name QDF_STATUS sme_set_pmk_cache_ft(mac_handle_t mac_handle, uint8_t vdev_id,
656*5113495bSYour Name 				struct wlan_crypto_pmksa *pmk_cache);
657*5113495bSYour Name #else
658*5113495bSYour Name static inline
sme_get_pmk_info(mac_handle_t mac_handle,uint8_t session_id,struct wlan_crypto_pmksa * pmk_cache)659*5113495bSYour Name void sme_get_pmk_info(mac_handle_t mac_handle, uint8_t session_id,
660*5113495bSYour Name 		      struct wlan_crypto_pmksa *pmk_cache)
661*5113495bSYour Name {}
662*5113495bSYour Name 
663*5113495bSYour Name static inline QDF_STATUS
sme_get_roam_scan_ch(mac_handle_t mac_handle,uint8_t vdev_id,void * pcontext)664*5113495bSYour Name sme_get_roam_scan_ch(mac_handle_t mac_handle,
665*5113495bSYour Name 		     uint8_t vdev_id, void *pcontext)
666*5113495bSYour Name {
667*5113495bSYour Name 	return QDF_STATUS_E_FAILURE;
668*5113495bSYour Name }
669*5113495bSYour Name 
670*5113495bSYour Name static inline QDF_STATUS
sme_set_roam_scan_ch_event_cb(mac_handle_t mac_handle,void * cb)671*5113495bSYour Name sme_set_roam_scan_ch_event_cb(mac_handle_t mac_handle,
672*5113495bSYour Name 			      void *cb)
673*5113495bSYour Name {
674*5113495bSYour Name 	return QDF_STATUS_E_FAILURE;
675*5113495bSYour Name }
676*5113495bSYour Name 
677*5113495bSYour Name static inline
sme_roam_set_psk_pmk(mac_handle_t mac_handle,struct wlan_crypto_pmksa * pmksa,uint8_t vdev_id,bool update_to_fw)678*5113495bSYour Name QDF_STATUS sme_roam_set_psk_pmk(mac_handle_t mac_handle,
679*5113495bSYour Name 				struct wlan_crypto_pmksa *pmksa,
680*5113495bSYour Name 				uint8_t vdev_id, bool update_to_fw)
681*5113495bSYour Name {
682*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
683*5113495bSYour Name }
684*5113495bSYour Name 
685*5113495bSYour Name static inline
sme_set_pmk_cache_ft(mac_handle_t mac_handle,uint8_t vdev_id,struct wlan_crypto_pmksa * pmk_cache)686*5113495bSYour Name QDF_STATUS sme_set_pmk_cache_ft(mac_handle_t mac_handle, uint8_t vdev_id,
687*5113495bSYour Name 				struct wlan_crypto_pmksa *pmk_cache)
688*5113495bSYour Name {
689*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
690*5113495bSYour Name }
691*5113495bSYour Name 
692*5113495bSYour Name #endif
693*5113495bSYour Name 
694*5113495bSYour Name QDF_STATUS sme_get_config_param(mac_handle_t mac_handle,
695*5113495bSYour Name 				struct sme_config_params *pParam);
696*5113495bSYour Name QDF_STATUS sme_get_snr(mac_handle_t mac_handle,
697*5113495bSYour Name 		       tCsrSnrCallback callback,
698*5113495bSYour Name 		       struct qdf_mac_addr bssId, void *pContext);
699*5113495bSYour Name #ifdef FEATURE_WLAN_ESE
700*5113495bSYour Name QDF_STATUS sme_get_tsm_stats(mac_handle_t mac_handle,
701*5113495bSYour Name 		tCsrTsmStatsCallback callback,
702*5113495bSYour Name 		struct qdf_mac_addr bssId,
703*5113495bSYour Name 		void *pContext, uint8_t tid);
704*5113495bSYour Name QDF_STATUS sme_set_ese_beacon_request(mac_handle_t mac_handle,
705*5113495bSYour Name 				      const uint8_t sessionId,
706*5113495bSYour Name 				      const tCsrEseBeaconReq *in_req);
707*5113495bSYour Name 
708*5113495bSYour Name /**
709*5113495bSYour Name  * sme_set_plm_request() - set plm request
710*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
711*5113495bSYour Name  * @req: Pointer to input plm request
712*5113495bSYour Name  *
713*5113495bSYour Name  * Return: QDF_STATUS enumeration
714*5113495bSYour Name  */
715*5113495bSYour Name QDF_STATUS sme_set_plm_request(mac_handle_t mac_handle,
716*5113495bSYour Name 			       struct plm_req_params *req);
717*5113495bSYour Name #endif /*FEATURE_WLAN_ESE */
718*5113495bSYour Name 
719*5113495bSYour Name #ifdef FEATURE_OEM_DATA_SUPPORT
720*5113495bSYour Name QDF_STATUS sme_register_oem_data_rsp_callback(mac_handle_t mac_handle,
721*5113495bSYour Name 		sme_send_oem_data_rsp_msg callback);
722*5113495bSYour Name void sme_deregister_oem_data_rsp_callback(mac_handle_t mac_handle);
723*5113495bSYour Name 
724*5113495bSYour Name #else
725*5113495bSYour Name static inline
sme_register_oem_data_rsp_callback(mac_handle_t mac_handle,void * callback)726*5113495bSYour Name QDF_STATUS sme_register_oem_data_rsp_callback(mac_handle_t mac_handle,
727*5113495bSYour Name 					      void *callback)
728*5113495bSYour Name {
729*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
730*5113495bSYour Name }
731*5113495bSYour Name 
732*5113495bSYour Name static inline
sme_deregister_oem_data_rsp_callback(mac_handle_t mac_handle)733*5113495bSYour Name void sme_deregister_oem_data_rsp_callback(mac_handle_t mac_handle)
734*5113495bSYour Name {
735*5113495bSYour Name }
736*5113495bSYour Name 
737*5113495bSYour Name #endif
738*5113495bSYour Name 
739*5113495bSYour Name QDF_STATUS sme_generic_change_country_code(mac_handle_t mac_handle,
740*5113495bSYour Name 					   uint8_t *pCountry);
741*5113495bSYour Name 
742*5113495bSYour Name 
743*5113495bSYour Name /**
744*5113495bSYour Name  * sme_update_channel_list() - Update configured channel list to fwr
745*5113495bSYour Name  * This is a synchronous API.
746*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context.
747*5113495bSYour Name  *
748*5113495bSYour Name  * Return: QDF_STATUS  SUCCESS.
749*5113495bSYour Name  * FAILURE or RESOURCES  The API finished and failed.
750*5113495bSYour Name  */
751*5113495bSYour Name QDF_STATUS sme_update_channel_list(mac_handle_t mac_handle);
752*5113495bSYour Name 
753*5113495bSYour Name QDF_STATUS sme_dhcp_start_ind(mac_handle_t mac_handle,
754*5113495bSYour Name 		uint8_t device_mode,
755*5113495bSYour Name 		uint8_t *macAddr, uint8_t sessionId);
756*5113495bSYour Name QDF_STATUS sme_dhcp_stop_ind(mac_handle_t mac_handle,
757*5113495bSYour Name 		uint8_t device_mode,
758*5113495bSYour Name 		uint8_t *macAddr, uint8_t sessionId);
759*5113495bSYour Name QDF_STATUS sme_neighbor_report_request(mac_handle_t mac_handle,
760*5113495bSYour Name 		 uint8_t sessionId,
761*5113495bSYour Name 		tpRrmNeighborReq pRrmNeighborReq,
762*5113495bSYour Name 		tpRrmNeighborRspCallbackInfo callbackInfo);
763*5113495bSYour Name 
764*5113495bSYour Name /**
765*5113495bSYour Name  * sme_register_pagefault_cb() - Register cb to handle host action on pagefault
766*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context.
767*5113495bSYour Name  * @hdd_pagefault_action_cb: Callback which needs to be registered
768*5113495bSYour Name  *
769*5113495bSYour Name  * Return: None
770*5113495bSYour Name  */
771*5113495bSYour Name void
772*5113495bSYour Name sme_register_pagefault_cb(mac_handle_t mac_handle,
773*5113495bSYour Name 			  QDF_STATUS (*hdd_pagefault_action_cb)(void *buf,
774*5113495bSYour Name 								uint32_t buf_len));
775*5113495bSYour Name 
776*5113495bSYour Name /**
777*5113495bSYour Name  * sme_deregister_ssr_on_pagefault_cb() - Deregister cb to trigger SSR on
778*5113495bSYour Name  * pagefault
779*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context.
780*5113495bSYour Name  *
781*5113495bSYour Name  * Return: None
782*5113495bSYour Name  */
783*5113495bSYour Name void sme_deregister_ssr_on_pagefault_cb(mac_handle_t mac_handle);
784*5113495bSYour Name 
785*5113495bSYour Name #ifdef FEATURE_OEM_DATA
786*5113495bSYour Name /**
787*5113495bSYour Name  * sme_oem_data_cmd() - the wrapper to send oem data cmd to wma
788*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context.
789*5113495bSYour Name  * @@oem_data_event_handler_cb: callback to be registered
790*5113495bSYour Name  * @oem_data: the pointer of oem data
791*5113495bSYour Name  * @vdev id: vdev id to fetch adapter
792*5113495bSYour Name  *
793*5113495bSYour Name  * Return: QDF_STATUS
794*5113495bSYour Name  */
795*5113495bSYour Name QDF_STATUS sme_oem_data_cmd(mac_handle_t mac_handle,
796*5113495bSYour Name 			    void (*oem_data_event_handler_cb)
797*5113495bSYour Name 			    (const struct oem_data *oem_event_data,
798*5113495bSYour Name 			     uint8_t vdev_id),
799*5113495bSYour Name 			     struct oem_data *oem_data,
800*5113495bSYour Name 			     uint8_t vdev_id);
801*5113495bSYour Name 
802*5113495bSYour Name /**
803*5113495bSYour Name  * sme_oem_event_deinit() - function to deregister cb for oem event
804*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
805*5113495bSYour Name  *
806*5113495bSYour Name  * Return: None
807*5113495bSYour Name  */
808*5113495bSYour Name void sme_oem_event_deinit(mac_handle_t mac_handle);
809*5113495bSYour Name 
810*5113495bSYour Name /**
811*5113495bSYour Name  * sme_async_oem_event_init() - function to register cb for async oem event
812*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
813*5113495bSYour Name  * @@oem_data_async_event_handler_cb: callback to be registered
814*5113495bSYour Name  *
815*5113495bSYour Name  * Return: None
816*5113495bSYour Name  */
817*5113495bSYour Name void sme_async_oem_event_init(mac_handle_t mac_handle,
818*5113495bSYour Name 			      void (*oem_data_async_event_handler_cb)
819*5113495bSYour Name 			      (const struct oem_data *oem_event_data));
820*5113495bSYour Name /**
821*5113495bSYour Name  * sme_async_oem_event_deinit() - function to deregister cb for async oem event
822*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
823*5113495bSYour Name  *
824*5113495bSYour Name  * Return: None
825*5113495bSYour Name  */
826*5113495bSYour Name void sme_async_oem_event_deinit(mac_handle_t mac_handle);
827*5113495bSYour Name #else
sme_async_oem_event_init(mac_handle_t mac_handle,void (* oem_data_async_event_handler_cb)(void * oem_event_data))828*5113495bSYour Name static inline void sme_async_oem_event_init(
829*5113495bSYour Name 				mac_handle_t mac_handle,
830*5113495bSYour Name 				void (*oem_data_async_event_handler_cb)
831*5113495bSYour Name 				(void *oem_event_data))
832*5113495bSYour Name {
833*5113495bSYour Name }
834*5113495bSYour Name 
sme_async_oem_event_deinit(mac_handle_t mac_handle)835*5113495bSYour Name static inline void sme_async_oem_event_deinit(mac_handle_t mac_handle)
836*5113495bSYour Name {
837*5113495bSYour Name }
838*5113495bSYour Name #endif
839*5113495bSYour Name 
840*5113495bSYour Name #ifdef FEATURE_OEM_DATA_SUPPORT
841*5113495bSYour Name /**
842*5113495bSYour Name  * sme_oem_req_cmd() - send oem request cmd to WMA
843*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
844*5113495bSYour Name  * @oem_req: OEM data request
845*5113495bSYour Name  *
846*5113495bSYour Name  * Return: QDF_STATUS
847*5113495bSYour Name  */
848*5113495bSYour Name QDF_STATUS sme_oem_req_cmd(mac_handle_t mac_handle,
849*5113495bSYour Name 			   struct oem_data_req *oem_req);
850*5113495bSYour Name QDF_STATUS sme_oem_update_capability(mac_handle_t mac_handle,
851*5113495bSYour Name 				     struct sme_oem_capability *cap);
852*5113495bSYour Name QDF_STATUS sme_oem_get_capability(mac_handle_t mac_handle,
853*5113495bSYour Name 				  struct sme_oem_capability *cap);
854*5113495bSYour Name #endif /*FEATURE_OEM_DATA_SUPPORT */
855*5113495bSYour Name QDF_STATUS sme_change_mcc_beacon_interval(uint8_t sessionId);
856*5113495bSYour Name QDF_STATUS sme_set_host_offload(mac_handle_t mac_handle, uint8_t sessionId,
857*5113495bSYour Name 		struct sir_host_offload_req *pRequest);
858*5113495bSYour Name QDF_STATUS sme_set_keep_alive(mac_handle_t mac_handle, uint8_t sessionId,
859*5113495bSYour Name 		struct keep_alive_req *pRequest);
860*5113495bSYour Name QDF_STATUS sme_get_operation_channel(mac_handle_t mac_handle,
861*5113495bSYour Name 				     uint32_t *chan_freq,
862*5113495bSYour Name 				     uint8_t sessionId);
863*5113495bSYour Name QDF_STATUS sme_register_mgmt_frame(mac_handle_t mac_handle, uint8_t sessionId,
864*5113495bSYour Name 		uint16_t frameType, uint8_t *matchData,
865*5113495bSYour Name 		uint16_t matchLen);
866*5113495bSYour Name QDF_STATUS sme_deregister_mgmt_frame(mac_handle_t mac_handle,
867*5113495bSYour Name 				     uint8_t sessionId,
868*5113495bSYour Name 				     uint16_t frameType, uint8_t *matchData,
869*5113495bSYour Name 				     uint16_t matchLen);
870*5113495bSYour Name /**
871*5113495bSYour Name  * sme_change_sap_csa_count() - Set CSA count
872*5113495bSYour Name  * @count: CSA count to be set
873*5113495bSYour Name  *
874*5113495bSYour Name  * Routine sets CSA count in CSA IE when channel switch
875*5113495bSYour Name  * is triggered
876*5113495bSYour Name  *
877*5113495bSYour Name  * Return: QDF_STATUS
878*5113495bSYour Name  */
879*5113495bSYour Name QDF_STATUS sme_change_sap_csa_count(uint8_t count);
880*5113495bSYour Name #ifdef WLAN_FEATURE_EXTWOW_SUPPORT
881*5113495bSYour Name QDF_STATUS sme_configure_ext_wow(mac_handle_t mac_handle,
882*5113495bSYour Name 		tpSirExtWoWParams wlanExtParams,
883*5113495bSYour Name 		csr_readyToSuspendCallback callback,
884*5113495bSYour Name 		void *callbackContext);
885*5113495bSYour Name QDF_STATUS sme_configure_app_type1_params(mac_handle_t mac_handle,
886*5113495bSYour Name 		tpSirAppType1Params wlanAppType1Params);
887*5113495bSYour Name QDF_STATUS sme_configure_app_type2_params(mac_handle_t mac_handle,
888*5113495bSYour Name 		tpSirAppType2Params wlanAppType2Params);
889*5113495bSYour Name #endif
890*5113495bSYour Name /**
891*5113495bSYour Name  * sme_get_beaconing_concurrent_operation_channel() - To get concurrent
892*5113495bSYour Name  * operating channel frequency of beaconing interface
893*5113495bSYour Name  * @mac_handle: Pointer to mac context
894*5113495bSYour Name  * @vdev_id_to_skip: channel of which vdev id to skip
895*5113495bSYour Name  *
896*5113495bSYour Name  * This routine will return operating channel of active AP/GO channel
897*5113495bSYour Name  * and will skip the channel of vdev_id_to_skip.
898*5113495bSYour Name  * If other no requested mode is active it will return 0
899*5113495bSYour Name  *
900*5113495bSYour Name  * Return: uint32_t
901*5113495bSYour Name  */
902*5113495bSYour Name uint32_t sme_get_beaconing_concurrent_operation_channel(mac_handle_t mac_handle,
903*5113495bSYour Name 						       uint8_t vdev_id_to_skip);
904*5113495bSYour Name #ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
905*5113495bSYour Name /**
906*5113495bSYour Name  * sme_check_concurrent_channel_overlap() - Get interfering concurrent channel
907*5113495bSYour Name  * @mac_handle: SAP context pointer
908*5113495bSYour Name  * @sap_ch_freq: SAP home channel frequency
909*5113495bSYour Name  * @sapPhyMode: sap phymode
910*5113495bSYour Name  * @cc_switch_mode: force scc channel switch mode
911*5113495bSYour Name  * @vdev_id: vdev id
912*5113495bSYour Name  *
913*5113495bSYour Name  * Determine if a concurrent channel is interfering.
914*5113495bSYour Name  *
915*5113495bSYour Name  * Return: Channel freq (Mhz) of the interfering channel, or 0 if none.
916*5113495bSYour Name  */
917*5113495bSYour Name uint16_t sme_check_concurrent_channel_overlap(mac_handle_t mac_handle,
918*5113495bSYour Name 					      uint16_t sap_ch_freq,
919*5113495bSYour Name 					      eCsrPhyMode sapPhyMode,
920*5113495bSYour Name 					      uint8_t cc_switch_mode,
921*5113495bSYour Name 					      uint8_t vdev_id);
922*5113495bSYour Name #endif
923*5113495bSYour Name 
924*5113495bSYour Name /**
925*5113495bSYour Name  * sme_get_cfg_valid_channels() - To get valid channel list
926*5113495bSYour Name  * @valid_ch_freq: pointer to array which save the valid channel list
927*5113495bSYour Name  * @len: the length of the valid channel list
928*5113495bSYour Name  *
929*5113495bSYour Name  * Return: QDF status
930*5113495bSYour Name  */
931*5113495bSYour Name QDF_STATUS sme_get_cfg_valid_channels(uint32_t *valid_ch_freq, uint32_t *len);
932*5113495bSYour Name 
933*5113495bSYour Name #ifdef WLAN_FEATURE_PACKET_FILTERING
934*5113495bSYour Name QDF_STATUS sme_8023_multicast_list(mac_handle_t mac_handle, uint8_t sessionId,
935*5113495bSYour Name 		tpSirRcvFltMcAddrList pMulticastAddrs);
936*5113495bSYour Name #endif /* WLAN_FEATURE_PACKET_FILTERING */
937*5113495bSYour Name uint16_t sme_chn_to_freq(uint8_t chanNum);
938*5113495bSYour Name 
939*5113495bSYour Name /*
940*5113495bSYour Name  * sme_is_channel_valid() - validate a channel against current regdmn
941*5113495bSYour Name  * To check if the channel is valid for currently established domain
942*5113495bSYour Name  *   This is a synchronous API.
943*5113495bSYour Name  *
944*5113495bSYour Name  * mac_handle - The handle returned by mac_open.
945*5113495bSYour Name  * chan_freq - channel to verify
946*5113495bSYour Name  *
947*5113495bSYour Name  * Return: true/false, true if channel is valid
948*5113495bSYour Name  */
949*5113495bSYour Name bool sme_is_channel_valid(mac_handle_t mac_handle, uint32_t chan_freq);
950*5113495bSYour Name 
951*5113495bSYour Name QDF_STATUS sme_set_max_tx_power(mac_handle_t mac_handle,
952*5113495bSYour Name 				struct qdf_mac_addr pBssid,
953*5113495bSYour Name 				struct qdf_mac_addr pSelfMacAddress, int8_t dB);
954*5113495bSYour Name QDF_STATUS sme_set_max_tx_power_per_band(enum band_info band, int8_t db);
955*5113495bSYour Name QDF_STATUS sme_set_tx_power(mac_handle_t mac_handle, uint8_t sessionId,
956*5113495bSYour Name 		struct qdf_mac_addr bssid,
957*5113495bSYour Name 		enum QDF_OPMODE dev_mode, int power);
958*5113495bSYour Name QDF_STATUS sme_set_custom_mac_addr(tSirMacAddr customMacAddr);
959*5113495bSYour Name QDF_STATUS sme_hide_ssid(mac_handle_t mac_handle, uint8_t sessionId,
960*5113495bSYour Name 		uint8_t ssidHidden);
961*5113495bSYour Name 
962*5113495bSYour Name /**
963*5113495bSYour Name  * sme_set_listen_interval() - Set the listen interval
964*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
965*5113495bSYour Name  * @vdev_id: vdev identifier
966*5113495bSYour Name  *
967*5113495bSYour Name  * Return: None
968*5113495bSYour Name  */
969*5113495bSYour Name void sme_set_listen_interval(mac_handle_t mac_handle, uint8_t vdev_id);
970*5113495bSYour Name 
971*5113495bSYour Name /**
972*5113495bSYour Name  * sme_update_roam_scan_n_probes() - Update no.of roam scan probes
973*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
974*5113495bSYour Name  * @vdev_id: vdev identifier
975*5113495bSYour Name  * @probes: number of probe requests to be sent out
976*5113495bSYour Name  *
977*5113495bSYour Name  * Return: QDF_STATUS
978*5113495bSYour Name  */
979*5113495bSYour Name QDF_STATUS sme_update_roam_scan_n_probes(mac_handle_t mac_handle,
980*5113495bSYour Name 					 uint8_t vdev_id,
981*5113495bSYour Name 					 const uint8_t probes);
982*5113495bSYour Name 
983*5113495bSYour Name /**
984*5113495bSYour Name  * sme_update_roam_scan_home_away_time() - Update roam scan Home away time
985*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
986*5113495bSYour Name  * @vdev_id: vdev identifier
987*5113495bSYour Name  * @roam_scan_home_away_time: Scan home away time
988*5113495bSYour Name  * @send_offload_cmd: If it's true, the command is sent to firmware,
989*5113495bSYour Name  *		      otherwise the command is not sent to firmware
990*5113495bSYour Name  *
991*5113495bSYour Name  * Return: QDF_STATUS
992*5113495bSYour Name  */
993*5113495bSYour Name QDF_STATUS
994*5113495bSYour Name sme_update_roam_scan_home_away_time(mac_handle_t mac_handle, uint8_t vdev_id,
995*5113495bSYour Name 				    const uint16_t roam_scan_home_away_time,
996*5113495bSYour Name 				    const bool send_offload_cmd);
997*5113495bSYour Name 
998*5113495bSYour Name /**
999*5113495bSYour Name  * sme_get_roam_scan_n_probes() - get Roam scan number of probes
1000*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
1001*5113495bSYour Name  * @vdev_id: vdev identifier
1002*5113495bSYour Name  * @roam_scan_n_probes: Buffer to fill the number of probes.
1003*5113495bSYour Name  *			Valid only if the return status is success.
1004*5113495bSYour Name  *
1005*5113495bSYour Name  * Return: QDF_STATUS
1006*5113495bSYour Name  */
1007*5113495bSYour Name QDF_STATUS sme_get_roam_scan_n_probes(mac_handle_t mac_handle, uint8_t vdev_id,
1008*5113495bSYour Name 				      uint8_t *roam_scan_n_probes);
1009*5113495bSYour Name 
1010*5113495bSYour Name /**
1011*5113495bSYour Name  * sme_update_roam_rssi_diff() - Update RoamRssiDiff
1012*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
1013*5113495bSYour Name  * @vdev_id: vdev identifier
1014*5113495bSYour Name  * @roam_rssi_diff: Minimum rssi difference between potential candidate and
1015*5113495bSYour Name  *		    current AP.
1016*5113495bSYour Name  *
1017*5113495bSYour Name  * Return: QDF_STATUS
1018*5113495bSYour Name  */
1019*5113495bSYour Name QDF_STATUS sme_update_roam_rssi_diff(mac_handle_t mac_handle, uint8_t vdev_id,
1020*5113495bSYour Name 				     uint8_t roam_rssi_diff);
1021*5113495bSYour Name 
1022*5113495bSYour Name QDF_STATUS sme_update_wes_mode(mac_handle_t mac_handle, bool isWESModeEnabled,
1023*5113495bSYour Name 		uint8_t sessionId);
1024*5113495bSYour Name 
1025*5113495bSYour Name QDF_STATUS sme_update_is_fast_roam_ini_feature_enabled(mac_handle_t mac_handle,
1026*5113495bSYour Name 		uint8_t sessionId,
1027*5113495bSYour Name 		const bool
1028*5113495bSYour Name 		isFastRoamIniFeatureEnabled);
1029*5113495bSYour Name 
1030*5113495bSYour Name QDF_STATUS sme_stop_roaming(mac_handle_t mac_handle, uint8_t sessionId,
1031*5113495bSYour Name 			    uint8_t reason,
1032*5113495bSYour Name 			    enum wlan_cm_rso_control_requestor requestor);
1033*5113495bSYour Name 
1034*5113495bSYour Name QDF_STATUS sme_start_roaming(mac_handle_t mac_handle, uint8_t sessionId,
1035*5113495bSYour Name 			     uint8_t reason,
1036*5113495bSYour Name 			     enum wlan_cm_rso_control_requestor requestor);
1037*5113495bSYour Name 
1038*5113495bSYour Name /**
1039*5113495bSYour Name  * sme_roaming_in_progress() - check if roaming is in progress
1040*5113495bSYour Name  * @mac_handle - The handle returned by mac_open
1041*5113495bSYour Name  * @vdev_id: vdev id
1042*5113495bSYour Name  *
1043*5113495bSYour Name  * Return: true or false
1044*5113495bSYour Name  */
1045*5113495bSYour Name bool sme_roaming_in_progress(mac_handle_t mac_handle, uint8_t vdev_id);
1046*5113495bSYour Name 
1047*5113495bSYour Name #ifdef FEATURE_WLAN_ESE
1048*5113495bSYour Name QDF_STATUS sme_update_is_ese_feature_enabled(mac_handle_t mac_handle,
1049*5113495bSYour Name 					     uint8_t sessionId,
1050*5113495bSYour Name 					     const bool isEseIniFeatureEnabled);
1051*5113495bSYour Name #endif /* FEATURE_WLAN_ESE */
1052*5113495bSYour Name QDF_STATUS sme_set_roam_rescan_rssi_diff(mac_handle_t mac_handle,
1053*5113495bSYour Name 		uint8_t sessionId,
1054*5113495bSYour Name 		const uint8_t nRoamRescanRssiDiff);
1055*5113495bSYour Name 
1056*5113495bSYour Name QDF_STATUS sme_set_roam_opportunistic_scan_threshold_diff(
1057*5113495bSYour Name 		mac_handle_t mac_handle,
1058*5113495bSYour Name 		uint8_t sessionId,
1059*5113495bSYour Name 		const uint8_t nOpportunisticThresholdDiff);
1060*5113495bSYour Name 
1061*5113495bSYour Name /**
1062*5113495bSYour Name  * sme_set_neighbor_lookup_rssi_threshold() - update neighbor lookup rssi thr
1063*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
1064*5113495bSYour Name  * @vdev_id: vdev identifier
1065*5113495bSYour Name  * @neighbor_lookup_rssi_threshold: Neighbor lookup rssi threshold
1066*5113495bSYour Name  *
1067*5113495bSYour Name  * Return: QDF_STATUS
1068*5113495bSYour Name  */
1069*5113495bSYour Name QDF_STATUS
1070*5113495bSYour Name sme_set_neighbor_lookup_rssi_threshold(mac_handle_t mac_handle,
1071*5113495bSYour Name 				       uint8_t vdev_id,
1072*5113495bSYour Name 				       uint8_t neighbor_lookup_rssi_threshold);
1073*5113495bSYour Name 
1074*5113495bSYour Name QDF_STATUS sme_set_neighbor_scan_refresh_period(mac_handle_t mac_handle,
1075*5113495bSYour Name 		uint8_t sessionId, uint16_t neighborScanResultsRefreshPeriod);
1076*5113495bSYour Name 
1077*5113495bSYour Name QDF_STATUS sme_update_empty_scan_refresh_period(mac_handle_t mac_handle,
1078*5113495bSYour Name 		uint8_t sessionId, uint16_t empty_scan_refresh_period);
1079*5113495bSYour Name /**
1080*5113495bSYour Name  * sme_update_full_roam_scan_period() - Send full roam scan period to SME
1081*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1082*5113495bSYour Name  * @vdev_id: vdev id
1083*5113495bSYour Name  * @full_roam_scan_period: Idle period in seconds between two successive
1084*5113495bSYour Name  * full channel roam scans
1085*5113495bSYour Name  *
1086*5113495bSYour Name  * Updated full scan period in roam info and a roam_offload_scan request.
1087*5113495bSYour Name  *
1088*5113495bSYour Name  * Return: QDF_STATUS
1089*5113495bSYour Name  */
1090*5113495bSYour Name QDF_STATUS sme_update_full_roam_scan_period(mac_handle_t mac_handle,
1091*5113495bSYour Name 					    uint8_t vdev_id,
1092*5113495bSYour Name 					    uint32_t full_roam_scan_period);
1093*5113495bSYour Name 
1094*5113495bSYour Name /**
1095*5113495bSYour Name  * sme_modify_roam_cand_sel_criteria() - Modify candidate selection criteria
1096*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
1097*5113495bSYour Name  * @vdev_id: vdev Identifier
1098*5113495bSYour Name  * @enable_scoring_for_roam: Carries enable/disable indication
1099*5113495bSYour Name  *
1100*5113495bSYour Name  * Enable/disable scoring for roam candidate selection based on the value of
1101*5113495bSYour Name  * enable_scoring_for_roam. Below is the description of enable/disable,
1102*5113495bSYour Name  * Disable-0: Disable scoring for roam candidate selection. Roaming
1103*5113495bSYour Name  *	      shall fallback to legacy selection criteria, only RSSI.
1104*5113495bSYour Name  * Enable-1 : Enable scoring for roam candidate selection.
1105*5113495bSYour Name  *
1106*5113495bSYour Name  * Return: Success or failure
1107*5113495bSYour Name  */
1108*5113495bSYour Name QDF_STATUS
1109*5113495bSYour Name sme_modify_roam_cand_sel_criteria(mac_handle_t mac_handle,
1110*5113495bSYour Name 				  uint8_t vdev_id,
1111*5113495bSYour Name 				  bool enable_scoring_for_roam);
1112*5113495bSYour Name 
1113*5113495bSYour Name /**
1114*5113495bSYour Name  * sme_roam_control_restore_default_config - Restore roam config to default
1115*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
1116*5113495bSYour Name  * @vdev_id: vdev Identifier
1117*5113495bSYour Name  *
1118*5113495bSYour Name  * Restore enable_scoring_for_roam, emptyScanRefreshPeriod,
1119*5113495bSYour Name  * full_roam_scan_period to their default values and send RSO command to
1120*5113495bSYour Name  * firmware with the updated values.
1121*5113495bSYour Name  *
1122*5113495bSYour Name  * Return: Success or failure
1123*5113495bSYour Name  */
1124*5113495bSYour Name QDF_STATUS sme_roam_control_restore_default_config(mac_handle_t mac_handle,
1125*5113495bSYour Name 						   uint8_t vdev_id);
1126*5113495bSYour Name 
1127*5113495bSYour Name QDF_STATUS sme_set_neighbor_scan_min_chan_time(mac_handle_t mac_handle,
1128*5113495bSYour Name 		const uint16_t nNeighborScanMinChanTime,
1129*5113495bSYour Name 		uint8_t sessionId);
1130*5113495bSYour Name QDF_STATUS sme_set_neighbor_scan_max_chan_time(mac_handle_t mac_handle,
1131*5113495bSYour Name 				uint8_t sessionId,
1132*5113495bSYour Name 				const uint16_t nNeighborScanMaxChanTime);
1133*5113495bSYour Name uint32_t sme_get_current_roam_state(mac_handle_t mac_handle, uint8_t sessionId);
1134*5113495bSYour Name uint32_t sme_get_current_roam_sub_state(mac_handle_t mac_handle,
1135*5113495bSYour Name 					uint8_t sessionId);
1136*5113495bSYour Name uint32_t sme_get_lim_sme_state(mac_handle_t mac_handle);
1137*5113495bSYour Name uint32_t sme_get_lim_mlm_state(mac_handle_t mac_handle);
1138*5113495bSYour Name bool sme_is_lim_session_valid(mac_handle_t mac_handle, uint8_t sessionId);
1139*5113495bSYour Name uint32_t sme_get_lim_sme_session_state(mac_handle_t mac_handle,
1140*5113495bSYour Name 				       uint8_t sessionId);
1141*5113495bSYour Name uint32_t sme_get_lim_mlm_session_state(mac_handle_t mac_handle,
1142*5113495bSYour Name 				       uint8_t sessionId);
1143*5113495bSYour Name QDF_STATUS sme_set_neighbor_scan_period(mac_handle_t mac_handle,
1144*5113495bSYour Name 		uint8_t sessionId,
1145*5113495bSYour Name 		const uint16_t nNeighborScanPeriod);
1146*5113495bSYour Name QDF_STATUS sme_set_roam_bmiss_first_bcnt(mac_handle_t mac_handle,
1147*5113495bSYour Name 		uint8_t sessionId, const uint8_t nRoamBmissFirstBcnt);
1148*5113495bSYour Name QDF_STATUS sme_set_roam_bmiss_final_bcnt(mac_handle_t mac_handle,
1149*5113495bSYour Name 					 uint8_t sessionId,
1150*5113495bSYour Name 					 const uint8_t nRoamBmissFinalBcnt);
1151*5113495bSYour Name QDF_STATUS sme_change_roam_scan_channel_list(mac_handle_t mac_handle,
1152*5113495bSYour Name 					     uint8_t sessionId,
1153*5113495bSYour Name 					     uint32_t *channel_freq_list,
1154*5113495bSYour Name 					     uint8_t numChannels);
1155*5113495bSYour Name 
1156*5113495bSYour Name /**
1157*5113495bSYour Name  * sme_update_roam_scan_freq_list() - Update roam scan freq list
1158*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
1159*5113495bSYour Name  * @vdev_id: vdev identifier
1160*5113495bSYour Name  * @freq_list: List of frequencies to be configured
1161*5113495bSYour Name  * @num_channels: Number of frequencies to be configured
1162*5113495bSYour Name  * @freq_list_type: Type of frequency list to be configured to
1163*5113495bSYour Name  *
1164*5113495bSYour Name  * Update the frequencies from freq_list to the corresponding channel list
1165*5113495bSYour Name  * in neighborRoamInfo
1166*5113495bSYour Name  *
1167*5113495bSYour Name  * Return: QDF_STATUS
1168*5113495bSYour Name  */
1169*5113495bSYour Name QDF_STATUS
1170*5113495bSYour Name sme_update_roam_scan_freq_list(mac_handle_t mac_handle, uint8_t vdev_id,
1171*5113495bSYour Name 			       uint32_t *freq_list, uint8_t num_chan,
1172*5113495bSYour Name 			       uint32_t freq_list_type);
1173*5113495bSYour Name QDF_STATUS sme_get_roam_scan_channel_list(mac_handle_t mac_handle,
1174*5113495bSYour Name 					  uint32_t *freq_list,
1175*5113495bSYour Name 					  uint8_t *pNumChannels,
1176*5113495bSYour Name 					  uint8_t sessionId);
1177*5113495bSYour Name 
1178*5113495bSYour Name bool sme_is_feature_supported_by_fw(enum cap_bitmap feature);
1179*5113495bSYour Name 
1180*5113495bSYour Name QDF_STATUS sme_set_phy_mode(mac_handle_t mac_handle, eCsrPhyMode phyMode);
1181*5113495bSYour Name eCsrPhyMode sme_get_phy_mode(mac_handle_t mac_handle);
1182*5113495bSYour Name uint32_t sme_get_11b_data_duration(mac_handle_t mac_handle,
1183*5113495bSYour Name 				   uint32_t chan_freq);
1184*5113495bSYour Name 
1185*5113495bSYour Name QDF_STATUS sme_add_periodic_tx_ptrn(mac_handle_t mac_handle,
1186*5113495bSYour Name 		tSirAddPeriodicTxPtrn *addPeriodicTxPtrnParams);
1187*5113495bSYour Name QDF_STATUS sme_del_periodic_tx_ptrn(mac_handle_t mac_handle,
1188*5113495bSYour Name 		tSirDelPeriodicTxPtrn *delPeriodicTxPtrnParams);
1189*5113495bSYour Name QDF_STATUS sme_send_rate_update_ind(mac_handle_t mac_handle,
1190*5113495bSYour Name 		tSirRateUpdateInd *rateUpdateParams);
1191*5113495bSYour Name void sme_get_command_q_status(mac_handle_t mac_handle);
1192*5113495bSYour Name 
1193*5113495bSYour Name /**
1194*5113495bSYour Name  * sme_set_wlm_latency_level() - Used to set the latency level to fw
1195*5113495bSYour Name  * @mac_handle: mac handle
1196*5113495bSYour Name  * @vdev_id: vdev id
1197*5113495bSYour Name  * @latency_level: latency level to be set in FW
1198*5113495bSYour Name  * @client_id_bitmap: client id bitmap
1199*5113495bSYour Name  * @force_reset: flag to reset latency level
1200*5113495bSYour Name  *
1201*5113495bSYour Name  * Return QDF_STATUS
1202*5113495bSYour Name  */
1203*5113495bSYour Name QDF_STATUS sme_set_wlm_latency_level(mac_handle_t mac_handle,
1204*5113495bSYour Name 				uint16_t vdev_id, uint16_t latency_level,
1205*5113495bSYour Name 				uint32_t client_id_bitmap,
1206*5113495bSYour Name 				bool force_reset);
1207*5113495bSYour Name 
1208*5113495bSYour Name /*
1209*5113495bSYour Name  * SME API to enable/disable idle mode powersave
1210*5113495bSYour Name  * This should be called only if powersave offload
1211*5113495bSYour Name  * is enabled
1212*5113495bSYour Name  */
1213*5113495bSYour Name QDF_STATUS sme_set_idle_powersave_config(bool value);
1214*5113495bSYour Name QDF_STATUS sme_notify_modem_power_state(mac_handle_t mac_handle,
1215*5113495bSYour Name 					uint32_t value);
1216*5113495bSYour Name 
1217*5113495bSYour Name /**
1218*5113495bSYour Name  * sme_set_peer_ampdu() - API to set peer A-MPDU count to target
1219*5113495bSYour Name  * @mac_handle: mac handle
1220*5113495bSYour Name  * @vdev_id: vdev id
1221*5113495bSYour Name  * @peer_mac: peer mac address
1222*5113495bSYour Name  * @cfg: A-MPDU count to configure
1223*5113495bSYour Name  *
1224*5113495bSYour Name  * Return: 0 if success, otherwise error code
1225*5113495bSYour Name  */
1226*5113495bSYour Name int sme_set_peer_ampdu(mac_handle_t mac_handle, uint8_t vdev_id,
1227*5113495bSYour Name 		       struct qdf_mac_addr *peer_mac, uint16_t cfg);
1228*5113495bSYour Name 
1229*5113495bSYour Name /*SME API to convert convert the ini value to the ENUM used in csr and MAC*/
1230*5113495bSYour Name ePhyChanBondState sme_get_cb_phy_state_from_cb_ini_value(uint32_t cb_ini_value);
1231*5113495bSYour Name int sme_update_ht_config(mac_handle_t mac_handle, uint8_t sessionId,
1232*5113495bSYour Name 			 uint16_t htCapab,
1233*5113495bSYour Name 			 int value);
1234*5113495bSYour Name int16_t sme_get_ht_config(mac_handle_t mac_handle, uint8_t session_id,
1235*5113495bSYour Name 			  uint16_t ht_capab);
1236*5113495bSYour Name #ifdef QCA_HT_2040_COEX
1237*5113495bSYour Name QDF_STATUS sme_notify_ht2040_mode(mac_handle_t mac_handle,
1238*5113495bSYour Name 				  struct qdf_mac_addr macAddrSTA,
1239*5113495bSYour Name 				  uint8_t sessionId,
1240*5113495bSYour Name 				  uint8_t channel_type);
1241*5113495bSYour Name QDF_STATUS sme_set_ht2040_mode(mac_handle_t mac_handle, uint8_t sessionId,
1242*5113495bSYour Name 			       uint8_t channel_type, bool obssEnabled);
1243*5113495bSYour Name 
1244*5113495bSYour Name /**
1245*5113495bSYour Name  * sme_get_ht2040_mode() - get ht operation mode
1246*5113495bSYour Name  * @mac_handle: pointer to mac context
1247*5113495bSYour Name  * @vdev_id: vdev id
1248*5113495bSYour Name  * @channel_type: channel type to provide
1249*5113495bSYour Name  *
1250*5113495bSYour Name  * Return QDF_STATUS
1251*5113495bSYour Name  */
1252*5113495bSYour Name QDF_STATUS sme_get_ht2040_mode(mac_handle_t mac_handle, uint8_t vdev_id,
1253*5113495bSYour Name 			       enum eSirMacHTChannelType *channel_type);
1254*5113495bSYour Name #endif
1255*5113495bSYour Name 
1256*5113495bSYour Name /**
1257*5113495bSYour Name  * sme_get_reg_info() - To get tx power information
1258*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
1259*5113495bSYour Name  * @chan_freq: channel freq
1260*5113495bSYour Name  * @regInfo1: first reg info to fill
1261*5113495bSYour Name  * @regInfo2: second reg info to fill
1262*5113495bSYour Name  *
1263*5113495bSYour Name  * This routine will give you tx power information
1264*5113495bSYour Name  *
1265*5113495bSYour Name  * Return: QDF_STATUS
1266*5113495bSYour Name  */
1267*5113495bSYour Name QDF_STATUS sme_get_reg_info(mac_handle_t mac_handle, uint32_t chan_freq,
1268*5113495bSYour Name 			    uint32_t *regInfo1, uint32_t *regInfo2);
1269*5113495bSYour Name 
1270*5113495bSYour Name #ifdef FEATURE_WLAN_CH_AVOID
1271*5113495bSYour Name QDF_STATUS sme_ch_avoid_update_req(mac_handle_t mac_handle);
1272*5113495bSYour Name #else
1273*5113495bSYour Name static inline
sme_ch_avoid_update_req(mac_handle_t mac_handle)1274*5113495bSYour Name QDF_STATUS sme_ch_avoid_update_req(mac_handle_t mac_handle)
1275*5113495bSYour Name {
1276*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
1277*5113495bSYour Name }
1278*5113495bSYour Name #endif
1279*5113495bSYour Name #ifdef FEATURE_WLAN_AUTO_SHUTDOWN
1280*5113495bSYour Name /**
1281*5113495bSYour Name  * sme_set_auto_shutdown_cb() - Register auto shutdown evt handler
1282*5113495bSYour Name  * @mac_handle: Handle to the global MAC context
1283*5113495bSYour Name  * @callback_fn: callback function to be invoked when an auto shutdown
1284*5113495bSYour Name  *               event is received
1285*5113495bSYour Name  *
1286*5113495bSYour Name  * Return: QDF_STATUS
1287*5113495bSYour Name  */
1288*5113495bSYour Name QDF_STATUS sme_set_auto_shutdown_cb(mac_handle_t mac_handle,
1289*5113495bSYour Name 				    void (*callback_fn)(void));
1290*5113495bSYour Name 
1291*5113495bSYour Name QDF_STATUS sme_set_auto_shutdown_timer(mac_handle_t mac_handle,
1292*5113495bSYour Name 				       uint32_t timer_value);
1293*5113495bSYour Name #endif
1294*5113495bSYour Name 
1295*5113495bSYour Name QDF_STATUS sme_roam_start_beacon_req(mac_handle_t mac_handle,
1296*5113495bSYour Name 				     struct qdf_mac_addr bssid,
1297*5113495bSYour Name 				     uint8_t dfsCacWaitStatus);
1298*5113495bSYour Name 
1299*5113495bSYour Name QDF_STATUS sme_csa_restart(struct mac_context *mac_ctx, uint8_t session_id);
1300*5113495bSYour Name 
1301*5113495bSYour Name /**
1302*5113495bSYour Name  * sme_roam_csa_ie_request() - request CSA IE transmission from PE
1303*5113495bSYour Name  * @mac_handle: handle returned by mac_open
1304*5113495bSYour Name  * @bssid: SAP bssid
1305*5113495bSYour Name  * @target_chan_freq: target channel frequency information
1306*5113495bSYour Name  * @csaIeReqd: CSA IE Request
1307*5113495bSYour Name  * @ch_params: channel information
1308*5113495bSYour Name  * @new_cac_ms: cac duration of new channel
1309*5113495bSYour Name  *
1310*5113495bSYour Name  * Return: QDF_STATUS
1311*5113495bSYour Name  */
1312*5113495bSYour Name QDF_STATUS sme_roam_csa_ie_request(mac_handle_t mac_handle,
1313*5113495bSYour Name 				   struct qdf_mac_addr bssid,
1314*5113495bSYour Name 				   uint32_t target_chan_freq, uint8_t csaIeReqd,
1315*5113495bSYour Name 				   struct ch_params *ch_params,
1316*5113495bSYour Name 				   uint32_t new_cac_ms);
1317*5113495bSYour Name 
1318*5113495bSYour Name /**
1319*5113495bSYour Name  * sme_set_addba_accept() - Allow/Reject the ADDBA req session
1320*5113495bSYour Name  * @mac_handle: handle returned by mac_open
1321*5113495bSYour Name  * @session_id: sme session id
1322*5113495bSYour Name  * @value: Allow/Reject AddBA session
1323*5113495bSYour Name  *
1324*5113495bSYour Name  * Allows/Rejects the ADDBA req session
1325*5113495bSYour Name  *
1326*5113495bSYour Name  * Return: 0 on success else errno
1327*5113495bSYour Name  */
1328*5113495bSYour Name int sme_set_addba_accept(mac_handle_t mac_handle, uint8_t session_id,
1329*5113495bSYour Name 			 int value);
1330*5113495bSYour Name 
1331*5113495bSYour Name QDF_STATUS sme_init_thermal_info(mac_handle_t mac_handle);
1332*5113495bSYour Name 
1333*5113495bSYour Name QDF_STATUS sme_set_thermal_level(mac_handle_t mac_handle, uint8_t level);
1334*5113495bSYour Name QDF_STATUS sme_txpower_limit(mac_handle_t mac_handle,
1335*5113495bSYour Name 			     struct tx_power_limit *psmetx);
1336*5113495bSYour Name 
1337*5113495bSYour Name /**
1338*5113495bSYour Name  * sme_get_link_speed() - Retrieve current link speed
1339*5113495bSYour Name  * @mac_handle: Global MAC handle
1340*5113495bSYour Name  * @req: Link speed request structure
1341*5113495bSYour Name  * @context: User context to be passed back when invoking @cb
1342*5113495bSYour Name  * @cb: Callback function to be invoked with link speed results
1343*5113495bSYour Name  *
1344*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS if the request was accepted, otherwise
1345*5113495bSYour Name  * an appropriate error status.
1346*5113495bSYour Name  */
1347*5113495bSYour Name QDF_STATUS sme_get_link_speed(mac_handle_t mac_handle,
1348*5113495bSYour Name 			      struct link_speed_info *req,
1349*5113495bSYour Name 			      void *context,
1350*5113495bSYour Name 			      sme_link_speed_cb cb);
1351*5113495bSYour Name 
1352*5113495bSYour Name QDF_STATUS sme_modify_add_ie(mac_handle_t mac_handle,
1353*5113495bSYour Name 		tSirModifyIE *pModifyIE, eUpdateIEsType updateType);
1354*5113495bSYour Name QDF_STATUS sme_update_add_ie(mac_handle_t mac_handle,
1355*5113495bSYour Name 		tSirUpdateIE *pUpdateIE, eUpdateIEsType updateType);
1356*5113495bSYour Name QDF_STATUS sme_update_connect_debug(mac_handle_t mac_handle,
1357*5113495bSYour Name 				    uint32_t set_value);
1358*5113495bSYour Name 
1359*5113495bSYour Name /**
1360*5113495bSYour Name  * sme_bss_type_to_string() - converts bss type to string.
1361*5113495bSYour Name  * @bss_type: bss type enum
1362*5113495bSYour Name  *
1363*5113495bSYour Name  * Return: printable string for bss type
1364*5113495bSYour Name  */
1365*5113495bSYour Name const char *sme_bss_type_to_string(const uint8_t bss_type);
1366*5113495bSYour Name QDF_STATUS sme_ap_disable_intra_bss_fwd(mac_handle_t mac_handle,
1367*5113495bSYour Name 					uint8_t sessionId,
1368*5113495bSYour Name 					bool disablefwd);
1369*5113495bSYour Name 
1370*5113495bSYour Name /**
1371*5113495bSYour Name  * sme_send_unit_test_cmd() - send unit test command to lower layer
1372*5113495bSYour Name  * @session_id: sme session id to be filled while forming the command
1373*5113495bSYour Name  * @module_id: module id given by user to be filled in the command
1374*5113495bSYour Name  * @arg_count: number of argument count
1375*5113495bSYour Name  * @arg: pointer to argument list
1376*5113495bSYour Name  *
1377*5113495bSYour Name  * This API exposed to HDD layer which takes the argument from user and sends
1378*5113495bSYour Name  * down to lower layer for further processing
1379*5113495bSYour Name  *
1380*5113495bSYour Name  * Return: QDF_STATUS based on overall success
1381*5113495bSYour Name  */
1382*5113495bSYour Name QDF_STATUS sme_send_unit_test_cmd(uint32_t vdev_id, uint32_t module_id,
1383*5113495bSYour Name 				  uint32_t arg_count, uint32_t *arg);
1384*5113495bSYour Name 
1385*5113495bSYour Name typedef struct sStatsExtRequestReq {
1386*5113495bSYour Name 	uint32_t request_data_len;
1387*5113495bSYour Name 	uint8_t *request_data;
1388*5113495bSYour Name } tStatsExtRequestReq, *tpStatsExtRequestReq;
1389*5113495bSYour Name 
1390*5113495bSYour Name #ifdef WLAN_FEATURE_STATS_EXT
1391*5113495bSYour Name /**
1392*5113495bSYour Name  * sme_stats_ext_register_callback() - Register stats ext callback
1393*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1394*5113495bSYour Name  * @callback: Function to be invoked for stats ext events
1395*5113495bSYour Name  *
1396*5113495bSYour Name  * This function is called to register the callback that send vendor
1397*5113495bSYour Name  * event for stats ext
1398*5113495bSYour Name  */
1399*5113495bSYour Name void sme_stats_ext_register_callback(mac_handle_t mac_handle,
1400*5113495bSYour Name 				     stats_ext_cb callback);
1401*5113495bSYour Name 
1402*5113495bSYour Name /**
1403*5113495bSYour Name  * sme_stats_ext_deregister_callback() - Deregister stats ext callback
1404*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1405*5113495bSYour Name  *
1406*5113495bSYour Name  * This function is called to deregister the callback that send vendor
1407*5113495bSYour Name  * event for stats ext
1408*5113495bSYour Name  */
1409*5113495bSYour Name void sme_stats_ext_deregister_callback(mac_handle_t mac_handle);
1410*5113495bSYour Name 
1411*5113495bSYour Name /**
1412*5113495bSYour Name  * sme_stats_ext2_register_callback() - Register stats ext2 callback
1413*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1414*5113495bSYour Name  * @callback: Function to be invoked for stats ext2 events
1415*5113495bSYour Name  *
1416*5113495bSYour Name  * This function will register a callback for frame aggregation failure
1417*5113495bSYour Name  * indications processing.
1418*5113495bSYour Name  *
1419*5113495bSYour Name  * Return: void
1420*5113495bSYour Name  */
1421*5113495bSYour Name void sme_stats_ext2_register_callback(mac_handle_t mac_handle,
1422*5113495bSYour Name 				      stats_ext2_cb callback);
1423*5113495bSYour Name 
1424*5113495bSYour Name QDF_STATUS sme_stats_ext_request(uint8_t session_id,
1425*5113495bSYour Name 				 tpStatsExtRequestReq input);
1426*5113495bSYour Name #else
1427*5113495bSYour Name static inline void
sme_stats_ext_register_callback(mac_handle_t mac_handle,stats_ext_cb callback)1428*5113495bSYour Name sme_stats_ext_register_callback(mac_handle_t mac_handle,
1429*5113495bSYour Name 				stats_ext_cb callback)
1430*5113495bSYour Name {
1431*5113495bSYour Name }
1432*5113495bSYour Name 
1433*5113495bSYour Name static inline void
sme_stats_ext_deregister_callback(mac_handle_t mac_handle)1434*5113495bSYour Name sme_stats_ext_deregister_callback(mac_handle_t mac_handle)
1435*5113495bSYour Name {
1436*5113495bSYour Name }
1437*5113495bSYour Name 
1438*5113495bSYour Name static inline void
sme_stats_ext2_register_callback(mac_handle_t mac_handle,stats_ext2_cb callback)1439*5113495bSYour Name sme_stats_ext2_register_callback(mac_handle_t mac_handle,
1440*5113495bSYour Name 				 stats_ext2_cb callback)
1441*5113495bSYour Name {
1442*5113495bSYour Name }
1443*5113495bSYour Name #endif /* WLAN_FEATURE_STATS_EXT */
1444*5113495bSYour Name QDF_STATUS sme_update_dfs_scan_mode(mac_handle_t mac_handle,
1445*5113495bSYour Name 		uint8_t sessionId,
1446*5113495bSYour Name 		uint8_t allowDFSChannelRoam);
1447*5113495bSYour Name uint8_t sme_get_dfs_scan_mode(mac_handle_t mac_handle);
1448*5113495bSYour Name 
1449*5113495bSYour Name /**
1450*5113495bSYour Name  * sme_get_valid_channels_by_band() - to fetch valid channels filtered by band
1451*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
1452*5113495bSYour Name  * @wifi_band: RF band information
1453*5113495bSYour Name  * @valid_chan_list: output array to store channel info
1454*5113495bSYour Name  * @valid_chan_len: output number of channels
1455*5113495bSYour Name  *
1456*5113495bSYour Name  *  SME API to fetch all valid channels filtered by band
1457*5113495bSYour Name  *
1458*5113495bSYour Name  *  Return: QDF_STATUS
1459*5113495bSYour Name  */
1460*5113495bSYour Name QDF_STATUS sme_get_valid_channels_by_band(mac_handle_t mac_handle,
1461*5113495bSYour Name 					  uint8_t wifi_band,
1462*5113495bSYour Name 					  uint32_t *valid_chan_list,
1463*5113495bSYour Name 					  uint8_t *valid_chan_len);
1464*5113495bSYour Name 
1465*5113495bSYour Name #ifdef FEATURE_WLAN_EXTSCAN
1466*5113495bSYour Name /**
1467*5113495bSYour Name  * sme_ext_scan_get_capabilities() - SME API to fetch extscan capabilities
1468*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1469*5113495bSYour Name  * @params: extscan capabilities request structure
1470*5113495bSYour Name  *
1471*5113495bSYour Name  * Return: QDF_STATUS
1472*5113495bSYour Name  */
1473*5113495bSYour Name QDF_STATUS
1474*5113495bSYour Name sme_ext_scan_get_capabilities(mac_handle_t mac_handle,
1475*5113495bSYour Name 			      struct extscan_capabilities_params *params);
1476*5113495bSYour Name 
1477*5113495bSYour Name /**
1478*5113495bSYour Name  * sme_ext_scan_start() - SME API to issue extscan start
1479*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1480*5113495bSYour Name  * @params: extscan start structure
1481*5113495bSYour Name  *
1482*5113495bSYour Name  * Return: QDF_STATUS
1483*5113495bSYour Name  */
1484*5113495bSYour Name QDF_STATUS
1485*5113495bSYour Name sme_ext_scan_start(mac_handle_t mac_handle,
1486*5113495bSYour Name 		   struct wifi_scan_cmd_req_params *params);
1487*5113495bSYour Name 
1488*5113495bSYour Name /**
1489*5113495bSYour Name  * sme_ext_scan_stop() - SME API to issue extscan stop
1490*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1491*5113495bSYour Name  * @params: extscan stop structure
1492*5113495bSYour Name  *
1493*5113495bSYour Name  * Return: QDF_STATUS
1494*5113495bSYour Name  */
1495*5113495bSYour Name QDF_STATUS sme_ext_scan_stop(mac_handle_t mac_handle,
1496*5113495bSYour Name 			     struct extscan_stop_req_params *params);
1497*5113495bSYour Name 
1498*5113495bSYour Name /**
1499*5113495bSYour Name  * sme_set_bss_hotlist() - SME API to set BSSID hotlist
1500*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1501*5113495bSYour Name  * @params: extscan set hotlist structure
1502*5113495bSYour Name  *
1503*5113495bSYour Name  * Handles the request to set the BSSID hotlist in firmware.
1504*5113495bSYour Name  *
1505*5113495bSYour Name  * Return: QDF_STATUS
1506*5113495bSYour Name  */
1507*5113495bSYour Name QDF_STATUS
1508*5113495bSYour Name sme_set_bss_hotlist(mac_handle_t mac_handle,
1509*5113495bSYour Name 		    struct extscan_bssid_hotlist_set_params *params);
1510*5113495bSYour Name 
1511*5113495bSYour Name /**
1512*5113495bSYour Name  * sme_reset_bss_hotlist() - SME API to reset BSSID hotlist
1513*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1514*5113495bSYour Name  * @params: extscan reset hotlist structure
1515*5113495bSYour Name  *
1516*5113495bSYour Name  * Handles the request to reset the BSSID hotlist in firmware.
1517*5113495bSYour Name  *
1518*5113495bSYour Name  * Return: QDF_STATUS
1519*5113495bSYour Name  */
1520*5113495bSYour Name QDF_STATUS
1521*5113495bSYour Name sme_reset_bss_hotlist(mac_handle_t mac_handle,
1522*5113495bSYour Name 		      struct extscan_bssid_hotlist_reset_params *params);
1523*5113495bSYour Name 
1524*5113495bSYour Name /**
1525*5113495bSYour Name  * sme_set_significant_change() - SME API to set significant change
1526*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1527*5113495bSYour Name  * @params: extscan set significant change structure
1528*5113495bSYour Name  *
1529*5113495bSYour Name  * Return: QDF_STATUS
1530*5113495bSYour Name  */
1531*5113495bSYour Name QDF_STATUS
1532*5113495bSYour Name sme_set_significant_change(mac_handle_t mac_handle,
1533*5113495bSYour Name 			   struct extscan_set_sig_changereq_params *params);
1534*5113495bSYour Name 
1535*5113495bSYour Name /**
1536*5113495bSYour Name  * sme_reset_significant_change() -  SME API to reset significant change
1537*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1538*5113495bSYour Name  * @params: extscan reset significant change structure
1539*5113495bSYour Name  *
1540*5113495bSYour Name  * Return: QDF_STATUS
1541*5113495bSYour Name  */
1542*5113495bSYour Name QDF_STATUS
1543*5113495bSYour Name sme_reset_significant_change(mac_handle_t mac_handle,
1544*5113495bSYour Name 			     struct extscan_capabilities_reset_params *params);
1545*5113495bSYour Name 
1546*5113495bSYour Name /**
1547*5113495bSYour Name  * sme_get_cached_results() - SME API to get cached results
1548*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1549*5113495bSYour Name  * @params: extscan get cached results structure
1550*5113495bSYour Name  *
1551*5113495bSYour Name  * Return: QDF_STATUS
1552*5113495bSYour Name  */
1553*5113495bSYour Name QDF_STATUS
1554*5113495bSYour Name sme_get_cached_results(mac_handle_t mac_handle,
1555*5113495bSYour Name 		       struct extscan_cached_result_params *params);
1556*5113495bSYour Name 
1557*5113495bSYour Name /**
1558*5113495bSYour Name  * sme_set_epno_list() - set epno network list
1559*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1560*5113495bSYour Name  * @params: request message
1561*5113495bSYour Name  *
1562*5113495bSYour Name  * This function sends an Enhanced PNO configuration to firmware.
1563*5113495bSYour Name  *
1564*5113495bSYour Name  * Return: QDF_STATUS enumeration
1565*5113495bSYour Name  */
1566*5113495bSYour Name QDF_STATUS sme_set_epno_list(mac_handle_t mac_handle,
1567*5113495bSYour Name 			     struct wifi_enhanced_pno_params *params);
1568*5113495bSYour Name 
1569*5113495bSYour Name /**
1570*5113495bSYour Name  * sme_set_passpoint_list() - set passpoint network list
1571*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1572*5113495bSYour Name  * @params: set passpoint list request parameters
1573*5113495bSYour Name  *
1574*5113495bSYour Name  * This function constructs the cds message and fill in message type,
1575*5113495bSYour Name  * bodyptr with @params and posts it to WDA queue.
1576*5113495bSYour Name  *
1577*5113495bSYour Name  * Return: QDF_STATUS enumeration
1578*5113495bSYour Name  */
1579*5113495bSYour Name QDF_STATUS sme_set_passpoint_list(mac_handle_t mac_handle,
1580*5113495bSYour Name 				  struct wifi_passpoint_req_param *params);
1581*5113495bSYour Name 
1582*5113495bSYour Name /**
1583*5113495bSYour Name  * sme_reset_passpoint_list() - reset passpoint network list
1584*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
1585*5113495bSYour Name  * @params: reset passpoint list request parameters
1586*5113495bSYour Name  *
1587*5113495bSYour Name  * Return: QDF_STATUS enumeration
1588*5113495bSYour Name  */
1589*5113495bSYour Name QDF_STATUS sme_reset_passpoint_list(mac_handle_t mac_handle,
1590*5113495bSYour Name 				    struct wifi_passpoint_req_param *params);
1591*5113495bSYour Name 
1592*5113495bSYour Name QDF_STATUS sme_ext_scan_register_callback(mac_handle_t mac_handle,
1593*5113495bSYour Name 					  ext_scan_ind_cb ext_scan_ind_cb);
1594*5113495bSYour Name #else
1595*5113495bSYour Name static inline
sme_ext_scan_register_callback(mac_handle_t mac_handle,ext_scan_ind_cb ext_scan_ind_cb)1596*5113495bSYour Name QDF_STATUS sme_ext_scan_register_callback(mac_handle_t mac_handle,
1597*5113495bSYour Name 					  ext_scan_ind_cb ext_scan_ind_cb)
1598*5113495bSYour Name {
1599*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
1600*5113495bSYour Name }
1601*5113495bSYour Name #endif /* FEATURE_WLAN_EXTSCAN */
1602*5113495bSYour Name 
1603*5113495bSYour Name /**
1604*5113495bSYour Name  * sme_get_vht_ch_width() - SME API to get the max supported FW chan width
1605*5113495bSYour Name  *
1606*5113495bSYour Name  * Return: Max channel width supported by FW (eg. 20, 40, 80, 160, 80+80)
1607*5113495bSYour Name  */
1608*5113495bSYour Name uint32_t sme_get_vht_ch_width(void);
1609*5113495bSYour Name 
1610*5113495bSYour Name #ifdef WLAN_FEATURE_LINK_LAYER_STATS
1611*5113495bSYour Name QDF_STATUS sme_ll_stats_clear_req(mac_handle_t mac_handle,
1612*5113495bSYour Name 		tSirLLStatsClearReq * pclearStatsReq);
1613*5113495bSYour Name QDF_STATUS sme_ll_stats_set_req(mac_handle_t mac_handle,
1614*5113495bSYour Name 		tSirLLStatsSetReq *psetStatsReq);
1615*5113495bSYour Name 
1616*5113495bSYour Name /**
1617*5113495bSYour Name  * sme_ll_stats_get_req() - SME API to get the Link Layer Statistics
1618*5113495bSYour Name  * @mac_handle: Global MAC handle
1619*5113495bSYour Name  * @get_stats_req: Link Layer get stats request params structure
1620*5113495bSYour Name  * @context: Callback context
1621*5113495bSYour Name  *
1622*5113495bSYour Name  * Return: QDF_STATUS
1623*5113495bSYour Name  */
1624*5113495bSYour Name QDF_STATUS sme_ll_stats_get_req(mac_handle_t mac_handle,
1625*5113495bSYour Name 				tSirLLStatsGetReq *get_stats_req,
1626*5113495bSYour Name 				void *context);
1627*5113495bSYour Name 
1628*5113495bSYour Name /**
1629*5113495bSYour Name  * sme_radio_tx_mem_free() - SME API to free the ll_stats memory
1630*5113495bSYour Name  *
1631*5113495bSYour Name  * Return: None
1632*5113495bSYour Name  */
1633*5113495bSYour Name void sme_radio_tx_mem_free(void);
1634*5113495bSYour Name 
1635*5113495bSYour Name /**
1636*5113495bSYour Name  * sme_set_link_layer_stats_ind_cb() -
1637*5113495bSYour Name  * SME API to trigger the stats are available after get request
1638*5113495bSYour Name  * @mac_handle: MAC handle
1639*5113495bSYour Name  * @callback: HDD callback which needs to be invoked after
1640*5113495bSYour Name  *    getting status notification from FW
1641*5113495bSYour Name  *
1642*5113495bSYour Name  * Return: QDF_STATUS
1643*5113495bSYour Name  */
1644*5113495bSYour Name QDF_STATUS sme_set_link_layer_stats_ind_cb(mac_handle_t mac_handle,
1645*5113495bSYour Name 					   link_layer_stats_cb callback);
1646*5113495bSYour Name 
1647*5113495bSYour Name QDF_STATUS sme_set_link_layer_ext_cb(mac_handle_t mac_handle,
1648*5113495bSYour Name 		     void (*ll_stats_ext_cb)(hdd_handle_t callback_ctx,
1649*5113495bSYour Name 					     tSirLLStatsResults * rsp));
1650*5113495bSYour Name QDF_STATUS sme_reset_link_layer_stats_ind_cb(mac_handle_t mac_handle);
1651*5113495bSYour Name QDF_STATUS sme_ll_stats_set_thresh(mac_handle_t mac_handle,
1652*5113495bSYour Name 				struct sir_ll_ext_stats_threshold *threshold);
1653*5113495bSYour Name #else /* WLAN_FEATURE_LINK_LAYER_STATS */
1654*5113495bSYour Name static inline QDF_STATUS
sme_set_link_layer_ext_cb(mac_handle_t mac_handle,void (* ll_stats_ext_cb)(hdd_handle_t callback_ctx,tSirLLStatsResults * rsp))1655*5113495bSYour Name sme_set_link_layer_ext_cb(mac_handle_t mac_handle, void (*ll_stats_ext_cb)
1656*5113495bSYour Name 			  (hdd_handle_t callback_ctx, tSirLLStatsResults
1657*5113495bSYour Name 			  *rsp))
1658*5113495bSYour Name {
1659*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
1660*5113495bSYour Name }
1661*5113495bSYour Name 
1662*5113495bSYour Name static inline QDF_STATUS
sme_set_link_layer_stats_ind_cb(mac_handle_t mac_handle,link_layer_stats_cb callback)1663*5113495bSYour Name sme_set_link_layer_stats_ind_cb(mac_handle_t mac_handle,
1664*5113495bSYour Name 				link_layer_stats_cb callback)
1665*5113495bSYour Name {
1666*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
1667*5113495bSYour Name }
1668*5113495bSYour Name 
1669*5113495bSYour Name static inline QDF_STATUS
sme_reset_link_layer_stats_ind_cb(mac_handle_t mac_handle)1670*5113495bSYour Name sme_reset_link_layer_stats_ind_cb(mac_handle_t mac_handle)
1671*5113495bSYour Name {
1672*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
1673*5113495bSYour Name }
1674*5113495bSYour Name #endif /* WLAN_FEATURE_LINK_LAYER_STATS */
1675*5113495bSYour Name 
1676*5113495bSYour Name QDF_STATUS sme_set_wisa_params(mac_handle_t mac_handle,
1677*5113495bSYour Name 			       struct sir_wisa_params *wisa_params);
1678*5113495bSYour Name QDF_STATUS sme_get_link_status(mac_handle_t mac_handle,
1679*5113495bSYour Name 			       csr_link_status_callback callback,
1680*5113495bSYour Name 			       void *context, uint8_t session_id);
1681*5113495bSYour Name QDF_STATUS sme_get_temperature(mac_handle_t mac_handle,
1682*5113495bSYour Name 		void *tempContext,
1683*5113495bSYour Name 		void (*pCallbackfn)(int temperature,
1684*5113495bSYour Name 			void *pContext));
1685*5113495bSYour Name 
1686*5113495bSYour Name /**
1687*5113495bSYour Name  * sme_set_scanning_mac_oui() - SME API to set scanning mac oui
1688*5113495bSYour Name  * @mac_handle: MAC Handle
1689*5113495bSYour Name  * @scan_mac_oui: Scanning Mac Oui
1690*5113495bSYour Name  *
1691*5113495bSYour Name  * Return: QDF_STATUS
1692*5113495bSYour Name  */
1693*5113495bSYour Name QDF_STATUS sme_set_scanning_mac_oui(mac_handle_t mac_handle,
1694*5113495bSYour Name 				    struct scan_mac_oui *scan_mac_oui);
1695*5113495bSYour Name 
1696*5113495bSYour Name #ifdef DHCP_SERVER_OFFLOAD
1697*5113495bSYour Name /**
1698*5113495bSYour Name  * sme_set_dhcp_srv_offload() - Set DHCP server offload
1699*5113495bSYour Name  * @mac_handle: Handle to the global MAC context
1700*5113495bSYour Name  * @dhcp_srv_info : DHCP server offload info struct
1701*5113495bSYour Name  *
1702*5113495bSYour Name  * Return: QDF_STATUS
1703*5113495bSYour Name  */
1704*5113495bSYour Name QDF_STATUS
1705*5113495bSYour Name sme_set_dhcp_srv_offload(mac_handle_t mac_handle,
1706*5113495bSYour Name 			 struct dhcp_offload_info_params *dhcp_srv_info);
1707*5113495bSYour Name #endif /* DHCP_SERVER_OFFLOAD */
1708*5113495bSYour Name #ifdef WLAN_FEATURE_GPIO_LED_FLASHING
1709*5113495bSYour Name QDF_STATUS sme_set_led_flashing(mac_handle_t mac_handle, uint8_t type,
1710*5113495bSYour Name 		uint32_t x0, uint32_t x1);
1711*5113495bSYour Name #endif
1712*5113495bSYour Name QDF_STATUS sme_enable_dfs_chan_scan(mac_handle_t mac_handle, uint8_t dfs_flag);
1713*5113495bSYour Name QDF_STATUS sme_set_mas(uint32_t val);
1714*5113495bSYour Name QDF_STATUS sme_set_miracast(mac_handle_t mac_handle, uint8_t filter_type);
1715*5113495bSYour Name QDF_STATUS sme_ext_change_freq(mac_handle_t mac_handle, qdf_freq_t freq,
1716*5113495bSYour Name 			       uint8_t session_id);
1717*5113495bSYour Name 
1718*5113495bSYour Name QDF_STATUS sme_configure_stats_avg_factor(mac_handle_t mac_handle,
1719*5113495bSYour Name 					  uint8_t session_id,
1720*5113495bSYour Name 					  uint16_t stats_avg_factor);
1721*5113495bSYour Name 
1722*5113495bSYour Name QDF_STATUS sme_configure_guard_time(mac_handle_t mac_handle, uint8_t session_id,
1723*5113495bSYour Name 				    uint32_t guard_time);
1724*5113495bSYour Name 
1725*5113495bSYour Name QDF_STATUS sme_wifi_start_logger(mac_handle_t mac_handle,
1726*5113495bSYour Name 				 struct sir_wifi_start_log start_log);
1727*5113495bSYour Name 
1728*5113495bSYour Name /**
1729*5113495bSYour Name  * sme_is_any_session_in_middle_of_roaming() - check if roaming is in progress
1730*5113495bSYour Name  * @mac_handle: MAC Handle
1731*5113495bSYour Name  *
1732*5113495bSYour Name  * Checks if any SME session is in middle of roaming
1733*5113495bSYour Name  *
1734*5113495bSYour Name  * Return: true if roaming is in progress else false
1735*5113495bSYour Name  */
1736*5113495bSYour Name bool sme_is_any_session_in_middle_of_roaming(mac_handle_t mac_handle);
1737*5113495bSYour Name 
1738*5113495bSYour Name /**
1739*5113495bSYour Name  * sme_send_flush_logs_cmd_to_fw() - Initiate command to FW to flush logs
1740*5113495bSYour Name  *
1741*5113495bSYour Name  * This function will initiate a command to firmware to flush their logs.
1742*5113495bSYour Name  * This should normally be done in response to an anomaly detected by the
1743*5113495bSYour Name  * host.
1744*5113495bSYour Name  *
1745*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS if the command was sent, otherwise an
1746*5113495bSYour Name  *         appropriate QDF_STATUS error
1747*5113495bSYour Name  */
1748*5113495bSYour Name QDF_STATUS sme_send_flush_logs_cmd_to_fw(void);
1749*5113495bSYour Name 
1750*5113495bSYour Name /**
1751*5113495bSYour Name  * sme_enable_uapsd_for_ac() - enable uapsd for access category request to WMA
1752*5113495bSYour Name  * @ac: access category
1753*5113495bSYour Name  * @tid: tid value
1754*5113495bSYour Name  * @pri: user priority
1755*5113495bSYour Name  * @srvc_int: service interval
1756*5113495bSYour Name  * @sus_int: suspend interval
1757*5113495bSYour Name  * @dir: tspec direction
1758*5113495bSYour Name  * @psb: PSB value
1759*5113495bSYour Name  * @sessionId: session id
1760*5113495bSYour Name  * @delay_interval: delay interval
1761*5113495bSYour Name  *
1762*5113495bSYour Name  * Return: QDF status
1763*5113495bSYour Name  */
1764*5113495bSYour Name QDF_STATUS sme_enable_uapsd_for_ac(sme_ac_enum_type ac, uint8_t tid,
1765*5113495bSYour Name 				   uint8_t pri, uint32_t srvc_int,
1766*5113495bSYour Name 				   uint32_t sus_int,
1767*5113495bSYour Name 				   enum sme_qos_wmm_dir_type dir,
1768*5113495bSYour Name 				   uint8_t psb, uint32_t sessionId,
1769*5113495bSYour Name 				   uint32_t delay_interval);
1770*5113495bSYour Name 
1771*5113495bSYour Name /**
1772*5113495bSYour Name  * sme_disable_uapsd_for_ac() - disable uapsd access category request to WMA
1773*5113495bSYour Name  * @ac: access category
1774*5113495bSYour Name  * @sessionId: session id
1775*5113495bSYour Name  *
1776*5113495bSYour Name  * Return: QDF status
1777*5113495bSYour Name  */
1778*5113495bSYour Name QDF_STATUS sme_disable_uapsd_for_ac(sme_ac_enum_type ac, uint32_t sessionId);
1779*5113495bSYour Name 
1780*5113495bSYour Name #ifdef FEATURE_RSSI_MONITOR
1781*5113495bSYour Name QDF_STATUS sme_set_rssi_monitoring(mac_handle_t mac_handle,
1782*5113495bSYour Name 				   struct rssi_monitor_param *input);
1783*5113495bSYour Name 
1784*5113495bSYour Name /**
1785*5113495bSYour Name  * sme_set_rssi_threshold_breached_cb() - Set RSSI threshold breached callback
1786*5113495bSYour Name  * @mac_handle: global MAC handle
1787*5113495bSYour Name  * @cb: callback function pointer
1788*5113495bSYour Name  *
1789*5113495bSYour Name  * This function registers the RSSI threshold breached callback function.
1790*5113495bSYour Name  *
1791*5113495bSYour Name  * Return: QDF_STATUS enumeration.
1792*5113495bSYour Name  */
1793*5113495bSYour Name QDF_STATUS sme_set_rssi_threshold_breached_cb(mac_handle_t mac_handle,
1794*5113495bSYour Name 					      rssi_threshold_breached_cb cb);
1795*5113495bSYour Name #else /* FEATURE_RSSI_MONITOR */
1796*5113495bSYour Name static inline
sme_set_rssi_threshold_breached_cb(mac_handle_t mac_handle,rssi_threshold_breached_cb cb)1797*5113495bSYour Name QDF_STATUS sme_set_rssi_threshold_breached_cb(mac_handle_t mac_handle,
1798*5113495bSYour Name 					      rssi_threshold_breached_cb cb)
1799*5113495bSYour Name {
1800*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
1801*5113495bSYour Name }
1802*5113495bSYour Name #endif
1803*5113495bSYour Name /**
1804*5113495bSYour Name  * sme_reset_rssi_threshold_breached_cb() - Reset RSSI threshold breached
1805*5113495bSYour Name  *                                          callback
1806*5113495bSYour Name  * @mac_handle: global MAC handle
1807*5113495bSYour Name  *
1808*5113495bSYour Name  * This function de-registers the RSSI threshold breached callback function.
1809*5113495bSYour Name  *
1810*5113495bSYour Name  * Return: QDF_STATUS enumeration.
1811*5113495bSYour Name  */
1812*5113495bSYour Name QDF_STATUS sme_reset_rssi_threshold_breached_cb(mac_handle_t mac_handle);
1813*5113495bSYour Name 
1814*5113495bSYour Name QDF_STATUS sme_register_mgmt_frame_ind_callback(mac_handle_t mac_handle,
1815*5113495bSYour Name 			sir_mgmt_frame_ind_callback callback);
1816*5113495bSYour Name 
1817*5113495bSYour Name QDF_STATUS sme_update_nss(mac_handle_t mac_handle, uint8_t nss);
1818*5113495bSYour Name void sme_update_user_configured_nss(mac_handle_t mac_handle, uint8_t nss);
1819*5113495bSYour Name 
1820*5113495bSYour Name bool sme_is_any_session_in_connected_state(mac_handle_t mac_handle);
1821*5113495bSYour Name 
1822*5113495bSYour Name QDF_STATUS sme_pdev_set_hw_mode(struct policy_mgr_hw_mode msg);
1823*5113495bSYour Name 
1824*5113495bSYour Name /**
1825*5113495bSYour Name  * sme_nss_update_request() - Send beacon template update to FW with new
1826*5113495bSYour Name  * nss value
1827*5113495bSYour Name  * @mac_handle: Handle returned by macOpen
1828*5113495bSYour Name  * @vdev_id: the session id
1829*5113495bSYour Name  * @new_nss: the new nss value
1830*5113495bSYour Name  * @ch_width: channel width, optional value
1831*5113495bSYour Name  * @cback: hdd callback
1832*5113495bSYour Name  * @next_action: next action to happen at policy mgr after beacon update
1833*5113495bSYour Name  * @original_vdev_id: original request hwmode change vdev id
1834*5113495bSYour Name  * @request_id: request id
1835*5113495bSYour Name  *
1836*5113495bSYour Name  * Sends the command to CSR to send to PE
1837*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on successful posting
1838*5113495bSYour Name  */
1839*5113495bSYour Name QDF_STATUS sme_nss_update_request(uint32_t vdev_id,
1840*5113495bSYour Name 				  uint8_t  new_nss, uint8_t ch_width,
1841*5113495bSYour Name 				  policy_mgr_nss_update_cback cback,
1842*5113495bSYour Name 				  uint8_t next_action,
1843*5113495bSYour Name 				  struct wlan_objmgr_psoc *psoc,
1844*5113495bSYour Name 				  enum policy_mgr_conn_update_reason reason,
1845*5113495bSYour Name 				  uint32_t original_vdev_id,
1846*5113495bSYour Name 				  uint32_t request_id);
1847*5113495bSYour Name 
1848*5113495bSYour Name /**
1849*5113495bSYour Name  * sme_sap_update_ch_width() - Update SAP ch_width
1850*5113495bSYour Name  * @psoc: Psoc object
1851*5113495bSYour Name  * @vdev_id: the session id
1852*5113495bSYour Name  * @ch_width: channel width to be updated
1853*5113495bSYour Name  * @reason: Reason for ch_width update
1854*5113495bSYour Name  * @conc_vdev_id: Concurrent connection vdev_id that is causing ch_width update
1855*5113495bSYour Name  * @request_id: request id
1856*5113495bSYour Name  *
1857*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on successful posting
1858*5113495bSYour Name  */
1859*5113495bSYour Name QDF_STATUS
1860*5113495bSYour Name sme_sap_update_ch_width(struct wlan_objmgr_psoc *psoc,
1861*5113495bSYour Name 			uint8_t vdev_id,
1862*5113495bSYour Name 			enum phy_ch_width ch_width,
1863*5113495bSYour Name 			enum policy_mgr_conn_update_reason reason,
1864*5113495bSYour Name 			uint8_t conc_vdev_id, uint32_t request_id);
1865*5113495bSYour Name 
1866*5113495bSYour Name QDF_STATUS sme_set_peer_authorized(uint8_t *peer_addr,
1867*5113495bSYour Name 				   uint32_t vdev_id);
1868*5113495bSYour Name QDF_STATUS sme_soc_set_dual_mac_config(struct policy_mgr_dual_mac_config msg);
1869*5113495bSYour Name QDF_STATUS sme_soc_set_antenna_mode(mac_handle_t mac_handle,
1870*5113495bSYour Name 				    struct sir_antenna_mode_param *msg);
1871*5113495bSYour Name 
1872*5113495bSYour Name void sme_setdef_dot11mode(mac_handle_t mac_handle);
1873*5113495bSYour Name 
1874*5113495bSYour Name /**
1875*5113495bSYour Name  * sme_update_tx_bfee_supp() - sets the Tx Bfee support
1876*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
1877*5113495bSYour Name  * @session_id: SME session id
1878*5113495bSYour Name  * @cfg_val: Tx Bfee config value
1879*5113495bSYour Name  *
1880*5113495bSYour Name  * Return: 0 on success else err code
1881*5113495bSYour Name  */
1882*5113495bSYour Name int sme_update_tx_bfee_supp(mac_handle_t mac_handle, uint8_t session_id,
1883*5113495bSYour Name 			    uint8_t cfg_val);
1884*5113495bSYour Name 
1885*5113495bSYour Name /**
1886*5113495bSYour Name  * sme_update_tx_bfee_nsts() - sets the Tx Bfee nsts
1887*5113495bSYour Name  * @mac_handle: MAC handle
1888*5113495bSYour Name  * @session_id: SME session id
1889*5113495bSYour Name  * @usr_cfg_val: user config value
1890*5113495bSYour Name  * @nsts_val: Tx Bfee nsts config value
1891*5113495bSYour Name  *
1892*5113495bSYour Name  * Return: 0 on success else err code
1893*5113495bSYour Name  */
1894*5113495bSYour Name int sme_update_tx_bfee_nsts(mac_handle_t mac_handle, uint8_t session_id,
1895*5113495bSYour Name 			    uint8_t usr_cfg_val, uint8_t nsts_val);
1896*5113495bSYour Name 
1897*5113495bSYour Name void wlan_sap_enable_phy_error_logs(mac_handle_t mac_handle,
1898*5113495bSYour Name 				    uint32_t enable_log);
1899*5113495bSYour Name #ifdef WLAN_FEATURE_DSRC
1900*5113495bSYour Name int sme_ocb_gen_timing_advert_frame(mac_handle_t mac_handle,
1901*5113495bSYour Name 				    tSirMacAddr self_addr,
1902*5113495bSYour Name 				    uint8_t **buf, uint32_t *timestamp_offset,
1903*5113495bSYour Name 				    uint32_t *time_value_offset);
1904*5113495bSYour Name 
1905*5113495bSYour Name #else
1906*5113495bSYour Name static inline
sme_ocb_gen_timing_advert_frame(mac_handle_t mac_handle,tSirMacAddr self_addr,uint8_t ** buf,uint32_t * timestamp_offset,uint32_t * time_value_offset)1907*5113495bSYour Name int sme_ocb_gen_timing_advert_frame(mac_handle_t mac_handle,
1908*5113495bSYour Name 				    tSirMacAddr self_addr, uint8_t **buf,
1909*5113495bSYour Name 				    uint32_t *timestamp_offset,
1910*5113495bSYour Name 				    uint32_t *time_value_offset)
1911*5113495bSYour Name {
1912*5113495bSYour Name 	return 0;
1913*5113495bSYour Name }
1914*5113495bSYour Name 
1915*5113495bSYour Name #endif
1916*5113495bSYour Name 
1917*5113495bSYour Name void sme_add_set_thermal_level_callback(mac_handle_t mac_handle,
1918*5113495bSYour Name 		sme_set_thermal_level_callback callback);
1919*5113495bSYour Name 
1920*5113495bSYour Name void sme_update_tgt_services(mac_handle_t mac_handle,
1921*5113495bSYour Name 			     struct wma_tgt_services *cfg);
1922*5113495bSYour Name 
1923*5113495bSYour Name bool sme_validate_sap_channel_switch(mac_handle_t mac_handle,
1924*5113495bSYour Name 				     uint32_t sap_ch_freq, eCsrPhyMode sap_phy_mode,
1925*5113495bSYour Name 				     uint8_t cc_switch_mode,
1926*5113495bSYour Name 				     uint8_t vdev_id);
1927*5113495bSYour Name 
1928*5113495bSYour Name bool sme_is_session_id_valid(mac_handle_t mac_handle, uint32_t session_id);
1929*5113495bSYour Name 
1930*5113495bSYour Name #ifdef FEATURE_WLAN_TDLS
1931*5113495bSYour Name void sme_get_opclass(mac_handle_t mac_handle, uint8_t channel,
1932*5113495bSYour Name 		     uint8_t bw_offset, uint8_t *opclass);
1933*5113495bSYour Name #else
1934*5113495bSYour Name static inline void
sme_get_opclass(mac_handle_t mac_handle,uint8_t channel,uint8_t bw_offset,uint8_t * opclass)1935*5113495bSYour Name sme_get_opclass(mac_handle_t mac_handle, uint8_t channel, uint8_t bw_offset,
1936*5113495bSYour Name 		uint8_t *opclass)
1937*5113495bSYour Name {
1938*5113495bSYour Name }
1939*5113495bSYour Name #endif
1940*5113495bSYour Name 
1941*5113495bSYour Name #ifdef FEATURE_LFR_SUBNET_DETECTION
1942*5113495bSYour Name QDF_STATUS sme_gateway_param_update(mac_handle_t mac_handle,
1943*5113495bSYour Name 				struct gateway_update_req_param *request);
1944*5113495bSYour Name #endif
1945*5113495bSYour Name 
1946*5113495bSYour Name void sme_update_fine_time_measurement_capab(mac_handle_t mac_handle,
1947*5113495bSYour Name 					    uint8_t session_id,
1948*5113495bSYour Name 					    uint32_t val);
1949*5113495bSYour Name QDF_STATUS sme_ht40_stop_obss_scan(mac_handle_t mac_handle, uint32_t vdev_id);
1950*5113495bSYour Name QDF_STATUS sme_set_fw_test(struct set_fwtest_params *fw_test);
1951*5113495bSYour Name QDF_STATUS sme_set_tsfcb(mac_handle_t mac_handle,
1952*5113495bSYour Name 	int (*cb_fn)(void *cb_ctx, struct stsf *ptsf), void *cb_ctx);
1953*5113495bSYour Name 
1954*5113495bSYour Name QDF_STATUS sme_reset_tsfcb(mac_handle_t mac_handle);
1955*5113495bSYour Name 
1956*5113495bSYour Name #if defined(WLAN_FEATURE_TSF) && !defined(WLAN_FEATURE_TSF_PLUS_NOIRQ)
1957*5113495bSYour Name QDF_STATUS sme_set_tsf_gpio(mac_handle_t mac_handle, uint32_t pinvalue);
1958*5113495bSYour Name #endif
1959*5113495bSYour Name 
1960*5113495bSYour Name #ifdef WLAN_BCN_RECV_FEATURE
1961*5113495bSYour Name /**
1962*5113495bSYour Name  * sme_handle_bcn_recv_start() - Enable fw to start sending
1963*5113495bSYour Name  * beacons of the current connected AP
1964*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
1965*5113495bSYour Name  * @vdev_id: SME session id
1966*5113495bSYour Name  * @nth_value: Beacon report period
1967*5113495bSYour Name  * @do_not_resume: beacon reporting resume after a pause is completed
1968*5113495bSYour Name  *
1969*5113495bSYour Name  * This function remove beacon filter. It allow fw to send
1970*5113495bSYour Name  * all beacons from connected peer to driver.
1971*5113495bSYour Name  *
1972*5113495bSYour Name  * Return: QDF_STATUS enumeration
1973*5113495bSYour Name  */
1974*5113495bSYour Name QDF_STATUS sme_handle_bcn_recv_start(mac_handle_t mac_handle,
1975*5113495bSYour Name 				     uint32_t vdev_id,
1976*5113495bSYour Name 				     uint32_t nth_value,
1977*5113495bSYour Name 				     bool do_not_resume);
1978*5113495bSYour Name 
1979*5113495bSYour Name /**
1980*5113495bSYour Name  * sme_is_beacon_report_started() - Check bcn recv started
1981*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
1982*5113495bSYour Name  * @session_id: SME session id
1983*5113495bSYour Name  *
1984*5113495bSYour Name  * This function is to check beacon report started or not.
1985*5113495bSYour Name  *
1986*5113495bSYour Name  * Return: true on success
1987*5113495bSYour Name  */
1988*5113495bSYour Name bool sme_is_beacon_report_started(mac_handle_t mac_handle,
1989*5113495bSYour Name 				  uint32_t session_id);
1990*5113495bSYour Name 
1991*5113495bSYour Name /**
1992*5113495bSYour Name  * sme_is_beacon_reporting_do_not_resume() - Check auto resume allowed or not
1993*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
1994*5113495bSYour Name  * @session_id: SME session id
1995*5113495bSYour Name  *
1996*5113495bSYour Name  * This function is to check auto resume of beacon reporting is allowed or not.
1997*5113495bSYour Name  *
1998*5113495bSYour Name  * Return: true on success
1999*5113495bSYour Name  */
2000*5113495bSYour Name bool sme_is_beacon_reporting_do_not_resume(mac_handle_t mac_handle,
2001*5113495bSYour Name 					   uint32_t session_id);
2002*5113495bSYour Name 
2003*5113495bSYour Name /**
2004*5113495bSYour Name  * stop_beacon_report() - To stop beacon report
2005*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2006*5113495bSYour Name  * @session_id: SME session id
2007*5113495bSYour Name  *
2008*5113495bSYour Name  * Return: None
2009*5113495bSYour Name  */
2010*5113495bSYour Name void sme_stop_beacon_report(mac_handle_t mac_handle,
2011*5113495bSYour Name 			    uint32_t session_id);
2012*5113495bSYour Name 
2013*5113495bSYour Name #else
2014*5113495bSYour Name static inline
sme_is_beacon_report_started(mac_handle_t mac_handle,uint32_t session_id)2015*5113495bSYour Name bool sme_is_beacon_report_started(mac_handle_t mac_handle,
2016*5113495bSYour Name 				  uint32_t session_id)
2017*5113495bSYour Name {
2018*5113495bSYour Name 	return true;
2019*5113495bSYour Name }
2020*5113495bSYour Name 
2021*5113495bSYour Name static inline
sme_is_beacon_reporting_do_not_resume(mac_handle_t mac_handle,uint32_t session_id)2022*5113495bSYour Name bool sme_is_beacon_reporting_do_not_resume(mac_handle_t mac_handle,
2023*5113495bSYour Name 					   uint32_t session_id)
2024*5113495bSYour Name {
2025*5113495bSYour Name 	return false;
2026*5113495bSYour Name }
2027*5113495bSYour Name 
2028*5113495bSYour Name static inline
sme_stop_beacon_report(mac_handle_t mac_handle,uint32_t session_id)2029*5113495bSYour Name void sme_stop_beacon_report(mac_handle_t mac_handle,
2030*5113495bSYour Name 			    uint32_t session_id)
2031*5113495bSYour Name {
2032*5113495bSYour Name }
2033*5113495bSYour Name 
2034*5113495bSYour Name #endif
2035*5113495bSYour Name 
2036*5113495bSYour Name QDF_STATUS sme_add_beacon_filter(mac_handle_t mac_handle,
2037*5113495bSYour Name 				 uint32_t session_id, uint32_t *ie_map);
2038*5113495bSYour Name QDF_STATUS sme_remove_beacon_filter(mac_handle_t mac_handle,
2039*5113495bSYour Name 				    uint32_t session_id);
2040*5113495bSYour Name 
2041*5113495bSYour Name #ifdef FEATURE_WLAN_APF
2042*5113495bSYour Name /**
2043*5113495bSYour Name  * sme_get_apf_capabilities() - Get APF capabilities
2044*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2045*5113495bSYour Name  * @callback: Callback function to be called with the result
2046*5113495bSYour Name  * @context: Opaque context to be used by the caller to associate the
2047*5113495bSYour Name  *   request with the response
2048*5113495bSYour Name  *
2049*5113495bSYour Name  * This function constructs the cds message and fill in message type,
2050*5113495bSYour Name  * post the same to WDA.
2051*5113495bSYour Name  *
2052*5113495bSYour Name  * Return: QDF_STATUS enumeration
2053*5113495bSYour Name  */
2054*5113495bSYour Name QDF_STATUS sme_get_apf_capabilities(mac_handle_t mac_handle,
2055*5113495bSYour Name 				    apf_get_offload_cb callback,
2056*5113495bSYour Name 				    void *context);
2057*5113495bSYour Name 
2058*5113495bSYour Name /**
2059*5113495bSYour Name  * sme_set_apf_instructions() - Set APF apf filter instructions.
2060*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2061*5113495bSYour Name  * @apf_set_offload: struct to set apf filter instructions.
2062*5113495bSYour Name  *
2063*5113495bSYour Name  * APFv2 (Legacy APF) API to set the APF packet filter.
2064*5113495bSYour Name  *
2065*5113495bSYour Name  * Return: QDF_STATUS enumeration.
2066*5113495bSYour Name  */
2067*5113495bSYour Name QDF_STATUS sme_set_apf_instructions(mac_handle_t mac_handle,
2068*5113495bSYour Name 				    struct sir_apf_set_offload
2069*5113495bSYour Name 							*apf_set_offload);
2070*5113495bSYour Name 
2071*5113495bSYour Name /**
2072*5113495bSYour Name  * sme_set_apf_enable_disable - Send apf enable/disable cmd
2073*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2074*5113495bSYour Name  * @vdev_id: vdev id
2075*5113495bSYour Name  * @apf_enable: true: Enable APF Int., false: Disable APF Int.
2076*5113495bSYour Name  *
2077*5113495bSYour Name  * API to either enable or disable the APF interpreter.
2078*5113495bSYour Name  *
2079*5113495bSYour Name  * Return: QDF_STATUS enumeration.
2080*5113495bSYour Name  */
2081*5113495bSYour Name QDF_STATUS sme_set_apf_enable_disable(mac_handle_t mac_handle, uint8_t vdev_id,
2082*5113495bSYour Name 				      bool apf_enable);
2083*5113495bSYour Name 
2084*5113495bSYour Name /**
2085*5113495bSYour Name  * sme_apf_write_work_memory - Write into the apf work memory
2086*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2087*5113495bSYour Name  * @write_params: APF parameters for the write operation
2088*5113495bSYour Name  *
2089*5113495bSYour Name  * API for writing into the APF work memory.
2090*5113495bSYour Name  *
2091*5113495bSYour Name  * Return: QDF_STATUS enumeration.
2092*5113495bSYour Name  */
2093*5113495bSYour Name QDF_STATUS sme_apf_write_work_memory(mac_handle_t mac_handle,
2094*5113495bSYour Name 				    struct wmi_apf_write_memory_params
2095*5113495bSYour Name 								*write_params);
2096*5113495bSYour Name 
2097*5113495bSYour Name /**
2098*5113495bSYour Name  * sme_apf_read_work_memory - Read part of apf work memory
2099*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2100*5113495bSYour Name  * @read_params: APF parameters for the get operation
2101*5113495bSYour Name  * @callback: callback to handle the the read response
2102*5113495bSYour Name  *
2103*5113495bSYour Name  * API for issuing a APF read memory request.
2104*5113495bSYour Name  *
2105*5113495bSYour Name  * Return: QDF_STATUS enumeration.
2106*5113495bSYour Name  */
2107*5113495bSYour Name QDF_STATUS
2108*5113495bSYour Name sme_apf_read_work_memory(mac_handle_t mac_handle,
2109*5113495bSYour Name 			 struct wmi_apf_read_memory_params *read_params,
2110*5113495bSYour Name 			 apf_read_mem_cb callback);
2111*5113495bSYour Name 
2112*5113495bSYour Name #endif /* FEATURE_WLAN_APF */
2113*5113495bSYour Name 
2114*5113495bSYour Name uint32_t sme_get_wni_dot11_mode(mac_handle_t mac_handle);
2115*5113495bSYour Name QDF_STATUS sme_create_mon_session(mac_handle_t mac_handle, uint8_t *bssid,
2116*5113495bSYour Name 				  uint8_t vdev_id);
2117*5113495bSYour Name 
2118*5113495bSYour Name /**
2119*5113495bSYour Name  * sme_delete_mon_session() - post message to delete PE session for mon_mode
2120*5113495bSYour Name  * operation
2121*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2122*5113495bSYour Name  * @vdev_id: sme session id
2123*5113495bSYour Name  *
2124*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on success, non-zero error code on failure.
2125*5113495bSYour Name  */
2126*5113495bSYour Name QDF_STATUS sme_delete_mon_session(mac_handle_t mac_handle, uint8_t vdev_id);
2127*5113495bSYour Name 
2128*5113495bSYour Name /**
2129*5113495bSYour Name  * sme_set_vdev_ies_per_band() - sends the per band IEs to vdev
2130*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2131*5113495bSYour Name  * @vdev_id: vdev_id for which IE is targeted
2132*5113495bSYour Name  * @device_mode: vdev mode
2133*5113495bSYour Name  *
2134*5113495bSYour Name  * Return: None
2135*5113495bSYour Name  */
2136*5113495bSYour Name void sme_set_vdev_ies_per_band(mac_handle_t mac_handle, uint8_t vdev_id,
2137*5113495bSYour Name 			       enum QDF_OPMODE device_mode);
2138*5113495bSYour Name 
2139*5113495bSYour Name void sme_set_pdev_ht_vht_ies(mac_handle_t mac_handle, bool enable2x2);
2140*5113495bSYour Name 
2141*5113495bSYour Name /**
2142*5113495bSYour Name  * sme_get_sap_vdev_type_nss() - get the sap nss per vdev type
2143*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2144*5113495bSYour Name  * @vdev_nss: Pointer to vdev_nss
2145*5113495bSYour Name  * @band: 5G or 2.4G band
2146*5113495bSYour Name  *
2147*5113495bSYour Name  * Get SAP vdev nss
2148*5113495bSYour Name  *
2149*5113495bSYour Name  * Return: None
2150*5113495bSYour Name  */
2151*5113495bSYour Name void sme_get_sap_vdev_type_nss(mac_handle_t mac_handle, uint8_t *vdev_nss,
2152*5113495bSYour Name 			       enum band_info band);
2153*5113495bSYour Name 
2154*5113495bSYour Name /**
2155*5113495bSYour Name  * sme_update_vdev_type_nss() - sets the nss per vdev type
2156*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2157*5113495bSYour Name  * @max_supp_nss: max_supported Nss
2158*5113495bSYour Name  * @band: 5G or 2.4G band
2159*5113495bSYour Name  *
2160*5113495bSYour Name  * Sets the per band Nss for each vdev type based on INI and configured
2161*5113495bSYour Name  * chain mask value.
2162*5113495bSYour Name  *
2163*5113495bSYour Name  * Return: None
2164*5113495bSYour Name  */
2165*5113495bSYour Name void sme_update_vdev_type_nss(mac_handle_t mac_handle, uint8_t max_supp_nss,
2166*5113495bSYour Name 			      enum nss_chains_band_info band);
2167*5113495bSYour Name 
2168*5113495bSYour Name #ifdef FEATURE_P2P_LISTEN_OFFLOAD
2169*5113495bSYour Name void sme_register_p2p_lo_event(mac_handle_t mac_handle, void *context,
2170*5113495bSYour Name 					p2p_lo_callback callback);
2171*5113495bSYour Name #else
sme_register_p2p_lo_event(mac_handle_t mac_handle,void * context,p2p_lo_callback callback)2172*5113495bSYour Name static inline void sme_register_p2p_lo_event(mac_handle_t mac_handle,
2173*5113495bSYour Name 					     void *context,
2174*5113495bSYour Name 					     p2p_lo_callback callback)
2175*5113495bSYour Name {
2176*5113495bSYour Name }
2177*5113495bSYour Name #endif
2178*5113495bSYour Name 
2179*5113495bSYour Name QDF_STATUS sme_process_mac_pwr_dbg_cmd(mac_handle_t mac_handle,
2180*5113495bSYour Name 				       uint32_t session_id,
2181*5113495bSYour Name 				       struct sir_mac_pwr_dbg_cmd*
2182*5113495bSYour Name 				       dbg_args);
2183*5113495bSYour Name 
2184*5113495bSYour Name void sme_get_vdev_type_nss(enum QDF_OPMODE dev_mode,
2185*5113495bSYour Name 			   uint8_t *nss_2g, uint8_t *nss_5g);
2186*5113495bSYour Name void sme_send_disassoc_req_frame(mac_handle_t mac_handle,
2187*5113495bSYour Name 				 uint8_t session_id, uint8_t *peer_mac,
2188*5113495bSYour Name 				 uint16_t reason, uint8_t wait_for_ack);
2189*5113495bSYour Name QDF_STATUS sme_update_access_policy_vendor_ie(mac_handle_t mac_handle,
2190*5113495bSYour Name 					      uint8_t session_id,
2191*5113495bSYour Name 					      uint8_t *vendor_ie,
2192*5113495bSYour Name 					      int access_policy);
2193*5113495bSYour Name 
2194*5113495bSYour Name /**
2195*5113495bSYour Name  * sme_set_peer_param() - set peer param
2196*5113495bSYour Name  * @vdev_id: vdev ID
2197*5113495bSYour Name  * @peer_addr: peer MAC address
2198*5113495bSYour Name  * @param_id: param ID to be updated
2199*5113495bSYour Name  * @param_Value: paraam value
2200*5113495bSYour Name  *
2201*5113495bSYour Name  * This SME API is used to send the peer param to WMA to be sent to FW.
2202*5113495bSYour Name  *
2203*5113495bSYour Name  * Return: QDF_STATUS
2204*5113495bSYour Name  */
2205*5113495bSYour Name QDF_STATUS sme_set_peer_param(uint8_t *peer_addr, uint32_t param_id,
2206*5113495bSYour Name 			      uint32_t param_value, uint32_t vdev_id);
2207*5113495bSYour Name 
2208*5113495bSYour Name QDF_STATUS sme_update_sta_roam_policy(mac_handle_t mac_handle,
2209*5113495bSYour Name 		enum sta_roam_policy_dfs_mode dfs_mode,
2210*5113495bSYour Name 		bool skip_unsafe_channels,
2211*5113495bSYour Name 		uint8_t session_id, uint8_t sap_operating_band);
2212*5113495bSYour Name QDF_STATUS sme_enable_disable_chanavoidind_event(mac_handle_t mac_handle,
2213*5113495bSYour Name 					uint8_t set_value);
2214*5113495bSYour Name QDF_STATUS sme_set_default_scan_ie(mac_handle_t mac_handle, uint16_t session_id,
2215*5113495bSYour Name 				uint8_t *ie_data, uint16_t ie_len);
2216*5113495bSYour Name /**
2217*5113495bSYour Name  * sme_set_check_assoc_disallowed() - API to update assoc disallowed
2218*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2219*5113495bSYour Name  * @check_assoc_disallowed: assoc disallowed check value
2220*5113495bSYour Name  *
2221*5113495bSYour Name  * Return: QDF_STATUS
2222*5113495bSYour Name  */
2223*5113495bSYour Name QDF_STATUS sme_set_check_assoc_disallowed(mac_handle_t mac_handle,
2224*5113495bSYour Name 					  bool check_assoc_disallowed);
2225*5113495bSYour Name 
2226*5113495bSYour Name /**
2227*5113495bSYour Name  * sme_update_session_param() - API to update PE session param
2228*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2229*5113495bSYour Name  * @session_id: Session ID
2230*5113495bSYour Name  * @param_type: Param type to be updated
2231*5113495bSYour Name  * @param_val: Param value to be update
2232*5113495bSYour Name  *
2233*5113495bSYour Name  * Note: this setting will not persist over reboots.
2234*5113495bSYour Name  *
2235*5113495bSYour Name  * Return: QDF_STATUS
2236*5113495bSYour Name  */
2237*5113495bSYour Name QDF_STATUS sme_update_session_param(mac_handle_t mac_handle, uint8_t session_id,
2238*5113495bSYour Name 		uint32_t param_type, uint32_t param_val);
2239*5113495bSYour Name #ifdef WLAN_FEATURE_FIPS
2240*5113495bSYour Name /**
2241*5113495bSYour Name  * sme_fips_request() - Perform a FIPS certification operation
2242*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2243*5113495bSYour Name  * @param: The FIPS certification parameters
2244*5113495bSYour Name  * @callback: Callback function to invoke with the results
2245*5113495bSYour Name  * @context: Opaque context to pass back to caller in the callback
2246*5113495bSYour Name  *
2247*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS if the request is successfully sent
2248*5113495bSYour Name  * to firmware for processing, otherwise an error status.
2249*5113495bSYour Name  */
2250*5113495bSYour Name QDF_STATUS sme_fips_request(mac_handle_t mac_handle, struct fips_params *param,
2251*5113495bSYour Name 			    wma_fips_cb callback, void *context);
2252*5113495bSYour Name #else
2253*5113495bSYour Name static inline
sme_fips_request(mac_handle_t mac_handle,struct fips_params * param,wma_fips_cb callback,void * context)2254*5113495bSYour Name QDF_STATUS sme_fips_request(mac_handle_t mac_handle, struct fips_params *param,
2255*5113495bSYour Name 			    wma_fips_cb callback, void *context)
2256*5113495bSYour Name {
2257*5113495bSYour Name 	return QDF_STATUS_E_NOSUPPORT;
2258*5113495bSYour Name }
2259*5113495bSYour Name #endif /* WLAN_FEATURE_FIPS */
2260*5113495bSYour Name 
2261*5113495bSYour Name /**
2262*5113495bSYour Name  * sme_set_cts2self_for_p2p_go() - sme function to set ini params to FW.
2263*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2264*5113495bSYour Name  *
2265*5113495bSYour Name  * Return: QDF_STATUS
2266*5113495bSYour Name  */
2267*5113495bSYour Name QDF_STATUS sme_set_cts2self_for_p2p_go(mac_handle_t mac_handle);
2268*5113495bSYour Name 
2269*5113495bSYour Name QDF_STATUS sme_update_tx_fail_cnt_threshold(mac_handle_t mac_handle,
2270*5113495bSYour Name 		uint8_t session_id, uint32_t tx_fail_count);
2271*5113495bSYour Name 
2272*5113495bSYour Name /**
2273*5113495bSYour Name  * sme_neighbor_roam_is11r_assoc() - Check if association type is 11R
2274*5113495bSYour Name  * @mac_handle: MAC_HANDLE handle
2275*5113495bSYour Name  * @session_id: session id
2276*5113495bSYour Name  *
2277*5113495bSYour Name  * Return: true if 11r Association, false otherwise.
2278*5113495bSYour Name  */
2279*5113495bSYour Name bool sme_neighbor_roam_is11r_assoc(mac_handle_t mac_handle, uint8_t session_id);
2280*5113495bSYour Name 
2281*5113495bSYour Name /**
2282*5113495bSYour Name  * sme_update_sta_inactivity_timeout(): Update sta_inactivity_timeout to FW
2283*5113495bSYour Name  * @mac_handle: Handle returned by mac_open
2284*5113495bSYour Name  * @sta_inactivity_timer:  struct for sta inactivity timer
2285*5113495bSYour Name  *
2286*5113495bSYour Name  * If a station does not send anything in sta_inactivity_timeout seconds, an
2287*5113495bSYour Name  * empty data frame is sent to it in order to verify whether it is
2288*5113495bSYour Name  * still in range. If this frame is not ACKed, the station will be
2289*5113495bSYour Name  * disassociated and then deauthenticated.
2290*5113495bSYour Name  *
2291*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure.
2292*5113495bSYour Name */
2293*5113495bSYour Name QDF_STATUS sme_update_sta_inactivity_timeout(mac_handle_t mac_handle,
2294*5113495bSYour Name 		struct sme_sta_inactivity_timeout  *sta_inactivity_timer);
2295*5113495bSYour Name 
2296*5113495bSYour Name /**
2297*5113495bSYour Name  * sme_set_lost_link_info_cb() - plug in callback function for receiving
2298*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
2299*5113495bSYour Name  * @cb: callback function
2300*5113495bSYour Name  *
2301*5113495bSYour Name  * Return: HAL status
2302*5113495bSYour Name  */
2303*5113495bSYour Name QDF_STATUS sme_set_lost_link_info_cb(mac_handle_t mac_handle,
2304*5113495bSYour Name 				     lost_link_info_cb cb);
2305*5113495bSYour Name 
2306*5113495bSYour Name /**
2307*5113495bSYour Name  * sme_update_new_channel_event() - update new channel event for sapFsm
2308*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2309*5113495bSYour Name  * @session_id: session id
2310*5113495bSYour Name  *
2311*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure.
2312*5113495bSYour Name  */
2313*5113495bSYour Name QDF_STATUS sme_update_new_channel_event(mac_handle_t mac_handle,
2314*5113495bSYour Name 					uint8_t session_id);
2315*5113495bSYour Name #ifdef WLAN_POWER_DEBUG
2316*5113495bSYour Name /**
2317*5113495bSYour Name  * sme_reset_power_debug_stats_cb() - SME API to reset Power debug stats cb
2318*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2319*5113495bSYour Name  *
2320*5113495bSYour Name  * Resets the power stats callback and context to NULL
2321*5113495bSYour Name  *
2322*5113495bSYour Name  * Return: None
2323*5113495bSYour Name  */
2324*5113495bSYour Name void sme_reset_power_debug_stats_cb(mac_handle_t mac_handle);
2325*5113495bSYour Name 
2326*5113495bSYour Name /**
2327*5113495bSYour Name  * sme_power_debug_stats_req() - SME API to collect Power debug stats
2328*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2329*5113495bSYour Name  * @callback_fn: Pointer to the callback function for Power stats event
2330*5113495bSYour Name  * @power_stats_context: Pointer to context
2331*5113495bSYour Name  *
2332*5113495bSYour Name  * Return: QDF_STATUS
2333*5113495bSYour Name  */
2334*5113495bSYour Name QDF_STATUS sme_power_debug_stats_req(
2335*5113495bSYour Name 		mac_handle_t mac_handle,
2336*5113495bSYour Name 		void (*callback_fn)(struct power_stats_response *response,
2337*5113495bSYour Name 				    void *context),
2338*5113495bSYour Name 		void *power_stats_context);
2339*5113495bSYour Name #endif
2340*5113495bSYour Name 
2341*5113495bSYour Name #ifdef WLAN_FEATURE_BEACON_RECEPTION_STATS
2342*5113495bSYour Name /**
2343*5113495bSYour Name  * sme_beacon_debug_stats_req() - SME API to collect beacon debug stats
2344*5113495bSYour Name  * @vdev_id: Vdev id on which stats is being requested
2345*5113495bSYour Name  * @callback_fn: Pointer to the callback function for beacon stats event
2346*5113495bSYour Name  * @beacon_stats_context: Pointer to context
2347*5113495bSYour Name  *
2348*5113495bSYour Name  * Return: QDF_STATUS
2349*5113495bSYour Name  */
2350*5113495bSYour Name QDF_STATUS sme_beacon_debug_stats_req(
2351*5113495bSYour Name 		mac_handle_t mac_handle, uint32_t vdev_id,
2352*5113495bSYour Name 		void (*callback_fn)(struct bcn_reception_stats_rsp
2353*5113495bSYour Name 				    *response, void *context),
2354*5113495bSYour Name 		void *beacon_stats_context);
2355*5113495bSYour Name #endif
2356*5113495bSYour Name 
2357*5113495bSYour Name /**
2358*5113495bSYour Name  * sme_get_sar_power_limits() - get SAR limits
2359*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2360*5113495bSYour Name  * @callback: Callback function to invoke with the results
2361*5113495bSYour Name  * @context: Opaque context to pass back to caller in the callback
2362*5113495bSYour Name  *
2363*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS if the request is successfully sent
2364*5113495bSYour Name  * to firmware for processing, otherwise an error status.
2365*5113495bSYour Name  */
2366*5113495bSYour Name QDF_STATUS sme_get_sar_power_limits(mac_handle_t mac_handle,
2367*5113495bSYour Name 				    wma_sar_cb callback, void *context);
2368*5113495bSYour Name 
2369*5113495bSYour Name /**
2370*5113495bSYour Name  * sme_set_sar_power_limits() - set sar limits
2371*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2372*5113495bSYour Name  * @sar_limit_cmd: struct to send sar limit cmd.
2373*5113495bSYour Name  *
2374*5113495bSYour Name  * Return: QDF_STATUS enumeration.
2375*5113495bSYour Name  */
2376*5113495bSYour Name QDF_STATUS sme_set_sar_power_limits(mac_handle_t mac_handle,
2377*5113495bSYour Name 		struct sar_limit_cmd_params *sar_limit_cmd);
2378*5113495bSYour Name 
2379*5113495bSYour Name /**
2380*5113495bSYour Name  * sme_send_coex_config_cmd() - Send COEX config params
2381*5113495bSYour Name  * @coex_cfg_params: struct to coex config params
2382*5113495bSYour Name  *
2383*5113495bSYour Name  * Return: QDF_STATUS
2384*5113495bSYour Name  */
2385*5113495bSYour Name QDF_STATUS sme_send_coex_config_cmd(struct coex_config_params *coex_cfg_params);
2386*5113495bSYour Name 
2387*5113495bSYour Name #ifdef WLAN_FEATURE_WOW_PULSE
2388*5113495bSYour Name QDF_STATUS sme_set_wow_pulse(struct wow_pulse_mode *wow_pulse_set_info);
2389*5113495bSYour Name #endif
2390*5113495bSYour Name 
2391*5113495bSYour Name /* ARP DEBUG STATS */
2392*5113495bSYour Name QDF_STATUS sme_set_nud_debug_stats(mac_handle_t mac_handle,
2393*5113495bSYour Name 				   struct set_arp_stats_params
2394*5113495bSYour Name 				   *set_stats_param);
2395*5113495bSYour Name QDF_STATUS sme_get_nud_debug_stats(mac_handle_t mac_handle,
2396*5113495bSYour Name 				   struct get_arp_stats_params
2397*5113495bSYour Name 				   *get_stats_param);
2398*5113495bSYour Name QDF_STATUS sme_set_nud_debug_stats_cb(mac_handle_t mac_handle,
2399*5113495bSYour Name 			void (*cb)(void *, struct rsp_stats *, void *context),
2400*5113495bSYour Name 			void *context);
2401*5113495bSYour Name 
2402*5113495bSYour Name /**
2403*5113495bSYour Name  * sme_set_del_peers_ind_callback() - Register del peers ind callback
2404*5113495bSYour Name  * @mac_handle - MAC global handle
2405*5113495bSYour Name  * @callback_routine - callback routine from HDD
2406*5113495bSYour Name  *
2407*5113495bSYour Name  * This API is invoked by HDD to register its callback to mac
2408*5113495bSYour Name  *
2409*5113495bSYour Name  * Return: QDF_STATUS
2410*5113495bSYour Name  */
2411*5113495bSYour Name void
2412*5113495bSYour Name sme_set_del_peers_ind_callback(mac_handle_t mac_handle,
2413*5113495bSYour Name 			       void (*callback)(struct wlan_objmgr_psoc *psoc,
2414*5113495bSYour Name 						uint8_t vdev_id));
2415*5113495bSYour Name 
2416*5113495bSYour Name /**
2417*5113495bSYour Name  * sme_set_chan_info_callback() - Register chan info callback
2418*5113495bSYour Name  * @mac_handle - MAC global handle
2419*5113495bSYour Name  * @callback_routine - callback routine from HDD
2420*5113495bSYour Name  *
2421*5113495bSYour Name  * This API is invoked by HDD to register its callback to mac
2422*5113495bSYour Name  *
2423*5113495bSYour Name  * Return: QDF_STATUS
2424*5113495bSYour Name  */
2425*5113495bSYour Name void sme_set_chan_info_callback(mac_handle_t mac_handle,
2426*5113495bSYour Name 			void (*callback)(struct scan_chan_info *chan_info));
2427*5113495bSYour Name 
2428*5113495bSYour Name #ifdef WLAN_FEATURE_CAL_FAILURE_TRIGGER
2429*5113495bSYour Name /**
2430*5113495bSYour Name  * sme_set_cal_failure_event_cb() - Register calibration failure event callback
2431*5113495bSYour Name  * @mac_handle - MAC global handle
2432*5113495bSYour Name  * @callback   - calibration failure event callback from HDD
2433*5113495bSYour Name  *
2434*5113495bSYour Name  * This API is invoked by HDD to register its callback to mac
2435*5113495bSYour Name  *
2436*5113495bSYour Name  * Return: None
2437*5113495bSYour Name  */
2438*5113495bSYour Name void sme_set_cal_failure_event_cb(
2439*5113495bSYour Name 			mac_handle_t mac_handle,
2440*5113495bSYour Name 			void (*callback)(uint8_t cal_type, uint8_t reason));
2441*5113495bSYour Name #else
2442*5113495bSYour Name static inline void
sme_set_cal_failure_event_cb(mac_handle_t mac_handle,void (* callback)(uint8_t cal_type,uint8_t reason))2443*5113495bSYour Name sme_set_cal_failure_event_cb(mac_handle_t mac_handle,
2444*5113495bSYour Name 			     void (*callback)(uint8_t cal_type, uint8_t reason))
2445*5113495bSYour Name {
2446*5113495bSYour Name }
2447*5113495bSYour Name #endif
2448*5113495bSYour Name 
2449*5113495bSYour Name /**
2450*5113495bSYour Name  * sme_get_rssi_snr_by_bssid() - gets the rssi and snr by bssid from scan cache
2451*5113495bSYour Name  * @mac_handle: handle returned by mac_open
2452*5113495bSYour Name  * @bssid: bssid to look for in scan cache
2453*5113495bSYour Name  * @rssi: rssi value found
2454*5113495bSYour Name  * @snr: snr value found
2455*5113495bSYour Name  *
2456*5113495bSYour Name  * Return: QDF_STATUS
2457*5113495bSYour Name  */
2458*5113495bSYour Name QDF_STATUS sme_get_rssi_snr_by_bssid(mac_handle_t mac_handle,
2459*5113495bSYour Name 				     const uint8_t *bssid, int8_t *rssi,
2460*5113495bSYour Name 				     int8_t *snr);
2461*5113495bSYour Name 
2462*5113495bSYour Name /**
2463*5113495bSYour Name  * sme_register_tx_queue_cb(): Register tx queue callback
2464*5113495bSYour Name  * @mac_handle: Opaque handle for MAC context
2465*5113495bSYour Name  * @tx_queue_cb: Transmit Queues callback
2466*5113495bSYour Name  *
2467*5113495bSYour Name  * Return: QDF_STATUS
2468*5113495bSYour Name  */
2469*5113495bSYour Name QDF_STATUS sme_register_tx_queue_cb(mac_handle_t mac_handle,
2470*5113495bSYour Name 				    tx_queue_cb tx_queue_cb);
2471*5113495bSYour Name 
2472*5113495bSYour Name /**
2473*5113495bSYour Name  * sme_deregister_tx_queue_cb() - Deregister the tx queue callback
2474*5113495bSYour Name  * @mac_handle: Opaque handle for MAC context
2475*5113495bSYour Name  *
2476*5113495bSYour Name  * Return: QDF status
2477*5113495bSYour Name  */
2478*5113495bSYour Name QDF_STATUS sme_deregister_tx_queue_cb(mac_handle_t mac_handle);
2479*5113495bSYour Name 
2480*5113495bSYour Name /**
2481*5113495bSYour Name  * sme_rso_cmd_status_cb() - Set RSO cmd status callback
2482*5113495bSYour Name  * @mac_handle: Opaque handle for the MAC context
2483*5113495bSYour Name  * @cb: HDD Callback to rso command status read
2484*5113495bSYour Name  *
2485*5113495bSYour Name  * This function is used to save HDD RSO Command status callback in MAC
2486*5113495bSYour Name  *
2487*5113495bSYour Name  * Return: QDF_STATUS
2488*5113495bSYour Name  */
2489*5113495bSYour Name QDF_STATUS sme_rso_cmd_status_cb(mac_handle_t mac_handle,
2490*5113495bSYour Name 				 rso_cmd_status_cb cb);
2491*5113495bSYour Name 
2492*5113495bSYour Name /**
2493*5113495bSYour Name  * sme_register_set_connection_info_cb() - Register connection
2494*5113495bSYour Name  * info callback
2495*5113495bSYour Name  * @mac_handle - MAC global handle
2496*5113495bSYour Name  * @set_connection_info_cb - callback routine from HDD to set
2497*5113495bSYour Name  *                   connection info flag
2498*5113495bSYour Name  * @get_connection_info_cb - callback routine from HDD to get
2499*5113495bSYour Name  *                         connection info
2500*5113495bSYour Name  *
2501*5113495bSYour Name  * This API is invoked by HDD to register its callback to mac
2502*5113495bSYour Name  *
2503*5113495bSYour Name  * Return: QDF_STATUS
2504*5113495bSYour Name  */
2505*5113495bSYour Name QDF_STATUS sme_register_set_connection_info_cb(mac_handle_t mac_handle,
2506*5113495bSYour Name 				bool (*set_connection_info_cb)(bool),
2507*5113495bSYour Name 				bool (*get_connection_info_cb)(uint8_t *session_id,
2508*5113495bSYour Name 				enum scan_reject_states *reason));
2509*5113495bSYour Name 
2510*5113495bSYour Name /**
2511*5113495bSYour Name  * sme_set_dbs_scan_selection_config() - Update DBS scan selection
2512*5113495bSYour Name  * configuration
2513*5113495bSYour Name  * @mac_handle: The handle returned by macOpen
2514*5113495bSYour Name  * @params: wmi_dbs_scan_sel_params config
2515*5113495bSYour Name  *
2516*5113495bSYour Name  * Return: QDF_STATUS if DBS scan selection update
2517*5113495bSYour Name  * configuration success else failure status
2518*5113495bSYour Name  */
2519*5113495bSYour Name QDF_STATUS sme_set_dbs_scan_selection_config(mac_handle_t mac_handle,
2520*5113495bSYour Name 		struct wmi_dbs_scan_sel_params *params);
2521*5113495bSYour Name 
2522*5113495bSYour Name /**
2523*5113495bSYour Name  * sme_store_pdev() - store pdev
2524*5113495bSYour Name  * @mac_handle - MAC global handle
2525*5113495bSYour Name  * @pdev - pdev ptr
2526*5113495bSYour Name  *
2527*5113495bSYour Name  * Return: QDF_STATUS
2528*5113495bSYour Name  */
2529*5113495bSYour Name void sme_store_pdev(mac_handle_t mac_handle, struct wlan_objmgr_pdev *pdev);
2530*5113495bSYour Name 
2531*5113495bSYour Name /**
2532*5113495bSYour Name  * sme_set_reorder_timeout() - set reorder timeout value
2533*5113495bSYour Name  * including Voice,Video,Besteffort,Background parameters
2534*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2535*5113495bSYour Name  * @reg: struct sir_set_rx_reorder_timeout_val
2536*5113495bSYour Name  *
2537*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure.
2538*5113495bSYour Name  */
2539*5113495bSYour Name QDF_STATUS sme_set_reorder_timeout(mac_handle_t mac_handle,
2540*5113495bSYour Name 		struct sir_set_rx_reorder_timeout_val *req);
2541*5113495bSYour Name 
2542*5113495bSYour Name /**
2543*5113495bSYour Name  * sme_set_rx_set_blocksize() - set blocksize value
2544*5113495bSYour Name  * including mac_addr and win_limit parameters
2545*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2546*5113495bSYour Name  * @reg: struct sir_peer_set_rx_blocksize
2547*5113495bSYour Name  *
2548*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure.
2549*5113495bSYour Name  */
2550*5113495bSYour Name 
2551*5113495bSYour Name QDF_STATUS sme_set_rx_set_blocksize(mac_handle_t mac_handle,
2552*5113495bSYour Name 				    struct sir_peer_set_rx_blocksize *req);
2553*5113495bSYour Name 
2554*5113495bSYour Name /**
2555*5113495bSYour Name  * sme_get_rcpi() - gets the rcpi value for peer mac addr
2556*5113495bSYour Name  * @mac_handle: handle returned by mac_open
2557*5113495bSYour Name  * @rcpi: rcpi request containing peer mac addr, callback and related info
2558*5113495bSYour Name  *
2559*5113495bSYour Name  * This function posts the rcpi measurement request message to wma queue
2560*5113495bSYour Name  *
2561*5113495bSYour Name  * Return: QDF_STATUS
2562*5113495bSYour Name  */
2563*5113495bSYour Name QDF_STATUS sme_get_rcpi(mac_handle_t mac_handle, struct sme_rcpi_req *rcpi);
2564*5113495bSYour Name 
2565*5113495bSYour Name /**
2566*5113495bSYour Name  * sme_set_chip_pwr_save_fail_cb() - set chip power save failure callback
2567*5113495bSYour Name  * @mac_handle: opaque handle to the MAC context
2568*5113495bSYour Name  * @cb: callback function pointer
2569*5113495bSYour Name  *
2570*5113495bSYour Name  * This function stores the chip power save failure callback function.
2571*5113495bSYour Name  *
2572*5113495bSYour Name  * Return: QDF_STATUS enumeration.
2573*5113495bSYour Name  */
2574*5113495bSYour Name 
2575*5113495bSYour Name QDF_STATUS sme_set_chip_pwr_save_fail_cb(mac_handle_t mac_handle,
2576*5113495bSYour Name 					 pwr_save_fail_cb cb);
2577*5113495bSYour Name /**
2578*5113495bSYour Name  * sme_cli_set_command() - SME wrapper API over WMA "set" command
2579*5113495bSYour Name  * processor cmd
2580*5113495bSYour Name  * @vdev_id: virtual device for the command
2581*5113495bSYour Name  * @param_id: parameter id
2582*5113495bSYour Name  * @sval: parameter value
2583*5113495bSYour Name  * @vpdev: parameter category
2584*5113495bSYour Name  *
2585*5113495bSYour Name  * Command handler for set operations
2586*5113495bSYour Name  *
2587*5113495bSYour Name  * Return: 0 on success, errno on failure
2588*5113495bSYour Name  */
2589*5113495bSYour Name int sme_cli_set_command(int vdev_id, int param_id, int sval, int vpdev);
2590*5113495bSYour Name 
2591*5113495bSYour Name /**
2592*5113495bSYour Name  * sme_set_bt_activity_info_cb - set the callback handler for bt events
2593*5113495bSYour Name  * @mac_handle: handle returned by mac_open
2594*5113495bSYour Name  * @cb: callback handler
2595*5113495bSYour Name  *
2596*5113495bSYour Name  * Return: QDF_STATUS
2597*5113495bSYour Name  */
2598*5113495bSYour Name QDF_STATUS sme_set_bt_activity_info_cb(mac_handle_t mac_handle,
2599*5113495bSYour Name 				       bt_activity_info_cb cb);
2600*5113495bSYour Name 
2601*5113495bSYour Name /**
2602*5113495bSYour Name  * sme_set_enable_mem_deep_sleep - set the mem deep sleep config to FW
2603*5113495bSYour Name  * @mac_handle: handle returned by mac_open
2604*5113495bSYour Name  * @vdev_id: vdev id
2605*5113495bSYour Name  *
2606*5113495bSYour Name  * Return: 0 for success else failure code
2607*5113495bSYour Name  */
2608*5113495bSYour Name int sme_set_enable_mem_deep_sleep(mac_handle_t mac_handle, int vdev_id);
2609*5113495bSYour Name 
2610*5113495bSYour Name /**
2611*5113495bSYour Name  * sme_set_cck_tx_fir_override - set the CCK TX FIR Override to FW
2612*5113495bSYour Name  * @mac_handle: handle returned by mac_open
2613*5113495bSYour Name  * @vdev_id: vdev id
2614*5113495bSYour Name  *
2615*5113495bSYour Name  * Return: 0 for success else failure code
2616*5113495bSYour Name  */
2617*5113495bSYour Name int sme_set_cck_tx_fir_override(mac_handle_t mac_handle, int vdev_id);
2618*5113495bSYour Name 
2619*5113495bSYour Name /**
2620*5113495bSYour Name  * sme_set_smps_cfg() - set SMPS config params
2621*5113495bSYour Name  * @vdev_id: virtual device for the command
2622*5113495bSYour Name  * @param_id: parameter id
2623*5113495bSYour Name  * @param_val: parameter value
2624*5113495bSYour Name  *
2625*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure
2626*5113495bSYour Name  */
2627*5113495bSYour Name 
2628*5113495bSYour Name QDF_STATUS sme_set_smps_cfg(uint32_t vdev_id, uint32_t param_id,
2629*5113495bSYour Name 				uint32_t param_val);
2630*5113495bSYour Name 
2631*5113495bSYour Name /**
2632*5113495bSYour Name  * sme_get_chain_rssi() - Get chain rssi
2633*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2634*5113495bSYour Name  * @input: get chain rssi req params
2635*5113495bSYour Name  * @callback: Callback function to be called with the result
2636*5113495bSYour Name  * @context: Opaque context to be used by the caller to associate the
2637*5113495bSYour Name  *   request with the response
2638*5113495bSYour Name  *
2639*5113495bSYour Name  * This function constructs the cds message and fill in message type,
2640*5113495bSYour Name  * post the same to WDA.
2641*5113495bSYour Name  *
2642*5113495bSYour Name  * Return: QDF_STATUS enumeration
2643*5113495bSYour Name  */
2644*5113495bSYour Name QDF_STATUS sme_get_chain_rssi(mac_handle_t mac_handle,
2645*5113495bSYour Name 			      struct get_chain_rssi_req_params *input,
2646*5113495bSYour Name 			      get_chain_rssi_callback callback,
2647*5113495bSYour Name 			      void *context);
2648*5113495bSYour Name 
2649*5113495bSYour Name /**
2650*5113495bSYour Name  * sme_get_isolation() - sme api to get antenna isolation
2651*5113495bSYour Name  * @mac_handle: hal handle for getting global mac struct
2652*5113495bSYour Name  * @context: context of callback function
2653*5113495bSYour Name  * @callbackfn: hdd callback function when receive response
2654*5113495bSYour Name  *
2655*5113495bSYour Name  * This function will send WMA_GET_ISOLATION to WMA
2656*5113495bSYour Name  *
2657*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure
2658*5113495bSYour Name  */
2659*5113495bSYour Name QDF_STATUS sme_get_isolation(mac_handle_t mac_handle,
2660*5113495bSYour Name 			     void *context,
2661*5113495bSYour Name 			     sme_get_isolation_cb callbackfn);
2662*5113495bSYour Name 
2663*5113495bSYour Name #ifdef FEATURE_FW_STATE
2664*5113495bSYour Name /**
2665*5113495bSYour Name  * sme_get_fw_state() - Get fw state
2666*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2667*5113495bSYour Name  * @callback: Callback function to be called with the result
2668*5113495bSYour Name  * @context: Opaque context to be used by the caller to associate the
2669*5113495bSYour Name  *   request with the response
2670*5113495bSYour Name  *
2671*5113495bSYour Name  * This function constructs the cds message and fill in message type,
2672*5113495bSYour Name  * post the same to WDA.
2673*5113495bSYour Name  *
2674*5113495bSYour Name  * Return: QDF_STATUS enumeration
2675*5113495bSYour Name  */
2676*5113495bSYour Name QDF_STATUS sme_get_fw_state(mac_handle_t mac_handle,
2677*5113495bSYour Name 			    fw_state_callback callback,
2678*5113495bSYour Name 			    void *context);
2679*5113495bSYour Name #endif /* FEATURE_FW_STATE */
2680*5113495bSYour Name 
2681*5113495bSYour Name /**
2682*5113495bSYour Name  * sme_get_mac_context() - sme api to get the pmac context
2683*5113495bSYour Name  *
2684*5113495bSYour Name  * This function will return the pmac context
2685*5113495bSYour Name  *
2686*5113495bSYour Name  * Return: pointer to pmac context
2687*5113495bSYour Name  */
2688*5113495bSYour Name struct mac_context *sme_get_mac_context(void);
2689*5113495bSYour Name 
2690*5113495bSYour Name /**
2691*5113495bSYour Name  * sme_display_disconnect_stats() - Display per session Disconnect stats
2692*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2693*5113495bSYour Name  * session_id: SME session id
2694*5113495bSYour Name  *
2695*5113495bSYour Name  * Return: None
2696*5113495bSYour Name  */
2697*5113495bSYour Name void sme_display_disconnect_stats(mac_handle_t mac_handle, uint8_t session_id);
2698*5113495bSYour Name 
2699*5113495bSYour Name #ifdef WLAN_FEATURE_MSCS
2700*5113495bSYour Name /**
2701*5113495bSYour Name  * sme_send_mscs_action_frame() - Send MSCS action frame
2702*5113495bSYour Name  * @vdev_id: sme vdev_id
2703*5113495bSYour Name  *
2704*5113495bSYour Name  * This function is used to send down the mscs request to PE
2705*5113495bSYour Name  *
2706*5113495bSYour Name  * Return: None
2707*5113495bSYour Name  */
2708*5113495bSYour Name void sme_send_mscs_action_frame(uint8_t vdev_id);
2709*5113495bSYour Name #endif
2710*5113495bSYour Name 
2711*5113495bSYour Name /**
2712*5113495bSYour Name  * sme_process_msg_callback() - process callback message from LIM
2713*5113495bSYour Name  * @mac: global mac context
2714*5113495bSYour Name  * @msg: scheduler message
2715*5113495bSYour Name  *
2716*5113495bSYour Name  * This function process the callback messages from LIM.
2717*5113495bSYour Name  *
2718*5113495bSYour Name  * Return: QDF_STATUS enumeration.
2719*5113495bSYour Name  */
2720*5113495bSYour Name QDF_STATUS sme_process_msg_callback(struct mac_context *mac,
2721*5113495bSYour Name 				    struct scheduler_msg *msg);
2722*5113495bSYour Name 
2723*5113495bSYour Name /**
2724*5113495bSYour Name  * sme_set_bmiss_bcnt() - set bmiss config parameters
2725*5113495bSYour Name  * @vdev_id: virtual device for the command
2726*5113495bSYour Name  * @first_cnt: bmiss first value
2727*5113495bSYour Name  * @final_cnt: bmiss final value
2728*5113495bSYour Name  *
2729*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure
2730*5113495bSYour Name  */
2731*5113495bSYour Name QDF_STATUS sme_set_bmiss_bcnt(uint32_t vdev_id, uint32_t first_cnt,
2732*5113495bSYour Name 		uint32_t final_cnt);
2733*5113495bSYour Name 
2734*5113495bSYour Name /**
2735*5113495bSYour Name  * sme_send_limit_off_channel_params() - send limit off channel parameters
2736*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2737*5113495bSYour Name  * @vdev_id: vdev id
2738*5113495bSYour Name  * @is_tos_active: tos active or inactive
2739*5113495bSYour Name  * @max_off_chan_time: max off channel time
2740*5113495bSYour Name  * @rest_time: rest time
2741*5113495bSYour Name  * @skip_dfs_chan: skip dfs channel
2742*5113495bSYour Name  *
2743*5113495bSYour Name  * This function sends command to WMA for setting limit off channel command
2744*5113495bSYour Name  * parameters.
2745*5113495bSYour Name  *
2746*5113495bSYour Name  * Return: QDF_STATUS enumeration.
2747*5113495bSYour Name  */
2748*5113495bSYour Name QDF_STATUS sme_send_limit_off_channel_params(mac_handle_t mac_handle,
2749*5113495bSYour Name 					     uint8_t vdev_id,
2750*5113495bSYour Name 					     bool is_tos_active,
2751*5113495bSYour Name 					     uint32_t max_off_chan_time,
2752*5113495bSYour Name 					     uint32_t rest_time,
2753*5113495bSYour Name 					     bool skip_dfs_chan);
2754*5113495bSYour Name 
2755*5113495bSYour Name #ifdef FEATURE_WLAN_DYNAMIC_CVM
2756*5113495bSYour Name /**
2757*5113495bSYour Name  * sme_set_vc_mode_config() - Set voltage corner config to FW.
2758*5113495bSYour Name  * @bitmap:	Bitmap that refers to voltage corner config with
2759*5113495bSYour Name  * different phymode and bw configuration
2760*5113495bSYour Name  *
2761*5113495bSYour Name  * Return: QDF_STATUS
2762*5113495bSYour Name  */
2763*5113495bSYour Name QDF_STATUS sme_set_vc_mode_config(uint32_t vc_bitmap);
2764*5113495bSYour Name #endif
2765*5113495bSYour Name 
2766*5113495bSYour Name /**
2767*5113495bSYour Name  * sme_set_del_pmkid_cache() - API to update PMKID cache
2768*5113495bSYour Name  * @psoc: psoc common object
2769*5113495bSYour Name  * @session_id: Session id
2770*5113495bSYour Name  * @pmk_cache_info: Pointer to PMK cache info
2771*5113495bSYour Name  * @is_add: boolean that implies whether to add or delete PMKID entry
2772*5113495bSYour Name  *
2773*5113495bSYour Name  * Return: QDF_STATUS
2774*5113495bSYour Name  */
2775*5113495bSYour Name QDF_STATUS sme_set_del_pmkid_cache(struct wlan_objmgr_psoc *psoc,
2776*5113495bSYour Name 				   uint8_t session_id,
2777*5113495bSYour Name 				   struct wlan_crypto_pmksa *pmk_cache_info,
2778*5113495bSYour Name 				   bool is_add);
2779*5113495bSYour Name 
2780*5113495bSYour Name /**
2781*5113495bSYour Name  * sme_clear_sae_single_pmk_info() - Clear sae_single_pmk onfo
2782*5113495bSYour Name  * @psoc: Psoc object
2783*5113495bSYour Name  * @session_id: session id
2784*5113495bSYour Name  * @pmk_cache_info: pmk cache info
2785*5113495bSYour Name  *
2786*5113495bSYour Name  * This function will clear sae_single_pmk info while processing delete pmk
2787*5113495bSYour Name  * command from userspace.
2788*5113495bSYour Name  *
2789*5113495bSYour Name  * Return: None
2790*5113495bSYour Name  */
2791*5113495bSYour Name void sme_clear_sae_single_pmk_info(struct wlan_objmgr_psoc *psoc,
2792*5113495bSYour Name 				   uint8_t session_id,
2793*5113495bSYour Name 				   struct wlan_crypto_pmksa *pmk_cache_info);
2794*5113495bSYour Name 
2795*5113495bSYour Name /**
2796*5113495bSYour Name  * sme_send_hlp_ie_info() - API to send HLP IE info to fw
2797*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2798*5113495bSYour Name  * @vdev_id: vdev id
2799*5113495bSYour Name  * @if_addr: IP address
2800*5113495bSYour Name  *
2801*5113495bSYour Name  * This API is used to send HLP IE info along with IP address
2802*5113495bSYour Name  * to fw if LFR3 is enabled.
2803*5113495bSYour Name  *
2804*5113495bSYour Name  * Return: None
2805*5113495bSYour Name  */
2806*5113495bSYour Name void sme_send_hlp_ie_info(mac_handle_t mac_handle, uint8_t vdev_id,
2807*5113495bSYour Name 			  uint32_t if_addr);
2808*5113495bSYour Name 
2809*5113495bSYour Name /**
2810*5113495bSYour Name  * sme_send_rso_connect_params() - Updates the assoc IEs to csr_roam_session
2811*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2812*5113495bSYour Name  * @vdev_id: vdev id
2813*5113495bSYour Name  *
2814*5113495bSYour Name  * When the user space updates the assoc IEs or FILS auth type or FILS ERP info,
2815*5113495bSYour Name  * host driver needs to send these updated parameters to firmware via
2816*5113495bSYour Name  * RSO update command.
2817*5113495bSYour Name  *
2818*5113495bSYour Name  * Return: None
2819*5113495bSYour Name  */
2820*5113495bSYour Name QDF_STATUS sme_send_rso_connect_params(mac_handle_t mac_handle,
2821*5113495bSYour Name 				       uint8_t vdev_id);
2822*5113495bSYour Name 
2823*5113495bSYour Name #ifdef WLAN_FEATURE_11AX_BSS_COLOR
2824*5113495bSYour Name /**
2825*5113495bSYour Name  * sme_set_he_bss_color() - Sets the HE BSS color
2826*5113495bSYour Name  *
2827*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
2828*5113495bSYour Name  * @session_id: session_id of the request
2829*5113495bSYour Name  * @bss_color: HE BSS color value to set
2830*5113495bSYour Name  *
2831*5113495bSYour Name  * Return: QDF_STATUS
2832*5113495bSYour Name  */
2833*5113495bSYour Name QDF_STATUS sme_set_he_bss_color(mac_handle_t mac_handle, uint8_t session_id,
2834*5113495bSYour Name 				uint8_t bss_color);
2835*5113495bSYour Name /**
2836*5113495bSYour Name  * sme_reconfig_obss_scan_param() - reconfig obss scan param
2837*5113495bSYour Name  *
2838*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
2839*5113495bSYour Name  * @session_id: session_id of the request
2840*5113495bSYour Name  * @is_scan_reconfig: true if modify OBSS scan periodicity, otherwise false
2841*5113495bSYour Name  *
2842*5113495bSYour Name  * Return: QDF_STATUS
2843*5113495bSYour Name  */
2844*5113495bSYour Name QDF_STATUS sme_reconfig_obss_scan_param(mac_handle_t mac_handle,
2845*5113495bSYour Name 					uint8_t session_id,
2846*5113495bSYour Name 					bool is_scan_reconfig);
2847*5113495bSYour Name #else
2848*5113495bSYour Name static inline
sme_set_he_bss_color(mac_handle_t mac_handle,uint8_t session_id,uint8_t bss_color)2849*5113495bSYour Name QDF_STATUS sme_set_he_bss_color(mac_handle_t mac_handle, uint8_t session_id,
2850*5113495bSYour Name 				uint8_t bss_color)
2851*5113495bSYour Name {
2852*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
2853*5113495bSYour Name }
2854*5113495bSYour Name 
2855*5113495bSYour Name static inline
sme_reconfig_obss_scan_param(mac_handle_t mac_handle,uint8_t session_id,bool is_scan_reconfig)2856*5113495bSYour Name QDF_STATUS sme_reconfig_obss_scan_param(mac_handle_t mac_handle,
2857*5113495bSYour Name 					uint8_t session_id,
2858*5113495bSYour Name 					bool is_scan_reconfig)
2859*5113495bSYour Name {
2860*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
2861*5113495bSYour Name }
2862*5113495bSYour Name #endif
2863*5113495bSYour Name 
2864*5113495bSYour Name /**
2865*5113495bSYour Name  * sme_is_conn_state_connected() -- check if SME connection state is connected
2866*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
2867*5113495bSYour Name  * @session_id: current Session Id
2868*5113495bSYour Name  *
2869*5113495bSYour Name  * This API checks if the current SME connection state is connected for the
2870*5113495bSYour Name  * given session id.
2871*5113495bSYour Name  *
2872*5113495bSYour Name  * Return: True if connected, false if any other state.
2873*5113495bSYour Name  */
2874*5113495bSYour Name bool sme_is_conn_state_connected(mac_handle_t mac_handle, uint8_t session_id);
2875*5113495bSYour Name 
2876*5113495bSYour Name /**
2877*5113495bSYour Name  * sme_get_bss_transition_status() - get bss transition status all candidates
2878*5113495bSYour Name  * @mac_handle: handle returned by mac_open
2879*5113495bSYour Name  * @transition_reason : Transition reason
2880*5113495bSYour Name  * @bssid: bssid to get BSS transition status
2881*5113495bSYour Name  * @info : bss candidate information
2882*5113495bSYour Name  * @n_candidates : number of candidates
2883*5113495bSYour Name  * @is_bt_in_progress: bt activity indicator
2884*5113495bSYour Name  *
2885*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on success otherwise a QDF_STATUS error
2886*5113495bSYour Name  */
2887*5113495bSYour Name QDF_STATUS sme_get_bss_transition_status(mac_handle_t mac_handle,
2888*5113495bSYour Name 					 uint8_t transition_reason,
2889*5113495bSYour Name 					 struct qdf_mac_addr *bssid,
2890*5113495bSYour Name 					 struct bss_candidate_info *info,
2891*5113495bSYour Name 					 uint16_t n_candidates,
2892*5113495bSYour Name 					 bool is_bt_in_progress);
2893*5113495bSYour Name 
2894*5113495bSYour Name /**
2895*5113495bSYour Name  * sme_unpack_rsn_ie: wrapper to unpack RSN IE and update def RSN params
2896*5113495bSYour Name  * if optional fields are not present.
2897*5113495bSYour Name  * @mac_handle: handle returned by mac_open
2898*5113495bSYour Name  * @buf: rsn ie buffer pointer
2899*5113495bSYour Name  * @buf_len: rsn ie buffer length
2900*5113495bSYour Name  * @rsn_ie: outframe rsn ie structure
2901*5113495bSYour Name  * @append_ie: flag to indicate if the rsn_ie need to be appended from buf
2902*5113495bSYour Name  *
2903*5113495bSYour Name  * Return: parse status
2904*5113495bSYour Name  */
2905*5113495bSYour Name uint32_t sme_unpack_rsn_ie(mac_handle_t mac_handle, uint8_t *buf,
2906*5113495bSYour Name 			   uint8_t buf_len, tDot11fIERSN *rsn_ie,
2907*5113495bSYour Name 			   bool append_ie);
2908*5113495bSYour Name 
2909*5113495bSYour Name /**
2910*5113495bSYour Name  * sme_unpack_assoc_rsp() - wrapper to unpack assoc response
2911*5113495bSYour Name  * @mac_handle: handle returned by mac_open
2912*5113495bSYour Name  * @rsp: Pointer to connect rsp
2913*5113495bSYour Name  * @assoc_resp: output assoc response structure
2914*5113495bSYour Name  *
2915*5113495bSYour Name  * Return: parse status
2916*5113495bSYour Name  */
2917*5113495bSYour Name QDF_STATUS sme_unpack_assoc_rsp(mac_handle_t mac_handle,
2918*5113495bSYour Name 				struct wlan_cm_connect_resp *rsp,
2919*5113495bSYour Name 				struct sDot11fAssocResponse *assoc_resp);
2920*5113495bSYour Name 
2921*5113495bSYour Name /**
2922*5113495bSYour Name  * sme_get_hs20vendor_ie() - wrapper to unpack beacon/probe response
2923*5113495bSYour Name  * @mac_handle: handle returned by mac_open
2924*5113495bSYour Name  * @frame: beacon/probe response response buffer pointer
2925*5113495bSYour Name  * @frame_len: beacone probe/ response buffer length
2926*5113495bSYour Name  * @hs20vendor_ie: output hs20vendor_ie structure
2927*5113495bSYour Name  *
2928*5113495bSYour Name  * Return: None
2929*5113495bSYour Name  */
2930*5113495bSYour Name void sme_get_hs20vendor_ie(mac_handle_t mac_handle, uint8_t *frame,
2931*5113495bSYour Name 			   uint32_t frame_len,
2932*5113495bSYour Name 			   tDot11fIEhs20vendor_ie *hs20vendor_ie);
2933*5113495bSYour Name 
2934*5113495bSYour Name /**
2935*5113495bSYour Name  * sme_add_qcn_ie: Adds QCN IE data to IE buffer
2936*5113495bSYour Name  * @mac_handle: handle returned by mac_open
2937*5113495bSYour Name  * @ie_data: ie buffer pointer
2938*5113495bSYour Name  * @ie_len: ie length pointer
2939*5113495bSYour Name  *
2940*5113495bSYour Name  * Return: none
2941*5113495bSYour Name  */
2942*5113495bSYour Name void sme_add_qcn_ie(mac_handle_t mac_handle, uint8_t *ie_data,
2943*5113495bSYour Name 		    uint16_t *ie_len);
2944*5113495bSYour Name 
2945*5113495bSYour Name /**
2946*5113495bSYour Name  * sme_get_oper_chan_freq - gets the operating channel freq
2947*5113495bSYour Name  * @vdev: vdev handle
2948*5113495bSYour Name  *
2949*5113495bSYour Name  * Return: operating channel frequency
2950*5113495bSYour Name  */
2951*5113495bSYour Name int16_t sme_get_oper_chan_freq(struct wlan_objmgr_vdev *vdev);
2952*5113495bSYour Name 
2953*5113495bSYour Name /**
2954*5113495bSYour Name  * sme_get_oper_ch_width - gets the operating channel width
2955*5113495bSYour Name  * @vdev: vdev handle
2956*5113495bSYour Name  *
2957*5113495bSYour Name  * Return: operating channel width
2958*5113495bSYour Name  */
2959*5113495bSYour Name enum phy_ch_width sme_get_oper_ch_width(struct wlan_objmgr_vdev *vdev);
2960*5113495bSYour Name 
2961*5113495bSYour Name /**
2962*5113495bSYour Name  * sme_get_oper_ch_width - gets the secondary channel frequency
2963*5113495bSYour Name  * @vdev: vdev handle
2964*5113495bSYour Name  * @sec20chan_freq: secondary channel frequency
2965*5113495bSYour Name  *
2966*5113495bSYour Name  * Return: secondary channel frequency
2967*5113495bSYour Name  */
2968*5113495bSYour Name int sme_get_sec20chan_freq_mhz(struct wlan_objmgr_vdev *vdev,
2969*5113495bSYour Name 						uint16_t *sec20chan_freq);
2970*5113495bSYour Name 
2971*5113495bSYour Name /**
2972*5113495bSYour Name  * sme_send_mgmt_tx() - Sends mgmt frame from CSR to LIM
2973*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
2974*5113495bSYour Name  * @session_id: session id
2975*5113495bSYour Name  * @buf: pointer to frame
2976*5113495bSYour Name  * @len: frame length
2977*5113495bSYour Name  *
2978*5113495bSYour Name  * Return: QDF_STATUS
2979*5113495bSYour Name  */
2980*5113495bSYour Name QDF_STATUS sme_send_mgmt_tx(mac_handle_t mac_handle, uint8_t session_id,
2981*5113495bSYour Name 			    const uint8_t *buf, uint32_t len);
2982*5113495bSYour Name 
2983*5113495bSYour Name #ifdef WLAN_FEATURE_SAE
2984*5113495bSYour Name /**
2985*5113495bSYour Name  * sme_handle_sae_msg() - Sends SAE message received from supplicant
2986*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
2987*5113495bSYour Name  * @session_id: session id
2988*5113495bSYour Name  * @sae_status: status of SAE authentication
2989*5113495bSYour Name  * @peer_mac_addr: mac address of the peer to be authenticated
2990*5113495bSYour Name  * @pmkid: PMKID derived at the end of SAE authentication
2991*5113495bSYour Name  *
2992*5113495bSYour Name  * Return: QDF_STATUS
2993*5113495bSYour Name  */
2994*5113495bSYour Name QDF_STATUS sme_handle_sae_msg(mac_handle_t mac_handle,
2995*5113495bSYour Name 			      uint8_t session_id,
2996*5113495bSYour Name 			      uint8_t sae_status,
2997*5113495bSYour Name 			      struct qdf_mac_addr peer_mac_addr,
2998*5113495bSYour Name 			      const uint8_t *pmkid);
2999*5113495bSYour Name #else
3000*5113495bSYour Name static inline
sme_handle_sae_msg(mac_handle_t mac_handle,uint8_t session_id,uint8_t sae_status,struct qdf_mac_addr peer_mac_addr,const uint8_t * pmkid)3001*5113495bSYour Name QDF_STATUS sme_handle_sae_msg(mac_handle_t mac_handle,
3002*5113495bSYour Name 			      uint8_t session_id,
3003*5113495bSYour Name 			      uint8_t sae_status,
3004*5113495bSYour Name 			      struct qdf_mac_addr peer_mac_addr,
3005*5113495bSYour Name 			      const uint8_t *pmkid)
3006*5113495bSYour Name {
3007*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
3008*5113495bSYour Name }
3009*5113495bSYour Name #endif
3010*5113495bSYour Name 
3011*5113495bSYour Name /**
3012*5113495bSYour Name  * sme_set_ba_buff_size() - sets BA buffer size
3013*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3014*5113495bSYour Name  * @session_id: SME session id
3015*5113495bSYour Name  * @buff_size: BA buffer size
3016*5113495bSYour Name  *
3017*5113495bSYour Name  * Return: 0 on success else err code
3018*5113495bSYour Name  */
3019*5113495bSYour Name int sme_set_ba_buff_size(mac_handle_t mac_handle, uint8_t session_id,
3020*5113495bSYour Name 			 uint16_t buff_size);
3021*5113495bSYour Name 
3022*5113495bSYour Name /**
3023*5113495bSYour Name  * sme_send_addba_req() - send ADDBA request with user config
3024*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3025*5113495bSYour Name  * @session_id: SME session id
3026*5113495bSYour Name  * @tid: tid val for BA session
3027*5113495bSYour Name  * @buff_size: BA buffer size
3028*5113495bSYour Name  *
3029*5113495bSYour Name  * Return: 0 on success else err code
3030*5113495bSYour Name  */
3031*5113495bSYour Name int sme_send_addba_req(mac_handle_t mac_handle, uint8_t session_id, uint8_t tid,
3032*5113495bSYour Name 		       uint16_t buff_size);
3033*5113495bSYour Name 
3034*5113495bSYour Name /**
3035*5113495bSYour Name  * sme_set_no_ack_policy() - Sets no ack policy for AC
3036*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3037*5113495bSYour Name  * @session_id: SME session id
3038*5113495bSYour Name  * @val: no ack policy value
3039*5113495bSYour Name  * @ac: access category
3040*5113495bSYour Name  *
3041*5113495bSYour Name  * Return: 0 on success else err code
3042*5113495bSYour Name  */
3043*5113495bSYour Name int sme_set_no_ack_policy(mac_handle_t mac_handle, uint8_t session_id,
3044*5113495bSYour Name 			  uint8_t val, uint8_t ac);
3045*5113495bSYour Name 
3046*5113495bSYour Name /**
3047*5113495bSYour Name  * sme_set_auto_rate_he_sgi() - Sets SGI for auto rate
3048*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3049*5113495bSYour Name  * @session_id: SME session id
3050*5113495bSYour Name  * @cfg_val: SGI configuration value
3051*5113495bSYour Name  *
3052*5113495bSYour Name  * Return: 0 on success else err code
3053*5113495bSYour Name  */
3054*5113495bSYour Name int sme_set_auto_rate_he_sgi(mac_handle_t mac_handle, uint8_t session_id,
3055*5113495bSYour Name 			     uint8_t cfg_val);
3056*5113495bSYour Name 
3057*5113495bSYour Name /**
3058*5113495bSYour Name  * sme_set_auto_rate_ldpc() - Sets LDPC for auto rate
3059*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3060*5113495bSYour Name  * @session_id: SME session id
3061*5113495bSYour Name  * @ldpc_disable: LDPC configuration value
3062*5113495bSYour Name  *
3063*5113495bSYour Name  * Return: 0 on success else err code
3064*5113495bSYour Name  */
3065*5113495bSYour Name int sme_set_auto_rate_ldpc(mac_handle_t mac_handle, uint8_t session_id,
3066*5113495bSYour Name 			   uint8_t ldpc_disable);
3067*5113495bSYour Name 
3068*5113495bSYour Name /**
3069*5113495bSYour Name  * sme_set_auto_rate_he_ltf() - Sets HE LTF for auto rate
3070*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3071*5113495bSYour Name  * @session_id: SME session id
3072*5113495bSYour Name  * @cfg_val: LTF configuration value
3073*5113495bSYour Name  *
3074*5113495bSYour Name  * Return: 0 on success else err code
3075*5113495bSYour Name  */
3076*5113495bSYour Name int sme_set_auto_rate_he_ltf(mac_handle_t mac_handle, uint8_t session_id,
3077*5113495bSYour Name 			     uint8_t cfg_val);
3078*5113495bSYour Name 
3079*5113495bSYour Name #ifdef WLAN_FEATURE_11BE
3080*5113495bSYour Name /**
3081*5113495bSYour Name  * sme_update_tgt_eht_cap() - sets the EHT caps to pmac
3082*5113495bSYour Name  * @mac_handle: Pointer to MAC handle
3083*5113495bSYour Name  * @cfg: Pointer to WMA target CFG
3084*5113495bSYour Name  * @eht_cap_ini: Pointer to EHT CAP configured by INI
3085*5113495bSYour Name  *
3086*5113495bSYour Name  * Return: None
3087*5113495bSYour Name  */
3088*5113495bSYour Name void sme_update_tgt_eht_cap(mac_handle_t mac_handle,
3089*5113495bSYour Name 			    struct wma_tgt_cfg *cfg,
3090*5113495bSYour Name 			    tDot11fIEeht_cap *eht_cap_ini);
3091*5113495bSYour Name 
3092*5113495bSYour Name /**
3093*5113495bSYour Name  * sme_update_eht_cap_nss() - sets the nss based on user request
3094*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3095*5113495bSYour Name  * @session_id: SME session id
3096*5113495bSYour Name  * @nss: no.of spatial streams value
3097*5113495bSYour Name  *
3098*5113495bSYour Name  * Return: None
3099*5113495bSYour Name  */
3100*5113495bSYour Name void sme_update_eht_cap_nss(mac_handle_t mac_handle, uint8_t session_id,
3101*5113495bSYour Name 			    uint8_t nss);
3102*5113495bSYour Name 
3103*5113495bSYour Name /**
3104*5113495bSYour Name  * sme_set_eht_bw_cap() - sets the EHT 320 MHz bandwidth capability
3105*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3106*5113495bSYour Name  * @vdev_id: vdev id
3107*5113495bSYour Name  * @chwidth: channel width
3108*5113495bSYour Name  *
3109*5113495bSYour Name  * Return: None
3110*5113495bSYour Name  */
3111*5113495bSYour Name void sme_set_eht_bw_cap(mac_handle_t mac_handle, uint8_t vdev_id,
3112*5113495bSYour Name 			enum eSirMacHTChannelWidth chwidth);
3113*5113495bSYour Name 
3114*5113495bSYour Name /**
3115*5113495bSYour Name  * sme_update_eht_cap_mcs() - updates EHT MCS capability based on user request
3116*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3117*5113495bSYour Name  * @session_id: SME session id
3118*5113495bSYour Name  * @mcs: MCS value
3119*5113495bSYour Name  *
3120*5113495bSYour Name  * Return: None
3121*5113495bSYour Name  */
3122*5113495bSYour Name void sme_update_eht_cap_mcs(mac_handle_t mac_handle, uint8_t session_id,
3123*5113495bSYour Name 			    uint8_t mcs);
3124*5113495bSYour Name 
3125*5113495bSYour Name /**
3126*5113495bSYour Name  * sme_update_eht_om_ctrl_supp() - sets the EHT OM control capability
3127*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3128*5113495bSYour Name  * @session_id: SME session id
3129*5113495bSYour Name  * @cfg_val: EHT OM control config
3130*5113495bSYour Name  *
3131*5113495bSYour Name  * Return: 0 on success else err code
3132*5113495bSYour Name  */
3133*5113495bSYour Name int sme_update_eht_om_ctrl_supp(mac_handle_t mac_handle, uint8_t session_id,
3134*5113495bSYour Name 				uint8_t cfg_val);
3135*5113495bSYour Name #else
sme_update_tgt_eht_cap(mac_handle_t mac_handle,struct wma_tgt_cfg * cfg,tDot11fIEeht_cap * eht_cap_ini)3136*5113495bSYour Name static inline void sme_update_tgt_eht_cap(mac_handle_t mac_handle,
3137*5113495bSYour Name 					  struct wma_tgt_cfg *cfg,
3138*5113495bSYour Name 					  tDot11fIEeht_cap *eht_cap_ini)
3139*5113495bSYour Name {}
3140*5113495bSYour Name 
sme_update_eht_cap_nss(mac_handle_t mac_handle,uint8_t session_id,uint8_t nss)3141*5113495bSYour Name static inline void sme_update_eht_cap_nss(mac_handle_t mac_handle,
3142*5113495bSYour Name 					  uint8_t session_id,
3143*5113495bSYour Name 					  uint8_t nss)
3144*5113495bSYour Name {}
3145*5113495bSYour Name 
sme_set_eht_bw_cap(mac_handle_t mac_handle,uint8_t vdev_id,enum eSirMacHTChannelWidth chwidth)3146*5113495bSYour Name static inline void sme_set_eht_bw_cap(mac_handle_t mac_handle, uint8_t vdev_id,
3147*5113495bSYour Name 				      enum eSirMacHTChannelWidth chwidth)
3148*5113495bSYour Name {}
sme_update_eht_cap_mcs(mac_handle_t mac_handle,uint8_t session_id,uint8_t mcs)3149*5113495bSYour Name static inline void sme_update_eht_cap_mcs(mac_handle_t mac_handle,
3150*5113495bSYour Name 					  uint8_t session_id,
3151*5113495bSYour Name 					  uint8_t mcs)
3152*5113495bSYour Name {}
3153*5113495bSYour Name 
3154*5113495bSYour Name static inline
sme_update_eht_om_ctrl_supp(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val)3155*5113495bSYour Name int sme_update_eht_om_ctrl_supp(mac_handle_t mac_handle, uint8_t session_id,
3156*5113495bSYour Name 				uint8_t cfg_val)
3157*5113495bSYour Name {
3158*5113495bSYour Name 	return 0;
3159*5113495bSYour Name }
3160*5113495bSYour Name #endif
3161*5113495bSYour Name 
3162*5113495bSYour Name struct omi_ctrl_tx {
3163*5113495bSYour Name 	uint32_t omi_in_vht:1;
3164*5113495bSYour Name 	uint32_t omi_in_he:1;
3165*5113495bSYour Name 	uint32_t a_ctrl_id:4;
3166*5113495bSYour Name 	uint32_t rx_nss:3;
3167*5113495bSYour Name 	uint32_t ch_bw:2;
3168*5113495bSYour Name 	uint32_t ul_mu_dis:1;
3169*5113495bSYour Name 	uint32_t tx_nsts:3;
3170*5113495bSYour Name 	uint32_t er_su_dis:1;
3171*5113495bSYour Name 	uint32_t dl_mu_mimo_resound:1;
3172*5113495bSYour Name 	uint32_t ul_mu_data_dis:1;
3173*5113495bSYour Name 	uint32_t eht_rx_nss_ext:1;
3174*5113495bSYour Name 	uint32_t eht_ch_bw_ext:1;
3175*5113495bSYour Name 	uint32_t eht_tx_nss_ext:1;
3176*5113495bSYour Name 	uint32_t reserved:11;
3177*5113495bSYour Name };
3178*5113495bSYour Name 
3179*5113495bSYour Name #ifdef WLAN_FEATURE_11AX
3180*5113495bSYour Name /**
3181*5113495bSYour Name  * sme_update_tgt_he_cap() - sets the HE caps to pmac
3182*5113495bSYour Name  * @mac_handle: Pointer to MAC handle
3183*5113495bSYour Name  * @cfg: Pointer to WMA target CFG
3184*5113495bSYour Name  * @he_cap_ini: Pointer to HE CAP configured by INI
3185*5113495bSYour Name  *
3186*5113495bSYour Name  * Return: None
3187*5113495bSYour Name  */
3188*5113495bSYour Name void sme_update_tgt_he_cap(mac_handle_t mac_handle,
3189*5113495bSYour Name 			   struct wma_tgt_cfg *cfg,
3190*5113495bSYour Name 			   tDot11fIEhe_cap *he_cap_ini);
3191*5113495bSYour Name 
3192*5113495bSYour Name /**
3193*5113495bSYour Name  * sme_update_he_cap_nss() - sets the nss based on user request
3194*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3195*5113495bSYour Name  * @session_id: SME session id
3196*5113495bSYour Name  * @nss: no.of spatial streams value
3197*5113495bSYour Name  *
3198*5113495bSYour Name  * Return: None
3199*5113495bSYour Name  */
3200*5113495bSYour Name void sme_update_he_cap_nss(mac_handle_t mac_handle, uint8_t session_id,
3201*5113495bSYour Name 			   uint8_t nss);
3202*5113495bSYour Name 
3203*5113495bSYour Name /**
3204*5113495bSYour Name  * sme_update_he_tx_bfee_supp() - sets the HE Tx Bfee support
3205*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3206*5113495bSYour Name  * @session_id: SME session id
3207*5113495bSYour Name  * @cfg_val: Tx Bfee config value
3208*5113495bSYour Name  *
3209*5113495bSYour Name  * Return: 0 on success else err code
3210*5113495bSYour Name  */
3211*5113495bSYour Name int sme_update_he_tx_bfee_supp(mac_handle_t mac_handle, uint8_t session_id,
3212*5113495bSYour Name 			       uint8_t cfg_val);
3213*5113495bSYour Name 
3214*5113495bSYour Name /**
3215*5113495bSYour Name  * sme_update_he_tx_bfee_nsts() - sets the HE Tx Bfee NSTS
3216*5113495bSYour Name  * @mac_handle: MAC handle
3217*5113495bSYour Name  * @session_id: SME session id
3218*5113495bSYour Name  * @cfg_val: Tx Bfee NSTS value
3219*5113495bSYour Name  *
3220*5113495bSYour Name  * Return: 0 on success else err code
3221*5113495bSYour Name  */
3222*5113495bSYour Name int sme_update_he_tx_bfee_nsts(mac_handle_t mac_handle, uint8_t session_id,
3223*5113495bSYour Name 			       uint8_t cfg_val);
3224*5113495bSYour Name 
3225*5113495bSYour Name /**
3226*5113495bSYour Name  * sme_set_he_tx_bf_cbf_rates() - sets the HE Tx Bfee CBF frame rates to FW
3227*5113495bSYour Name  * @session_id: SME session id
3228*5113495bSYour Name  *
3229*5113495bSYour Name  * Return: None
3230*5113495bSYour Name  */
3231*5113495bSYour Name void sme_set_he_tx_bf_cbf_rates(uint8_t session_id);
3232*5113495bSYour Name 
3233*5113495bSYour Name /**
3234*5113495bSYour Name  * sme_config_su_ppdu_queue() - Configures SU PPDU queue enable/disable in FW
3235*5113495bSYour Name  * @session_id: SME session id
3236*5113495bSYour Name  * @enable: Enable/Disable config
3237*5113495bSYour Name  *
3238*5113495bSYour Name  * Return: None
3239*5113495bSYour Name  */
3240*5113495bSYour Name void sme_config_su_ppdu_queue(uint8_t session_id, bool enable);
3241*5113495bSYour Name 
3242*5113495bSYour Name /**
3243*5113495bSYour Name  * sme_update_he_mcs() - sets the HE MCS based on user request
3244*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3245*5113495bSYour Name  * @session_id: SME session id
3246*5113495bSYour Name  * @he_mcs: HE MCS value
3247*5113495bSYour Name  *
3248*5113495bSYour Name  * Return: 0 on success else err code
3249*5113495bSYour Name  */
3250*5113495bSYour Name int sme_update_he_mcs(mac_handle_t mac_handle, uint8_t session_id,
3251*5113495bSYour Name 		      uint16_t he_mcs);
3252*5113495bSYour Name 
3253*5113495bSYour Name /**
3254*5113495bSYour Name  * sme_update_he_trigger_frm_mac_pad() - sets the HE MAC padding capability
3255*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3256*5113495bSYour Name  * @session_id: SME session id
3257*5113495bSYour Name  * @cfg_val: HE MAC padding duration value
3258*5113495bSYour Name  *
3259*5113495bSYour Name  * Return: 0 on success else err code
3260*5113495bSYour Name  */
3261*5113495bSYour Name int sme_update_he_trigger_frm_mac_pad(mac_handle_t mac_handle,
3262*5113495bSYour Name 				      uint8_t session_id,
3263*5113495bSYour Name 				      uint8_t cfg_val);
3264*5113495bSYour Name 
3265*5113495bSYour Name /**
3266*5113495bSYour Name  * sme_update_he_om_ctrl_supp() - sets the HE OM control capability
3267*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3268*5113495bSYour Name  * @session_id: SME session id
3269*5113495bSYour Name  * @cfg_val: HE OM control config
3270*5113495bSYour Name  *
3271*5113495bSYour Name  * Return: 0 on success else err code
3272*5113495bSYour Name  */
3273*5113495bSYour Name int sme_update_he_om_ctrl_supp(mac_handle_t mac_handle, uint8_t session_id,
3274*5113495bSYour Name 			       uint8_t cfg_val);
3275*5113495bSYour Name 
3276*5113495bSYour Name #define A_CTRL_ID_OMI 0x1
3277*5113495bSYour Name 
3278*5113495bSYour Name void sme_reset_he_om_ctrl(mac_handle_t mac_handle);
3279*5113495bSYour Name 
3280*5113495bSYour Name /**
3281*5113495bSYour Name  * sme_config_action_tx_in_tb_ppdu() - Sends action frame in TB PPDU cfg to FW
3282*5113495bSYour Name  * @mac_handle: Pointer to MAC handle
3283*5113495bSYour Name  * @session_id: SME session id
3284*5113495bSYour Name  * @cfg_val: configuration setting value
3285*5113495bSYour Name  *
3286*5113495bSYour Name  * Return: 0 on success else err code
3287*5113495bSYour Name  */
3288*5113495bSYour Name int sme_config_action_tx_in_tb_ppdu(mac_handle_t mac_handle, uint8_t session_id,
3289*5113495bSYour Name 				    uint8_t cfg_val);
3290*5113495bSYour Name 
3291*5113495bSYour Name /**
3292*5113495bSYour Name  * sme_send_he_om_ctrl_update() - Send HE OM ctrl Tx cmd to FW
3293*5113495bSYour Name  * @mac_handle: Pointer to mac handle
3294*5113495bSYour Name  * @session_id: SME session id
3295*5113495bSYour Name  * @omi_data: OMI control data
3296*5113495bSYour Name  *
3297*5113495bSYour Name  * Return: 0 on success else err code
3298*5113495bSYour Name  */
3299*5113495bSYour Name int sme_send_he_om_ctrl_update(mac_handle_t mac_handle, uint8_t session_id,
3300*5113495bSYour Name 			       struct omi_ctrl_tx *omi_data);
3301*5113495bSYour Name 
3302*5113495bSYour Name /**
3303*5113495bSYour Name  * sme_set_he_om_ctrl_param() - Update HE OM control params for OMI Tx
3304*5113495bSYour Name  * @mac_handle: Pointer to mac handle
3305*5113495bSYour Name  * @session_id: SME session id
3306*5113495bSYour Name  * @param: HE om control parameter
3307*5113495bSYour Name  * @cfg_val: HE OM control parameter config value
3308*5113495bSYour Name  *
3309*5113495bSYour Name  * Return: 0 on success else err code
3310*5113495bSYour Name  */
3311*5113495bSYour Name int sme_set_he_om_ctrl_param(mac_handle_t mac_handle, uint8_t session_id,
3312*5113495bSYour Name 			     enum qca_wlan_vendor_attr_he_omi_tx param,
3313*5113495bSYour Name 			     uint8_t cfg_val);
3314*5113495bSYour Name 
3315*5113495bSYour Name /**
3316*5113495bSYour Name  * sme_set_usr_cfg_mu_edca() - sets the user cfg MU EDCA params flag
3317*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3318*5113495bSYour Name  * @val: value to be set
3319*5113495bSYour Name  *
3320*5113495bSYour Name  * Return: none
3321*5113495bSYour Name  */
3322*5113495bSYour Name void sme_set_usr_cfg_mu_edca(mac_handle_t mac_handle, bool val);
3323*5113495bSYour Name 
3324*5113495bSYour Name /**
3325*5113495bSYour Name  * sme_set_he_mu_edca_def_cfg() - sets the default MU EDCA params values
3326*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3327*5113495bSYour Name  *
3328*5113495bSYour Name  * Return: none
3329*5113495bSYour Name  */
3330*5113495bSYour Name void sme_set_he_mu_edca_def_cfg(mac_handle_t mac_handle);
3331*5113495bSYour Name 
3332*5113495bSYour Name /**
3333*5113495bSYour Name  * sme_update_he_htc_he_supp() - Update +HTC-HE support in HE capabilities
3334*5113495bSYour Name  * @mac_handle: Pointer to mac handle
3335*5113495bSYour Name  * @session_id: SME session id
3336*5113495bSYour Name  * @cfg_val: config setting
3337*5113495bSYour Name  *
3338*5113495bSYour Name  * Return: 0 on success else err code
3339*5113495bSYour Name  */
3340*5113495bSYour Name int sme_update_he_htc_he_supp(mac_handle_t mac_handle, uint8_t session_id,
3341*5113495bSYour Name 			      bool cfg_val);
3342*5113495bSYour Name 
3343*5113495bSYour Name /**
3344*5113495bSYour Name  * sme_update_mu_edca_params() - updates MU EDCA params values
3345*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3346*5113495bSYour Name  * @session_id: SME session id
3347*5113495bSYour Name  *
3348*5113495bSYour Name  * Return: 0 on success else err code
3349*5113495bSYour Name  */
3350*5113495bSYour Name int sme_update_mu_edca_params(mac_handle_t mac_handle, uint8_t session_id);
3351*5113495bSYour Name 
3352*5113495bSYour Name /**
3353*5113495bSYour Name  * sme_update_he_tx_stbc_cap() - Sets the HE Tx STBC capability
3354*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3355*5113495bSYour Name  * @session_id: SME session id
3356*5113495bSYour Name  * @value: set value
3357*5113495bSYour Name  *
3358*5113495bSYour Name  * Return: 0 on success else err code
3359*5113495bSYour Name  */
3360*5113495bSYour Name int sme_update_he_tx_stbc_cap(mac_handle_t mac_handle, uint8_t session_id,
3361*5113495bSYour Name 			      int value);
3362*5113495bSYour Name 
3363*5113495bSYour Name /**
3364*5113495bSYour Name  * sme_update_he_rx_stbc_cap() - Sets the HE Rx STBC capability
3365*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3366*5113495bSYour Name  * @session_id: SME session id
3367*5113495bSYour Name  * @value: set value
3368*5113495bSYour Name  *
3369*5113495bSYour Name  * Return: 0 on success else err code
3370*5113495bSYour Name  */
3371*5113495bSYour Name int sme_update_he_rx_stbc_cap(mac_handle_t mac_handle, uint8_t session_id,
3372*5113495bSYour Name 			      int value);
3373*5113495bSYour Name 
3374*5113495bSYour Name /**
3375*5113495bSYour Name  * sme_update_he_frag_supp() - sets the HE fragmentation support
3376*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3377*5113495bSYour Name  * @session_id: SME session id
3378*5113495bSYour Name  * @he_frag: HE fragmention support value
3379*5113495bSYour Name  *
3380*5113495bSYour Name  * Return: 0 on success else err code
3381*5113495bSYour Name  */
3382*5113495bSYour Name int sme_update_he_frag_supp(mac_handle_t mac_handle, uint8_t session_id,
3383*5113495bSYour Name 			    uint16_t he_frag);
3384*5113495bSYour Name 
3385*5113495bSYour Name /**
3386*5113495bSYour Name  * sme_update_he_ldpc_supp() - sets the HE LDPC support
3387*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3388*5113495bSYour Name  * @session_id: SME session id
3389*5113495bSYour Name  * @he_ldpc: HE LDPC support value
3390*5113495bSYour Name  *
3391*5113495bSYour Name  * Return: 0 on success else err code
3392*5113495bSYour Name  */
3393*5113495bSYour Name int sme_update_he_ldpc_supp(mac_handle_t mac_handle, uint8_t session_id,
3394*5113495bSYour Name 			    uint16_t he_ldpc);
3395*5113495bSYour Name 
3396*5113495bSYour Name /**
3397*5113495bSYour Name  * sme_update_he_capabilities() - Update the session HE capability
3398*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3399*5113495bSYour Name  * @session_id: SME session id
3400*5113495bSYour Name  * @cfg_val: set value
3401*5113495bSYour Name  * @cfg_id: HE cap cfg id
3402*5113495bSYour Name  *
3403*5113495bSYour Name  * Return: 0 on success else err code
3404*5113495bSYour Name  */
3405*5113495bSYour Name int sme_update_he_capabilities(mac_handle_t mac_handle, uint8_t session_id,
3406*5113495bSYour Name 			       uint8_t cfg_val, uint8_t cfg_id);
3407*5113495bSYour Name 
3408*5113495bSYour Name /**
3409*5113495bSYour Name  * sme_update_he_twt_req_support() - Sets twt request capability
3410*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3411*5113495bSYour Name  * @session_id: SME session id
3412*5113495bSYour Name  * @cfg_val: set value
3413*5113495bSYour Name  *
3414*5113495bSYour Name  * Return: 0 on success else err code
3415*5113495bSYour Name  */
3416*5113495bSYour Name int sme_update_he_twt_req_support(mac_handle_t mac_handle, uint8_t session_id,
3417*5113495bSYour Name 				  uint8_t cfg_val);
3418*5113495bSYour Name 
3419*5113495bSYour Name /**
3420*5113495bSYour Name  * sme_update_he_full_ul_mumimo() - Configure full bandwidth of ul mu-mimo
3421*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3422*5113495bSYour Name  * @session_id: SME session id
3423*5113495bSYour Name  * @value: set value
3424*5113495bSYour Name  *
3425*5113495bSYour Name  * Return: 0 on success else err code
3426*5113495bSYour Name  */
3427*5113495bSYour Name int sme_update_he_full_ul_mumimo(mac_handle_t mac_handle, uint8_t session_id,
3428*5113495bSYour Name 				 uint8_t cfg_val);
3429*5113495bSYour Name #else
sme_update_tgt_he_cap(mac_handle_t mac_handle,struct wma_tgt_cfg * cfg,tDot11fIEhe_cap * he_cap_ini)3430*5113495bSYour Name static inline void sme_update_tgt_he_cap(mac_handle_t mac_handle,
3431*5113495bSYour Name 					 struct wma_tgt_cfg *cfg,
3432*5113495bSYour Name 					 tDot11fIEhe_cap *he_cap_ini)
3433*5113495bSYour Name {}
sme_update_he_cap_nss(mac_handle_t mac_handle,uint8_t session_id,uint8_t nss)3434*5113495bSYour Name static inline void sme_update_he_cap_nss(mac_handle_t mac_handle,
3435*5113495bSYour Name 					 uint8_t session_id,
3436*5113495bSYour Name 					 uint8_t nss)
3437*5113495bSYour Name {}
sme_update_he_mcs(mac_handle_t mac_handle,uint8_t session_id,uint16_t he_mcs)3438*5113495bSYour Name static inline int sme_update_he_mcs(mac_handle_t mac_handle, uint8_t session_id,
3439*5113495bSYour Name 				    uint16_t he_mcs)
3440*5113495bSYour Name {
3441*5113495bSYour Name 	return 0;
3442*5113495bSYour Name }
3443*5113495bSYour Name 
sme_set_he_mu_edca_def_cfg(mac_handle_t mac_handle)3444*5113495bSYour Name static inline void sme_set_he_mu_edca_def_cfg(mac_handle_t mac_handle)
3445*5113495bSYour Name {
3446*5113495bSYour Name }
3447*5113495bSYour Name 
sme_update_mu_edca_params(mac_handle_t mac_handle,uint8_t session_id)3448*5113495bSYour Name static inline int sme_update_mu_edca_params(mac_handle_t mac_handle,
3449*5113495bSYour Name 					    uint8_t session_id)
3450*5113495bSYour Name {
3451*5113495bSYour Name 	return 0;
3452*5113495bSYour Name }
3453*5113495bSYour Name 
sme_update_he_trigger_frm_mac_pad(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val)3454*5113495bSYour Name static inline int sme_update_he_trigger_frm_mac_pad(mac_handle_t mac_handle,
3455*5113495bSYour Name 						    uint8_t session_id,
3456*5113495bSYour Name 						    uint8_t cfg_val)
3457*5113495bSYour Name {
3458*5113495bSYour Name 	return 0;
3459*5113495bSYour Name }
3460*5113495bSYour Name 
sme_update_he_om_ctrl_supp(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val)3461*5113495bSYour Name static inline int sme_update_he_om_ctrl_supp(mac_handle_t mac_handle,
3462*5113495bSYour Name 					     uint8_t session_id,
3463*5113495bSYour Name 					     uint8_t cfg_val)
3464*5113495bSYour Name {
3465*5113495bSYour Name 	return 0;
3466*5113495bSYour Name }
3467*5113495bSYour Name 
3468*5113495bSYour Name 
3469*5113495bSYour Name static inline int
sme_set_he_om_ctrl_param(mac_handle_t mac_handle,uint8_t session_id,enum qca_wlan_vendor_attr_he_omi_tx param,uint8_t cfg_val)3470*5113495bSYour Name sme_set_he_om_ctrl_param(mac_handle_t mac_handle, uint8_t session_id,
3471*5113495bSYour Name 			 enum qca_wlan_vendor_attr_he_omi_tx param,
3472*5113495bSYour Name 			 uint8_t cfg_val)
3473*5113495bSYour Name {
3474*5113495bSYour Name 	return 0;
3475*5113495bSYour Name }
3476*5113495bSYour Name 
sme_reset_he_om_ctrl(mac_handle_t mac_handle)3477*5113495bSYour Name static inline void sme_reset_he_om_ctrl(mac_handle_t mac_handle)
3478*5113495bSYour Name {
3479*5113495bSYour Name }
3480*5113495bSYour Name 
sme_config_action_tx_in_tb_ppdu(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val)3481*5113495bSYour Name static inline int sme_config_action_tx_in_tb_ppdu(mac_handle_t mac_handle,
3482*5113495bSYour Name 						  uint8_t session_id,
3483*5113495bSYour Name 						  uint8_t cfg_val)
3484*5113495bSYour Name {
3485*5113495bSYour Name 	return 0;
3486*5113495bSYour Name }
3487*5113495bSYour Name 
sme_update_he_htc_he_supp(mac_handle_t mac_handle,uint8_t session_id,bool cfg_val)3488*5113495bSYour Name static inline int sme_update_he_htc_he_supp(mac_handle_t mac_handle,
3489*5113495bSYour Name 					    uint8_t session_id,
3490*5113495bSYour Name 					    bool cfg_val)
3491*5113495bSYour Name {
3492*5113495bSYour Name 	return 0;
3493*5113495bSYour Name }
3494*5113495bSYour Name 
3495*5113495bSYour Name static inline int
sme_send_he_om_ctrl_update(mac_handle_t mac_handle,uint8_t session_id,struct omi_ctrl_tx * omi_data)3496*5113495bSYour Name sme_send_he_om_ctrl_update(mac_handle_t mac_handle, uint8_t session_id,
3497*5113495bSYour Name 			   struct omi_ctrl_tx *omi_data)
3498*5113495bSYour Name {
3499*5113495bSYour Name 	return 0;
3500*5113495bSYour Name }
sme_set_usr_cfg_mu_edca(mac_handle_t mac_handle,bool val)3501*5113495bSYour Name static inline void sme_set_usr_cfg_mu_edca(mac_handle_t mac_handle, bool val)
3502*5113495bSYour Name {
3503*5113495bSYour Name }
3504*5113495bSYour Name 
sme_update_he_tx_stbc_cap(mac_handle_t mac_handle,uint8_t session_id,int value)3505*5113495bSYour Name static inline int sme_update_he_tx_stbc_cap(mac_handle_t mac_handle,
3506*5113495bSYour Name 					    uint8_t session_id,
3507*5113495bSYour Name 					    int value)
3508*5113495bSYour Name {
3509*5113495bSYour Name 	return 0;
3510*5113495bSYour Name }
3511*5113495bSYour Name 
sme_update_he_rx_stbc_cap(mac_handle_t mac_handle,uint8_t session_id,int value)3512*5113495bSYour Name static inline int sme_update_he_rx_stbc_cap(mac_handle_t mac_handle,
3513*5113495bSYour Name 					    uint8_t session_id,
3514*5113495bSYour Name 					    int value)
3515*5113495bSYour Name {
3516*5113495bSYour Name 	return 0;
3517*5113495bSYour Name }
3518*5113495bSYour Name 
sme_update_he_frag_supp(mac_handle_t mac_handle,uint8_t session_id,uint16_t he_frag)3519*5113495bSYour Name static inline int sme_update_he_frag_supp(mac_handle_t mac_handle,
3520*5113495bSYour Name 					  uint8_t session_id,
3521*5113495bSYour Name 					  uint16_t he_frag)
3522*5113495bSYour Name {
3523*5113495bSYour Name 	return 0;
3524*5113495bSYour Name }
3525*5113495bSYour Name 
sme_update_he_ldpc_supp(mac_handle_t mac_handle,uint8_t session_id,uint16_t he_ldpc)3526*5113495bSYour Name static inline int sme_update_he_ldpc_supp(mac_handle_t mac_handle,
3527*5113495bSYour Name 					  uint8_t session_id,
3528*5113495bSYour Name 					  uint16_t he_ldpc)
3529*5113495bSYour Name {
3530*5113495bSYour Name 	return 0;
3531*5113495bSYour Name }
3532*5113495bSYour Name 
sme_update_he_tx_bfee_supp(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val)3533*5113495bSYour Name static inline int sme_update_he_tx_bfee_supp(mac_handle_t mac_handle,
3534*5113495bSYour Name 					     uint8_t session_id,
3535*5113495bSYour Name 					     uint8_t cfg_val)
3536*5113495bSYour Name {
3537*5113495bSYour Name 	return 0;
3538*5113495bSYour Name }
sme_update_he_tx_bfee_nsts(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val)3539*5113495bSYour Name static inline int sme_update_he_tx_bfee_nsts(mac_handle_t mac_handle,
3540*5113495bSYour Name 					     uint8_t session_id,
3541*5113495bSYour Name 					     uint8_t cfg_val)
3542*5113495bSYour Name {
3543*5113495bSYour Name 	return 0;
3544*5113495bSYour Name }
3545*5113495bSYour Name 
sme_set_he_tx_bf_cbf_rates(uint8_t session_id)3546*5113495bSYour Name static inline void sme_set_he_tx_bf_cbf_rates(uint8_t session_id)
3547*5113495bSYour Name {
3548*5113495bSYour Name }
3549*5113495bSYour Name 
sme_config_su_ppdu_queue(uint8_t session_id,bool enable)3550*5113495bSYour Name static inline void sme_config_su_ppdu_queue(uint8_t session_id, bool enable)
3551*5113495bSYour Name {
3552*5113495bSYour Name }
3553*5113495bSYour Name 
sme_update_he_twt_req_support(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val)3554*5113495bSYour Name static inline int sme_update_he_twt_req_support(mac_handle_t mac_handle,
3555*5113495bSYour Name 						uint8_t session_id,
3556*5113495bSYour Name 						uint8_t cfg_val)
3557*5113495bSYour Name {
3558*5113495bSYour Name 	return 0;
3559*5113495bSYour Name }
3560*5113495bSYour Name 
sme_update_he_capabilities(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val,uint8_t cfg_id)3561*5113495bSYour Name static inline int sme_update_he_capabilities(mac_handle_t mac_handle,
3562*5113495bSYour Name 					      uint8_t session_id,
3563*5113495bSYour Name 					      uint8_t cfg_val,
3564*5113495bSYour Name 					      uint8_t cfg_id)
3565*5113495bSYour Name {
3566*5113495bSYour Name 	return 0;
3567*5113495bSYour Name }
3568*5113495bSYour Name 
sme_update_he_full_ul_mumimo(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val)3569*5113495bSYour Name static inline int sme_update_he_full_ul_mumimo(mac_handle_t mac_handle,
3570*5113495bSYour Name 					       uint8_t session_id,
3571*5113495bSYour Name 					       uint8_t cfg_val)
3572*5113495bSYour Name {
3573*5113495bSYour Name 	return 0;
3574*5113495bSYour Name }
3575*5113495bSYour Name 
3576*5113495bSYour Name #endif
3577*5113495bSYour Name 
3578*5113495bSYour Name /**
3579*5113495bSYour Name  * sme_update_session_txq_edca_params() - sets the configured
3580*5113495bSYour Name  * internal EDCA params values
3581*5113495bSYour Name  *
3582*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3583*5113495bSYour Name  * @session_id: session id
3584*5113495bSYour Name  * @txq_edca_params: edca parameters
3585*5113495bSYour Name  *
3586*5113495bSYour Name  * Return: QDF_STATUS
3587*5113495bSYour Name  */
3588*5113495bSYour Name QDF_STATUS
3589*5113495bSYour Name sme_update_session_txq_edca_params(mac_handle_t mac_handle, uint8_t session_id,
3590*5113495bSYour Name 				   tSirMacEdcaParamRecord *txq_edca_params);
3591*5113495bSYour Name 
3592*5113495bSYour Name /**
3593*5113495bSYour Name  * sme_is_sta_key_exchange_in_progress() - checks whether the STA/P2P client
3594*5113495bSYour Name  * session has key exchange in progress
3595*5113495bSYour Name  *
3596*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3597*5113495bSYour Name  * @session_id: session id
3598*5113495bSYour Name  *
3599*5113495bSYour Name  * Return: true - if key exchange in progress
3600*5113495bSYour Name  *         false - if not in progress
3601*5113495bSYour Name  */
3602*5113495bSYour Name bool sme_is_sta_key_exchange_in_progress(mac_handle_t mac_handle,
3603*5113495bSYour Name 					 uint8_t session_id);
3604*5113495bSYour Name 
3605*5113495bSYour Name /*
3606*5113495bSYour Name  * sme_validate_channel_list() - Validate the given channel list
3607*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3608*5113495bSYour Name  * @chan_freq_list: Pointer to the channel list
3609*5113495bSYour Name  * @num_channels: number of channels present in the chan_list
3610*5113495bSYour Name  *
3611*5113495bSYour Name  * Validates the given channel list with base channels in mac context
3612*5113495bSYour Name  *
3613*5113495bSYour Name  * Return: True if all channels in the list are valid, false otherwise
3614*5113495bSYour Name  */
3615*5113495bSYour Name bool sme_validate_channel_list(mac_handle_t mac_handle,
3616*5113495bSYour Name 			       uint32_t *chan_freq_list,
3617*5113495bSYour Name 			       uint8_t num_channels);
3618*5113495bSYour Name 
3619*5113495bSYour Name /**
3620*5113495bSYour Name  * sme_set_amsdu() - set amsdu enable/disable based on user cfg
3621*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3622*5113495bSYour Name  * @enable: enable or disable
3623*5113495bSYour Name  *
3624*5113495bSYour Name  * Return: None
3625*5113495bSYour Name  */
3626*5113495bSYour Name void sme_set_amsdu(mac_handle_t mac_handle, bool enable);
3627*5113495bSYour Name 
3628*5113495bSYour Name /**
3629*5113495bSYour Name  * sme_set_pmf_wep_cfg() - set user cfg for PMF setting
3630*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3631*5113495bSYour Name  * @pmf_wep_cfg: PMF configuration
3632*5113495bSYour Name  *
3633*5113495bSYour Name  * Return: None
3634*5113495bSYour Name  */
3635*5113495bSYour Name void sme_set_pmf_wep_cfg(mac_handle_t mac_handle, uint8_t pmf_wep_cfg);
3636*5113495bSYour Name 
3637*5113495bSYour Name /**
3638*5113495bSYour Name  * sme_set_cfg_disable_tx() - set user cfg to disable data and mgmt tx
3639*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3640*5113495bSYour Name  * @vdev_id: vdev id
3641*5113495bSYour Name  * @val: configuration value
3642*5113495bSYour Name  *
3643*5113495bSYour Name  * Return: None
3644*5113495bSYour Name  */
3645*5113495bSYour Name void sme_set_cfg_disable_tx(mac_handle_t mac_handle, uint8_t vdev_id,
3646*5113495bSYour Name 			    uint8_t val);
3647*5113495bSYour Name /**
3648*5113495bSYour Name  * sme_set_bss_max_idle_period() - Configure the bss max idle period
3649*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3650*5113495bSYour Name  * @cfg_val: bss max idle period
3651*5113495bSYour Name  *
3652*5113495bSYour Name  * Return: None
3653*5113495bSYour Name  */
3654*5113495bSYour Name void sme_set_bss_max_idle_period(mac_handle_t mac_handle, uint16_t cfg_val);
3655*5113495bSYour Name 
3656*5113495bSYour Name #ifdef WLAN_FEATURE_11AX
3657*5113495bSYour Name void sme_set_he_testbed_def(mac_handle_t mac_handle, uint8_t vdev_id);
3658*5113495bSYour Name void sme_reset_he_caps(mac_handle_t mac_handle, uint8_t vdev_id);
3659*5113495bSYour Name void sme_set_he_bw_cap(mac_handle_t mac_handle, uint8_t vdev_id,
3660*5113495bSYour Name 		       enum eSirMacHTChannelWidth chwidth);
3661*5113495bSYour Name /**
3662*5113495bSYour Name  * sme_set_ru_242_tone_tx_cfg() - set ru 242 tone tx user cfg
3663*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3664*5113495bSYour Name  * @cfg_val: enable or disable
3665*5113495bSYour Name  *
3666*5113495bSYour Name  * Return: None
3667*5113495bSYour Name  */
3668*5113495bSYour Name void sme_set_ru_242_tone_tx_cfg(mac_handle_t mac_handle, uint8_t cfg_val);
3669*5113495bSYour Name 
3670*5113495bSYour Name /**
3671*5113495bSYour Name  * sme_check_enable_ru_242_tx() - check usr cfg and enable ru 242 tone tx
3672*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3673*5113495bSYour Name  * @vdev_id: VDEV id
3674*5113495bSYour Name  *
3675*5113495bSYour Name  * Return: None
3676*5113495bSYour Name  */
3677*5113495bSYour Name void sme_check_enable_ru_242_tx(mac_handle_t mac_handle, uint8_t vdev_id);
3678*5113495bSYour Name 
3679*5113495bSYour Name #else
sme_set_he_testbed_def(mac_handle_t mac_handle,uint8_t vdev_id)3680*5113495bSYour Name static inline void sme_set_he_testbed_def(mac_handle_t mac_handle,
3681*5113495bSYour Name 					  uint8_t vdev_id)
3682*5113495bSYour Name {
3683*5113495bSYour Name }
sme_reset_he_caps(mac_handle_t mac_handle,uint8_t vdev_id)3684*5113495bSYour Name static inline void sme_reset_he_caps(mac_handle_t mac_handle, uint8_t vdev_id)
3685*5113495bSYour Name {
3686*5113495bSYour Name }
3687*5113495bSYour Name 
sme_set_he_bw_cap(mac_handle_t mac_handle,uint8_t vdev_id,enum eSirMacHTChannelWidth chwidth)3688*5113495bSYour Name static inline void sme_set_he_bw_cap(mac_handle_t mac_handle, uint8_t vdev_id,
3689*5113495bSYour Name 				     enum eSirMacHTChannelWidth chwidth)
3690*5113495bSYour Name {
3691*5113495bSYour Name }
sme_check_enable_ru_242_tx(mac_handle_t mac_handle,uint8_t vdev_id)3692*5113495bSYour Name static inline void sme_check_enable_ru_242_tx(mac_handle_t mac_handle,
3693*5113495bSYour Name 					      uint8_t vdev_id)
3694*5113495bSYour Name {
3695*5113495bSYour Name }
3696*5113495bSYour Name 
sme_set_ru_242_tone_tx_cfg(mac_handle_t mac_handle,uint8_t cfg_val)3697*5113495bSYour Name static inline void sme_set_ru_242_tone_tx_cfg(mac_handle_t mac_handle,
3698*5113495bSYour Name 					      uint8_t cfg_val)
3699*5113495bSYour Name {
3700*5113495bSYour Name }
3701*5113495bSYour Name #endif
3702*5113495bSYour Name 
3703*5113495bSYour Name /**
3704*5113495bSYour Name  * sme_set_nss_capability() - sets HE, EHT NSS capability based on user request
3705*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3706*5113495bSYour Name  * @vdev_id: VDEV id
3707*5113495bSYour Name  * @nss: Number of spatial streams value
3708*5113495bSYour Name  * @op_mode: Operation mode of the vdev
3709*5113495bSYour Name  *
3710*5113495bSYour Name  * Return: None
3711*5113495bSYour Name  */
3712*5113495bSYour Name void sme_set_nss_capability(mac_handle_t mac_handle, uint8_t vdev_id,
3713*5113495bSYour Name 			    uint8_t nss, enum QDF_OPMODE op_mode);
3714*5113495bSYour Name 
3715*5113495bSYour Name /**
3716*5113495bSYour Name  * enum sme_eht_tx_bfee_cap_type - EHT TX Beamformee capability type
3717*5113495bSYour Name  * @EHT_TX_BFEE_ENABLE: TX beamformee enable
3718*5113495bSYour Name  * @EHT_TX_BFEE_SS_80MHZ: TX beamformee for 80 MHz
3719*5113495bSYour Name  * @EHT_TX_BFEE_SS_160MHZ: TX beamformee for 160 MHz
3720*5113495bSYour Name  * @EHT_TX_BFEE_SS_320MHZ: TX beamformee for 320 MHz
3721*5113495bSYour Name  * @EHT_TX_BFEE_SOUNDING_FEEDBACK_RATELIMIT: TX beamformee sounding feedback
3722*5113495bSYour Name  * ratelimit
3723*5113495bSYour Name  */
3724*5113495bSYour Name enum sme_eht_tx_bfee_cap_type {
3725*5113495bSYour Name 	EHT_TX_BFEE_ENABLE = 1,
3726*5113495bSYour Name 	EHT_TX_BFEE_SS_80MHZ = 2,
3727*5113495bSYour Name 	EHT_TX_BFEE_SS_160MHZ = 3,
3728*5113495bSYour Name 	EHT_TX_BFEE_SS_320MHZ = 4,
3729*5113495bSYour Name 	EHT_TX_BFEE_SOUNDING_FEEDBACK_RATELIMIT = 5,
3730*5113495bSYour Name };
3731*5113495bSYour Name 
3732*5113495bSYour Name #ifdef WLAN_FEATURE_11BE
3733*5113495bSYour Name /**
3734*5113495bSYour Name  * sme_set_eht_testbed_def() - set eht testbed default
3735*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3736*5113495bSYour Name  * @vdev_id: VDEV id
3737*5113495bSYour Name  *
3738*5113495bSYour Name  * Return: None
3739*5113495bSYour Name  */
3740*5113495bSYour Name void sme_set_eht_testbed_def(mac_handle_t mac_handle, uint8_t vdev_id);
3741*5113495bSYour Name 
3742*5113495bSYour Name /**
3743*5113495bSYour Name  * sme_reset_eht_caps() - reset eht capabilities
3744*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3745*5113495bSYour Name  * @vdev_id: VDEV id
3746*5113495bSYour Name  *
3747*5113495bSYour Name  * Return: None
3748*5113495bSYour Name  */
3749*5113495bSYour Name void sme_reset_eht_caps(mac_handle_t mac_handle, uint8_t vdev_id);
3750*5113495bSYour Name 
3751*5113495bSYour Name /**
3752*5113495bSYour Name  * sme_set_mlo_max_links() - set mlo max links
3753*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3754*5113495bSYour Name  * @vdev_id: VDEV id
3755*5113495bSYour Name  * @val: value to be set
3756*5113495bSYour Name  *
3757*5113495bSYour Name  * Return: None
3758*5113495bSYour Name  */
3759*5113495bSYour Name void sme_set_mlo_max_links(mac_handle_t mac_handle, uint8_t vdev_id,
3760*5113495bSYour Name 			   uint8_t val);
3761*5113495bSYour Name 
3762*5113495bSYour Name /**
3763*5113495bSYour Name  * sme_set_mlo_max_simultaneous_links() - set mlo max simultaneous links
3764*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3765*5113495bSYour Name  * @vdev_id: VDEV id
3766*5113495bSYour Name  * @val: value to set
3767*5113495bSYour Name  *
3768*5113495bSYour Name  * Return: None
3769*5113495bSYour Name  */
3770*5113495bSYour Name void sme_set_mlo_max_simultaneous_links(mac_handle_t mac_handle,
3771*5113495bSYour Name 					uint8_t vdev_id, uint8_t val);
3772*5113495bSYour Name 
3773*5113495bSYour Name /**
3774*5113495bSYour Name  * sme_set_mlo_assoc_link_band() - set mlo assoc link band
3775*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3776*5113495bSYour Name  * @vdev_id: VDEV id
3777*5113495bSYour Name  * @val: value to be set
3778*5113495bSYour Name  *
3779*5113495bSYour Name  * Return: None
3780*5113495bSYour Name  */
3781*5113495bSYour Name void sme_set_mlo_assoc_link_band(mac_handle_t mac_handle, uint8_t vdev_id,
3782*5113495bSYour Name 				 uint8_t val);
3783*5113495bSYour Name 
3784*5113495bSYour Name /**
3785*5113495bSYour Name  * sme_activate_mlo_links() - Force active ML links based on user
3786*5113495bSYour Name  * requested link mac address
3787*5113495bSYour Name  *
3788*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3789*5113495bSYour Name  * @session_id: session id
3790*5113495bSYour Name  * @num_links: number of links to be forced active
3791*5113495bSYour Name  * @active_link_addr: link mac address of (up to 2) links to be forced active
3792*5113495bSYour Name  *
3793*5113495bSYour Name  * Return: void
3794*5113495bSYour Name  */
3795*5113495bSYour Name void sme_activate_mlo_links(mac_handle_t mac_handle, uint8_t session_id,
3796*5113495bSYour Name 			    uint8_t num_links,
3797*5113495bSYour Name 			    struct qdf_mac_addr active_link_addr[2]);
3798*5113495bSYour Name 
3799*5113495bSYour Name /**
3800*5113495bSYour Name  * sme_update_eht_caps() - Update the session EHT caps
3801*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3802*5113495bSYour Name  * @session_id: SME session id
3803*5113495bSYour Name  * @cfg_val: Set value
3804*5113495bSYour Name  * @cap_type: EHT TX beamformee capability type
3805*5113495bSYour Name  * @op_mode: Operation mode of the vdev
3806*5113495bSYour Name  *
3807*5113495bSYour Name  * Return: 0 on success otherwise error code
3808*5113495bSYour Name  */
3809*5113495bSYour Name int sme_update_eht_caps(mac_handle_t mac_handle, uint8_t session_id,
3810*5113495bSYour Name 			uint8_t cfg_val, enum sme_eht_tx_bfee_cap_type cap_type,
3811*5113495bSYour Name 			enum QDF_OPMODE op_mode);
3812*5113495bSYour Name /**
3813*5113495bSYour Name  * sme_send_vdev_pause_for_bcn_period() - Send vdev pause indication to FW
3814*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3815*5113495bSYour Name  * @session_id: SME session id
3816*5113495bSYour Name  * @cfg_val: Set vdev pause duration
3817*5113495bSYour Name  *
3818*5113495bSYour Name  * Return: 0 on success otherwise error code
3819*5113495bSYour Name  */
3820*5113495bSYour Name int sme_send_vdev_pause_for_bcn_period(mac_handle_t mac_handle,
3821*5113495bSYour Name 				       uint8_t session_id,
3822*5113495bSYour Name 				       uint8_t cfg_val);
3823*5113495bSYour Name 
3824*5113495bSYour Name /**
3825*5113495bSYour Name  * sme_set_per_link_ba_mode() - sets BA mode for each STA MLD link
3826*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
3827*5113495bSYour Name  * @val: BA mode
3828*5113495bSYour Name  *
3829*5113495bSYour Name  * Return: None
3830*5113495bSYour Name  */
3831*5113495bSYour Name void sme_set_per_link_ba_mode(mac_handle_t mac_handle, uint8_t val);
3832*5113495bSYour Name #else
sme_set_eht_testbed_def(mac_handle_t mac_handle,uint8_t vdev_id)3833*5113495bSYour Name static inline void sme_set_eht_testbed_def(mac_handle_t mac_handle,
3834*5113495bSYour Name 					   uint8_t vdev_id)
3835*5113495bSYour Name {
3836*5113495bSYour Name }
3837*5113495bSYour Name 
3838*5113495bSYour Name static inline
sme_reset_eht_caps(mac_handle_t mac_handle,uint8_t vdev_id)3839*5113495bSYour Name void sme_reset_eht_caps(mac_handle_t mac_handle, uint8_t vdev_id)
3840*5113495bSYour Name {
3841*5113495bSYour Name }
3842*5113495bSYour Name 
3843*5113495bSYour Name static inline
sme_set_mlo_max_links(mac_handle_t mac_handle,uint8_t vdev_id,uint8_t val)3844*5113495bSYour Name void sme_set_mlo_max_links(mac_handle_t mac_handle, uint8_t vdev_id,
3845*5113495bSYour Name 			   uint8_t val)
3846*5113495bSYour Name {
3847*5113495bSYour Name }
3848*5113495bSYour Name 
3849*5113495bSYour Name static inline
sme_set_mlo_assoc_link_band(mac_handle_t mac_handle,uint8_t vdev_id,uint8_t val)3850*5113495bSYour Name void sme_set_mlo_assoc_link_band(mac_handle_t mac_handle, uint8_t vdev_id,
3851*5113495bSYour Name 				 uint8_t val)
3852*5113495bSYour Name {
3853*5113495bSYour Name }
3854*5113495bSYour Name 
3855*5113495bSYour Name static inline
sme_set_mlo_max_simultaneous_links(mac_handle_t mac_handle,uint8_t vdev_id,uint8_t val)3856*5113495bSYour Name void sme_set_mlo_max_simultaneous_links(mac_handle_t mac_handle,
3857*5113495bSYour Name 					uint8_t vdev_id, uint8_t val)
3858*5113495bSYour Name {
3859*5113495bSYour Name }
3860*5113495bSYour Name 
3861*5113495bSYour Name static inline
sme_update_eht_caps(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val,enum sme_eht_tx_bfee_cap_type cap_type,enum QDF_OPMODE op_mode)3862*5113495bSYour Name int sme_update_eht_caps(mac_handle_t mac_handle, uint8_t session_id,
3863*5113495bSYour Name 			uint8_t cfg_val, enum sme_eht_tx_bfee_cap_type cap_type,
3864*5113495bSYour Name 			enum QDF_OPMODE op_mode)
3865*5113495bSYour Name {
3866*5113495bSYour Name 	return 0;
3867*5113495bSYour Name }
3868*5113495bSYour Name 
3869*5113495bSYour Name static inline
sme_send_vdev_pause_for_bcn_period(mac_handle_t mac_handle,uint8_t session_id,uint8_t cfg_val)3870*5113495bSYour Name int sme_send_vdev_pause_for_bcn_period(mac_handle_t mac_handle,
3871*5113495bSYour Name 				       uint8_t session_id,
3872*5113495bSYour Name 				       uint8_t cfg_val)
3873*5113495bSYour Name {
3874*5113495bSYour Name 	return 0;
3875*5113495bSYour Name }
3876*5113495bSYour Name 
3877*5113495bSYour Name static inline
sme_activate_mlo_links(mac_handle_t mac_handle,uint8_t session_id,uint8_t num_links,struct qdf_mac_addr active_link_addr[2])3878*5113495bSYour Name void sme_activate_mlo_links(mac_handle_t mac_handle, uint8_t session_id,
3879*5113495bSYour Name 			    uint8_t num_links,
3880*5113495bSYour Name 			    struct qdf_mac_addr active_link_addr[2])
3881*5113495bSYour Name {
3882*5113495bSYour Name }
3883*5113495bSYour Name 
3884*5113495bSYour Name static inline
sme_set_per_link_ba_mode(mac_handle_t mac_handle,uint8_t val)3885*5113495bSYour Name void sme_set_per_link_ba_mode(mac_handle_t mac_handle, uint8_t val)
3886*5113495bSYour Name {}
3887*5113495bSYour Name #endif
3888*5113495bSYour Name 
3889*5113495bSYour Name /**
3890*5113495bSYour Name  * sme_get_mcs_idx() - gets mcs index
3891*5113495bSYour Name  * @raw_rate: raw rate from fw
3892*5113495bSYour Name  * @rate_flags: rate flags
3893*5113495bSYour Name  * @is_he_mcs_12_13_supported: is he mcs12/13 supported
3894*5113495bSYour Name  * @nss: number of nss
3895*5113495bSYour Name  * @dcm: dcm will be calculated from rate
3896*5113495bSYour Name  * @guard_interval: guard interval info from rate
3897*5113495bSYour Name  * @mcs_rate_flags: mcs rate flag
3898*5113495bSYour Name  *
3899*5113495bSYour Name  * Return: return mcs index
3900*5113495bSYour Name  */
3901*5113495bSYour Name uint8_t sme_get_mcs_idx(uint16_t raw_rate, enum tx_rate_info rate_flags,
3902*5113495bSYour Name 			bool is_he_mcs_12_13_supported,
3903*5113495bSYour Name 			uint8_t *nss, uint8_t *dcm,
3904*5113495bSYour Name 			enum txrate_gi *guard_interval,
3905*5113495bSYour Name 			enum tx_rate_info *mcs_rate_flags);
3906*5113495bSYour Name 
3907*5113495bSYour Name #ifdef WLAN_SUPPORT_TWT
3908*5113495bSYour Name 
3909*5113495bSYour Name /**
3910*5113495bSYour Name  * sme_test_config_twt_terminate() - send TWT del dialog wmi command
3911*5113495bSYour Name  * to firmware
3912*5113495bSYour Name  * @params: TWT del dialog parameters
3913*5113495bSYour Name  *
3914*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on Success, other QDF_STATUS error codes
3915*5113495bSYour Name  * on failure
3916*5113495bSYour Name  */
3917*5113495bSYour Name QDF_STATUS
3918*5113495bSYour Name sme_test_config_twt_terminate(struct wmi_twt_del_dialog_param *params);
3919*5113495bSYour Name 
3920*5113495bSYour Name /**
3921*5113495bSYour Name  * sme_test_config_twt_setup() - send TWT add dialog wmi command
3922*5113495bSYour Name  * to firmware
3923*5113495bSYour Name  * @params: TWT add dialog parameters
3924*5113495bSYour Name  *
3925*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on Success, other QDF_STATUS error codes
3926*5113495bSYour Name  * on failure
3927*5113495bSYour Name  */
3928*5113495bSYour Name QDF_STATUS sme_test_config_twt_setup(struct wmi_twt_add_dialog_param *params);
3929*5113495bSYour Name 
3930*5113495bSYour Name /**
3931*5113495bSYour Name  * sme_clear_twt_complete_cb() - Initialize TWT callbacks
3932*5113495bSYour Name  * @mac_handle: MAC handle
3933*5113495bSYour Name  *
3934*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on Success, other QDF_STATUS error codes
3935*5113495bSYour Name  * on failure
3936*5113495bSYour Name  */
3937*5113495bSYour Name QDF_STATUS sme_clear_twt_complete_cb(mac_handle_t mac_handle);
3938*5113495bSYour Name 
3939*5113495bSYour Name /**
3940*5113495bSYour Name  * sme_register_twt_callbacks() - TWT enable registrar
3941*5113495bSYour Name  * @mac_handle: MAC handle
3942*5113495bSYour Name  * @twt_cb: TWT callbacks
3943*5113495bSYour Name  *
3944*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on Success, other QDF_STATUS error codes
3945*5113495bSYour Name  * on failure
3946*5113495bSYour Name  */
3947*5113495bSYour Name QDF_STATUS sme_register_twt_callbacks(mac_handle_t mac_handle,
3948*5113495bSYour Name 				      struct twt_callbacks *twt_cb);
3949*5113495bSYour Name 
3950*5113495bSYour Name /**
3951*5113495bSYour Name  * sme_add_dialog_cmd() - Register callback and send TWT add dialog
3952*5113495bSYour Name  * command to firmware
3953*5113495bSYour Name  * @mac_handle: MAC handle
3954*5113495bSYour Name  * @twt_add_dialog_cb: Function callback to handle add_dialog event
3955*5113495bSYour Name  * @twt_params: TWT add dialog parameters
3956*5113495bSYour Name  * @context: TWT context
3957*5113495bSYour Name  *
3958*5113495bSYour Name  * Return: QDF Status
3959*5113495bSYour Name  */
3960*5113495bSYour Name QDF_STATUS sme_add_dialog_cmd(mac_handle_t mac_handle,
3961*5113495bSYour Name 			      twt_add_dialog_cb twt_add_dialog_cb,
3962*5113495bSYour Name 			      struct wmi_twt_add_dialog_param *twt_params,
3963*5113495bSYour Name 			      void *context);
3964*5113495bSYour Name 
3965*5113495bSYour Name /**
3966*5113495bSYour Name  * sme_del_dialog_cmd() - Register callback and send TWT del dialog
3967*5113495bSYour Name  * command to firmware
3968*5113495bSYour Name  * @mac_handle: MAC handle
3969*5113495bSYour Name  * @twt_del_dialog_cb: Function callback to handle del_dialog event
3970*5113495bSYour Name  * @twt_params: TWT del dialog parameters
3971*5113495bSYour Name  * @context: TWT context
3972*5113495bSYour Name  *
3973*5113495bSYour Name  * Return: QDF Status
3974*5113495bSYour Name  */
3975*5113495bSYour Name QDF_STATUS sme_del_dialog_cmd(mac_handle_t mac_handle,
3976*5113495bSYour Name 			      twt_del_dialog_cb del_dialog_cb,
3977*5113495bSYour Name 			      struct wmi_twt_del_dialog_param *twt_params,
3978*5113495bSYour Name 			      void *context);
3979*5113495bSYour Name 
3980*5113495bSYour Name /**
3981*5113495bSYour Name  * sme_sap_del_dialog_cmd() - Register callback and send TWT del dialog
3982*5113495bSYour Name  * command to firmware
3983*5113495bSYour Name  * @mac_handle: MAC handle
3984*5113495bSYour Name  * @twt_del_dialog_cb: Function callback to handle del_dialog event
3985*5113495bSYour Name  * @twt_params: TWT del dialog parameters
3986*5113495bSYour Name  *
3987*5113495bSYour Name  * Return: QDF Status
3988*5113495bSYour Name  */
3989*5113495bSYour Name QDF_STATUS sme_sap_del_dialog_cmd(mac_handle_t mac_handle,
3990*5113495bSYour Name 				  twt_del_dialog_cb del_dialog_cb,
3991*5113495bSYour Name 				  struct wmi_twt_del_dialog_param *twt_params);
3992*5113495bSYour Name 
3993*5113495bSYour Name /**
3994*5113495bSYour Name  * sme_pause_dialog_cmd() - Register callback and send TWT pause dialog
3995*5113495bSYour Name  * command to firmware
3996*5113495bSYour Name  * @mac_handle: MAC handle
3997*5113495bSYour Name  * @twt_params: TWT pause dialog parameters
3998*5113495bSYour Name  * @context: TWT context
3999*5113495bSYour Name  *
4000*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on Success, other QDF_STATUS error codes
4001*5113495bSYour Name  * on failure
4002*5113495bSYour Name  */
4003*5113495bSYour Name QDF_STATUS
4004*5113495bSYour Name sme_pause_dialog_cmd(mac_handle_t mac_handle,
4005*5113495bSYour Name 		     struct wmi_twt_pause_dialog_cmd_param *twt_params,
4006*5113495bSYour Name 		     void *context);
4007*5113495bSYour Name 
4008*5113495bSYour Name /**
4009*5113495bSYour Name  * sme_nudge_dialog_cmd() - Register callback and send TWT nudge dialog
4010*5113495bSYour Name  * command to firmware
4011*5113495bSYour Name  * @mac_handle: MAC handle
4012*5113495bSYour Name  * @twt_params: TWT nudge dialog parameters
4013*5113495bSYour Name  * @context: TWT context
4014*5113495bSYour Name  *
4015*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on Success, other QDF_STATUS error codes
4016*5113495bSYour Name  * on failure
4017*5113495bSYour Name  */
4018*5113495bSYour Name QDF_STATUS
4019*5113495bSYour Name sme_nudge_dialog_cmd(mac_handle_t mac_handle,
4020*5113495bSYour Name 		     struct wmi_twt_nudge_dialog_cmd_param *twt_params,
4021*5113495bSYour Name 		     void *context);
4022*5113495bSYour Name 
4023*5113495bSYour Name /**
4024*5113495bSYour Name  * sme_resume_dialog_cmd() - Register callback and send TWT resume dialog
4025*5113495bSYour Name  * command to firmware
4026*5113495bSYour Name  * @mac_handle: MAC handle
4027*5113495bSYour Name  * @twt_params: TWT resume dialog parameters
4028*5113495bSYour Name  * @context: TWT context
4029*5113495bSYour Name  *
4030*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS on Success, other QDF_STATUS error codes
4031*5113495bSYour Name  * on failure
4032*5113495bSYour Name  */
4033*5113495bSYour Name QDF_STATUS
4034*5113495bSYour Name sme_resume_dialog_cmd(mac_handle_t mac_handle,
4035*5113495bSYour Name 		      struct wmi_twt_resume_dialog_cmd_param *twt_params,
4036*5113495bSYour Name 		      void *context);
4037*5113495bSYour Name 
4038*5113495bSYour Name /**
4039*5113495bSYour Name  * sme_twt_update_beacon_template() - API to send beacon update to fw
4040*5113495bSYour Name  * @mac_handle: MAC handle
4041*5113495bSYour Name  *
4042*5113495bSYour Name  * Return: None
4043*5113495bSYour Name  */
4044*5113495bSYour Name void sme_twt_update_beacon_template(mac_handle_t mac_handle);
4045*5113495bSYour Name 
4046*5113495bSYour Name #else
4047*5113495bSYour Name 
4048*5113495bSYour Name static inline
sme_test_config_twt_setup(struct wmi_twt_add_dialog_param * params)4049*5113495bSYour Name QDF_STATUS sme_test_config_twt_setup(struct wmi_twt_add_dialog_param *params)
4050*5113495bSYour Name {
4051*5113495bSYour Name 	return QDF_STATUS_E_FAILURE;
4052*5113495bSYour Name }
4053*5113495bSYour Name 
4054*5113495bSYour Name static inline QDF_STATUS
sme_test_config_twt_terminate(struct wmi_twt_del_dialog_param * params)4055*5113495bSYour Name sme_test_config_twt_terminate(struct wmi_twt_del_dialog_param *params)
4056*5113495bSYour Name {
4057*5113495bSYour Name 	return QDF_STATUS_E_FAILURE;
4058*5113495bSYour Name }
4059*5113495bSYour Name 
4060*5113495bSYour Name static inline
sme_twt_update_beacon_template(mac_handle_t mac_handle)4061*5113495bSYour Name void sme_twt_update_beacon_template(mac_handle_t mac_handle)
4062*5113495bSYour Name {
4063*5113495bSYour Name }
4064*5113495bSYour Name 
4065*5113495bSYour Name #endif
4066*5113495bSYour Name 
4067*5113495bSYour Name #ifdef WLAN_UNIT_TEST
4068*5113495bSYour Name /**
4069*5113495bSYour Name  * sme_get_sta_cxn_info() - This function populates all the connection
4070*5113495bSYour Name  *			    information which is formed by DUT-STA to AP
4071*5113495bSYour Name  *			    by calling CSR helper API.
4072*5113495bSYour Name  * @mac_ctx: pointer to mac context
4073*5113495bSYour Name  * @session: pointer to sta session
4074*5113495bSYour Name  * @conn_profile: pointer to connected DUTSTA-REFAP profile
4075*5113495bSYour Name  * @buf: pointer to char buffer to write all the connection information.
4076*5113495bSYour Name  * @buf_size: maximum size of the provided buffer
4077*5113495bSYour Name  *
4078*5113495bSYour Name  * Returns: QDF_STATUS
4079*5113495bSYour Name  */
4080*5113495bSYour Name #ifdef FEATURE_WLAN_DIAG_SUPPORT_CSR
4081*5113495bSYour Name QDF_STATUS sme_get_sta_cxn_info(mac_handle_t mac_handle, uint32_t session_id,
4082*5113495bSYour Name 				char *buf, uint32_t buf_sz);
4083*5113495bSYour Name #else
4084*5113495bSYour Name static inline QDF_STATUS
sme_get_sta_cxn_info(mac_handle_t mac_handle,uint32_t session_id,char * buf,uint32_t buf_sz)4085*5113495bSYour Name sme_get_sta_cxn_info(mac_handle_t mac_handle, uint32_t session_id,
4086*5113495bSYour Name 		     char *buf, uint32_t buf_sz)
4087*5113495bSYour Name {
4088*5113495bSYour Name 	qdf_scnprintf(buf, buf_sz,
4089*5113495bSYour Name 		      "\nDiag macro disable, ask vendor to enable");
4090*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
4091*5113495bSYour Name }
4092*5113495bSYour Name #endif
4093*5113495bSYour Name #endif
4094*5113495bSYour Name 
4095*5113495bSYour Name #if defined(FEATURE_WLAN_ESE) && defined(WLAN_FEATURE_ROAM_OFFLOAD)
4096*5113495bSYour Name /**
4097*5113495bSYour Name  * sme_add_key_btk() - Add BTK key
4098*5113495bSYour Name  * @mac_handle: MAC handle
4099*5113495bSYour Name  * @session_id: SME session identifier
4100*5113495bSYour Name  * @key: key material
4101*5113495bSYour Name  * @key_len: length of the key
4102*5113495bSYour Name  *
4103*5113495bSYour Name  * Return: 0 on success and negative value for failure
4104*5113495bSYour Name  */
4105*5113495bSYour Name int sme_add_key_btk(mac_handle_t mac_handle, uint8_t session_id,
4106*5113495bSYour Name 		    const uint8_t *key, const int key_len);
4107*5113495bSYour Name 
4108*5113495bSYour Name #else
sme_add_key_btk(mac_handle_t mac_handle,uint8_t session_id,const uint8_t * key,const int key_len)4109*5113495bSYour Name static inline int sme_add_key_btk(mac_handle_t mac_handle, uint8_t session_id,
4110*5113495bSYour Name 				  const uint8_t *key, const int key_len)
4111*5113495bSYour Name {
4112*5113495bSYour Name 	return 0;
4113*5113495bSYour Name }
4114*5113495bSYour Name #endif
4115*5113495bSYour Name 
4116*5113495bSYour Name #ifdef FEATURE_WLAN_ESE
4117*5113495bSYour Name /**
4118*5113495bSYour Name  * sme_add_key_krk() - Add KRK key
4119*5113495bSYour Name  * @mac_handle: MAC handle
4120*5113495bSYour Name  * @session_id: SME session identifier
4121*5113495bSYour Name  * @key: key material
4122*5113495bSYour Name  * @key_len: length of the key
4123*5113495bSYour Name  *
4124*5113495bSYour Name  * Return: 0 on success and negative value for failure
4125*5113495bSYour Name  */
4126*5113495bSYour Name int sme_add_key_krk(mac_handle_t mac_handle, uint8_t session_id,
4127*5113495bSYour Name 		    const uint8_t *key, const int key_len);
4128*5113495bSYour Name 
4129*5113495bSYour Name #else
4130*5113495bSYour Name 
sme_add_key_krk(mac_handle_t mac_handle,uint8_t session_id,const uint8_t * key,const int key_len)4131*5113495bSYour Name static inline int sme_add_key_krk(mac_handle_t mac_handle, uint8_t session_id,
4132*5113495bSYour Name 				  const uint8_t *key, const int key_len)
4133*5113495bSYour Name {
4134*5113495bSYour Name 	return 0;
4135*5113495bSYour Name }
4136*5113495bSYour Name #endif
4137*5113495bSYour Name 
4138*5113495bSYour Name /**
4139*5113495bSYour Name  * sme_get_roam_scan_stats() - Send roam scan stats cmd to wma
4140*5113495bSYour Name  * @mac_handle: handle returned by mac_open
4141*5113495bSYour Name  * @cb: call-back invoked for roam scan stats response
4142*5113495bSYour Name  * @context: context of callback
4143*5113495bSYour Name  * @vdev_id: vdev id
4144*5113495bSYour Name  *
4145*5113495bSYour Name  * Return: QDF_STATUS
4146*5113495bSYour Name  */
4147*5113495bSYour Name QDF_STATUS
4148*5113495bSYour Name sme_get_roam_scan_stats(mac_handle_t mac_handle, roam_scan_stats_cb cb,
4149*5113495bSYour Name 			void *context, uint32_t vdev_id);
4150*5113495bSYour Name 
4151*5113495bSYour Name /**
4152*5113495bSYour Name  * sme_update_score_config() - Update the Scoring Config from MLME
4153*5113495bSYour Name  * @mac_handle: Mac Handle
4154*5113495bSYour Name  * @phy_mode: Phymode to be used
4155*5113495bSYour Name  * @num_rf_chains: num of RF chains supported by HW
4156*5113495bSYour Name  *
4157*5113495bSYour Name  * Return: None
4158*5113495bSYour Name  */
4159*5113495bSYour Name void sme_update_score_config(mac_handle_t mac_handle, eCsrPhyMode phy_mode,
4160*5113495bSYour Name 			     uint8_t num_rf_chains);
4161*5113495bSYour Name 
4162*5113495bSYour Name /**
4163*5113495bSYour Name  * sme_enable_fw_module_log_level() - enable fw module log level
4164*5113495bSYour Name  * @mac_handle: handle returned by mac_open
4165*5113495bSYour Name  * @vdev_id: vdev id
4166*5113495bSYour Name  *
4167*5113495bSYour Name  * Return: None
4168*5113495bSYour Name  */
4169*5113495bSYour Name void sme_enable_fw_module_log_level(mac_handle_t mac_handle, int vdev_id);
4170*5113495bSYour Name 
4171*5113495bSYour Name #ifdef WLAN_FEATURE_MOTION_DETECTION
4172*5113495bSYour Name /**
4173*5113495bSYour Name  * sme_motion_det_cfg - motion detection configuration
4174*5113495bSYour Name  * @vdev_id: vdev id
4175*5113495bSYour Name  * @time_t1: Time T1 for motion detection in msecs
4176*5113495bSYour Name  * @time_t2: Time T2 for motion detection in msecs
4177*5113495bSYour Name  * @n1: number of packets for coarse detection
4178*5113495bSYour Name  * @n2: number of packets for fine detection
4179*5113495bSYour Name  * @time_t1_gap: gap between packets in coarse detection in msecs
4180*5113495bSYour Name  * @time_t2_gap: gap between packets in fine detection in msecs
4181*5113495bSYour Name  * @coarse_k: number of times fine motion detection has to be performed for
4182*5113495bSYour Name  *	      coarse detection
4183*5113495bSYour Name  * @fine_k: number of times fine motion detection has to be performed for
4184*5113495bSYour Name  *	    fine detection
4185*5113495bSYour Name  * @coarse_q: number of times motion is expected to be detected for success
4186*5113495bSYour Name  *	      case in coarse detection
4187*5113495bSYour Name  * @fine_q: number of times motion is expected to be detected for success
4188*5113495bSYour Name  *	    case in fine detection
4189*5113495bSYour Name  * @md_coarse_thr_high: higher threshold value (in percent) from host to FW,
4190*5113495bSYour Name  *			which will be used in coarse detection phase of motion
4191*5113495bSYour Name  *			detection. This is the threshold for the correlation of
4192*5113495bSYour Name  *			the old RF local-scattering environment with current RF
4193*5113495bSYour Name  *			local-scattering environment. Value of 100(%) indicates
4194*5113495bSYour Name  *			that neither the transceiver nor any nearby objects
4195*5113495bSYour Name  *			have changed position
4196*5113495bSYour Name  * @md_fine_thr_high: higher threshold value (in percent) from host to FW, which
4197*5113495bSYour Name  *		      will be used in fine detection phase of motion detection.
4198*5113495bSYour Name  *		      This is the threshold for correlation between the old and
4199*5113495bSYour Name  *		      current RF environments, as explained above
4200*5113495bSYour Name  * @md_coarse_thr_low: lower threshold value (in percent) for immediate
4201*5113495bSYour Name  *		       detection of motion in coarse detection phase. This is
4202*5113495bSYour Name  *		       the threshold for correlation between the old and current
4203*5113495bSYour Name  *		       RF environments, as explained above
4204*5113495bSYour Name  * @md_fine_thr_low: lower threshold value (in percent) for immediate detection
4205*5113495bSYour Name  *		     of motion in fine detection phase. This is the threshold
4206*5113495bSYour Name  *		     for correlation between the old and current RF
4207*5113495bSYour Name  *		     environments, as explained above
4208*5113495bSYour Name  * @eSME_TDLS_PEER_REMOVE_MAC_ADDR: remove peer mac from connection table
4209*5113495bSYour Name  */
4210*5113495bSYour Name 
4211*5113495bSYour Name struct sme_motion_det_cfg {
4212*5113495bSYour Name 	uint8_t vdev_id;
4213*5113495bSYour Name 	uint32_t time_t1;
4214*5113495bSYour Name 	uint32_t time_t2;
4215*5113495bSYour Name 	uint32_t n1;
4216*5113495bSYour Name 	uint32_t n2;
4217*5113495bSYour Name 	uint32_t time_t1_gap;
4218*5113495bSYour Name 	uint32_t time_t2_gap;
4219*5113495bSYour Name 	uint32_t coarse_K;
4220*5113495bSYour Name 	uint32_t fine_K;
4221*5113495bSYour Name 	uint32_t coarse_Q;
4222*5113495bSYour Name 	uint32_t fine_Q;
4223*5113495bSYour Name 	uint8_t md_coarse_thr_high;
4224*5113495bSYour Name 	uint8_t md_fine_thr_high;
4225*5113495bSYour Name 	uint8_t md_coarse_thr_low;
4226*5113495bSYour Name 	uint8_t md_fine_thr_low;
4227*5113495bSYour Name };
4228*5113495bSYour Name 
4229*5113495bSYour Name /**
4230*5113495bSYour Name  * sme_motion_det_base_line_cfg - motion detection base line configuration
4231*5113495bSYour Name  * @vdev_id : vdev id
4232*5113495bSYour Name  * @bl_time_t: time T for baseline (in ms), every bl_time_t, bl_n pkts are sent
4233*5113495bSYour Name  * @bl_packet_gap: gap between packets for baseline  in msecs
4234*5113495bSYour Name  * bl_n: number of packets to be sent during one baseline
4235*5113495bSYour Name  * bl_num_meas: number of times the baseline measurement to be done
4236*5113495bSYour Name  */
4237*5113495bSYour Name struct sme_motion_det_base_line_cfg {
4238*5113495bSYour Name 	uint8_t vdev_id;
4239*5113495bSYour Name 	uint32_t bl_time_t;
4240*5113495bSYour Name 	uint32_t bl_packet_gap;
4241*5113495bSYour Name 	uint32_t bl_n;
4242*5113495bSYour Name 	uint32_t bl_num_meas;
4243*5113495bSYour Name };
4244*5113495bSYour Name 
4245*5113495bSYour Name /**
4246*5113495bSYour Name  * sme_motion_det_en - Start/Stop motion detection
4247*5113495bSYour Name  * @vdev_id: vdev_id
4248*5113495bSYour Name  * @enable: start = 1, stop =0
4249*5113495bSYour Name  */
4250*5113495bSYour Name struct sme_motion_det_en {
4251*5113495bSYour Name 	uint8_t vdev_id;
4252*5113495bSYour Name 	bool enable;
4253*5113495bSYour Name };
4254*5113495bSYour Name 
4255*5113495bSYour Name /**
4256*5113495bSYour Name  * sme_motion_det_base_line_en - Start/Stop motion detection base line
4257*5113495bSYour Name  * @vdev_id: vdev_id
4258*5113495bSYour Name  * @enable: start = 1, stop =0
4259*5113495bSYour Name  */
4260*5113495bSYour Name struct sme_motion_det_base_line_en {
4261*5113495bSYour Name 	uint8_t vdev_id;
4262*5113495bSYour Name 	bool enable;
4263*5113495bSYour Name };
4264*5113495bSYour Name 
4265*5113495bSYour Name /**
4266*5113495bSYour Name  * sme_motion_det_config - Post motion detection configuration msg to scheduler
4267*5113495bSYour Name  * @mac_handle: mac handle
4268*5113495bSYour Name  * @motion_det_cfg: motion detection configuration
4269*5113495bSYour Name  *
4270*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure
4271*5113495bSYour Name  */
4272*5113495bSYour Name QDF_STATUS sme_motion_det_config(mac_handle_t mac_handle,
4273*5113495bSYour Name 				 struct sme_motion_det_cfg *motion_det_cfg);
4274*5113495bSYour Name 
4275*5113495bSYour Name /**
4276*5113495bSYour Name  * sme_motion_det_enable - Post motion detection start/stop msg to scheduler
4277*5113495bSYour Name  * @mac_handle: mac handle
4278*5113495bSYour Name  * @motion_det_en: motion detection start/stop
4279*5113495bSYour Name  *
4280*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure
4281*5113495bSYour Name  */
4282*5113495bSYour Name QDF_STATUS sme_motion_det_enable(mac_handle_t mac_handle,
4283*5113495bSYour Name 				 struct sme_motion_det_en *motion_det_en);
4284*5113495bSYour Name 
4285*5113495bSYour Name /**
4286*5113495bSYour Name  * sme_motion_det_base_line_config - Post md baselining cfg msg to scheduler
4287*5113495bSYour Name  * @mac_handle: mac handle
4288*5113495bSYour Name  * @motion_det_base_line_cfg: motion detection baselining configuration
4289*5113495bSYour Name  *
4290*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure
4291*5113495bSYour Name  */
4292*5113495bSYour Name QDF_STATUS sme_motion_det_base_line_config(
4293*5113495bSYour Name 		mac_handle_t mac_handle,
4294*5113495bSYour Name 		struct sme_motion_det_base_line_cfg *motion_det_base_line_cfg);
4295*5113495bSYour Name 
4296*5113495bSYour Name /**
4297*5113495bSYour Name  * sme_motion_det_base_line_enable - Post md baselining enable msg to scheduler
4298*5113495bSYour Name  * @mac_handle: mac handle
4299*5113495bSYour Name  * @motion_det_base_line_en: motion detection baselining start/stop
4300*5113495bSYour Name  *
4301*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure
4302*5113495bSYour Name  */
4303*5113495bSYour Name QDF_STATUS sme_motion_det_base_line_enable(
4304*5113495bSYour Name 		mac_handle_t mac_handle,
4305*5113495bSYour Name 		struct sme_motion_det_base_line_en *motion_det_base_line_en);
4306*5113495bSYour Name 
4307*5113495bSYour Name /**
4308*5113495bSYour Name  * sme_set_md_host_evt_cb - Register/set motion detection callback
4309*5113495bSYour Name  * @mac_handle: mac handle
4310*5113495bSYour Name  * @callback_fn: motion detection callback function pointer
4311*5113495bSYour Name  * @hdd_ctx: hdd context
4312*5113495bSYour Name  *
4313*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure
4314*5113495bSYour Name  */
4315*5113495bSYour Name QDF_STATUS sme_set_md_host_evt_cb
4316*5113495bSYour Name (
4317*5113495bSYour Name 	mac_handle_t mac_handle,
4318*5113495bSYour Name 	QDF_STATUS (*callback_fn)(void *ctx, struct sir_md_evt *event),
4319*5113495bSYour Name 	void *hdd_ctx
4320*5113495bSYour Name );
4321*5113495bSYour Name 
4322*5113495bSYour Name /**
4323*5113495bSYour Name  * sme_set_md_bl_evt_cb - Register/set motion detection baseline callback
4324*5113495bSYour Name  * @mac_handle: mac handle
4325*5113495bSYour Name  * @callback_fn: callback function pointer
4326*5113495bSYour Name  * @hdd_ctx: hdd context
4327*5113495bSYour Name  *
4328*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS or non-zero on failure
4329*5113495bSYour Name  */
4330*5113495bSYour Name QDF_STATUS sme_set_md_bl_evt_cb
4331*5113495bSYour Name (
4332*5113495bSYour Name 	mac_handle_t mac_handle,
4333*5113495bSYour Name 	QDF_STATUS (*callback_fn)(void *ctx, struct sir_md_bl_evt *event),
4334*5113495bSYour Name 	void *hdd_ctx
4335*5113495bSYour Name );
4336*5113495bSYour Name #endif /* WLAN_FEATURE_MOTION_DETECTION */
4337*5113495bSYour Name 
4338*5113495bSYour Name #ifdef FW_THERMAL_THROTTLE_SUPPORT
4339*5113495bSYour Name /**
4340*5113495bSYour Name  * sme_set_thermal_throttle_cfg() - SME API to set the thermal throttle
4341*5113495bSYour Name  * configuration parameters
4342*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
4343*5113495bSYour Name  * @therm_params: Thermal_params
4344*5113495bSYour Name  *
4345*5113495bSYour Name  * Return: QDF_STATUS
4346*5113495bSYour Name  */
4347*5113495bSYour Name QDF_STATUS sme_set_thermal_throttle_cfg(mac_handle_t mac_handle,
4348*5113495bSYour Name 			    struct thermal_mitigation_params *therm_params);
4349*5113495bSYour Name 
4350*5113495bSYour Name /**
4351*5113495bSYour Name  * sme_set_thermal_mgmt() - SME API to set the thermal management params
4352*5113495bSYour Name  * @mac_handle: Opaque handle to the global MAC context
4353*5113495bSYour Name  * @lower_thresh_deg: Lower threshold value of Temperature
4354*5113495bSYour Name  * @higher_thresh_deg: Higher threshold value of Temperature
4355*5113495bSYour Name  *
4356*5113495bSYour Name  * Return: QDF_STATUS
4357*5113495bSYour Name  */
4358*5113495bSYour Name QDF_STATUS sme_set_thermal_mgmt(mac_handle_t mac_handle,
4359*5113495bSYour Name 				uint16_t lower_thresh_deg,
4360*5113495bSYour Name 				uint16_t higher_thresh_deg);
4361*5113495bSYour Name #endif /* FW_THERMAL_THROTTLE_SUPPORT */
4362*5113495bSYour Name 
4363*5113495bSYour Name /**
4364*5113495bSYour Name  * sme_update_hidden_ssid_status_cb() - cb fun to update hidden ssid stats
4365*5113495bSYour Name  * @mac_handle: mac handler
4366*5113495bSYour Name  * @cb: cb of type hidden_ssid_cb
4367*5113495bSYour Name  */
4368*5113495bSYour Name QDF_STATUS sme_update_hidden_ssid_status_cb(mac_handle_t mac_handle,
4369*5113495bSYour Name 					    hidden_ssid_cb cb);
4370*5113495bSYour Name 
4371*5113495bSYour Name /**
4372*5113495bSYour Name  * sme_update_owe_info() - Update OWE info
4373*5113495bSYour Name  * @mac: mac context
4374*5113495bSYour Name  * @assoc_ind: assoc ind
4375*5113495bSYour Name  *
4376*5113495bSYour Name  * Return: QDF_STATUS
4377*5113495bSYour Name  */
4378*5113495bSYour Name QDF_STATUS sme_update_owe_info(struct mac_context *mac,
4379*5113495bSYour Name 			       struct assoc_ind *assoc_ind);
4380*5113495bSYour Name 
4381*5113495bSYour Name /**
4382*5113495bSYour Name  * sme_update_ft_info() - Update FT info
4383*5113495bSYour Name  * @mac: mac context
4384*5113495bSYour Name  * @assoc_ind: assoc ind
4385*5113495bSYour Name  *
4386*5113495bSYour Name  * Return: QDF_STATUS
4387*5113495bSYour Name  */
4388*5113495bSYour Name 
4389*5113495bSYour Name QDF_STATUS sme_update_ft_info(struct mac_context *mac,
4390*5113495bSYour Name 			      struct assoc_ind *assoc_ind);
4391*5113495bSYour Name 
4392*5113495bSYour Name #ifdef WLAN_MWS_INFO_DEBUGFS
4393*5113495bSYour Name /**
4394*5113495bSYour Name  * sme_get_mws_coex_info() - SME API to get the coex information
4395*5113495bSYour Name  * @mac_handle: mac handler
4396*5113495bSYour Name  * @vdev_id: Vdev_id
4397*5113495bSYour Name  * @cmd_id: enum mws_coex_cmdid which information is needed.
4398*5113495bSYour Name  * @callback_fn: Callback function
4399*5113495bSYour Name  * @context: callback context
4400*5113495bSYour Name  *
4401*5113495bSYour Name  * Return: QDF_STATUS
4402*5113495bSYour Name  */
4403*5113495bSYour Name QDF_STATUS
4404*5113495bSYour Name sme_get_mws_coex_info(mac_handle_t mac_handle, uint32_t vdev_id,
4405*5113495bSYour Name 		      uint32_t cmd_id, void (*callback_fn)(void *coex_info_data,
4406*5113495bSYour Name 							   void *context,
4407*5113495bSYour Name 							   wmi_mws_coex_cmd_id
4408*5113495bSYour Name 							   cmd_id),
4409*5113495bSYour Name 		      void *context);
4410*5113495bSYour Name #endif /* WLAN_MWS_INFO_DEBUGFS */
4411*5113495bSYour Name 
4412*5113495bSYour Name #ifdef WLAN_BCN_RECV_FEATURE
4413*5113495bSYour Name /**
4414*5113495bSYour Name  * sme_register_bcn_recv_pause_ind_cb() - Register pause ind cb
4415*5113495bSYour Name  * mac_handle: man handler
4416*5113495bSYour Name  * cb: callback function to HDD
4417*5113495bSYour Name  *
4418*5113495bSYour Name  * This function register HDD callback in order to indicate beacon
4419*5113495bSYour Name  * receive pause indication to userspace.
4420*5113495bSYour Name  *
4421*5113495bSYour Name  * return QDF_STATUS of cb registration
4422*5113495bSYour Name  */
4423*5113495bSYour Name QDF_STATUS sme_register_bcn_recv_pause_ind_cb(mac_handle_t mac_handle,
4424*5113495bSYour Name 					      beacon_pause_cb cb);
4425*5113495bSYour Name 
4426*5113495bSYour Name #else
4427*5113495bSYour Name static inline
sme_register_bcn_recv_pause_ind_cb(mac_handle_t mac_handle,beacon_pause_cb cb)4428*5113495bSYour Name QDF_STATUS sme_register_bcn_recv_pause_ind_cb(mac_handle_t mac_handle,
4429*5113495bSYour Name 					      beacon_pause_cb cb)
4430*5113495bSYour Name {
4431*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
4432*5113495bSYour Name }
4433*5113495bSYour Name #endif
4434*5113495bSYour Name 
4435*5113495bSYour Name /**
4436*5113495bSYour Name  * sme_set_disconnect_ies() - set disconnect IEs
4437*5113495bSYour Name  * @mac_handle: handle returned by mac_open
4438*5113495bSYour Name  * @vdev_id: vdev id
4439*5113495bSYour Name  * @ie_data: Disconnect IE data
4440*5113495bSYour Name  * @ie_len: Disconnect IE length
4441*5113495bSYour Name  *
4442*5113495bSYour Name  * Return: QDF_STATUS
4443*5113495bSYour Name  */
4444*5113495bSYour Name QDF_STATUS sme_set_disconnect_ies(mac_handle_t mac_handle, uint8_t vdev_id,
4445*5113495bSYour Name 				  uint8_t *ie_data, uint16_t ie_len);
4446*5113495bSYour Name 
4447*5113495bSYour Name /**
4448*5113495bSYour Name  * sme_set_vdev_sw_retry() - set sw retry threshold per vdev
4449*5113495bSYour Name  * @vdev_id: vdev id
4450*5113495bSYour Name  * @sw_retry_count: sw retry number
4451*5113495bSYour Name  * @retry_type: SW vdev retry type
4452*5113495bSYour Name  *
4453*5113495bSYour Name  * This function calls WMA api to send the sw retry threshold per vdev.
4454*5113495bSYour Name  *
4455*5113495bSYour Name  * Return: QDF_STATUS.
4456*5113495bSYour Name  */
4457*5113495bSYour Name QDF_STATUS sme_set_vdev_sw_retry(uint8_t vdev_id, uint8_t sw_retry_count,
4458*5113495bSYour Name 				 wmi_vdev_custom_sw_retry_type_t sw_retry_type);
4459*5113495bSYour Name 
4460*5113495bSYour Name /**
4461*5113495bSYour Name  * sme_set_roam_config_enable() - Cache roam config status in SME
4462*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
4463*5113495bSYour Name  * @vdev_id: vdev id
4464*5113495bSYour Name  * @roam_control_enable: Carries a non-zero value if the current set request is
4465*5113495bSYour Name  *			 for enable, otherwise carries a 0.
4466*5113495bSYour Name  *
4467*5113495bSYour Name  * Cache control roam config enable/disable status in SME so that the
4468*5113495bSYour Name  * userspace can query for the status based on a vdev/session at any time.
4469*5113495bSYour Name  *
4470*5113495bSYour Name  * Return: QDF_STATUS
4471*5113495bSYour Name  */
4472*5113495bSYour Name QDF_STATUS sme_set_roam_config_enable(mac_handle_t mac_handle,
4473*5113495bSYour Name 				      uint8_t vdev_id,
4474*5113495bSYour Name 				      uint8_t roam_control_enable);
4475*5113495bSYour Name 
4476*5113495bSYour Name /**
4477*5113495bSYour Name  * sme_send_vendor_btm_params - Send vendor btm params to FW
4478*5113495bSYour Name  * @hdd_ctx: HDD context
4479*5113495bSYour Name  * @vdev_id: vdev id
4480*5113495bSYour Name  *
4481*5113495bSYour Name  * Send roam trigger param to firmware if valid.
4482*5113495bSYour Name  *
4483*5113495bSYour Name  * Return: QDF_STATUS
4484*5113495bSYour Name  */
4485*5113495bSYour Name QDF_STATUS
4486*5113495bSYour Name sme_send_vendor_btm_params(mac_handle_t mac_handle, uint8_t vdev_id);
4487*5113495bSYour Name 
4488*5113495bSYour Name /**
4489*5113495bSYour Name  * sme_get_roam_config_status() - Get roam config status from SME
4490*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
4491*5113495bSYour Name  * @vdev_id: vdev id
4492*5113495bSYour Name  * @config_status: Pointer of a buffer to fill the status
4493*5113495bSYour Name  *
4494*5113495bSYour Name  * Get the cached control roam config status in SME and copy to status.
4495*5113495bSYour Name  *
4496*5113495bSYour Name  * Return: QDF_STATUS
4497*5113495bSYour Name  */
4498*5113495bSYour Name QDF_STATUS sme_get_roam_config_status(mac_handle_t mac_handle, uint8_t vdev_id,
4499*5113495bSYour Name 				      uint8_t *config_status);
4500*5113495bSYour Name 
4501*5113495bSYour Name /**
4502*5113495bSYour Name  * sme_get_full_roam_scan_period_global() - get global full scan refresh period
4503*5113495bSYour Name  * @mac_handle: The handle returned by mac_open
4504*5113495bSYour Name  *
4505*5113495bSYour Name  * Return: Full roam scan period configured through ini
4506*5113495bSYour Name  */
4507*5113495bSYour Name uint16_t sme_get_full_roam_scan_period_global(mac_handle_t mac_handle);
4508*5113495bSYour Name 
4509*5113495bSYour Name /**
4510*5113495bSYour Name  * sme_get_full_roam_scan_period() - Get full roam scan period
4511*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
4512*5113495bSYour Name  * @vdev_id: vdev id
4513*5113495bSYour Name  * @full_roam_scan_period: Pointer of a buffer to fill the full roam scan period
4514*5113495bSYour Name  *
4515*5113495bSYour Name  * Get the full scan period cached in neighborRoamInfo and fill in the given
4516*5113495bSYour Name  * buffer full_roam_scan_period.
4517*5113495bSYour Name  *
4518*5113495bSYour Name  * Return: QDF_STATUS
4519*5113495bSYour Name  */
4520*5113495bSYour Name QDF_STATUS sme_get_full_roam_scan_period(mac_handle_t mac_handle,
4521*5113495bSYour Name 					 uint8_t vdev_id,
4522*5113495bSYour Name 					 uint32_t *full_roam_scan_period);
4523*5113495bSYour Name 
4524*5113495bSYour Name /**
4525*5113495bSYour Name  * sme_check_for_duplicate_session() - check for duplicate session
4526*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
4527*5113495bSYour Name  * @mac_list: List of mac address of peers.
4528*5113495bSYour Name  *
4529*5113495bSYour Name  * Check for duplicate mac address is available on other vdev.
4530*5113495bSYour Name  * The list pointed by @mac_list has to be NULL terminated.
4531*5113495bSYour Name  *
4532*5113495bSYour Name  * Return: QDF_STATUS
4533*5113495bSYour Name  */
4534*5113495bSYour Name QDF_STATUS sme_check_for_duplicate_session(mac_handle_t mac_handle,
4535*5113495bSYour Name 					   uint8_t **mac_list);
4536*5113495bSYour Name #ifdef FEATURE_ANI_LEVEL_REQUEST
4537*5113495bSYour Name /*
4538*5113495bSYour Name  * sme_get_ani_level() -
4539*5113495bSYour Name  * A wrapper function that client calls to register a callback to get ani level
4540*5113495bSYour Name  *
4541*5113495bSYour Name  * @mac_handle - pointer to mac handle
4542*5113495bSYour Name  * @freqs - frequencies for which ANI level has to be fetched
4543*5113495bSYour Name  * @num_freqs - number of frequencies
4544*5113495bSYour Name  * @callback - SME sends back the ani level using the callback
4545*5113495bSYour Name  * @context - user context to be passed back along with the callback
4546*5113495bSYour Name  *
4547*5113495bSYour Name  * Return: QDF_STATUS
4548*5113495bSYour Name  */
4549*5113495bSYour Name QDF_STATUS sme_get_ani_level(mac_handle_t mac_handle, uint32_t *freqs,
4550*5113495bSYour Name 			     uint8_t num_freqs, void (*callback)(
4551*5113495bSYour Name 			     struct wmi_host_ani_level_event *ani, uint8_t num,
4552*5113495bSYour Name 			     void *context), void *context);
4553*5113495bSYour Name #endif /* FEATURE_ANI_LEVEL_REQUEST */
4554*5113495bSYour Name 
4555*5113495bSYour Name /*
4556*5113495bSYour Name  * sme_vdev_self_peer_delete_resp() - Response for self peer delete
4557*5113495bSYour Name  * @del_vdev_params: parameters for which vdev self peer has been deleted
4558*5113495bSYour Name  *
4559*5113495bSYour Name  * This function is called by the lower level function as a response to
4560*5113495bSYour Name  * vdev self peer delete request.
4561*5113495bSYour Name  *
4562*5113495bSYour Name  * Return: QDF_STATUS.
4563*5113495bSYour Name  */
4564*5113495bSYour Name QDF_STATUS sme_vdev_self_peer_delete_resp(struct del_vdev_params *param);
4565*5113495bSYour Name 
4566*5113495bSYour Name /**
4567*5113495bSYour Name  * sme_vdev_del_resp() - Vdev delete response function
4568*5113495bSYour Name  * @vdev_id: vdevid which  has been deleted
4569*5113495bSYour Name  *
4570*5113495bSYour Name  * This function is called by the lower level function as a response to
4571*5113495bSYour Name  * vdev delete request
4572*5113495bSYour Name  *
4573*5113495bSYour Name  * Return: None
4574*5113495bSYour Name  */
4575*5113495bSYour Name void sme_vdev_del_resp(uint8_t vdev_id);
4576*5113495bSYour Name 
4577*5113495bSYour Name #ifdef FEATURE_MONITOR_MODE_SUPPORT
4578*5113495bSYour Name /**
4579*5113495bSYour Name  * sme_set_monitor_mode_cb() - Register monitor mode vdev up operation callback
4580*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
4581*5113495bSYour Name  * @monitor_mode_cb: callback to be registered
4582*5113495bSYour Name  *
4583*5113495bSYour Name  * Return: QDF_STATUS
4584*5113495bSYour Name  */
4585*5113495bSYour Name QDF_STATUS sme_set_monitor_mode_cb(mac_handle_t mac_handle,
4586*5113495bSYour Name 				   void (*monitor_mode_cb)(uint8_t vdev_id));
4587*5113495bSYour Name 
4588*5113495bSYour Name /*
4589*5113495bSYour Name  * sme_process_monitor_mode_vdev_up_evt() - Handle vdev up completion
4590*5113495bSYour Name  * @vdev_id: vdev id
4591*5113495bSYour Name  *
4592*5113495bSYour Name  * Return: QDF_STATUS.
4593*5113495bSYour Name  */
4594*5113495bSYour Name QDF_STATUS sme_process_monitor_mode_vdev_up_evt(uint8_t vdev_id);
4595*5113495bSYour Name #else
4596*5113495bSYour Name static inline
sme_set_monitor_mode_cb(mac_handle_t mac_handle,void (* monitor_mode_cb)(uint8_t vdev_id))4597*5113495bSYour Name QDF_STATUS sme_set_monitor_mode_cb(mac_handle_t mac_handle,
4598*5113495bSYour Name 				   void (*monitor_mode_cb)(uint8_t vdev_id))
4599*5113495bSYour Name {
4600*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
4601*5113495bSYour Name }
4602*5113495bSYour Name 
4603*5113495bSYour Name static inline QDF_STATUS
sme_process_monitor_mode_vdev_up_evt(uint8_t vdev_id)4604*5113495bSYour Name sme_process_monitor_mode_vdev_up_evt(uint8_t vdev_id)
4605*5113495bSYour Name {
4606*5113495bSYour Name 	return QDF_STATUS_E_FAILURE;
4607*5113495bSYour Name }
4608*5113495bSYour Name #endif
4609*5113495bSYour Name 
4610*5113495bSYour Name #if defined(CLD_PM_QOS) && defined(WLAN_FEATURE_LL_MODE)
4611*5113495bSYour Name /**
4612*5113495bSYour Name  * sme_set_beacon_latency_event_cb() - Register beacon latency IE callback
4613*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
4614*5113495bSYour Name  * @beacon_latency_event_cb: callback to be registered
4615*5113495bSYour Name  *
4616*5113495bSYour Name  * Return: QDF_STATUS
4617*5113495bSYour Name  */
4618*5113495bSYour Name QDF_STATUS
4619*5113495bSYour Name sme_set_beacon_latency_event_cb(mac_handle_t mac_handle,
4620*5113495bSYour Name 				void (*beacon_latency_event_cb)
4621*5113495bSYour Name 				(uint32_t latency_level));
4622*5113495bSYour Name #else
4623*5113495bSYour Name static inline QDF_STATUS
sme_set_beacon_latency_event_cb(mac_handle_t mac_handle,void (* beacon_latency_event_cb)(uint32_t latency_level))4624*5113495bSYour Name sme_set_beacon_latency_event_cb(mac_handle_t mac_handle,
4625*5113495bSYour Name 				void (*beacon_latency_event_cb)
4626*5113495bSYour Name 				(uint32_t latency_level))
4627*5113495bSYour Name {
4628*5113495bSYour Name 	return QDF_STATUS_SUCCESS;
4629*5113495bSYour Name }
4630*5113495bSYour Name #endif
4631*5113495bSYour Name 
4632*5113495bSYour Name /**
4633*5113495bSYour Name  * sme_fill_enc_type() - converts crypto cipher set to csr specific cipher type
4634*5113495bSYour Name  * @cipher_type: output csr cipher type
4635*5113495bSYour Name  * @ cipherset:input cipher set
4636*5113495bSYour Name  *
4637*5113495bSYour Name  * Return: None
4638*5113495bSYour Name  */
4639*5113495bSYour Name 
4640*5113495bSYour Name void sme_fill_enc_type(eCsrEncryptionType *cipher_type,
4641*5113495bSYour Name 		       uint32_t cipherset);
4642*5113495bSYour Name 
4643*5113495bSYour Name /**
4644*5113495bSYour Name  * sme_fill_auth_type() - converts auth mode set to csr specific auth type
4645*5113495bSYour Name  * @auth_type: output csr auth type
4646*5113495bSYour Name  * @ authmodeset: authmode set
4647*5113495bSYour Name  * @akm: akm
4648*5113495bSYour Name  * @ucastcipherset: ucastcipherset
4649*5113495bSYour Name  *
4650*5113495bSYour Name  * Return: None
4651*5113495bSYour Name  */
4652*5113495bSYour Name void sme_fill_auth_type(enum csr_akm_type *auth_type,
4653*5113495bSYour Name 			uint32_t authmodeset, uint32_t akm,
4654*5113495bSYour Name 			uint32_t ucastcipherset);
4655*5113495bSYour Name 
4656*5113495bSYour Name /**
4657*5113495bSYour Name  * sme_phy_mode_to_dot11mode() - converts phy mode to dot11 mode
4658*5113495bSYour Name  * @phy_mode: wlan phy mode
4659*5113495bSYour Name  *
4660*5113495bSYour Name  * Return: csr_cfgdot11mode
4661*5113495bSYour Name  */
4662*5113495bSYour Name enum csr_cfgdot11mode sme_phy_mode_to_dot11mode(enum wlan_phymode phy_mode);
4663*5113495bSYour Name 
4664*5113495bSYour Name #ifdef WLAN_FEATURE_11BE
4665*5113495bSYour Name /**
4666*5113495bSYour Name  * sme_get_eht_ch_width() - SME API to get max supported EHT chan width by FW
4667*5113495bSYour Name  *
4668*5113495bSYour Name  * Return: Max EHT channel width supported by FW (eg. 80, 160, 320)
4669*5113495bSYour Name  */
4670*5113495bSYour Name uint32_t sme_get_eht_ch_width(void);
4671*5113495bSYour Name #else /* !WLAN_FEATURE_11BE */
sme_get_eht_ch_width(void)4672*5113495bSYour Name static inline uint32_t sme_get_eht_ch_width(void)
4673*5113495bSYour Name {
4674*5113495bSYour Name 	return 0;
4675*5113495bSYour Name }
4676*5113495bSYour Name #endif /* WLAN_FEATURE_11BE */
4677*5113495bSYour Name 
4678*5113495bSYour Name /**
4679*5113495bSYour Name  * sme_switch_channel() - Request to switch channel
4680*5113495bSYour Name  * @mac_handle: Opaque handle to the MAC context
4681*5113495bSYour Name  * @bssid: current connected bssid
4682*5113495bSYour Name  * @chan_freq: new channel frequency
4683*5113495bSYour Name  * @chan_width: new channel width
4684*5113495bSYour Name  *
4685*5113495bSYour Name  * Return: QDF_STATUS
4686*5113495bSYour Name  */
4687*5113495bSYour Name QDF_STATUS sme_switch_channel(mac_handle_t mac_handle,
4688*5113495bSYour Name 			      struct qdf_mac_addr *bssid,
4689*5113495bSYour Name 			      qdf_freq_t chan_freq,
4690*5113495bSYour Name 			      enum phy_ch_width chan_width);
4691*5113495bSYour Name 
4692*5113495bSYour Name #ifdef WLAN_FEATURE_DYNAMIC_MAC_ADDR_UPDATE
4693*5113495bSYour Name /**
4694*5113495bSYour Name  * sme_send_set_mac_addr() - Send set MAC address command to FW
4695*5113495bSYour Name  * @mac_addr: VDEV MAC address
4696*5113495bSYour Name  * @mld_addr: VDEV MLD address
4697*5113495bSYour Name  * @vdev: Pointer to object manager VDEV
4698*5113495bSYour Name  *
4699*5113495bSYour Name  * API to send set MAC address request command to FW
4700*5113495bSYour Name  *
4701*5113495bSYour Name  * Return: QDF_STATUS
4702*5113495bSYour Name  */
4703*5113495bSYour Name QDF_STATUS sme_send_set_mac_addr(struct qdf_mac_addr mac_addr,
4704*5113495bSYour Name 				 struct qdf_mac_addr mld_addr,
4705*5113495bSYour Name 				 struct wlan_objmgr_vdev *vdev);
4706*5113495bSYour Name 
4707*5113495bSYour Name /**
4708*5113495bSYour Name  * sme_update_vdev_mac_addr() - Update VDEV MAC address
4709*5113495bSYour Name  * @vdev: Objmgr VDEV pointer
4710*5113495bSYour Name  * @mac_addr: VDEV MAC address
4711*5113495bSYour Name  * @mld_addr: VDEV MLD address
4712*5113495bSYour Name  * @update_sta_self_peer: Flag to check self peer MAC address or not.
4713*5113495bSYour Name  * @update_mld_addr: Flag to check if MLD address update needed or not.
4714*5113495bSYour Name  * @req_status: Status of the set MAC address request to the FW
4715*5113495bSYour Name  *
4716*5113495bSYour Name  * API to update MLME structures with new MAC address. This will be invoked
4717*5113495bSYour Name  * after receiving success status form the FW for the set MAC address request
4718*5113495bSYour Name  * command.
4719*5113495bSYour Name  *
4720*5113495bSYour Name  * Return: QDF_STATUS
4721*5113495bSYour Name  */
4722*5113495bSYour Name QDF_STATUS sme_update_vdev_mac_addr(struct wlan_objmgr_vdev *vdev,
4723*5113495bSYour Name 				    struct qdf_mac_addr mac_addr,
4724*5113495bSYour Name 				    struct qdf_mac_addr mld_addr,
4725*5113495bSYour Name 				    bool update_sta_self_peer,
4726*5113495bSYour Name 				    bool update_mld_addr, int req_status);
4727*5113495bSYour Name #endif
4728*5113495bSYour Name 
4729*5113495bSYour Name /**
4730*5113495bSYour Name  * sme_get_network_params() - SME API to get dot11 config for SAP
4731*5113495bSYour Name  * functionality
4732*5113495bSYour Name  *@mac_ctx: mac context
4733*5113495bSYour Name  *@dot11_cfg : pointer to dot11 config
4734*5113495bSYour Name  *
4735*5113495bSYour Name  * Return : QDF_STATUS
4736*5113495bSYour Name  */
4737*5113495bSYour Name QDF_STATUS sme_get_network_params(struct mac_context *mac_ctx,
4738*5113495bSYour Name 				  struct bss_dot11_config *dot11_cfg);
4739*5113495bSYour Name 
4740*5113495bSYour Name /**
4741*5113495bSYour Name  * sme_start_bss() -A wrapper function to request CSR to
4742*5113495bSYour Name  * inititiate start bss
4743*5113495bSYour Name  * @mac_handle: mac hancle
4744*5113495bSYour Name  * @vdev_id: vdev id
4745*5113495bSYour Name  * @bss_config: pointer to start bss config
4746*5113495bSYour Name  *
4747*5113495bSYour Name  * Return: QDF_STATUS
4748*5113495bSYour Name  */
4749*5113495bSYour Name QDF_STATUS sme_start_bss(mac_handle_t mac_handle, uint8_t vdev_id,
4750*5113495bSYour Name 			 struct start_bss_config *bss_config);
4751*5113495bSYour Name 
4752*5113495bSYour Name /**
4753*5113495bSYour Name  * sme_sap_ser_callback() - callback from serialization module
4754*5113495bSYour Name  * @cmd: serialization command
4755*5113495bSYour Name  * @reason: reason why serialization module has given this callback
4756*5113495bSYour Name  *
4757*5113495bSYour Name  * Serialization module will give callback to SME for why it triggered
4758*5113495bSYour Name  * the callback
4759*5113495bSYour Name  *
4760*5113495bSYour Name  * Return: QDF_STATUS
4761*5113495bSYour Name  */
4762*5113495bSYour Name QDF_STATUS sme_sap_ser_callback(struct wlan_serialization_command *cmd,
4763*5113495bSYour Name 				enum wlan_serialization_cb_reason reason);
4764*5113495bSYour Name 
4765*5113495bSYour Name /**
4766*5113495bSYour Name  *sme_fill_channel_change_request() - SME API to fill the channel
4767*5113495bSYour Name  * change request for monitor mode
4768*5113495bSYour Name  * @mac_handle: mac handle
4769*5113495bSYour Name  * @req: pointer to change channel request message
4770*5113495bSYour Name  * @phy_mode: phy mode of the vdev
4771*5113495bSYour Name  *
4772*5113495bSYour Name  * Return: QDF_STATUS
4773*5113495bSYour Name  */
4774*5113495bSYour Name void sme_fill_channel_change_request(mac_handle_t mac_handle,
4775*5113495bSYour Name 				     struct channel_change_req *req,
4776*5113495bSYour Name 				      eCsrPhyMode phy_mode);
4777*5113495bSYour Name 
4778*5113495bSYour Name /**
4779*5113495bSYour Name  * sme_send_channel_change_req() - SME API to post channel change
4780*5113495bSYour Name  * request to LIM
4781*5113495bSYour Name  * @mac_handle: mac handle
4782*5113495bSYour Name  * @req: pointer to change channel request message
4783*5113495bSYour Name  *
4784*5113495bSYour Name  * Return: QDF_STATUS
4785*5113495bSYour Name  */
4786*5113495bSYour Name QDF_STATUS sme_send_channel_change_req(mac_handle_t mac_handle,
4787*5113495bSYour Name 				      struct channel_change_req *req);
4788*5113495bSYour Name 
4789*5113495bSYour Name /**
4790*5113495bSYour Name  * sme_update_beacon_country_ie() - SME API to update beacon
4791*5113495bSYour Name  * country ie
4792*5113495bSYour Name  * @mac_handle: mac handle
4793*5113495bSYour Name  * @vdev_id: vdev id
4794*5113495bSYour Name  * @country_ie_for_all_band: country ie should take all band channel
4795*5113495bSYour Name  *			     or only the current band channel
4796*5113495bSYour Name  *
4797*5113495bSYour Name  * Return: QDF_STATUS
4798*5113495bSYour Name  */
4799*5113495bSYour Name QDF_STATUS sme_update_beacon_country_ie(mac_handle_t mac_handle,
4800*5113495bSYour Name 					uint8_t vdev_id,
4801*5113495bSYour Name 					bool country_ie_for_all_band);
4802*5113495bSYour Name 
4803*5113495bSYour Name #endif /* #if !defined( __SME_API_H ) */
4804