blob: c0e90822a6501258dbc62fbaf1e26ddffbc2fa8f [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,
Jeff Johnson295189b2012-06-20 16:38:30 -0700371 eWNI_SME_MSG_TYPES_END
372};
373
374#define WNI_CFG_MSG_TYPES_BEGIN 0x1100
375
376/*---------------------------------------------------------------------*/
377/* CFG Module Definitions */
378/*---------------------------------------------------------------------*/
379
380
381/*---------------------------------------------------------------------*/
382/* CFG message definitions */
383/*---------------------------------------------------------------------*/
384#define WNI_CFG_MSG_HDR_MASK 0xffff0000
385#define WNI_CFG_MSG_LEN_MASK 0x0000ffff
386#define WNI_CFG_MB_HDR_LEN 4
387#define WNI_CFG_MAX_PARAM_NUM 32
388
389
390/*---------------------------------------------------------------------*/
391/* CFG to HDD message types */
392/*---------------------------------------------------------------------*/
393#define WNI_CFG_PARAM_UPDATE_IND (WNI_CFG_MSG_TYPES_BEGIN | 0x00)
394#define WNI_CFG_DNLD_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x01)
395#define WNI_CFG_DNLD_CNF (WNI_CFG_MSG_TYPES_BEGIN | 0x02)
396#define WNI_CFG_GET_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x03)
397#define WNI_CFG_SET_CNF (WNI_CFG_MSG_TYPES_BEGIN | 0x04)
398#define WNI_CFG_GET_ATTRIB_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x05)
399#define WNI_CFG_ADD_GRP_ADDR_CNF (WNI_CFG_MSG_TYPES_BEGIN | 0x06)
400#define WNI_CFG_DEL_GRP_ADDR_CNF (WNI_CFG_MSG_TYPES_BEGIN | 0x07)
401
402#define ANI_CFG_GET_RADIO_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x08)
403#define ANI_CFG_GET_PER_STA_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x09)
404#define ANI_CFG_GET_AGG_STA_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x0a)
405#define ANI_CFG_CLEAR_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x0b)
406
407
408/*---------------------------------------------------------------------*/
409/* CFG to HDD message paramter indices */
410/* */
411/* The followings are word indices starting from the message body */
412/* */
413/* WNI_CFG_xxxx_xxxx_xxxx: index of parameter */
414/* */
415/* WNI_CFG_xxxx_xxxx_NUM: number of parameters in message */
416/* */
417/* WNI_CFG_xxxx_xxxx_LEN: byte length of message including */
418/* MB header */
419/* */
420/* WNI_CFG_xxxx_xxxx_PARTIAL_LEN: byte length of message including */
421/* parameters and MB header but */
422/* excluding variable data length */
423/*---------------------------------------------------------------------*/
424
Jeff Johnson295189b2012-06-20 16:38:30 -0700425// Parameter update indication
426#define WNI_CFG_PARAM_UPDATE_IND_PID 0
427
428#define WNI_CFG_PARAM_UPDATE_IND_NUM 1
429#define WNI_CFG_PARAM_UPDATE_IND_LEN (WNI_CFG_MB_HDR_LEN + \
430 (WNI_CFG_PARAM_UPDATE_IND_NUM << 2))
Jeff Johnson295189b2012-06-20 16:38:30 -0700431
432// Configuration download request
433#define WNI_CFG_DNLD_REQ_NUM 0
434#define WNI_CFG_DNLD_REQ_LEN WNI_CFG_MB_HDR_LEN
435
436// Configuration download confirm
437#define WNI_CFG_DNLD_CNF_RES 0
438
439#define WNI_CFG_DNLD_CNF_NUM 1
440#define WNI_CFG_DNLD_CNF_LEN (WNI_CFG_MB_HDR_LEN + \
441 (WNI_CFG_DNLD_CNF_NUM << 2))
442// Get response
443#define WNI_CFG_GET_RSP_RES 0
444#define WNI_CFG_GET_RSP_PID 1
445#define WNI_CFG_GET_RSP_PLEN 2
446
447#define WNI_CFG_GET_RSP_NUM 3
448#define WNI_CFG_GET_RSP_PARTIAL_LEN (WNI_CFG_MB_HDR_LEN + \
449 (WNI_CFG_GET_RSP_NUM << 2))
450// Set confirm
451#define WNI_CFG_SET_CNF_RES 0
452#define WNI_CFG_SET_CNF_PID 1
453
454#define WNI_CFG_SET_CNF_NUM 2
455#define WNI_CFG_SET_CNF_LEN (WNI_CFG_MB_HDR_LEN + \
456 (WNI_CFG_SET_CNF_NUM << 2))
457// Get attribute response
458#define WNI_CFG_GET_ATTRIB_RSP_RES 0
459#define WNI_CFG_GET_ATTRIB_RSP_PID 1
460#define WNI_CFG_GET_ATTRIB_RSP_TYPE 2
461#define WNI_CFG_GET_ATTRIB_RSP_PLEN 3
462#define WNI_CFG_GET_ATTRIB_RSP_RW 4
463
464#define WNI_CFG_GET_ATTRIB_RSP_NUM 5
465#define WNI_CFG_GET_ATTRIB_RSP_LEN (WNI_CFG_MB_HDR_LEN + \
466 (WNI_CFG_GET_ATTRIB_RSP_NUM << 2))
467
468// Add group address confirm
469#define WNI_CFG_ADD_GRP_ADDR_CNF_RES 0
470
471#define WNI_CFG_ADD_GRP_ADDR_CNF_NUM 1
472#define WNI_CFG_ADD_GRP_ADDR_CNF_LEN (WNI_CFG_MB_HDR_LEN + \
473 (WNI_CFG_ADD_GRP_ADDR_CNF_NUM << 2))
474
475// Delete group address confirm
476#define WNI_CFG_DEL_GRP_ADDR_CNF_RES 0
477
478#define WNI_CFG_DEL_GRP_ADDR_CNF_NUM 1
479#define WNI_CFG_DEL_GRP_ADDR_CNF_LEN (WNI_CFG_MB_HDR_LEN + \
480 (WNI_CFG_DEL_GRP_ADDR_CNF_NUM <<2))
481
482
483#define IS_CFG_MSG(msg) ((msg & 0xff00) == WNI_CFG_MSG_TYPES_BEGIN)
484
485// Clear stats types.
486#define ANI_CLEAR_ALL_STATS 0
487#define ANI_CLEAR_RX_STATS 1
488#define ANI_CLEAR_TX_STATS 2
489#define ANI_CLEAR_PER_STA_STATS 3
490#define ANI_CLEAR_AGGR_PER_STA_STATS 4
491#define ANI_CLEAR_STAT_TYPES_END 5
492
493/*---------------------------------------------------------------------*/
494/* HDD to CFG message types */
495/*---------------------------------------------------------------------*/
496#define WNI_CFG_DNLD_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x80)
497#define WNI_CFG_GET_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x81)
498#define WNI_CFG_SET_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x82)
499#define WNI_CFG_SET_REQ_NO_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x83) //No RSP for this set
500
501// Shall be removed after stats integration
502
503
504/*---------------------------------------------------------------------*/
505/* HDD to CFG message paramter indices */
506/* */
507/* The followings are word indices starting from the message body */
508/* */
509/* WNI_CFG_xxxx_xxxx_xxxx: index of parameter */
510/* */
511/* WNI_CFG_xxxx_xxxx_NUM: number of parameters in message */
512/* */
513/* WNI_CFG_xxxx_xxxx_LEN: byte length of message including */
514/* MB header */
515/* */
516/* WNI_CFG_xxxx_xxxx_PARTIAL_LEN: byte length of message including */
517/* parameters and MB header but */
518/* excluding variable data length */
519/*---------------------------------------------------------------------*/
520
521// Download response
522#define WNI_CFG_DNLD_RSP_BIN_LEN 0
523
524#define WNI_CFG_DNLD_RSP_NUM 1
525#define WNI_CFG_DNLD_RSP_PARTIAL_LEN (WNI_CFG_MB_HDR_LEN + \
526 (WNI_CFG_DNLD_RSP_NUM << 2))
527
528// Set parameter request
529#define WNI_CFG_SET_REQ_PID 0
530#define WNI_CFG_SET_REQ_PLEN 1
531
532/*
533// Get attribute request
534//#define WNI_CFG_GET_ATTRIB_REQ_PID 0
535
536//#define WNI_CFG_GET_ATTRIB_REQ_NUM 1
537//#define WNI_CFG_GET_ATTRIB_REQ_LEN (WNI_CFG_MB_HDR_LEN + \
538 (WNI_CFG_GET_ATTRIB_REQ_NUM << 2))
539// Add group address request
540#define WNI_CFG_ADD_GRP_ADDR_REQ_MAC_ADDR 0
541
542#define WNI_CFG_ADD_GRP_ADDR_REQ_NUM 1
543#define WNI_CFG_ADD_GRP_ADDR_REQ_LEN (WNI_CFG_MB_HDR_LEN + \
544 (WNI_CFG_ADD_GRP_ADDR_REQ_NUM << 2))
545// Delete group address request
546#define WNI_CFG_DEL_GRP_ADDR_REQ_MAC_ADDR 0
547
548#define WNI_CFG_DEL_GRP_ADDR_REQ_NUM 1
549#define WNI_CFG_DEL_GRP_ADDR_REQ_LEN (WNI_CFG_MB_HDR_LEN + \
550 (WNI_CFG_DEL_GRP_ADDR_REQ_NUM << 2))
551*/
552
553
554/*---------------------------------------------------------------------*/
555/* CFG return values */
556/*---------------------------------------------------------------------*/
557#define WNI_CFG_SUCCESS 1
558#define WNI_CFG_NOT_READY 2
559#define WNI_CFG_INVALID_PID 3
560#define WNI_CFG_INVALID_LEN 4
561#define WNI_CFG_RO_PARAM 5
562#define WNI_CFG_WO_PARAM 6
563#define WNI_CFG_INVALID_STAID 7
564#define WNI_CFG_OTHER_ERROR 8
565#define WNI_CFG_NEED_RESTART 9
566#define WNI_CFG_NEED_RELOAD 10
567
568
569/*---------------------------------------------------------------------*/
570/* CFG definitions */
571/*---------------------------------------------------------------------*/
572#define WNI_CFG_TYPE_STR 0x0000000
573#define WNI_CFG_TYPE_INT 0x0000001
574#define WNI_CFG_HOST_RE 0x0000002
575#define WNI_CFG_HOST_WE 0x0000004
576
577
578// Shall be removed after integration of stats.
579// Get statistic response
580#define WNI_CFG_GET_STAT_RSP_RES 0
581#define WNI_CFG_GET_STAT_RSP_PARAMID 1
582#define WNI_CFG_GET_STAT_RSP_VALUE 2
583
584#define WNI_CFG_GET_STAT_RSP_NUM 3
585#define WNI_CFG_GET_STAT_RSP_LEN (WNI_CFG_MB_HDR_LEN + \
586 (WNI_CFG_GET_STAT_RSP_NUM <<2))
587// Get per station statistic response
588#define WNI_CFG_GET_PER_STA_STAT_RSP_RES 0
589#define WNI_CFG_GET_PER_STA_STAT_RSP_STAID 1
590#define WNI_CFG_GET_PER_STA_STAT_RSP_FIRST_PARAM 2
591
592// Per STA statistic structure
593typedef struct sAniCfgPerStaStatStruct
594{
595 unsigned long sentAesBlksUcastHi;
596 unsigned long sentAesBlksUcastLo;
597
598 unsigned long recvAesBlksUcastHi;
599 unsigned long recvAesBlksUcastLo;
600
601 unsigned long aesFormatErrorUcastCnts;
602
603 unsigned long aesReplaysUcast;
604
605 unsigned long aesDecryptErrUcast;
606
607 unsigned long singleRetryPkts;
608
609 unsigned long failedTxPkts;
610
611 unsigned long ackTimeouts;
612
613 unsigned long multiRetryPkts;
614
615 unsigned long fragTxCntsHi;
616 unsigned long fragTxCntsLo;
617
618 unsigned long transmittedPktsHi;
619 unsigned long transmittedPktsLo;
620
621 unsigned long phyStatHi;
622 unsigned long phyStatLo;
623} tCfgPerStaStatStruct, *tpAniCfgPerStaStatStruct;
624
625#define WNI_CFG_GET_PER_STA_STAT_RSP_NUM 23
626#define WNI_CFG_GET_PER_STA_STAT_RSP_LEN (WNI_CFG_MB_HDR_LEN + \
627 (WNI_CFG_GET_PER_STA_STAT_RSP_NUM << 2))
628
629
630// Shall be removed after integrating stats.
631#define WNI_CFG_GET_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x08)
632#define WNI_CFG_GET_PER_STA_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x09)
633#define WNI_CFG_GET_AGG_STA_STAT_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x0a)
634#define WNI_CFG_GET_TX_RATE_CTR_RSP (WNI_CFG_MSG_TYPES_BEGIN | 0x0b)
635
636#define WNI_CFG_GET_AGG_STA_STAT_RSP_NUM 21
637#define WNI_CFG_GET_AGG_STA_STAT_RSP_LEN (WNI_CFG_MB_HDR_LEN + \
638 (WNI_CFG_GET_AGG_STA_STAT_RSP_NUM << 2))
639#define WNI_CFG_GET_AGG_STA_STAT_RSP_RES 0
640
641 // Get TX rate based stats
642#define WNI_CFG_GET_TX_RATE_CTR_RSP_RES 0
643
644typedef struct sAniCfgTxRateCtrs
645{
646// add the rate counters here
647 unsigned long TxFrames_1Mbps;
648 unsigned long TxFrames_2Mbps;
649 unsigned long TxFrames_5_5Mbps;
650 unsigned long TxFrames_6Mbps;
651 unsigned long TxFrames_9Mbps;
652 unsigned long TxFrames_11Mbps;
653 unsigned long TxFrames_12Mbps;
654 unsigned long TxFrames_18Mbps;
655 unsigned long TxFrames_24Mbps;
656 unsigned long TxFrames_36Mbps;
657 unsigned long TxFrames_48Mbps;
658 unsigned long TxFrames_54Mbps;
659 unsigned long TxFrames_72Mbps;
660 unsigned long TxFrames_96Mbps;
661 unsigned long TxFrames_108Mbps;
662
663} tAniCfgTxRateCtrs, *tpAniCfgTxRateCtrs;
664
665
666#define WNI_CFG_GET_STAT_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x86)
667#define WNI_CFG_GET_PER_STA_STAT_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x87)
668#define WNI_CFG_GET_AGG_STA_STAT_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x88)
669#define WNI_CFG_GET_TX_RATE_CTR_REQ (WNI_CFG_MSG_TYPES_BEGIN | 0x89)
670
671// Get statistic request
672#define WNI_CFG_GET_STAT_REQ_PARAMID 0
673
674#define WNI_CFG_GET_STAT_REQ_NUM 1
675#define WNI_CFG_GET_STAT_REQ_LEN (WNI_CFG_MB_HDR_LEN + \
676 (WNI_CFG_GET_STAT_REQ_NUM << 2))
677
678 // Get per station statistic request
679#define WNI_CFG_GET_PER_STA_STAT_REQ_STAID 0
680
681#define WNI_CFG_GET_PER_STA_STAT_REQ_NUM 1
682#define WNI_CFG_GET_PER_STA_STAT_REQ_LEN (WNI_CFG_MB_HDR_LEN + \
683 (WNI_CFG_GET_PER_STA_STAT_REQ_NUM << 2))
684
685
686
687
688#define DYNAMIC_CFG_TYPE_SELECTED_REGISTRAR (0)
689#define DYNAMIC_CFG_TYPE_WPS_STATE (1)
690
691#endif /* __WNI_API_H */
692