blob: 06de40f9bb75d595f85dc175f24edbc809ecb909 [file] [log] [blame]
Jeff Johnson295189b2012-06-20 16:38:30 -07001/*
Gopichand Nakkala92f07d82013-01-08 21:16:34 -08002 * Copyright (c) 2012-2013, The Linux Foundation. All rights reserved.
3 *
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/*
Jeff Johnson32d95a32012-09-10 13:15:23 -070022 * Copyright (c) 2012, The Linux Foundation. All rights reserved.
Jeff Johnson295189b2012-06-20 16:38:30 -070023 *
24 * Previously licensed under the ISC license by Qualcomm Atheros, Inc.
25 *
26 *
27 * Permission to use, copy, modify, and/or distribute this software for
28 * any purpose with or without fee is hereby granted, provided that the
29 * above copyright notice and this permission notice appear in all
30 * copies.
31 *
32 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
33 * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
34 * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
35 * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
36 * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
37 * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
38 * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
39 * PERFORMANCE OF THIS SOFTWARE.
40 */
41
42/*
43 * Airgo Networks, Inc proprietary. All rights reserved.
44 * This file wniApi.h contains message definitions exported by
45 * Sirius software modules.
46 * NOTE: See projects/sirius/include/sirApi.h for structure
47 * definitions of the host/FW messages.
48 *
49 * Author: Chandra Modumudi
50 * Date: 04/11/2002
51 * History:-
52 * Date Modified by Modification Information
53 * --------------------------------------------------------------------
54 */
55
56#ifndef __WNI_API_H
57#define __WNI_API_H
58
59// DPH return error codes
60#define ANI_DPH_SUCCESS 0
61
62#define ANI_DPH_RX_STA_INVALID 1
63
64#define ANI_DPH_DO_TKIP 2
65
66#define ANI_DPH_PORT_BLOCKED 3
67#define ANI_DPH_TX_PUSH_ERROR 10
68#define ANI_DPH_TX_MAC_HDR_ERROR 11
69#define ANI_DPH_TX_INVALID_PAYLOAD 12
70#define ANI_DPH_TX_STA_INVALID 13
71#define ANI_DPH_TX_HASH_MISS 14
72#define ANI_DPH_TX_UNINITIALIZED 15
73#define ANI_DPH_TX_RADIO_IN_DIAG_MODE 16
74#define ANI_DPH_WMM_DROP 17
75#define ANI_DPH_APSD_DROP 18
76#define ANI_DPH_UNKNOWN_STA 19
77
78/// HDD type for special handling of BDs in the TX pkts
79/// Used in the structure ani_mod_info_t->bd_spl_proc_type
80#define ANI_HDD_NO_SPL_PROC 0
81#define ANI_HDD_DUMMY_PKT_SPL_PROC 1
82#define ANI_HDD_PRE_DUMMY_PKT_SPL_PROC 2
83#define ANI_HDD_WNS_L2_UPDATE_SPL_PROC 3
84#define ANI_HDD_DUMMY_DATA 4
85#ifdef WMM_APSD
86#define ANI_HDD_EOSP_PKT 5
87#endif
88
89/// Message offset for the cmd to enqueue a dummy pkt to HDD TD ring
90#define ANI_DUMMY_PKT_MSG_TYPE_OFFSET 0
91#define ANI_DUMMY_PKT_MSG_LEN_OFFSET 2
92#define ANI_DUMMY_PKT_MAC_ADDR_OFFSET 4
93#define ANI_DUMMY_PKT_STA_ID_OFFSET 10
94#define ANI_DUMMY_PKT_RT_FL_OFFSET 12
95#define ANI_DUMMY_PKT_MSG_LEN 16
96#define ANI_DUMMY_DATA_PAYLOAD_OFFSET 10
97
98/**
99 * Product IDs stored in the EEPROM for the different types of AP radio cards
100 * supported by Polaris
101 */
102#define AGN1323AR_00 4
103#define AGN1323AR_01 5
104#define AGN1223AR_00 6
105#define AGN1223AR_01 7
106#define AGN1223AR_02 8
107#define AGN_EEP_PRODUCT_ID_MAX 8
108
109
110
111
112/// Start of Sirius/Host message types
Saurabh Gupta775073c2013-02-14 13:31:36 +0530113#define WNI_HOST_MSG_START 0x1400
Jeff Johnson295189b2012-06-20 16:38:30 -0700114
115enum eWniMsgTypes
116{
117 /// CFG message types
118 eWNI_CFG_MSG_TYPES_BEGIN=WNI_HOST_MSG_START,
119 eWNI_CFG_MSG_TYPES_END=eWNI_CFG_MSG_TYPES_BEGIN+0xFF,
120
121 /// SME message types
122 eWNI_SME_MSG_TYPES_BEGIN=eWNI_CFG_MSG_TYPES_END,
123 eWNI_SME_START_REQ,
124 eWNI_SME_START_RSP,
125 eWNI_SME_SYS_READY_IND,
126 eWNI_SME_SCAN_REQ,
127 eWNI_SME_SCAN_ABORT_IND,
128 eWNI_SME_SCAN_RSP,
Jeff Johnsone7245742012-09-05 17:12:55 -0700129#ifdef FEATURE_OEM_DATA_SUPPORT
130 eWNI_SME_OEM_DATA_REQ,
131 eWNI_SME_OEM_DATA_RSP,
132#endif
Jeff Johnson295189b2012-06-20 16:38:30 -0700133 eWNI_SME_JOIN_REQ,
134 eWNI_SME_JOIN_RSP,
135 eWNI_SME_SETCONTEXT_REQ,
136 eWNI_SME_SETCONTEXT_RSP,
137 eWNI_SME_REASSOC_REQ,
138 eWNI_SME_REASSOC_RSP,
139 eWNI_SME_AUTH_REQ,
140 eWNI_SME_AUTH_RSP,
141 eWNI_SME_DISASSOC_REQ,
142 eWNI_SME_DISASSOC_RSP,
143 eWNI_SME_DISASSOC_IND,
144 eWNI_SME_DISASSOC_CNF,
145 eWNI_SME_DEAUTH_REQ,
146 eWNI_SME_DEAUTH_RSP,
147 eWNI_SME_DEAUTH_IND,
148 eWNI_SME_WM_STATUS_CHANGE_NTF,
149 eWNI_SME_IBSS_NEW_PEER_IND,
150 eWNI_SME_IBSS_PEER_DEPARTED_IND,
151 eWNI_SME_START_BSS_REQ,
152 eWNI_SME_START_BSS_RSP,
153 eWNI_SME_AUTH_IND,
154 eWNI_SME_ASSOC_IND,
155 eWNI_SME_ASSOC_CNF,
156 eWNI_SME_REASSOC_IND,
157 eWNI_SME_REASSOC_CNF,
158 eWNI_SME_SWITCH_CHL_REQ,
159 eWNI_SME_SWITCH_CHL_RSP,
160 eWNI_SME_STOP_BSS_REQ,
161 eWNI_SME_STOP_BSS_RSP,
162 eWNI_SME_DEL_BA_PEER_IND,
Jeff Johnson295189b2012-06-20 16:38:30 -0700163 eWNI_SME_DEFINE_QOS_REQ,
164 eWNI_SME_DEFINE_QOS_RSP,
165 eWNI_SME_DELETE_QOS_REQ,
166 eWNI_SME_DELETE_QOS_RSP,
Jeff Johnson295189b2012-06-20 16:38:30 -0700167 eWNI_SME_PROMISCUOUS_MODE_REQ,
168 eWNI_SME_PROMISCUOUS_MODE_RSP,
Jeff Johnson295189b2012-06-20 16:38:30 -0700169 eWNI_SME_LINK_TEST_START_REQ,
170 eWNI_SME_LINK_TEST_START_RSP,
171 eWNI_SME_LINK_TEST_STOP_REQ,
172 eWNI_SME_LINK_TEST_STOP_RSP,
173 eWNI_SME_LINK_TEST_REPORT_IND,
Jeff Johnson295189b2012-06-20 16:38:30 -0700174 eWNI_SME_NEIGHBOR_BSS_IND,
175 eWNI_SME_MEASUREMENT_REQ,
176 eWNI_SME_MEASUREMENT_RSP,
177 eWNI_SME_MEASUREMENT_IND,
178 eWNI_SME_SET_WDS_INFO_REQ,
179 eWNI_SME_SET_WDS_INFO_RSP,
180 eWNI_SME_WDS_INFO_IND,
Jeff Johnson295189b2012-06-20 16:38:30 -0700181 eWNI_SME_SET_POWER_REQ,
182 eWNI_SME_SET_POWER_RSP,
183 eWNI_SME_CLIENT_SIDE_LOAD_BALANCE_REQ,
184 eWNI_SME_CLIENT_SIDE_LOAD_BALANCE_RSP,
185 eWNI_SME_SELECT_CHANNEL_REQ,
186 eWNI_SME_SELECT_CHANNEL_RSP,
187 eWNI_SME_SET_PROPRIETARY_IE_REQ,
188 eWNI_SME_SET_PROPRIETARY_IE_RSP, // #endif
189 eWNI_SME_DISCARD_SKB_NTF, // Used to cleanup SKBs by HDD
Jeff Johnson295189b2012-06-20 16:38:30 -0700190 eWNI_SME_DEAUTH_CNF,
191 eWNI_SME_MIC_FAILURE_IND,
192 eWNI_SME_ADDTS_REQ,
193 eWNI_SME_ADDTS_RSP,
194 eWNI_SME_ADDTS_CNF,
195 eWNI_SME_ADDTS_IND,
196 eWNI_SME_DELTS_REQ,
197 eWNI_SME_DELTS_RSP,
198 eWNI_SME_DELTS_IND,
199 eWNI_SME_SET_BACKGROUND_SCAN_MODE_REQ,
200 eWNI_SME_SWITCH_CHL_CB_PRIMARY_REQ,
201 eWNI_SME_SWITCH_CHL_CB_PRIMARY_RSP,
202 eWNI_SME_SWITCH_CHL_CB_SECONDARY_REQ,
203 eWNI_SME_SWITCH_CHL_CB_SECONDARY_RSP,
204 eWNI_SME_PROBE_REQ,
205 eWNI_SME_STA_STAT_REQ,
206 eWNI_SME_STA_STAT_RSP,
207 eWNI_SME_AGGR_STAT_REQ,
208 eWNI_SME_AGGR_STAT_RSP,
209 eWNI_SME_GLOBAL_STAT_REQ,
210 eWNI_SME_GLOBAL_STAT_RSP,
211 eWNI_SME_STAT_SUMM_REQ,
212 eWNI_SME_STAT_SUMM_RSP,
213 eWNI_SME_REMOVEKEY_REQ,
214 eWNI_SME_REMOVEKEY_RSP,
215 eWNI_SME_GET_SCANNED_CHANNEL_REQ,
216 eWNI_SME_GET_SCANNED_CHANNEL_RSP,
217 eWNI_SME_SET_TX_POWER_REQ,
218 eWNI_SME_SET_TX_POWER_RSP,
219 eWNI_SME_GET_TX_POWER_REQ,
220 eWNI_SME_GET_TX_POWER_RSP,
221 eWNI_SME_GET_NOISE_REQ,
222 eWNI_SME_GET_NOISE_RSP,
223 eWNI_SME_LOW_RSSI_IND,
224 eWNI_SME_GET_STATISTICS_REQ,
225 eWNI_SME_GET_STATISTICS_RSP,
226 eWNI_SME_GET_RSSI_REQ,
Srinivas Girigowdad34cedb2013-01-25 13:33:11 -0800227 eWNI_SME_GET_ROAM_RSSI_REQ,
228 eWNI_SME_GET_ROAM_RSSI_RSP,
Jeff Johnson295189b2012-06-20 16:38:30 -0700229 eWNI_SME_GET_ASSOC_STAS_REQ,
230 eWNI_SME_TKIP_CNTR_MEAS_REQ,
231 eWNI_SME_UPDATE_APWPSIE_REQ,
232 eWNI_SME_GET_WPSPBC_SESSION_REQ,
233 eWNI_SME_WPS_PBC_PROBE_REQ_IND,
234 eWNI_SME_SET_APWPARSNIEs_REQ,
235 eWNI_SME_UPPER_LAYER_ASSOC_CNF,
236 eWNI_SME_HIDE_SSID_REQ,
Madan Mohan Koyyalamudi167b95e2012-11-27 15:53:38 -0800237 eWNI_SME_CHNG_MCC_BEACON_INTERVAL,
Jeff Johnson295189b2012-06-20 16:38:30 -0700238 eWNI_SME_REMAIN_ON_CHANNEL_REQ,
239 eWNI_SME_REMAIN_ON_CHN_IND,
240 eWNI_SME_REMAIN_ON_CHN_RSP,
241 eWNI_SME_MGMT_FRM_IND,
242 eWNI_SME_REMAIN_ON_CHN_RDY_IND,
243 eWNI_SME_SEND_ACTION_FRAME_IND,
244 eWNI_SME_ACTION_FRAME_SEND_CNF,
245 eWNI_SME_ABORT_REMAIN_ON_CHAN_IND,
246 eWNI_SME_UPDATE_NOA,
Jeff Johnson295189b2012-06-20 16:38:30 -0700247 eWNI_SME_PRE_CHANNEL_SWITCH_FULL_POWER,
248 //General Power Save Messages
249 eWNI_PMC_MSG_TYPES_BEGIN,
250 eWNI_PMC_PWR_SAVE_CFG,
251
252 //BMPS Messages
253 eWNI_PMC_ENTER_BMPS_REQ,
254 eWNI_PMC_ENTER_BMPS_RSP,
255 eWNI_PMC_EXIT_BMPS_REQ,
256 eWNI_PMC_EXIT_BMPS_RSP,
257 eWNI_PMC_EXIT_BMPS_IND,
258
259 //IMPS Messages.
260 eWNI_PMC_ENTER_IMPS_REQ,
261 eWNI_PMC_ENTER_IMPS_RSP,
262 eWNI_PMC_EXIT_IMPS_REQ,
263 eWNI_PMC_EXIT_IMPS_RSP,
264
265 //UAPSD Messages
266 eWNI_PMC_ENTER_UAPSD_REQ,
267 eWNI_PMC_ENTER_UAPSD_RSP,
268 eWNI_PMC_EXIT_UAPSD_REQ,
269 eWNI_PMC_EXIT_UAPSD_RSP,
270
271 //WOWL Messages
272 eWNI_PMC_SMPS_STATE_IND,
273
274 //WoWLAN Messages
275 eWNI_PMC_WOWL_ADD_BCAST_PTRN,
276 eWNI_PMC_WOWL_DEL_BCAST_PTRN,
277 eWNI_PMC_ENTER_WOWL_REQ,
278 eWNI_PMC_ENTER_WOWL_RSP,
279 eWNI_PMC_EXIT_WOWL_REQ,
280 eWNI_PMC_EXIT_WOWL_RSP,
281
282#ifdef WLAN_FEATURE_PACKET_FILTERING
283 eWNI_PMC_PACKET_COALESCING_FILTER_MATCH_COUNT_RSP,
284#endif // WLAN_FEATURE_PACKET_FILTERING
285
Jeff Johnson295189b2012-06-20 16:38:30 -0700286#if defined WLAN_FEATURE_VOWIFI
287 eWNI_SME_RRM_MSG_TYPE_BEGIN,
288
289 eWNI_SME_NEIGHBOR_REPORT_REQ_IND,
290 eWNI_SME_NEIGHBOR_REPORT_IND,
291 eWNI_SME_BEACON_REPORT_REQ_IND,
292 eWNI_SME_BEACON_REPORT_RESP_XMIT_IND,
293
Jeff Johnson295189b2012-06-20 16:38:30 -0700294#endif
295 eWNI_SME_ADD_STA_SELF_REQ,
296 eWNI_SME_ADD_STA_SELF_RSP,
297 eWNI_SME_DEL_STA_SELF_REQ,
298 eWNI_SME_DEL_STA_SELF_RSP,
299
300#if defined WLAN_FEATURE_VOWIFI_11R
301 eWNI_SME_FT_PRE_AUTH_REQ,
302 eWNI_SME_FT_PRE_AUTH_RSP,
303 eWNI_SME_FT_UPDATE_KEY,
304 eWNI_SME_FT_AGGR_QOS_REQ,
305 eWNI_SME_FT_AGGR_QOS_RSP,
306#endif
307
308#if defined FEATURE_WLAN_CCX
309 eWNI_SME_CCX_ADJACENT_AP_REPORT,
310#endif
311
Jeff Johnson295189b2012-06-20 16:38:30 -0700312 eWNI_SME_REGISTER_MGMT_FRAME_REQ,
Jeff Johnson295189b2012-06-20 16:38:30 -0700313
314 eWNI_SME_COEX_IND,
315
316#ifdef FEATURE_WLAN_SCAN_PNO
317 eWNI_SME_PREF_NETWORK_FOUND_IND,
318#endif // FEATURE_WLAN_SCAN_PNO
319
320 eWNI_SME_TX_PER_HIT_IND,
321
322 eWNI_SME_CHANGE_COUNTRY_CODE,
323 eWNI_SME_PRE_SWITCH_CHL_IND,
324 eWNI_SME_POST_SWITCH_CHL_IND,
325
326 eWNI_SME_MAX_ASSOC_EXCEEDED,
327
328 eWNI_SME_BTAMP_LOG_LINK_IND,//to serialize the create/accpet LL req from HCI
329
330#ifdef WLAN_FEATURE_GTK_OFFLOAD
331 eWNI_PMC_GTK_OFFLOAD_GETINFO_RSP,
332#endif // WLAN_FEATURE_GTK_OFFLOAD
333
334#ifdef WLAN_WAKEUP_EVENTS
335 eWNI_SME_WAKE_REASON_IND,
336#endif // WLAN_WAKEUP_EVENTS
Jeff Johnsone7245742012-09-05 17:12:55 -0700337 eWNI_SME_EXCLUDE_UNENCRYPTED,
338 eWNI_SME_RSSI_IND, //RSSI indication from TL to be serialized on MC thread
Mohit Khanna698ba2a2012-12-04 15:08:18 -0800339#ifdef FEATURE_WLAN_TDLS
340 eWNI_SME_TDLS_SEND_MGMT_REQ,
341 eWNI_SME_TDLS_SEND_MGMT_RSP,
342 eWNI_SME_TDLS_ADD_STA_REQ,
343 eWNI_SME_TDLS_ADD_STA_RSP,
344 eWNI_SME_TDLS_DEL_STA_REQ,
Hoonki Leee6bfe942013-02-05 15:01:19 -0800345 eWNI_SME_TDLS_DEL_STA_RSP,
346 eWNI_SME_TDLS_DEL_STA_IND,
Gopichand Nakkala2a0a1572013-02-10 21:39:16 -0800347 eWNI_SME_TDLS_DEL_ALL_PEER_IND,
Gopichand Nakkalab977a972013-02-18 19:15:09 -0800348 eWNI_SME_MGMT_FRM_TX_COMPLETION_IND,
Mohit Khanna698ba2a2012-12-04 15:08:18 -0800349#endif
350 //NOTE: If you are planning to add more mesages, please make sure that
351 //SIR_LIM_ITC_MSG_TYPES_BEGIN is moved appropriately. It is set as
352 //SIR_LIM_MSG_TYPES_BEGIN+0xB0 = 12B0 (which means max of 176 messages and
353 //eWNI_SME_TDLS_DEL_STA_RSP = 175.
354 //Should fix above issue to enable TDLS_INTERNAL
355#ifdef FEATURE_WLAN_TDLS_INTERNAL
356#error ERROR_TDLS_INTERNAL
357 eWNI_SME_TDLS_DISCOVERY_START_REQ,
358 eWNI_SME_TDLS_DISCOVERY_START_RSP,
359 eWNI_SME_TDLS_DISCOVERY_START_IND,
360 eWNI_SME_TDLS_LINK_START_REQ,
361 eWNI_SME_TDLS_LINK_START_RSP,
362 eWNI_SME_TDLS_LINK_START_IND,
363 eWNI_SME_TDLS_TEARDOWN_REQ,
364 eWNI_SME_TDLS_TEARDOWN_RSP,
365 eWNI_SME_TDLS_TEARDOWN_IND,
366 eWNI_SME_ADD_TDLS_PEER_IND,
367 eWNI_SME_DELETE_TDLS_PEER_IND,
368#endif
Yathish9f22e662012-12-10 14:21:35 -0800369 eWNI_SME_SET_BCN_FILTER_REQ,
Gopichand Nakkalacca24d12013-03-07 17:05:07 +0530370 eWNI_SME_RESET_AP_CAPS_CHANGED,
Chet Lanctot186b5732013-03-18 10:26:30 -0700371#ifdef WLAN_FEATURE_11W
372 eWNI_SME_UNPROT_MGMT_FRM_IND,
373#endif
Jeff Johnson295189b2012-06-20 16:38:30 -0700374 eWNI_SME_MSG_TYPES_END
375};
376
377#define WNI_CFG_MSG_TYPES_BEGIN 0x1100
378
379/*---------------------------------------------------------------------*/
380/* CFG Module Definitions */
381/*---------------------------------------------------------------------*/
382
383
384/*---------------------------------------------------------------------*/
385/* CFG message definitions */
386/*---------------------------------------------------------------------*/
387#define WNI_CFG_MSG_HDR_MASK 0xffff0000
388#define WNI_CFG_MSG_LEN_MASK 0x0000ffff
389#define WNI_CFG_MB_HDR_LEN 4
390#define WNI_CFG_MAX_PARAM_NUM 32
391
392
393/*---------------------------------------------------------------------*/
394/* CFG to HDD message types */
395/*---------------------------------------------------------------------*/
396#define WNI_CFG_PARAM_UPDATE_IND (WNI_CFG_MSG_TYPES_BEGIN | 0x00)
397#define WNI_CFG_DNLD_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x01)
398#define WNI_CFG_DNLD_CNF (WNI_CFG_MSG_TYPES_BEGIN | 0x02)
399#define WNI_CFG_GET_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x03)
400#define WNI_CFG_SET_CNF (WNI_CFG_MSG_TYPES_BEGIN | 0x04)
401#define WNI_CFG_GET_ATTRIB_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x05)
402#define WNI_CFG_ADD_GRP_ADDR_CNF (WNI_CFG_MSG_TYPES_BEGIN | 0x06)
403#define WNI_CFG_DEL_GRP_ADDR_CNF (WNI_CFG_MSG_TYPES_BEGIN | 0x07)
404
405#define ANI_CFG_GET_RADIO_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x08)
406#define ANI_CFG_GET_PER_STA_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x09)
407#define ANI_CFG_GET_AGG_STA_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x0a)
408#define ANI_CFG_CLEAR_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x0b)
409
410
411/*---------------------------------------------------------------------*/
412/* CFG to HDD message paramter indices */
413/* */
414/* The followings are word indices starting from the message body */
415/* */
416/* WNI_CFG_xxxx_xxxx_xxxx: index of parameter */
417/* */
418/* WNI_CFG_xxxx_xxxx_NUM: number of parameters in message */
419/* */
420/* WNI_CFG_xxxx_xxxx_LEN: byte length of message including */
421/* MB header */
422/* */
423/* WNI_CFG_xxxx_xxxx_PARTIAL_LEN: byte length of message including */
424/* parameters and MB header but */
425/* excluding variable data length */
426/*---------------------------------------------------------------------*/
427
Jeff Johnson295189b2012-06-20 16:38:30 -0700428// Parameter update indication
429#define WNI_CFG_PARAM_UPDATE_IND_PID 0
430
431#define WNI_CFG_PARAM_UPDATE_IND_NUM 1
432#define WNI_CFG_PARAM_UPDATE_IND_LEN (WNI_CFG_MB_HDR_LEN + \
433 (WNI_CFG_PARAM_UPDATE_IND_NUM << 2))
Jeff Johnson295189b2012-06-20 16:38:30 -0700434
435// Configuration download request
436#define WNI_CFG_DNLD_REQ_NUM 0
437#define WNI_CFG_DNLD_REQ_LEN WNI_CFG_MB_HDR_LEN
438
439// Configuration download confirm
440#define WNI_CFG_DNLD_CNF_RES 0
441
442#define WNI_CFG_DNLD_CNF_NUM 1
443#define WNI_CFG_DNLD_CNF_LEN (WNI_CFG_MB_HDR_LEN + \
444 (WNI_CFG_DNLD_CNF_NUM << 2))
445// Get response
446#define WNI_CFG_GET_RSP_RES 0
447#define WNI_CFG_GET_RSP_PID 1
448#define WNI_CFG_GET_RSP_PLEN 2
449
450#define WNI_CFG_GET_RSP_NUM 3
451#define WNI_CFG_GET_RSP_PARTIAL_LEN (WNI_CFG_MB_HDR_LEN + \
452 (WNI_CFG_GET_RSP_NUM << 2))
453// Set confirm
454#define WNI_CFG_SET_CNF_RES 0
455#define WNI_CFG_SET_CNF_PID 1
456
457#define WNI_CFG_SET_CNF_NUM 2
458#define WNI_CFG_SET_CNF_LEN (WNI_CFG_MB_HDR_LEN + \
459 (WNI_CFG_SET_CNF_NUM << 2))
460// Get attribute response
461#define WNI_CFG_GET_ATTRIB_RSP_RES 0
462#define WNI_CFG_GET_ATTRIB_RSP_PID 1
463#define WNI_CFG_GET_ATTRIB_RSP_TYPE 2
464#define WNI_CFG_GET_ATTRIB_RSP_PLEN 3
465#define WNI_CFG_GET_ATTRIB_RSP_RW 4
466
467#define WNI_CFG_GET_ATTRIB_RSP_NUM 5
468#define WNI_CFG_GET_ATTRIB_RSP_LEN (WNI_CFG_MB_HDR_LEN + \
469 (WNI_CFG_GET_ATTRIB_RSP_NUM << 2))
470
471// Add group address confirm
472#define WNI_CFG_ADD_GRP_ADDR_CNF_RES 0
473
474#define WNI_CFG_ADD_GRP_ADDR_CNF_NUM 1
475#define WNI_CFG_ADD_GRP_ADDR_CNF_LEN (WNI_CFG_MB_HDR_LEN + \
476 (WNI_CFG_ADD_GRP_ADDR_CNF_NUM << 2))
477
478// Delete group address confirm
479#define WNI_CFG_DEL_GRP_ADDR_CNF_RES 0
480
481#define WNI_CFG_DEL_GRP_ADDR_CNF_NUM 1
482#define WNI_CFG_DEL_GRP_ADDR_CNF_LEN (WNI_CFG_MB_HDR_LEN + \
483 (WNI_CFG_DEL_GRP_ADDR_CNF_NUM <<2))
484
485
486#define IS_CFG_MSG(msg) ((msg & 0xff00) == WNI_CFG_MSG_TYPES_BEGIN)
487
488// Clear stats types.
489#define ANI_CLEAR_ALL_STATS 0
490#define ANI_CLEAR_RX_STATS 1
491#define ANI_CLEAR_TX_STATS 2
492#define ANI_CLEAR_PER_STA_STATS 3
493#define ANI_CLEAR_AGGR_PER_STA_STATS 4
494#define ANI_CLEAR_STAT_TYPES_END 5
495
496/*---------------------------------------------------------------------*/
497/* HDD to CFG message types */
498/*---------------------------------------------------------------------*/
499#define WNI_CFG_DNLD_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x80)
500#define WNI_CFG_GET_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x81)
501#define WNI_CFG_SET_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x82)
502#define WNI_CFG_SET_REQ_NO_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x83) //No RSP for this set
503
504// Shall be removed after stats integration
505
506
507/*---------------------------------------------------------------------*/
508/* HDD to CFG message paramter indices */
509/* */
510/* The followings are word indices starting from the message body */
511/* */
512/* WNI_CFG_xxxx_xxxx_xxxx: index of parameter */
513/* */
514/* WNI_CFG_xxxx_xxxx_NUM: number of parameters in message */
515/* */
516/* WNI_CFG_xxxx_xxxx_LEN: byte length of message including */
517/* MB header */
518/* */
519/* WNI_CFG_xxxx_xxxx_PARTIAL_LEN: byte length of message including */
520/* parameters and MB header but */
521/* excluding variable data length */
522/*---------------------------------------------------------------------*/
523
524// Download response
525#define WNI_CFG_DNLD_RSP_BIN_LEN 0
526
527#define WNI_CFG_DNLD_RSP_NUM 1
528#define WNI_CFG_DNLD_RSP_PARTIAL_LEN (WNI_CFG_MB_HDR_LEN + \
529 (WNI_CFG_DNLD_RSP_NUM << 2))
530
531// Set parameter request
532#define WNI_CFG_SET_REQ_PID 0
533#define WNI_CFG_SET_REQ_PLEN 1
534
535/*
536// Get attribute request
537//#define WNI_CFG_GET_ATTRIB_REQ_PID 0
538
539//#define WNI_CFG_GET_ATTRIB_REQ_NUM 1
540//#define WNI_CFG_GET_ATTRIB_REQ_LEN (WNI_CFG_MB_HDR_LEN + \
541 (WNI_CFG_GET_ATTRIB_REQ_NUM << 2))
542// Add group address request
543#define WNI_CFG_ADD_GRP_ADDR_REQ_MAC_ADDR 0
544
545#define WNI_CFG_ADD_GRP_ADDR_REQ_NUM 1
546#define WNI_CFG_ADD_GRP_ADDR_REQ_LEN (WNI_CFG_MB_HDR_LEN + \
547 (WNI_CFG_ADD_GRP_ADDR_REQ_NUM << 2))
548// Delete group address request
549#define WNI_CFG_DEL_GRP_ADDR_REQ_MAC_ADDR 0
550
551#define WNI_CFG_DEL_GRP_ADDR_REQ_NUM 1
552#define WNI_CFG_DEL_GRP_ADDR_REQ_LEN (WNI_CFG_MB_HDR_LEN + \
553 (WNI_CFG_DEL_GRP_ADDR_REQ_NUM << 2))
554*/
555
556
557/*---------------------------------------------------------------------*/
558/* CFG return values */
559/*---------------------------------------------------------------------*/
560#define WNI_CFG_SUCCESS 1
561#define WNI_CFG_NOT_READY 2
562#define WNI_CFG_INVALID_PID 3
563#define WNI_CFG_INVALID_LEN 4
564#define WNI_CFG_RO_PARAM 5
565#define WNI_CFG_WO_PARAM 6
566#define WNI_CFG_INVALID_STAID 7
567#define WNI_CFG_OTHER_ERROR 8
568#define WNI_CFG_NEED_RESTART 9
569#define WNI_CFG_NEED_RELOAD 10
570
571
572/*---------------------------------------------------------------------*/
573/* CFG definitions */
574/*---------------------------------------------------------------------*/
575#define WNI_CFG_TYPE_STR 0x0000000
576#define WNI_CFG_TYPE_INT 0x0000001
577#define WNI_CFG_HOST_RE 0x0000002
578#define WNI_CFG_HOST_WE 0x0000004
579
580
581// Shall be removed after integration of stats.
582// Get statistic response
583#define WNI_CFG_GET_STAT_RSP_RES 0
584#define WNI_CFG_GET_STAT_RSP_PARAMID 1
585#define WNI_CFG_GET_STAT_RSP_VALUE 2
586
587#define WNI_CFG_GET_STAT_RSP_NUM 3
588#define WNI_CFG_GET_STAT_RSP_LEN (WNI_CFG_MB_HDR_LEN + \
589 (WNI_CFG_GET_STAT_RSP_NUM <<2))
590// Get per station statistic response
591#define WNI_CFG_GET_PER_STA_STAT_RSP_RES 0
592#define WNI_CFG_GET_PER_STA_STAT_RSP_STAID 1
593#define WNI_CFG_GET_PER_STA_STAT_RSP_FIRST_PARAM 2
594
595// Per STA statistic structure
596typedef struct sAniCfgPerStaStatStruct
597{
598 unsigned long sentAesBlksUcastHi;
599 unsigned long sentAesBlksUcastLo;
600
601 unsigned long recvAesBlksUcastHi;
602 unsigned long recvAesBlksUcastLo;
603
604 unsigned long aesFormatErrorUcastCnts;
605
606 unsigned long aesReplaysUcast;
607
608 unsigned long aesDecryptErrUcast;
609
610 unsigned long singleRetryPkts;
611
612 unsigned long failedTxPkts;
613
614 unsigned long ackTimeouts;
615
616 unsigned long multiRetryPkts;
617
618 unsigned long fragTxCntsHi;
619 unsigned long fragTxCntsLo;
620
621 unsigned long transmittedPktsHi;
622 unsigned long transmittedPktsLo;
623
624 unsigned long phyStatHi;
625 unsigned long phyStatLo;
626} tCfgPerStaStatStruct, *tpAniCfgPerStaStatStruct;
627
628#define WNI_CFG_GET_PER_STA_STAT_RSP_NUM 23
629#define WNI_CFG_GET_PER_STA_STAT_RSP_LEN (WNI_CFG_MB_HDR_LEN + \
630 (WNI_CFG_GET_PER_STA_STAT_RSP_NUM << 2))
631
632
633// Shall be removed after integrating stats.
634#define WNI_CFG_GET_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x08)
635#define WNI_CFG_GET_PER_STA_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x09)
636#define WNI_CFG_GET_AGG_STA_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x0a)
637#define WNI_CFG_GET_TX_RATE_CTR_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x0b)
638
639#define WNI_CFG_GET_AGG_STA_STAT_RSP_NUM 21
640#define WNI_CFG_GET_AGG_STA_STAT_RSP_LEN (WNI_CFG_MB_HDR_LEN + \
641 (WNI_CFG_GET_AGG_STA_STAT_RSP_NUM << 2))
642#define WNI_CFG_GET_AGG_STA_STAT_RSP_RES 0
643
644 // Get TX rate based stats
645#define WNI_CFG_GET_TX_RATE_CTR_RSP_RES 0
646
647typedef struct sAniCfgTxRateCtrs
648{
649// add the rate counters here
650 unsigned long TxFrames_1Mbps;
651 unsigned long TxFrames_2Mbps;
652 unsigned long TxFrames_5_5Mbps;
653 unsigned long TxFrames_6Mbps;
654 unsigned long TxFrames_9Mbps;
655 unsigned long TxFrames_11Mbps;
656 unsigned long TxFrames_12Mbps;
657 unsigned long TxFrames_18Mbps;
658 unsigned long TxFrames_24Mbps;
659 unsigned long TxFrames_36Mbps;
660 unsigned long TxFrames_48Mbps;
661 unsigned long TxFrames_54Mbps;
662 unsigned long TxFrames_72Mbps;
663 unsigned long TxFrames_96Mbps;
664 unsigned long TxFrames_108Mbps;
665
666} tAniCfgTxRateCtrs, *tpAniCfgTxRateCtrs;
667
668
669#define WNI_CFG_GET_STAT_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x86)
670#define WNI_CFG_GET_PER_STA_STAT_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x87)
671#define WNI_CFG_GET_AGG_STA_STAT_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x88)
672#define WNI_CFG_GET_TX_RATE_CTR_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x89)
673
674// Get statistic request
675#define WNI_CFG_GET_STAT_REQ_PARAMID 0
676
677#define WNI_CFG_GET_STAT_REQ_NUM 1
678#define WNI_CFG_GET_STAT_REQ_LEN (WNI_CFG_MB_HDR_LEN + \
679 (WNI_CFG_GET_STAT_REQ_NUM << 2))
680
681 // Get per station statistic request
682#define WNI_CFG_GET_PER_STA_STAT_REQ_STAID 0
683
684#define WNI_CFG_GET_PER_STA_STAT_REQ_NUM 1
685#define WNI_CFG_GET_PER_STA_STAT_REQ_LEN (WNI_CFG_MB_HDR_LEN + \
686 (WNI_CFG_GET_PER_STA_STAT_REQ_NUM << 2))
687
688
689
690
691#define DYNAMIC_CFG_TYPE_SELECTED_REGISTRAR (0)
692#define DYNAMIC_CFG_TYPE_WPS_STATE (1)
693
694#endif /* __WNI_API_H */
695