blob: fd35a0a9962759eb74695bac3ae337ae85c2f12d [file] [log] [blame]
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001/*
Abhishek Singh7996eb72015-12-30 17:24:02 +05302 * Copyright (c) 2012-2016 The Linux Foundation. All rights reserved.
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08003 *
4 * Previously licensed under the ISC license by Qualcomm Atheros, Inc.
5 *
6 *
7 * Permission to use, copy, modify, and/or distribute this software for
8 * any purpose with or without fee is hereby granted, provided that the
9 * above copyright notice and this permission notice appear in all
10 * copies.
11 *
12 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
13 * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
14 * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
15 * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
16 * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
17 * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
18 * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
19 * PERFORMANCE OF THIS SOFTWARE.
20 */
21
22/*
23 * This file was originally distributed by Qualcomm Atheros, Inc.
24 * under proprietary terms before Copyright ownership was assigned
25 * to the Linux Foundation.
26 */
27
28#if !defined(__SME_API_H)
29#define __SME_API_H
30
31/**
32 * file smeApi.h
33 *
34 * brief prototype for SME APIs
35 */
36
37/*--------------------------------------------------------------------------
38 Include Files
39 ------------------------------------------------------------------------*/
40#include "csr_api.h"
41#include "cds_mq.h"
42#include "cdf_lock.h"
43#include "cdf_types.h"
44#include "sir_api.h"
45#include "cds_reg_service.h"
46#include "p2p_api.h"
47#include "cds_regdomain.h"
48#include "sme_internal.h"
Krishna Kumaar Natarajan052c6e62015-09-28 15:32:55 -070049#include "wma_tgt_cfg.h"
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080050
51#ifdef FEATURE_OEM_DATA_SUPPORT
52#include "oem_data_api.h"
53#endif
54
55#if defined WLAN_FEATURE_VOWIFI
56#include "sme_rrm_internal.h"
57#endif
58#include "sir_types.h"
59/*--------------------------------------------------------------------------
60 Preprocessor definitions and constants
61 ------------------------------------------------------------------------*/
62
63#define SME_SUMMARY_STATS 1
64#define SME_GLOBAL_CLASSA_STATS 2
65#define SME_GLOBAL_CLASSB_STATS 4
66#define SME_GLOBAL_CLASSC_STATS 8
67#define SME_GLOBAL_CLASSD_STATS 16
68#define SME_PER_STA_STATS 32
69
70#define SME_SESSION_ID_ANY 50
71
72#define SME_INVALID_COUNTRY_CODE "XX"
73
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080074#define SME_SET_CHANNEL_REG_POWER(reg_info_1, val) do { \
75 reg_info_1 &= 0xff00ffff; \
76 reg_info_1 |= ((val & 0xff) << 16); \
77} while (0)
78
79#define SME_SET_CHANNEL_MAX_TX_POWER(reg_info_2, val) do { \
80 reg_info_2 &= 0xffff00ff; \
81 reg_info_2 |= ((val & 0xff) << 8); \
82} while (0)
83
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -070084#define SME_CONFIG_TO_ROAM_CONFIG 1
85#define ROAM_CONFIG_TO_SME_CONFIG 2
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080086
87/*--------------------------------------------------------------------------
88 Type declarations
89 ------------------------------------------------------------------------*/
90typedef void (*hdd_ftm_msg_processor)(void *);
91typedef struct _smeConfigParams {
92 tCsrConfigParam csrConfig;
93#if defined WLAN_FEATURE_VOWIFI
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -080094 struct rrm_config_param rrmConfig;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080095#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080096} tSmeConfigParams, *tpSmeConfigParams;
97
98#ifdef FEATURE_WLAN_TDLS
99#define SME_TDLS_MAX_SUPP_CHANNELS 128
100#define SME_TDLS_MAX_SUPP_OPER_CLASSES 32
101
102typedef struct _smeTdlsPeerCapParams {
103 uint8_t isPeerResponder;
104 uint8_t peerUapsdQueue;
105 uint8_t peerMaxSp;
106 uint8_t peerBuffStaSupport;
107 uint8_t peerOffChanSupport;
108 uint8_t peerCurrOperClass;
109 uint8_t selfCurrOperClass;
110 uint8_t peerChanLen;
111 uint8_t peerChan[SME_TDLS_MAX_SUPP_CHANNELS];
112 uint8_t peerOperClassLen;
113 uint8_t peerOperClass[SME_TDLS_MAX_SUPP_OPER_CLASSES];
114 uint8_t prefOffChanNum;
115 uint8_t prefOffChanBandwidth;
116 uint8_t opClassForPrefOffChan;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800117} tSmeTdlsPeerCapParams;
118
Kabilan Kannan421714b2015-11-23 04:44:59 -0800119/**
120 * eSmeTdlsPeerState - tdls peer state
121 * @eSME_TDLS_PEER_STATE_PEERING: tdls connection in progress
122 * @eSME_TDLS_PEER_STATE_CONNECTED: tdls peer is connected
123 * @eSME_TDLS_PEER_STATE_TEARDOWN: tdls peer is tear down
124 * @eSME_TDLS_PEER_ADD_MAC_ADDR: add peer mac into connection table
125 * @eSME_TDLS_PEER_REMOVE_MAC_ADDR: remove peer mac from connection table
126 */
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800127typedef enum {
128 eSME_TDLS_PEER_STATE_PEERING,
129 eSME_TDLS_PEER_STATE_CONNECTED,
Kabilan Kannan421714b2015-11-23 04:44:59 -0800130 eSME_TDLS_PEER_STATE_TEARDOWN,
131 eSME_TDLS_PEER_ADD_MAC_ADDR,
132 eSME_TDLS_PEER_REMOVE_MAC_ADDR,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800133} eSmeTdlsPeerState;
134
135typedef struct _smeTdlsPeerStateParams {
136 uint32_t vdevId;
137 tSirMacAddr peerMacAddr;
138 uint32_t peerState;
139 tSmeTdlsPeerCapParams peerCap;
140} tSmeTdlsPeerStateParams;
141
142#define ENABLE_CHANSWITCH 1
143#define DISABLE_CHANSWITCH 2
144#define BW_20_OFFSET_BIT 0
145#define BW_40_OFFSET_BIT 1
146#define BW_80_OFFSET_BIT 2
147#define BW_160_OFFSET_BIT 3
148typedef struct sme_tdls_chan_switch_params_struct {
149 uint32_t vdev_id;
150 tSirMacAddr peer_mac_addr;
151 uint16_t tdls_off_ch_bw_offset;/* Target Off Channel Bandwidth offset */
152 uint8_t tdls_off_channel; /* Target Off Channel */
153 uint8_t tdls_off_ch_mode; /* TDLS Off Channel Mode */
154 uint8_t is_responder; /* is peer responder or initiator */
Masti, Narayanraddic4a7ab82015-11-25 15:41:10 +0530155 uint8_t opclass; /* tdls operating class */
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800156} sme_tdls_chan_switch_params;
157#endif /* FEATURE_WLAN_TDLS */
158
159/* Thermal Mitigation*/
160typedef struct {
161 uint16_t smeMinTempThreshold;
162 uint16_t smeMaxTempThreshold;
163} tSmeThermalLevelInfo;
164
165#define SME_MAX_THERMAL_LEVELS (4)
166typedef struct {
167 /* Array of thermal levels */
168 tSmeThermalLevelInfo smeThermalLevels[SME_MAX_THERMAL_LEVELS];
169 uint8_t smeThermalMgmtEnabled;
170 uint32_t smeThrottlePeriod;
171} tSmeThermalParams;
172
173typedef enum {
174 SME_AC_BK = 0,
175 SME_AC_BE = 1,
176 SME_AC_VI = 2,
177 SME_AC_VO = 3
178} sme_ac_enum_type;
179
180/* TSPEC Direction Enum Type */
181typedef enum {
182 /* uplink */
183 SME_TX_DIR = 0,
184 /* downlink */
185 SME_RX_DIR = 1,
186 /* bidirectional */
187 SME_BI_DIR = 2,
188} sme_tspec_dir_type;
189
Krishna Kumaar Natarajan53ca2902015-12-04 14:01:46 -0800190/**
191 * struct sme_oem_capability - OEM capability to be exchanged between host
192 * and userspace
193 * @ftm_rr: FTM range report capability bit
194 * @lci_capability: LCI capability bit
195 * @reserved1: reserved
196 * @reserved2: reserved
197 */
198struct sme_oem_capability {
199 uint32_t ftm_rr:1;
200 uint32_t lci_capability:1;
201 uint32_t reserved1:30;
202 uint32_t reserved2;
203};
204
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800205/*-------------------------------------------------------------------------
206 Function declarations and documenation
207 ------------------------------------------------------------------------*/
208CDF_STATUS sme_open(tHalHandle hHal);
209CDF_STATUS sme_init_chan_list(tHalHandle hal, uint8_t *alpha2,
Amar Singhala297bfa2015-10-15 15:07:29 -0700210 enum country_src cc_src);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800211CDF_STATUS sme_close(tHalHandle hHal);
212CDF_STATUS sme_start(tHalHandle hHal);
213CDF_STATUS sme_stop(tHalHandle hHal, tHalStopType stopType);
214CDF_STATUS sme_open_session(tHalHandle hHal, csr_roam_completeCallback callback,
215 void *pContext, uint8_t *pSelfMacAddr,
216 uint8_t *pbSessionId, uint32_t type,
217 uint32_t subType);
Peng Xuf5d60c82015-10-02 17:17:03 -0700218void sme_set_curr_device_mode(tHalHandle hHal,
219 enum tCDF_ADAPTER_MODE currDeviceMode);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800220CDF_STATUS sme_close_session(tHalHandle hHal, uint8_t sessionId,
221 csr_roamSessionCloseCallback callback,
222 void *pContext);
223CDF_STATUS sme_update_roam_params(tHalHandle hHal, uint8_t session_id,
224 struct roam_ext_params roam_params_src, int update_param);
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -0700225#ifdef FEATURE_WLAN_SCAN_PNO
226void sme_update_roam_pno_channel_prediction_config(
Krunal Soni1878d3a2016-01-14 13:00:44 -0800227 tHalHandle hal, tCsrConfigParam * csr_config,
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -0700228 uint8_t copy_from_to);
229#else
230static inline void sme_update_roam_pno_channel_prediction_config(
Krunal Soni1878d3a2016-01-14 13:00:44 -0800231 tHalHandle hal, tCsrConfigParam *csr_config,
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -0700232 uint8_t copy_from_to)
233{}
234#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800235CDF_STATUS sme_update_config(tHalHandle hHal,
236 tpSmeConfigParams pSmeConfigParams);
237
238#if defined(FEATURE_WLAN_ESE) && defined(FEATURE_WLAN_ESE_UPLOAD)
239CDF_STATUS sme_set_plm_request(tHalHandle hHal, tpSirPlmReq pPlm);
240#endif
241
242CDF_STATUS sme_set11dinfo(tHalHandle hHal, tpSmeConfigParams pSmeConfigParams);
243CDF_STATUS sme_get_soft_ap_domain(tHalHandle hHal,
244 v_REGDOMAIN_t *domainIdSoftAp);
245CDF_STATUS sme_set_reg_info(tHalHandle hHal, uint8_t *apCntryCode);
246CDF_STATUS sme_change_config_params(tHalHandle hHal,
247 tCsrUpdateConfigParam *pUpdateConfigParam);
248CDF_STATUS sme_hdd_ready_ind(tHalHandle hHal);
249CDF_STATUS sme_process_msg(tHalHandle hHal, cds_msg_t *pMsg);
250void sme_free_msg(tHalHandle hHal, cds_msg_t *pMsg);
251CDF_STATUS sme_scan_request(tHalHandle hHal, uint8_t sessionId,
252 tCsrScanRequest *, csr_scan_completeCallback callback,
253 void *pContext);
254CDF_STATUS sme_scan_get_result(tHalHandle hHal, uint8_t sessionId,
255 tCsrScanResultFilter *pFilter,
256 tScanResultHandle *phResult);
257CDF_STATUS sme_get_ap_channel_from_scan_cache(tHalHandle hHal,
258 tCsrRoamProfile *profile,
259 tScanResultHandle *scan_cache,
260 uint8_t *ap_chnl_id);
261bool sme_store_joinreq_param(tHalHandle hal_handle,
262 tCsrRoamProfile *profile,
263 tScanResultHandle scan_cache,
264 uint32_t *roam_id,
265 uint32_t session_id);
266bool sme_clear_joinreq_param(tHalHandle hal_handle,
267 uint32_t session_id);
268CDF_STATUS sme_issue_stored_joinreq(tHalHandle hal_handle,
269 uint32_t *roam_id,
270 uint32_t session_id);
271CDF_STATUS sme_scan_flush_result(tHalHandle hHal);
272CDF_STATUS sme_filter_scan_results(tHalHandle hHal, uint8_t sessionId);
273CDF_STATUS sme_scan_flush_p2p_result(tHalHandle hHal, uint8_t sessionId);
274tCsrScanResultInfo *sme_scan_result_get_first(tHalHandle,
275 tScanResultHandle hScanResult);
276tCsrScanResultInfo *sme_scan_result_get_next(tHalHandle,
277 tScanResultHandle hScanResult);
278CDF_STATUS sme_scan_result_purge(tHalHandle hHal,
279 tScanResultHandle hScanResult);
280CDF_STATUS sme_scan_get_pmkid_candidate_list(tHalHandle hHal, uint8_t sessionId,
281 tPmkidCandidateInfo *pPmkidList,
282 uint32_t *pNumItems);
283CDF_STATUS sme_roam_connect(tHalHandle hHal, uint8_t sessionId,
284 tCsrRoamProfile *pProfile, uint32_t *pRoamId);
285CDF_STATUS sme_roam_reassoc(tHalHandle hHal, uint8_t sessionId,
286 tCsrRoamProfile *pProfile,
287 tCsrRoamModifyProfileFields modProfileFields,
288 uint32_t *pRoamId, bool fForce);
289CDF_STATUS sme_roam_connect_to_last_profile(tHalHandle hHal, uint8_t sessionId);
290CDF_STATUS sme_roam_disconnect(tHalHandle hHal, uint8_t sessionId,
291 eCsrRoamDisconnectReason reason);
292CDF_STATUS sme_roam_stop_bss(tHalHandle hHal, uint8_t sessionId);
293CDF_STATUS sme_roam_get_associated_stas(tHalHandle hHal, uint8_t sessionId,
294 CDF_MODULE_ID modId, void *pUsrContext,
295 void *pfnSapEventCallback,
296 uint8_t *pAssocStasBuf);
297CDF_STATUS sme_roam_disconnect_sta(tHalHandle hHal, uint8_t sessionId,
298 const uint8_t *pPeerMacAddr);
299CDF_STATUS sme_roam_deauth_sta(tHalHandle hHal, uint8_t sessionId,
300 struct tagCsrDelStaParams *pDelStaParams);
301CDF_STATUS sme_roam_tkip_counter_measures(tHalHandle hHal, uint8_t sessionId,
302 bool bEnable);
303CDF_STATUS sme_roam_get_wps_session_overlap(tHalHandle hHal, uint8_t sessionId,
304 void *pUsrContext,
305 void *pfnSapEventCallback,
306 struct cdf_mac_addr pRemoveMac);
307CDF_STATUS sme_roam_get_connect_state(tHalHandle hHal, uint8_t sessionId,
308 eCsrConnectState *pState);
309CDF_STATUS sme_roam_get_connect_profile(tHalHandle hHal, uint8_t sessionId,
310 tCsrRoamConnectedProfile *pProfile);
Naveen Rawatdf0a7e72016-01-06 18:35:53 -0800311void sme_roam_free_connect_profile(tCsrRoamConnectedProfile *profile);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800312CDF_STATUS sme_roam_set_pmkid_cache(tHalHandle hHal, uint8_t sessionId,
313 tPmkidCacheInfo *pPMKIDCache,
314 uint32_t numItems,
315 bool update_entire_cache);
316
317#ifdef WLAN_FEATURE_ROAM_OFFLOAD
318CDF_STATUS sme_roam_set_psk_pmk(tHalHandle hHal, uint8_t sessionId,
319 uint8_t *pPSK_PMK, size_t pmk_len);
320#endif
321CDF_STATUS sme_roam_get_security_req_ie(tHalHandle hHal, uint8_t sessionId,
322 uint32_t *pLen, uint8_t *pBuf,
323 eCsrSecurityType secType);
324CDF_STATUS sme_roam_get_security_rsp_ie(tHalHandle hHal, uint8_t sessionId,
325 uint32_t *pLen, uint8_t *pBuf,
326 eCsrSecurityType secType);
327uint32_t sme_roam_get_num_pmkid_cache(tHalHandle hHal, uint8_t sessionId);
328CDF_STATUS sme_roam_get_pmkid_cache(tHalHandle hHal, uint8_t sessionId,
329 uint32_t *pNum,
330 tPmkidCacheInfo *pPmkidCache);
331CDF_STATUS sme_get_config_param(tHalHandle hHal, tSmeConfigParams *pParam);
332CDF_STATUS sme_get_statistics(tHalHandle hHal,
333 eCsrStatsRequesterType requesterId,
334 uint32_t statsMask, tCsrStatsCallback callback,
335 uint32_t periodicity, bool cache, uint8_t staId,
336 void *pContext, uint8_t sessionId);
337CDF_STATUS sme_get_rssi(tHalHandle hHal,
338 tCsrRssiCallback callback,
339 uint8_t staId, struct cdf_mac_addr bssId, int8_t lastRSSI,
340 void *pContext, void *p_cds_context);
341CDF_STATUS sme_get_snr(tHalHandle hHal,
342 tCsrSnrCallback callback,
343 uint8_t staId, struct cdf_mac_addr bssId, void *pContext);
344#if defined(FEATURE_WLAN_ESE) && defined(FEATURE_WLAN_ESE_UPLOAD)
345CDF_STATUS sme_get_tsm_stats(tHalHandle hHal,
346 tCsrTsmStatsCallback callback,
347 uint8_t staId, struct cdf_mac_addr bssId,
348 void *pContext, void *p_cds_context, uint8_t tid);
349CDF_STATUS sme_set_cckm_ie(tHalHandle hHal,
350 uint8_t sessionId,
351 uint8_t *pCckmIe, uint8_t cckmIeLen);
352CDF_STATUS sme_set_ese_beacon_request(tHalHandle hHal, const uint8_t sessionId,
353 const tCsrEseBeaconReq *pEseBcnReq);
354#endif /*FEATURE_WLAN_ESE && FEATURE_WLAN_ESE_UPLOAD */
355CDF_STATUS sme_cfg_set_int(tHalHandle hal, uint16_t cfg_id, uint32_t value);
356CDF_STATUS sme_cfg_set_str(tHalHandle hal, uint16_t cfg_id, uint8_t *str,
357 uint32_t length);
358CDF_STATUS sme_cfg_get_int(tHalHandle hal, uint16_t cfg_id,
359 uint32_t *cfg_value);
360CDF_STATUS sme_cfg_get_str(tHalHandle hal, uint16_t cfg_id, uint8_t *str,
361 uint32_t *length);
362CDF_STATUS sme_get_modify_profile_fields(tHalHandle hHal, uint8_t sessionId,
363 tCsrRoamModifyProfileFields *
364 pModifyProfileFields);
365
366extern CDF_STATUS sme_set_host_power_save(tHalHandle hHal, bool psMode);
367
368void sme_set_dhcp_till_power_active_flag(tHalHandle hHal, uint8_t flag);
369extern CDF_STATUS sme_register11d_scan_done_callback(tHalHandle hHal,
370 csr_scan_completeCallback);
371#ifdef FEATURE_OEM_DATA_SUPPORT
372extern CDF_STATUS sme_register_oem_data_rsp_callback(tHalHandle h_hal,
373 sme_send_oem_data_rsp_msg callback);
Prashanth Bhatta75fa9a12016-01-11 18:30:08 -0800374#else
375static inline CDF_STATUS sme_register_oem_data_rsp_callback(tHalHandle h_hal,
376 sme_send_oem_data_rsp_msg callback)
377{
378 return CDF_STATUS_SUCCESS;
379}
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800380#endif
381
382extern CDF_STATUS sme_wow_add_pattern(tHalHandle hHal,
383 struct wow_add_pattern *pattern, uint8_t sessionId);
384extern CDF_STATUS sme_wow_delete_pattern(tHalHandle hHal,
385 struct wow_delete_pattern *pattern, uint8_t sessionId);
386
387void sme_register_ftm_msg_processor(tHalHandle hal,
388 hdd_ftm_msg_processor callback);
389
390extern CDF_STATUS sme_enter_wowl(tHalHandle hHal,
391 void (*enter_wowl_callback_routine)(void
392 *callbackContext,
393 CDF_STATUS status),
394 void *enter_wowl_callback_context,
395#ifdef WLAN_WAKEUP_EVENTS
396 void (*wake_reason_ind_cb)(void *callbackContext,
397 tpSirWakeReasonInd
398 wake_reason_ind),
399 void *wake_reason_ind_cb_ctx,
400#endif /* WLAN_WAKEUP_EVENTS */
401 tpSirSmeWowlEnterParams wowl_enter_params,
402 uint8_t sessionId);
403
404extern CDF_STATUS sme_exit_wowl(tHalHandle hHal,
405 tpSirSmeWowlExitParams wowl_exit_params);
406CDF_STATUS sme_roam_set_key(tHalHandle, uint8_t sessionId,
407 tCsrRoamSetKey *pSetKey, uint32_t *pRoamId);
408CDF_STATUS sme_get_country_code(tHalHandle hHal, uint8_t *pBuf, uint8_t *pbLen);
409
410
411void sme_apply_channel_power_info_to_fw(tHalHandle hHal);
412
413/* some support functions */
414bool sme_is11d_supported(tHalHandle hHal);
415bool sme_is11h_supported(tHalHandle hHal);
416bool sme_is_wmm_supported(tHalHandle hHal);
417
418typedef void (*tSmeChangeCountryCallback)(void *pContext);
419CDF_STATUS sme_change_country_code(tHalHandle hHal,
420 tSmeChangeCountryCallback callback,
421 uint8_t *pCountry,
422 void *pContext,
423 void *p_cds_context,
424 tAniBool countryFromUserSpace,
425 tAniBool sendRegHint);
426CDF_STATUS sme_generic_change_country_code(tHalHandle hHal,
Amar Singhal7f1f3ec2015-10-13 17:14:08 -0700427 uint8_t *pCountry);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800428CDF_STATUS sme_dhcp_start_ind(tHalHandle hHal,
429 uint8_t device_mode,
430 uint8_t *macAddr, uint8_t sessionId);
431CDF_STATUS sme_dhcp_stop_ind(tHalHandle hHal,
432 uint8_t device_mode,
433 uint8_t *macAddr, uint8_t sessionId);
434void sme_set_cfg_privacy(tHalHandle hHal, tCsrRoamProfile *pProfile,
435 bool fPrivacy);
436void sme_get_recovery_stats(tHalHandle hHal);
437#if defined WLAN_FEATURE_VOWIFI
438CDF_STATUS sme_neighbor_report_request(tHalHandle hHal, uint8_t sessionId,
439 tpRrmNeighborReq pRrmNeighborReq,
440 tpRrmNeighborRspCallbackInfo callbackInfo);
441#endif
442CDF_STATUS sme_get_wcnss_wlan_compiled_version(tHalHandle hHal,
443 tSirVersionType * pVersion);
444CDF_STATUS sme_get_wcnss_wlan_reported_version(tHalHandle hHal,
445 tSirVersionType *pVersion);
446CDF_STATUS sme_get_wcnss_software_version(tHalHandle hHal,
447 uint8_t *pVersion, uint32_t versionBufferSize);
448CDF_STATUS sme_get_wcnss_hardware_version(tHalHandle hHal,
449 uint8_t *pVersion, uint32_t versionBufferSize);
450#ifdef FEATURE_WLAN_WAPI
451CDF_STATUS sme_scan_get_bkid_candidate_list(tHalHandle hHal, uint32_t sessionId,
452 tBkidCandidateInfo * pBkidList,
453 uint32_t *pNumItems);
454#endif /* FEATURE_WLAN_WAPI */
455#ifdef FEATURE_OEM_DATA_SUPPORT
456CDF_STATUS sme_oem_data_req(tHalHandle hHal,
457 uint8_t sessionId,
458 tOemDataReqConfig *,
Jeff Johnsonf6358f12015-12-07 13:36:10 -0800459 uint32_t *pOemDataReqID);
Krishna Kumaar Natarajan53ca2902015-12-04 14:01:46 -0800460CDF_STATUS sme_oem_update_capability(tHalHandle hHal,
461 struct sme_oem_capability *cap);
462CDF_STATUS sme_oem_get_capability(tHalHandle hHal,
463 struct sme_oem_capability *cap);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800464#endif /*FEATURE_OEM_DATA_SUPPORT */
465CDF_STATUS sme_roam_update_apwpsie(tHalHandle, uint8_t sessionId,
466 tSirAPWPSIEs * pAPWPSIES);
467CDF_STATUS sme_roam_update_apwparsni_es(tHalHandle hHal, uint8_t sessionId,
468 tSirRSNie *pAPSirRSNie);
469CDF_STATUS sme_change_mcc_beacon_interval(tHalHandle hHal, uint8_t sessionId);
470CDF_STATUS sme_set_host_offload(tHalHandle hHal, uint8_t sessionId,
471 tpSirHostOffloadReq pRequest);
472CDF_STATUS sme_set_keep_alive(tHalHandle hHal, uint8_t sessionId,
473 tpSirKeepAliveReq pRequest);
474CDF_STATUS sme_get_operation_channel(tHalHandle hHal, uint32_t *pChannel,
475 uint8_t sessionId);
476CDF_STATUS sme_register_mgmt_frame(tHalHandle hHal, uint8_t sessionId,
477 uint16_t frameType, uint8_t *matchData,
478 uint16_t matchLen);
479CDF_STATUS sme_deregister_mgmt_frame(tHalHandle hHal, uint8_t sessionId,
480 uint16_t frameType, uint8_t *matchData,
481 uint16_t matchLen);
482CDF_STATUS sme_configure_rxp_filter(tHalHandle hHal,
483 tpSirWlanSetRxpFilters wlanRxpFilterParam);
484CDF_STATUS sme_ConfigureAppsCpuWakeupState(tHalHandle hHal, bool isAppsAwake);
485CDF_STATUS sme_configure_suspend_ind(tHalHandle hHal,
Houston Hoffman7260ecb2015-10-05 18:43:07 -0700486 uint32_t conn_state_mask,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800487 csr_readyToSuspendCallback,
488 void *callbackContext);
489CDF_STATUS sme_configure_resume_req(tHalHandle hHal,
490 tpSirWlanResumeParam wlanResumeParam);
491#ifdef WLAN_FEATURE_EXTWOW_SUPPORT
Krishna Kumaar Natarajand9131902015-10-19 11:52:47 -0700492CDF_STATUS sme_configure_ext_wow(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800493 tpSirExtWoWParams wlanExtParams,
494 csr_readyToSuspendCallback callback,
495 void *callbackContext);
496CDF_STATUS sme_configure_app_type1_params(tHalHandle hHal,
497 tpSirAppType1Params wlanAppType1Params);
498CDF_STATUS sme_configure_app_type2_params(tHalHandle hHal,
499 tpSirAppType2Params wlanAppType2Params);
500#endif
501int8_t sme_get_infra_session_id(tHalHandle hHal);
502uint8_t sme_get_infra_operation_channel(tHalHandle hHal, uint8_t sessionId);
503uint8_t sme_get_concurrent_operation_channel(tHalHandle hHal);
504#ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
505uint16_t sme_check_concurrent_channel_overlap(tHalHandle hHal, uint16_t sap_ch,
506 eCsrPhyMode sapPhyMode,
507 uint8_t cc_switch_mode);
508#endif
509CDF_STATUS sme_abort_mac_scan(tHalHandle hHal, uint8_t sessionId,
510 eCsrAbortReason reason);
511CDF_STATUS sme_get_cfg_valid_channels(tHalHandle hHal, uint8_t *aValidChannels,
512 uint32_t *len);
513#ifdef FEATURE_WLAN_SCAN_PNO
514CDF_STATUS sme_set_preferred_network_list(tHalHandle hHal,
515 tpSirPNOScanReq pRequest,
516 uint8_t sessionId,
517 preferred_network_found_ind_cb
518 callbackRoutine, void *callbackContext);
519
520CDF_STATUS sme_preferred_network_found_ind(tHalHandle hHal, void *pMsg);
521#endif /* FEATURE_WLAN_SCAN_PNO */
522#ifdef WLAN_FEATURE_PACKET_FILTERING
523CDF_STATUS sme_8023_multicast_list(tHalHandle hHal, uint8_t sessionId,
524 tpSirRcvFltMcAddrList pMulticastAddrs);
525CDF_STATUS sme_receive_filter_set_filter(tHalHandle hHal,
526 tpSirRcvPktFilterCfgType pRcvPktFilterCfg,
527 uint8_t sessionId);
528CDF_STATUS sme_receive_filter_clear_filter(tHalHandle hHal,
529 tpSirRcvFltPktClearParam pRcvFltPktClearParam,
530 uint8_t sessionId);
531#endif /* WLAN_FEATURE_PACKET_FILTERING */
532bool sme_is_channel_valid(tHalHandle hHal, uint8_t channel);
533CDF_STATUS sme_set_freq_band(tHalHandle hHal, uint8_t sessionId,
534 eCsrBand eBand);
535CDF_STATUS sme_get_freq_band(tHalHandle hHal, eCsrBand *pBand);
536#ifdef WLAN_FEATURE_GTK_OFFLOAD
537CDF_STATUS sme_set_gtk_offload(tHalHandle hal_ctx,
538 tpSirGtkOffloadParams request,
539 uint8_t session_id);
540CDF_STATUS sme_get_gtk_offload(tHalHandle hal_ctx,
541 gtk_offload_get_info_callback callback_routine,
542 void *callback_context, uint8_t session_id);
543#endif /* WLAN_FEATURE_GTK_OFFLOAD */
544uint16_t sme_chn_to_freq(uint8_t chanNum);
545bool sme_is_channel_valid(tHalHandle hHal, uint8_t channel);
Srinivas Girigowda97215232015-09-24 12:26:28 -0700546CDF_STATUS sme_set_max_tx_power(tHalHandle hHal, struct cdf_mac_addr pBssid,
547 struct cdf_mac_addr pSelfMacAddress, int8_t dB);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800548CDF_STATUS sme_set_max_tx_power_per_band(eCsrBand band, int8_t db);
549CDF_STATUS sme_set_tx_power(tHalHandle hHal, uint8_t sessionId,
Srinivas Girigowda97215232015-09-24 12:26:28 -0700550 struct cdf_mac_addr bssid,
Peng Xuf5d60c82015-10-02 17:17:03 -0700551 enum tCDF_ADAPTER_MODE dev_mode, int power);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800552CDF_STATUS sme_set_custom_mac_addr(tSirMacAddr customMacAddr);
553CDF_STATUS sme_hide_ssid(tHalHandle hHal, uint8_t sessionId,
554 uint8_t ssidHidden);
555CDF_STATUS sme_set_tm_level(tHalHandle hHal, uint16_t newTMLevel,
556 uint16_t tmMode);
557void sme_feature_caps_exchange(tHalHandle hHal);
558void sme_disable_feature_capablity(uint8_t feature_index);
559void sme_reset_power_values_for5_g(tHalHandle hHal);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800560CDF_STATUS sme_update_roam_prefer5_g_hz(tHalHandle hHal, bool nRoamPrefer5GHz);
561CDF_STATUS sme_set_roam_intra_band(tHalHandle hHal, const bool nRoamIntraBand);
562CDF_STATUS sme_update_roam_scan_n_probes(tHalHandle hHal, uint8_t sessionId,
563 const uint8_t nProbes);
564CDF_STATUS sme_update_roam_scan_home_away_time(tHalHandle hHal,
565 uint8_t sessionId,
566 const uint16_t nRoamScanHomeAwayTime,
567 const bool bSendOffloadCmd);
568
569bool sme_get_roam_intra_band(tHalHandle hHal);
570uint8_t sme_get_roam_scan_n_probes(tHalHandle hHal);
571uint16_t sme_get_roam_scan_home_away_time(tHalHandle hHal);
572CDF_STATUS sme_update_roam_rssi_diff(tHalHandle hHal, uint8_t sessionId,
573 uint8_t RoamRssiDiff);
574CDF_STATUS sme_update_fast_transition_enabled(tHalHandle hHal,
575 bool isFastTransitionEnabled);
576CDF_STATUS sme_update_wes_mode(tHalHandle hHal, bool isWESModeEnabled,
577 uint8_t sessionId);
578CDF_STATUS sme_set_roam_scan_control(tHalHandle hHal, uint8_t sessionId,
579 bool roamScanControl);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800580
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800581CDF_STATUS sme_update_is_fast_roam_ini_feature_enabled(tHalHandle hHal,
582 uint8_t sessionId,
583 const bool
584 isFastRoamIniFeatureEnabled);
585CDF_STATUS sme_update_is_mawc_ini_feature_enabled(tHalHandle hHal,
586 const bool MAWCEnabled);
587CDF_STATUS sme_stop_roaming(tHalHandle hHal, uint8_t sessionId, uint8_t reason);
588CDF_STATUS sme_start_roaming(tHalHandle hHal, uint8_t sessionId,
589 uint8_t reason);
590CDF_STATUS sme_update_enable_fast_roam_in_concurrency(tHalHandle hHal,
591 bool bFastRoamInConIniFeatureEnabled);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800592#ifdef FEATURE_WLAN_ESE
593CDF_STATUS sme_update_is_ese_feature_enabled(tHalHandle hHal, uint8_t sessionId,
594 const bool isEseIniFeatureEnabled);
595#endif /* FEATURE_WLAN_ESE */
596CDF_STATUS sme_update_config_fw_rssi_monitoring(tHalHandle hHal,
597 bool fEnableFwRssiMonitoring);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800598CDF_STATUS sme_set_roam_rescan_rssi_diff(tHalHandle hHal,
599 uint8_t sessionId,
600 const uint8_t nRoamRescanRssiDiff);
601uint8_t sme_get_roam_rescan_rssi_diff(tHalHandle hHal);
602
603CDF_STATUS sme_set_roam_opportunistic_scan_threshold_diff(tHalHandle hHal,
604 uint8_t sessionId,
605 const uint8_t nOpportunisticThresholdDiff);
606uint8_t sme_get_roam_opportunistic_scan_threshold_diff(tHalHandle hHal);
607CDF_STATUS sme_set_neighbor_lookup_rssi_threshold(tHalHandle hHal,
608 uint8_t sessionId, uint8_t neighborLookupRssiThreshold);
609CDF_STATUS sme_set_delay_before_vdev_stop(tHalHandle hHal,
610 uint8_t sessionId, uint8_t delay_before_vdev_stop);
611uint8_t sme_get_neighbor_lookup_rssi_threshold(tHalHandle hHal);
612CDF_STATUS sme_set_neighbor_scan_refresh_period(tHalHandle hHal,
613 uint8_t sessionId, uint16_t neighborScanResultsRefreshPeriod);
614uint16_t sme_get_neighbor_scan_refresh_period(tHalHandle hHal);
615uint16_t sme_get_empty_scan_refresh_period(tHalHandle hHal);
616CDF_STATUS sme_update_empty_scan_refresh_period(tHalHandle hHal,
617 uint8_t sessionId, uint16_t nEmptyScanRefreshPeriod);
618CDF_STATUS sme_set_neighbor_scan_min_chan_time(tHalHandle hHal,
619 const uint16_t nNeighborScanMinChanTime,
620 uint8_t sessionId);
621CDF_STATUS sme_set_neighbor_scan_max_chan_time(tHalHandle hHal,
622 uint8_t sessionId, const uint16_t nNeighborScanMaxChanTime);
623uint16_t sme_get_neighbor_scan_min_chan_time(tHalHandle hHal,
624 uint8_t sessionId);
625uint32_t sme_get_neighbor_roam_state(tHalHandle hHal, uint8_t sessionId);
626uint32_t sme_get_current_roam_state(tHalHandle hHal, uint8_t sessionId);
627uint32_t sme_get_current_roam_sub_state(tHalHandle hHal, uint8_t sessionId);
628uint32_t sme_get_lim_sme_state(tHalHandle hHal);
629uint32_t sme_get_lim_mlm_state(tHalHandle hHal);
630bool sme_is_lim_session_valid(tHalHandle hHal, uint8_t sessionId);
631uint32_t sme_get_lim_sme_session_state(tHalHandle hHal, uint8_t sessionId);
632uint32_t sme_get_lim_mlm_session_state(tHalHandle hHal, uint8_t sessionId);
633uint16_t sme_get_neighbor_scan_max_chan_time(tHalHandle hHal,
634 uint8_t sessionId);
635CDF_STATUS sme_set_neighbor_scan_period(tHalHandle hHal, uint8_t sessionId,
636 const uint16_t nNeighborScanPeriod);
637uint16_t sme_get_neighbor_scan_period(tHalHandle hHal, uint8_t sessionId);
638CDF_STATUS sme_set_roam_bmiss_first_bcnt(tHalHandle hHal,
639 uint8_t sessionId, const uint8_t nRoamBmissFirstBcnt);
640uint8_t sme_get_roam_bmiss_first_bcnt(tHalHandle hHal);
641CDF_STATUS sme_set_roam_bmiss_final_bcnt(tHalHandle hHal, uint8_t sessionId,
642 const uint8_t nRoamBmissFinalBcnt);
643uint8_t sme_get_roam_bmiss_final_bcnt(tHalHandle hHal);
644CDF_STATUS sme_set_roam_beacon_rssi_weight(tHalHandle hHal, uint8_t sessionId,
645 const uint8_t nRoamBeaconRssiWeight);
646uint8_t sme_get_roam_beacon_rssi_weight(tHalHandle hHal);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800647uint8_t sme_get_roam_rssi_diff(tHalHandle hHal);
648CDF_STATUS sme_change_roam_scan_channel_list(tHalHandle hHal, uint8_t sessionId,
649 uint8_t *pChannelList,
650 uint8_t numChannels);
651#ifdef FEATURE_WLAN_ESE_UPLOAD
652CDF_STATUS sme_set_ese_roam_scan_channel_list(tHalHandle hHal,
653 uint8_t sessionId, uint8_t *pChannelList,
654 uint8_t numChannels);
655#endif
656CDF_STATUS sme_get_roam_scan_channel_list(tHalHandle hHal,
657 uint8_t *pChannelList, uint8_t *pNumChannels,
658 uint8_t sessionId);
659bool sme_get_is_ese_feature_enabled(tHalHandle hHal);
660bool sme_get_wes_mode(tHalHandle hHal);
661bool sme_get_roam_scan_control(tHalHandle hHal);
662bool sme_get_is_lfr_feature_enabled(tHalHandle hHal);
663bool sme_get_is_ft_feature_enabled(tHalHandle hHal);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800664CDF_STATUS sme_update_roam_scan_offload_enabled(tHalHandle hHal,
665 bool nRoamScanOffloadEnabled);
666uint8_t sme_is_feature_supported_by_fw(uint8_t featEnumValue);
667#ifdef FEATURE_WLAN_TDLS
668CDF_STATUS sme_send_tdls_link_establish_params(tHalHandle hHal,
669 uint8_t sessionId,
670 const tSirMacAddr peerMac,
671 tCsrTdlsLinkEstablishParams *
672 tdlsLinkEstablishParams);
673CDF_STATUS sme_send_tdls_mgmt_frame(tHalHandle hHal, uint8_t sessionId,
674 const tSirMacAddr peerMac, uint8_t frame_type,
675 uint8_t dialog, uint16_t status,
676 uint32_t peerCapability, uint8_t *buf,
677 uint8_t len, uint8_t responder);
678CDF_STATUS sme_change_tdls_peer_sta(tHalHandle hHal, uint8_t sessionId,
679 const tSirMacAddr peerMac,
680 tCsrStaParams *pstaParams);
681CDF_STATUS sme_add_tdls_peer_sta(tHalHandle hHal, uint8_t sessionId,
682 const tSirMacAddr peerMac);
683CDF_STATUS sme_delete_tdls_peer_sta(tHalHandle hHal, uint8_t sessionId,
684 const tSirMacAddr peerMac);
685void sme_set_tdls_power_save_prohibited(tHalHandle hHal, uint32_t sessionId,
686 bool val);
687CDF_STATUS sme_send_tdls_chan_switch_req(
688 tHalHandle hal,
689 sme_tdls_chan_switch_params *ch_switch_params);
690#endif
691
692/*
693 * SME API to enable/disable WLAN driver initiated SSR
694 */
695void sme_update_enable_ssr(tHalHandle hHal, bool enableSSR);
696CDF_STATUS sme_set_phy_mode(tHalHandle hHal, eCsrPhyMode phyMode);
697eCsrPhyMode sme_get_phy_mode(tHalHandle hHal);
698/*
699 * SME API to determine the channel bonding mode
700 */
701CDF_STATUS sme_set_ch_params(tHalHandle hHal, eCsrPhyMode eCsrPhyMode,
702 uint8_t channel, uint8_t ht_sec_ch, chan_params_t *ch_params);
703CDF_STATUS sme_handoff_request(tHalHandle hHal, uint8_t sessionId,
704 tCsrHandoffRequest *pHandoffInfo);
705CDF_STATUS sme_is_sta_p2p_client_connected(tHalHandle hHal);
706#ifdef FEATURE_WLAN_LPHB
707CDF_STATUS sme_lphb_config_req(tHalHandle hHal,
708 tSirLPHBReq * lphdReq,
709 void (*pCallbackfn)(void *pHddCtx,
710 tSirLPHBInd * indParam));
711#endif /* FEATURE_WLAN_LPHB */
712CDF_STATUS sme_add_periodic_tx_ptrn(tHalHandle hHal, tSirAddPeriodicTxPtrn
713 *addPeriodicTxPtrnParams);
714CDF_STATUS sme_del_periodic_tx_ptrn(tHalHandle hHal, tSirDelPeriodicTxPtrn
715 *delPeriodicTxPtrnParams);
716void sme_enable_disable_split_scan(tHalHandle hHal, uint8_t nNumStaChan,
717 uint8_t nNumP2PChan);
718CDF_STATUS sme_send_rate_update_ind(tHalHandle hHal,
719 tSirRateUpdateInd *rateUpdateParams);
720CDF_STATUS sme_roam_del_pmkid_from_cache(tHalHandle hHal, uint8_t sessionId,
721 const uint8_t *pBSSId, bool flush_cache);
722void sme_get_command_q_status(tHalHandle hHal);
723
724/*
725 * SME API to enable/disable idle mode powersave
726 * This should be called only if powersave offload
727 * is enabled
728 */
729CDF_STATUS sme_set_idle_powersave_config(void *cds_context,
730 tHalHandle hHal, uint32_t value);
731CDF_STATUS sme_notify_modem_power_state(tHalHandle hHal, uint32_t value);
732
733/*SME API to convert convert the ini value to the ENUM used in csr and MAC*/
734ePhyChanBondState sme_get_cb_phy_state_from_cb_ini_value(uint32_t cb_ini_value);
735int sme_update_ht_config(tHalHandle hHal, uint8_t sessionId, uint16_t htCapab,
736 int value);
737int16_t sme_get_ht_config(tHalHandle hHal, uint8_t session_id,
738 uint16_t ht_capab);
739#ifdef QCA_HT_2040_COEX
740CDF_STATUS sme_notify_ht2040_mode(tHalHandle hHal, uint16_t staId,
741 struct cdf_mac_addr macAddrSTA,
742 uint8_t sessionId,
743 uint8_t channel_type);
744CDF_STATUS sme_set_ht2040_mode(tHalHandle hHal, uint8_t sessionId,
745 uint8_t channel_type, bool obssEnabled);
746#endif
747CDF_STATUS sme_get_reg_info(tHalHandle hHal, uint8_t chanId,
748 uint32_t *regInfo1, uint32_t *regInfo2);
749#ifdef FEATURE_WLAN_TDLS
750CDF_STATUS sme_update_fw_tdls_state(tHalHandle hHal, void *psmeTdlsParams,
751 bool useSmeLock);
752CDF_STATUS sme_update_tdls_peer_state(tHalHandle hHal,
753 tSmeTdlsPeerStateParams *pPeerStateParams);
754#endif /* FEATURE_WLAN_TDLS */
755#ifdef FEATURE_WLAN_CH_AVOID
756CDF_STATUS sme_add_ch_avoid_callback(tHalHandle hHal,
757 void (*pCallbackfn)(void *hdd_context, void *indi_param));
758CDF_STATUS sme_ch_avoid_update_req(tHalHandle hHal);
759#else
760static inline
761CDF_STATUS sme_add_ch_avoid_callback(tHalHandle hHal,
762 void (*pCallbackfn)(void *hdd_context, void *indi_param))
763{
764 return CDF_STATUS_E_NOSUPPORT;
765}
766
767static inline
768CDF_STATUS sme_ch_avoid_update_req(tHalHandle hHal)
769{
770 return CDF_STATUS_E_NOSUPPORT;
771}
772#endif /* FEATURE_WLAN_CH_AVOID */
773#ifdef FEATURE_WLAN_AUTO_SHUTDOWN
774CDF_STATUS sme_set_auto_shutdown_cb(tHalHandle hHal, void (*pCallbackfn)(void));
775CDF_STATUS sme_set_auto_shutdown_timer(tHalHandle hHal, uint32_t timer_value);
776#endif
777CDF_STATUS sme_roam_channel_change_req(tHalHandle hHal,
Kiran Kumar Lokere999e58c2016-01-07 02:18:39 -0800778 struct cdf_mac_addr bssid, chan_params_t *ch_params,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800779 tCsrRoamProfile *profile);
780CDF_STATUS sme_roam_start_beacon_req(tHalHandle hHal,
781 struct cdf_mac_addr bssid, uint8_t dfsCacWaitStatus);
782CDF_STATUS sme_roam_csa_ie_request(tHalHandle hHal, struct cdf_mac_addr bssid,
Kiran Kumar Lokere999e58c2016-01-07 02:18:39 -0800783 uint8_t targetChannel, uint8_t csaIeReqd,
784 chan_params_t *ch_params);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800785CDF_STATUS sme_init_thermal_info(tHalHandle hHal,
786 tSmeThermalParams thermalParam);
787CDF_STATUS sme_set_thermal_level(tHalHandle hHal, uint8_t level);
788CDF_STATUS sme_txpower_limit(tHalHandle hHal, tSirTxPowerLimit *psmetx);
789CDF_STATUS sme_get_link_speed(tHalHandle hHal, tSirLinkSpeedInfo *lsReq,
790 void *plsContext,
791 void (*pCallbackfn)(tSirLinkSpeedInfo *indParam,
792 void *pContext));
793CDF_STATUS sme_modify_add_ie(tHalHandle hHal,
794 tSirModifyIE *pModifyIE, eUpdateIEsType updateType);
795CDF_STATUS sme_update_add_ie(tHalHandle hHal,
796 tSirUpdateIE *pUpdateIE, eUpdateIEsType updateType);
797CDF_STATUS sme_update_connect_debug(tHalHandle hHal, uint32_t set_value);
Sreelakshmi Konamki39acb132015-12-16 13:06:22 +0530798const char *sme_request_type_to_string(const uint8_t request_type);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800799CDF_STATUS sme_ap_disable_intra_bss_fwd(tHalHandle hHal, uint8_t sessionId,
800 bool disablefwd);
801uint32_t sme_get_channel_bonding_mode5_g(tHalHandle hHal);
802uint32_t sme_get_channel_bonding_mode24_g(tHalHandle hHal);
803#ifdef WLAN_FEATURE_STATS_EXT
804typedef struct sStatsExtRequestReq {
805 uint32_t request_data_len;
806 uint8_t *request_data;
807} tStatsExtRequestReq, *tpStatsExtRequestReq;
808typedef void (*StatsExtCallback)(void *, tStatsExtEvent *);
809void sme_stats_ext_register_callback(tHalHandle hHal,
810 StatsExtCallback callback);
811CDF_STATUS sme_stats_ext_request(uint8_t session_id,
812 tpStatsExtRequestReq input);
813CDF_STATUS sme_stats_ext_event(tHalHandle hHal, void *pMsg);
814#endif
815CDF_STATUS sme_update_dfs_scan_mode(tHalHandle hHal,
816 uint8_t sessionId,
817 uint8_t allowDFSChannelRoam);
818uint8_t sme_get_dfs_scan_mode(tHalHandle hHal);
819bool sme_sta_in_middle_of_roaming(tHalHandle hHal, uint8_t sessionId);
820
821#ifdef FEATURE_WLAN_EXTSCAN
822CDF_STATUS sme_get_valid_channels_by_band(tHalHandle hHal, uint8_t wifiBand,
823 uint32_t *aValidChannels,
824 uint8_t *pNumChannels);
825CDF_STATUS sme_ext_scan_get_capabilities(tHalHandle hHal,
826 tSirGetExtScanCapabilitiesReqParams *pReq);
827CDF_STATUS sme_ext_scan_start(tHalHandle hHal,
828 tSirWifiScanCmdReqParams *pStartCmd);
829CDF_STATUS sme_ext_scan_stop(tHalHandle hHal,
830 tSirExtScanStopReqParams *pStopReq);
831CDF_STATUS sme_set_bss_hotlist(tHalHandle hHal,
832 tSirExtScanSetBssidHotListReqParams *
833 pSetHotListReq);
834CDF_STATUS sme_reset_bss_hotlist(tHalHandle hHal,
835 tSirExtScanResetBssidHotlistReqParams *
836 pResetReq);
837CDF_STATUS sme_set_significant_change(tHalHandle hHal,
838 tSirExtScanSetSigChangeReqParams *
839 pSetSignificantChangeReq);
840CDF_STATUS sme_reset_significant_change(tHalHandle hHal,
841 tSirExtScanResetSignificantChangeReqParams
842 *pResetReq);
843CDF_STATUS sme_get_cached_results(tHalHandle hHal,
844 tSirExtScanGetCachedResultsReqParams *
845 pCachedResultsReq);
846
847CDF_STATUS sme_set_epno_list(tHalHandle hal,
848 struct wifi_epno_params *req_msg);
849CDF_STATUS sme_set_passpoint_list(tHalHandle hal,
850 struct wifi_passpoint_req *req_msg);
851CDF_STATUS sme_reset_passpoint_list(tHalHandle hal,
852 struct wifi_passpoint_req *req_msg);
853CDF_STATUS
854sme_set_ssid_hotlist(tHalHandle hal,
855 struct sir_set_ssid_hotlist_request *request);
856
857CDF_STATUS sme_ext_scan_register_callback(tHalHandle hHal,
858 void (*pExtScanIndCb)(void *, const uint16_t, void *));
Prashanth Bhatta75fa9a12016-01-11 18:30:08 -0800859#else
860static inline CDF_STATUS sme_ext_scan_register_callback(tHalHandle hHal,
861 void (*pExtScanIndCb)(void *, const uint16_t, void *))
862{
863 return CDF_STATUS_SUCCESS;
864}
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800865#endif /* FEATURE_WLAN_EXTSCAN */
866CDF_STATUS sme_abort_roam_scan(tHalHandle hHal, uint8_t sessionId);
867#ifdef WLAN_FEATURE_LINK_LAYER_STATS
868CDF_STATUS sme_ll_stats_clear_req(tHalHandle hHal,
869 tSirLLStatsClearReq * pclearStatsReq);
870CDF_STATUS sme_ll_stats_set_req(tHalHandle hHal,
871 tSirLLStatsSetReq *psetStatsReq);
872CDF_STATUS sme_ll_stats_get_req(tHalHandle hHal,
873 tSirLLStatsGetReq *pgetStatsReq);
874CDF_STATUS sme_set_link_layer_stats_ind_cb(tHalHandle hHal,
875 void (*callbackRoutine)(void *callbackCtx,
876 int indType, void *pRsp));
877#endif /* WLAN_FEATURE_LINK_LAYER_STATS */
878
879CDF_STATUS sme_fw_mem_dump(tHalHandle hHal, void *recvd_req);
880CDF_STATUS sme_fw_mem_dump_register_cb(tHalHandle hHal,
881 void (*callback_routine)(void *cb_context,
882 struct fw_dump_rsp *rsp));
883CDF_STATUS sme_fw_mem_dump_unregister_cb(tHalHandle hHal);
884
885#ifdef WLAN_FEATURE_ROAM_OFFLOAD
886CDF_STATUS sme_update_roam_offload_enabled(tHalHandle hHal,
887 bool nRoamOffloadEnabled);
888CDF_STATUS sme_update_roam_key_mgmt_offload_enabled(tHalHandle hHal,
889 uint8_t sessionId,
890 bool nRoamKeyMgmtOffloadEnabled);
891#endif
892#ifdef WLAN_FEATURE_NAN
893CDF_STATUS sme_nan_event(tHalHandle hHal, void *pMsg);
894#endif /* WLAN_FEATURE_NAN */
895CDF_STATUS sme_get_link_status(tHalHandle hHal,
896 tCsrLinkStatusCallback callback,
897 void *pContext, uint8_t sessionId);
898CDF_STATUS sme_get_temperature(tHalHandle hHal,
899 void *tempContext,
900 void (*pCallbackfn)(int temperature,
901 void *pContext));
902CDF_STATUS sme_set_scanning_mac_oui(tHalHandle hHal,
903 tSirScanMacOui *pScanMacOui);
904
905#ifdef IPA_OFFLOAD
906/* ---------------------------------------------------------------------------
907 \fn sme_ipa_offload_enable_disable
908 \brief API to enable/disable IPA offload
909 \param hHal - The handle returned by macOpen.
910 \param sessionId - Session Identifier
911 \param pRequest - Pointer to the offload request.
912 \return eHalStatus
913 ---------------------------------------------------------------------------*/
914CDF_STATUS sme_ipa_offload_enable_disable(tHalHandle hal,
915 uint8_t session_id,
916 struct sir_ipa_offload_enable_disable *request);
917#else
918static inline CDF_STATUS sme_ipa_offload_enable_disable(tHalHandle hal,
919 uint8_t session_id,
920 struct sir_ipa_offload_enable_disable *request)
921{
922 return CDF_STATUS_SUCCESS;
923}
924#endif /* IPA_OFFLOAD */
925
926#ifdef DHCP_SERVER_OFFLOAD
927CDF_STATUS sme_set_dhcp_srv_offload(tHalHandle hHal,
928 tSirDhcpSrvOffloadInfo * pDhcpSrvInfo);
929#endif /* DHCP_SERVER_OFFLOAD */
930#ifdef WLAN_FEATURE_GPIO_LED_FLASHING
931CDF_STATUS sme_set_led_flashing(tHalHandle hHal, uint8_t type,
932 uint32_t x0, uint32_t x1);
933#endif
934CDF_STATUS sme_handle_dfs_chan_scan(tHalHandle hHal, uint8_t dfs_flag);
935CDF_STATUS sme_set_mas(uint32_t val);
936CDF_STATUS sme_set_miracast(tHalHandle hal, uint8_t filter_type);
Abhishek Singh518323d2015-10-19 17:42:01 +0530937CDF_STATUS sme_ext_change_channel(tHalHandle hHal, uint32_t channel,
938 uint8_t session_id);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800939
940CDF_STATUS sme_configure_modulated_dtim(tHalHandle hal, uint8_t session_id,
941 uint32_t modulated_dtim);
942
943CDF_STATUS sme_configure_stats_avg_factor(tHalHandle hal, uint8_t session_id,
944 uint16_t stats_avg_factor);
945
946CDF_STATUS sme_configure_guard_time(tHalHandle hal, uint8_t session_id,
947 uint32_t guard_time);
948
949CDF_STATUS sme_wifi_start_logger(tHalHandle hal,
950 struct sir_wifi_start_log start_log);
951
952bool sme_neighbor_middle_of_roaming(tHalHandle hHal,
953 uint8_t sessionId);
954
955CDF_STATUS sme_enable_uapsd_for_ac(void *cds_ctx, uint8_t sta_id,
956 sme_ac_enum_type ac, uint8_t tid,
957 uint8_t pri, uint32_t srvc_int,
958 uint32_t sus_int,
959 sme_tspec_dir_type dir,
960 uint8_t psb, uint32_t sessionId,
961 uint32_t delay_interval);
962
963CDF_STATUS sme_disable_uapsd_for_ac(void *cds_ctx, uint8_t sta_id,
964 sme_ac_enum_type ac,
965 uint32_t sessionId);
966
967CDF_STATUS sme_set_rssi_monitoring(tHalHandle hal,
968 struct rssi_monitor_req *input);
969CDF_STATUS sme_set_rssi_threshold_breached_cb(tHalHandle hal,
970 void (*cb)(void *, struct rssi_breach_event *));
971
Abhishek Singh7996eb72015-12-30 17:24:02 +0530972CDF_STATUS sme_register_mgmt_frame_ind_callback(tHalHandle hal,
973 sir_mgmt_frame_ind_callback callback);
974
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800975CDF_STATUS sme_update_nss(tHalHandle h_hal, uint8_t nss);
976
977bool sme_is_any_session_in_connected_state(tHalHandle h_hal);
978
979CDF_STATUS sme_soc_set_pcl(tHalHandle hal,
980 struct sir_pcl_list msg);
981CDF_STATUS sme_soc_set_hw_mode(tHalHandle hal,
982 struct sir_hw_mode msg);
983void sme_register_hw_mode_trans_cb(tHalHandle hal,
984 hw_mode_transition_cb callback);
985CDF_STATUS sme_nss_update_request(tHalHandle hHal, uint32_t vdev_id,
986 uint8_t new_nss, void *cback,
987 uint8_t next_action, void *hdd_context);
988
989typedef void (*sme_peer_authorized_fp) (uint32_t vdev_id);
990CDF_STATUS sme_set_peer_authorized(uint8_t *peer_addr,
991 sme_peer_authorized_fp auth_fp,
992 uint32_t vdev_id);
993CDF_STATUS sme_soc_set_dual_mac_config(tHalHandle hal,
994 struct sir_dual_mac_config msg);
995
996void sme_set_scan_disable(tHalHandle h_hal, int value);
997void sme_setdef_dot11mode(tHalHandle hal);
998
999CDF_STATUS sme_disable_non_fcc_channel(tHalHandle hHal,
1000 bool fcc_constraint);
1001
1002CDF_STATUS sme_update_roam_scan_hi_rssi_scan_params(tHalHandle hal_handle,
1003 uint8_t session_id,
1004 uint32_t notify_id,
1005 int32_t val);
1006
1007void wlan_sap_enable_phy_error_logs(tHalHandle hal, bool enable_log);
1008void sme_set_dot11p_config(tHalHandle hal, bool enable_dot11p);
1009
1010CDF_STATUS sme_ocb_set_config(tHalHandle hHal, void *context,
1011 ocb_callback callback,
1012 struct sir_ocb_config *config);
1013
1014CDF_STATUS sme_ocb_set_utc_time(tHalHandle hHal, struct sir_ocb_utc *utc);
1015
1016CDF_STATUS sme_ocb_start_timing_advert(tHalHandle hHal,
1017 struct sir_ocb_timing_advert *timing_advert);
1018
1019CDF_STATUS sme_ocb_stop_timing_advert(tHalHandle hHal,
1020 struct sir_ocb_timing_advert *timing_advert);
1021
Naveen Rawatb4d37622015-11-13 16:15:25 -08001022int sme_ocb_gen_timing_advert_frame(tHalHandle hHal, tSirMacAddr self_addr,
1023 uint8_t **buf, uint32_t *timestamp_offset,
1024 uint32_t *time_value_offset);
1025
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001026CDF_STATUS sme_ocb_get_tsf_timer(tHalHandle hHal, void *context,
1027 ocb_callback callback,
1028 struct sir_ocb_get_tsf_timer *request);
1029
1030CDF_STATUS sme_dcc_get_stats(tHalHandle hHal, void *context,
1031 ocb_callback callback,
1032 struct sir_dcc_get_stats *request);
1033
1034CDF_STATUS sme_dcc_clear_stats(tHalHandle hHal, uint32_t vdev_id,
1035 uint32_t dcc_stats_bitmap);
1036
1037CDF_STATUS sme_dcc_update_ndl(tHalHandle hHal, void *context,
1038 ocb_callback callback,
1039 struct sir_dcc_update_ndl *request);
1040
1041CDF_STATUS sme_register_for_dcc_stats_event(tHalHandle hHal, void *context,
1042 ocb_callback callback);
1043void sme_add_set_thermal_level_callback(tHalHandle hal,
1044 sme_set_thermal_level_callback callback);
1045
Krishna Kumaar Natarajan052c6e62015-09-28 15:32:55 -07001046void sme_update_tgt_services(tHalHandle hal, struct wma_tgt_services *cfg);
Edhar, Mahesh Kumardf2ec122015-11-16 11:33:16 +05301047bool sme_validate_sap_channel_switch(tHalHandle hal,
1048 uint16_t sap_ch, eCsrPhyMode sap_phy_mode,
1049 uint8_t cc_switch_mode, uint8_t session_id);
Masti, Narayanraddic4a7ab82015-11-25 15:41:10 +05301050
1051#ifdef FEATURE_WLAN_TDLS
1052void sme_get_opclass(tHalHandle hal, uint8_t channel, uint8_t bw_offset,
1053 uint8_t *opclass);
1054#else
1055static inline void
1056sme_get_opclass(tHalHandle hal, uint8_t channel, uint8_t bw_offset,
1057 uint8_t *opclass)
1058{
1059}
1060#endif
1061
Ravi Joshi61c3c7a2015-11-09 18:41:20 -08001062#ifdef FEATURE_LFR_SUBNET_DETECTION
1063CDF_STATUS sme_gateway_param_update(tHalHandle hHal,
1064 struct gateway_param_update_req *request);
1065#endif
1066
Ryan Hsu3c8f79f2015-12-02 16:45:09 -08001067#ifdef FEATURE_GREEN_AP
1068CDF_STATUS sme_send_egap_conf_params(uint32_t enable,
1069 uint32_t inactivity_time,
1070 uint32_t wait_time,
1071 uint32_t flags);
1072#else
1073static inline CDF_STATUS sme_send_egap_conf_params(uint32_t enable,
1074 uint32_t inactivity_time,
1075 uint32_t wait_time,
1076 uint32_t flags)
1077{
1078 return CDF_STATUS_E_NOSUPPORT;
1079}
1080#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001081#endif /* #if !defined( __SME_API_H ) */