blob: 1197e551f150827ca59aafa84876e6aa8ea22d8d [file] [log] [blame]
Jeff Johnson295189b2012-06-20 16:38:30 -07001/*
Siddharth Bhalb7c421c2015-02-27 00:26:09 +05302 * Copyright (c) 2012-2015 The Linux Foundation. All rights reserved.
Kiet Lam1ed83fc2014-02-19 01:15:45 -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/*
Kiet Lama7f454d2014-07-24 12:04:06 -070023 * This file was originally distributed by Qualcomm Atheros, Inc.
24 * under proprietary terms before Copyright ownership was assigned
25 * to the Linux Foundation.
Gopichand Nakkala92f07d82013-01-08 21:16:34 -080026 */
Kiet Lam1ed83fc2014-02-19 01:15:45 -080027
28
Kiet Lama7f454d2014-07-24 12:04:06 -070029
30
Jeff Johnson295189b2012-06-20 16:38:30 -070031#ifndef WLAN_QCT_WDA_H
32#define WLAN_QCT_WDA_H
33
34/*===========================================================================
35
Jeff Johnson6239e642013-02-22 21:22:26 -080036 W L A N DEVICE ADAPTATION L A Y E R
Jeff Johnson295189b2012-06-20 16:38:30 -070037 E X T E R N A L A P I
Jeff Johnson6239e642013-02-22 21:22:26 -080038
39
Jeff Johnson295189b2012-06-20 16:38:30 -070040DESCRIPTION
41 This file contains the external API exposed by the wlan adaptation layer for Prima
42 and Volans.
43
44 For Volans this layer is actually a thin layer that maps all WDA messages and
45 functions to equivalent HAL messages and functions. The reason this layer was introduced
Jeff Johnson6239e642013-02-22 21:22:26 -080046 was to keep the UMAC identical across Prima and Volans. This layer provides the glue
Jeff Johnson295189b2012-06-20 16:38:30 -070047 between SME, PE , TL and HAL.
48
Jeff Johnson295189b2012-06-20 16:38:30 -070049===========================================================================*/
50
51
52/*===========================================================================
53
54 EDIT HISTORY FOR FILE
55
56
57 This section contains comments describing changes made to the module.
58 Notice that changes are listed in reverse chronological order.
59
60
61 $Header:$ $DateTime: $ $Author: $
62
63
64when who what, where, why
65-------- --- ----------------------------------------------
6610/05/2011 haparna Adding support for Keep Alive Feature
6701/27/2011 rnair Adding WDA support for Volans.
6812/08/2010 seokyoun Move down HAL interfaces from TL to WDA
69 for UMAC convergence btween Volans/Libra and Prima
Jeff Johnson6239e642013-02-22 21:22:26 -08007008/25/2010 adwivedi WDA Context and exposed API's
Jeff Johnson295189b2012-06-20 16:38:30 -070071=========================================================================== */
72
73#include "aniGlobal.h"
74
Jeff Johnson295189b2012-06-20 16:38:30 -070075
76# include "wlan_qct_wdi_ds.h"
77
Jeff Johnson295189b2012-06-20 16:38:30 -070078
79/* Add Include */
80
81typedef enum
82{
83 WDA_INIT_STATE,
84 WDA_START_STATE,
85 WDA_READY_STATE,
86 WDA_PRE_ASSOC_STATE,
87 WDA_BA_UPDATE_TL_STATE,
88 WDA_BA_UPDATE_LIM_STATE,
89 WDA_STOP_STATE,
90 WDA_CLOSE_STATE
91}WDA_state;
92
93typedef enum
94{
95 WDA_PROCESS_SET_LINK_STATE,
96 WDA_IGNORE_SET_LINK_STATE
97}WDA_processSetLinkStateStatus;
98
99typedef enum
100{
101 WDA_DISABLE_BA,
102 WDA_ENABLE_BA
103}WDA_BaEnableFlags;
104
105typedef enum
106{
107 WDA_INVALID_STA_INDEX,
108 WDA_VALID_STA_INDEX
109}WDA_ValidStaIndex;
Varun Reddy Yeturud0a3f252013-04-15 21:58:13 -0700110typedef enum
111{
112 eWDA_AUTH_TYPE_NONE, //never used
113 // MAC layer authentication types
114 eWDA_AUTH_TYPE_OPEN_SYSTEM,
115 // Upper layer authentication types
116 eWDA_AUTH_TYPE_WPA,
117 eWDA_AUTH_TYPE_WPA_PSK,
118
119 eWDA_AUTH_TYPE_RSN,
120 eWDA_AUTH_TYPE_RSN_PSK,
121 eWDA_AUTH_TYPE_FT_RSN,
122 eWDA_AUTH_TYPE_FT_RSN_PSK,
123 eWDA_AUTH_TYPE_WAPI_WAI_CERTIFICATE,
124 eWDA_AUTH_TYPE_WAPI_WAI_PSK,
125 eWDA_AUTH_TYPE_CCKM_WPA,
126 eWDA_AUTH_TYPE_CCKM_RSN,
127 eWDA_AUTH_TYPE_WPA_NONE,
128 eWDA_AUTH_TYPE_AUTOSWITCH,
129 eWDA_AUTH_TYPE_SHARED_KEY,
130 eWDA_NUM_OF_SUPPORT_AUTH_TYPE,
131 eWDA_AUTH_TYPE_FAILED = 0xff,
132 eWDA_AUTH_TYPE_UNKNOWN = eCSR_AUTH_TYPE_FAILED,
133}WDA_AuthType;
Jeff Johnson295189b2012-06-20 16:38:30 -0700134
Kanchanapally, Vidyullathaf9426e52013-12-24 17:28:54 +0530135#define IS_FW_IN_TX_PATH_FEATURE_ENABLE ((WDI_getHostWlanFeatCaps(FW_IN_TX_PATH)) & (WDA_getFwWlanFeatCaps(FW_IN_TX_PATH)))
Abhishek Singh6927fa02014-06-27 17:19:55 +0530136#define IS_MUMIMO_BFORMEE_CAPABLE ((WDI_getHostWlanFeatCaps(MU_MIMO)) & (WDA_getFwWlanFeatCaps(MU_MIMO)))
Abhishek Singh5fef4042014-11-25 18:33:00 +0530137#define IS_FEATURE_BCN_FLT_DELTA_ENABLE ((WDI_getHostWlanFeatCaps(BCN_IE_FLT_DELTA)) & (WDA_getFwWlanFeatCaps(BCN_IE_FLT_DELTA)))
Abhishek Singh85b74712014-10-08 11:38:19 +0530138#define IS_FEATURE_FW_STATS_ENABLE ((WDI_getHostWlanFeatCaps(FW_STATS)) & (WDA_getFwWlanFeatCaps(FW_STATS)))
Jeff Johnson295189b2012-06-20 16:38:30 -0700139/*--------------------------------------------------------------------------
140 Utilities
141 --------------------------------------------------------------------------*/
142
143#define WDA_TLI_CEIL( _a, _b) (( 0 != (_a)%(_b))? (_a)/(_b) + 1: (_a)/(_b))
144
145/*
146 * Check the version number and find if MCC feature is supported or not
147 */
148#define IS_MCC_SUPPORTED (WDA_IsWcnssWlanReportedVersionGreaterThanOrEqual( 0, 1, 1, 0))
Viral Modid86bde22012-12-10 13:09:21 -0800149#define IS_FEATURE_SUPPORTED_BY_FW(featEnumValue) (!!WDA_getFwWlanFeatCaps(featEnumValue))
Kiet Lam0f320422013-11-21 19:29:17 +0530150#define IS_FEATURE_SUPPORTED_BY_DRIVER(featEnumValue) (!!WDA_getHostWlanFeatCaps(featEnumValue))
Jeff Johnson295189b2012-06-20 16:38:30 -0700151
Yathish9f22e662012-12-10 14:21:35 -0800152#ifdef WLAN_ACTIVEMODE_OFFLOAD_FEATURE
153#define IS_ACTIVEMODE_OFFLOAD_FEATURE_ENABLE ((WDA_getFwWlanFeatCaps(WLANACTIVE_OFFLOAD)) & (WDI_getHostWlanFeatCaps(WLANACTIVE_OFFLOAD)))
154#else
155#define IS_ACTIVEMODE_OFFLOAD_FEATURE_ENABLE 0
156#endif
157
Varun Reddy Yeturud0a3f252013-04-15 21:58:13 -0700158#ifdef WLAN_FEATURE_ROAM_SCAN_OFFLOAD
159#define IS_ROAM_SCAN_OFFLOAD_FEATURE_ENABLE ((WDI_getHostWlanFeatCaps(WLAN_ROAM_SCAN_OFFLOAD)) & (WDA_getFwWlanFeatCaps(WLAN_ROAM_SCAN_OFFLOAD)))
160#else
161#define IS_ROAM_SCAN_OFFLOAD_FEATURE_ENABLE 0
162#endif
Yathish9f22e662012-12-10 14:21:35 -0800163
Mihir Shete9c238772014-10-15 14:35:16 +0530164#define IS_DYNAMIC_WMM_PS_ENABLED ((WDI_getHostWlanFeatCaps(DYNAMIC_WMM_PS)) & (WDA_getFwWlanFeatCaps(DYNAMIC_WMM_PS)))
165
Ravi Joshid2ca7c42013-07-23 08:37:49 -0700166/* Check if heartbeat offload is enabled */
167#define IS_IBSS_HEARTBEAT_OFFLOAD_FEATURE_ENABLE ((WDI_getHostWlanFeatCaps(IBSS_HEARTBEAT_OFFLOAD)) & (WDA_getFwWlanFeatCaps(IBSS_HEARTBEAT_OFFLOAD)))
168
Madan Mohan Koyyalamudice419872013-09-13 19:36:52 +0530169#ifdef FEATURE_WLAN_TDLS
170#define IS_ADVANCE_TDLS_ENABLE ((WDI_getHostWlanFeatCaps(ADVANCE_TDLS)) & (WDA_getFwWlanFeatCaps(ADVANCE_TDLS)))
171#else
172#define IS_ADVANCE_TDLS_ENABLE 0
173#endif
Sandeep Puligilla60342762014-01-30 21:05:37 +0530174#define IS_HT40_OBSS_SCAN_FEATURE_ENABLE ((WDA_getFwWlanFeatCaps(HT40_OBSS_SCAN)) & (WDI_getHostWlanFeatCaps(HT40_OBSS_SCAN)))
175
Manjunathappa Prakash86f78ca2014-02-10 18:09:15 -0800176typedef enum {
177 MODE_11A = 0, /* 11a Mode */
178 MODE_11G = 1, /* 11b/g Mode */
179 MODE_11B = 2, /* 11b Mode */
180 MODE_11GONLY = 3, /* 11g only Mode */
181 MODE_11NA_HT20 = 4, /* 11a HT20 mode */
182 MODE_11NG_HT20 = 5, /* 11g HT20 mode */
183 MODE_11NA_HT40 = 6, /* 11a HT40 mode */
184 MODE_11NG_HT40 = 7, /* 11g HT40 mode */
185 MODE_11AC_VHT20 = 8,
186 MODE_11AC_VHT40 = 9,
187 MODE_11AC_VHT80 = 10,
188// MODE_11AC_VHT160 = 11,
189 MODE_11AC_VHT20_2G = 11,
190 MODE_11AC_VHT40_2G = 12,
191 MODE_11AC_VHT80_2G = 13,
192 MODE_UNKNOWN = 14,
193 MODE_MAX = 14
194} WLAN_PHY_MODE;
195
196#define WLAN_HAL_CHAN_FLAG_HT40_PLUS 6
197#define WLAN_HAL_CHAN_FLAG_PASSIVE 7
198#define WLAN_HAL_CHAN_ADHOC_ALLOWED 8
199#define WLAN_HAL_CHAN_AP_DISABLED 9
200#define WLAN_HAL_CHAN_FLAG_DFS 10
201#define WLAN_HAL_CHAN_FLAG_ALLOW_HT 11 /* HT is allowed on this channel */
202#define WLAN_HAL_CHAN_FLAG_ALLOW_VHT 12 /* VHT is allowed on this channel */
203
204#define WDA_SET_CHANNEL_FLAG(pwda_channel,flag) do { \
205 (pwda_channel)->channel_info |= (1 << flag); \
206 } while(0)
207
208#define WDA_SET_CHANNEL_MODE(pwda_channel,val) do { \
209 (pwda_channel)->channel_info &= 0xffffffc0; \
210 (pwda_channel)->channel_info |= (val); \
211 } while(0)
212
213#define WDA_SET_CHANNEL_MAX_POWER(pwda_channel,val) do { \
214 (pwda_channel)->reg_info_1 &= 0xffff00ff; \
215 (pwda_channel)->reg_info_1 |= ((val&0xff) << 8); \
216 } while(0)
217
218#define WDA_SET_CHANNEL_REG_POWER(pwda_channel,val) do { \
219 (pwda_channel)->reg_info_1 &= 0xff00ffff; \
220 (pwda_channel)->reg_info_1 |= ((val&0xff) << 16); \
221 } while(0)
Sachin Ahujacb64fc82015-01-12 17:01:05 +0530222#define WDA_SET_CUURENT_REG_DOMAIN(pwda_channel, val) do { \
223 (pwda_channel)->reg_info_2 |= ((val&0x7) << 24); \
224 (pwda_channel)->reg_info_2 |= 0x80000000; \
225 } while(0)
Manjunathappa Prakash86f78ca2014-02-10 18:09:15 -0800226#define WDA_SET_CHANNEL_MIN_POWER(pwlan_hal_update_channel,val) do { \
227 (pwlan_hal_update_channel)->reg_info_1 &= 0xffffff00; \
228 (pwlan_hal_update_channel)->reg_info_1 |= (val&0xff); \
229 } while(0)
230#define WDA_SET_CHANNEL_ANTENNA_MAX(pwlan_hal_update_channel,val) do { \
231 (pwlan_hal_update_channel)->reg_info_2 &= 0xffffff00; \
232 (pwlan_hal_update_channel)->reg_info_2 |= (val&0xff); \
233 } while(0)
234#define WDA_SET_CHANNEL_REG_CLASSID(pwlan_hal_update_channel,val) do { \
235 (pwlan_hal_update_channel)->reg_info_1 &= 0x00ffffff; \
236 (pwlan_hal_update_channel)->reg_info_1 |= ((val&0xff) << 24); \
237 } while(0)
238
Amar Singhald08ce752014-03-21 16:28:27 -0700239#define WDA_IS_MCAST_FLT_ENABLE_IN_FW (WDA_getFwWlanFeatCaps(WLAN_MCADDR_FLT))
240
Jeff Johnson295189b2012-06-20 16:38:30 -0700241/*--------------------------------------------------------------------------
242 Definitions for Data path APIs
243 --------------------------------------------------------------------------*/
244
245/*As per 802.11 spec */
246#define WDA_TLI_MGMT_FRAME_TYPE 0x00
247#define WDA_TLI_CTRL_FRAME_TYPE 0x10
248#define WDA_TLI_DATA_FRAME_TYPE 0x20
249
250/*802.3 header definitions*/
251#define WDA_TLI_802_3_HEADER_LEN 14
252/*802.11 header definitions - header len without QOS ctrl field*/
253#define WDA_TLI_802_11_HEADER_LEN 24
254
255/*Determines the header len based on the disable xtl field*/
256#define WDA_TLI_MAC_HEADER_LEN( _dxtl) \
257 ( ( 0 == _dxtl )? \
258 WDA_TLI_802_3_HEADER_LEN:WDA_TLI_802_11_HEADER_LEN )
259
260/* TX channel enum type:
261
262 We have five types of TX packets so far and want to block/unblock each
263 traffic individually according to, for example, low resouce condition.
264 Define five TX channels for UMAC here. WDA can map these logical
265 channels to physical DXE channels if needed.
266*/
267typedef enum
268{
269 WDA_TXFLOW_AC_BK = 0,
270 WDA_TXFLOW_AC_BE = 1,
271 WDA_TXFLOW_AC_VI = 2,
272 WDA_TXFLOW_AC_VO = 3,
273 WDA_TXFLOW_MGMT = 4,
274 WDA_TXFLOW_BAP = 1, /* BAP is sent as BE */
275 WDA_TXFLOW_FC = 1, /* FC is sent as BE */
276 WDA_TXFLOW_MAX
277} WDA_TXFlowEnumType;
278
279#define WDA_TXFLOWMASK 0x1F /* 1~4bit:low priority ch / 5bit: high */
280
281/* ---------------------------------------------------------------------
282 Libra and Volans specifics
283
284 TODO Consider refactoring it and put it into two separate headers,
285 one for Prima and one for Volans
Jeff Johnson295189b2012-06-20 16:38:30 -0700286 ----------------------------------------------------------------------*/
287
288/* For backward compatability with SDIO. It's BAL header size for SDIO
289 interface. It's nothing for integrated SOC */
Jeff Johnson295189b2012-06-20 16:38:30 -0700290#define WDA_DXE_HEADER_SIZE 0
Jeff Johnson295189b2012-06-20 16:38:30 -0700291
Jeff Johnson295189b2012-06-20 16:38:30 -0700292
293/*Minimum resources needed - arbitrary*/
294
295/*DXE + SD*/
Madan Mohan Koyyalamudia53c4dc2012-11-13 10:35:42 -0800296#define WDA_WLAN_LIBRA_HEADER_LEN (20 + 8)
Jeff Johnson295189b2012-06-20 16:38:30 -0700297
Jeff Johnson295189b2012-06-20 16:38:30 -0700298#define WDA_TLI_BD_PDU_RESERVE_THRESHOLD 10
Jeff Johnson295189b2012-06-20 16:38:30 -0700299
300
Jeff Johnson295189b2012-06-20 16:38:30 -0700301# define WDA_TLI_MIN_RES_MF 1
302# define WDA_TLI_MIN_RES_BAP 2
303# define WDA_TLI_MIN_RES_DATA 3
Jeff Johnson295189b2012-06-20 16:38:30 -0700304
Jeff Johnson295189b2012-06-20 16:38:30 -0700305# define WDA_NUM_STA 8
Jeff Johnson295189b2012-06-20 16:38:30 -0700306
307/* For backward compatability with SDIO.
308
309 For SDIO interface, calculate the TX frame length and number of PDU
310 to transfter the frame.
311
312 _vosBuff: IN VOS pakcet buffer pointer
313 _usPktLen: OUT VOS packet length in bytes
314 _uResLen: OUT Number of PDU to hold this VOS packet
315 _uTotalPktLen: OUT Totoal packet length including BAL header size
316
317 For integrated SOC, _usPktLen and _uTotalPktLen is VOS pakcet length
318 which does include BD header length. _uResLen is hardcoded 2.
319 */
Jeff Johnson295189b2012-06-20 16:38:30 -0700320
321#ifdef WINDOWS_DT
322#define WDA_TLI_PROCESS_FRAME_LEN( _vosBuff, _usPktLen, \
323 _uResLen, _uTotalPktLen) \
324 do \
325 { \
326 _usPktLen = wpalPacketGetFragCount((wpt_packet*)_vosBuff) + 1/*BD*/;\
327 _uResLen = _usPktLen; \
328 _uTotalPktLen = _usPktLen; \
329 } \
330 while ( 0 )
331#else /* WINDOWS_DT */
332#define WDA_TLI_PROCESS_FRAME_LEN( _vosBuff, _usPktLen, \
333 _uResLen, _uTotalPktLen) \
334 do \
335 { \
336 _usPktLen = 2; /* Need 1 descriptor per a packet + packet*/ \
337 _uResLen = 2; /* Assume that we spends two DXE descriptor */ \
338 _uTotalPktLen = _usPktLen; \
339 } \
340 while ( 0 )
341#endif /* WINDOWS_DT */
342
Jeff Johnson295189b2012-06-20 16:38:30 -0700343
344
345/*--------------------------------------------------------------------------
346 Message Definitions
347 --------------------------------------------------------------------------*/
348
349/* TX Tranmit request message. It serializes TX request to TX thread.
350 The message is processed in TL.
351*/
352#define WDA_DS_TX_START_XMIT WLANTL_TX_START_XMIT
353#define WDA_DS_FINISH_ULA WLANTL_FINISH_ULA
354
Madan Mohan Koyyalamudi31e4cad2013-08-21 20:21:14 +0530355#define VOS_TO_WPAL_PKT(_vos_pkt) ((wpt_packet*)_vos_pkt)
Jeff Johnson295189b2012-06-20 16:38:30 -0700356
357#define WDA_TX_PACKET_FREED 0X0
358
Jeff Johnson43971f52012-07-17 12:26:56 -0700359/* Approximate amount of time to wait for WDA to stop WDI considering 1 pendig req too*/
360#define WDA_STOP_TIMEOUT ( (WDI_RESPONSE_TIMEOUT * 2) + WDI_SET_POWER_STATE_TIMEOUT + 5)
Jeff Johnson295189b2012-06-20 16:38:30 -0700361/*--------------------------------------------------------------------------
362 Functions
363 --------------------------------------------------------------------------*/
364
365/* For data client */
366typedef VOS_STATUS (*WDA_DS_TxCompleteCallback) ( v_PVOID_t pContext, vos_pkt_t *pFrameDataBuff, VOS_STATUS txStatus );
367typedef VOS_STATUS (*WDA_DS_RxPacketCallback) ( v_PVOID_t pContext, vos_pkt_t *pFrameDataBuff );
368typedef v_U32_t (*WDA_DS_TxPacketCallback) ( v_PVOID_t pContext,
369 vos_pkt_t **ppFrameDataBuff,
370 v_U32_t uSize,
Jeff Johnson295189b2012-06-20 16:38:30 -0700371 v_U8_t uFlowMask,
Jeff Johnson295189b2012-06-20 16:38:30 -0700372 v_BOOL_t *pbUrgent );
373typedef VOS_STATUS (*WDA_DS_ResourceCB) ( v_PVOID_t pContext, v_U32_t uCount );
374
375
Jeff Johnson295189b2012-06-20 16:38:30 -0700376/* For management client */
377typedef VOS_STATUS (*WDA_DS_TxCompleteCb)( v_PVOID_t pContext, wpt_packet *pFrame );
378typedef VOS_STATUS (*WDA_DS_RxCompleteCb)( v_PVOID_t pContext, wpt_packet *pFrame );
379typedef VOS_STATUS (*WDA_DS_TxFlowControlCb)( v_PVOID_t pContext, v_U8_t acMask );
380typedef void (*pWDATxRxCompFunc)( v_PVOID_t pContext, void *pData );
381
382//callback function for TX complete
383//parameter 1 - global pMac pointer
384//parameter 2 - txComplete status : 1- success, 0 - failure.
Ganesh Kondabattini358fc9b2015-03-11 16:14:25 +0530385typedef eHalStatus (*pWDAAckFnTxComp)(tpAniSirGlobal, void *pData);
Jeff Johnson295189b2012-06-20 16:38:30 -0700386
387typedef struct
388{
389 tANI_U16 ucValidStaIndex ;
390 /*
391 * each bit in ucUseBaBitmap represent BA is enabled or not for this tid
392 * tid0 ..bit0, tid1..bit1 and so on..
393 */
394 tANI_U8 ucUseBaBitmap ;
395 tANI_U8 bssIdx;
Abhishek Singh0644e482014-10-06 18:38:23 +0530396 tANI_U32 currentOperChan;
Jeff Johnson295189b2012-06-20 16:38:30 -0700397 tANI_U32 framesTxed[STACFG_MAX_TC];
398}tWdaStaInfo, *tpWdaStaInfo ;
399
400/* group all the WDA timers into this structure */
401typedef struct
402{
403 /* BA activity check timer */
404 TX_TIMER baActivityChkTmr ;
405
406 /* Tx Complete Timeout timer */
407 TX_TIMER TxCompleteTimer ;
Madan Mohan Koyyalamudi01cba042013-01-10 21:56:05 -0800408
409 /* Traffic Stats timer */
410 TX_TIMER trafficStatsTimer ;
Jeff Johnson295189b2012-06-20 16:38:30 -0700411}tWdaTimers ;
Siddharth Bhal85f99b12014-05-09 08:09:07 +0530412
Gopichand Nakkala976e3252013-01-03 15:45:56 -0800413#ifdef WLAN_SOFTAP_VSTA_FEATURE
Yathish Hanumapuradoddi Shivanna64dfc472013-03-08 10:48:34 -0800414#define WDA_MAX_STA (41)
Gopichand Nakkala976e3252013-01-03 15:45:56 -0800415#else
Jeff Johnson295189b2012-06-20 16:38:30 -0700416#define WDA_MAX_STA (16)
Gopichand Nakkala976e3252013-01-03 15:45:56 -0800417#endif
Siddharth Bhal85f99b12014-05-09 08:09:07 +0530418typedef enum
419{
420 WDA_ADDSTA_REQ_NO_MEM = 0,
421 WDA_ADDSTA_REQ_WDI_FAIL = 1,
422 WDA_ADDSTA_RSP_NO_MEM = 2,
423 WDA_ADDSTA_RSP_WDI_FAIL = 3,
424 WDA_ADDSTA_MAX
425} WDA_AddSelfStaFailReasonDebug;
426
427/*AddSelfSta Request and Response Debug*/
428typedef struct
429{
430 wpt_uint8 wdiAddStaSelfStaReqCounter;
431 wpt_uint8 wdiAddStaSelfStaRspCounter;
432 wpt_uint8 wdiAddStaSelfStaFailCounter;
433 wpt_uint8 ucSTASelfIdx; /* received SelfStaIdx*/
434 wpt_uint8 wdaAddSelfStaFailReason;
435} tWDA_AddSelfStaDebugParams;
436
Jeff Johnson295189b2012-06-20 16:38:30 -0700437typedef struct
438{
439 v_PVOID_t pVosContext; /* global VOSS context*/
440 v_PVOID_t pWdiContext; /* WDI context */
441 WDA_state wdaState ; /* WDA state tracking */
Jeff Johnson295189b2012-06-20 16:38:30 -0700442 v_PVOID_t wdaWdiCfgApiMsgParam ; /* WDI API paramter tracking */
443 vos_event_t wdaWdiEvent; /* WDI API sync event */
444
445 /* Event to wait for tx completion */
446 vos_event_t txFrameEvent;
447
448 /* call back function for tx complete*/
449 pWDATxRxCompFunc pTxCbFunc;
450 /* call back function for tx packet ack */
451 pWDAAckFnTxComp pAckTxCbFunc;
452 tANI_U32 frameTransRequired;
453 tSirMacAddr macBSSID; /*BSSID of the network */
454 tSirMacAddr macSTASelf; /*Self STA MAC*/
455
456 /* TX channel mask for flow control */
457 v_U8_t uTxFlowMask;
458 /* TL's TX resource callback */
459 WDA_DS_ResourceCB pfnTxResourceCB;
460 /* TL's TX complete callback */
461 WDA_DS_TxCompleteCallback pfnTxCompleteCallback;
462
463 tWdaStaInfo wdaStaInfo[WDA_MAX_STA];
464
465 tANI_U8 wdaMaxSta;
466 tWdaTimers wdaTimers;
467
468 /* STA, AP, IBSS, MULTI-BSS etc.*/
469 tBssSystemRole wdaGlobalSystemRole;
470
471 /* driver mode, PRODUCTION or FTM */
472 tDriverType driverMode;
473
Jeff Johnson295189b2012-06-20 16:38:30 -0700474 /* FTM Command Request tracking */
475 v_PVOID_t wdaFTMCmdReq;
Jeff Johnson295189b2012-06-20 16:38:30 -0700476
477 /* Event to wait for suspend data tx*/
478 vos_event_t suspendDataTxEvent;
479 /* Status frm TL after suspend/resume Tx */
480 tANI_U8 txStatus;
481 /* Flag set to true when TL suspend timesout.*/
482 tANI_U8 txSuspendTimedOut;
483
484 vos_event_t waitOnWdiIndicationCallBack;
485
486 /* version information */
487 tSirVersionType wcnssWlanCompiledVersion;
488 tSirVersionType wcnssWlanReportedVersion;
489 tSirVersionString wcnssSoftwareVersionString;
490 tSirVersionString wcnssHardwareVersionString;
491
492
493 tSirLinkState linkState;
494 /* set, when BT AMP session is going on */
495 v_BOOL_t wdaAmpSessionOn;
Jeff Johnsone7245742012-09-05 17:12:55 -0700496 v_BOOL_t needShutdown;
Madan Mohan Koyyalamudia2fc6412012-10-21 12:06:12 -0700497 v_BOOL_t wdiFailed;
Madan Mohan Koyyalamudid57ae632012-11-06 18:42:48 -0800498 v_BOOL_t wdaTimersCreated;
Mahesh A Saptasagarcadc3542014-12-01 19:00:02 +0530499 uintptr_t VosPacketToFree;
Leo Chang9d76f622013-08-23 16:34:52 -0700500
501 /* Event to wait for WDA stop on FTM mode */
502 vos_event_t ftmStopDoneEvent;
Siddharth Bhal85f99b12014-05-09 08:09:07 +0530503
504 tWDA_AddSelfStaDebugParams wdaAddSelfStaParams;
505
Jeff Johnson295189b2012-06-20 16:38:30 -0700506} tWDA_CbContext ;
507
508typedef struct
509{
510 v_PVOID_t pWdaContext; /* pointer to WDA context*/
511 v_PVOID_t wdaMsgParam; /* PE parameter tracking */
512 v_PVOID_t wdaWdiApiMsgParam; /* WDI API paramter tracking */
513} tWDA_ReqParams;
514
Siddharth Bhal68115602015-01-18 20:44:55 +0530515typedef struct
516{
517 v_PVOID_t pWdaContext; /* pointer to WDA context*/
518 v_PVOID_t wdaMsgParam; /* PE parameter tracking */
519 v_PVOID_t wdaWdiApiMsgParam; /* WDI API paramter tracking */
520 v_BOOL_t wdaHALDumpAsync; /* Async Request */
521
522} tWDA_HalDumpReqParams;
523
Jeff Johnson295189b2012-06-20 16:38:30 -0700524/*
525 * FUNCTION: WDA_open
526 * open WDA context
527 */
528
Arun Kumar Khandavalliebb19482014-03-25 13:56:53 +0530529VOS_STATUS WDA_open(v_PVOID_t pVosContext, v_PVOID_t devHandle,
Jeff Johnson295189b2012-06-20 16:38:30 -0700530 tMacOpenParameters *pMacParams ) ;
531
532/*
533 * FUNCTION: WDA_preStart
534 * Trigger DAL-AL to start CFG download
535 */
536VOS_STATUS WDA_start(v_PVOID_t pVosContext) ;
537
538VOS_STATUS WDA_NVDownload_Start(v_PVOID_t pVosContext);
539
540/*
541 * FUNCTION: WDA_preStart
542 * Trigger WDA to start CFG download
543 */
544VOS_STATUS WDA_preStart(v_PVOID_t pVosContext) ;
545/*
546 * FUNCTION: WDA_stop
547 * stop WDA
548 */
549VOS_STATUS WDA_stop(v_PVOID_t pVosContext,tANI_U8 reason);
550
551/*
552 * FUNCTION: WDA_close
553 * close WDA context
554 */
555VOS_STATUS WDA_close(v_PVOID_t pVosContext);
556/*
557 * FUNCTION: WDA_shutdown
558 * Shutdown will not close the control transport, added by SSR
559 */
560VOS_STATUS WDA_shutdown(v_PVOID_t pVosContext, wpt_boolean closeTransport);
561
562/*
Madan Mohan Koyyalamudi9d7a27f2012-11-28 15:55:25 -0800563 * FUNCTION: WDA_setNeedShutdown
564 * WDA stop failed or WDA NV Download failed
Jeff Johnsone7245742012-09-05 17:12:55 -0700565 */
Madan Mohan Koyyalamudi9d7a27f2012-11-28 15:55:25 -0800566void WDA_setNeedShutdown(v_PVOID_t pVosContext);
Jeff Johnsone7245742012-09-05 17:12:55 -0700567/*
568 * FUNCTION: WDA_needShutdown
569 * WDA requires a shutdown rather than a close
570 */
571v_BOOL_t WDA_needShutdown(v_PVOID_t pVosContext);
572
573/*
Jeff Johnson295189b2012-06-20 16:38:30 -0700574 * FUNCTION: WDA_McProcessMsg
575 * DAL-AL message processing entry function
576 */
577
578VOS_STATUS WDA_McProcessMsg( v_CONTEXT_t pVosContext, vos_msg_t *pMsg ) ;
579
580/* -----------------------------------------------------------------
581 * WDA data path API's
582 * ----------------------------------------------------------------*/
583/*
584 * FUNCTION: WDA_MgmtDSRegister
585 * Send Message back to PE
586 */
587
588VOS_STATUS WDA_MgmtDSRegister(tWDA_CbContext *pWDA,
589 WDA_DS_TxCompleteCb WDA_TxCompleteCallback,
590 WDA_DS_RxCompleteCb WDA_RxCompleteCallback,
591 WDA_DS_TxFlowControlCb WDA_TxFlowCtrlCallback
592 ) ;
593/*
594 * FUNCTION: WDA_MgmtDSTxPacket
595 * Forward TX management frame to WDI
596 */
597
598VOS_STATUS WDA_TxPacket(tWDA_CbContext *pWDA,
599 void *pFrmBuf,
600 tANI_U16 frmLen,
601 eFrameType frmType,
602 eFrameTxDir txDir,
603 tANI_U8 tid,
604 pWDATxRxCompFunc pCompFunc,
605 void *pData,
606 pWDAAckFnTxComp pAckTxComp,
Kanchanapally, Vidyullathaf9426e52013-12-24 17:28:54 +0530607 tANI_U32 txFlag);
Jeff Johnson295189b2012-06-20 16:38:30 -0700608
609/*
610 * FUNCTION: WDA_PostMsgApi
611 * API fpr PE to post Message to WDA
612 */
613VOS_STATUS WDA_PostMsgApi(tpAniSirGlobal pMac, tSirMsgQ *pMsg) ;
614
615/* ---------------------------------------------------------
616 * FUNCTION: wdaGetGlobalSystemRole()
617 *
618 * Get the global HAL system role.
619 * ---------------------------------------------------------
620 */
621tBssSystemRole wdaGetGlobalSystemRole(tpAniSirGlobal pMac);
622
623/* maximum wait time for WDA complete event (correct value has to be derived)
624 * for now giving the value 1000 ms */
625#define WDA_WDI_COMPLETION_TIME_OUT 30000 /* in ms */
626
627#define WDA_TL_TX_FRAME_TIMEOUT 10000 /* in msec a very high upper limit of 5,000 msec */
628#define WDA_TL_SUSPEND_TIMEOUT 2000 /* in ms unit */
629
630/*Tag used by WDA to mark a timed out frame*/
631#define WDA_TL_TX_MGMT_TIMED_OUT 0xDEAD
632
633#define WDA_TL_TX_SUSPEND_SUCCESS 0
634#define WDA_TL_TX_SUSPEND_FAILURE 1
635
636// FIXME Temporary value for R33D integaration
637//#define WDA_TL_TX_FRAME_TIMEOUT 20000 /* in msec a very high upper limit */
638
Chet Lanctot186b5732013-03-18 10:26:30 -0700639#define DPU_FEEDBACK_UNPROTECTED_ERROR 0x0F
Jeff Johnson295189b2012-06-20 16:38:30 -0700640
Jeff Johnson295189b2012-06-20 16:38:30 -0700641
642/* ---------------------------------------------------------------------------
643
644 RX Meta info access for Integrated SOC
645 RX BD header access for NON Integrated SOC
646
647 These MACRO are for RX frames that are on flat buffers
648
649 ---------------------------------------------------------------------------*/
650
651/* WDA_GET_RX_MAC_HEADER *****************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700652# define WDA_GET_RX_MAC_HEADER(pRxMeta) \
653 (tpSirMacMgmtHdr)( ((WDI_DS_RxMetaInfoType *)(pRxMeta))->mpduHeaderPtr )
Jeff Johnson295189b2012-06-20 16:38:30 -0700654
655/* WDA_GET_RX_MPDUHEADER3A ****************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700656# define WDA_GET_RX_MPDUHEADER3A(pRxMeta) \
657 (tpSirMacDataHdr3a)( ((WDI_DS_RxMetaInfoType *)(pRxMeta))->mpduHeaderPtr )
Jeff Johnson295189b2012-06-20 16:38:30 -0700658
659/* WDA_GET_RX_MPDU_HEADER_LEN *************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700660# define WDA_GET_RX_MPDU_HEADER_LEN(pRxMeta) \
661 ( ((WDI_DS_RxMetaInfoType *)(pRxMeta))->mpduHeaderLength )
Jeff Johnson295189b2012-06-20 16:38:30 -0700662
663/* WDA_GET_RX_MPDU_LEN ********************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700664# define WDA_GET_RX_MPDU_LEN(pRxMeta) \
665 ( ((WDI_DS_RxMetaInfoType *)(pRxMeta))->mpduLength )
Jeff Johnson295189b2012-06-20 16:38:30 -0700666
667/* WDA_GET_RX_PAYLOAD_LEN ****************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700668# define WDA_GET_RX_PAYLOAD_LEN(pRxMeta) \
669 ( WDA_GET_RX_MPDU_LEN(pRxMeta) - WDA_GET_RX_MPDU_HEADER_LEN(pRxMeta) )
Jeff Johnson295189b2012-06-20 16:38:30 -0700670
671/* WDA_GET_RX_MAC_RATE_IDX ***************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700672# define WDA_GET_RX_MAC_RATE_IDX(pRxMeta) \
673 ( ((WDI_DS_RxMetaInfoType *)(pRxMeta))->rateIndex )
Jeff Johnson295189b2012-06-20 16:38:30 -0700674
675/* WDA_GET_RX_MPDU_DATA ******************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700676# define WDA_GET_RX_MPDU_DATA(pRxMeta) \
677 ( ((WDI_DS_RxMetaInfoType *)(pRxMeta))->mpduDataPtr )
Jeff Johnson295189b2012-06-20 16:38:30 -0700678
679/* WDA_GET_RX_MPDU_DATA_OFFSET ***********************************************/
680// For Integrated SOC: When UMAC receive the packet. BD is already stripped off.
681// Data offset is the MPDU header length
Jeff Johnson295189b2012-06-20 16:38:30 -0700682# define WDA_GET_RX_MPDU_DATA_OFFSET(pRxMeta) WDA_GET_RX_MPDU_HEADER_LEN(pRxMeta)
Jeff Johnson295189b2012-06-20 16:38:30 -0700683
684/* WDA_GET_RX_MPDU_HEADER_OFFSET *********************************************/
685// For Integrated SOC: We UMAC receive the frame,
686// BD is gone and MAC header at offset 0
Jeff Johnson295189b2012-06-20 16:38:30 -0700687# define WDA_GET_RX_MPDU_HEADER_OFFSET(pRxMeta) 0
Jeff Johnson295189b2012-06-20 16:38:30 -0700688
689/* WDA_GET_RX_UNKNOWN_UCAST **************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700690# define WDA_GET_RX_UNKNOWN_UCAST(pRxMeta) \
691 ( ((WDI_DS_RxMetaInfoType *)(pRxMeta))->unknownUcastPkt )
Jeff Johnson295189b2012-06-20 16:38:30 -0700692
693/* WDA_GET_RX_TID ************************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700694# define WDA_GET_RX_TID(pRxMeta) ( ((WDI_DS_RxMetaInfoType *)(pRxMeta))->tid )
Jeff Johnson295189b2012-06-20 16:38:30 -0700695
696/* WDA_GET_RX_STAID **********************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700697# define WDA_GET_RX_STAID(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->staId)
Jeff Johnson295189b2012-06-20 16:38:30 -0700698
699/* WDA_GET_RX_ADDR3_IDX ******************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700700# define WDA_GET_RX_ADDR3_IDX(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->addr3Idx)
Jeff Johnson295189b2012-06-20 16:38:30 -0700701
702/* WDA_GET_RX_CH *************************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700703# define WDA_GET_RX_CH(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->rxChannel)
Jeff Johnson295189b2012-06-20 16:38:30 -0700704
Kiran Kumar Lokere79540f92013-04-25 17:32:16 -0700705/* WDA_GET_RX_RFBAND *********************************************************/
706# define WDA_GET_RX_RFBAND(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->rfBand)
707
Jeff Johnson295189b2012-06-20 16:38:30 -0700708/* WDA_GET_RX_DPUSIG *********************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700709# define WDA_GET_RX_DPUSIG(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->dpuSig)
Jeff Johnson295189b2012-06-20 16:38:30 -0700710
711/* WDA_IS_RX_BCAST ***********************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700712# define WDA_IS_RX_BCAST(pRxMeta) \
713 ( (1 == ((WDI_DS_RxMetaInfoType*)(pRxMeta))->bcast) ? VOS_TRUE : VOS_FALSE )
Jeff Johnson295189b2012-06-20 16:38:30 -0700714
715/* WDA_GET_RX_FT_DONE ********************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700716# define WDA_GET_RX_FT_DONE(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->ft)
Jeff Johnson295189b2012-06-20 16:38:30 -0700717
718/* WDA_GET_RX_DPU_FEEDBACK **************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700719# define WDA_GET_RX_DPU_FEEDBACK(pRxMeta) \
720 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->dpuFeedback)
Jeff Johnson295189b2012-06-20 16:38:30 -0700721
722/* WDA_GET_RX_ASF ************************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700723# define WDA_GET_RX_ASF(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->amsdu_asf)
Jeff Johnson295189b2012-06-20 16:38:30 -0700724
725/* WDA_GET_RX_AEF ************************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700726# define WDA_GET_RX_AEF(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->amsdu_aef)
Jeff Johnson295189b2012-06-20 16:38:30 -0700727
728/* WDA_GET_RX_ESF ************************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700729# define WDA_GET_RX_ESF(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->amsdu_esf)
Jeff Johnson295189b2012-06-20 16:38:30 -0700730
731/* WDA_GET_RX_BEACON_SENT ****************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700732# define WDA_GET_RX_BEACON_SENT(pRxMeta) \
733 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->bsf)
Jeff Johnson295189b2012-06-20 16:38:30 -0700734
735/* WDA_GET_RX_TSF_LATER *****************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700736# define WDA_GET_RX_TSF_LATER(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->rtsf)
Jeff Johnson295189b2012-06-20 16:38:30 -0700737
738/* WDA_GET_RX_TYPE ***********************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700739# define WDA_GET_RX_TYPE(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->type)
Jeff Johnson295189b2012-06-20 16:38:30 -0700740
741/* WDA_GET_RX_SUBTYPE ********************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700742# define WDA_GET_RX_SUBTYPE(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->subtype)
Jeff Johnson295189b2012-06-20 16:38:30 -0700743
744/* WDA_GET_RX_TYPE_SUBTYPE ****************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700745# define WDA_GET_RX_TYPE_SUBTYPE(pRxMeta) \
746 ((WDA_GET_RX_TYPE(pRxMeta)<<4)|WDA_GET_RX_SUBTYPE(pRxMeta))
Jeff Johnson295189b2012-06-20 16:38:30 -0700747
748/* WDA_GET_RX_REORDER_OPCODE : For MSDU reorder *******************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700749# define WDA_GET_RX_REORDER_OPCODE(pRxMeta) \
750 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->ampdu_reorderOpcode)
Jeff Johnson295189b2012-06-20 16:38:30 -0700751
752/* WDA_GET_RX_REORDER_SLOT_IDX : For MSDU reorder ****************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700753# define WDA_GET_RX_REORDER_SLOT_IDX(pRxMeta) \
754 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->ampdu_reorderSlotIdx)
Jeff Johnson295189b2012-06-20 16:38:30 -0700755
756/* WDA_GET_RX_REORDER_FWD_IDX : For MSDU reorder *****************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700757# define WDA_GET_RX_REORDER_FWD_IDX(pRxMeta) \
758 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->ampdu_reorderFwdIdx)
Jeff Johnson295189b2012-06-20 16:38:30 -0700759
760/* WDA_GET_RX_REORDER_CUR_PKT_SEQ_NO : Fro MSDU reorder **********************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700761# define WDA_GET_RX_REORDER_CUR_PKT_SEQ_NO(pRxMeta) \
762 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->currentPktSeqNo)
Jeff Johnson295189b2012-06-20 16:38:30 -0700763
764/* WDA_IS_RX_LLC_PRESENT *****************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700765# define WDA_IS_RX_LLC_PRESENT(pRxMeta) \
766 ( (0 == ((WDI_DS_RxMetaInfoType*)(pRxMeta))->llcr) ? VOS_TRUE : VOS_FALSE )
Jeff Johnson295189b2012-06-20 16:38:30 -0700767
768#define WLANWDA_HO_IS_AN_AMPDU 0x4000
769#define WLANWDA_HO_LAST_MPDU_OF_AMPDU 0x400
770
771/* WDA_IS_RX_AN_AMPDU ********************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700772# define WDA_IS_RX_AN_AMPDU(pRxMeta) \
773 ( ((WDI_DS_RxMetaInfoType*)(pRxMeta))->rxpFlags & WLANWDA_HO_IS_AN_AMPDU )
Jeff Johnson295189b2012-06-20 16:38:30 -0700774
775/* WDA_IS_RX_LAST_MPDU *******************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700776# define WDA_IS_RX_LAST_MPDU(pRxMeta) \
777 ( ((WDI_DS_RxMetaInfoType*)(pRxMeta))->rxpFlags & WLANWDA_HO_LAST_MPDU_OF_AMPDU )
Jeff Johnson295189b2012-06-20 16:38:30 -0700778
779/* WDA_GET_RX_TIMESTAMP *****************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700780# define WDA_GET_RX_TIMESTAMP(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->mclkRxTimestamp)
Jeff Johnson295189b2012-06-20 16:38:30 -0700781
782/* WDA_IS_RX_IN_SCAN *********************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700783# define WDA_IS_RX_IN_SCAN(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->scan)
Varun Reddy Yeturud0a3f252013-04-15 21:58:13 -0700784#ifdef WLAN_FEATURE_ROAM_SCAN_OFFLOAD
785/* WDA_GET_OFFLOADSCANLEARN **************************************************/
786# define WDA_GET_OFFLOADSCANLEARN(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->offloadScanLearn)
787/* WDA_GET_ROAMCANDIDATEIND **************************************************/
788# define WDA_GET_ROAMCANDIDATEIND(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->roamCandidateInd)
789#endif
Dino Mycle41bdc942014-06-10 11:30:24 +0530790#ifdef WLAN_FEATURE_EXTSCAN
791#define WDA_GET_EXTSCANFULLSCANRESIND(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->extscanBuffer)
792#endif
Jeff Johnson295189b2012-06-20 16:38:30 -0700793/* WDA_GET_RX_RSSI_DB ********************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700794// Volans RF
795# define WDA_RSSI_OFFSET 100
796# define WDA_GET_RSSI0_DB(rssi0) (rssi0 - WDA_RSSI_OFFSET)
797# define WDA_GET_RSSI1_DB(rssi0) (0 - WDA_RSSI_OFFSET)
798# define WDA_MAX_OF_TWO(val1, val2) ( ((val1) > (val2)) ? (val1) : (val2))
799# define WDA_GET_RSSI_DB(rssi0) \
800 WDA_MAX_OF_TWO(WDA_GET_RSSI0_DB(rssi0), WDA_GET_RSSI1_DB(rssi0))
801# define WDA_GET_RX_RSSI_DB(pRxMeta) \
802 WDA_GET_RSSI_DB((((WDI_DS_RxMetaInfoType*)(pRxMeta))->rssi0))
Jeff Johnson295189b2012-06-20 16:38:30 -0700803
804/* WDA_GET_RX_SNR ************************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700805# define WDA_GET_RX_SNR(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->snr)
Jeff Johnson295189b2012-06-20 16:38:30 -0700806
807/* WDA_IS_RX_FC **************************************************************/
808// Flow control frames
Jeff Johnson295189b2012-06-20 16:38:30 -0700809/* FIXME WDA should provide the meta info which indicates FC frame
810 In the meantime, use hardcoded FALSE, since we don't support FC yet */
811# define WDA_IS_RX_FC(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->fc)
Jeff Johnson295189b2012-06-20 16:38:30 -0700812
813/* WDA_GET_RX_FC_VALID_STA_MASK **********************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700814# define WDA_GET_RX_FC_VALID_STA_MASK(pRxMeta) \
815 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->fcSTAValidMask)
Jeff Johnson295189b2012-06-20 16:38:30 -0700816
817/* WDA_GET_RX_FC_PWRSAVE_STA_MASK ********************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700818# define WDA_GET_RX_FC_PWRSAVE_STA_MASK(pRxMeta) \
819 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->fcSTAPwrSaveStateMask)
Jeff Johnson295189b2012-06-20 16:38:30 -0700820
821/* WDA_GET_RX_FC_STA_THRD_IND_MASK ********************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700822# define WDA_GET_RX_FC_STA_THRD_IND_MASK(pRxMeta) \
823 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->fcSTAThreshIndMask)
Jeff Johnson295189b2012-06-20 16:38:30 -0700824
825/* WDA_GET_RX_FC_FORCED_STA_TX_DISABLED_BITMAP ********************************************/
826# define WDA_GET_RX_FC_STA_TX_DISABLED_BITMAP(pRxMeta) \
827 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->fcStaTxDisabledBitmap)
828
829/* WDA_GET_RX_FC_STA_TXQ_LEN *************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700830# define WDA_GET_RX_FC_STA_TXQ_LEN(pRxMeta, staId) \
831 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->fcSTATxQLen[(staId)])
Jeff Johnson295189b2012-06-20 16:38:30 -0700832
833/* WDA_GET_RX_FC_STA_CUR_TXRATE **********************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700834# define WDA_GET_RX_FC_STA_CUR_TXRATE(pRxMeta, staId) \
835 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->fcSTACurTxRate[(staId)])
Jeff Johnson295189b2012-06-20 16:38:30 -0700836
837/* WDA_GET_RX_REPLAY_COUNT ***************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700838# define WDA_GET_RX_REPLAY_COUNT(pRxMeta) \
839 (((WDI_DS_RxMetaInfoType*)(pRxMeta))->replayCount)
Jeff Johnson295189b2012-06-20 16:38:30 -0700840
841/* WDA_GETRSSI0 ***************************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700842# define WDA_GETRSSI0(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->rssi0)
Jeff Johnson295189b2012-06-20 16:38:30 -0700843
844/* WDA_GETRSSI1 ***************************************************************/
Jeff Johnson295189b2012-06-20 16:38:30 -0700845# define WDA_GETRSSI1(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->rssi1)
Jeff Johnson295189b2012-06-20 16:38:30 -0700846
Chet Lanctot186b5732013-03-18 10:26:30 -0700847/* WDA_GET_RX_RMF *****************************************************/
848#ifdef WLAN_FEATURE_11W
849# define WDA_GET_RX_RMF(pRxMeta) (((WDI_DS_RxMetaInfoType*)(pRxMeta))->rmf)
850#endif
Jeff Johnson295189b2012-06-20 16:38:30 -0700851
852/* --------------------------------------------------------------------*/
853
Jeff Johnson295189b2012-06-20 16:38:30 -0700854uint8 WDA_IsWcnssWlanCompiledVersionGreaterThanOrEqual(uint8 major, uint8 minor, uint8 version, uint8 revision);
855uint8 WDA_IsWcnssWlanReportedVersionGreaterThanOrEqual(uint8 major, uint8 minor, uint8 version, uint8 revision);
856
857
858VOS_STATUS WDA_GetWcnssWlanCompiledVersion(v_PVOID_t pvosGCtx,
859 tSirVersionType *pVersion);
860VOS_STATUS WDA_GetWcnssWlanReportedVersion(v_PVOID_t pvosGCtx,
861 tSirVersionType *pVersion);
862VOS_STATUS WDA_GetWcnssSoftwareVersion(v_PVOID_t pvosGCtx,
863 tANI_U8 *pVersion,
864 tANI_U32 versionBufferSize);
865VOS_STATUS WDA_GetWcnssHardwareVersion(v_PVOID_t pvosGCtx,
866 tANI_U8 *pVersion,
867 tANI_U32 versionBufferSize);
868
869VOS_STATUS WDA_SetUapsdAcParamsReq(v_PVOID_t , v_U8_t , tUapsdInfo *);
870VOS_STATUS WDA_ClearUapsdAcParamsReq(v_PVOID_t , v_U8_t , wpt_uint8 );
871VOS_STATUS WDA_SetRSSIThresholdsReq(tpAniSirGlobal , tSirRSSIThresholds *);
872// Just declare the function extern here and save some time.
873extern tSirRetStatus halMmhForwardMBmsg(void*, tSirMbMsg*);
874tSirRetStatus uMacPostCtrlMsg(void* pSirGlobal, tSirMbMsg* pMb);
Jeff Johnson295189b2012-06-20 16:38:30 -0700875
876
Jeff Johnson295189b2012-06-20 16:38:30 -0700877#define WDA_MAX_TXPOWER_INVALID HAL_MAX_TXPOWER_INVALID
878
879//WDA Messages to HAL messages Mapping
880#if 0
881//Required by SME
882//#define WDA_SIGNAL_BT_EVENT SIR_HAL_SIGNAL_BT_EVENT - this is defined in sirParams.h
883//#define WDA_BTC_SET_CFG SIR_HAL_BTC_SET_CFG
884
885//Required by PE
886#define WDA_HOST_MSG_START SIR_HAL_HOST_MSG_START
887#define WDA_INITIAL_CAL_FAILED_NTF SIR_HAL_INITIAL_CAL_FAILED_NTF
888#define WDA_SHUTDOWN_REQ SIR_HAL_SHUTDOWN_REQ
889#define WDA_SHUTDOWN_CNF SIR_HAL_SHUTDOWN_CNF
890#define WDA_RADIO_ON_OFF_IND SIR_HAL_RADIO_ON_OFF_IND
891#define WDA_RESET_CNF SIR_HAL_RESET_CNF
892#define WDA_SetRegDomain \
Madan Mohan Koyyalamudic0d1b3f2012-11-13 10:41:07 -0800893 (eHalStatus halPhySetRegDomain(tHalHandle hHal, eRegDomainId regDomain))
Jeff Johnson295189b2012-06-20 16:38:30 -0700894#endif
895
896#define WDA_APP_SETUP_NTF SIR_HAL_APP_SETUP_NTF
897#define WDA_NIC_OPER_NTF SIR_HAL_NIC_OPER_NTF
898#define WDA_INIT_START_REQ SIR_HAL_INIT_START_REQ
899#define WDA_RESET_REQ SIR_HAL_RESET_REQ
900#define WDA_HDD_ADDBA_REQ SIR_HAL_HDD_ADDBA_REQ
901#define WDA_HDD_ADDBA_RSP SIR_HAL_HDD_ADDBA_RSP
902#define WDA_DELETEBA_IND SIR_HAL_DELETEBA_IND
903#define WDA_BA_FAIL_IND SIR_HAL_BA_FAIL_IND
904#define WDA_TL_FLUSH_AC_REQ SIR_TL_HAL_FLUSH_AC_REQ
905#define WDA_TL_FLUSH_AC_RSP SIR_HAL_TL_FLUSH_AC_RSP
906
907#define WDA_MSG_TYPES_BEGIN SIR_HAL_MSG_TYPES_BEGIN
Siddharth Bhal64246172015-02-27 01:04:37 +0530908#define WDA_EXT_MSG_TYPES_BEGIN SIR_HAL_EXT_MSG_TYPES_BEGIN
Jeff Johnson295189b2012-06-20 16:38:30 -0700909#define WDA_ITC_MSG_TYPES_BEGIN SIR_HAL_ITC_MSG_TYPES_BEGIN
910#define WDA_RADAR_DETECTED_IND SIR_HAL_RADAR_DETECTED_IND
911#define WDA_WDT_KAM_RSP SIR_HAL_WDT_KAM_RSP
912#define WDA_TIMER_TEMP_MEAS_REQ SIR_HAL_TIMER_TEMP_MEAS_REQ
913#define WDA_TIMER_PERIODIC_STATS_COLLECT_REQ SIR_HAL_TIMER_PERIODIC_STATS_COLLECT_REQ
914#define WDA_CAL_REQ_NTF SIR_HAL_CAL_REQ_NTF
915#define WDA_MNT_OPEN_TPC_TEMP_MEAS_REQ SIR_HAL_MNT_OPEN_TPC_TEMP_MEAS_REQ
916#define WDA_CCA_MONITOR_INTERVAL_TO SIR_HAL_CCA_MONITOR_INTERVAL_TO
917#define WDA_CCA_MONITOR_DURATION_TO SIR_HAL_CCA_MONITOR_DURATION_TO
918#define WDA_CCA_MONITOR_START SIR_HAL_CCA_MONITOR_START
919#define WDA_CCA_MONITOR_STOP SIR_HAL_CCA_MONITOR_STOP
920#define WDA_CCA_CHANGE_MODE SIR_HAL_CCA_CHANGE_MODE
921#define WDA_TIMER_WRAP_AROUND_STATS_COLLECT_REQ SIR_HAL_TIMER_WRAP_AROUND_STATS_COLLECT_REQ
922
923/*
924 * New Taurus related messages
925 */
926#define WDA_ADD_STA_REQ SIR_HAL_ADD_STA_REQ
927#define WDA_ADD_STA_RSP SIR_HAL_ADD_STA_RSP
928#define WDA_ADD_STA_SELF_RSP SIR_HAL_ADD_STA_SELF_RSP
929#define WDA_DEL_STA_SELF_RSP SIR_HAL_DEL_STA_SELF_RSP
930#define WDA_DELETE_STA_REQ SIR_HAL_DELETE_STA_REQ
931#define WDA_DELETE_STA_RSP SIR_HAL_DELETE_STA_RSP
932#define WDA_ADD_BSS_REQ SIR_HAL_ADD_BSS_REQ
933#define WDA_ADD_BSS_RSP SIR_HAL_ADD_BSS_RSP
934#define WDA_DELETE_BSS_REQ SIR_HAL_DELETE_BSS_REQ
935#define WDA_DELETE_BSS_RSP SIR_HAL_DELETE_BSS_RSP
936#define WDA_INIT_SCAN_REQ SIR_HAL_INIT_SCAN_REQ
937#define WDA_INIT_SCAN_RSP SIR_HAL_INIT_SCAN_RSP
938#define WDA_START_SCAN_REQ SIR_HAL_START_SCAN_REQ
939#define WDA_START_SCAN_RSP SIR_HAL_START_SCAN_RSP
940#define WDA_END_SCAN_REQ SIR_HAL_END_SCAN_REQ
941#define WDA_END_SCAN_RSP SIR_HAL_END_SCAN_RSP
942#define WDA_FINISH_SCAN_REQ SIR_HAL_FINISH_SCAN_REQ
943#define WDA_FINISH_SCAN_RSP SIR_HAL_FINISH_SCAN_RSP
944#define WDA_SEND_BEACON_REQ SIR_HAL_SEND_BEACON_REQ
945#define WDA_SEND_BEACON_RSP SIR_HAL_SEND_BEACON_RSP
946
947#define WDA_INIT_CFG_REQ SIR_HAL_INIT_CFG_REQ
948#define WDA_INIT_CFG_RSP SIR_HAL_INIT_CFG_RSP
949
950#define WDA_INIT_WM_CFG_REQ SIR_HAL_INIT_WM_CFG_REQ
951#define WDA_INIT_WM_CFG_RSP SIR_HAL_INIT_WM_CFG_RSP
952
953#define WDA_SET_BSSKEY_REQ SIR_HAL_SET_BSSKEY_REQ
954#define WDA_SET_BSSKEY_RSP SIR_HAL_SET_BSSKEY_RSP
955#define WDA_SET_STAKEY_REQ SIR_HAL_SET_STAKEY_REQ
956#define WDA_SET_STAKEY_RSP SIR_HAL_SET_STAKEY_RSP
957#define WDA_DPU_STATS_REQ SIR_HAL_DPU_STATS_REQ
958#define WDA_DPU_STATS_RSP SIR_HAL_DPU_STATS_RSP
959#define WDA_GET_DPUINFO_REQ SIR_HAL_GET_DPUINFO_REQ
960#define WDA_GET_DPUINFO_RSP SIR_HAL_GET_DPUINFO_RSP
961
962#define WDA_UPDATE_EDCA_PROFILE_IND SIR_HAL_UPDATE_EDCA_PROFILE_IND
963
964#define WDA_UPDATE_STARATEINFO_REQ SIR_HAL_UPDATE_STARATEINFO_REQ
965#define WDA_UPDATE_STARATEINFO_RSP SIR_HAL_UPDATE_STARATEINFO_RSP
966
967#define WDA_UPDATE_BEACON_IND SIR_HAL_UPDATE_BEACON_IND
968#define WDA_UPDATE_CF_IND SIR_HAL_UPDATE_CF_IND
969#define WDA_CHNL_SWITCH_REQ SIR_HAL_CHNL_SWITCH_REQ
970#define WDA_ADD_TS_REQ SIR_HAL_ADD_TS_REQ
971#define WDA_DEL_TS_REQ SIR_HAL_DEL_TS_REQ
972#define WDA_SOFTMAC_TXSTAT_REPORT SIR_HAL_SOFTMAC_TXSTAT_REPORT
973
974#define WDA_MBOX_SENDMSG_COMPLETE_IND SIR_HAL_MBOX_SENDMSG_COMPLETE_IND
975#define WDA_EXIT_BMPS_REQ SIR_HAL_EXIT_BMPS_REQ
976#define WDA_EXIT_BMPS_RSP SIR_HAL_EXIT_BMPS_RSP
977#define WDA_EXIT_BMPS_IND SIR_HAL_EXIT_BMPS_IND
978#define WDA_ENTER_BMPS_REQ SIR_HAL_ENTER_BMPS_REQ
979#define WDA_ENTER_BMPS_RSP SIR_HAL_ENTER_BMPS_RSP
980#define WDA_BMPS_STATUS_IND SIR_HAL_BMPS_STATUS_IND
981#define WDA_MISSED_BEACON_IND SIR_HAL_MISSED_BEACON_IND
982
983#define WDA_CFG_RXP_FILTER_REQ SIR_HAL_CFG_RXP_FILTER_REQ
984#define WDA_CFG_RXP_FILTER_RSP SIR_HAL_CFG_RXP_FILTER_RSP
985
986#define WDA_SWITCH_CHANNEL_RSP SIR_HAL_SWITCH_CHANNEL_RSP
987#define WDA_P2P_NOA_ATTR_IND SIR_HAL_P2P_NOA_ATTR_IND
Viral Modid86bde22012-12-10 13:09:21 -0800988#define WDA_P2P_NOA_START_IND SIR_HAL_P2P_NOA_START_IND
Jeff Johnson295189b2012-06-20 16:38:30 -0700989#define WDA_PWR_SAVE_CFG SIR_HAL_PWR_SAVE_CFG
990
991#define WDA_REGISTER_PE_CALLBACK SIR_HAL_REGISTER_PE_CALLBACK
992#define WDA_SOFTMAC_MEM_READREQUEST SIR_HAL_SOFTMAC_MEM_READREQUEST
993#define WDA_SOFTMAC_MEM_WRITEREQUEST SIR_HAL_SOFTMAC_MEM_WRITEREQUEST
994
995#define WDA_SOFTMAC_MEM_READRESPONSE SIR_HAL_SOFTMAC_MEM_READRESPONSE
996#define WDA_SOFTMAC_BULKREGWRITE_CONFIRM SIR_HAL_SOFTMAC_BULKREGWRITE_CONFIRM
997#define WDA_SOFTMAC_BULKREGREAD_RESPONSE SIR_HAL_SOFTMAC_BULKREGREAD_RESPONSE
998#define WDA_SOFTMAC_HOSTMESG_MSGPROCESSRESULT SIR_HAL_SOFTMAC_HOSTMESG_MSGPROCESSRESULT
999
1000#define WDA_ADDBA_REQ SIR_HAL_ADDBA_REQ
1001#define WDA_ADDBA_RSP SIR_HAL_ADDBA_RSP
1002#define WDA_DELBA_IND SIR_HAL_DELBA_IND
1003#define WDA_DEL_BA_IND SIR_HAL_DEL_BA_IND
1004#define WDA_MIC_FAILURE_IND SIR_HAL_MIC_FAILURE_IND
1005
1006//message from sme to initiate delete block ack session.
1007#define WDA_DELBA_REQ SIR_HAL_DELBA_REQ
1008#define WDA_IBSS_STA_ADD SIR_HAL_IBSS_STA_ADD
1009#define WDA_TIMER_ADJUST_ADAPTIVE_THRESHOLD_IND SIR_HAL_TIMER_ADJUST_ADAPTIVE_THRESHOLD_IND
1010#define WDA_SET_LINK_STATE SIR_HAL_SET_LINK_STATE
1011#define WDA_SET_LINK_STATE_RSP SIR_HAL_SET_LINK_STATE_RSP
1012#define WDA_ENTER_IMPS_REQ SIR_HAL_ENTER_IMPS_REQ
1013#define WDA_ENTER_IMPS_RSP SIR_HAL_ENTER_IMPS_RSP
1014#define WDA_EXIT_IMPS_RSP SIR_HAL_EXIT_IMPS_RSP
1015#define WDA_EXIT_IMPS_REQ SIR_HAL_EXIT_IMPS_REQ
1016#define WDA_SOFTMAC_HOSTMESG_PS_STATUS_IND SIR_HAL_SOFTMAC_HOSTMESG_PS_STATUS_IND
1017#define WDA_POSTPONE_ENTER_IMPS_RSP SIR_HAL_POSTPONE_ENTER_IMPS_RSP
1018#define WDA_STA_STAT_REQ SIR_HAL_STA_STAT_REQ
1019#define WDA_GLOBAL_STAT_REQ SIR_HAL_GLOBAL_STAT_REQ
1020#define WDA_AGGR_STAT_REQ SIR_HAL_AGGR_STAT_REQ
1021#define WDA_STA_STAT_RSP SIR_HAL_STA_STAT_RSP
1022#define WDA_GLOBAL_STAT_RSP SIR_HAL_GLOBAL_STAT_RSP
1023#define WDA_AGGR_STAT_RSP SIR_HAL_AGGR_STAT_RSP
1024#define WDA_STAT_SUMM_REQ SIR_HAL_STAT_SUMM_REQ
1025#define WDA_STAT_SUMM_RSP SIR_HAL_STAT_SUMM_RSP
1026#define WDA_REMOVE_BSSKEY_REQ SIR_HAL_REMOVE_BSSKEY_REQ
1027#define WDA_REMOVE_BSSKEY_RSP SIR_HAL_REMOVE_BSSKEY_RSP
1028#define WDA_REMOVE_STAKEY_REQ SIR_HAL_REMOVE_STAKEY_REQ
1029#define WDA_REMOVE_STAKEY_RSP SIR_HAL_REMOVE_STAKEY_RSP
1030#define WDA_SET_STA_BCASTKEY_REQ SIR_HAL_SET_STA_BCASTKEY_REQ
1031#define WDA_SET_STA_BCASTKEY_RSP SIR_HAL_SET_STA_BCASTKEY_RSP
1032#define WDA_REMOVE_STA_BCASTKEY_REQ SIR_HAL_REMOVE_STA_BCASTKEY_REQ
1033#define WDA_REMOVE_STA_BCASTKEY_RSP SIR_HAL_REMOVE_STA_BCASTKEY_RSP
1034#define WDA_ADD_TS_RSP SIR_HAL_ADD_TS_RSP
1035#define WDA_DPU_MIC_ERROR SIR_HAL_DPU_MIC_ERROR
1036#define WDA_TIMER_BA_ACTIVITY_REQ SIR_HAL_TIMER_BA_ACTIVITY_REQ
1037#define WDA_TIMER_CHIP_MONITOR_TIMEOUT SIR_HAL_TIMER_CHIP_MONITOR_TIMEOUT
1038#define WDA_TIMER_TRAFFIC_ACTIVITY_REQ SIR_HAL_TIMER_TRAFFIC_ACTIVITY_REQ
1039#define WDA_TIMER_ADC_RSSI_STATS SIR_HAL_TIMER_ADC_RSSI_STATS
Madan Mohan Koyyalamudi01cba042013-01-10 21:56:05 -08001040#define WDA_TIMER_TRAFFIC_STATS_IND SIR_HAL_TRAFFIC_STATS_IND
1041
Chet Lanctot186b5732013-03-18 10:26:30 -07001042#ifdef WLAN_FEATURE_11W
1043#define WDA_EXCLUDE_UNENCRYPTED_IND SIR_HAL_EXCLUDE_UNENCRYPTED_IND
1044#endif
Jeff Johnson295189b2012-06-20 16:38:30 -07001045
Varun Reddy Yeturu5d5e2c62014-02-27 13:31:29 -08001046#ifdef FEATURE_WLAN_ESE
Jeff Johnson295189b2012-06-20 16:38:30 -07001047#define WDA_TSM_STATS_REQ SIR_HAL_TSM_STATS_REQ
1048#define WDA_TSM_STATS_RSP SIR_HAL_TSM_STATS_RSP
1049#endif
Jeff Johnson295189b2012-06-20 16:38:30 -07001050#define WDA_UPDATE_PROBE_RSP_IE_BITMAP_IND SIR_HAL_UPDATE_PROBE_RSP_IE_BITMAP_IND
1051#define WDA_UPDATE_UAPSD_IND SIR_HAL_UPDATE_UAPSD_IND
Jeff Johnson295189b2012-06-20 16:38:30 -07001052
1053#define WDA_SET_MIMOPS_REQ SIR_HAL_SET_MIMOPS_REQ
1054#define WDA_SET_MIMOPS_RSP SIR_HAL_SET_MIMOPS_RSP
1055#define WDA_SYS_READY_IND SIR_HAL_SYS_READY_IND
1056#define WDA_SET_TX_POWER_REQ SIR_HAL_SET_TX_POWER_REQ
1057#define WDA_SET_TX_POWER_RSP SIR_HAL_SET_TX_POWER_RSP
1058#define WDA_GET_TX_POWER_REQ SIR_HAL_GET_TX_POWER_REQ
1059#define WDA_GET_TX_POWER_RSP SIR_HAL_GET_TX_POWER_RSP
1060#define WDA_GET_NOISE_REQ SIR_HAL_GET_NOISE_REQ
1061#define WDA_GET_NOISE_RSP SIR_HAL_GET_NOISE_RSP
1062#define WDA_SET_TX_PER_TRACKING_REQ SIR_HAL_SET_TX_PER_TRACKING_REQ
1063
1064/* Messages to support transmit_halt and transmit_resume */
1065#define WDA_TRANSMISSION_CONTROL_IND SIR_HAL_TRANSMISSION_CONTROL_IND
1066/* Indication from LIM to HAL to Initialize radar interrupt */
1067#define WDA_INIT_RADAR_IND SIR_HAL_INIT_RADAR_IND
1068/* Messages to support transmit_halt and transmit_resume */
1069
1070
1071#define WDA_BEACON_PRE_IND SIR_HAL_BEACON_PRE_IND
1072#define WDA_ENTER_UAPSD_REQ SIR_HAL_ENTER_UAPSD_REQ
1073#define WDA_ENTER_UAPSD_RSP SIR_HAL_ENTER_UAPSD_RSP
1074#define WDA_EXIT_UAPSD_REQ SIR_HAL_EXIT_UAPSD_REQ
1075#define WDA_EXIT_UAPSD_RSP SIR_HAL_EXIT_UAPSD_RSP
1076#define WDA_LOW_RSSI_IND SIR_HAL_LOW_RSSI_IND
1077#define WDA_BEACON_FILTER_IND SIR_HAL_BEACON_FILTER_IND
1078/// PE <-> HAL WOWL messages
1079#define WDA_WOWL_ADD_BCAST_PTRN SIR_HAL_WOWL_ADD_BCAST_PTRN
1080#define WDA_WOWL_DEL_BCAST_PTRN SIR_HAL_WOWL_DEL_BCAST_PTRN
1081#define WDA_WOWL_ENTER_REQ SIR_HAL_WOWL_ENTER_REQ
1082#define WDA_WOWL_ENTER_RSP SIR_HAL_WOWL_ENTER_RSP
1083#define WDA_WOWL_EXIT_REQ SIR_HAL_WOWL_EXIT_REQ
1084#define WDA_WOWL_EXIT_RSP SIR_HAL_WOWL_EXIT_RSP
1085#define WDA_TX_COMPLETE_IND SIR_HAL_TX_COMPLETE_IND
1086#define WDA_TIMER_RA_COLLECT_AND_ADAPT SIR_HAL_TIMER_RA_COLLECT_AND_ADAPT
1087/// PE <-> HAL statistics messages
1088#define WDA_GET_STATISTICS_REQ SIR_HAL_GET_STATISTICS_REQ
1089#define WDA_GET_STATISTICS_RSP SIR_HAL_GET_STATISTICS_RSP
1090#define WDA_SET_KEY_DONE SIR_HAL_SET_KEY_DONE
1091
1092/// PE <-> HAL BTC messages
1093#define WDA_BTC_SET_CFG SIR_HAL_BTC_SET_CFG
1094#define WDA_SIGNAL_BT_EVENT SIR_HAL_SIGNAL_BT_EVENT
1095#define WDA_HANDLE_FW_MBOX_RSP SIR_HAL_HANDLE_FW_MBOX_RSP
1096#define WDA_UPDATE_PROBE_RSP_TEMPLATE_IND SIR_HAL_UPDATE_PROBE_RSP_TEMPLATE_IND
1097#define WDA_SIGNAL_BTAMP_EVENT SIR_HAL_SIGNAL_BTAMP_EVENT
1098
Jeff Johnsone7245742012-09-05 17:12:55 -07001099#ifdef FEATURE_OEM_DATA_SUPPORT
1100/* PE <-> HAL OEM_DATA RELATED MESSAGES */
1101#define WDA_START_OEM_DATA_REQ SIR_HAL_START_OEM_DATA_REQ
1102#define WDA_START_OEM_DATA_RSP SIR_HAL_START_OEM_DATA_RSP
1103#define WDA_FINISH_OEM_DATA_REQ SIR_HAL_FINISH_OEM_DATA_REQ
1104#endif
Jeff Johnson295189b2012-06-20 16:38:30 -07001105
1106#define WDA_SET_MAX_TX_POWER_REQ SIR_HAL_SET_MAX_TX_POWER_REQ
1107#define WDA_SET_MAX_TX_POWER_RSP SIR_HAL_SET_MAX_TX_POWER_RSP
1108
Arif Hussaina5ebce02013-08-09 15:09:58 -07001109#define WDA_SET_MAX_TX_POWER_PER_BAND_REQ \
1110 SIR_HAL_SET_MAX_TX_POWER_PER_BAND_REQ
1111#define WDA_SET_MAX_TX_POWER_PER_BAND_RSP \
1112 SIR_HAL_SET_MAX_TX_POWER_PER_BAND_RSP
1113
Jeff Johnson295189b2012-06-20 16:38:30 -07001114#define WDA_SEND_MSG_COMPLETE SIR_HAL_SEND_MSG_COMPLETE
1115
1116/// PE <-> HAL Host Offload message
1117#define WDA_SET_HOST_OFFLOAD SIR_HAL_SET_HOST_OFFLOAD
1118
1119/// PE <-> HAL Keep Alive message
1120#define WDA_SET_KEEP_ALIVE SIR_HAL_SET_KEEP_ALIVE
1121
1122#ifdef WLAN_NS_OFFLOAD
1123#define WDA_SET_NS_OFFLOAD SIR_HAL_SET_NS_OFFLOAD
1124#endif //WLAN_NS_OFFLOAD
1125#define WDA_ADD_STA_SELF_REQ SIR_HAL_ADD_STA_SELF_REQ
1126#define WDA_DEL_STA_SELF_REQ SIR_HAL_DEL_STA_SELF_REQ
1127
Jeff Johnson295189b2012-06-20 16:38:30 -07001128#define WDA_SET_P2P_GO_NOA_REQ SIR_HAL_SET_P2P_GO_NOA_REQ
Gopichand Nakkala79ff85d2013-05-27 17:05:29 +05301129#define WDA_SET_TDLS_LINK_ESTABLISH_REQ SIR_HAL_TDLS_LINK_ESTABLISH_REQ
1130#define WDA_SET_TDLS_LINK_ESTABLISH_REQ_RSP SIR_HAL_TDLS_LINK_ESTABLISH_REQ_RSP
Jeff Johnson295189b2012-06-20 16:38:30 -07001131
Madan Mohan Koyyalamudia53c4dc2012-11-13 10:35:42 -08001132#define WDA_TX_COMPLETE_TIMEOUT_IND (WDA_MSG_TYPES_END - 1)
Jeff Johnson295189b2012-06-20 16:38:30 -07001133#define WDA_WLAN_SUSPEND_IND SIR_HAL_WLAN_SUSPEND_IND
1134#define WDA_WLAN_RESUME_REQ SIR_HAL_WLAN_RESUME_REQ
1135#define WDA_MSG_TYPES_END SIR_HAL_MSG_TYPES_END
1136
Jeff Johnson295189b2012-06-20 16:38:30 -07001137#define WDA_MMH_TXMB_READY_EVT SIR_HAL_MMH_TXMB_READY_EVT
1138#define WDA_MMH_RXMB_DONE_EVT SIR_HAL_MMH_RXMB_DONE_EVT
1139#define WDA_MMH_MSGQ_NE_EVT SIR_HAL_MMH_MSGQ_NE_EVT
Jeff Johnson295189b2012-06-20 16:38:30 -07001140
1141#ifdef WLAN_FEATURE_VOWIFI_11R
1142#define WDA_AGGR_QOS_REQ SIR_HAL_AGGR_QOS_REQ
1143#define WDA_AGGR_QOS_RSP SIR_HAL_AGGR_QOS_RSP
1144#endif /* WLAN_FEATURE_VOWIFI_11R */
1145
Jeff Johnson295189b2012-06-20 16:38:30 -07001146/* FTM CMD MSG */
1147#define WDA_FTM_CMD_REQ SIR_PTT_MSG_TYPES_BEGIN
1148#define WDA_FTM_CMD_RSP SIR_PTT_MSG_TYPES_END
Jeff Johnson295189b2012-06-20 16:38:30 -07001149
1150#ifdef FEATURE_WLAN_SCAN_PNO
1151/*Requests sent to lower driver*/
1152#define WDA_SET_PNO_REQ SIR_HAL_SET_PNO_REQ
1153#define WDA_SET_RSSI_FILTER_REQ SIR_HAL_SET_RSSI_FILTER_REQ
1154#define WDA_UPDATE_SCAN_PARAMS_REQ SIR_HAL_UPDATE_SCAN_PARAMS
1155
1156/*Indication comming from lower driver*/
1157#define WDA_SET_PNO_CHANGED_IND SIR_HAL_SET_PNO_CHANGED_IND
1158#endif // FEATURE_WLAN_SCAN_PNO
1159
Varun Reddy Yeturud0a3f252013-04-15 21:58:13 -07001160#ifdef WLAN_FEATURE_ROAM_SCAN_OFFLOAD
Varun Reddy Yeturu920df212013-05-22 08:07:23 -07001161#define WDA_ROAM_SCAN_OFFLOAD_REQ SIR_HAL_ROAM_SCAN_OFFLOAD_REQ
Varun Reddy Yeturucc661d22013-05-20 11:47:10 -07001162#define WDA_ROAM_SCAN_OFFLOAD_RSP SIR_HAL_ROAM_SCAN_OFFLOAD_RSP
Varun Reddy Yeturud0a3f252013-04-15 21:58:13 -07001163#endif
1164
Jeff Johnson295189b2012-06-20 16:38:30 -07001165#ifdef WLAN_WAKEUP_EVENTS
1166#define WDA_WAKE_REASON_IND SIR_HAL_WAKE_REASON_IND
1167#endif // WLAN_WAKEUP_EVENTS
1168
1169#ifdef WLAN_FEATURE_PACKET_FILTERING
1170#define WDA_8023_MULTICAST_LIST_REQ SIR_HAL_8023_MULTICAST_LIST_REQ
1171#define WDA_RECEIVE_FILTER_SET_FILTER_REQ SIR_HAL_RECEIVE_FILTER_SET_FILTER_REQ
1172#define WDA_PACKET_COALESCING_FILTER_MATCH_COUNT_REQ SIR_HAL_PACKET_COALESCING_FILTER_MATCH_COUNT_REQ
1173#define WDA_PACKET_COALESCING_FILTER_MATCH_COUNT_RSP SIR_HAL_PACKET_COALESCING_FILTER_MATCH_COUNT_RSP
1174#define WDA_RECEIVE_FILTER_CLEAR_FILTER_REQ SIR_HAL_RECEIVE_FILTER_CLEAR_FILTER_REQ
1175#endif // WLAN_FEATURE_PACKET_FILTERING
1176
1177#define WDA_SET_POWER_PARAMS_REQ SIR_HAL_SET_POWER_PARAMS_REQ
Sundaresan Ramachandran76e48e82013-07-15 13:07:17 +05301178#define WDA_DHCP_START_IND SIR_HAL_DHCP_START_IND
1179#define WDA_DHCP_STOP_IND SIR_HAL_DHCP_STOP_IND
1180
Jeff Johnson295189b2012-06-20 16:38:30 -07001181
1182#ifdef WLAN_FEATURE_GTK_OFFLOAD
1183#define WDA_GTK_OFFLOAD_REQ SIR_HAL_GTK_OFFLOAD_REQ
1184#define WDA_GTK_OFFLOAD_GETINFO_REQ SIR_HAL_GTK_OFFLOAD_GETINFO_REQ
1185#define WDA_GTK_OFFLOAD_GETINFO_RSP SIR_HAL_GTK_OFFLOAD_GETINFO_RSP
1186#endif //WLAN_FEATURE_GTK_OFFLOAD
1187
1188#define WDA_SET_TM_LEVEL_REQ SIR_HAL_SET_TM_LEVEL_REQ
1189
Mohit Khanna4a70d262012-09-11 16:30:12 -07001190#ifdef WLAN_FEATURE_11AC
1191#define WDA_UPDATE_OP_MODE SIR_HAL_UPDATE_OP_MODE
1192#endif
1193
Srinivas Girigowdad34cedb2013-01-25 13:33:11 -08001194#define WDA_GET_ROAM_RSSI_REQ SIR_HAL_GET_ROAM_RSSI_REQ
1195#define WDA_GET_ROAM_RSSI_RSP SIR_HAL_GET_ROAM_RSSI_RSP
1196
Ganesh Kondabattinif0fa07c2013-06-11 17:47:49 +05301197#define WDA_START_SCAN_OFFLOAD_REQ SIR_HAL_START_SCAN_OFFLOAD_REQ
1198#define WDA_START_SCAN_OFFLOAD_RSP SIR_HAL_START_SCAN_OFFLOAD_RSP
Gopichand Nakkala09358592013-06-13 14:47:55 +05301199#define WDA_STOP_SCAN_OFFLOAD_REQ SIR_HAL_STOP_SCAN_OFFLOAD_REQ
1200#define WDA_STOP_SCAN_OFFLOAD_RSP SIR_HAL_STOP_SCAN_OFFLOAD_RSP
Ganesh Kondabattinif0fa07c2013-06-11 17:47:49 +05301201#define WDA_UPDATE_CHAN_LIST_REQ SIR_HAL_UPDATE_CHAN_LIST_REQ
1202#define WDA_UPDATE_CHAN_LIST_RSP SIR_HAL_UPDATE_CHAN_LIST_RSP
1203#define WDA_RX_SCAN_EVENT SIR_HAL_RX_SCAN_EVENT
Ravi Joshid2ca7c42013-07-23 08:37:49 -07001204#define WDA_IBSS_PEER_INACTIVITY_IND SIR_HAL_IBSS_PEER_INACTIVITY_IND
Ganesh Kondabattinif0fa07c2013-06-11 17:47:49 +05301205
Leo Chang9056f462013-08-01 19:21:11 -07001206#ifdef FEATURE_WLAN_LPHB
1207#define WDA_LPHB_CONF_REQ SIR_HAL_LPHB_CONF_IND
1208#define WDA_LPHB_WAIT_EXPIRE_IND SIR_HAL_LPHB_WAIT_EXPIRE_IND
1209#endif /* FEATURE_WLAN_LPHB */
1210
Yue Mab9c86f42013-08-14 15:59:08 -07001211#define WDA_ADD_PERIODIC_TX_PTRN_IND SIR_HAL_ADD_PERIODIC_TX_PTRN_IND
1212#define WDA_DEL_PERIODIC_TX_PTRN_IND SIR_HAL_DEL_PERIODIC_TX_PTRN_IND
1213
Rajeev79dbe4c2013-10-05 11:03:42 +05301214#ifdef FEATURE_WLAN_BATCH_SCAN
1215#define WDA_SET_BATCH_SCAN_REQ SIR_HAL_SET_BATCH_SCAN_REQ
1216#define WDA_SET_BATCH_SCAN_RSP SIR_HAL_SET_BATCH_SCAN_RSP
1217#define WDA_STOP_BATCH_SCAN_IND SIR_HAL_STOP_BATCH_SCAN_IND
1218#define WDA_TRIGGER_BATCH_SCAN_RESULT_IND SIR_HAL_TRIGGER_BATCH_SCAN_RESULT_IND
1219#endif
Chittajit Mitraf5413a42013-10-18 14:20:08 -07001220#define WDA_RATE_UPDATE_IND SIR_HAL_RATE_UPDATE_IND
1221
Rajeev79dbe4c2013-10-05 11:03:42 +05301222
Sandeep Puligilla8b8b74b2014-02-10 16:39:05 +05301223#define WDA_HT40_OBSS_SCAN_IND SIR_HAL_HT40_OBSS_SCAN_IND
1224#define WDA_HT40_OBSS_STOP_SCAN_IND SIR_HAL_HT40_OBSS_STOP_SCAN_IND
c_hpothu92367912014-05-01 15:18:17 +05301225
1226#define WDA_GET_BCN_MISS_RATE_REQ SIR_HAL_BCN_MISS_RATE_REQ
Srinivas Dasari4dae48f2014-11-26 21:14:16 +05301227#define WDA_ENCRYPT_MSG_REQ SIR_HAL_ENCRYPT_MSG_REQ
1228#define WDA_ENCRYPT_MSG_RSP SIR_HAL_ENCRYPT_MSG_RSP
c_hpothu92367912014-05-01 15:18:17 +05301229
Sunil Duttbd736ed2014-05-26 21:19:41 +05301230#ifdef WLAN_FEATURE_LINK_LAYER_STATS
1231#define WDA_LINK_LAYER_STATS_CLEAR_REQ SIR_HAL_LL_STATS_CLEAR_REQ
1232#define WDA_LINK_LAYER_STATS_SET_REQ SIR_HAL_LL_STATS_SET_REQ
1233#define WDA_LINK_LAYER_STATS_GET_REQ SIR_HAL_LL_STATS_GET_REQ
1234#define WDA_LINK_LAYER_STATS_RESULTS_RSP SIR_HAL_LL_STATS_RESULTS_RSP
1235#endif /* WLAN_FEATURE_LINK_LAYER_STATS */
1236
Atul Mittalc0f739f2014-07-31 13:47:47 +05301237#ifdef FEATURE_WLAN_TDLS
1238// tdlsoffchan
1239#define WDA_SET_TDLS_CHAN_SWITCH_REQ SIR_HAL_TDLS_CHAN_SWITCH_REQ
1240#define WDA_SET_TDLS_CHAN_SWITCH_REQ_RSP SIR_HAL_TDLS_CHAN_SWITCH_REQ_RSP
1241#endif
Abhishek Singh85b74712014-10-08 11:38:19 +05301242
1243#define WDA_FW_STATS_GET_REQ SIR_HAL_FW_STATS_GET_REQ
Jeff Johnson295189b2012-06-20 16:38:30 -07001244tSirRetStatus wdaPostCtrlMsg(tpAniSirGlobal pMac, tSirMsgQ *pMsg);
Jeff Johnson295189b2012-06-20 16:38:30 -07001245
Abhishek Singha306a442013-11-07 18:39:01 +05301246eHalStatus WDA_SetRegDomain(void * clientCtxt, v_REGDOMAIN_t regId,
1247 tAniBool sendRegHint);
Jeff Johnson295189b2012-06-20 16:38:30 -07001248
Dino Mycle41bdc942014-06-10 11:30:24 +05301249#ifdef WLAN_FEATURE_EXTSCAN
1250#define WDA_EXTSCAN_GET_CAPABILITIES_REQ SIR_HAL_EXTSCAN_GET_CAPABILITIES_REQ
1251#define WDA_EXTSCAN_GET_CAPABILITIES_RSP SIR_HAL_EXTSCAN_GET_CAPABILITIES_RSP
1252#define WDA_EXTSCAN_START_REQ SIR_HAL_EXTSCAN_START_REQ
1253#define WDA_EXTSCAN_START_RSP SIR_HAL_EXTSCAN_START_RSP
1254#define WDA_EXTSCAN_STOP_REQ SIR_HAL_EXTSCAN_STOP_REQ
1255#define WDA_EXTSCAN_STOP_RSP SIR_HAL_EXTSCAN_STOP_RSP
1256#define WDA_EXTSCAN_SET_BSSID_HOTLIST_REQ SIR_HAL_EXTSCAN_SET_BSS_HOTLIST_REQ
1257#define WDA_EXTSCAN_SET_BSSID_HOTLIST_RSP SIR_HAL_EXTSCAN_SET_BSS_HOTLIST_RSP
1258#define WDA_EXTSCAN_RESET_BSSID_HOTLIST_REQ SIR_HAL_EXTSCAN_RESET_BSS_HOTLIST_REQ
1259#define WDA_EXTSCAN_RESET_BSSID_HOTLIST_RSP SIR_HAL_EXTSCAN_RESET_BSS_HOTLIST_RSP
1260#define WDA_EXTSCAN_SET_SIGNF_RSSI_CHANGE_REQ SIR_HAL_EXTSCAN_SET_SIGNF_RSSI_CHANGE_REQ
1261#define WDA_EXTSCAN_SET_SIGNF_RSSI_CHANGE_RSP SIR_HAL_EXTSCAN_SET_SIGNF_RSSI_CHANGE_RSP
1262#define WDA_EXTSCAN_RESET_SIGNF_RSSI_CHANGE_REQ SIR_HAL_EXTSCAN_RESET_SIGNF_RSSI_CHANGE_REQ
1263#define WDA_EXTSCAN_RESET_SIGNF_RSSI_CHANGE_RSP SIR_HAL_EXTSCAN_RESET_SIGNF_RSSI_CHANGE_RSP
1264#define WDA_EXTSCAN_GET_CACHED_RESULTS_REQ SIR_HAL_EXTSCAN_GET_CACHED_RESULTS_REQ
1265#define WDA_EXTSCAN_GET_CACHED_RESULTS_RSP SIR_HAL_EXTSCAN_GET_CACHED_RESULTS_RSP
1266
1267#define WDA_EXTSCAN_PROGRESS_IND SIR_HAL_EXTSCAN_PROGRESS_IND
1268#define WDA_EXTSCAN_SCAN_AVAILABLE_IND SIR_HAL_EXTSCAN_SCAN_AVAILABLE_IND
1269#define WDA_EXTSCAN_SCAN_RESULT_IND SIR_HAL_EXTSCAN_SCAN_RESULT_IND
1270#define WDA_EXTSCAN_BSSID_HOTLIST_RESULT_IND SIR_HAL_EXTSCAN_HOTLIST_MATCH_IND
1271#define WDA_EXTSCAN_SIGNF_RSSI_RESULT_IND SIR_HAL_EXTSCAN_SIGNF_WIFI_CHANGE_IND
1272#endif /* WLAN_FEATURE_EXTSCAN */
1273
Siddharth Bhal171788a2014-09-29 21:02:40 +05301274#define WDA_SPOOF_MAC_ADDR_REQ SIR_HAL_SPOOF_MAC_ADDR_REQ
Siddharth Bhal029d6732014-10-09 21:31:23 +05301275#define WDA_SPOOF_MAC_ADDR_RSP SIR_HAL_SPOOF_MAC_ADDR_RSP
Dino Mycle41bdc942014-06-10 11:30:24 +05301276
Siddharth Bhalb7c421c2015-02-27 00:26:09 +05301277#define WDA_MGMT_LOGGING_INIT_REQ SIR_HAL_MGMT_LOGGING_INIT_REQ
Siddharth Bhal64246172015-02-27 01:04:37 +05301278#define WDA_GET_FRAME_LOG_REQ SIR_HAL_GET_FRAME_LOG_REQ
Siddharth Bhalb7c421c2015-02-27 00:26:09 +05301279
Jeff Johnson295189b2012-06-20 16:38:30 -07001280#define HAL_USE_BD_RATE2_FOR_MANAGEMENT_FRAME 0x40 // Bit 6 will be used to control BD rate for Management frames
1281
Jeff Johnson295189b2012-06-20 16:38:30 -07001282#define halTxFrame(hHal, pFrmBuf, frmLen, frmType, txDir, tid, pCompFunc, pData, txFlag) \
1283 (eHalStatus)( WDA_TxPacket(\
1284 vos_get_context(VOS_MODULE_ID_WDA, vos_get_global_context(VOS_MODULE_ID_WDA, (hHal))),\
1285 (pFrmBuf),\
1286 (frmLen),\
1287 (frmType),\
1288 (txDir),\
1289 (tid),\
1290 (pCompFunc),\
1291 (pData),\
1292 (NULL), \
1293 (txFlag)) )
1294
1295#define halTxFrameWithTxComplete(hHal, pFrmBuf, frmLen, frmType, txDir, tid, pCompFunc, pData, pCBackFnTxComp, txFlag) \
1296 (eHalStatus)( WDA_TxPacket(\
1297 vos_get_context(VOS_MODULE_ID_WDA, vos_get_global_context(VOS_MODULE_ID_WDA, (hHal))),\
1298 (pFrmBuf),\
1299 (frmLen),\
1300 (frmType),\
1301 (txDir),\
1302 (tid),\
1303 (pCompFunc),\
1304 (pData),\
1305 (pCBackFnTxComp), \
1306 (txFlag)) )
Jeff Johnson295189b2012-06-20 16:38:30 -07001307
1308/* -----------------------------------------------------------------
1309 WDA data path API's for TL
1310 -------------------------------------------------------------------*/
1311
Jeff Johnson295189b2012-06-20 16:38:30 -07001312v_BOOL_t WDA_IsHwFrameTxTranslationCapable(v_PVOID_t pVosGCtx,
1313 tANI_U8 staIdx);
Jeff Johnson295189b2012-06-20 16:38:30 -07001314
Katya Nigam6201c3e2014-05-27 17:51:42 +05301315v_BOOL_t WDA_IsSelfSTA(v_PVOID_t pVosGCtx,tANI_U8 staIdx);
1316
Jeff Johnson295189b2012-06-20 16:38:30 -07001317# define WDA_EnableUapsdAcParams(vosGCtx, staId, uapsdInfo) \
1318 WDA_SetUapsdAcParamsReq(vosGCtx, staId, uapsdInfo)
Jeff Johnson295189b2012-06-20 16:38:30 -07001319
Jeff Johnson295189b2012-06-20 16:38:30 -07001320# define WDA_DisableUapsdAcParams(vosGCtx, staId, ac) \
1321 WDA_ClearUapsdAcParamsReq(vosGCtx, staId, ac)
Jeff Johnson295189b2012-06-20 16:38:30 -07001322
Jeff Johnson295189b2012-06-20 16:38:30 -07001323# define WDA_SetRSSIThresholds(pMac, pThresholds) \
1324 WDA_SetRSSIThresholdsReq(pMac, pThresholds)
Jeff Johnson295189b2012-06-20 16:38:30 -07001325
Jeff Johnson295189b2012-06-20 16:38:30 -07001326#define WDA_UpdateRssiBmps(pvosGCtx, staId, rssi) \
Madan Mohan Koyyalamudia53c4dc2012-11-13 10:35:42 -08001327 WLANTL_UpdateRssiBmps(pvosGCtx, staId, rssi)
Jeff Johnson295189b2012-06-20 16:38:30 -07001328
Madan Mohan Koyyalamudid9383fd2013-08-13 09:27:30 +05301329#define WDA_UpdateSnrBmps(pvosGCtx, staId, rssi) \
1330 WLANTL_UpdateSnrBmps(pvosGCtx, staId, snr)
1331
1332#define WDA_GetSnr(staId, snr) \
1333 WLANTL_GetSnr(staId, snr)
1334
Gopichand Nakkala8a2b1442013-05-29 15:33:14 +05301335#define WDA_UpdateLinkCapacity(pvosGCtx, staId, linkCapacity) \
1336 WLANTL_UpdateLinkCapacity(pvosGCtx, staId, linkCapacity)
1337
Jeff Johnson295189b2012-06-20 16:38:30 -07001338#ifdef WLAN_PERF
1339/*==========================================================================
1340 FUNCTION WDA_TLI_FastHwFwdDataFrame
1341
1342 DESCRIPTION
1343 For NON integrated SOC, this function is called by TL.
1344
1345 Fast path function to quickly forward a data frame if HAL determines BD
1346 signature computed here matches the signature inside current VOSS packet.
1347 If there is a match, HAL and TL fills in the swapped packet length into
1348 BD header and DxE header, respectively. Otherwise, packet goes back to
1349 normal (slow) path and a new BD signature would be tagged into BD in this
1350 VOSS packet later by the WLANHAL_FillTxBd() function.
1351
1352 TODO For integrated SOC, this function does nothing yet. Pima SLM/HAL
1353 should provide the equivelant functionality.
1354
1355 DEPENDENCIES
1356
1357 PARAMETERS
1358
1359 IN
1360 pvosGCtx VOS context
1361 vosDataBuff Ptr to VOSS packet
1362 pMetaInfo For getting frame's TID
1363 pStaInfo For checking STA type
1364
1365 OUT
1366 pvosStatus returned status
1367 puFastFwdOK Flag to indicate whether frame could be fast forwarded
1368
1369 RETURN VALUE
1370 No return.
1371
1372 SIDE EFFECTS
1373
1374============================================================================*/
1375void WDA_TLI_FastHwFwdDataFrame
1376(
1377 v_PVOID_t pvosGCtx,
1378 vos_pkt_t* vosDataBuff,
1379 VOS_STATUS* pvosStatus,
1380 v_U32_t* puFastFwdOK,
1381 WLANTL_MetaInfoType* pMetaInfo,
1382 WLAN_STADescType* pStaInfo
1383);
1384#endif /* WLAN_PERF */
1385
1386/*==========================================================================
1387 FUNCTION WDA_DS_Register
1388
1389 DESCRIPTION
1390 Register TL client to WDA. This function registers TL RX/TX functions
1391 to WDI by calling WDI_DS_Register.
1392
1393
1394 For NON integrated SOC, this function calls WLANBAL_RegTlCbFunctions
1395 to register TL's RX/TX functions to BAL
1396
1397 TODO
1398 For Prima, pfnResourceCB gets called in WDTS_OOResourceNotification.
1399 The uCount parameter is AC mask. It should be redefined to use the
1400 same resource callback function.
1401
1402 DEPENDENCIES
1403
1404 PARAMETERS
1405
1406 IN
1407 pvosGCtx VOS context
1408 pfnTxCompleteCallback TX complete callback upon TX completion
1409 pfnRxPacketCallback RX callback
1410 pfnResourceCB gets called when updating TX PDU number
1411 uResTheshold minimum TX PDU size for a packet
1412 pCallbackContext WDI calls callback function with it
1413 VOS global context pointer
1414 OUT
1415 uAvailableTxBuf available TX PDU numbder.
1416 BAL returns it for NON integrated SOC
1417
1418 RETURN VALUE
1419 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1420 VOS_STATUS_SUCCESS: Everything is good :)
1421
1422 SIDE EFFECTS
1423
1424============================================================================*/
1425VOS_STATUS
1426WDA_DS_Register
1427(
1428 v_PVOID_t pvosGCtx,
1429 WDA_DS_TxCompleteCallback pfnTxCompleteCallback,
1430 WDA_DS_RxPacketCallback pfnRxPacketCallback,
1431 WDA_DS_TxPacketCallback pfnTxPacketCallback,
1432 WDA_DS_ResourceCB pfnResourceCB,
1433 v_U32_t uResTheshold,
1434 v_PVOID_t pCallbackContext,
1435 v_U32_t *uAvailableTxBuf
1436);
1437
1438/*==========================================================================
1439 FUNCTION WDA_DS_StartXmit
1440
1441 DESCRIPTION
1442 Serialize TX transmit reques to TX thread.
1443
1444 TODO This sends TX transmit request to TL. It should send to WDI for
1445 abstraction.
1446
1447 For NON integrated SOC, this function calls WLANBAL_StartXmit
1448
1449 DEPENDENCIES
1450
1451 PARAMETERS
1452
1453 IN
1454 pvosGCtx VOS context
1455
1456 RETURN VALUE
1457 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1458 VOS_STATUS_SUCCESS: Everything is good :)
1459
1460 SIDE EFFECTS
1461
1462============================================================================*/
1463VOS_STATUS
1464WDA_DS_StartXmit
1465(
1466 v_PVOID_t pvosGCtx
1467);
1468
1469/*==========================================================================
1470 FUNCTION WDA_DS_FinishULA
1471
1472 DESCRIPTION
1473 Serialize Finish Upper Level Authentication reques to TX thread.
1474
1475 DEPENDENCIES
1476
1477 PARAMETERS
1478
1479 IN
1480 callbackRoutine routine to be called in TX thread
1481 callbackContext user data for the above routine
1482
1483 RETURN VALUE
1484 please see vos_tx_mq_serialize
1485
1486 SIDE EFFECTS
1487
1488============================================================================*/
1489VOS_STATUS
1490WDA_DS_FinishULA
1491(
1492 void (*callbackRoutine) (void *callbackContext),
Tushnim Bhattacharyya39a8f182013-02-20 18:10:30 -08001493 void *callbackContext
Jeff Johnson295189b2012-06-20 16:38:30 -07001494);
1495
1496/*==========================================================================
1497 FUNCTION WDA_DS_BuildTxPacketInfo
1498
1499 DESCRIPTION
1500 Build TX meta info for integrated SOC.
1501
1502 Same function calls HAL for reserve BD header space into VOS packet and
1503 HAL function to fill it.
1504
1505 DEPENDENCIES
1506
1507 PARAMETERS
1508
1509 IN
1510 pvosGCtx VOS context
1511 vosDataBuff vos data buffer
1512 pvDestMacAddr destination MAC address ponter
1513 ucDisableFrmXtl Is frame xtl disabled?
1514 ucQosEnabled Is QoS enabled?
1515 ucWDSEnabled Is WDS enabled?
1516 extraHeadSpace Extra head bytes. If it's not 0 due to 4 bytes align
1517 of BD header.
1518 typeSubtype typeSubtype from MAC header or TX metainfo/BD
1519 pAddr2 address 2
1520 uTid tid
1521 txFlag
1522 timeStamp
1523 ucIsEapol
1524 ucUP
1525
1526 OUT
1527 *pusPktLen Packet length
1528
1529 RETURN VALUE
1530 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1531 VOS_STATUS_SUCCESS: Everything is good :)
1532
1533 SIDE EFFECTS
1534
1535============================================================================*/
1536VOS_STATUS
1537WDA_DS_BuildTxPacketInfo
1538(
1539 v_PVOID_t pvosGCtx,
1540 vos_pkt_t* vosDataBuff,
1541 v_MACADDR_t* pvDestMacAddr,
1542 v_U8_t ucDisableFrmXtl,
1543 v_U16_t* pusPktLen,
1544 v_U8_t ucQosEnabled,
1545 v_U8_t ucWDSEnabled,
1546 v_U8_t extraHeadSpace,
1547 v_U8_t typeSubtype,
1548 v_PVOID_t pAddr2,
1549 v_U8_t uTid,
Kanchanapally, Vidyullathaf9426e52013-12-24 17:28:54 +05301550 v_U32_t txFlag,
Jeff Johnson295189b2012-06-20 16:38:30 -07001551 v_U32_t timeStamp,
1552 v_U8_t ucIsEapol,
1553 v_U8_t ucUP
1554);
1555
1556/*==========================================================================
1557 FUNCTION WDA_DS_PeekRxPacketInfo
1558
1559 DESCRIPTION
1560 Return RX metainfo pointer for for integrated SOC.
1561
1562 Same function will return BD header pointer.
1563
1564 DEPENDENCIES
1565
1566 PARAMETERS
1567
1568 IN
1569 vosDataBuff vos data buffer
1570
1571 pvDestMacAddr destination MAC address ponter
1572 bSwap Want to swap BD header? For backward compatability
1573 It does nothing for integrated SOC
1574 OUT
1575 *ppRxHeader RX metainfo pointer
1576
1577 RETURN VALUE
1578 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1579 VOS_STATUS_SUCCESS: Everything is good :)
1580
1581 SIDE EFFECTS
1582
1583============================================================================*/
1584VOS_STATUS
1585WDA_DS_PeekRxPacketInfo
1586(
1587 vos_pkt_t *vosDataBuff,
1588 v_PVOID_t *ppRxHeader,
1589 v_BOOL_t bSwap
1590);
1591
1592/*==========================================================================
1593 FUNCTION WDA_DS_TrimRxPacketInfo
1594
1595 DESCRIPTION
1596 Trim/Remove RX BD header for NON integrated SOC.
1597 It does nothing for integrated SOC.
1598
1599 DEPENDENCIES
1600
1601 PARAMETERS
1602
1603 IN
1604 vosDataBuff vos data buffer
1605
1606 RETURN VALUE
1607 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1608 VOS_STATUS_SUCCESS: Everything is good :)
1609
1610 SIDE EFFECTS
1611
1612============================================================================*/
1613VOS_STATUS
1614WDA_DS_TrimRxPacketInfo
1615(
1616 vos_pkt_t *vosDataBuff
1617);
1618
1619/*==========================================================================
1620 FUNCTION WDA_DS_GetTxResources
1621
1622 DESCRIPTION
1623 It does return hardcoded value for Prima. It should bigger number than 0.
1624 Returning 0 will put TL in out-of-resource condition for TX.
1625
1626 Return current PDU resources from BAL for NON integrated SOC.
1627
1628 DEPENDENCIES
1629
1630 PARAMETERS
1631
1632 IN
1633 vosDataBuff vos data buffer
1634
1635 OUT
1636 puResCount available PDU number for TX
1637
1638 RETURN VALUE
1639 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1640 VOS_STATUS_SUCCESS: Everything is good :)
1641
1642 SIDE EFFECTS
1643
1644============================================================================*/
1645VOS_STATUS
1646WDA_DS_GetTxResources
1647(
1648 v_PVOID_t pvosGCtx,
1649 v_U32_t* puResCount
1650);
1651
1652/*==========================================================================
1653 FUNCTION WDA_DS_GetRssi
1654
1655 DESCRIPTION
1656 Get RSSI
1657
1658 TODO It returns hardcoded value in the meantime since WDA/WDI does nothing
1659 support it yet for Prima.
1660
1661 DEPENDENCIES
1662
1663 PARAMETERS
1664
1665 IN
1666 vosDataBuff vos data buffer
1667
1668 OUT
1669 puRssi RSSI
1670
1671 RETURN VALUE
1672 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1673 VOS_STATUS_SUCCESS: Everything is good :)
1674
1675 SIDE EFFECTS
1676
1677============================================================================*/
1678VOS_STATUS
1679WDA_DS_GetRssi
1680(
1681 v_PVOID_t pvosGCtx,
1682 v_S7_t* puRssi
1683);
1684
1685/*==========================================================================
1686 FUNCTION WDA_DS_RxAmsduBdFix
1687
1688 DESCRIPTION
1689 For backward compatability with Libra/Volans. Need to call HAL function
1690 for HW BD bug fix
1691
1692 It does nothing for integrated SOC.
1693
1694 DEPENDENCIES
1695
1696 PARAMETERS
1697
1698 IN
1699 pvosGCtx VOS context
1700 pvBDHeader BD header pointer
1701
1702 OUT
1703
1704 RETURN VALUE
1705 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1706 VOS_STATUS_SUCCESS: Everything is good :)
1707
1708 SIDE EFFECTS
1709
1710============================================================================*/
1711VOS_STATUS
1712WDA_DS_RxAmsduBdFix
1713(
1714 v_PVOID_t pvosGCtx,
1715 v_PVOID_t pvBDHeader
1716);
1717
1718/*==========================================================================
1719 FUNCTION WDA_DS_GetFrameTypeSubType
1720
1721 DESCRIPTION
1722 Get typeSubtype from the packet. The BD header should have this.
1723 But some reason, Libra/Volans read it from 802.11 header and save it
1724 back to BD header. So for NON integrated SOC, this function does
1725 the same.
1726
1727 For integrated SOC, WDI does the same, not TL.
1728 It does return typeSubtype from RX meta info for integrated SOC.
1729
1730 DEPENDENCIES
1731
1732 PARAMETERS
1733
1734 IN
1735 pvosGCtx VOS context
1736 vosDataBuff vos data buffer
1737 pRxHeader RX meta info or BD header pointer
1738
1739 OUT
1740 ucTypeSubtype typeSubtype
1741
1742 RETURN VALUE
1743 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1744 VOS_STATUS_SUCCESS: Everything is good :)
1745
1746 SIDE EFFECTS
1747
1748============================================================================*/
1749VOS_STATUS
1750WDA_DS_GetFrameTypeSubType
1751(
1752 v_PVOID_t pvosGCtx,
1753 vos_pkt_t *vosDataBuff,
1754 v_PVOID_t pRxHeader,
1755 v_U8_t *ucTypeSubtype
1756);
1757
1758/*==========================================================================
1759 FUNCTION WDA_DS_GetReplayCounter
1760
1761 DESCRIPTION
1762 Return replay counter from BD header or RX meta info
1763
1764 DEPENDENCIES
1765
1766 PARAMETERS
1767
1768 IN
1769 pRxHeader RX meta info or BD header pointer
1770
1771 OUT
1772
1773 RETURN VALUE
1774 Replay Counter
1775
1776 SIDE EFFECTS
1777
1778============================================================================*/
1779v_U64_t
1780WDA_DS_GetReplayCounter
1781(
1782 v_PVOID_t pRxHeader
1783);
1784
1785/*==========================================================================
1786 FUNCTION WDA_DS_GetReplayCounter
1787
1788 DESCRIPTION
1789 HO support. Set RSSI threshold via HAL function for NON integrated SOC
1790
1791 TODO
1792 Same function should be provided by WDA/WDI for Prima.
1793
1794 DEPENDENCIES
1795
1796 PARAMETERS
1797
1798 IN
1799 pMac MAC global pointer
1800 pThresholds pointer of threshold structure to set.
1801
1802 OUT
1803
1804 RETURN VALUE
1805 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1806 VOS_STATUS_SUCCESS: Everything is good :)
1807
1808 SIDE EFFECTS
1809
1810============================================================================*/
1811VOS_STATUS
1812WDA_DS_SetRSSIThresholds
1813(
1814 tpAniSirGlobal pMac,
1815 tpSirRSSIThresholds pThresholds
1816);
1817
Jeff Johnson295189b2012-06-20 16:38:30 -07001818/*==========================================================================
1819 FUNCTION WDA_DS_TxFrames
1820
1821 DESCRIPTION
1822 Pull packets from TL and push them to WDI. It gets invoked upon
1823 WDA_DS_TX_START_XMIT.
1824
1825 This function is equivelant of WLANSSC_Transmit in Libra/Volans.
1826
1827 TODO
1828 This function should be implemented and moved in WDI.
1829
1830 DEPENDENCIES
1831
1832 PARAMETERS
1833
1834 IN
1835 pvosGCtx VOS context
1836
1837 OUT
1838
1839 RETURN VALUE
1840 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1841 VOS_STATUS_SUCCESS: Everything is good :)
1842
1843 SIDE EFFECTS
1844
1845============================================================================*/
1846VOS_STATUS
1847WDA_DS_TxFrames
1848(
1849 v_PVOID_t pvosGCtx
1850);
Jeff Johnson295189b2012-06-20 16:38:30 -07001851
1852/*==========================================================================
1853 FUNCTION WDA_DS_TxFlowControlCallback
1854
1855 DESCRIPTION
1856 Invoked by WDI to control TX flow.
1857
1858 DEPENDENCIES
1859
1860 PARAMETERS
1861
1862 IN
1863 pvosGCtx VOS context
1864 uFlowMask TX channel mask for flow control
1865 Defined in WDA_TXFlowEnumType
1866
1867 OUT
1868
1869 RETURN VALUE
1870
1871 SIDE EFFECTS
1872
1873============================================================================*/
1874v_VOID_t
1875WDA_DS_TxFlowControlCallback
1876(
1877 v_PVOID_t pvosGCtx,
1878 v_U8_t uFlowMask
1879);
1880
1881/*==========================================================================
1882 FUNCTION WDA_DS_GetTxFlowMask
1883
1884 DESCRIPTION
1885 return TX flow mask control value
1886
1887 DEPENDENCIES
1888
1889 PARAMETERS
1890
1891 IN
1892 pvosGCtx VOS context
1893
1894 OUT
1895 uFlowMask TX channel mask for flow control
1896 Defined in WDA_TXFlowEnumType
1897
1898 RETURN VALUE
1899 VOS_STATUS_E_INVAL: pointer is NULL and other errors
1900 VOS_STATUS_SUCCESS: Everything is good :)
1901
1902 SIDE EFFECTS
1903
1904============================================================================*/
1905VOS_STATUS
1906WDA_DS_GetTxFlowMask
1907(
1908 v_PVOID_t pvosGCtx,
1909 v_U8_t* puFlowMask
1910);
1911
1912/*==========================================================================
Nirav Shah4f765af2015-01-21 19:51:30 +05301913 FUNCTION WDA_DS_GetAvailableResCount
1914
1915 DESCRIPTION
1916 It returns Available resource count for appropriate Pool Type
1917
1918 DEPENDENCIES
1919
1920 PARAMETERS
1921
1922 IN
1923 pvosGCtx vos context
1924 wdiResPool Pool Type
1925
1926 RETURN VALUE
1927 Available resource count
1928
1929============================================================================*/
1930uint32
1931WDA_DS_GetAvailableResCount
1932(
1933 v_PVOID_t pvosGCtx,
1934 WDI_ResPoolType wdiResPool
1935);
1936
1937
1938/*==========================================================================
Jeff Johnson295189b2012-06-20 16:38:30 -07001939 FUNCTION WDA_HALDumpCmdReq
1940
1941 DESCRIPTION
1942 Send Dump commandsto WDI
1943
1944 DEPENDENCIES
1945
1946 PARAMETERS
1947
1948 IN
1949 pMac MAC global pointer
Siddharth Bhal68115602015-01-18 20:44:55 +05301950 cmd Hal dump command
1951 arg1 Dump command argument 1
1952 arg2 Dump command argument 2
1953 arg3 Dump command argument 3
1954 arg4 Dump command argument 4
1955 async Asynchronous event. Doesn't wait for rsp.
Jeff Johnson295189b2012-06-20 16:38:30 -07001956
1957 OUT
1958 pBuffer Dump command Response buffer
1959
1960 RETURN VALUE
1961 VOS_STATUS_E_FAULT: pointer is NULL and other errors
1962 VOS_STATUS_SUCCESS: Everything is good :)
1963
1964 SIDE EFFECTS
1965
1966============================================================================*/
1967VOS_STATUS WDA_HALDumpCmdReq(tpAniSirGlobal pMac,tANI_U32 cmd,
1968 tANI_U32 arg1, tANI_U32 arg2, tANI_U32 arg3,
Siddharth Bhal68115602015-01-18 20:44:55 +05301969 tANI_U32 arg4, tANI_U8 *pBuffer, wpt_boolean async);
Jeff Johnson295189b2012-06-20 16:38:30 -07001970
1971/*==========================================================================
1972 FUNCTION WDA_featureCapsExchange
1973
1974 DESCRIPTION
1975 WDA API to invoke capability exchange between host and FW
1976
1977 DEPENDENCIES
1978
1979 PARAMETERS
1980
1981 IN
1982 pVosContext VOS context
1983
1984 OUT
1985 NONE
1986
1987 RETURN VALUE
1988 NONE
1989
1990 SIDE EFFECTS
1991============================================================================*/
1992void WDA_featureCapsExchange(v_PVOID_t pVosContext);
1993
Yathish9f22e662012-12-10 14:21:35 -08001994void WDA_disableCapablityFeature(tANI_U8 feature_index);
Jeff Johnson295189b2012-06-20 16:38:30 -07001995/*==========================================================================
1996 FUNCTION WDA_getHostWlanFeatCaps
1997
1998 DESCRIPTION
1999 Wrapper for WDI API, that will return if the feature (enum value).passed
2000 to this API is supported or not in Host
2001
2002 DEPENDENCIES
2003
2004 PARAMETERS
2005
2006 IN
2007 featEnumValue enum value for the feature as in placeHolderInCapBitmap in wlan_hal_msg.h.
2008
2009 OUT
2010 NONE
2011
2012 RETURN VALUE
2013 0 - implies feature is NOT Supported
2014 any non zero value - implies feature is SUPPORTED
2015
2016 SIDE EFFECTS
2017============================================================================*/
2018tANI_U8 WDA_getHostWlanFeatCaps(tANI_U8 featEnumValue);
2019
2020/*==========================================================================
2021 FUNCTION WDA_getFwWlanFeatCaps
2022
2023 DESCRIPTION
2024 Wrapper for WDI API, that will return if the feature (enum value).passed
2025 to this API is supported or not in FW
2026
2027 DEPENDENCIES
2028
2029 PARAMETERS
2030
2031 IN
2032 featEnumValue enum value for the feature as in placeHolderInCapBitmap in wlan_hal_msg.h.
2033
2034 OUT
2035 NONE
2036
2037 RETURN VALUE
2038 0 - implies feature is NOT Supported
2039 any non zero value - implies feature is SUPPORTED
2040
2041 SIDE EFFECTS
2042============================================================================*/
2043tANI_U8 WDA_getFwWlanFeatCaps(tANI_U8 featEnumValue);
2044
Madan Mohan Koyyalamudi8cb53982012-09-28 14:34:47 -07002045/*==========================================================================
2046 FUNCTION WDA_TransportChannelDebug
2047
2048 DESCRIPTION
2049 Display Transport Channel debugging information
2050 User may request to display DXE channel snapshot
2051 Or if host driver detects any abnormal stcuk may display
2052
2053 PARAMETERS
schang6295e542013-03-12 15:31:23 -07002054 pMac : upper MAC context pointer
Jeff Johnsonb88db982012-12-10 13:34:59 -08002055 displaySnapshot : Display DXE snapshot option
Mihir Shete40a55652014-03-02 14:14:47 +05302056 debugFlags : Enable stall detect features
2057 defined by WPAL_DeviceDebugFlags
2058 These features may effect
2059 data performance.
Madan Mohan Koyyalamudi8cb53982012-09-28 14:34:47 -07002060
2061 RETURN VALUE
2062 NONE
2063
2064===========================================================================*/
2065void WDA_TransportChannelDebug
2066(
schang6295e542013-03-12 15:31:23 -07002067 tpAniSirGlobal pMac,
2068 v_BOOL_t displaySnapshot,
Mihir Shete40a55652014-03-02 14:14:47 +05302069 v_U8_t debugFlags
Madan Mohan Koyyalamudi8cb53982012-09-28 14:34:47 -07002070);
Madan Mohan Koyyalamudi01cba042013-01-10 21:56:05 -08002071
2072/*==========================================================================
2073 FUNCTION WDA_TrafficStatsTimerActivate
2074
2075 DESCRIPTION
2076 API to activate/deactivate Traffic Stats timer. Traffic stats timer is only needed during MCC
2077 PARAMETERS
2078 activate : Activate or not
2079
2080 RETURN VALUE
2081 NONE
2082
2083===========================================================================*/
2084void WDA_TrafficStatsTimerActivate(wpt_boolean activate);
2085
Gopichand Nakkalae620d5a2013-04-26 05:45:57 -07002086/*==========================================================================
2087 FUNCTION WDA_SetEnableSSR
2088
2089 DESCRIPTION
2090 API to enable/disable SSR on WDI timeout
2091
2092 PARAMETERS
2093 enableSSR : enable/disable SSR
2094
2095 RETURN VALUE
2096 NONE
2097
2098===========================================================================*/
2099void WDA_SetEnableSSR(v_BOOL_t enableSSR);
Jeff Johnson295189b2012-06-20 16:38:30 -07002100#endif