2 *************************************************************************
4 * 5F., No.36, Taiyuan St., Jhubei City,
8 * (c) Copyright 2002-2007, Ralink Technology, Inc.
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. *
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. *
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. *
25 *************************************************************************
34 -------- ---------- ----------------------------------------------
35 Name Date Modification logs
44 // IEEE 802.11 Structures and definitions
46 #define MAX_TX_POWER_LEVEL 100 /* mW */
47 #define MAX_RSSI_TRIGGER -10 /* dBm */
48 #define MIN_RSSI_TRIGGER -200 /* dBm */
49 #define MAX_FRAG_THRESHOLD 2346 /* byte count */
50 #define MIN_FRAG_THRESHOLD 256 /* byte count */
51 #define MAX_RTS_THRESHOLD 2347 /* byte count */
53 // new types for Media Specific Indications
54 // Extension channel offset
56 #define EXTCHA_ABOVE 0x1
57 #define EXTCHA_BELOW 0x3
60 #define BAND_WIDTH_20 0
61 #define BAND_WIDTH_40 1
62 #define BAND_WIDTH_BOTH 2
63 #define BAND_WIDTH_10 3 // 802.11j has 10MHz. This definition is for internal usage. doesn't fill in the IE or other field.
65 #define GAP_INTERVAL_400 1 // only support in HT mode
66 #define GAP_INTERVAL_800 0
67 #define GAP_INTERVAL_BOTH 2
69 #define NdisMediaStateConnected 1
70 #define NdisMediaStateDisconnected 0
72 #define NDIS_802_11_LENGTH_SSID 32
73 #define NDIS_802_11_LENGTH_RATES 8
74 #define NDIS_802_11_LENGTH_RATES_EX 16
75 #define MAC_ADDR_LENGTH 6
76 #define MAX_NUM_OF_CHS 49 // 14 channels @2.4G + 12@UNII + 4 @MMAC + 11 @HiperLAN2 + 7 @Japan + 1 as NULL terminationc
77 #define MAX_NUMBER_OF_EVENT 10 // entry # in EVENT table
78 #define MAX_NUMBER_OF_MAC 32 // if MAX_MBSSID_NUM is 8, this value can't be larger than 211
79 #define MAX_NUMBER_OF_ACL 64
80 #define MAX_LENGTH_OF_SUPPORT_RATES 12 // 1, 2, 5.5, 11, 6, 9, 12, 18, 24, 36, 48, 54
81 #define MAX_NUMBER_OF_DLS_ENTRY 4
85 #define OID_GEN_MACHINE_NAME 0x0001021A
88 #define RT_QUERY_ATE_TXDONE_COUNT 0x0401
89 #endif // RALINK_ATE //
90 #define RT_QUERY_SIGNAL_CONTEXT 0x0402
91 #define RT_SET_IAPP_PID 0x0404
92 #define RT_SET_APD_PID 0x0405
93 #define RT_SET_DEL_MAC_ENTRY 0x0406
98 #define OID_GET_SET_TOGGLE 0x8000
100 #define OID_802_11_NETWORK_TYPES_SUPPORTED 0x0103
101 #define OID_802_11_NETWORK_TYPE_IN_USE 0x0104
102 #define OID_802_11_RSSI_TRIGGER 0x0107
103 #define RT_OID_802_11_RSSI 0x0108 //rt2860 only , kathy
104 #define RT_OID_802_11_RSSI_1 0x0109 //rt2860 only , kathy
105 #define RT_OID_802_11_RSSI_2 0x010A //rt2860 only , kathy
106 #define OID_802_11_NUMBER_OF_ANTENNAS 0x010B
107 #define OID_802_11_RX_ANTENNA_SELECTED 0x010C
108 #define OID_802_11_TX_ANTENNA_SELECTED 0x010D
109 #define OID_802_11_SUPPORTED_RATES 0x010E
110 #define OID_802_11_ADD_WEP 0x0112
111 #define OID_802_11_REMOVE_WEP 0x0113
112 #define OID_802_11_DISASSOCIATE 0x0114
113 #define OID_802_11_PRIVACY_FILTER 0x0118
114 #define OID_802_11_ASSOCIATION_INFORMATION 0x011E
115 #define OID_802_11_TEST 0x011F
116 #define RT_OID_802_11_COUNTRY_REGION 0x0507
117 #define OID_802_11_BSSID_LIST_SCAN 0x0508
118 #define OID_802_11_SSID 0x0509
119 #define OID_802_11_BSSID 0x050A
120 #define RT_OID_802_11_RADIO 0x050B
121 #define RT_OID_802_11_PHY_MODE 0x050C
122 #define RT_OID_802_11_STA_CONFIG 0x050D
123 #define OID_802_11_DESIRED_RATES 0x050E
124 #define RT_OID_802_11_PREAMBLE 0x050F
125 #define OID_802_11_WEP_STATUS 0x0510
126 #define OID_802_11_AUTHENTICATION_MODE 0x0511
127 #define OID_802_11_INFRASTRUCTURE_MODE 0x0512
128 #define RT_OID_802_11_RESET_COUNTERS 0x0513
129 #define OID_802_11_RTS_THRESHOLD 0x0514
130 #define OID_802_11_FRAGMENTATION_THRESHOLD 0x0515
131 #define OID_802_11_POWER_MODE 0x0516
132 #define OID_802_11_TX_POWER_LEVEL 0x0517
133 #define RT_OID_802_11_ADD_WPA 0x0518
134 #define OID_802_11_REMOVE_KEY 0x0519
135 #define OID_802_11_ADD_KEY 0x0520
136 #define OID_802_11_CONFIGURATION 0x0521
137 #define OID_802_11_TX_PACKET_BURST 0x0522
138 #define RT_OID_802_11_QUERY_NOISE_LEVEL 0x0523
139 #define RT_OID_802_11_EXTRA_INFO 0x0524
141 #define RT_OID_802_11_HARDWARE_REGISTER 0x0525
143 #define OID_802_11_ENCRYPTION_STATUS OID_802_11_WEP_STATUS
144 #define OID_802_11_DEAUTHENTICATION 0x0526
145 #define OID_802_11_DROP_UNENCRYPTED 0x0527
146 #define OID_802_11_MIC_FAILURE_REPORT_FRAME 0x0528
148 // For 802.1x daemin using to require current driver configuration
149 #define OID_802_11_RADIUS_QUERY_SETTING 0x0540
151 #define RT_OID_DEVICE_NAME 0x0607
152 #define RT_OID_VERSION_INFO 0x0608
153 #define OID_802_11_BSSID_LIST 0x0609
154 #define OID_802_3_CURRENT_ADDRESS 0x060A
155 #define OID_GEN_MEDIA_CONNECT_STATUS 0x060B
156 #define RT_OID_802_11_QUERY_LINK_STATUS 0x060C
157 #define OID_802_11_RSSI 0x060D
158 #define OID_802_11_STATISTICS 0x060E
159 #define OID_GEN_RCV_OK 0x060F
160 #define OID_GEN_RCV_NO_BUFFER 0x0610
161 #define RT_OID_802_11_QUERY_EEPROM_VERSION 0x0611
162 #define RT_OID_802_11_QUERY_FIRMWARE_VERSION 0x0612
163 #define RT_OID_802_11_QUERY_LAST_RX_RATE 0x0613
164 #define RT_OID_802_11_TX_POWER_LEVEL_1 0x0614
165 #define RT_OID_802_11_QUERY_PIDVID 0x0615
166 //for WPA_SUPPLICANT_SUPPORT
167 #define OID_SET_COUNTERMEASURES 0x0616
168 #define OID_802_11_SET_IEEE8021X 0x0617
169 #define OID_802_11_SET_IEEE8021X_REQUIRE_KEY 0x0618
170 #define OID_802_11_PMKID 0x0620
171 #define RT_OID_WPA_SUPPLICANT_SUPPORT 0x0621
172 #define RT_OID_WE_VERSION_COMPILED 0x0622
173 #define RT_OID_NEW_DRIVER 0x0623
177 #define RT_OID_802_11_SNR_0 0x0630
178 #define RT_OID_802_11_SNR_1 0x0631
179 #define RT_OID_802_11_QUERY_LAST_TX_RATE 0x0632
180 #define RT_OID_802_11_QUERY_HT_PHYMODE 0x0633
181 #define RT_OID_802_11_SET_HT_PHYMODE 0x0634
182 #define OID_802_11_RELOAD_DEFAULTS 0x0635
183 #define RT_OID_802_11_QUERY_APSD_SETTING 0x0636
184 #define RT_OID_802_11_SET_APSD_SETTING 0x0637
185 #define RT_OID_802_11_QUERY_APSD_PSM 0x0638
186 #define RT_OID_802_11_SET_APSD_PSM 0x0639
187 #define RT_OID_802_11_QUERY_DLS 0x063A
188 #define RT_OID_802_11_SET_DLS 0x063B
189 #define RT_OID_802_11_QUERY_DLS_PARAM 0x063C
190 #define RT_OID_802_11_SET_DLS_PARAM 0x063D
191 #define RT_OID_802_11_QUERY_WMM 0x063E
192 #define RT_OID_802_11_SET_WMM 0x063F
193 #define RT_OID_802_11_QUERY_IMME_BA_CAP 0x0640
194 #define RT_OID_802_11_SET_IMME_BA_CAP 0x0641
195 #define RT_OID_802_11_QUERY_BATABLE 0x0642
196 #define RT_OID_802_11_ADD_IMME_BA 0x0643
197 #define RT_OID_802_11_TEAR_IMME_BA 0x0644
198 #define RT_OID_DRIVER_DEVICE_NAME 0x0645
199 #define RT_OID_802_11_QUERY_DAT_HT_PHYMODE 0x0646
200 #define RT_OID_QUERY_MULTIPLE_CARD_SUPPORT 0x0647
202 // Ralink defined OIDs
203 // Dennis Lee move to platform specific
205 #define RT_OID_802_11_BSSID (OID_GET_SET_TOGGLE | OID_802_11_BSSID)
206 #define RT_OID_802_11_SSID (OID_GET_SET_TOGGLE | OID_802_11_SSID)
207 #define RT_OID_802_11_INFRASTRUCTURE_MODE (OID_GET_SET_TOGGLE | OID_802_11_INFRASTRUCTURE_MODE)
208 #define RT_OID_802_11_ADD_WEP (OID_GET_SET_TOGGLE | OID_802_11_ADD_WEP)
209 #define RT_OID_802_11_ADD_KEY (OID_GET_SET_TOGGLE | OID_802_11_ADD_KEY)
210 #define RT_OID_802_11_REMOVE_WEP (OID_GET_SET_TOGGLE | OID_802_11_REMOVE_WEP)
211 #define RT_OID_802_11_REMOVE_KEY (OID_GET_SET_TOGGLE | OID_802_11_REMOVE_KEY)
212 #define RT_OID_802_11_DISASSOCIATE (OID_GET_SET_TOGGLE | OID_802_11_DISASSOCIATE)
213 #define RT_OID_802_11_AUTHENTICATION_MODE (OID_GET_SET_TOGGLE | OID_802_11_AUTHENTICATION_MODE)
214 #define RT_OID_802_11_PRIVACY_FILTER (OID_GET_SET_TOGGLE | OID_802_11_PRIVACY_FILTER)
215 #define RT_OID_802_11_BSSID_LIST_SCAN (OID_GET_SET_TOGGLE | OID_802_11_BSSID_LIST_SCAN)
216 #define RT_OID_802_11_WEP_STATUS (OID_GET_SET_TOGGLE | OID_802_11_WEP_STATUS)
217 #define RT_OID_802_11_RELOAD_DEFAULTS (OID_GET_SET_TOGGLE | OID_802_11_RELOAD_DEFAULTS)
218 #define RT_OID_802_11_NETWORK_TYPE_IN_USE (OID_GET_SET_TOGGLE | OID_802_11_NETWORK_TYPE_IN_USE)
219 #define RT_OID_802_11_TX_POWER_LEVEL (OID_GET_SET_TOGGLE | OID_802_11_TX_POWER_LEVEL)
220 #define RT_OID_802_11_RSSI_TRIGGER (OID_GET_SET_TOGGLE | OID_802_11_RSSI_TRIGGER)
221 #define RT_OID_802_11_FRAGMENTATION_THRESHOLD (OID_GET_SET_TOGGLE | OID_802_11_FRAGMENTATION_THRESHOLD)
222 #define RT_OID_802_11_RTS_THRESHOLD (OID_GET_SET_TOGGLE | OID_802_11_RTS_THRESHOLD)
223 #define RT_OID_802_11_RX_ANTENNA_SELECTED (OID_GET_SET_TOGGLE | OID_802_11_RX_ANTENNA_SELECTED)
224 #define RT_OID_802_11_TX_ANTENNA_SELECTED (OID_GET_SET_TOGGLE | OID_802_11_TX_ANTENNA_SELECTED)
225 #define RT_OID_802_11_SUPPORTED_RATES (OID_GET_SET_TOGGLE | OID_802_11_SUPPORTED_RATES)
226 #define RT_OID_802_11_DESIRED_RATES (OID_GET_SET_TOGGLE | OID_802_11_DESIRED_RATES)
227 #define RT_OID_802_11_CONFIGURATION (OID_GET_SET_TOGGLE | OID_802_11_CONFIGURATION)
228 #define RT_OID_802_11_POWER_MODE (OID_GET_SET_TOGGLE | OID_802_11_POWER_MODE)
230 typedef enum _NDIS_802_11_STATUS_TYPE
232 Ndis802_11StatusType_Authentication,
233 Ndis802_11StatusType_MediaStreamMode,
234 Ndis802_11StatusType_PMKID_CandidateList,
235 Ndis802_11StatusTypeMax // not a real type, defined as an upper bound
236 } NDIS_802_11_STATUS_TYPE, *PNDIS_802_11_STATUS_TYPE;
238 typedef UCHAR NDIS_802_11_MAC_ADDRESS[6];
240 typedef struct _NDIS_802_11_STATUS_INDICATION
242 NDIS_802_11_STATUS_TYPE StatusType;
243 } NDIS_802_11_STATUS_INDICATION, *PNDIS_802_11_STATUS_INDICATION;
245 // mask for authentication/integrity fields
246 #define NDIS_802_11_AUTH_REQUEST_AUTH_FIELDS 0x0f
248 #define NDIS_802_11_AUTH_REQUEST_REAUTH 0x01
249 #define NDIS_802_11_AUTH_REQUEST_KEYUPDATE 0x02
250 #define NDIS_802_11_AUTH_REQUEST_PAIRWISE_ERROR 0x06
251 #define NDIS_802_11_AUTH_REQUEST_GROUP_ERROR 0x0E
253 typedef struct _NDIS_802_11_AUTHENTICATION_REQUEST
255 ULONG Length; // Length of structure
256 NDIS_802_11_MAC_ADDRESS Bssid;
258 } NDIS_802_11_AUTHENTICATION_REQUEST, *PNDIS_802_11_AUTHENTICATION_REQUEST;
260 //Added new types for PMKID Candidate lists.
261 typedef struct _PMKID_CANDIDATE {
262 NDIS_802_11_MAC_ADDRESS BSSID;
264 } PMKID_CANDIDATE, *PPMKID_CANDIDATE;
266 typedef struct _NDIS_802_11_PMKID_CANDIDATE_LIST
268 ULONG Version; // Version of the structure
269 ULONG NumCandidates; // No. of pmkid candidates
270 PMKID_CANDIDATE CandidateList[1];
271 } NDIS_802_11_PMKID_CANDIDATE_LIST, *PNDIS_802_11_PMKID_CANDIDATE_LIST;
273 //Flags for PMKID Candidate list structure
274 #define NDIS_802_11_PMKID_CANDIDATE_PREAUTH_ENABLED 0x01
276 // Added new types for OFDM 5G and 2.4G
277 typedef enum _NDIS_802_11_NETWORK_TYPE
286 Ndis802_11NetworkTypeMax // not a real type, defined as an upper bound
287 } NDIS_802_11_NETWORK_TYPE, *PNDIS_802_11_NETWORK_TYPE;
289 typedef struct _NDIS_802_11_NETWORK_TYPE_LIST
291 UINT NumberOfItems; // in list below, at least 1
292 NDIS_802_11_NETWORK_TYPE NetworkType [1];
293 } NDIS_802_11_NETWORK_TYPE_LIST, *PNDIS_802_11_NETWORK_TYPE_LIST;
295 typedef enum _NDIS_802_11_POWER_MODE
297 Ndis802_11PowerModeCAM,
298 Ndis802_11PowerModeMAX_PSP,
299 Ndis802_11PowerModeFast_PSP,
300 Ndis802_11PowerModeLegacy_PSP,
301 Ndis802_11PowerModeMax // not a real mode, defined as an upper bound
302 } NDIS_802_11_POWER_MODE, *PNDIS_802_11_POWER_MODE;
304 typedef ULONG NDIS_802_11_TX_POWER_LEVEL; // in milliwatts
307 // Received Signal Strength Indication
309 typedef LONG NDIS_802_11_RSSI; // in dBm
311 typedef struct _NDIS_802_11_CONFIGURATION_FH
313 ULONG Length; // Length of structure
314 ULONG HopPattern; // As defined by 802.11, MSB set
315 ULONG HopSet; // to one if non-802.11
316 ULONG DwellTime; // units are Kusec
317 } NDIS_802_11_CONFIGURATION_FH, *PNDIS_802_11_CONFIGURATION_FH;
319 typedef struct _NDIS_802_11_CONFIGURATION
321 ULONG Length; // Length of structure
322 ULONG BeaconPeriod; // units are Kusec
323 ULONG ATIMWindow; // units are Kusec
324 ULONG DSConfig; // Frequency, units are kHz
325 NDIS_802_11_CONFIGURATION_FH FHConfig;
326 } NDIS_802_11_CONFIGURATION, *PNDIS_802_11_CONFIGURATION;
328 typedef struct _NDIS_802_11_STATISTICS
330 ULONG Length; // Length of structure
331 LARGE_INTEGER TransmittedFragmentCount;
332 LARGE_INTEGER MulticastTransmittedFrameCount;
333 LARGE_INTEGER FailedCount;
334 LARGE_INTEGER RetryCount;
335 LARGE_INTEGER MultipleRetryCount;
336 LARGE_INTEGER RTSSuccessCount;
337 LARGE_INTEGER RTSFailureCount;
338 LARGE_INTEGER ACKFailureCount;
339 LARGE_INTEGER FrameDuplicateCount;
340 LARGE_INTEGER ReceivedFragmentCount;
341 LARGE_INTEGER MulticastReceivedFrameCount;
342 LARGE_INTEGER FCSErrorCount;
343 LARGE_INTEGER TKIPLocalMICFailures;
344 LARGE_INTEGER TKIPRemoteMICErrors;
345 LARGE_INTEGER TKIPICVErrors;
346 LARGE_INTEGER TKIPCounterMeasuresInvoked;
347 LARGE_INTEGER TKIPReplays;
348 LARGE_INTEGER CCMPFormatErrors;
349 LARGE_INTEGER CCMPReplays;
350 LARGE_INTEGER CCMPDecryptErrors;
351 LARGE_INTEGER FourWayHandshakeFailures;
352 } NDIS_802_11_STATISTICS, *PNDIS_802_11_STATISTICS;
354 typedef ULONG NDIS_802_11_KEY_INDEX;
355 typedef ULONGLONG NDIS_802_11_KEY_RSC;
357 #define MAX_RADIUS_SRV_NUM 2 // 802.1x failover number
359 typedef struct PACKED _RADIUS_SRV_INFO {
362 UCHAR radius_key[64];
363 UCHAR radius_key_len;
364 } RADIUS_SRV_INFO, *PRADIUS_SRV_INFO;
366 typedef struct PACKED _RADIUS_KEY_INFO
368 UCHAR radius_srv_num;
369 RADIUS_SRV_INFO radius_srv_info[MAX_RADIUS_SRV_NUM];
370 UCHAR ieee8021xWEP; // dynamic WEP
372 UCHAR key_length; // length of key in bytes
373 UCHAR key_material[13];
374 } RADIUS_KEY_INFO, *PRADIUS_KEY_INFO;
376 // It's used by 802.1x daemon to require relative configuration
377 typedef struct PACKED _RADIUS_CONF
379 UINT32 Length; // Length of this structure
380 UCHAR mbss_num; // indicate multiple BSS number
382 UINT32 retry_interval;
383 UINT32 session_timeout_interval;
384 UCHAR EAPifname[IFNAMSIZ];
386 UCHAR PreAuthifname[IFNAMSIZ];
387 UCHAR PreAuthifname_len;
388 RADIUS_KEY_INFO RadiusInfo[8/*MAX_MBSSID_NUM*/];
389 } RADIUS_CONF, *PRADIUS_CONF;
393 #ifdef CONFIG_STA_SUPPORT
394 // Key mapping keys require a BSSID
395 typedef struct _NDIS_802_11_KEY
397 UINT Length; // Length of this structure
399 UINT KeyLength; // length of key in bytes
400 NDIS_802_11_MAC_ADDRESS BSSID;
401 NDIS_802_11_KEY_RSC KeyRSC;
402 UCHAR KeyMaterial[1]; // variable length depending on above field
403 } NDIS_802_11_KEY, *PNDIS_802_11_KEY;
404 #endif // CONFIG_STA_SUPPORT //
406 typedef struct _NDIS_802_11_REMOVE_KEY
408 UINT Length; // Length of this structure
410 NDIS_802_11_MAC_ADDRESS BSSID;
411 } NDIS_802_11_REMOVE_KEY, *PNDIS_802_11_REMOVE_KEY;
413 typedef struct _NDIS_802_11_WEP
415 UINT Length; // Length of this structure
416 UINT KeyIndex; // 0 is the per-client key, 1-N are the
418 UINT KeyLength; // length of key in bytes
419 UCHAR KeyMaterial[1];// variable length depending on above field
420 } NDIS_802_11_WEP, *PNDIS_802_11_WEP;
423 typedef enum _NDIS_802_11_NETWORK_INFRASTRUCTURE
426 Ndis802_11Infrastructure,
427 Ndis802_11AutoUnknown,
429 Ndis802_11InfrastructureMax // Not a real value, defined as upper bound
430 } NDIS_802_11_NETWORK_INFRASTRUCTURE, *PNDIS_802_11_NETWORK_INFRASTRUCTURE;
432 // Add new authentication modes
433 typedef enum _NDIS_802_11_AUTHENTICATION_MODE
435 Ndis802_11AuthModeOpen,
436 Ndis802_11AuthModeShared,
437 Ndis802_11AuthModeAutoSwitch,
438 Ndis802_11AuthModeWPA,
439 Ndis802_11AuthModeWPAPSK,
440 Ndis802_11AuthModeWPANone,
441 Ndis802_11AuthModeWPA2,
442 Ndis802_11AuthModeWPA2PSK,
443 Ndis802_11AuthModeWPA1WPA2,
444 Ndis802_11AuthModeWPA1PSKWPA2PSK,
445 Ndis802_11AuthModeMax // Not a real mode, defined as upper bound
446 } NDIS_802_11_AUTHENTICATION_MODE, *PNDIS_802_11_AUTHENTICATION_MODE;
448 typedef UCHAR NDIS_802_11_RATES[NDIS_802_11_LENGTH_RATES]; // Set of 8 data rates
449 typedef UCHAR NDIS_802_11_RATES_EX[NDIS_802_11_LENGTH_RATES_EX]; // Set of 16 data rates
451 typedef struct PACKED _NDIS_802_11_SSID
453 UINT SsidLength; // length of SSID field below, in bytes;
455 UCHAR Ssid[NDIS_802_11_LENGTH_SSID]; // SSID information field
456 } NDIS_802_11_SSID, *PNDIS_802_11_SSID;
459 typedef struct PACKED _NDIS_WLAN_BSSID
461 ULONG Length; // Length of this structure
462 NDIS_802_11_MAC_ADDRESS MacAddress; // BSSID
464 NDIS_802_11_SSID Ssid; // SSID
465 ULONG Privacy; // WEP encryption requirement
466 NDIS_802_11_RSSI Rssi; // receive signal strength in dBm
467 NDIS_802_11_NETWORK_TYPE NetworkTypeInUse;
468 NDIS_802_11_CONFIGURATION Configuration;
469 NDIS_802_11_NETWORK_INFRASTRUCTURE InfrastructureMode;
470 NDIS_802_11_RATES SupportedRates;
471 } NDIS_WLAN_BSSID, *PNDIS_WLAN_BSSID;
473 typedef struct PACKED _NDIS_802_11_BSSID_LIST
475 UINT NumberOfItems; // in list below, at least 1
476 NDIS_WLAN_BSSID Bssid[1];
477 } NDIS_802_11_BSSID_LIST, *PNDIS_802_11_BSSID_LIST;
479 // Added Capabilities, IELength and IEs for each BSSID
480 typedef struct PACKED _NDIS_WLAN_BSSID_EX
482 ULONG Length; // Length of this structure
483 NDIS_802_11_MAC_ADDRESS MacAddress; // BSSID
485 NDIS_802_11_SSID Ssid; // SSID
486 UINT Privacy; // WEP encryption requirement
487 NDIS_802_11_RSSI Rssi; // receive signal
489 NDIS_802_11_NETWORK_TYPE NetworkTypeInUse;
490 NDIS_802_11_CONFIGURATION Configuration;
491 NDIS_802_11_NETWORK_INFRASTRUCTURE InfrastructureMode;
492 NDIS_802_11_RATES_EX SupportedRates;
495 } NDIS_WLAN_BSSID_EX, *PNDIS_WLAN_BSSID_EX;
497 typedef struct PACKED _NDIS_802_11_BSSID_LIST_EX
499 UINT NumberOfItems; // in list below, at least 1
500 NDIS_WLAN_BSSID_EX Bssid[1];
501 } NDIS_802_11_BSSID_LIST_EX, *PNDIS_802_11_BSSID_LIST_EX;
503 typedef struct PACKED _NDIS_802_11_FIXED_IEs
506 USHORT BeaconInterval;
508 } NDIS_802_11_FIXED_IEs, *PNDIS_802_11_FIXED_IEs;
510 typedef struct _NDIS_802_11_VARIABLE_IEs
513 UCHAR Length; // Number of bytes in data field
515 } NDIS_802_11_VARIABLE_IEs, *PNDIS_802_11_VARIABLE_IEs;
517 typedef ULONG NDIS_802_11_FRAGMENTATION_THRESHOLD;
519 typedef ULONG NDIS_802_11_RTS_THRESHOLD;
521 typedef ULONG NDIS_802_11_ANTENNA;
523 typedef enum _NDIS_802_11_PRIVACY_FILTER
525 Ndis802_11PrivFilterAcceptAll,
526 Ndis802_11PrivFilter8021xWEP
527 } NDIS_802_11_PRIVACY_FILTER, *PNDIS_802_11_PRIVACY_FILTER;
529 // Added new encryption types
530 // Also aliased typedef to new name
531 typedef enum _NDIS_802_11_WEP_STATUS
533 Ndis802_11WEPEnabled,
534 Ndis802_11Encryption1Enabled = Ndis802_11WEPEnabled,
535 Ndis802_11WEPDisabled,
536 Ndis802_11EncryptionDisabled = Ndis802_11WEPDisabled,
537 Ndis802_11WEPKeyAbsent,
538 Ndis802_11Encryption1KeyAbsent = Ndis802_11WEPKeyAbsent,
539 Ndis802_11WEPNotSupported,
540 Ndis802_11EncryptionNotSupported = Ndis802_11WEPNotSupported,
541 Ndis802_11Encryption2Enabled,
542 Ndis802_11Encryption2KeyAbsent,
543 Ndis802_11Encryption3Enabled,
544 Ndis802_11Encryption3KeyAbsent,
545 Ndis802_11Encryption4Enabled, // TKIP or AES mix
546 Ndis802_11Encryption4KeyAbsent,
547 Ndis802_11GroupWEP40Enabled,
548 Ndis802_11GroupWEP104Enabled,
549 } NDIS_802_11_WEP_STATUS, *PNDIS_802_11_WEP_STATUS,
550 NDIS_802_11_ENCRYPTION_STATUS, *PNDIS_802_11_ENCRYPTION_STATUS;
552 typedef enum _NDIS_802_11_RELOAD_DEFAULTS
554 Ndis802_11ReloadWEPKeys
555 } NDIS_802_11_RELOAD_DEFAULTS, *PNDIS_802_11_RELOAD_DEFAULTS;
557 #define NDIS_802_11_AI_REQFI_CAPABILITIES 1
558 #define NDIS_802_11_AI_REQFI_LISTENINTERVAL 2
559 #define NDIS_802_11_AI_REQFI_CURRENTAPADDRESS 4
561 #define NDIS_802_11_AI_RESFI_CAPABILITIES 1
562 #define NDIS_802_11_AI_RESFI_STATUSCODE 2
563 #define NDIS_802_11_AI_RESFI_ASSOCIATIONID 4
565 typedef struct _NDIS_802_11_AI_REQFI
568 USHORT ListenInterval;
569 NDIS_802_11_MAC_ADDRESS CurrentAPAddress;
570 } NDIS_802_11_AI_REQFI, *PNDIS_802_11_AI_REQFI;
572 typedef struct _NDIS_802_11_AI_RESFI
576 USHORT AssociationId;
577 } NDIS_802_11_AI_RESFI, *PNDIS_802_11_AI_RESFI;
579 typedef struct _NDIS_802_11_ASSOCIATION_INFORMATION
582 USHORT AvailableRequestFixedIEs;
583 NDIS_802_11_AI_REQFI RequestFixedIEs;
584 ULONG RequestIELength;
585 ULONG OffsetRequestIEs;
586 USHORT AvailableResponseFixedIEs;
587 NDIS_802_11_AI_RESFI ResponseFixedIEs;
588 ULONG ResponseIELength;
589 ULONG OffsetResponseIEs;
590 } NDIS_802_11_ASSOCIATION_INFORMATION, *PNDIS_802_11_ASSOCIATION_INFORMATION;
592 typedef struct _NDIS_802_11_AUTHENTICATION_EVENT
594 NDIS_802_11_STATUS_INDICATION Status;
595 NDIS_802_11_AUTHENTICATION_REQUEST Request[1];
596 } NDIS_802_11_AUTHENTICATION_EVENT, *PNDIS_802_11_AUTHENTICATION_EVENT;
598 // 802.11 Media stream constraints, associated with OID_802_11_MEDIA_STREAM_MODE
599 typedef enum _NDIS_802_11_MEDIA_STREAM_MODE
601 Ndis802_11MediaStreamOff,
602 Ndis802_11MediaStreamOn,
603 } NDIS_802_11_MEDIA_STREAM_MODE, *PNDIS_802_11_MEDIA_STREAM_MODE;
606 typedef UCHAR NDIS_802_11_PMKID_VALUE[16];
608 #ifdef CONFIG_STA_SUPPORT
609 typedef struct _BSSID_INFO
611 NDIS_802_11_MAC_ADDRESS BSSID;
612 NDIS_802_11_PMKID_VALUE PMKID;
613 } BSSID_INFO, *PBSSID_INFO;
615 typedef struct _NDIS_802_11_PMKID
619 BSSID_INFO BSSIDInfo[1];
620 } NDIS_802_11_PMKID, *PNDIS_802_11_PMKID;
621 #endif // CONFIG_STA_SUPPORT //
624 typedef struct _NDIS_802_11_AUTHENTICATION_ENCRYPTION
626 NDIS_802_11_AUTHENTICATION_MODE AuthModeSupported;
627 NDIS_802_11_ENCRYPTION_STATUS EncryptStatusSupported;
628 } NDIS_802_11_AUTHENTICATION_ENCRYPTION, *PNDIS_802_11_AUTHENTICATION_ENCRYPTION;
630 typedef struct _NDIS_802_11_CAPABILITY
635 ULONG NoOfAuthEncryptPairsSupported;
636 NDIS_802_11_AUTHENTICATION_ENCRYPTION AuthenticationEncryptionSupported[1];
637 } NDIS_802_11_CAPABILITY, *PNDIS_802_11_CAPABILITY;
642 #if WIRELESS_EXT <= 11
643 #ifndef SIOCDEVPRIVATE
644 #define SIOCDEVPRIVATE 0x8BE0
646 #define SIOCIWFIRSTPRIV SIOCDEVPRIVATE
649 #ifdef CONFIG_STA_SUPPORT
650 #define RTPRIV_IOCTL_SET (SIOCIWFIRSTPRIV + 0x02)
653 #define RTPRIV_IOCTL_BBP (SIOCIWFIRSTPRIV + 0x03)
654 #define RTPRIV_IOCTL_MAC (SIOCIWFIRSTPRIV + 0x05)
655 #define RTPRIV_IOCTL_E2P (SIOCIWFIRSTPRIV + 0x07)
659 #ifdef RALINK_28xx_QA
660 #define RTPRIV_IOCTL_ATE (SIOCIWFIRSTPRIV + 0x08)
661 #endif // RALINK_28xx_QA //
662 #endif // RALINK_ATE //
664 #define RTPRIV_IOCTL_STATISTICS (SIOCIWFIRSTPRIV + 0x09)
665 #define RTPRIV_IOCTL_ADD_PMKID_CACHE (SIOCIWFIRSTPRIV + 0x0A)
666 #define RTPRIV_IOCTL_RADIUS_DATA (SIOCIWFIRSTPRIV + 0x0C)
667 #define RTPRIV_IOCTL_GSITESURVEY (SIOCIWFIRSTPRIV + 0x0D)
668 #define RT_PRIV_IOCTL (SIOCIWFIRSTPRIV + 0x0E) // Sync. with RT61 (for wpa_supplicant)
669 #define RTPRIV_IOCTL_GET_MAC_TABLE (SIOCIWFIRSTPRIV + 0x0F)
671 #define RTPRIV_IOCTL_SHOW (SIOCIWFIRSTPRIV + 0x11)
673 SHOW_CONN_STATUS = 4,
674 SHOW_DRVIER_VERION = 5,
679 #ifdef QOS_DLS_SUPPORT
680 SHOW_DLS_ENTRY_INFO = 19,
681 #endif // QOS_DLS_SUPPORT //
685 #endif // CONFIG_STA_SUPPORT //
688 //SNMP ieee 802dot11, kathy , 2008_0220
690 #define RT_OID_802_11_MANUFACTUREROUI 0x0700
691 #define RT_OID_802_11_MANUFACTURERNAME 0x0701
692 #define RT_OID_802_11_RESOURCETYPEIDNAME 0x0702
695 #define RT_OID_802_11_PRIVACYOPTIONIMPLEMENTED 0x0703
696 #define RT_OID_802_11_POWERMANAGEMENTMODE 0x0704
697 #define OID_802_11_WEPDEFAULTKEYVALUE 0x0705 // read , write
698 #define OID_802_11_WEPDEFAULTKEYID 0x0706
699 #define RT_OID_802_11_WEPKEYMAPPINGLENGTH 0x0707
700 #define OID_802_11_SHORTRETRYLIMIT 0x0708
701 #define OID_802_11_LONGRETRYLIMIT 0x0709
702 #define RT_OID_802_11_PRODUCTID 0x0710
703 #define RT_OID_802_11_MANUFACTUREID 0x0711
706 #define OID_802_11_CURRENTCHANNEL 0x0712
709 #define RT_OID_802_11_MAC_ADDRESS 0x0713
710 #endif // SNMP_SUPPORT //
712 #define OID_802_11_BUILD_CHANNEL_EX 0x0714
713 #define OID_802_11_GET_CH_LIST 0x0715
714 #define OID_802_11_GET_COUNTRY_CODE 0x0716
715 #define OID_802_11_GET_CHANNEL_GEOGRAPHY 0x0717
718 // for consistency with RT61
719 #define RT_OID_GET_PHY_MODE 0x761
720 #endif // LLTD_SUPPORT //
722 // New for MeetingHouse Api support
723 #define OID_MH_802_1X_SUPPORTED 0xFFEDC100
725 // MIMO Tx parameter, ShortGI, MCS, STBC, etc. these are fields in TXWI. Don't change this definition!!!
726 typedef union _HTTRANSMIT_SETTING {
729 USHORT MODE:2; // Use definition MODE_xxx.
732 USHORT STBC:2; //SPACE
734 USHORT BW:1; //channel bandwidth 20MHz or 40 MHz
740 USHORT BW:1; //channel bandwidth 20MHz or 40 MHz
742 USHORT STBC:2; //SPACE
745 USHORT MODE:2; // Use definition MODE_xxx.
749 } HTTRANSMIT_SETTING, *PHTTRANSMIT_SETTING;
751 typedef enum _RT_802_11_PREAMBLE {
752 Rt802_11PreambleLong,
753 Rt802_11PreambleShort,
755 } RT_802_11_PREAMBLE, *PRT_802_11_PREAMBLE;
757 // Only for STA, need to sync with AP
758 // 2005-03-08 match current RaConfig.
759 typedef enum _RT_802_11_PHY_MODE {
765 #ifdef DOT11_N_SUPPORT
766 PHY_11ABGN_MIXED, // both band 5
767 PHY_11N_2_4G, // 11n-only with 2.4G band 6
768 PHY_11GN_MIXED, // 2.4G band 7
769 PHY_11AN_MIXED, // 5G band 8
770 PHY_11BGN_MIXED, // if check 802.11b. 9
771 PHY_11AGN_MIXED, // if check 802.11b. 10
772 PHY_11N_5G, // 11n-only with 5G band 11
773 #endif // DOT11_N_SUPPORT //
774 } RT_802_11_PHY_MODE;
776 // put all proprietery for-query objects here to reduce # of Query_OID
777 typedef struct _RT_802_11_LINK_STATUS {
778 ULONG CurrTxRate; // in units of 0.5Mbps
779 ULONG ChannelQuality; // 0..100 %
780 ULONG TxByteCount; // both ok and fail
781 ULONG RxByteCount; // both ok and fail
782 ULONG CentralChannel; // 40MHz central channel number
783 } RT_802_11_LINK_STATUS, *PRT_802_11_LINK_STATUS;
785 typedef struct _RT_802_11_EVENT_LOG {
786 LARGE_INTEGER SystemTime; // timestammp via NdisGetCurrentSystemTime()
787 UCHAR Addr[MAC_ADDR_LENGTH];
788 USHORT Event; // EVENT_xxx
789 } RT_802_11_EVENT_LOG, *PRT_802_11_EVENT_LOG;
791 typedef struct _RT_802_11_EVENT_TABLE {
793 ULONG Rsv; // to align Log[] at LARGE_INEGER boundary
794 RT_802_11_EVENT_LOG Log[MAX_NUMBER_OF_EVENT];
795 } RT_802_11_EVENT_TABLE, PRT_802_11_EVENT_TABLE;
797 // MIMO Tx parameter, ShortGI, MCS, STBC, etc. these are fields in TXWI. Don't change this definition!!!
798 typedef union _MACHTTRANSMIT_SETTING {
801 USHORT BW:1; //channel bandwidth 20MHz or 40 MHz
803 USHORT STBC:2; //SPACE
805 USHORT MODE:2; // Use definition MODE_xxx.
808 } MACHTTRANSMIT_SETTING, *PMACHTTRANSMIT_SETTING;
810 typedef struct _RT_802_11_MAC_ENTRY {
811 UCHAR Addr[MAC_ADDR_LENGTH];
813 UCHAR Psm; // 0:PWR_ACTIVE, 1:PWR_SAVE
814 UCHAR MimoPs; // 0:MMPS_STATIC, 1:MMPS_DYNAMIC, 3:MMPS_Enabled
818 UINT32 ConnectedTime;
819 MACHTTRANSMIT_SETTING TxRate;
820 } RT_802_11_MAC_ENTRY, *PRT_802_11_MAC_ENTRY;
822 typedef struct _RT_802_11_MAC_TABLE {
824 RT_802_11_MAC_ENTRY Entry[MAX_NUMBER_OF_MAC];
825 } RT_802_11_MAC_TABLE, *PRT_802_11_MAC_TABLE;
827 // structure for query/set hardware register - MAC, BBP, RF register
828 typedef struct _RT_802_11_HARDWARE_REGISTER {
829 ULONG HardwareType; // 0:MAC, 1:BBP, 2:RF register, 3:EEPROM
830 ULONG Offset; // Q/S register offset addr
831 ULONG Data; // R/W data buffer
832 } RT_802_11_HARDWARE_REGISTER, *PRT_802_11_HARDWARE_REGISTER;
834 typedef struct _RT_802_11_AP_CONFIG {
835 ULONG EnableTxBurst; // 0-disable, 1-enable
836 ULONG EnableTurboRate; // 0-disable, 1-enable 72/100mbps turbo rate
837 ULONG IsolateInterStaTraffic; // 0-disable, 1-enable isolation
838 ULONG HideSsid; // 0-disable, 1-enable hiding
839 ULONG UseBGProtection; // 0-AUTO, 1-always ON, 2-always OFF
840 ULONG UseShortSlotTime; // 0-no use, 1-use 9-us short slot time
841 ULONG Rsv1; // must be 0
842 ULONG SystemErrorBitmap; // ignore upon SET, return system error upon QUERY
843 } RT_802_11_AP_CONFIG, *PRT_802_11_AP_CONFIG;
845 // structure to query/set STA_CONFIG
846 typedef struct _RT_802_11_STA_CONFIG {
847 ULONG EnableTxBurst; // 0-disable, 1-enable
848 ULONG EnableTurboRate; // 0-disable, 1-enable 72/100mbps turbo rate
849 ULONG UseBGProtection; // 0-AUTO, 1-always ON, 2-always OFF
850 ULONG UseShortSlotTime; // 0-no use, 1-use 9-us short slot time when applicable
851 ULONG AdhocMode; // 0-11b rates only (WIFI spec), 1 - b/g mixed, 2 - g only
852 ULONG HwRadioStatus; // 0-OFF, 1-ON, default is 1, Read-Only
853 ULONG Rsv1; // must be 0
854 ULONG SystemErrorBitmap; // ignore upon SET, return system error upon QUERY
855 } RT_802_11_STA_CONFIG, *PRT_802_11_STA_CONFIG;
858 // For OID Query or Set about BA structure
860 typedef struct _OID_BACAP_STRUC {
863 UCHAR Policy; // 0: DELAY_BA 1:IMMED_BA (//BA Policy subfiled value in ADDBA frame) 2:BA-not use. other value invalid
864 UCHAR MpduDensity; // 0: DELAY_BA 1:IMMED_BA (//BA Policy subfiled value in ADDBA frame) 2:BA-not use. other value invalid
865 UCHAR AmsduEnable; //Enable AMSDU transmisstion
866 UCHAR AmsduSize; // 0:3839, 1:7935 bytes. UINT MSDUSizeToBytes[] = { 3839, 7935};
867 UCHAR MMPSmode; // MIMO power save more, 0:static, 1:dynamic, 2:rsv, 3:mimo enable
868 BOOLEAN AutoBA; // Auto BA will automatically
869 } OID_BACAP_STRUC, *POID_BACAP_STRUC;
871 typedef struct _RT_802_11_ACL_ENTRY {
872 UCHAR Addr[MAC_ADDR_LENGTH];
874 } RT_802_11_ACL_ENTRY, *PRT_802_11_ACL_ENTRY;
876 typedef struct PACKED _RT_802_11_ACL {
877 ULONG Policy; // 0-disable, 1-positive list, 2-negative list
879 RT_802_11_ACL_ENTRY Entry[MAX_NUMBER_OF_ACL];
880 } RT_802_11_ACL, *PRT_802_11_ACL;
882 typedef struct _RT_802_11_WDS {
884 NDIS_802_11_MAC_ADDRESS Entry[24/*MAX_NUM_OF_WDS_LINK*/];
886 UCHAR KeyMaterial[32];
887 } RT_802_11_WDS, *PRT_802_11_WDS;
889 typedef struct _RT_802_11_TX_RATES_ {
891 UCHAR SupRate[MAX_LENGTH_OF_SUPPORT_RATES];
893 UCHAR ExtRate[MAX_LENGTH_OF_SUPPORT_RATES];
894 } RT_802_11_TX_RATES, *PRT_802_11_TX_RATES;
897 // Definition of extra information code
898 #define GENERAL_LINK_UP 0x0 // Link is Up
899 #define GENERAL_LINK_DOWN 0x1 // Link is Down
900 #define HW_RADIO_OFF 0x2 // Hardware radio off
901 #define SW_RADIO_OFF 0x3 // Software radio off
902 #define AUTH_FAIL 0x4 // Open authentication fail
903 #define AUTH_FAIL_KEYS 0x5 // Shared authentication fail
904 #define ASSOC_FAIL 0x6 // Association failed
905 #define EAP_MIC_FAILURE 0x7 // Deauthencation because MIC failure
906 #define EAP_4WAY_TIMEOUT 0x8 // Deauthencation on 4-way handshake timeout
907 #define EAP_GROUP_KEY_TIMEOUT 0x9 // Deauthencation on group key handshake timeout
908 #define EAP_SUCCESS 0xa // EAP succeed
909 #define DETECT_RADAR_SIGNAL 0xb // Radar signal occur in current channel
910 #define EXTRA_INFO_MAX 0xb // Indicate Last OID
912 #define EXTRA_INFO_CLEAR 0xffffffff
914 // This is OID setting structure. So only GF or MM as Mode. This is valid when our wirelss mode has 802.11n in use.
916 RT_802_11_PHY_MODE PhyMode; //
918 UCHAR HtMode; //HTMODE_GF or HTMODE_MM
919 UCHAR ExtOffset; //extension channel above or below
925 } OID_SET_HT_PHYMODE, *POID_SET_HT_PHYMODE;
928 typedef struct _RT_LLTD_ASSOICATION_ENTRY {
929 UCHAR Addr[ETH_LENGTH_OF_ADDRESS];
930 unsigned short MOR; // maximum operational rate
932 } RT_LLTD_ASSOICATION_ENTRY, *PRT_LLTD_ASSOICATION_ENTRY;
934 typedef struct _RT_LLTD_ASSOICATION_TABLE {
936 RT_LLTD_ASSOICATION_ENTRY Entry[MAX_NUMBER_OF_MAC];
937 } RT_LLTD_ASSOICATION_TABLE, *PRT_LLTD_ASSOICATION_TABLE;
938 #endif // LLTD_SUPPORT //
940 #ifdef CONFIG_STA_SUPPORT
941 #ifdef QOS_DLS_SUPPORT
942 //rt2860, kathy 2007-0118
944 typedef struct _RT_802_11_DLS_UI {
945 USHORT TimeOut; // unit: second , set by UI
946 USHORT CountDownTimer; // unit: second , used by driver only
947 NDIS_802_11_MAC_ADDRESS MacAddr; // set by UI
948 UCHAR Status; // 0: none , 1: wait STAkey, 2: finish DLS setup , set by driver only
949 BOOLEAN Valid; // 1: valid , 0: invalid , set by UI, use to setup or tear down DLS link
950 } RT_802_11_DLS_UI, *PRT_802_11_DLS_UI;
952 typedef struct _RT_802_11_DLS_INFO {
953 RT_802_11_DLS_UI Entry[MAX_NUMBER_OF_DLS_ENTRY];
955 } RT_802_11_DLS_INFO, *PRT_802_11_DLS_INFO;
957 typedef enum _RT_802_11_DLS_MODE {
961 } RT_802_11_DLS_MODE;
962 #endif // QOS_DLS_SUPPORT //
964 #ifdef WPA_SUPPLICANT_SUPPORT
965 #ifndef NATIVE_WPA_SUPPLICANT_SUPPORT
966 #define RT_ASSOC_EVENT_FLAG 0x0101
967 #define RT_DISASSOC_EVENT_FLAG 0x0102
968 #define RT_REQIE_EVENT_FLAG 0x0103
969 #define RT_RESPIE_EVENT_FLAG 0x0104
970 #define RT_ASSOCINFO_EVENT_FLAG 0x0105
971 #define RT_PMKIDCAND_FLAG 0x0106
972 #define RT_INTERFACE_DOWN 0x0107
973 #define RT_INTERFACE_UP 0x0108
974 #endif // NATIVE_WPA_SUPPLICANT_SUPPORT //
975 #endif // WPA_SUPPLICANT_SUPPORT //
976 #endif // CONFIG_STA_SUPPORT //
978 #define MAX_CUSTOM_LEN 128
980 #ifdef CONFIG_STA_SUPPORT
981 typedef enum _RT_802_11_D_CLIENT_MODE
986 } RT_802_11_D_CLIENT_MODE, *PRT_802_11_D_CLIENT_MODE;
987 #endif // CONFIG_STA_SUPPORT //
989 typedef struct _RT_CHANNEL_LIST_INFO
991 UCHAR ChannelList[MAX_NUM_OF_CHS]; // list all supported channels for site survey
992 UCHAR ChannelListNum; // number of channel in ChannelList[]
993 } RT_CHANNEL_LIST_INFO, *PRT_CHANNEL_LIST_INFO;