blob: 5cb7b231651094a758523de11dad8b1b97e164f5 [file] [log] [blame]
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001/*
yeshwanth sriram guntuka310b3ac2016-11-15 23:25:26 +05302 * Copyright (c) 2012-2017 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"
Anurag Chouhana37b5b72016-02-21 14:53:42 +053041#include "qdf_lock.h"
Anurag Chouhan6d760662016-02-20 16:05:43 +053042#include "qdf_types.h"
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080043#include "sir_api.h"
44#include "cds_reg_service.h"
45#include "p2p_api.h"
46#include "cds_regdomain.h"
47#include "sme_internal.h"
Krishna Kumaar Natarajan052c6e62015-09-28 15:32:55 -070048#include "wma_tgt_cfg.h"
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080049
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080050#include "sme_rrm_internal.h"
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080051#include "sir_types.h"
Krunal Sonid32c6bc2016-10-18 18:00:21 -070052#include "scheduler_api.h"
Varun Reddy Yeturu35c07f92017-02-28 10:35:00 -080053#include "wlan_serialization_legacy_api.h"
Krunal Sonid32c6bc2016-10-18 18:00:21 -070054
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080055/*--------------------------------------------------------------------------
56 Preprocessor definitions and constants
57 ------------------------------------------------------------------------*/
58
Jeff Johnson97fdfd02017-03-13 09:25:31 -070059#define SME_SUMMARY_STATS (1 << eCsrSummaryStats)
60#define SME_GLOBAL_CLASSA_STATS (1 << eCsrGlobalClassAStats)
61#define SME_GLOBAL_CLASSB_STATS (1 << eCsrGlobalClassBStats)
62#define SME_GLOBAL_CLASSC_STATS (1 << eCsrGlobalClassCStats)
63#define SME_GLOBAL_CLASSD_STATS (1 << eCsrGlobalClassDStats)
64#define SME_PER_STA_STATS (1 << eCsrPerStaStats)
65#define SME_PER_CHAIN_RSSI_STATS (1 << csr_per_chain_rssi_stats)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080066
67#define SME_SESSION_ID_ANY 50
68
69#define SME_INVALID_COUNTRY_CODE "XX"
70
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080071#define SME_SET_CHANNEL_REG_POWER(reg_info_1, val) do { \
72 reg_info_1 &= 0xff00ffff; \
73 reg_info_1 |= ((val & 0xff) << 16); \
74} while (0)
75
76#define SME_SET_CHANNEL_MAX_TX_POWER(reg_info_2, val) do { \
77 reg_info_2 &= 0xffff00ff; \
78 reg_info_2 |= ((val & 0xff) << 8); \
79} while (0)
80
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -070081#define SME_CONFIG_TO_ROAM_CONFIG 1
82#define ROAM_CONFIG_TO_SME_CONFIG 2
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080083
Kiran Kumar Lokere666bf852016-05-02 12:23:02 -070084#define NUM_OF_BANDS 2
Naveen Rawatb56880c2016-12-13 17:56:03 -080085
86#define SME_ACTIVE_LIST_CMD_TIMEOUT_VALUE (30*1000)
87#define SME_CMD_TIMEOUT_VALUE (SME_ACTIVE_LIST_CMD_TIMEOUT_VALUE + 1000)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -080088/*--------------------------------------------------------------------------
89 Type declarations
90 ------------------------------------------------------------------------*/
91typedef void (*hdd_ftm_msg_processor)(void *);
92typedef struct _smeConfigParams {
93 tCsrConfigParam csrConfig;
Krishna Kumaar Natarajanf599c6e2015-11-03 11:44:03 -080094 struct rrm_config_param rrmConfig;
Kapil Gupta4f0c0c12017-02-07 15:21:15 +053095 bool snr_monitor_enabled;
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)
Poddar, Siddarth83905022016-04-16 17:56:08 -0700166#define SME_MAX_THROTTLE_LEVELS (4)
167
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800168typedef struct {
169 /* Array of thermal levels */
170 tSmeThermalLevelInfo smeThermalLevels[SME_MAX_THERMAL_LEVELS];
171 uint8_t smeThermalMgmtEnabled;
172 uint32_t smeThrottlePeriod;
Poddar, Siddarth83905022016-04-16 17:56:08 -0700173 uint8_t sme_throttle_duty_cycle_tbl[SME_MAX_THROTTLE_LEVELS];
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800174} tSmeThermalParams;
175
176typedef enum {
177 SME_AC_BK = 0,
178 SME_AC_BE = 1,
179 SME_AC_VI = 2,
180 SME_AC_VO = 3
181} sme_ac_enum_type;
182
183/* TSPEC Direction Enum Type */
184typedef enum {
185 /* uplink */
186 SME_TX_DIR = 0,
187 /* downlink */
188 SME_RX_DIR = 1,
189 /* bidirectional */
190 SME_BI_DIR = 2,
191} sme_tspec_dir_type;
192
Krishna Kumaar Natarajan53ca2902015-12-04 14:01:46 -0800193/**
194 * struct sme_oem_capability - OEM capability to be exchanged between host
195 * and userspace
196 * @ftm_rr: FTM range report capability bit
197 * @lci_capability: LCI capability bit
198 * @reserved1: reserved
199 * @reserved2: reserved
200 */
201struct sme_oem_capability {
202 uint32_t ftm_rr:1;
203 uint32_t lci_capability:1;
204 uint32_t reserved1:30;
205 uint32_t reserved2;
206};
207
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800208/*-------------------------------------------------------------------------
209 Function declarations and documenation
210 ------------------------------------------------------------------------*/
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530211QDF_STATUS sme_open(tHalHandle hHal);
212QDF_STATUS sme_init_chan_list(tHalHandle hal, uint8_t *alpha2,
Amar Singhala297bfa2015-10-15 15:07:29 -0700213 enum country_src cc_src);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530214QDF_STATUS sme_close(tHalHandle hHal);
215QDF_STATUS sme_start(tHalHandle hHal);
216QDF_STATUS sme_stop(tHalHandle hHal, tHalStopType stopType);
217QDF_STATUS sme_open_session(tHalHandle hHal, csr_roam_completeCallback callback,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800218 void *pContext, uint8_t *pSelfMacAddr,
219 uint8_t *pbSessionId, uint32_t type,
220 uint32_t subType);
Peng Xuf5d60c82015-10-02 17:17:03 -0700221void sme_set_curr_device_mode(tHalHandle hHal,
Anurag Chouhan6d760662016-02-20 16:05:43 +0530222 enum tQDF_ADAPTER_MODE currDeviceMode);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530223QDF_STATUS sme_close_session(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800224 csr_roamSessionCloseCallback callback,
225 void *pContext);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530226QDF_STATUS sme_update_roam_params(tHalHandle hHal, uint8_t session_id,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800227 struct roam_ext_params roam_params_src, int update_param);
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -0700228#ifdef FEATURE_WLAN_SCAN_PNO
229void sme_update_roam_pno_channel_prediction_config(
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530230 tHalHandle hal, tCsrConfigParam *csr_config,
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -0700231 uint8_t copy_from_to);
232#else
233static inline void sme_update_roam_pno_channel_prediction_config(
Krunal Soni1878d3a2016-01-14 13:00:44 -0800234 tHalHandle hal, tCsrConfigParam *csr_config,
Varun Reddy Yeturub43fda12015-09-10 18:16:21 -0700235 uint8_t copy_from_to)
236{}
237#endif
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530238QDF_STATUS sme_update_config(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800239 tpSmeConfigParams pSmeConfigParams);
240
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530241QDF_STATUS sme_set11dinfo(tHalHandle hHal, tpSmeConfigParams pSmeConfigParams);
242QDF_STATUS sme_get_soft_ap_domain(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800243 v_REGDOMAIN_t *domainIdSoftAp);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530244QDF_STATUS sme_set_reg_info(tHalHandle hHal, uint8_t *apCntryCode);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530245QDF_STATUS sme_hdd_ready_ind(tHalHandle hHal);
Krunal Sonia8270f52017-02-23 19:51:25 -0800246/**
247 * sme_ser_cmd_callback() - callback from serialization module
248 * @buf: serialization command buffer
249 * @reason: reason why serialization module has given this callback
250 *
251 * Serialization module will give callback to SME for why it triggered
252 * the callback
253 *
254 * Return: QDF_STATUS_SUCCESS
255 */
256QDF_STATUS sme_ser_cmd_callback(void *buf,
257 enum wlan_serialization_cb_reason reason);
Rajeev Kumar8eaedf62017-01-21 11:03:13 -0800258QDF_STATUS sme_process_msg(tHalHandle hHal, struct scheduler_msg *pMsg);
Krunal Sonid32c6bc2016-10-18 18:00:21 -0700259QDF_STATUS sme_mc_process_handler(struct scheduler_msg *msg);
Rajeev Kumar8eaedf62017-01-21 11:03:13 -0800260void sme_free_msg(tHalHandle hHal, struct scheduler_msg *pMsg);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530261QDF_STATUS sme_scan_request(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800262 tCsrScanRequest *, csr_scan_completeCallback callback,
263 void *pContext);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530264QDF_STATUS sme_scan_get_result(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800265 tCsrScanResultFilter *pFilter,
266 tScanResultHandle *phResult);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530267QDF_STATUS sme_get_ap_channel_from_scan_cache(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800268 tCsrRoamProfile *profile,
269 tScanResultHandle *scan_cache,
270 uint8_t *ap_chnl_id);
271bool sme_store_joinreq_param(tHalHandle hal_handle,
272 tCsrRoamProfile *profile,
273 tScanResultHandle scan_cache,
274 uint32_t *roam_id,
275 uint32_t session_id);
276bool sme_clear_joinreq_param(tHalHandle hal_handle,
277 uint32_t session_id);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530278QDF_STATUS sme_issue_stored_joinreq(tHalHandle hal_handle,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800279 uint32_t *roam_id,
280 uint32_t session_id);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530281QDF_STATUS sme_scan_flush_result(tHalHandle hHal);
282QDF_STATUS sme_filter_scan_results(tHalHandle hHal, uint8_t sessionId);
283QDF_STATUS sme_scan_flush_p2p_result(tHalHandle hHal, uint8_t sessionId);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800284tCsrScanResultInfo *sme_scan_result_get_first(tHalHandle,
285 tScanResultHandle hScanResult);
286tCsrScanResultInfo *sme_scan_result_get_next(tHalHandle,
287 tScanResultHandle hScanResult);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530288QDF_STATUS sme_scan_result_purge(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800289 tScanResultHandle hScanResult);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530290QDF_STATUS sme_scan_get_pmkid_candidate_list(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800291 tPmkidCandidateInfo *pPmkidList,
292 uint32_t *pNumItems);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530293QDF_STATUS sme_roam_connect(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800294 tCsrRoamProfile *pProfile, uint32_t *pRoamId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530295QDF_STATUS sme_roam_reassoc(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800296 tCsrRoamProfile *pProfile,
297 tCsrRoamModifyProfileFields modProfileFields,
298 uint32_t *pRoamId, bool fForce);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530299QDF_STATUS sme_roam_connect_to_last_profile(tHalHandle hHal, uint8_t sessionId);
300QDF_STATUS sme_roam_disconnect(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800301 eCsrRoamDisconnectReason reason);
Abhishek Singhca408032016-09-13 15:26:12 +0530302void sme_dhcp_done_ind(tHalHandle hal, uint8_t session_id);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530303QDF_STATUS sme_roam_stop_bss(tHalHandle hHal, uint8_t sessionId);
304QDF_STATUS sme_roam_get_associated_stas(tHalHandle hHal, uint8_t sessionId,
Anurag Chouhan6d760662016-02-20 16:05:43 +0530305 QDF_MODULE_ID modId, void *pUsrContext,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800306 void *pfnSapEventCallback,
307 uint8_t *pAssocStasBuf);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530308QDF_STATUS sme_roam_disconnect_sta(tHalHandle hHal, uint8_t sessionId,
Deepthi Gowrib3bfefd2016-09-13 15:14:34 +0530309 struct tagCsrDelStaParams *p_del_sta_params);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530310QDF_STATUS sme_roam_deauth_sta(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800311 struct tagCsrDelStaParams *pDelStaParams);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530312QDF_STATUS sme_roam_tkip_counter_measures(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800313 bool bEnable);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530314QDF_STATUS sme_roam_get_wps_session_overlap(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800315 void *pUsrContext,
316 void *pfnSapEventCallback,
Anurag Chouhan6d760662016-02-20 16:05:43 +0530317 struct qdf_mac_addr pRemoveMac);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530318QDF_STATUS sme_roam_get_connect_state(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800319 eCsrConnectState *pState);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530320QDF_STATUS sme_roam_get_connect_profile(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800321 tCsrRoamConnectedProfile *pProfile);
Naveen Rawatdf0a7e72016-01-06 18:35:53 -0800322void sme_roam_free_connect_profile(tCsrRoamConnectedProfile *profile);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530323QDF_STATUS sme_roam_set_pmkid_cache(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800324 tPmkidCacheInfo *pPMKIDCache,
325 uint32_t numItems,
326 bool update_entire_cache);
327
328#ifdef WLAN_FEATURE_ROAM_OFFLOAD
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530329QDF_STATUS sme_roam_set_psk_pmk(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800330 uint8_t *pPSK_PMK, size_t pmk_len);
331#endif
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530332QDF_STATUS sme_roam_get_security_req_ie(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800333 uint32_t *pLen, uint8_t *pBuf,
334 eCsrSecurityType secType);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530335QDF_STATUS sme_roam_get_security_rsp_ie(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800336 uint32_t *pLen, uint8_t *pBuf,
337 eCsrSecurityType secType);
338uint32_t sme_roam_get_num_pmkid_cache(tHalHandle hHal, uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530339QDF_STATUS sme_roam_get_pmkid_cache(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800340 uint32_t *pNum,
341 tPmkidCacheInfo *pPmkidCache);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530342QDF_STATUS sme_get_config_param(tHalHandle hHal, tSmeConfigParams *pParam);
343QDF_STATUS sme_get_statistics(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800344 eCsrStatsRequesterType requesterId,
345 uint32_t statsMask, tCsrStatsCallback callback,
346 uint32_t periodicity, bool cache, uint8_t staId,
347 void *pContext, uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530348QDF_STATUS sme_get_rssi(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800349 tCsrRssiCallback callback,
Anurag Chouhan6d760662016-02-20 16:05:43 +0530350 uint8_t staId, struct qdf_mac_addr bssId, int8_t lastRSSI,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800351 void *pContext, void *p_cds_context);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530352QDF_STATUS sme_get_snr(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800353 tCsrSnrCallback callback,
Anurag Chouhan6d760662016-02-20 16:05:43 +0530354 uint8_t staId, struct qdf_mac_addr bssId, void *pContext);
Srinivas Girigowda515a9ef2015-12-11 11:00:48 -0800355#ifdef FEATURE_WLAN_ESE
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530356QDF_STATUS sme_get_tsm_stats(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800357 tCsrTsmStatsCallback callback,
Anurag Chouhan6d760662016-02-20 16:05:43 +0530358 uint8_t staId, struct qdf_mac_addr bssId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800359 void *pContext, void *p_cds_context, uint8_t tid);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530360QDF_STATUS sme_set_cckm_ie(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800361 uint8_t sessionId,
362 uint8_t *pCckmIe, uint8_t cckmIeLen);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530363QDF_STATUS sme_set_ese_beacon_request(tHalHandle hHal, const uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800364 const tCsrEseBeaconReq *pEseBcnReq);
Srinivas Girigowda515a9ef2015-12-11 11:00:48 -0800365QDF_STATUS sme_set_plm_request(tHalHandle hHal, tpSirPlmReq pPlm);
366#endif /*FEATURE_WLAN_ESE */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530367QDF_STATUS sme_cfg_set_int(tHalHandle hal, uint16_t cfg_id, uint32_t value);
368QDF_STATUS sme_cfg_set_str(tHalHandle hal, uint16_t cfg_id, uint8_t *str,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800369 uint32_t length);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530370QDF_STATUS sme_cfg_get_int(tHalHandle hal, uint16_t cfg_id,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800371 uint32_t *cfg_value);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530372QDF_STATUS sme_cfg_get_str(tHalHandle hal, uint16_t cfg_id, uint8_t *str,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800373 uint32_t *length);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530374QDF_STATUS sme_get_modify_profile_fields(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800375 tCsrRoamModifyProfileFields *
376 pModifyProfileFields);
377
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530378extern QDF_STATUS sme_set_host_power_save(tHalHandle hHal, bool psMode);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800379
380void sme_set_dhcp_till_power_active_flag(tHalHandle hHal, uint8_t flag);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530381extern QDF_STATUS sme_register11d_scan_done_callback(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800382 csr_scan_completeCallback);
Arun Khandavalli4b55da72016-07-19 19:55:01 +0530383void sme_deregister11d_scan_done_callback(tHalHandle hHal);
384
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800385#ifdef FEATURE_OEM_DATA_SUPPORT
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530386extern QDF_STATUS sme_register_oem_data_rsp_callback(tHalHandle h_hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800387 sme_send_oem_data_rsp_msg callback);
Arun Khandavalli4b55da72016-07-19 19:55:01 +0530388void sme_deregister_oem_data_rsp_callback(tHalHandle h_hal);
389
Prashanth Bhatta75fa9a12016-01-11 18:30:08 -0800390#else
Naveen Rawat910726a2017-03-06 11:42:51 -0800391static inline QDF_STATUS sme_register_oem_data_rsp_callback(tHalHandle hal,
392 void *callback)
Prashanth Bhatta75fa9a12016-01-11 18:30:08 -0800393{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530394 return QDF_STATUS_SUCCESS;
Prashanth Bhatta75fa9a12016-01-11 18:30:08 -0800395}
Arun Khandavalli4b55da72016-07-19 19:55:01 +0530396static inline void sme_deregister_oem_data_rsp_callback(tHalHandle h_hal)
397{
398}
399
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800400#endif
401
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530402extern QDF_STATUS sme_wow_add_pattern(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800403 struct wow_add_pattern *pattern, uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530404extern QDF_STATUS sme_wow_delete_pattern(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800405 struct wow_delete_pattern *pattern, uint8_t sessionId);
406
407void sme_register_ftm_msg_processor(tHalHandle hal,
408 hdd_ftm_msg_processor callback);
409
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530410extern QDF_STATUS sme_enter_wowl(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800411 void (*enter_wowl_callback_routine)(void
412 *callbackContext,
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530413 QDF_STATUS status),
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800414 void *enter_wowl_callback_context,
415#ifdef WLAN_WAKEUP_EVENTS
416 void (*wake_reason_ind_cb)(void *callbackContext,
417 tpSirWakeReasonInd
418 wake_reason_ind),
419 void *wake_reason_ind_cb_ctx,
420#endif /* WLAN_WAKEUP_EVENTS */
421 tpSirSmeWowlEnterParams wowl_enter_params,
422 uint8_t sessionId);
423
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530424extern QDF_STATUS sme_exit_wowl(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800425 tpSirSmeWowlExitParams wowl_exit_params);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530426QDF_STATUS sme_roam_set_key(tHalHandle, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800427 tCsrRoamSetKey *pSetKey, uint32_t *pRoamId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530428QDF_STATUS sme_get_country_code(tHalHandle hHal, uint8_t *pBuf, uint8_t *pbLen);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800429
430
431void sme_apply_channel_power_info_to_fw(tHalHandle hHal);
432
433/* some support functions */
434bool sme_is11d_supported(tHalHandle hHal);
435bool sme_is11h_supported(tHalHandle hHal);
436bool sme_is_wmm_supported(tHalHandle hHal);
437
438typedef void (*tSmeChangeCountryCallback)(void *pContext);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530439QDF_STATUS sme_change_country_code(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800440 tSmeChangeCountryCallback callback,
441 uint8_t *pCountry,
442 void *pContext,
443 void *p_cds_context,
444 tAniBool countryFromUserSpace,
445 tAniBool sendRegHint);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530446QDF_STATUS sme_generic_change_country_code(tHalHandle hHal,
Amar Singhal7f1f3ec2015-10-13 17:14:08 -0700447 uint8_t *pCountry);
Rajeev Kumar8e3e2832015-11-06 16:02:54 -0800448QDF_STATUS sme_tx_fail_monitor_start_stop_ind(tHalHandle hHal,
449 uint8_t tx_fail_count,
450 void *txFailIndCallback);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530451QDF_STATUS sme_dhcp_start_ind(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800452 uint8_t device_mode,
453 uint8_t *macAddr, uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530454QDF_STATUS sme_dhcp_stop_ind(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800455 uint8_t device_mode,
456 uint8_t *macAddr, uint8_t sessionId);
457void sme_set_cfg_privacy(tHalHandle hHal, tCsrRoamProfile *pProfile,
458 bool fPrivacy);
459void sme_get_recovery_stats(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530460QDF_STATUS sme_neighbor_report_request(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800461 tpRrmNeighborReq pRrmNeighborReq,
462 tpRrmNeighborRspCallbackInfo callbackInfo);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530463QDF_STATUS sme_get_wcnss_wlan_compiled_version(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800464 tSirVersionType * pVersion);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530465QDF_STATUS sme_get_wcnss_wlan_reported_version(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800466 tSirVersionType *pVersion);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530467QDF_STATUS sme_get_wcnss_software_version(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800468 uint8_t *pVersion, uint32_t versionBufferSize);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530469QDF_STATUS sme_get_wcnss_hardware_version(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800470 uint8_t *pVersion, uint32_t versionBufferSize);
471#ifdef FEATURE_WLAN_WAPI
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530472QDF_STATUS sme_scan_get_bkid_candidate_list(tHalHandle hHal, uint32_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800473 tBkidCandidateInfo * pBkidList,
474 uint32_t *pNumItems);
475#endif /* FEATURE_WLAN_WAPI */
476#ifdef FEATURE_OEM_DATA_SUPPORT
Krishna Kumaar Natarajanc1fa17d2016-08-03 14:19:20 -0700477QDF_STATUS sme_oem_data_req(tHalHandle hHal, struct oem_data_req *);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530478QDF_STATUS sme_oem_update_capability(tHalHandle hHal,
Krishna Kumaar Natarajan53ca2902015-12-04 14:01:46 -0800479 struct sme_oem_capability *cap);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530480QDF_STATUS sme_oem_get_capability(tHalHandle hHal,
Krishna Kumaar Natarajan53ca2902015-12-04 14:01:46 -0800481 struct sme_oem_capability *cap);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800482#endif /*FEATURE_OEM_DATA_SUPPORT */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530483QDF_STATUS sme_roam_update_apwpsie(tHalHandle, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800484 tSirAPWPSIEs * pAPWPSIES);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530485QDF_STATUS sme_roam_update_apwparsni_es(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800486 tSirRSNie *pAPSirRSNie);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530487QDF_STATUS sme_change_mcc_beacon_interval(tHalHandle hHal, uint8_t sessionId);
488QDF_STATUS sme_set_host_offload(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800489 tpSirHostOffloadReq pRequest);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530490QDF_STATUS sme_set_keep_alive(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800491 tpSirKeepAliveReq pRequest);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530492QDF_STATUS sme_get_operation_channel(tHalHandle hHal, uint32_t *pChannel,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800493 uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530494QDF_STATUS sme_register_mgmt_frame(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800495 uint16_t frameType, uint8_t *matchData,
496 uint16_t matchLen);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530497QDF_STATUS sme_deregister_mgmt_frame(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800498 uint16_t frameType, uint8_t *matchData,
499 uint16_t matchLen);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530500QDF_STATUS sme_ConfigureAppsCpuWakeupState(tHalHandle hHal, bool isAppsAwake);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800501#ifdef WLAN_FEATURE_EXTWOW_SUPPORT
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530502QDF_STATUS sme_configure_ext_wow(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800503 tpSirExtWoWParams wlanExtParams,
504 csr_readyToSuspendCallback callback,
505 void *callbackContext);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530506QDF_STATUS sme_configure_app_type1_params(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800507 tpSirAppType1Params wlanAppType1Params);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530508QDF_STATUS sme_configure_app_type2_params(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800509 tpSirAppType2Params wlanAppType2Params);
510#endif
511int8_t sme_get_infra_session_id(tHalHandle hHal);
512uint8_t sme_get_infra_operation_channel(tHalHandle hHal, uint8_t sessionId);
513uint8_t sme_get_concurrent_operation_channel(tHalHandle hHal);
514#ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
515uint16_t sme_check_concurrent_channel_overlap(tHalHandle hHal, uint16_t sap_ch,
516 eCsrPhyMode sapPhyMode,
517 uint8_t cc_switch_mode);
518#endif
yeshwanth sriram guntuka310b3ac2016-11-15 23:25:26 +0530519/**
520 * sme_abort_mac_scan() - API to cancel MAC scan
521 * @hHal: The handle returned by mac_open
522 * @sessionId: sessionId on which we need to abort scan
523 * @scan_id: scan id on which we need to abort scan
524 * @reason: Reason to abort the scan
525 *
526 * This function aborts MAC scan.
527 *
528 * Return: QDF_STATUS_E_FAILURE for failure, QDF_STATUS_SUCCESS for
529 * success
530 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530531QDF_STATUS sme_abort_mac_scan(tHalHandle hHal, uint8_t sessionId,
yeshwanth sriram guntuka310b3ac2016-11-15 23:25:26 +0530532 uint32_t scan_id, eCsrAbortReason reason);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530533QDF_STATUS sme_get_cfg_valid_channels(tHalHandle hHal, uint8_t *aValidChannels,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800534 uint32_t *len);
535#ifdef FEATURE_WLAN_SCAN_PNO
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530536QDF_STATUS sme_set_preferred_network_list(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800537 tpSirPNOScanReq pRequest,
538 uint8_t sessionId,
539 preferred_network_found_ind_cb
540 callbackRoutine, void *callbackContext);
541
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530542QDF_STATUS sme_preferred_network_found_ind(tHalHandle hHal, void *pMsg);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800543#endif /* FEATURE_WLAN_SCAN_PNO */
544#ifdef WLAN_FEATURE_PACKET_FILTERING
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530545QDF_STATUS sme_8023_multicast_list(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800546 tpSirRcvFltMcAddrList pMulticastAddrs);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530547QDF_STATUS sme_receive_filter_set_filter(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800548 tpSirRcvPktFilterCfgType pRcvPktFilterCfg,
549 uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530550QDF_STATUS sme_receive_filter_clear_filter(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800551 tpSirRcvFltPktClearParam pRcvFltPktClearParam,
552 uint8_t sessionId);
553#endif /* WLAN_FEATURE_PACKET_FILTERING */
554bool sme_is_channel_valid(tHalHandle hHal, uint8_t channel);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530555QDF_STATUS sme_set_freq_band(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800556 eCsrBand eBand);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530557QDF_STATUS sme_get_freq_band(tHalHandle hHal, eCsrBand *pBand);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800558uint16_t sme_chn_to_freq(uint8_t chanNum);
559bool sme_is_channel_valid(tHalHandle hHal, uint8_t channel);
Anurag Chouhan6d760662016-02-20 16:05:43 +0530560QDF_STATUS sme_set_max_tx_power(tHalHandle hHal, struct qdf_mac_addr pBssid,
561 struct qdf_mac_addr pSelfMacAddress, int8_t dB);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530562QDF_STATUS sme_set_max_tx_power_per_band(eCsrBand band, int8_t db);
563QDF_STATUS sme_set_tx_power(tHalHandle hHal, uint8_t sessionId,
Anurag Chouhan6d760662016-02-20 16:05:43 +0530564 struct qdf_mac_addr bssid,
565 enum tQDF_ADAPTER_MODE dev_mode, int power);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530566QDF_STATUS sme_set_custom_mac_addr(tSirMacAddr customMacAddr);
567QDF_STATUS sme_hide_ssid(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800568 uint8_t ssidHidden);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530569QDF_STATUS sme_set_tm_level(tHalHandle hHal, uint16_t newTMLevel,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800570 uint16_t tmMode);
571void sme_feature_caps_exchange(tHalHandle hHal);
572void sme_disable_feature_capablity(uint8_t feature_index);
573void sme_reset_power_values_for5_g(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530574QDF_STATUS sme_update_roam_prefer5_g_hz(tHalHandle hHal, bool nRoamPrefer5GHz);
575QDF_STATUS sme_set_roam_intra_band(tHalHandle hHal, const bool nRoamIntraBand);
576QDF_STATUS sme_update_roam_scan_n_probes(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800577 const uint8_t nProbes);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530578QDF_STATUS sme_update_roam_scan_home_away_time(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800579 uint8_t sessionId,
580 const uint16_t nRoamScanHomeAwayTime,
581 const bool bSendOffloadCmd);
582
583bool sme_get_roam_intra_band(tHalHandle hHal);
584uint8_t sme_get_roam_scan_n_probes(tHalHandle hHal);
585uint16_t sme_get_roam_scan_home_away_time(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530586QDF_STATUS sme_update_roam_rssi_diff(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800587 uint8_t RoamRssiDiff);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530588QDF_STATUS sme_update_fast_transition_enabled(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800589 bool isFastTransitionEnabled);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530590QDF_STATUS sme_update_wes_mode(tHalHandle hHal, bool isWESModeEnabled,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800591 uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530592QDF_STATUS sme_set_roam_scan_control(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800593 bool roamScanControl);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800594
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530595QDF_STATUS sme_update_is_fast_roam_ini_feature_enabled(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800596 uint8_t sessionId,
597 const bool
598 isFastRoamIniFeatureEnabled);
Mukul Sharma69c44cd2016-09-12 18:33:57 +0530599
600QDF_STATUS sme_config_fast_roaming(tHalHandle hal, uint8_t session_id,
601 const bool is_fast_roam_enabled);
602
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530603QDF_STATUS sme_update_is_mawc_ini_feature_enabled(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800604 const bool MAWCEnabled);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530605QDF_STATUS sme_stop_roaming(tHalHandle hHal, uint8_t sessionId, uint8_t reason);
606QDF_STATUS sme_start_roaming(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800607 uint8_t reason);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530608QDF_STATUS sme_update_enable_fast_roam_in_concurrency(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800609 bool bFastRoamInConIniFeatureEnabled);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800610#ifdef FEATURE_WLAN_ESE
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530611QDF_STATUS sme_update_is_ese_feature_enabled(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800612 const bool isEseIniFeatureEnabled);
613#endif /* FEATURE_WLAN_ESE */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530614QDF_STATUS sme_update_config_fw_rssi_monitoring(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800615 bool fEnableFwRssiMonitoring);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530616QDF_STATUS sme_set_roam_rescan_rssi_diff(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800617 uint8_t sessionId,
618 const uint8_t nRoamRescanRssiDiff);
619uint8_t sme_get_roam_rescan_rssi_diff(tHalHandle hHal);
620
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530621QDF_STATUS sme_set_roam_opportunistic_scan_threshold_diff(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800622 uint8_t sessionId,
623 const uint8_t nOpportunisticThresholdDiff);
624uint8_t sme_get_roam_opportunistic_scan_threshold_diff(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530625QDF_STATUS sme_set_neighbor_lookup_rssi_threshold(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800626 uint8_t sessionId, uint8_t neighborLookupRssiThreshold);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530627QDF_STATUS sme_set_delay_before_vdev_stop(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800628 uint8_t sessionId, uint8_t delay_before_vdev_stop);
629uint8_t sme_get_neighbor_lookup_rssi_threshold(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530630QDF_STATUS sme_set_neighbor_scan_refresh_period(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800631 uint8_t sessionId, uint16_t neighborScanResultsRefreshPeriod);
632uint16_t sme_get_neighbor_scan_refresh_period(tHalHandle hHal);
633uint16_t sme_get_empty_scan_refresh_period(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530634QDF_STATUS sme_update_empty_scan_refresh_period(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800635 uint8_t sessionId, uint16_t nEmptyScanRefreshPeriod);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530636QDF_STATUS sme_set_neighbor_scan_min_chan_time(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800637 const uint16_t nNeighborScanMinChanTime,
638 uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530639QDF_STATUS sme_set_neighbor_scan_max_chan_time(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800640 uint8_t sessionId, const uint16_t nNeighborScanMaxChanTime);
641uint16_t sme_get_neighbor_scan_min_chan_time(tHalHandle hHal,
642 uint8_t sessionId);
643uint32_t sme_get_neighbor_roam_state(tHalHandle hHal, uint8_t sessionId);
644uint32_t sme_get_current_roam_state(tHalHandle hHal, uint8_t sessionId);
645uint32_t sme_get_current_roam_sub_state(tHalHandle hHal, uint8_t sessionId);
646uint32_t sme_get_lim_sme_state(tHalHandle hHal);
647uint32_t sme_get_lim_mlm_state(tHalHandle hHal);
648bool sme_is_lim_session_valid(tHalHandle hHal, uint8_t sessionId);
649uint32_t sme_get_lim_sme_session_state(tHalHandle hHal, uint8_t sessionId);
650uint32_t sme_get_lim_mlm_session_state(tHalHandle hHal, uint8_t sessionId);
651uint16_t sme_get_neighbor_scan_max_chan_time(tHalHandle hHal,
652 uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530653QDF_STATUS sme_set_neighbor_scan_period(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800654 const uint16_t nNeighborScanPeriod);
655uint16_t sme_get_neighbor_scan_period(tHalHandle hHal, uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530656QDF_STATUS sme_set_roam_bmiss_first_bcnt(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800657 uint8_t sessionId, const uint8_t nRoamBmissFirstBcnt);
658uint8_t sme_get_roam_bmiss_first_bcnt(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530659QDF_STATUS sme_set_roam_bmiss_final_bcnt(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800660 const uint8_t nRoamBmissFinalBcnt);
661uint8_t sme_get_roam_bmiss_final_bcnt(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530662QDF_STATUS sme_set_roam_beacon_rssi_weight(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800663 const uint8_t nRoamBeaconRssiWeight);
664uint8_t sme_get_roam_beacon_rssi_weight(tHalHandle hHal);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800665uint8_t sme_get_roam_rssi_diff(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530666QDF_STATUS sme_change_roam_scan_channel_list(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800667 uint8_t *pChannelList,
668 uint8_t numChannels);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530669QDF_STATUS sme_set_ese_roam_scan_channel_list(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800670 uint8_t sessionId, uint8_t *pChannelList,
671 uint8_t numChannels);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530672QDF_STATUS sme_get_roam_scan_channel_list(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800673 uint8_t *pChannelList, uint8_t *pNumChannels,
674 uint8_t sessionId);
675bool sme_get_is_ese_feature_enabled(tHalHandle hHal);
676bool sme_get_wes_mode(tHalHandle hHal);
677bool sme_get_roam_scan_control(tHalHandle hHal);
678bool sme_get_is_lfr_feature_enabled(tHalHandle hHal);
679bool sme_get_is_ft_feature_enabled(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530680QDF_STATUS sme_update_roam_scan_offload_enabled(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800681 bool nRoamScanOffloadEnabled);
Krishna Kumaar Natarajand0bbb3c2017-03-13 17:04:58 -0700682bool sme_is_feature_supported_by_fw(enum cap_bitmap feature);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800683#ifdef FEATURE_WLAN_TDLS
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530684QDF_STATUS sme_send_tdls_link_establish_params(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800685 uint8_t sessionId,
686 const tSirMacAddr peerMac,
687 tCsrTdlsLinkEstablishParams *
688 tdlsLinkEstablishParams);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530689QDF_STATUS sme_send_tdls_mgmt_frame(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800690 const tSirMacAddr peerMac, uint8_t frame_type,
691 uint8_t dialog, uint16_t status,
692 uint32_t peerCapability, uint8_t *buf,
693 uint8_t len, uint8_t responder);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530694QDF_STATUS sme_change_tdls_peer_sta(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800695 const tSirMacAddr peerMac,
696 tCsrStaParams *pstaParams);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530697QDF_STATUS sme_add_tdls_peer_sta(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800698 const tSirMacAddr peerMac);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530699QDF_STATUS sme_delete_tdls_peer_sta(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800700 const tSirMacAddr peerMac);
701void sme_set_tdls_power_save_prohibited(tHalHandle hHal, uint32_t sessionId,
702 bool val);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530703QDF_STATUS sme_send_tdls_chan_switch_req(
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800704 tHalHandle hal,
705 sme_tdls_chan_switch_params *ch_switch_params);
706#endif
707
708/*
709 * SME API to enable/disable WLAN driver initiated SSR
710 */
711void sme_update_enable_ssr(tHalHandle hHal, bool enableSSR);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530712QDF_STATUS sme_set_phy_mode(tHalHandle hHal, eCsrPhyMode phyMode);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800713eCsrPhyMode sme_get_phy_mode(tHalHandle hHal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530714QDF_STATUS sme_handoff_request(tHalHandle hHal, uint8_t sessionId,
Amar Singhale4f28ee2015-10-21 14:36:56 -0700715 tCsrHandoffRequest *pHandoffInfo);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530716QDF_STATUS sme_is_sta_p2p_client_connected(tHalHandle hHal);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800717#ifdef FEATURE_WLAN_LPHB
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530718QDF_STATUS sme_lphb_config_req(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800719 tSirLPHBReq * lphdReq,
720 void (*pCallbackfn)(void *pHddCtx,
721 tSirLPHBInd * indParam));
722#endif /* FEATURE_WLAN_LPHB */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530723QDF_STATUS sme_add_periodic_tx_ptrn(tHalHandle hHal, tSirAddPeriodicTxPtrn
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800724 *addPeriodicTxPtrnParams);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530725QDF_STATUS sme_del_periodic_tx_ptrn(tHalHandle hHal, tSirDelPeriodicTxPtrn
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800726 *delPeriodicTxPtrnParams);
727void sme_enable_disable_split_scan(tHalHandle hHal, uint8_t nNumStaChan,
728 uint8_t nNumP2PChan);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530729QDF_STATUS sme_send_rate_update_ind(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800730 tSirRateUpdateInd *rateUpdateParams);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530731QDF_STATUS sme_roam_del_pmkid_from_cache(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800732 const uint8_t *pBSSId, bool flush_cache);
733void sme_get_command_q_status(tHalHandle hHal);
734
Rajeev Kumar8e3e2832015-11-06 16:02:54 -0800735QDF_STATUS sme_enable_rmc(tHalHandle hHal, uint32_t sessionId);
736QDF_STATUS sme_disable_rmc(tHalHandle hHal, uint32_t sessionId);
737QDF_STATUS sme_send_rmc_action_period(tHalHandle hHal, uint32_t sessionId);
738QDF_STATUS sme_request_ibss_peer_info(tHalHandle hHal, void *pUserData,
739 pIbssPeerInfoCb peerInfoCbk, bool allPeerInfoReqd, uint8_t staIdx);
740QDF_STATUS sme_send_cesium_enable_ind(tHalHandle hHal, uint32_t sessionId);
741
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800742/*
743 * SME API to enable/disable idle mode powersave
744 * This should be called only if powersave offload
745 * is enabled
746 */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530747QDF_STATUS sme_set_idle_powersave_config(void *cds_context,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800748 tHalHandle hHal, uint32_t value);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530749QDF_STATUS sme_notify_modem_power_state(tHalHandle hHal, uint32_t value);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800750
751/*SME API to convert convert the ini value to the ENUM used in csr and MAC*/
752ePhyChanBondState sme_get_cb_phy_state_from_cb_ini_value(uint32_t cb_ini_value);
753int sme_update_ht_config(tHalHandle hHal, uint8_t sessionId, uint16_t htCapab,
754 int value);
755int16_t sme_get_ht_config(tHalHandle hHal, uint8_t session_id,
756 uint16_t ht_capab);
757#ifdef QCA_HT_2040_COEX
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530758QDF_STATUS sme_notify_ht2040_mode(tHalHandle hHal, uint16_t staId,
Anurag Chouhan6d760662016-02-20 16:05:43 +0530759 struct qdf_mac_addr macAddrSTA,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800760 uint8_t sessionId,
761 uint8_t channel_type);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530762QDF_STATUS sme_set_ht2040_mode(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800763 uint8_t channel_type, bool obssEnabled);
764#endif
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530765QDF_STATUS sme_get_reg_info(tHalHandle hHal, uint8_t chanId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800766 uint32_t *regInfo1, uint32_t *regInfo2);
767#ifdef FEATURE_WLAN_TDLS
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530768QDF_STATUS sme_update_fw_tdls_state(tHalHandle hHal, void *psmeTdlsParams,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800769 bool useSmeLock);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530770QDF_STATUS sme_update_tdls_peer_state(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800771 tSmeTdlsPeerStateParams *pPeerStateParams);
772#endif /* FEATURE_WLAN_TDLS */
773#ifdef FEATURE_WLAN_CH_AVOID
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530774QDF_STATUS sme_add_ch_avoid_callback(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800775 void (*pCallbackfn)(void *hdd_context, void *indi_param));
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530776QDF_STATUS sme_ch_avoid_update_req(tHalHandle hHal);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800777#else
778static inline
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530779QDF_STATUS sme_add_ch_avoid_callback(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800780 void (*pCallbackfn)(void *hdd_context, void *indi_param))
781{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530782 return QDF_STATUS_E_NOSUPPORT;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800783}
784
785static inline
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530786QDF_STATUS sme_ch_avoid_update_req(tHalHandle hHal)
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800787{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530788 return QDF_STATUS_E_NOSUPPORT;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800789}
790#endif /* FEATURE_WLAN_CH_AVOID */
791#ifdef FEATURE_WLAN_AUTO_SHUTDOWN
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530792QDF_STATUS sme_set_auto_shutdown_cb(tHalHandle hHal, void (*pCallbackfn)(void));
793QDF_STATUS sme_set_auto_shutdown_timer(tHalHandle hHal, uint32_t timer_value);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800794#endif
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530795QDF_STATUS sme_roam_channel_change_req(tHalHandle hHal,
Amar Singhale4f28ee2015-10-21 14:36:56 -0700796 struct qdf_mac_addr bssid,
797 struct ch_params_s *ch_params,
798 tCsrRoamProfile *profile);
799
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530800QDF_STATUS sme_roam_start_beacon_req(tHalHandle hHal,
Anurag Chouhan6d760662016-02-20 16:05:43 +0530801 struct qdf_mac_addr bssid, uint8_t dfsCacWaitStatus);
802QDF_STATUS sme_roam_csa_ie_request(tHalHandle hHal, struct qdf_mac_addr bssid,
Amar Singhale4f28ee2015-10-21 14:36:56 -0700803 uint8_t targetChannel, uint8_t csaIeReqd,
804 struct ch_params_s *ch_params);
805
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530806QDF_STATUS sme_init_thermal_info(tHalHandle hHal,
Amar Singhale4f28ee2015-10-21 14:36:56 -0700807 tSmeThermalParams thermalParam);
808
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530809QDF_STATUS sme_set_thermal_level(tHalHandle hHal, uint8_t level);
810QDF_STATUS sme_txpower_limit(tHalHandle hHal, tSirTxPowerLimit *psmetx);
811QDF_STATUS sme_get_link_speed(tHalHandle hHal, tSirLinkSpeedInfo *lsReq,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800812 void *plsContext,
813 void (*pCallbackfn)(tSirLinkSpeedInfo *indParam,
814 void *pContext));
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530815QDF_STATUS sme_modify_add_ie(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800816 tSirModifyIE *pModifyIE, eUpdateIEsType updateType);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530817QDF_STATUS sme_update_add_ie(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800818 tSirUpdateIE *pUpdateIE, eUpdateIEsType updateType);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530819QDF_STATUS sme_update_connect_debug(tHalHandle hHal, uint32_t set_value);
Sreelakshmi Konamki39acb132015-12-16 13:06:22 +0530820const char *sme_request_type_to_string(const uint8_t request_type);
Rajeev Kumar43e25b12016-04-15 16:26:36 -0700821const char *sme_scan_type_to_string(const uint8_t scan_type);
822const char *sme_bss_type_to_string(const uint8_t bss_type);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530823QDF_STATUS sme_ap_disable_intra_bss_fwd(tHalHandle hHal, uint8_t sessionId,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800824 bool disablefwd);
825uint32_t sme_get_channel_bonding_mode5_g(tHalHandle hHal);
826uint32_t sme_get_channel_bonding_mode24_g(tHalHandle hHal);
827#ifdef WLAN_FEATURE_STATS_EXT
828typedef struct sStatsExtRequestReq {
829 uint32_t request_data_len;
830 uint8_t *request_data;
831} tStatsExtRequestReq, *tpStatsExtRequestReq;
832typedef void (*StatsExtCallback)(void *, tStatsExtEvent *);
833void sme_stats_ext_register_callback(tHalHandle hHal,
834 StatsExtCallback callback);
Arun Khandavalli4b55da72016-07-19 19:55:01 +0530835void sme_stats_ext_deregister_callback(tHalHandle hhal);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530836QDF_STATUS sme_stats_ext_request(uint8_t session_id,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800837 tpStatsExtRequestReq input);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530838QDF_STATUS sme_stats_ext_event(tHalHandle hHal, void *pMsg);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800839#endif
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530840QDF_STATUS sme_update_dfs_scan_mode(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800841 uint8_t sessionId,
842 uint8_t allowDFSChannelRoam);
843uint8_t sme_get_dfs_scan_mode(tHalHandle hHal);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800844
845#ifdef FEATURE_WLAN_EXTSCAN
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530846QDF_STATUS sme_get_valid_channels_by_band(tHalHandle hHal, uint8_t wifiBand,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800847 uint32_t *aValidChannels,
848 uint8_t *pNumChannels);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530849QDF_STATUS sme_ext_scan_get_capabilities(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800850 tSirGetExtScanCapabilitiesReqParams *pReq);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530851QDF_STATUS sme_ext_scan_start(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800852 tSirWifiScanCmdReqParams *pStartCmd);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530853QDF_STATUS sme_ext_scan_stop(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800854 tSirExtScanStopReqParams *pStopReq);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530855QDF_STATUS sme_set_bss_hotlist(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800856 tSirExtScanSetBssidHotListReqParams *
857 pSetHotListReq);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530858QDF_STATUS sme_reset_bss_hotlist(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800859 tSirExtScanResetBssidHotlistReqParams *
860 pResetReq);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530861QDF_STATUS sme_set_significant_change(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800862 tSirExtScanSetSigChangeReqParams *
863 pSetSignificantChangeReq);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530864QDF_STATUS sme_reset_significant_change(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800865 tSirExtScanResetSignificantChangeReqParams
866 *pResetReq);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530867QDF_STATUS sme_get_cached_results(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800868 tSirExtScanGetCachedResultsReqParams *
869 pCachedResultsReq);
870
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530871QDF_STATUS sme_set_epno_list(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800872 struct wifi_epno_params *req_msg);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530873QDF_STATUS sme_set_passpoint_list(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800874 struct wifi_passpoint_req *req_msg);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530875QDF_STATUS sme_reset_passpoint_list(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800876 struct wifi_passpoint_req *req_msg);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530877QDF_STATUS
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800878sme_set_ssid_hotlist(tHalHandle hal,
879 struct sir_set_ssid_hotlist_request *request);
880
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530881QDF_STATUS sme_ext_scan_register_callback(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800882 void (*pExtScanIndCb)(void *, const uint16_t, void *));
Prashanth Bhatta75fa9a12016-01-11 18:30:08 -0800883#else
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530884static inline QDF_STATUS sme_ext_scan_register_callback(tHalHandle hHal,
Prashanth Bhatta75fa9a12016-01-11 18:30:08 -0800885 void (*pExtScanIndCb)(void *, const uint16_t, void *))
886{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530887 return QDF_STATUS_SUCCESS;
Prashanth Bhatta75fa9a12016-01-11 18:30:08 -0800888}
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800889#endif /* FEATURE_WLAN_EXTSCAN */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530890QDF_STATUS sme_abort_roam_scan(tHalHandle hHal, uint8_t sessionId);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800891#ifdef WLAN_FEATURE_LINK_LAYER_STATS
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530892QDF_STATUS sme_ll_stats_clear_req(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800893 tSirLLStatsClearReq * pclearStatsReq);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530894QDF_STATUS sme_ll_stats_set_req(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800895 tSirLLStatsSetReq *psetStatsReq);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530896QDF_STATUS sme_ll_stats_get_req(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800897 tSirLLStatsGetReq *pgetStatsReq);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530898QDF_STATUS sme_set_link_layer_stats_ind_cb(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800899 void (*callbackRoutine)(void *callbackCtx,
900 int indType, void *pRsp));
Arun Khandavalli4b55da72016-07-19 19:55:01 +0530901QDF_STATUS sme_reset_link_layer_stats_ind_cb(tHalHandle hhal);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800902#endif /* WLAN_FEATURE_LINK_LAYER_STATS */
903
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530904QDF_STATUS sme_fw_mem_dump(tHalHandle hHal, void *recvd_req);
905QDF_STATUS sme_fw_mem_dump_register_cb(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800906 void (*callback_routine)(void *cb_context,
907 struct fw_dump_rsp *rsp));
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530908QDF_STATUS sme_fw_mem_dump_unregister_cb(tHalHandle hHal);
Manikandan Mohan80dea792016-04-28 16:36:48 -0700909QDF_STATUS sme_set_wisa_params(tHalHandle hal,
910 struct sir_wisa_params *wisa_params);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800911#ifdef WLAN_FEATURE_ROAM_OFFLOAD
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530912QDF_STATUS sme_update_roam_offload_enabled(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800913 bool nRoamOffloadEnabled);
Deepak Dhamdheref2a7d8b2016-08-19 16:17:38 -0700914QDF_STATUS sme_update_roam_key_mgmt_offload_enabled(tHalHandle hal_ctx,
915 uint8_t session_id,
916 bool key_mgmt_offload_enabled,
917 bool okc_enabled);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800918#endif
919#ifdef WLAN_FEATURE_NAN
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530920QDF_STATUS sme_nan_event(tHalHandle hHal, void *pMsg);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800921#endif /* WLAN_FEATURE_NAN */
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530922QDF_STATUS sme_get_link_status(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800923 tCsrLinkStatusCallback callback,
924 void *pContext, uint8_t sessionId);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530925QDF_STATUS sme_get_temperature(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800926 void *tempContext,
927 void (*pCallbackfn)(int temperature,
928 void *pContext));
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530929QDF_STATUS sme_set_scanning_mac_oui(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800930 tSirScanMacOui *pScanMacOui);
931
932#ifdef IPA_OFFLOAD
933/* ---------------------------------------------------------------------------
934 \fn sme_ipa_offload_enable_disable
935 \brief API to enable/disable IPA offload
936 \param hHal - The handle returned by macOpen.
937 \param sessionId - Session Identifier
938 \param pRequest - Pointer to the offload request.
Deepak Dhamdhere0f076bd2016-06-02 11:29:21 -0700939 \return QDF_STATUS
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800940 ---------------------------------------------------------------------------*/
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530941QDF_STATUS sme_ipa_offload_enable_disable(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800942 uint8_t session_id,
943 struct sir_ipa_offload_enable_disable *request);
944#else
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530945static inline QDF_STATUS sme_ipa_offload_enable_disable(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800946 uint8_t session_id,
947 struct sir_ipa_offload_enable_disable *request)
948{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530949 return QDF_STATUS_SUCCESS;
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800950}
951#endif /* IPA_OFFLOAD */
952
953#ifdef DHCP_SERVER_OFFLOAD
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530954QDF_STATUS sme_set_dhcp_srv_offload(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800955 tSirDhcpSrvOffloadInfo * pDhcpSrvInfo);
956#endif /* DHCP_SERVER_OFFLOAD */
957#ifdef WLAN_FEATURE_GPIO_LED_FLASHING
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530958QDF_STATUS sme_set_led_flashing(tHalHandle hHal, uint8_t type,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800959 uint32_t x0, uint32_t x1);
960#endif
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530961QDF_STATUS sme_handle_dfs_chan_scan(tHalHandle hHal, uint8_t dfs_flag);
962QDF_STATUS sme_set_mas(uint32_t val);
963QDF_STATUS sme_set_miracast(tHalHandle hal, uint8_t filter_type);
964QDF_STATUS sme_ext_change_channel(tHalHandle hHal, uint32_t channel,
Abhishek Singh518323d2015-10-19 17:42:01 +0530965 uint8_t session_id);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800966
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530967QDF_STATUS sme_configure_modulated_dtim(tHalHandle hal, uint8_t session_id,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800968 uint32_t modulated_dtim);
969
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530970QDF_STATUS sme_configure_stats_avg_factor(tHalHandle hal, uint8_t session_id,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800971 uint16_t stats_avg_factor);
972
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530973QDF_STATUS sme_configure_guard_time(tHalHandle hal, uint8_t session_id,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800974 uint32_t guard_time);
975
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530976QDF_STATUS sme_wifi_start_logger(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800977 struct sir_wifi_start_log start_log);
978
979bool sme_neighbor_middle_of_roaming(tHalHandle hHal,
980 uint8_t sessionId);
981
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530982QDF_STATUS sme_enable_uapsd_for_ac(void *cds_ctx, uint8_t sta_id,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800983 sme_ac_enum_type ac, uint8_t tid,
984 uint8_t pri, uint32_t srvc_int,
985 uint32_t sus_int,
986 sme_tspec_dir_type dir,
987 uint8_t psb, uint32_t sessionId,
988 uint32_t delay_interval);
989
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530990QDF_STATUS sme_disable_uapsd_for_ac(void *cds_ctx, uint8_t sta_id,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800991 sme_ac_enum_type ac,
992 uint32_t sessionId);
993
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530994QDF_STATUS sme_set_rssi_monitoring(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800995 struct rssi_monitor_req *input);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +0530996QDF_STATUS sme_set_rssi_threshold_breached_cb(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800997 void (*cb)(void *, struct rssi_breach_event *));
Arun Khandavalli4b55da72016-07-19 19:55:01 +0530998QDF_STATUS sme_reset_rssi_threshold_breached_cb(tHalHandle hal);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -0800999
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301000QDF_STATUS sme_register_mgmt_frame_ind_callback(tHalHandle hal,
Abhishek Singh7996eb72015-12-30 17:24:02 +05301001 sir_mgmt_frame_ind_callback callback);
1002
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301003QDF_STATUS sme_update_nss(tHalHandle h_hal, uint8_t nss);
Archana Ramachandran5041b252016-04-25 14:29:25 -07001004void sme_update_user_configured_nss(tHalHandle hal, uint8_t nss);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001005
1006bool sme_is_any_session_in_connected_state(tHalHandle h_hal);
1007
Manishekar Chandrasekaran7009f252016-04-21 19:14:15 +05301008QDF_STATUS sme_pdev_set_pcl(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001009 struct sir_pcl_list msg);
Manishekar Chandrasekarand9640342016-04-27 12:28:26 +05301010QDF_STATUS sme_pdev_set_hw_mode(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001011 struct sir_hw_mode msg);
1012void sme_register_hw_mode_trans_cb(tHalHandle hal,
1013 hw_mode_transition_cb callback);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301014QDF_STATUS sme_nss_update_request(tHalHandle hHal, uint32_t vdev_id,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001015 uint8_t new_nss, void *cback,
Chandrasekaran, Manishekarce2172e2016-02-18 16:12:43 +05301016 uint8_t next_action, void *hdd_context,
1017 enum sir_conn_update_reason reason);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001018
1019typedef void (*sme_peer_authorized_fp) (uint32_t vdev_id);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301020QDF_STATUS sme_set_peer_authorized(uint8_t *peer_addr,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001021 sme_peer_authorized_fp auth_fp,
1022 uint32_t vdev_id);
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301023QDF_STATUS sme_soc_set_dual_mac_config(tHalHandle hal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001024 struct sir_dual_mac_config msg);
Archana Ramachandrand41c3ed2016-02-10 15:48:06 -08001025QDF_STATUS sme_soc_set_antenna_mode(tHalHandle hal,
1026 struct sir_antenna_mode_param *msg);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001027
1028void sme_set_scan_disable(tHalHandle h_hal, int value);
1029void sme_setdef_dot11mode(tHalHandle hal);
1030
Amar Singhal7c1e8982016-05-19 15:08:09 -07001031QDF_STATUS sme_handle_set_fcc_channel(tHalHandle hHal,
Amar Singhal83a047a2016-05-19 15:56:11 -07001032 bool fcc_constraint,
1033 bool scan_pending);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001034
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301035QDF_STATUS sme_update_roam_scan_hi_rssi_scan_params(tHalHandle hal_handle,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001036 uint8_t session_id,
1037 uint32_t notify_id,
1038 int32_t val);
1039
1040void wlan_sap_enable_phy_error_logs(tHalHandle hal, bool enable_log);
Agrawal Ashishb141b092016-09-02 19:59:26 +05301041#ifdef WLAN_FEATURE_DSRC
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001042void sme_set_dot11p_config(tHalHandle hal, bool enable_dot11p);
1043
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301044QDF_STATUS sme_ocb_set_config(tHalHandle hHal, void *context,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001045 ocb_callback callback,
1046 struct sir_ocb_config *config);
1047
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301048QDF_STATUS sme_ocb_set_utc_time(tHalHandle hHal, struct sir_ocb_utc *utc);
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001049
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301050QDF_STATUS sme_ocb_start_timing_advert(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001051 struct sir_ocb_timing_advert *timing_advert);
1052
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301053QDF_STATUS sme_ocb_stop_timing_advert(tHalHandle hHal,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001054 struct sir_ocb_timing_advert *timing_advert);
1055
Naveen Rawatb4d37622015-11-13 16:15:25 -08001056int sme_ocb_gen_timing_advert_frame(tHalHandle hHal, tSirMacAddr self_addr,
1057 uint8_t **buf, uint32_t *timestamp_offset,
1058 uint32_t *time_value_offset);
1059
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301060QDF_STATUS sme_ocb_get_tsf_timer(tHalHandle hHal, void *context,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001061 ocb_callback callback,
1062 struct sir_ocb_get_tsf_timer *request);
1063
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301064QDF_STATUS sme_dcc_get_stats(tHalHandle hHal, void *context,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001065 ocb_callback callback,
1066 struct sir_dcc_get_stats *request);
1067
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301068QDF_STATUS sme_dcc_clear_stats(tHalHandle hHal, uint32_t vdev_id,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001069 uint32_t dcc_stats_bitmap);
1070
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301071QDF_STATUS sme_dcc_update_ndl(tHalHandle hHal, void *context,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001072 ocb_callback callback,
1073 struct sir_dcc_update_ndl *request);
1074
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301075QDF_STATUS sme_register_for_dcc_stats_event(tHalHandle hHal, void *context,
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001076 ocb_callback callback);
Arun Khandavalli4b55da72016-07-19 19:55:01 +05301077QDF_STATUS sme_deregister_for_dcc_stats_event(tHalHandle hHal);
1078
Agrawal Ashishb141b092016-09-02 19:59:26 +05301079#else
1080static inline void sme_set_dot11p_config(tHalHandle hal, bool enable_dot11p)
1081{
1082 return;
1083}
1084
1085static inline QDF_STATUS sme_ocb_set_config(tHalHandle hHal, void *context,
1086 ocb_callback callback,
1087 struct sir_ocb_config *config)
1088{
1089 return QDF_STATUS_SUCCESS;
1090}
1091
1092static inline QDF_STATUS sme_ocb_set_utc_time(struct sir_ocb_utc *utc)
1093{
1094 return QDF_STATUS_SUCCESS;
1095}
1096
1097static inline QDF_STATUS sme_ocb_start_timing_advert(
1098 struct sir_ocb_timing_advert *timing_advert)
1099{
1100 return QDF_STATUS_SUCCESS;
1101}
1102
1103static inline QDF_STATUS sme_ocb_stop_timing_advert(struct sir_ocb_timing_advert
1104 *timing_advert)
1105{
1106 return QDF_STATUS_SUCCESS;
1107}
1108
1109static inline int sme_ocb_gen_timing_advert_frame(tHalHandle hHal,
1110 tSirMacAddr self_addr, uint8_t **buf,
1111 uint32_t *timestamp_offset,
1112 uint32_t *time_value_offset)
1113{
1114 return 0;
1115}
1116
1117static inline QDF_STATUS sme_ocb_get_tsf_timer(tHalHandle hHal, void *context,
1118 ocb_callback callback,
1119 struct sir_ocb_get_tsf_timer *request)
1120{
1121 return QDF_STATUS_SUCCESS;
1122}
1123
1124static inline QDF_STATUS sme_dcc_get_stats(tHalHandle hHal, void *context,
1125 ocb_callback callback,
1126 struct sir_dcc_get_stats *request)
1127{
1128 return QDF_STATUS_SUCCESS;
1129}
1130
1131static inline QDF_STATUS sme_dcc_clear_stats(uint32_t vdev_id,
1132 uint32_t dcc_stats_bitmap)
1133{
1134 return QDF_STATUS_SUCCESS;
1135}
1136
1137static inline QDF_STATUS sme_dcc_update_ndl(tHalHandle hHal, void *context,
1138 ocb_callback callback,
1139 struct sir_dcc_update_ndl *request)
1140{
1141 return QDF_STATUS_SUCCESS;
1142}
1143
1144static inline QDF_STATUS sme_register_for_dcc_stats_event(tHalHandle hHal,
1145 void *context, ocb_callback callback)
1146{
1147 return QDF_STATUS_SUCCESS;
1148}
1149static inline QDF_STATUS sme_deregister_for_dcc_stats_event(tHalHandle hHal)
1150{
1151 return QDF_STATUS_SUCCESS;
1152}
1153#endif
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001154void sme_add_set_thermal_level_callback(tHalHandle hal,
1155 sme_set_thermal_level_callback callback);
1156
Krishna Kumaar Natarajan052c6e62015-09-28 15:32:55 -07001157void sme_update_tgt_services(tHalHandle hal, struct wma_tgt_services *cfg);
Edhar, Mahesh Kumardf2ec122015-11-16 11:33:16 +05301158bool sme_validate_sap_channel_switch(tHalHandle hal,
1159 uint16_t sap_ch, eCsrPhyMode sap_phy_mode,
1160 uint8_t cc_switch_mode, uint8_t session_id);
Masti, Narayanraddic4a7ab82015-11-25 15:41:10 +05301161
Chandrasekaran, Manishekar2859de42016-02-11 16:17:38 +05301162bool sme_is_session_id_valid(tHalHandle hal, uint32_t session_id);
1163
Masti, Narayanraddic4a7ab82015-11-25 15:41:10 +05301164#ifdef FEATURE_WLAN_TDLS
1165void sme_get_opclass(tHalHandle hal, uint8_t channel, uint8_t bw_offset,
1166 uint8_t *opclass);
1167#else
1168static inline void
1169sme_get_opclass(tHalHandle hal, uint8_t channel, uint8_t bw_offset,
1170 uint8_t *opclass)
1171{
1172}
1173#endif
1174
Ravi Joshi61c3c7a2015-11-09 18:41:20 -08001175#ifdef FEATURE_LFR_SUBNET_DETECTION
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301176QDF_STATUS sme_gateway_param_update(tHalHandle hHal,
Ravi Joshi61c3c7a2015-11-09 18:41:20 -08001177 struct gateway_param_update_req *request);
1178#endif
1179
Ryan Hsu3c8f79f2015-12-02 16:45:09 -08001180#ifdef FEATURE_GREEN_AP
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301181QDF_STATUS sme_send_egap_conf_params(uint32_t enable,
Ryan Hsu3c8f79f2015-12-02 16:45:09 -08001182 uint32_t inactivity_time,
1183 uint32_t wait_time,
1184 uint32_t flags);
1185#else
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301186static inline QDF_STATUS sme_send_egap_conf_params(uint32_t enable,
Ryan Hsu3c8f79f2015-12-02 16:45:09 -08001187 uint32_t inactivity_time,
1188 uint32_t wait_time,
1189 uint32_t flags)
1190{
Anurag Chouhanfb54ab02016-02-18 18:00:46 +05301191 return QDF_STATUS_E_NOSUPPORT;
Ryan Hsu3c8f79f2015-12-02 16:45:09 -08001192}
1193#endif
Krunal Sonie3531942016-04-12 17:43:53 -07001194
Selvaraj, Sridhar57bb4d02016-08-31 16:14:15 +05301195void sme_update_fine_time_measurement_capab(tHalHandle hal, uint8_t session_id,
1196 uint32_t val);
Sandeep Puligillae0875662016-02-12 16:09:21 -08001197QDF_STATUS sme_ht40_stop_obss_scan(tHalHandle hHal, uint32_t vdev_id);
Anurag Chouhanbf5e0e22016-09-12 12:54:09 +05301198QDF_STATUS sme_set_fw_test(struct set_fwtest_params *fw_test);
Manikandan Mohandcc21ba2016-03-15 14:31:56 -07001199QDF_STATUS sme_set_tsfcb(tHalHandle hHal,
1200 int (*cb_fn)(void *cb_ctx, struct stsf *ptsf), void *cb_ctx);
Krunal Sonie3531942016-04-12 17:43:53 -07001201
Arun Khandavalli4b55da72016-07-19 19:55:01 +05301202QDF_STATUS sme_reset_tsfcb(tHalHandle h_hal);
1203
Manikandan Mohan976e7562016-03-15 16:33:31 -07001204#ifdef WLAN_FEATURE_TSF
1205QDF_STATUS sme_set_tsf_gpio(tHalHandle h_hal, uint32_t pinvalue);
Arun Khandavalli4b55da72016-07-19 19:55:01 +05301206QDF_STATUS sme_reset_tsf_gpio(tHalHandle h_hal);
1207
Manikandan Mohan976e7562016-03-15 16:33:31 -07001208#else
1209static inline QDF_STATUS sme_set_tsf_gpio(tHalHandle h_hal, uint32_t pinvalue)
1210{
1211 return QDF_STATUS_E_FAILURE;
1212}
Arun Khandavalli4b55da72016-07-19 19:55:01 +05301213static inline QDF_STATUS sme_reset_tsf_gpio(tHalHandle h_hal)
1214{
1215 return QDF_STATUS_E_FAILURE;
1216}
1217
Manikandan Mohan976e7562016-03-15 16:33:31 -07001218#endif
1219
Archana Ramachandran20d2e232016-02-11 16:58:40 -08001220QDF_STATUS sme_update_mimo_power_save(tHalHandle hHal,
1221 uint8_t is_ht_smps_enabled,
Archana Ramachandranfec24812016-02-16 16:31:56 -08001222 uint8_t ht_smps_mode,
1223 bool send_smps_action);
Archana Ramachandran20d2e232016-02-11 16:58:40 -08001224
1225bool sme_is_sta_smps_allowed(tHalHandle hHal, uint8_t session_id);
Gupta, Kapil4cb1d7d2016-04-16 18:16:25 -07001226QDF_STATUS sme_add_beacon_filter(tHalHandle hal,
1227 uint32_t session_id, uint32_t *ie_map);
1228QDF_STATUS sme_remove_beacon_filter(tHalHandle hal, uint32_t session_id);
Arun Khandavalli2476ef52016-04-26 20:19:43 +05301229
Jeff Johnsona867e0c2017-01-26 13:43:51 -08001230/**
1231 * sme_get_bpf_offload_capabilities() - Get BPF offload capabilities
1232 * @hal: Global HAL handle
1233 * @callback: Callback function to be called with the result
1234 * @context: Opaque context to be used by the caller to associate the
1235 * request with the response
1236 *
1237 * This function constructs the cds message and fill in message type,
1238 * post the same to WDA.
1239 *
1240 * Return: QDF_STATUS enumeration
1241 */
1242QDF_STATUS sme_get_bpf_offload_capabilities(tHalHandle hal,
1243 bpf_get_offload_cb callback,
1244 void *context);
1245
Arun Khandavalli2476ef52016-04-26 20:19:43 +05301246QDF_STATUS sme_set_bpf_instructions(tHalHandle hal,
1247 struct sir_bpf_set_offload *);
Abhishek Singh1c676222016-05-09 14:20:28 +05301248uint32_t sme_get_wni_dot11_mode(tHalHandle hal);
Manjunathappa Prakash59f861d2016-04-21 10:33:31 -07001249QDF_STATUS sme_create_mon_session(tHalHandle hal_handle, uint8_t *bssid);
Gupta, Kapil96c7f2f2016-04-25 19:13:41 +05301250QDF_STATUS sme_set_adaptive_dwelltime_config(tHalHandle hal,
1251 struct adaptive_dwelltime_params *dwelltime_params);
Naveen Rawata410c5a2016-09-19 14:22:33 -07001252
1253void sme_set_vdev_ies_per_band(tHalHandle hal, uint8_t vdev_id);
Kiran Kumar Lokere666bf852016-05-02 12:23:02 -07001254void sme_set_pdev_ht_vht_ies(tHalHandle hHal, bool enable2x2);
1255
1256void sme_update_vdev_type_nss(tHalHandle hal, uint8_t max_supp_nss,
1257 uint32_t vdev_type_nss, eCsrBand band);
Peng Xu8fdaa492016-06-22 10:20:47 -07001258void sme_register_p2p_lo_event(tHalHandle hHal, void *context,
1259 p2p_lo_callback callback);
Manjeet Singhf82ed072016-07-08 11:40:00 +05301260
Abhishek Singhc9941602016-08-09 16:06:22 +05301261QDF_STATUS sme_remove_bssid_from_scan_list(tHalHandle hal,
1262 tSirMacAddr bssid);
1263
Manjeet Singhf82ed072016-07-08 11:40:00 +05301264QDF_STATUS sme_process_mac_pwr_dbg_cmd(tHalHandle hal, uint32_t session_id,
1265 struct sir_mac_pwr_dbg_cmd*
1266 dbg_args);
1267
Tushnim Bhattacharyyaf44a9d82016-07-05 10:52:06 -07001268void sme_get_vdev_type_nss(tHalHandle hal, enum tQDF_ADAPTER_MODE dev_mode,
1269 uint8_t *nss_2g, uint8_t *nss_5g);
Masti, Narayanraddiab712a72016-08-04 11:59:11 +05301270QDF_STATUS sme_roam_set_default_key_index(tHalHandle hal, uint8_t session_id,
1271 uint8_t default_idx);
Selvaraj, Sridhar4577a9b2016-09-04 15:17:07 +05301272QDF_STATUS sme_register_p2p_ack_ind_callback(tHalHandle hal,
1273 sir_p2p_ack_ind_callback callback);
Kondabattini, Ganesh3f2d02c2016-09-13 12:23:47 +05301274void sme_send_disassoc_req_frame(tHalHandle hal, uint8_t session_id, uint8_t
1275 *peer_mac, uint16_t reason, uint8_t
1276 wait_for_ack);
Kondabattini, Ganeshe4f18e02016-09-13 13:01:22 +05301277QDF_STATUS sme_update_access_policy_vendor_ie(tHalHandle hal,
1278 uint8_t session_id, uint8_t *vendor_ie,
1279 int access_policy);
1280
Agrawal Ashish21ba2572016-09-03 16:40:10 +05301281QDF_STATUS sme_update_sta_roam_policy(tHalHandle hal,
1282 enum sta_roam_policy_dfs_mode dfs_mode,
1283 bool skip_unsafe_channels,
Agrawal, Ashish9f84c402016-11-30 16:19:44 +05301284 uint8_t session_id, uint8_t sap_operating_band);
Selvaraj, Sridharebda0f22016-08-29 16:05:23 +05301285QDF_STATUS sme_enable_disable_chanavoidind_event(tHalHandle hal,
1286 uint8_t set_value);
Deepak Dhamdhereb106ae52016-08-10 20:55:30 +05301287QDF_STATUS sme_set_default_scan_ie(tHalHandle hal, uint16_t session_id,
1288 uint8_t *ie_data, uint16_t ie_len);
Selvaraj, Sridhar7231c5f2016-09-28 12:42:33 +05301289/**
1290 * sme_update_session_param() - API to update PE session param
1291 * @hal: HAL handle for device
1292 * @session_id: Session ID
1293 * @param_type: Param type to be updated
1294 * @param_val: Param value to be update
1295 *
1296 * Note: this setting will not persist over reboots.
1297 *
1298 * Return: QDF_STATUS
1299 */
1300QDF_STATUS sme_update_session_param(tHalHandle hal, uint8_t session_id,
1301 uint32_t param_type, uint32_t param_val);
Padma, Santhosh Kumard7cc0792016-06-28 18:54:12 +05301302
Padma, Santhosh Kumar72e7aec2016-10-12 17:23:44 +05301303#ifdef WLAN_FEATURE_DISA
Padma, Santhosh Kumard7cc0792016-06-28 18:54:12 +05301304/**
Padma, Santhosh Kumard7cc0792016-06-28 18:54:12 +05301305 * sme_encrypt_decrypt_msg() - handles encrypt/decrypt mesaage
1306 * @hal: HAL handle
1307 * @encrypt_decrypt_params: struct to set encryption/decryption params.
Jeff Johnsone8216e82017-01-26 15:54:51 -08001308 * @callback: callback function to be called with the result
1309 * @context: Opaque context to be passed to callback function
Padma, Santhosh Kumard7cc0792016-06-28 18:54:12 +05301310 *
1311 * Return: QDF_STATUS enumeration.
1312 */
1313QDF_STATUS sme_encrypt_decrypt_msg(tHalHandle hal,
Jeff Johnsone8216e82017-01-26 15:54:51 -08001314 struct encrypt_decrypt_req_params *encrypt_decrypt_params,
1315 sme_encrypt_decrypt_callback callback,
1316 void *context);
Padma, Santhosh Kumar72e7aec2016-10-12 17:23:44 +05301317#endif
Padma, Santhosh Kumard7cc0792016-06-28 18:54:12 +05301318
Agrawal Ashishb2d1a452016-05-05 12:23:58 +05301319/**
1320 * sme_set_cts2self_for_p2p_go() - sme function to set ini parms to FW.
1321 * @hal: reference to the HAL
1322 *
1323 * Return: QDF_STATUS
1324 */
1325QDF_STATUS sme_set_cts2self_for_p2p_go(tHalHandle hal);
Kiran Kumar Lokere1aa9c9a2016-10-05 18:50:59 -07001326void sme_set_prefer_80MHz_over_160MHz(tHalHandle hal,
1327 bool sta_prefer_80MHz_over_160MHz);
Agrawal, Ashish35b251d2016-09-08 19:21:03 +05301328QDF_STATUS sme_update_tx_fail_cnt_threshold(tHalHandle hal_handle,
1329 uint8_t session_id, uint32_t tx_fail_count);
Agrawal Ashishda3e9502016-09-21 17:43:51 +05301330QDF_STATUS sme_update_short_retry_limit_threshold(tHalHandle hal_handle,
1331 struct sme_short_retry_limit *short_retry_limit_th);
1332QDF_STATUS sme_update_long_retry_limit_threshold(tHalHandle hal_handle,
1333 struct sme_long_retry_limit *long_retry_limit_th);
yeshwanth sriram guntukaa1ba9a22017-02-28 16:17:32 +05301334/**
1335 * sme_roam_is_ese_assoc() - Check if association type is ESE
1336 * @roam_info: Pointer to roam info
1337 *
1338 * Return: true if ESE Association, false otherwise.
1339 */
1340#ifdef FEATURE_WLAN_ESE
1341bool sme_roam_is_ese_assoc(tCsrRoamInfo *roam_info);
1342#else
1343static inline bool sme_roam_is_ese_assoc(tCsrRoamInfo *roam_info)
1344{
1345 return false;
1346}
1347#endif
1348/**
1349 * sme_neighbor_roam_is11r_assoc() - Check if association type is 11R
1350 * @hal_ctx: HAL handle
1351 * @session_id: session id
1352 *
1353 * Return: true if 11r Association, false otherwise.
1354 */
1355bool sme_neighbor_roam_is11r_assoc(tHalHandle hal_ctx, uint8_t session_id);
Agrawal, Ashish4e5fa1c2016-09-21 19:03:43 +05301356
1357/**
1358 * sme_update_sta_inactivity_timeout(): Update sta_inactivity_timeout to FW
1359 * @hal: Handle returned by mac_open
1360 * @sta_inactivity_timer: struct for sta inactivity timer
1361 *
1362 * If a station does not send anything in sta_inactivity_timeout seconds, an
1363 * empty data frame is sent to it in order to verify whether it is
1364 * still in range. If this frame is not ACKed, the station will be
1365 * disassociated and then deauthenticated.
1366 *
1367 * Return: QDF_STATUS_SUCCESS or non-zero on failure.
1368*/
1369QDF_STATUS sme_update_sta_inactivity_timeout(tHalHandle hal_handle,
1370 struct sme_sta_inactivity_timeout *sta_inactivity_timer);
1371
Sreelakshmi Konamki58c72432016-11-09 17:06:44 +05301372/**
1373 * sme_set_lost_link_info_cb() - plug in callback function for receiving
1374 * @hal: HAL handle
1375 * @cb: callback function
1376 *
1377 * Return: HAL status
1378 */
1379QDF_STATUS sme_set_lost_link_info_cb(tHalHandle hal,
1380 void (*cb)(void *, struct sir_lost_link_info *));
Yingying Tang95409972016-10-20 15:16:15 +08001381
Kapil Gupta8878ad92017-02-13 11:56:04 +05301382/**
1383 * sme_update_new_channel_event() - update new channel event for sapFsm
1384 * @hal: HAL handle
1385 * @session_id: session id
1386 *
1387 * Return: QDF_STATUS_SUCCESS or non-zero on failure.
1388 */
1389QDF_STATUS sme_update_new_channel_event(tHalHandle hal, uint8_t session_id);
Sridhar Selvarajdc400d22016-10-18 17:18:03 +05301390#ifdef WLAN_POWER_DEBUGFS
1391QDF_STATUS sme_power_debug_stats_req(tHalHandle hal, void (*callback_fn)
1392 (struct power_stats_response *response,
1393 void *context), void *power_stats_context);
1394#endif
Kabilan Kannan3c0a7352016-12-02 18:49:38 -08001395/**
1396 * sme_set_sar_power_limits() - set sar limits
1397 * @hal: HAL handle
1398 * @sar_limit_cmd: struct to send sar limit cmd.
1399 *
1400 * Return: QDF_STATUS enumeration.
1401 */
1402QDF_STATUS sme_set_sar_power_limits(tHalHandle hal,
1403 struct sar_limit_cmd_params *sar_limit_cmd);
Amar Singhal6edf9732016-11-20 21:43:40 -08001404void sme_set_cc_src(tHalHandle hal_handle, enum country_src);
Yingying Tang95409972016-10-20 15:16:15 +08001405
1406
1407#ifdef WLAN_FEATURE_WOW_PULSE
1408QDF_STATUS sme_set_wow_pulse(struct wow_pulse_mode *wow_pulse_set_info);
1409#endif
1410
Kapil Gupta4f0c0c12017-02-07 15:21:15 +05301411/**
1412 * sme_set_chan_info_callback() - Register chan info callback
1413 * @hal - MAC global handle
1414 * @callback_routine - callback routine from HDD
1415 *
1416 * This API is invoked by HDD to register its callback to mac
1417 *
1418 * Return: QDF_STATUS
1419 */
1420void sme_set_chan_info_callback(tHalHandle hal_handle,
1421 void (*callback)(struct scan_chan_info *chan_info));
Naveen Rawat664a7cb2017-01-19 17:58:14 -08001422
1423/**
1424 * sme_get_beacon_frm() - gets the bss descriptor from scan cache and prepares
1425 * beacon frame
1426 * @hal: handle returned by mac_open
1427 * @profile: current connected profile
1428 * @bssid: bssid to look for in scan cache
1429 * @frame_buf: frame buffer to populate
1430 * @frame_len: length of constructed frame
1431 *
1432 * Return: QDF_STATUS
1433 */
1434QDF_STATUS sme_get_beacon_frm(tHalHandle hal, tCsrRoamProfile *profile,
1435 const tSirMacAddr bssid,
1436 uint8_t **frame_buf, uint32_t *frame_len);
1437
Nitesh Shah99dd9552017-03-20 19:27:47 +05301438QDF_STATUS sme_delete_all_tdls_peers(tHalHandle hal, uint8_t session_id);
1439
Prakash Dhavali7090c5f2015-11-02 17:55:19 -08001440#endif /* #if !defined( __SME_API_H ) */