Staging: rt2870: remove dead QOS_DLS_SUPPORT code
[linux-2.6] / drivers / staging / rt2870 / rtmp_def.h
1 /*
2  *************************************************************************
3  * Ralink Tech Inc.
4  * 5F., No.36, Taiyuan St., Jhubei City,
5  * Hsinchu County 302,
6  * Taiwan, R.O.C.
7  *
8  * (c) Copyright 2002-2007, Ralink Technology, Inc.
9  *
10  * This program is free software; you can redistribute it and/or modify  *
11  * it under the terms of the GNU General Public License as published by  *
12  * the Free Software Foundation; either version 2 of the License, or     *
13  * (at your option) any later version.                                   *
14  *                                                                       *
15  * This program is distributed in the hope that it will be useful,       *
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of        *
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
18  * GNU General Public License for more details.                          *
19  *                                                                       *
20  * You should have received a copy of the GNU General Public License     *
21  * along with this program; if not, write to the                         *
22  * Free Software Foundation, Inc.,                                       *
23  * 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
24  *                                                                       *
25  *************************************************************************
26
27     Module Name:
28     rtmp_def.h
29
30     Abstract:
31     Miniport related definition header
32
33     Revision History:
34     Who         When          What
35     --------    ----------    ----------------------------------------------
36     Paul Lin    08-01-2002    created
37     John Chang  08-05-2003    add definition for 11g & other drafts
38 */
39 #ifndef __RTMP_DEF_H__
40 #define __RTMP_DEF_H__
41
42 #include "oid.h"
43
44 //
45 //  Debug information verbosity: lower values indicate higher urgency
46 //
47 #define RT_DEBUG_OFF        0
48 #define RT_DEBUG_ERROR      1
49 #define RT_DEBUG_WARN       2
50 #define RT_DEBUG_TRACE      3
51 #define RT_DEBUG_INFO       4
52 #define RT_DEBUG_LOUD       5
53
54 #define NIC_TAG             ((ULONG)'0682')
55 #define NIC_DBG_STRING      ("**RT28xx**")
56
57 #ifdef SNMP_SUPPORT
58 // for snmp
59 // to get manufacturer OUI, kathy, 2008_0220
60 #define ManufacturerOUI_LEN                     3
61 #define ManufacturerNAME                        ("Ralink Technology Company.")
62 #define ResourceTypeIdName                      ("Ralink_ID")
63 #endif
64
65
66 //#define PACKED
67
68 #define RALINK_2883_VERSION             ((UINT32)0x28830300)
69 #define RALINK_2880E_VERSION    ((UINT32)0x28720200)
70 #define RALINK_3070_VERSION             ((UINT32)0x30700200)
71
72 //
73 // NDIS version in use by the NIC driver.
74 // The high byte is the major version. The low byte is the minor version.
75 //
76 #ifdef  NDIS51_MINIPORT
77 #define NIC_DRIVER_VERSION      0x0501
78 #else
79 #define NIC_DRIVER_VERSION      0x0500
80 #endif
81
82 //
83 // NDIS media type, current is ethernet, change if native wireless supported
84 //
85 #define NIC_MEDIA_TYPE          NdisMedium802_3
86 #define NIC_PCI_HDR_LENGTH      0xe2
87 #define NIC_MAX_PACKET_SIZE     2304
88 #define NIC_HEADER_SIZE         14
89 #define MAX_MAP_REGISTERS_NEEDED 32
90 #define MIN_MAP_REGISTERS_NEEDED 2   //Todo: should consider fragment issue.
91
92 //
93 // interface type, we use PCI
94 //
95 #define NIC_INTERFACE_TYPE      NdisInterfacePci
96 #define NIC_INTERRUPT_MODE      NdisInterruptLevelSensitive
97
98 //
99 // buffer size passed in NdisMQueryAdapterResources
100 // We should only need three adapter resources (IO, interrupt and memory),
101 // Some devices get extra resources, so have room for 10 resources
102 //                    UF_SIZE   (sizeof(NDIS_RESOURCE_LIST) + (10*sizeof(CM_PARTIAL_RESOURCE_DESCRIPTOR)))
103
104
105 #define NIC_RESOURCE_B//
106 // IO space length
107 //
108 #define NIC_MAP_IOSPACE_LENGTH  sizeof(CSR_STRUC)
109
110 #define MAX_RX_PKT_LEN  1520
111
112 //
113 // Entry number for each DMA descriptor ring
114 //
115
116
117 #ifdef RT2870
118 #define TX_RING_SIZE            8 // 1
119 #define PRIO_RING_SIZE          8
120 #define MGMT_RING_SIZE       32 // PRIO_RING_SIZE
121 #define RX_RING_SIZE            8
122 #define MAX_TX_PROCESS          4
123 #define LOCAL_TXBUF_SIZE        2048
124 #endif // RT2870 //
125
126 #define MAX_RX_PROCESS          128 //64 //32
127 #define NUM_OF_LOCAL_TXBUF      2
128 #define TXD_SIZE                16
129 #define TXWI_SIZE               16
130 #define RXD_SIZE                16
131 #define RXWI_SIZE               16
132 // TXINFO_SIZE + TXWI_SIZE + 802.11 Header Size + AMSDU sub frame header
133 #define TX_DMA_1ST_BUFFER_SIZE  96    // only the 1st physical buffer is pre-allocated
134 #define MGMT_DMA_BUFFER_SIZE    1536 //2048
135 #define RX_BUFFER_AGGRESIZE     3840 //3904 //3968 //4096 //2048 //4096
136 #define RX_BUFFER_NORMSIZE      3840 //3904 //3968 //4096 //2048 //4096
137 #define TX_BUFFER_NORMSIZE              RX_BUFFER_NORMSIZE
138 #define MAX_FRAME_SIZE          2346                    // Maximum 802.11 frame size
139 #define MAX_AGGREGATION_SIZE    3840 //3904 //3968 //4096
140 #define MAX_NUM_OF_TUPLE_CACHE  2
141 #define MAX_MCAST_LIST_SIZE     32
142 #define MAX_LEN_OF_VENDOR_DESC  64
143 //#define MAX_SIZE_OF_MCAST_PSQ   (NUM_OF_LOCAL_TXBUF >> 2) // AP won't spend more than 1/4 of total buffers on M/BCAST PSQ
144 #define MAX_SIZE_OF_MCAST_PSQ               32
145
146 #define MAX_RX_PROCESS_CNT      (RX_RING_SIZE)
147
148
149 #define MAX_PACKETS_IN_QUEUE                            (512) //(512)    // to pass WMM A5-WPAPSK
150 #define MAX_PACKETS_IN_MCAST_PS_QUEUE           32
151 #define MAX_PACKETS_IN_PS_QUEUE                         128     //32
152 #define WMM_NUM_OF_AC                       4  /* AC0, AC1, AC2, and AC3 */
153
154
155
156 // RxFilter
157 #define STANORMAL        0x17f97
158 #define APNORMAL         0x15f97
159 //
160 //  RTMP_ADAPTER flags
161 //
162 #define fRTMP_ADAPTER_MAP_REGISTER          0x00000001
163 #define fRTMP_ADAPTER_INTERRUPT_IN_USE      0x00000002
164 #define fRTMP_ADAPTER_HARDWARE_ERROR        0x00000004
165 #define fRTMP_ADAPTER_SCATTER_GATHER        0x00000008
166 #define fRTMP_ADAPTER_SEND_PACKET_ERROR     0x00000010
167 #define fRTMP_ADAPTER_MLME_RESET_IN_PROGRESS 0x00000020
168 #define fRTMP_ADAPTER_HALT_IN_PROGRESS      0x00000040
169 #define fRTMP_ADAPTER_RESET_IN_PROGRESS     0x00000080
170 #define fRTMP_ADAPTER_NIC_NOT_EXIST         0x00000100
171 #define fRTMP_ADAPTER_TX_RING_ALLOCATED     0x00000200
172 #define fRTMP_ADAPTER_REMOVE_IN_PROGRESS    0x00000400
173 #define fRTMP_ADAPTER_MIMORATE_INUSED       0x00000800
174 #define fRTMP_ADAPTER_RX_RING_ALLOCATED     0x00001000
175 #define fRTMP_ADAPTER_INTERRUPT_ACTIVE      0x00002000
176 #define fRTMP_ADAPTER_BSS_SCAN_IN_PROGRESS  0x00004000
177 #define fRTMP_ADAPTER_REASSOC_IN_PROGRESS       0x00008000
178 #define fRTMP_ADAPTER_MEDIA_STATE_PENDING       0x00010000
179 #define fRTMP_ADAPTER_RADIO_OFF                         0x00020000
180 #define fRTMP_ADAPTER_BULKOUT_RESET                     0x00040000
181 #define fRTMP_ADAPTER_BULKIN_RESET                      0x00080000
182 #define fRTMP_ADAPTER_RDG_ACTIVE                        0x00100000
183 #define fRTMP_ADAPTER_DYNAMIC_BE_TXOP_ACTIVE 0x00200000
184 #define fRTMP_ADAPTER_SCAN_2040                         0x04000000
185 #define fRTMP_ADAPTER_RADIO_MEASUREMENT         0x08000000
186
187 #define fRTMP_ADAPTER_START_UP                  0x10000000      //Devive already initialized and enabled Tx/Rx.
188 #define fRTMP_ADAPTER_MEDIA_STATE_CHANGE    0x20000000
189 #define fRTMP_ADAPTER_IDLE_RADIO_OFF        0x40000000
190
191 // Lock bit for accessing different ring buffers
192 //#define fRTMP_ADAPTER_TX_RING_BUSY        0x80000000
193 //#define fRTMP_ADAPTER_MGMT_RING_BUSY      0x40000000
194 //#define fRTMP_ADAPTER_ATIM_RING_BUSY      0x20000000
195 //#define fRTMP_ADAPTER_RX_RING_BUSY        0x10000000
196
197 // Lock bit for accessing different queue
198 //#define   fRTMP_ADAPTER_TX_QUEUE_BUSY     0x08000000
199 //#define   fRTMP_ADAPTER_MGMT_QUEUE_BUSY   0x04000000
200
201 //
202 //  STA operation status flags
203 //
204 #define fOP_STATUS_INFRA_ON                 0x00000001
205 #define fOP_STATUS_ADHOC_ON                 0x00000002
206 #define fOP_STATUS_BG_PROTECTION_INUSED     0x00000004
207 #define fOP_STATUS_SHORT_SLOT_INUSED        0x00000008
208 #define fOP_STATUS_SHORT_PREAMBLE_INUSED    0x00000010
209 #define fOP_STATUS_RECEIVE_DTIM             0x00000020
210 //#define fOP_STATUS_TX_RATE_SWITCH_ENABLED   0x00000040
211 #define fOP_STATUS_MEDIA_STATE_CONNECTED    0x00000080
212 #define fOP_STATUS_WMM_INUSED               0x00000100
213 #define fOP_STATUS_AGGREGATION_INUSED       0x00000200
214 #define fOP_STATUS_DOZE                     0x00000400  // debug purpose
215 #define fOP_STATUS_PIGGYBACK_INUSED         0x00000800  // piggy-back, and aggregation
216 #define fOP_STATUS_APSD_INUSED                          0x00001000
217 #define fOP_STATUS_TX_AMSDU_INUSED                      0x00002000
218 #define fOP_STATUS_MAX_RETRY_ENABLED            0x00004000
219 #define fOP_STATUS_WAKEUP_NOW               0x00008000
220 #define fOP_STATUS_ADVANCE_POWER_SAVE_PCIE_DEVICE       0x00020000
221
222 #ifdef DOT11N_DRAFT3
223 #define fOP_STATUS_SCAN_2040                        0x00040000
224 #endif // DOT11N_DRAFT3 //
225
226 #define CCKSETPROTECT           0x1
227 #define OFDMSETPROTECT          0x2
228 #define MM20SETPROTECT          0x4
229 #define MM40SETPROTECT          0x8
230 #define GF20SETPROTECT          0x10
231 #define GR40SETPROTECT          0x20
232 #define ALLN_SETPROTECT         (GR40SETPROTECT | GF20SETPROTECT | MM40SETPROTECT | MM20SETPROTECT)
233
234 //
235 //  AP's client table operation status flags
236 //
237 #define fCLIENT_STATUS_WMM_CAPABLE          0x00000001  // CLIENT can parse QOS DATA frame
238 #define fCLIENT_STATUS_AGGREGATION_CAPABLE  0x00000002  // CLIENT can receive Ralink's proprietary TX aggregation frame
239 #define fCLIENT_STATUS_PIGGYBACK_CAPABLE    0x00000004  // CLIENT support piggy-back
240 #define fCLIENT_STATUS_AMSDU_INUSED                     0x00000008
241 #define fCLIENT_STATUS_SGI20_CAPABLE            0x00000010
242 #define fCLIENT_STATUS_SGI40_CAPABLE            0x00000020
243 #define fCLIENT_STATUS_TxSTBC_CAPABLE           0x00000040
244 #define fCLIENT_STATUS_RxSTBC_CAPABLE           0x00000080
245 #define fCLIENT_STATUS_HTC_CAPABLE                      0x00000100
246 #define fCLIENT_STATUS_RDG_CAPABLE                      0x00000200
247 #define fCLIENT_STATUS_MCSFEEDBACK_CAPABLE  0x00000400
248 #define fCLIENT_STATUS_APSD_CAPABLE         0x00000800  /* UAPSD STATION */
249
250 #ifdef DOT11N_DRAFT3
251 #define fCLIENT_STATUS_BSSCOEXIST_CAPABLE       0x00001000
252 #endif // DOT11N_DRAFT3 //
253
254 #define fCLIENT_STATUS_RALINK_CHIPSET           0x00100000
255 //
256 //  STA configuration flags
257 //
258 //#define fSTA_CFG_ENABLE_TX_BURST          0x00000001
259
260 // 802.11n Operating Mode Definition. 0-3 also used in ASICUPdateProtect switch case
261 #define HT_NO_PROTECT   0
262 #define HT_LEGACY_PROTECT       1
263 #define HT_40_PROTECT   2
264 #define HT_2040_PROTECT 3
265 #define HT_RTSCTS_6M    7
266 //following is our own definition in order to turn on our ASIC protection register in INFRASTRUCTURE.
267 #define HT_ATHEROS      8       // rt2860c has problem with atheros chip. we need to turn on RTS/CTS .
268 #define HT_FORCERTSCTS  9       // Force turn on RTS/CTS first. then go to evaluate if this force RTS is necessary.
269
270 //
271 // RX Packet Filter control flags. Apply on pAd->PacketFilter
272 //
273 #define fRX_FILTER_ACCEPT_DIRECT            NDIS_PACKET_TYPE_DIRECTED
274 #define fRX_FILTER_ACCEPT_MULTICAST         NDIS_PACKET_TYPE_MULTICAST
275 #define fRX_FILTER_ACCEPT_BROADCAST         NDIS_PACKET_TYPE_BROADCAST
276 #define fRX_FILTER_ACCEPT_ALL_MULTICAST     NDIS_PACKET_TYPE_ALL_MULTICAST
277
278 //
279 // Error code section
280 //
281 // NDIS_ERROR_CODE_ADAPTER_NOT_FOUND
282 #define ERRLOG_READ_PCI_SLOT_FAILED     0x00000101L
283 #define ERRLOG_WRITE_PCI_SLOT_FAILED    0x00000102L
284 #define ERRLOG_VENDOR_DEVICE_NOMATCH    0x00000103L
285
286 // NDIS_ERROR_CODE_ADAPTER_DISABLED
287 #define ERRLOG_BUS_MASTER_DISABLED      0x00000201L
288
289 // NDIS_ERROR_CODE_UNSUPPORTED_CONFIGURATION
290 #define ERRLOG_INVALID_SPEED_DUPLEX     0x00000301L
291 #define ERRLOG_SET_SECONDARY_FAILED     0x00000302L
292
293 // NDIS_ERROR_CODE_OUT_OF_RESOURCES
294 #define ERRLOG_OUT_OF_MEMORY            0x00000401L
295 #define ERRLOG_OUT_OF_SHARED_MEMORY     0x00000402L
296 #define ERRLOG_OUT_OF_MAP_REGISTERS     0x00000403L
297 #define ERRLOG_OUT_OF_BUFFER_POOL       0x00000404L
298 #define ERRLOG_OUT_OF_NDIS_BUFFER       0x00000405L
299 #define ERRLOG_OUT_OF_PACKET_POOL       0x00000406L
300 #define ERRLOG_OUT_OF_NDIS_PACKET       0x00000407L
301 #define ERRLOG_OUT_OF_LOOKASIDE_MEMORY  0x00000408L
302
303 // NDIS_ERROR_CODE_HARDWARE_FAILURE
304 #define ERRLOG_SELFTEST_FAILED          0x00000501L
305 #define ERRLOG_INITIALIZE_ADAPTER       0x00000502L
306 #define ERRLOG_REMOVE_MINIPORT          0x00000503L
307
308 // NDIS_ERROR_CODE_RESOURCE_CONFLICT
309 #define ERRLOG_MAP_IO_SPACE             0x00000601L
310 #define ERRLOG_QUERY_ADAPTER_RESOURCES  0x00000602L
311 #define ERRLOG_NO_IO_RESOURCE           0x00000603L
312 #define ERRLOG_NO_INTERRUPT_RESOURCE    0x00000604L
313 #define ERRLOG_NO_MEMORY_RESOURCE       0x00000605L
314
315
316 // WDS definition
317 #define MAX_WDS_ENTRY               4
318 #define WDS_PAIRWISE_KEY_OFFSET     60    // WDS links uses pairwise key#60 ~ 63 in ASIC pairwise key table
319
320 #define WDS_DISABLE_MODE            0
321 #define WDS_RESTRICT_MODE           1
322 #define WDS_BRIDGE_MODE             2
323 #define WDS_REPEATER_MODE           3
324 #define WDS_LAZY_MODE               4
325
326
327 #define MAX_MESH_NUM                            0
328
329 #define MAX_APCLI_NUM                           0
330
331 #define MAX_MBSSID_NUM                          1
332
333 /* sanity check for apidx */
334 #define MBSS_MR_APIDX_SANITY_CHECK(apidx) \
335     { if (apidx > MAX_MBSSID_NUM) { \
336           printk("%s> Error! apidx = %d > MAX_MBSSID_NUM!\n", __func__, apidx); \
337           apidx = MAIN_MBSSID; } }
338
339 #define VALID_WCID(_wcid)       ((_wcid) > 0 && (_wcid) < MAX_LEN_OF_MAC_TABLE )
340
341 #define MAIN_MBSSID                 0
342 #define FIRST_MBSSID                1
343
344
345 #define MAX_BEACON_SIZE                         512
346 // If the MAX_MBSSID_NUM is larger than 6,
347 // it shall reserve some WCID space(wcid 222~253) for beacon frames.
348 // -    these wcid 238~253 are reserved for beacon#6(ra6).
349 // -    these wcid 222~237 are reserved for beacon#7(ra7).
350 #if defined(MAX_MBSSID_NUM) && (MAX_MBSSID_NUM == 8)
351 #define HW_RESERVED_WCID        222
352 #elif defined(MAX_MBSSID_NUM) && (MAX_MBSSID_NUM == 7)
353 #define HW_RESERVED_WCID        238
354 #else
355 #define HW_RESERVED_WCID        255
356 #endif
357
358 // Then dedicate wcid of DFS and Carrier-Sense.
359 #define DFS_CTS_WCID            (HW_RESERVED_WCID - 1)
360 #define CS_CTS_WCID             (HW_RESERVED_WCID - 2)
361 #define LAST_SPECIFIC_WCID      (HW_RESERVED_WCID - 2)
362
363 // If MAX_MBSSID_NUM is 8, the maximum available wcid for the associated STA is 211.
364 // If MAX_MBSSID_NUM is 7, the maximum available wcid for the associated STA is 228.
365 #define MAX_AVAILABLE_CLIENT_WCID       (LAST_SPECIFIC_WCID - MAX_MBSSID_NUM - 1)
366
367 // TX need WCID to find Cipher Key
368 // these wcid 212 ~ 219 are reserved for bc/mc packets if MAX_MBSSID_NUM is 8.
369 #define GET_GroupKey_WCID(__wcid, __bssidx) \
370         {                                                                               \
371                 __wcid = LAST_SPECIFIC_WCID - (MAX_MBSSID_NUM) + __bssidx;      \
372         }
373
374 #define IsGroupKeyWCID(__wcid) (((__wcid) < LAST_SPECIFIC_WCID) && ((__wcid) >= (LAST_SPECIFIC_WCID - (MAX_MBSSID_NUM))))
375
376
377 // definition to support multiple BSSID
378 #define BSS0                            0
379 #define BSS1                            1
380 #define BSS2                            2
381 #define BSS3                            3
382 #define BSS4                            4
383 #define BSS5                            5
384 #define BSS6                            6
385 #define BSS7                            7
386
387
388 //============================================================
389 // Length definitions
390 #define PEER_KEY_NO                     2
391 #define MAC_ADDR_LEN                    6
392 #define TIMESTAMP_LEN                   8
393 #define MAX_LEN_OF_SUPPORTED_RATES      MAX_LENGTH_OF_SUPPORT_RATES // 1, 2, 5.5, 11, 6, 9, 12, 18, 24, 36, 48, 54
394 #define MAX_LEN_OF_KEY                  32      // 32 octets == 256 bits, Redefine for WPA
395 #define MAX_NUM_OF_CHANNELS             MAX_NUM_OF_CHS      // 14 channels @2.4G +  12@UNII + 4 @MMAC + 11 @HiperLAN2 + 7 @Japan + 1 as NULL termination
396 #define MAX_NUM_OF_11JCHANNELS             20      // 14 channels @2.4G +  12@UNII + 4 @MMAC + 11 @HiperLAN2 + 7 @Japan + 1 as NULL termination
397 #define MAX_LEN_OF_SSID                 32
398 #define CIPHER_TEXT_LEN                 128
399 #define HASH_TABLE_SIZE                 256
400 #define MAX_VIE_LEN                     1024   // New for WPA cipher suite variable IE sizes.
401 #define MAX_SUPPORT_MCS             32
402
403 //============================================================
404 // ASIC WCID Table definition.
405 //============================================================
406 #define BSSID_WCID              1       // in infra mode, always put bssid with this WCID
407 #define MCAST_WCID      0x0
408 #define BSS0Mcast_WCID  0x0
409 #define BSS1Mcast_WCID  0xf8
410 #define BSS2Mcast_WCID  0xf9
411 #define BSS3Mcast_WCID  0xfa
412 #define BSS4Mcast_WCID  0xfb
413 #define BSS5Mcast_WCID  0xfc
414 #define BSS6Mcast_WCID  0xfd
415 #define BSS7Mcast_WCID  0xfe
416 #define RESERVED_WCID           0xff
417
418 #define MAX_NUM_OF_ACL_LIST                             MAX_NUMBER_OF_ACL
419
420 #define MAX_LEN_OF_MAC_TABLE            MAX_NUMBER_OF_MAC // if MAX_MBSSID_NUM is 8, this value can't be larger than 211
421
422 #if MAX_LEN_OF_MAC_TABLE>MAX_AVAILABLE_CLIENT_WCID
423 #error MAX_LEN_OF_MAC_TABLE can not be larger than MAX_AVAILABLE_CLIENT_WCID!!!!
424 #endif
425
426 #define MAX_NUM_OF_WDS_LINK_PERBSSID                3
427 #define MAX_NUM_OF_WDS_LINK                 (MAX_NUM_OF_WDS_LINK_PERBSSID*MAX_MBSSID_NUM)
428 #define MAX_NUM_OF_EVENT                MAX_NUMBER_OF_EVENT
429 #define WDS_LINK_START_WCID                             (MAX_LEN_OF_MAC_TABLE-1)
430
431 #define NUM_OF_TID                      8
432 #define MAX_AID_BA                    4
433 #define MAX_LEN_OF_BA_REC_TABLE          ((NUM_OF_TID * MAX_LEN_OF_MAC_TABLE)/2)//   (NUM_OF_TID*MAX_AID_BA + 32)        //Block ACK recipient
434 #define MAX_LEN_OF_BA_ORI_TABLE          ((NUM_OF_TID * MAX_LEN_OF_MAC_TABLE)/2)//   (NUM_OF_TID*MAX_AID_BA + 32)   // Block ACK originator
435 #define MAX_LEN_OF_BSS_TABLE             64
436 #define MAX_REORDERING_MPDU_NUM                  512
437
438 // key related definitions
439 #define SHARE_KEY_NUM                   4
440 #define MAX_LEN_OF_SHARE_KEY            16    // byte count
441 #define MAX_LEN_OF_PEER_KEY             16    // byte count
442 #define PAIRWISE_KEY_NUM                64    // in MAC ASIC pairwise key table
443 #define GROUP_KEY_NUM                   4
444 #define PMK_LEN                         32
445 #define WDS_PAIRWISE_KEY_OFFSET         60    // WDS links uses pairwise key#60 ~ 63 in ASIC pairwise key table
446 #define PMKID_NO                        4     // Number of PMKID saved supported
447 #define MAX_LEN_OF_MLME_BUFFER          2048
448
449 // power status related definitions
450 #define PWR_ACTIVE                      0
451 #define PWR_SAVE                        1
452 #define PWR_MMPS                        2                       //MIMO power save
453 //#define PWR_UNKNOWN                   2
454
455 // Auth and Assoc mode related definitions
456 #define AUTH_MODE_OPEN                  0x00
457 #define AUTH_MODE_KEY                   0x01
458 //#define AUTH_MODE_AUTO_SWITCH         0x03
459 //#define AUTH_MODE_DEAUTH              0x04
460 //#define AUTH_MODE_UPLAYER             0x05 // reserved for 802.11i use
461
462 // BSS Type definitions
463 #define BSS_ADHOC                       0  // = Ndis802_11IBSS
464 #define BSS_INFRA                       1  // = Ndis802_11Infrastructure
465 #define BSS_ANY                         2  // = Ndis802_11AutoUnknown
466 #define BSS_MONITOR                                 3  // = Ndis802_11Monitor
467
468
469 // Reason code definitions
470 #define REASON_RESERVED                 0
471 #define REASON_UNSPECIFY                1
472 #define REASON_NO_LONGER_VALID          2
473 #define REASON_DEAUTH_STA_LEAVING       3
474 #define REASON_DISASSOC_INACTIVE        4
475 #define REASON_DISASSPC_AP_UNABLE       5
476 #define REASON_CLS2ERR                  6
477 #define REASON_CLS3ERR                  7
478 #define REASON_DISASSOC_STA_LEAVING     8
479 #define REASON_STA_REQ_ASSOC_NOT_AUTH   9
480 #define REASON_INVALID_IE               13
481 #define REASON_MIC_FAILURE              14
482 #define REASON_4_WAY_TIMEOUT            15
483 #define REASON_GROUP_KEY_HS_TIMEOUT     16
484 #define REASON_IE_DIFFERENT             17
485 #define REASON_MCIPHER_NOT_VALID        18
486 #define REASON_UCIPHER_NOT_VALID        19
487 #define REASON_AKMP_NOT_VALID           20
488 #define REASON_UNSUPPORT_RSNE_VER       21
489 #define REASON_INVALID_RSNE_CAP         22
490 #define REASON_8021X_AUTH_FAIL          23
491 #define REASON_CIPHER_SUITE_REJECTED    24
492 #define REASON_DECLINED                 37
493
494 #define REASON_QOS_UNSPECIFY              32
495 #define REASON_QOS_LACK_BANDWIDTH         33
496 #define REASON_POOR_CHANNEL_CONDITION     34
497 #define REASON_QOS_OUTSIDE_TXOP_LIMITION  35
498 #define REASON_QOS_QSTA_LEAVING_QBSS      36
499 #define REASON_QOS_UNWANTED_MECHANISM     37
500 #define REASON_QOS_MECH_SETUP_REQUIRED    38
501 #define REASON_QOS_REQUEST_TIMEOUT        39
502 #define REASON_QOS_CIPHER_NOT_SUPPORT     45
503
504 // Status code definitions
505 #define MLME_SUCCESS                    0
506 #define MLME_UNSPECIFY_FAIL             1
507 #define MLME_CANNOT_SUPPORT_CAP         10
508 #define MLME_REASSOC_DENY_ASSOC_EXIST   11
509 #define MLME_ASSOC_DENY_OUT_SCOPE       12
510 #define MLME_ALG_NOT_SUPPORT            13
511 #define MLME_SEQ_NR_OUT_OF_SEQUENCE     14
512 #define MLME_REJ_CHALLENGE_FAILURE      15
513 #define MLME_REJ_TIMEOUT                  16
514 #define MLME_ASSOC_REJ_UNABLE_HANDLE_STA  17
515 #define MLME_ASSOC_REJ_DATA_RATE          18
516
517 #define MLME_ASSOC_REJ_NO_EXT_RATE        22
518 #define MLME_ASSOC_REJ_NO_EXT_RATE_PBCC   23
519 #define MLME_ASSOC_REJ_NO_CCK_OFDM        24
520
521 #define MLME_QOS_UNSPECIFY                32
522 #define MLME_REQUEST_DECLINED             37
523 #define MLME_REQUEST_WITH_INVALID_PARAM   38
524 #define MLME_DLS_NOT_ALLOW_IN_QBSS        48
525 #define MLME_DEST_STA_NOT_IN_QBSS         49
526 #define MLME_DEST_STA_IS_NOT_A_QSTA       50
527
528 #define MLME_INVALID_FORMAT             0x51
529 #define MLME_FAIL_NO_RESOURCE           0x52
530 #define MLME_STATE_MACHINE_REJECT       0x53
531 #define MLME_MAC_TABLE_FAIL             0x54
532
533 // IE code
534 #define IE_SSID                         0
535 #define IE_SUPP_RATES                   1
536 #define IE_FH_PARM                      2
537 #define IE_DS_PARM                      3
538 #define IE_CF_PARM                      4
539 #define IE_TIM                          5
540 #define IE_IBSS_PARM                    6
541 #define IE_COUNTRY                      7     // 802.11d
542 #define IE_802_11D_REQUEST              10    // 802.11d
543 #define IE_QBSS_LOAD                    11    // 802.11e d9
544 #define IE_EDCA_PARAMETER               12    // 802.11e d9
545 #define IE_TSPEC                        13    // 802.11e d9
546 #define IE_TCLAS                        14    // 802.11e d9
547 #define IE_SCHEDULE                     15    // 802.11e d9
548 #define IE_CHALLENGE_TEXT               16
549 #define IE_POWER_CONSTRAINT             32    // 802.11h d3.3
550 #define IE_POWER_CAPABILITY             33    // 802.11h d3.3
551 #define IE_TPC_REQUEST                  34    // 802.11h d3.3
552 #define IE_TPC_REPORT                   35    // 802.11h d3.3
553 #define IE_SUPP_CHANNELS                36    // 802.11h d3.3
554 #define IE_CHANNEL_SWITCH_ANNOUNCEMENT  37    // 802.11h d3.3
555 #define IE_MEASUREMENT_REQUEST          38    // 802.11h d3.3
556 #define IE_MEASUREMENT_REPORT           39    // 802.11h d3.3
557 #define IE_QUIET                        40    // 802.11h d3.3
558 #define IE_IBSS_DFS                     41    // 802.11h d3.3
559 #define IE_ERP                          42    // 802.11g
560 #define IE_TS_DELAY                     43    // 802.11e d9
561 #define IE_TCLAS_PROCESSING             44    // 802.11e d9
562 #define IE_QOS_CAPABILITY               46    // 802.11e d6
563 #define IE_HT_CAP                       45    // 802.11n d1. HT CAPABILITY. ELEMENT ID TBD
564 #define IE_AP_CHANNEL_REPORT                    51    // 802.11k d6
565 #define IE_HT_CAP2                         52    // 802.11n d1. HT CAPABILITY. ELEMENT ID TBD
566 #define IE_RSN                          48    // 802.11i d3.0
567 #define IE_WPA2                         48    // WPA2
568 #define IE_EXT_SUPP_RATES               50    // 802.11g
569 #define IE_SUPP_REG_CLASS               59    // 802.11y. Supported regulatory classes.
570 #define IE_EXT_CHANNEL_SWITCH_ANNOUNCEMENT      60      // 802.11n
571 #define IE_ADD_HT                         61    // 802.11n d1. ADDITIONAL HT CAPABILITY. ELEMENT ID TBD
572 #define IE_ADD_HT2                        53    // 802.11n d1. ADDITIONAL HT CAPABILITY. ELEMENT ID TBD
573
574
575 // For 802.11n D3.03
576 //#define IE_NEW_EXT_CHA_OFFSET             62    // 802.11n d1. New extension channel offset elemet
577 #define IE_SECONDARY_CH_OFFSET          62      // 802.11n D3.03        Secondary Channel Offset element
578 #define IE_WAPI                                                 68              // WAPI information element
579 #define IE_2040_BSS_COEXIST               72    // 802.11n D3.0.3
580 #define IE_2040_BSS_INTOLERANT_REPORT     73    // 802.11n D3.03
581 #define IE_OVERLAPBSS_SCAN_PARM           74    // 802.11n D3.03
582 #define IE_EXT_CAPABILITY                127   // 802.11n D3.03
583
584
585 #define IE_WPA                          221   // WPA
586 #define IE_VENDOR_SPECIFIC              221   // Wifi WMM (WME)
587
588 #define OUI_BROADCOM_HT              51   //
589 #define OUI_BROADCOM_HTADD              52   //
590 #define OUI_PREN_HT_CAP              51   //
591 #define OUI_PREN_ADD_HT              52   //
592
593 // CCX information
594 #define IE_AIRONET_CKIP                 133   // CCX1.0 ID 85H for CKIP
595 #define IE_AP_TX_POWER                  150   // CCX 2.0 for AP transmit power
596 #define IE_MEASUREMENT_CAPABILITY       221   // CCX 2.0
597 #define IE_CCX_V2                       221
598 #define IE_AIRONET_IPADDRESS            149   // CCX ID 95H for IP Address
599 #define IE_AIRONET_CCKMREASSOC          156   // CCX ID 9CH for CCKM Reassociation Request element
600 #define CKIP_NEGOTIATION_LENGTH         30
601 #define AIRONET_IPADDRESS_LENGTH        10
602 #define AIRONET_CCKMREASSOC_LENGTH      24
603
604 // ========================================================
605 // MLME state machine definition
606 // ========================================================
607
608 // STA MLME state mahcines
609 #define ASSOC_STATE_MACHINE             1
610 #define AUTH_STATE_MACHINE              2
611 #define AUTH_RSP_STATE_MACHINE          3
612 #define SYNC_STATE_MACHINE              4
613 #define MLME_CNTL_STATE_MACHINE         5
614 #define WPA_PSK_STATE_MACHINE           6
615 #define LEAP_STATE_MACHINE              7
616 #define AIRONET_STATE_MACHINE           8
617 #define ACTION_STATE_MACHINE           9
618
619 // AP MLME state machines
620 #define AP_ASSOC_STATE_MACHINE          11
621 #define AP_AUTH_STATE_MACHINE           12
622 #define AP_AUTH_RSP_STATE_MACHINE       13
623 #define AP_SYNC_STATE_MACHINE           14
624 #define AP_CNTL_STATE_MACHINE           15
625 #define AP_WPA_STATE_MACHINE            16
626
627 //
628 // STA's CONTROL/CONNECT state machine: states, events, total function #
629 //
630 #define CNTL_IDLE                       0
631 #define CNTL_WAIT_DISASSOC              1
632 #define CNTL_WAIT_JOIN                  2
633 #define CNTL_WAIT_REASSOC               3
634 #define CNTL_WAIT_START                 4
635 #define CNTL_WAIT_AUTH                  5
636 #define CNTL_WAIT_ASSOC                 6
637 #define CNTL_WAIT_AUTH2                 7
638 #define CNTL_WAIT_OID_LIST_SCAN         8
639 #define CNTL_WAIT_OID_DISASSOC          9
640 #ifdef RT2870
641 #define CNTL_WAIT_SCAN_FOR_CONNECT      10
642 #endif // RT2870 //
643
644 #define MT2_ASSOC_CONF                  34
645 #define MT2_AUTH_CONF                   35
646 #define MT2_DEAUTH_CONF                 36
647 #define MT2_DISASSOC_CONF               37
648 #define MT2_REASSOC_CONF                38
649 #define MT2_PWR_MGMT_CONF               39
650 #define MT2_JOIN_CONF                   40
651 #define MT2_SCAN_CONF                   41
652 #define MT2_START_CONF                  42
653 #define MT2_GET_CONF                    43
654 #define MT2_SET_CONF                    44
655 #define MT2_RESET_CONF                  45
656 #define MT2_MLME_ROAMING_REQ            52
657
658 #define CNTL_FUNC_SIZE                  1
659
660 //
661 // STA's ASSOC state machine: states, events, total function #
662 //
663 #define ASSOC_IDLE                      0
664 #define ASSOC_WAIT_RSP                  1
665 #define REASSOC_WAIT_RSP                2
666 #define DISASSOC_WAIT_RSP               3
667 #define MAX_ASSOC_STATE                 4
668
669 #define ASSOC_MACHINE_BASE              0
670 #define MT2_MLME_ASSOC_REQ              0
671 #define MT2_MLME_REASSOC_REQ            1
672 #define MT2_MLME_DISASSOC_REQ           2
673 #define MT2_PEER_DISASSOC_REQ           3
674 #define MT2_PEER_ASSOC_REQ              4
675 #define MT2_PEER_ASSOC_RSP              5
676 #define MT2_PEER_REASSOC_REQ            6
677 #define MT2_PEER_REASSOC_RSP            7
678 #define MT2_DISASSOC_TIMEOUT            8
679 #define MT2_ASSOC_TIMEOUT               9
680 #define MT2_REASSOC_TIMEOUT             10
681 #define MAX_ASSOC_MSG                   11
682
683 #define ASSOC_FUNC_SIZE                 (MAX_ASSOC_STATE * MAX_ASSOC_MSG)
684
685 //
686 // ACT state machine: states, events, total function #
687 //
688 #define ACT_IDLE                      0
689 #define MAX_ACT_STATE                 1
690
691 #define ACT_MACHINE_BASE              0
692
693 //Those PEER_xx_CATE number is based on real Categary value in IEEE spec. Please don'es modify it by your self.
694 //Category
695 #define MT2_PEER_SPECTRUM_CATE              0
696 #define MT2_PEER_QOS_CATE              1
697 #define MT2_PEER_DLS_CATE             2
698 #define MT2_PEER_BA_CATE             3
699 #define MT2_PEER_PUBLIC_CATE             4
700 #define MT2_PEER_RM_CATE             5
701 #define MT2_PEER_HT_CATE             7  //      7.4.7
702 #define MAX_PEER_CATE_MSG                   7
703 #define MT2_MLME_ADD_BA_CATE             8
704 #define MT2_MLME_ORI_DELBA_CATE             9
705 #define MT2_MLME_REC_DELBA_CATE             10
706 #define MT2_MLME_QOS_CATE              11
707 #define MT2_MLME_DLS_CATE             12
708 #define MT2_ACT_INVALID             13
709 #define MAX_ACT_MSG                   14
710
711 //Category field
712 #define CATEGORY_SPECTRUM               0
713 #define CATEGORY_QOS                    1
714 #define CATEGORY_DLS                    2
715 #define CATEGORY_BA                     3
716 #define CATEGORY_PUBLIC         4
717 #define CATEGORY_RM                     5
718 #define CATEGORY_HT                     7
719
720
721 // DLS Action frame definition
722 #define ACTION_DLS_REQUEST                      0
723 #define ACTION_DLS_RESPONSE                     1
724 #define ACTION_DLS_TEARDOWN                     2
725
726 //Spectrum  Action field value 802.11h 7.4.1
727 #define SPEC_MRQ        0       // Request
728 #define SPEC_MRP        1       //Report
729 #define SPEC_TPCRQ      2
730 #define SPEC_TPCRP      3
731 #define SPEC_CHANNEL_SWITCH     4
732
733
734 //BA  Action field value
735 #define ADDBA_REQ       0
736 #define ADDBA_RESP      1
737 #define DELBA   2
738
739 //Public's  Action field value in Public Category.  Some in 802.11y and some in 11n
740 #define ACTION_BSS_2040_COEXIST                         0       // 11n
741 #define ACTION_DSE_ENABLEMENT                                   1       // 11y D9.0
742 #define ACTION_DSE_DEENABLEMENT                         2       // 11y D9.0
743 #define ACTION_DSE_REG_LOCATION_ANNOUNCE        3       // 11y D9.0
744 #define ACTION_EXT_CH_SWITCH_ANNOUNCE           4       // 11y D9.0
745 #define ACTION_DSE_MEASUREMENT_REQ                      5       // 11y D9.0
746 #define ACTION_DSE_MEASUREMENT_REPORT           6       // 11y D9.0
747 #define ACTION_MEASUREMENT_PILOT_ACTION         7       // 11y D9.0
748 #define ACTION_DSE_POWER_CONSTRAINT                     8       // 11y D9.0
749
750
751 //HT  Action field value
752 #define NOTIFY_BW_ACTION                                0
753 #define SMPS_ACTION                                             1
754 #define PSMP_ACTION                                     2
755 #define SETPCO_ACTION                                   3
756 #define MIMO_CHA_MEASURE_ACTION                 4
757 #define MIMO_N_BEACONFORM                               5
758 #define MIMO_BEACONFORM                                 6
759 #define ANTENNA_SELECT                                  7
760 #define HT_INFO_EXCHANGE                                8
761
762 #define ACT_FUNC_SIZE                 (MAX_ACT_STATE * MAX_ACT_MSG)
763 //
764 // STA's AUTHENTICATION state machine: states, evvents, total function #
765 //
766 #define AUTH_REQ_IDLE                   0
767 #define AUTH_WAIT_SEQ2                  1
768 #define AUTH_WAIT_SEQ4                  2
769 #define MAX_AUTH_STATE                  3
770
771 #define AUTH_MACHINE_BASE               0
772 #define MT2_MLME_AUTH_REQ               0
773 #define MT2_PEER_AUTH_EVEN              1
774 #define MT2_AUTH_TIMEOUT                2
775 #define MAX_AUTH_MSG                    3
776
777 #define AUTH_FUNC_SIZE                  (MAX_AUTH_STATE * MAX_AUTH_MSG)
778
779 //
780 // STA's AUTH_RSP state machine: states, events, total function #
781 //
782 #define AUTH_RSP_IDLE                   0
783 #define AUTH_RSP_WAIT_CHAL              1
784 #define MAX_AUTH_RSP_STATE              2
785
786 #define AUTH_RSP_MACHINE_BASE           0
787 #define MT2_AUTH_CHALLENGE_TIMEOUT      0
788 #define MT2_PEER_AUTH_ODD               1
789 #define MT2_PEER_DEAUTH                 2
790 #define MAX_AUTH_RSP_MSG                3
791
792 #define AUTH_RSP_FUNC_SIZE              (MAX_AUTH_RSP_STATE * MAX_AUTH_RSP_MSG)
793
794 //
795 // STA's SYNC state machine: states, events, total function #
796 //
797 #define SYNC_IDLE                       0  // merge NO_BSS,IBSS_IDLE,IBSS_ACTIVE and BSS in to 1 state
798 #define JOIN_WAIT_BEACON                1
799 #define SCAN_LISTEN                     2
800 #define MAX_SYNC_STATE                  3
801
802 #define SYNC_MACHINE_BASE               0
803 #define MT2_MLME_SCAN_REQ               0
804 #define MT2_MLME_JOIN_REQ               1
805 #define MT2_MLME_START_REQ              2
806 #define MT2_PEER_BEACON                 3
807 #define MT2_PEER_PROBE_RSP              4
808 #define MT2_PEER_ATIM                   5
809 #define MT2_SCAN_TIMEOUT                6
810 #define MT2_BEACON_TIMEOUT              7
811 #define MT2_ATIM_TIMEOUT                8
812 #define MT2_PEER_PROBE_REQ              9
813 #define MAX_SYNC_MSG                    10
814
815 #define SYNC_FUNC_SIZE                  (MAX_SYNC_STATE * MAX_SYNC_MSG)
816
817 //Messages for the DLS state machine
818 #define DLS_IDLE                                                0
819 #define MAX_DLS_STATE                                   1
820
821 #define DLS_MACHINE_BASE                                0
822 #define MT2_MLME_DLS_REQ                            0
823 #define MT2_PEER_DLS_REQ                            1
824 #define MT2_PEER_DLS_RSP                            2
825 #define MT2_MLME_DLS_TEAR_DOWN              3
826 #define MT2_PEER_DLS_TEAR_DOWN              4
827 #define MAX_DLS_MSG                                     5
828
829 #define DLS_FUNC_SIZE                                   (MAX_DLS_STATE * MAX_DLS_MSG)
830
831 //
832 // STA's WPA-PSK State machine: states, events, total function #
833 //
834 #define WPA_PSK_IDLE                                    0
835 #define MAX_WPA_PSK_STATE                               1
836
837 #define WPA_MACHINE_BASE                0
838 #define MT2_EAPPacket                   0
839 #define MT2_EAPOLStart                  1
840 #define MT2_EAPOLLogoff                 2
841 #define MT2_EAPOLKey                    3
842 #define MT2_EAPOLASFAlert               4
843 #define MAX_WPA_PSK_MSG                 5
844
845 #define WPA_PSK_FUNC_SIZE                               (MAX_WPA_PSK_STATE * MAX_WPA_PSK_MSG)
846
847 //
848 // STA's CISCO-AIRONET State machine: states, events, total function #
849 //
850 #define AIRONET_IDLE                                    0
851 #define AIRONET_SCANNING                                1
852 #define MAX_AIRONET_STATE                               2
853
854 #define AIRONET_MACHINE_BASE                0
855 #define MT2_AIRONET_MSG                             0
856 #define MT2_AIRONET_SCAN_REQ                1
857 #define MT2_AIRONET_SCAN_DONE               2
858 #define MAX_AIRONET_MSG                             3
859
860 #define AIRONET_FUNC_SIZE                               (MAX_AIRONET_STATE * MAX_AIRONET_MSG)
861
862 //
863 // AP's CONTROL/CONNECT state machine: states, events, total function #
864 //
865 #define AP_CNTL_FUNC_SIZE               1
866
867 //
868 // AP's ASSOC state machine: states, events, total function #
869 //
870 #define AP_ASSOC_IDLE                   0
871 #define AP_MAX_ASSOC_STATE              1
872
873 #define AP_ASSOC_MACHINE_BASE           0
874 #define APMT2_MLME_DISASSOC_REQ         0
875 #define APMT2_PEER_DISASSOC_REQ         1
876 #define APMT2_PEER_ASSOC_REQ            2
877 #define APMT2_PEER_REASSOC_REQ          3
878 #define APMT2_CLS3ERR                   4
879 #define AP_MAX_ASSOC_MSG                5
880
881 #define AP_ASSOC_FUNC_SIZE              (AP_MAX_ASSOC_STATE * AP_MAX_ASSOC_MSG)
882
883 //
884 // AP's AUTHENTICATION state machine: states, events, total function #
885 //
886 #define AP_AUTH_REQ_IDLE                0
887 #define AP_MAX_AUTH_STATE               1
888
889 #define AP_AUTH_MACHINE_BASE            0
890 #define APMT2_MLME_DEAUTH_REQ           0
891 #define APMT2_CLS2ERR                   1
892 #define AP_MAX_AUTH_MSG                 2
893
894 #define AP_AUTH_FUNC_SIZE               (AP_MAX_AUTH_STATE * AP_MAX_AUTH_MSG)
895
896 //
897 // AP's AUTH-RSP state machine: states, events, total function #
898 //
899 #define AP_AUTH_RSP_IDLE                0
900 #define AP_MAX_AUTH_RSP_STATE           1
901
902 #define AP_AUTH_RSP_MACHINE_BASE        0
903 #define APMT2_AUTH_CHALLENGE_TIMEOUT    0
904 #define APMT2_PEER_AUTH_ODD             1
905 #define APMT2_PEER_DEAUTH               2
906 #define AP_MAX_AUTH_RSP_MSG             3
907
908 #define AP_AUTH_RSP_FUNC_SIZE           (AP_MAX_AUTH_RSP_STATE * AP_MAX_AUTH_RSP_MSG)
909
910 //
911 // AP's SYNC state machine: states, events, total function #
912 //
913 #define AP_SYNC_IDLE                    0
914 #define AP_SCAN_LISTEN                                  1
915 #define AP_MAX_SYNC_STATE               2
916
917 #define AP_SYNC_MACHINE_BASE            0
918 #define APMT2_PEER_PROBE_REQ            0
919 #define APMT2_PEER_BEACON               1
920 #define APMT2_MLME_SCAN_REQ                             2
921 #define APMT2_PEER_PROBE_RSP                    3
922 #define APMT2_SCAN_TIMEOUT                              4
923 #define APMT2_MLME_SCAN_CNCL                    5
924 #define AP_MAX_SYNC_MSG                 6
925
926 #define AP_SYNC_FUNC_SIZE               (AP_MAX_SYNC_STATE * AP_MAX_SYNC_MSG)
927
928 //
929 // AP's WPA state machine: states, events, total function #
930 //
931 #define AP_WPA_PTK                      0
932 #define AP_MAX_WPA_PTK_STATE            1
933
934 #define AP_WPA_MACHINE_BASE             0
935 #define APMT2_EAPPacket                 0
936 #define APMT2_EAPOLStart                1
937 #define APMT2_EAPOLLogoff               2
938 #define APMT2_EAPOLKey                  3
939 #define APMT2_EAPOLASFAlert             4
940 #define AP_MAX_WPA_MSG                  5
941
942 #define AP_WPA_FUNC_SIZE                (AP_MAX_WPA_PTK_STATE * AP_MAX_WPA_MSG)
943
944 // =============================================================================
945
946 // value domain of 802.11 header FC.Tyte, which is b3..b2 of the 1st-byte of MAC header
947 #define BTYPE_MGMT                  0
948 #define BTYPE_CNTL                  1
949 #define BTYPE_DATA                  2
950
951 // value domain of 802.11 MGMT frame's FC.subtype, which is b7..4 of the 1st-byte of MAC header
952 #define SUBTYPE_ASSOC_REQ           0
953 #define SUBTYPE_ASSOC_RSP           1
954 #define SUBTYPE_REASSOC_REQ         2
955 #define SUBTYPE_REASSOC_RSP         3
956 #define SUBTYPE_PROBE_REQ           4
957 #define SUBTYPE_PROBE_RSP           5
958 #define SUBTYPE_BEACON              8
959 #define SUBTYPE_ATIM                9
960 #define SUBTYPE_DISASSOC            10
961 #define SUBTYPE_AUTH                11
962 #define SUBTYPE_DEAUTH              12
963 #define SUBTYPE_ACTION              13
964 #define SUBTYPE_ACTION_NO_ACK              14
965
966 // value domain of 802.11 CNTL frame's FC.subtype, which is b7..4 of the 1st-byte of MAC header
967 #define SUBTYPE_WRAPPER         7
968 #define SUBTYPE_BLOCK_ACK_REQ       8
969 #define SUBTYPE_BLOCK_ACK           9
970 #define SUBTYPE_PS_POLL             10
971 #define SUBTYPE_RTS                 11
972 #define SUBTYPE_CTS                 12
973 #define SUBTYPE_ACK                 13
974 #define SUBTYPE_CFEND               14
975 #define SUBTYPE_CFEND_CFACK         15
976
977 // value domain of 802.11 DATA frame's FC.subtype, which is b7..4 of the 1st-byte of MAC header
978 #define SUBTYPE_DATA                0
979 #define SUBTYPE_DATA_CFACK          1
980 #define SUBTYPE_DATA_CFPOLL         2
981 #define SUBTYPE_DATA_CFACK_CFPOLL   3
982 #define SUBTYPE_NULL_FUNC           4
983 #define SUBTYPE_CFACK               5
984 #define SUBTYPE_CFPOLL              6
985 #define SUBTYPE_CFACK_CFPOLL        7
986 #define SUBTYPE_QDATA               8
987 #define SUBTYPE_QDATA_CFACK         9
988 #define SUBTYPE_QDATA_CFPOLL        10
989 #define SUBTYPE_QDATA_CFACK_CFPOLL  11
990 #define SUBTYPE_QOS_NULL            12
991 #define SUBTYPE_QOS_CFACK           13
992 #define SUBTYPE_QOS_CFPOLL          14
993 #define SUBTYPE_QOS_CFACK_CFPOLL    15
994
995 // ACK policy of QOS Control field bit 6:5
996 #define NORMAL_ACK                  0x00  // b6:5 = 00
997 #define NO_ACK                      0x20  // b6:5 = 01
998 #define NO_EXPLICIT_ACK             0x40  // b6:5 = 10
999 #define BLOCK_ACK                   0x60  // b6:5 = 11
1000
1001 //
1002 // rtmp_data.c use these definition
1003 //
1004 #define LENGTH_802_11               24
1005 #define LENGTH_802_11_AND_H         30
1006 #define LENGTH_802_11_CRC_H         34
1007 #define LENGTH_802_11_CRC           28
1008 #define LENGTH_802_11_WITH_ADDR4    30
1009 #define LENGTH_802_3                14
1010 #define LENGTH_802_3_TYPE           2
1011 #define LENGTH_802_1_H              8
1012 #define LENGTH_EAPOL_H              4
1013 #define LENGTH_WMMQOS_H                         2
1014 #define LENGTH_CRC                  4
1015 #define MAX_SEQ_NUMBER              0x0fff
1016 #define LENGTH_802_3_NO_TYPE            12
1017 #define LENGTH_802_1Q                           4 /* VLAN related */
1018
1019 // STA_CSR4.field.TxResult
1020 #define TX_RESULT_SUCCESS           0
1021 #define TX_RESULT_ZERO_LENGTH       1
1022 #define TX_RESULT_UNDER_RUN         2
1023 #define TX_RESULT_OHY_ERROR         4
1024 #define TX_RESULT_RETRY_FAIL        6
1025
1026 // All PHY rate summary in TXD
1027 // Preamble MODE in TxD
1028 #define MODE_CCK        0
1029 #define MODE_OFDM   1
1030 #ifdef DOT11_N_SUPPORT
1031 #define MODE_HTMIX      2
1032 #define MODE_HTGREENFIELD       3
1033 #endif // DOT11_N_SUPPORT //
1034 // MCS for CCK.  BW.SGI.STBC are reserved
1035 #define MCS_LONGP_RATE_1                      0  // long preamble CCK 1Mbps
1036 #define MCS_LONGP_RATE_2                      1 // long preamble CCK 1Mbps
1037 #define MCS_LONGP_RATE_5_5                    2
1038 #define MCS_LONGP_RATE_11                     3
1039 #define MCS_SHORTP_RATE_1                      4         // long preamble CCK 1Mbps. short is forbidden in 1Mbps
1040 #define MCS_SHORTP_RATE_2                      5        // short preamble CCK 2Mbps
1041 #define MCS_SHORTP_RATE_5_5                    6
1042 #define MCS_SHORTP_RATE_11                     7
1043 // To send duplicate legacy OFDM. set BW=BW_40.  SGI.STBC are reserved
1044 #define MCS_RATE_6                      0   // legacy OFDM
1045 #define MCS_RATE_9                      1   // OFDM
1046 #define MCS_RATE_12                     2   // OFDM
1047 #define MCS_RATE_18                     3   // OFDM
1048 #define MCS_RATE_24                     4  // OFDM
1049 #define MCS_RATE_36                     5   // OFDM
1050 #define MCS_RATE_48                     6  // OFDM
1051 #define MCS_RATE_54                     7 // OFDM
1052 // HT
1053 #define MCS_0           0       // 1S
1054 #define MCS_1           1
1055 #define MCS_2           2
1056 #define MCS_3           3
1057 #define MCS_4           4
1058 #define MCS_5           5
1059 #define MCS_6           6
1060 #define MCS_7           7
1061 #define MCS_8           8       // 2S
1062 #define MCS_9           9
1063 #define MCS_10          10
1064 #define MCS_11          11
1065 #define MCS_12          12
1066 #define MCS_13          13
1067 #define MCS_14          14
1068 #define MCS_15          15
1069 #define MCS_16          16      // 3*3
1070 #define MCS_17          17
1071 #define MCS_18          18
1072 #define MCS_19          19
1073 #define MCS_20          20
1074 #define MCS_21          21
1075 #define MCS_22          22
1076 #define MCS_23          23
1077 #define MCS_32          32
1078 #define MCS_AUTO                33
1079
1080 #ifdef DOT11_N_SUPPORT
1081 // OID_HTPHYMODE
1082 // MODE
1083 #define HTMODE_MM       0
1084 #define HTMODE_GF       1
1085 #endif // DOT11_N_SUPPORT //
1086
1087 // Fixed Tx MODE - HT, CCK or OFDM
1088 #define FIXED_TXMODE_HT         0
1089 #define FIXED_TXMODE_CCK        1
1090 #define FIXED_TXMODE_OFDM       2
1091 // BW
1092 #define BW_20           BAND_WIDTH_20
1093 #define BW_40           BAND_WIDTH_40
1094 #define BW_BOTH         BAND_WIDTH_BOTH
1095 #define BW_10           BAND_WIDTH_10   // 802.11j has 10MHz. This definition is for internal usage. doesn't fill in the IE or other field.
1096
1097 #ifdef DOT11_N_SUPPORT
1098 // SHORTGI
1099 #define GI_400          GAP_INTERVAL_400        // only support in HT mode
1100 #define GI_BOTH         GAP_INTERVAL_BOTH
1101 #endif // DOT11_N_SUPPORT //
1102 #define GI_800          GAP_INTERVAL_800
1103 // STBC
1104 #define STBC_NONE       0
1105 #ifdef DOT11_N_SUPPORT
1106 #define STBC_USE        1       // limited use in rt2860b phy
1107 #define RXSTBC_ONE      1       // rx support of one spatial stream
1108 #define RXSTBC_TWO      2       // rx support of 1 and 2 spatial stream
1109 #define RXSTBC_THR      3       // rx support of 1~3 spatial stream
1110 // MCS FEEDBACK
1111 #define MCSFBK_NONE     0  // not support mcs feedback /
1112 #define MCSFBK_RSV      1       // reserved
1113 #define MCSFBK_UNSOLICIT        2       // only support unsolict mcs feedback
1114 #define MCSFBK_MRQ      3       // response to both MRQ and unsolict mcs feedback
1115
1116 // MIMO power safe
1117 #define MMPS_STATIC     0
1118 #define MMPS_DYNAMIC            1
1119 #define   MMPS_RSV              2
1120 #define MMPS_ENABLE             3
1121
1122
1123 // A-MSDU size
1124 #define AMSDU_0 0
1125 #define AMSDU_1         1
1126
1127 #endif // DOT11_N_SUPPORT //
1128
1129 // MCS use 7 bits
1130 #define TXRATEMIMO              0x80
1131 #define TXRATEMCS               0x7F
1132 #define TXRATEOFDM              0x7F
1133 #define RATE_1                      0
1134 #define RATE_2                      1
1135 #define RATE_5_5                    2
1136 #define RATE_11                     3
1137 #define RATE_6                      4   // OFDM
1138 #define RATE_9                      5   // OFDM
1139 #define RATE_12                     6   // OFDM
1140 #define RATE_18                     7   // OFDM
1141 #define RATE_24                     8   // OFDM
1142 #define RATE_36                     9   // OFDM
1143 #define RATE_48                     10  // OFDM
1144 #define RATE_54                     11  // OFDM
1145 #define RATE_FIRST_OFDM_RATE        RATE_6
1146 #define RATE_LAST_OFDM_RATE             RATE_54
1147 #define RATE_6_5                    12  // HT mix
1148 #define RATE_13                     13  // HT mix
1149 #define RATE_19_5                   14  // HT mix
1150 #define RATE_26                     15  // HT mix
1151 #define RATE_39                     16  // HT mix
1152 #define RATE_52                     17  // HT mix
1153 #define RATE_58_5                   18  // HT mix
1154 #define RATE_65                     19  // HT mix
1155 #define RATE_78                     20  // HT mix
1156 #define RATE_104                    21  // HT mix
1157 #define RATE_117                    22  // HT mix
1158 #define RATE_130                    23  // HT mix
1159 //#define RATE_AUTO_SWITCH            255 // for StaCfg.FixedTxRate only
1160 #define HTRATE_0                      12
1161 #define RATE_FIRST_MM_RATE        HTRATE_0
1162 #define RATE_FIRST_HT_RATE        HTRATE_0
1163 #define RATE_LAST_HT_RATE        HTRATE_0
1164
1165 // pTxWI->txop
1166 #define IFS_HTTXOP                 0    // The txop will be handles by ASIC.
1167 #define IFS_PIFS                    1
1168 #define IFS_SIFS                    2
1169 #define IFS_BACKOFF                 3
1170
1171 // pTxD->RetryMode
1172 #define LONG_RETRY                  1
1173 #define SHORT_RETRY                 0
1174
1175 // Country Region definition
1176 #define REGION_MINIMUM_BG_BAND            0
1177 #define REGION_0_BG_BAND                  0       // 1-11
1178 #define REGION_1_BG_BAND                  1       // 1-13
1179 #define REGION_2_BG_BAND                  2       // 10-11
1180 #define REGION_3_BG_BAND                  3       // 10-13
1181 #define REGION_4_BG_BAND                  4       // 14
1182 #define REGION_5_BG_BAND                  5       // 1-14
1183 #define REGION_6_BG_BAND                  6       // 3-9
1184 #define REGION_7_BG_BAND                  7       // 5-13
1185 #define REGION_31_BG_BAND                 31       // 5-13
1186 #define REGION_MAXIMUM_BG_BAND            7
1187
1188 #define REGION_MINIMUM_A_BAND             0
1189 #define REGION_0_A_BAND                   0       // 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165
1190 #define REGION_1_A_BAND                   1       // 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140
1191 #define REGION_2_A_BAND                   2       // 36, 40, 44, 48, 52, 56, 60, 64
1192 #define REGION_3_A_BAND                   3       // 52, 56, 60, 64, 149, 153, 157, 161
1193 #define REGION_4_A_BAND                   4       // 149, 153, 157, 161, 165
1194 #define REGION_5_A_BAND                   5       // 149, 153, 157, 161
1195 #define REGION_6_A_BAND                   6       // 36, 40, 44, 48
1196 #define REGION_7_A_BAND                   7       // 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165
1197 #define REGION_8_A_BAND                   8       // 52, 56, 60, 64
1198 #define REGION_9_A_BAND                   9       // 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165
1199 #define REGION_10_A_BAND                  10      // 36, 40, 44, 48, 149, 153, 157, 161, 165
1200 #define REGION_11_A_BAND                  11      // 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 149, 153, 157, 161
1201 #define REGION_MAXIMUM_A_BAND             11
1202
1203 // pTxD->CipherAlg
1204 #define CIPHER_NONE                 0
1205 #define CIPHER_WEP64                1
1206 #define CIPHER_WEP128               2
1207 #define CIPHER_TKIP                 3
1208 #define CIPHER_AES                  4
1209 #define CIPHER_CKIP64               5
1210 #define CIPHER_CKIP128              6
1211 #define CIPHER_TKIP_NO_MIC          7       // MIC appended by driver: not a valid value in hardware key table
1212 #define CIPHER_SMS4                                     8
1213
1214 // value domain of pAd->RfIcType
1215 #define RFIC_2820                   1       // 2.4G 2T3R
1216 #define RFIC_2850                   2       // 2.4G/5G 2T3R
1217 #define RFIC_2720                   3       // 2.4G 1T2R
1218 #define RFIC_2750                   4       // 2.4G/5G 1T2R
1219 #define RFIC_3020                   5       // 2.4G 1T1R
1220 #define RFIC_2020                   6       // 2.4G B/G
1221
1222 // LED Status.
1223 #define LED_LINK_DOWN               0
1224 #define LED_LINK_UP                 1
1225 #define LED_RADIO_OFF               2
1226 #define LED_RADIO_ON                3
1227 #define LED_HALT                    4
1228 #define LED_WPS                     5
1229 #define LED_ON_SITE_SURVEY          6
1230 #define LED_POWER_UP                7
1231
1232 // value domain of pAd->LedCntl.LedMode and E2PROM
1233 #define LED_MODE_DEFAULT            0
1234 #define LED_MODE_TWO_LED                        1
1235 #define LED_MODE_SIGNAL_STREGTH         8  // EEPROM define =8
1236
1237 // RC4 init value, used fro WEP & TKIP
1238 #define PPPINITFCS32                0xffffffff   /* Initial FCS value */
1239
1240 // value domain of pAd->StaCfg.PortSecured. 802.1X controlled port definition
1241 #define WPA_802_1X_PORT_SECURED     1
1242 #define WPA_802_1X_PORT_NOT_SECURED 2
1243
1244 #define PAIRWISE_KEY                1
1245 #define GROUP_KEY                   2
1246
1247 //definition of DRS
1248 #define MAX_STEP_OF_TX_RATE_SWITCH      32
1249
1250
1251 // pre-allocated free NDIS PACKET/BUFFER poll for internal usage
1252 #define MAX_NUM_OF_FREE_NDIS_PACKET 128
1253
1254 //Block ACK
1255 #define MAX_TX_REORDERBUF   64
1256 #define MAX_RX_REORDERBUF   64
1257 #define DEFAULT_TX_TIMEOUT   30
1258 #define DEFAULT_RX_TIMEOUT   30
1259
1260 // definition of Recipient or Originator
1261 #define I_RECIPIENT                  TRUE
1262 #define I_ORIGINATOR                   FALSE
1263
1264 #define DEFAULT_BBP_TX_POWER        0
1265 #define DEFAULT_RF_TX_POWER         5
1266
1267 #define MAX_INI_BUFFER_SIZE                     4096
1268 #define MAX_PARAM_BUFFER_SIZE           (2048) // enough for ACL (18*64)
1269                                                                                         //18 : the length of Mac address acceptable format "01:02:03:04:05:06;")
1270                                                                                         //64 : MAX_NUM_OF_ACL_LIST
1271 // definition of pAd->OpMode
1272 #define OPMODE_STA                  0
1273 #define OPMODE_AP                   1
1274 //#define OPMODE_L3_BRG               2       // as AP and STA at the same time
1275
1276 #ifdef RT_BIG_ENDIAN
1277 #define DIR_READ                    0
1278 #define DIR_WRITE                   1
1279 #define TYPE_TXD                    0
1280 #define TYPE_RXD                    1
1281 #define TYPE_TXINFO                                     0
1282 #define TYPE_RXINFO                                     1
1283 #define TYPE_TXWI                                       0
1284 #define TYPE_RXWI                                       1
1285 #endif
1286
1287 // ========================= AP rtmp_def.h ===========================
1288 // value domain for pAd->EventTab.Log[].Event
1289 #define EVENT_RESET_ACCESS_POINT    0 // Log = "hh:mm:ss   Restart Access Point"
1290 #define EVENT_ASSOCIATED            1 // Log = "hh:mm:ss   STA 00:01:02:03:04:05 associated"
1291 #define EVENT_DISASSOCIATED         2 // Log = "hh:mm:ss   STA 00:01:02:03:04:05 left this BSS"
1292 #define EVENT_AGED_OUT              3 // Log = "hh:mm:ss   STA 00:01:02:03:04:05 was aged-out and removed from this BSS"
1293 #define EVENT_COUNTER_M             4
1294 #define EVENT_INVALID_PSK           5
1295 #define EVENT_MAX_EVENT_TYPE        6
1296 // ==== end of AP rtmp_def.h ============
1297
1298 // definition RSSI Number
1299 #define RSSI_0                                  0
1300 #define RSSI_1                                  1
1301 #define RSSI_2                                  2
1302
1303 // definition of radar detection
1304 #define RD_NORMAL_MODE                          0       // Not found radar signal
1305 #define RD_SWITCHING_MODE                       1       // Found radar signal, and doing channel switch
1306 #define RD_SILENCE_MODE                         2       // After channel switch, need to be silence a while to ensure radar not found
1307
1308 //Driver defined cid for mapping status and command.
1309 #define  SLEEPCID       0x11
1310 #define  WAKECID        0x22
1311 #define  QUERYPOWERCID  0x33
1312 #define  OWNERMCU       0x1
1313 #define  OWNERCPU       0x0
1314
1315 // MBSSID definition
1316 #define ENTRY_NOT_FOUND             0xFF
1317
1318
1319 /* After Linux 2.6.9,
1320  * VLAN module use Private (from user) interface flags (netdevice->priv_flags).
1321  * #define IFF_802_1Q_VLAN 0x1         --    802.1Q VLAN device.  in if.h
1322  * ref to ip_sabotage_out() [ out->priv_flags & IFF_802_1Q_VLAN ] in br_netfilter.c
1323  *
1324  * For this reason, we MUST use EVEN value in priv_flags
1325  */
1326 #define INT_MAIN                    0x0100
1327 #define INT_MBSSID                  0x0200
1328 #define INT_WDS                     0x0300
1329 #define INT_APCLI                   0x0400
1330 #define INT_MESH                        0x0500
1331
1332 // Use bitmap to allow coexist of ATE_TXFRAME and ATE_RXFRAME(i.e.,to support LoopBack mode)
1333
1334 // WEP Key TYPE
1335 #define WEP_HEXADECIMAL_TYPE    0
1336 #define WEP_ASCII_TYPE          1
1337
1338
1339
1340 // WIRELESS EVENTS definition
1341 /* Max number of char in custom event, refer to wireless_tools.28/wireless.20.h */
1342 #define IW_CUSTOM_MAX_LEN                                                       255     /* In bytes */
1343
1344 // For system event - start
1345 #define IW_SYS_EVENT_FLAG_START                     0x0200
1346 #define IW_ASSOC_EVENT_FLAG                         0x0200
1347 #define IW_DISASSOC_EVENT_FLAG                      0x0201
1348 #define IW_DEAUTH_EVENT_FLAG                            0x0202
1349 #define IW_AGEOUT_EVENT_FLAG                            0x0203
1350 #define IW_COUNTER_MEASURES_EVENT_FLAG              0x0204
1351 #define IW_REPLAY_COUNTER_DIFF_EVENT_FLAG           0x0205
1352 #define IW_RSNIE_DIFF_EVENT_FLAG                                0x0206
1353 #define IW_MIC_DIFF_EVENT_FLAG                                  0x0207
1354 #define IW_ICV_ERROR_EVENT_FLAG                                         0x0208
1355 #define IW_MIC_ERROR_EVENT_FLAG                                         0x0209
1356 #define IW_GROUP_HS_TIMEOUT_EVENT_FLAG                          0x020A
1357 #define IW_PAIRWISE_HS_TIMEOUT_EVENT_FLAG                       0x020B
1358 #define IW_RSNIE_SANITY_FAIL_EVENT_FLAG                         0x020C
1359 #define IW_SET_KEY_DONE_WPA1_EVENT_FLAG                         0x020D
1360 #define IW_SET_KEY_DONE_WPA2_EVENT_FLAG                         0x020E
1361 #define IW_STA_LINKUP_EVENT_FLAG                                        0x020F
1362 #define IW_STA_LINKDOWN_EVENT_FLAG                                      0x0210
1363 #define IW_SCAN_COMPLETED_EVENT_FLAG                            0x0211
1364 #define IW_SCAN_ENQUEUE_FAIL_EVENT_FLAG                         0x0212
1365 // if add new system event flag, please upadte the IW_SYS_EVENT_FLAG_END
1366 #define IW_SYS_EVENT_FLAG_END                       0x0212
1367 #define IW_SYS_EVENT_TYPE_NUM                                           (IW_SYS_EVENT_FLAG_END - IW_SYS_EVENT_FLAG_START + 1)
1368 // For system event - end
1369
1370 // For spoof attack event - start
1371 #define IW_SPOOF_EVENT_FLAG_START                   0x0300
1372 #define IW_CONFLICT_SSID_EVENT_FLAG                                     0x0300
1373 #define IW_SPOOF_ASSOC_RESP_EVENT_FLAG                          0x0301
1374 #define IW_SPOOF_REASSOC_RESP_EVENT_FLAG                        0x0302
1375 #define IW_SPOOF_PROBE_RESP_EVENT_FLAG                          0x0303
1376 #define IW_SPOOF_BEACON_EVENT_FLAG                                      0x0304
1377 #define IW_SPOOF_DISASSOC_EVENT_FLAG                            0x0305
1378 #define IW_SPOOF_AUTH_EVENT_FLAG                                        0x0306
1379 #define IW_SPOOF_DEAUTH_EVENT_FLAG                                      0x0307
1380 #define IW_SPOOF_UNKNOWN_MGMT_EVENT_FLAG                        0x0308
1381 #define IW_REPLAY_ATTACK_EVENT_FLAG                                     0x0309
1382 // if add new spoof attack event flag, please upadte the IW_SPOOF_EVENT_FLAG_END
1383 #define IW_SPOOF_EVENT_FLAG_END                     0x0309
1384 #define IW_SPOOF_EVENT_TYPE_NUM                                         (IW_SPOOF_EVENT_FLAG_END - IW_SPOOF_EVENT_FLAG_START + 1)
1385 // For spoof attack event - end
1386
1387 // For flooding attack event - start
1388 #define IW_FLOOD_EVENT_FLAG_START                   0x0400
1389 #define IW_FLOOD_AUTH_EVENT_FLAG                                        0x0400
1390 #define IW_FLOOD_ASSOC_REQ_EVENT_FLAG                           0x0401
1391 #define IW_FLOOD_REASSOC_REQ_EVENT_FLAG                         0x0402
1392 #define IW_FLOOD_PROBE_REQ_EVENT_FLAG                           0x0403
1393 #define IW_FLOOD_DISASSOC_EVENT_FLAG                            0x0404
1394 #define IW_FLOOD_DEAUTH_EVENT_FLAG                                      0x0405
1395 #define IW_FLOOD_EAP_REQ_EVENT_FLAG                                     0x0406
1396 // if add new flooding attack event flag, please upadte the IW_FLOOD_EVENT_FLAG_END
1397 #define IW_FLOOD_EVENT_FLAG_END                         0x0406
1398 #define IW_FLOOD_EVENT_TYPE_NUM                                         (IW_FLOOD_EVENT_FLAG_END - IW_FLOOD_EVENT_FLAG_START + 1)
1399 // For flooding attack - end
1400
1401 // End - WIRELESS EVENTS definition
1402
1403 #ifdef CONFIG_STA_SUPPORT
1404 // definition for DLS, kathy
1405 #define MAX_NUM_OF_INIT_DLS_ENTRY   1
1406 #define MAX_NUM_OF_DLS_ENTRY        MAX_NUMBER_OF_DLS_ENTRY
1407
1408 //Block ACK , rt2860, kathy
1409 #define MAX_TX_REORDERBUF               64
1410 #define MAX_RX_REORDERBUF               64
1411 #define DEFAULT_TX_TIMEOUT              30
1412 #define DEFAULT_RX_TIMEOUT              30
1413 #ifndef CONFIG_AP_SUPPORT
1414 #define MAX_BARECI_SESSION              8
1415 #endif
1416
1417 #ifndef IW_ESSID_MAX_SIZE
1418 /* Maximum size of the ESSID and pAd->nickname strings */
1419 #define IW_ESSID_MAX_SIZE               32
1420 #endif
1421 #endif // CONFIG_STA_SUPPORT //
1422
1423 #ifdef MCAST_RATE_SPECIFIC
1424 #define MCAST_DISABLE   0
1425 #define MCAST_CCK               1
1426 #define MCAST_OFDM              2
1427 #define MCAST_HTMIX             3
1428 #endif // MCAST_RATE_SPECIFIC //
1429
1430 // For AsicRadioOff/AsicRadioOn function
1431 #define DOT11POWERSAVE          0
1432 #define GUIRADIO_OFF            1
1433 #define RTMP_HALT                   2
1434 #define GUI_IDLE_POWER_SAVE             3
1435 // --
1436
1437
1438 // definition for WpaSupport flag
1439 #define WPA_SUPPLICANT_DISABLE                          0
1440 #define WPA_SUPPLICANT_ENABLE                           1
1441 #define WPA_SUPPLICANT_ENABLE_WITH_WEB_UI       2
1442
1443 // Endian byte swapping codes
1444 #define SWAP16(x) \
1445     ((UINT16)( \
1446     (((UINT16)(x) & (UINT16) 0x00ffU) << 8) | \
1447     (((UINT16)(x) & (UINT16) 0xff00U) >> 8) ))
1448
1449 #define SWAP32(x) \
1450     ((UINT32)( \
1451     (((UINT32)(x) & (UINT32) 0x000000ffUL) << 24) | \
1452     (((UINT32)(x) & (UINT32) 0x0000ff00UL) <<  8) | \
1453     (((UINT32)(x) & (UINT32) 0x00ff0000UL) >>  8) | \
1454     (((UINT32)(x) & (UINT32) 0xff000000UL) >> 24) ))
1455
1456 #define SWAP64(x) \
1457     ((UINT64)( \
1458     (UINT64)(((UINT64)(x) & (UINT64) 0x00000000000000ffULL) << 56) | \
1459     (UINT64)(((UINT64)(x) & (UINT64) 0x000000000000ff00ULL) << 40) | \
1460     (UINT64)(((UINT64)(x) & (UINT64) 0x0000000000ff0000ULL) << 24) | \
1461     (UINT64)(((UINT64)(x) & (UINT64) 0x00000000ff000000ULL) <<  8) | \
1462     (UINT64)(((UINT64)(x) & (UINT64) 0x000000ff00000000ULL) >>  8) | \
1463     (UINT64)(((UINT64)(x) & (UINT64) 0x0000ff0000000000ULL) >> 24) | \
1464     (UINT64)(((UINT64)(x) & (UINT64) 0x00ff000000000000ULL) >> 40) | \
1465     (UINT64)(((UINT64)(x) & (UINT64) 0xff00000000000000ULL) >> 56) ))
1466
1467 #ifdef RT_BIG_ENDIAN
1468
1469 #define cpu2le64(x) SWAP64((x))
1470 #define le2cpu64(x) SWAP64((x))
1471 #define cpu2le32(x) SWAP32((x))
1472 #define le2cpu32(x) SWAP32((x))
1473 #define cpu2le16(x) SWAP16((x))
1474 #define le2cpu16(x) SWAP16((x))
1475 #define cpu2be64(x) ((UINT64)(x))
1476 #define be2cpu64(x) ((UINT64)(x))
1477 #define cpu2be32(x) ((UINT32)(x))
1478 #define be2cpu32(x) ((UINT32)(x))
1479 #define cpu2be16(x) ((UINT16)(x))
1480 #define be2cpu16(x) ((UINT16)(x))
1481
1482 #else   // Little_Endian
1483
1484 #define cpu2le64(x) ((UINT64)(x))
1485 #define le2cpu64(x) ((UINT64)(x))
1486 #define cpu2le32(x) ((UINT32)(x))
1487 #define le2cpu32(x) ((UINT32)(x))
1488 #define cpu2le16(x) ((UINT16)(x))
1489 #define le2cpu16(x) ((UINT16)(x))
1490 #define cpu2be64(x) SWAP64((x))
1491 #define be2cpu64(x) SWAP64((x))
1492 #define cpu2be32(x) SWAP32((x))
1493 #define be2cpu32(x) SWAP32((x))
1494 #define cpu2be16(x) SWAP16((x))
1495 #define be2cpu16(x) SWAP16((x))
1496
1497 #endif  // RT_BIG_ENDIAN
1498
1499 #endif  // __RTMP_DEF_H__
1500
1501