1 /******************************************************************************
3 * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of version 2 of the GNU General Public License as
7 * published by the Free Software Foundation.
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 ******************************************************************************/
18 #define P80211CAPTURE_VERSION 0x80211001
20 /* This value is tested by WiFi 11n Test Plan 5.2.3.
21 * This test verifies the WLAN NIC can update the NAV through sending
22 * the CTS with large duration.
24 #define WiFiNavUpperUs 30000 /* 30 ms */
26 enum WIFI_FRAME_TYPE {
28 WIFI_CTRL_TYPE = (BIT(2)),
29 WIFI_DATA_TYPE = (BIT(3)),
30 WIFI_QOS_DATA_TYPE = (BIT(7)|BIT(3)), /* QoS Data */
33 enum WIFI_FRAME_SUBTYPE {
34 /* below is for mgt frame */
35 WIFI_ASSOCREQ = (0 | WIFI_MGT_TYPE),
36 WIFI_ASSOCRSP = (BIT(4) | WIFI_MGT_TYPE),
37 WIFI_REASSOCREQ = (BIT(5) | WIFI_MGT_TYPE),
38 WIFI_REASSOCRSP = (BIT(5) | BIT(4) | WIFI_MGT_TYPE),
39 WIFI_PROBEREQ = (BIT(6) | WIFI_MGT_TYPE),
40 WIFI_PROBERSP = (BIT(6) | BIT(4) | WIFI_MGT_TYPE),
41 WIFI_BEACON = (BIT(7) | WIFI_MGT_TYPE),
42 WIFI_ATIM = (BIT(7) | BIT(4) | WIFI_MGT_TYPE),
43 WIFI_DISASSOC = (BIT(7) | BIT(5) | WIFI_MGT_TYPE),
44 WIFI_AUTH = (BIT(7) | BIT(5) | BIT(4) | WIFI_MGT_TYPE),
45 WIFI_DEAUTH = (BIT(7) | BIT(6) | WIFI_MGT_TYPE),
46 WIFI_ACTION = (BIT(7) | BIT(6) | BIT(4) | WIFI_MGT_TYPE),
48 /* below is for control frame */
49 WIFI_PSPOLL = (BIT(7) | BIT(5) | WIFI_CTRL_TYPE),
50 WIFI_RTS = (BIT(7) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),
51 WIFI_CTS = (BIT(7) | BIT(6) | WIFI_CTRL_TYPE),
52 WIFI_ACK = (BIT(7) | BIT(6) | BIT(4) | WIFI_CTRL_TYPE),
53 WIFI_CFEND = (BIT(7) | BIT(6) | BIT(5) | WIFI_CTRL_TYPE),
54 WIFI_CFEND_CFACK = (BIT(7) | BIT(6) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),
56 /* below is for data frame */
57 WIFI_DATA = (0 | WIFI_DATA_TYPE),
58 WIFI_DATA_CFACK = (BIT(4) | WIFI_DATA_TYPE),
59 WIFI_DATA_CFPOLL = (BIT(5) | WIFI_DATA_TYPE),
60 WIFI_DATA_CFACKPOLL = (BIT(5) | BIT(4) | WIFI_DATA_TYPE),
61 WIFI_DATA_NULL = (BIT(6) | WIFI_DATA_TYPE),
62 WIFI_CF_ACK = (BIT(6) | BIT(4) | WIFI_DATA_TYPE),
63 WIFI_CF_POLL = (BIT(6) | BIT(5) | WIFI_DATA_TYPE),
64 WIFI_CF_ACKPOLL = (BIT(6) | BIT(5) | BIT(4) | WIFI_DATA_TYPE),
65 WIFI_QOS_DATA_NULL = (BIT(6) | WIFI_QOS_DATA_TYPE),
69 enum WIFI_REG_DOMAIN {
84 #define SetToDs(pbuf) \
85 (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_TODS))
87 #define SetFrDs(pbuf) \
88 (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_FROMDS))
90 #define SetMFrag(pbuf) \
91 (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_MOREFRAGS))
93 #define ClearMFrag(pbuf) \
94 (*(__le16 *)(pbuf) &= (~cpu_to_le16(IEEE80211_FCTL_MOREFRAGS)))
96 #define SetRetry(pbuf) \
97 (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_RETRY))
99 #define SetPwrMgt(pbuf) \
100 (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_PM))
102 #define SetMData(pbuf) \
103 (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_MOREDATA))
105 #define SetPrivacy(pbuf) \
106 (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_PROTECTED))
108 #define SetFrameType(pbuf, type) \
110 *(__le16 *)(pbuf) &= __constant_cpu_to_le16(~(BIT(3) | BIT(2))); \
111 *(__le16 *)(pbuf) |= __constant_cpu_to_le16(type); \
114 #define SetFrameSubType(pbuf, type) \
116 *(__le16 *)(pbuf) &= cpu_to_le16(~(BIT(7) | BIT(6) | BIT(5) | BIT(4) | BIT(3) | BIT(2))); \
117 *(__le16 *)(pbuf) |= cpu_to_le16(type); \
120 #define GetTupleCache(pbuf) (cpu_to_le16(*(unsigned short *)((unsigned long)(pbuf) + 22)))
122 #define SetFragNum(pbuf, num) \
124 *(unsigned short *)((unsigned long)(pbuf) + 22) = \
125 ((*(unsigned short *)((unsigned long)(pbuf) + 22)) & le16_to_cpu(~(0x000f))) | \
126 cpu_to_le16(0x0f & (num)); \
129 #define SetSeqNum(pbuf, num) \
131 *(__le16 *)((size_t)(pbuf) + 22) = \
132 ((*(__le16 *)((size_t)(pbuf) + 22)) & cpu_to_le16((unsigned short)0x000f)) | \
133 cpu_to_le16((unsigned short)(0xfff0 & (num << 4))); \
136 #define SetDuration(pbuf, dur) \
137 (*(__le16 *)((unsigned long)(pbuf) + 2) = \
138 cpu_to_le16(0xffff & (dur)))
140 #define SetPriority(pbuf, tid) \
141 (*(__le16 *)(pbuf) |= cpu_to_le16(tid & 0xf))
143 #define SetEOSP(pbuf, eosp) \
144 (*(__le16 *)(pbuf) |= cpu_to_le16((eosp & 1) << 4))
146 #define SetAckpolicy(pbuf, ack) \
147 (*(__le16 *)(pbuf) |= cpu_to_le16((ack & 3) << 5))
149 #define SetAMsdu(pbuf, amsdu) \
150 (*(__le16 *)(pbuf) |= cpu_to_le16((amsdu & 1) << 7))
152 #define GetAid(pbuf) \
153 (cpu_to_le16(*(unsigned short *)((unsigned long)(pbuf) + 2)) & \
156 #define GetTid(pbuf) \
157 (cpu_to_le16(*(unsigned short *)((unsigned long)(pbuf) + \
158 (((ieee80211_has_tods(pbuf)<<1) | \
159 ieee80211_has_fromds(pbuf)) == 3 ? 30 : 24))) & 0x000f)
161 static inline unsigned char *get_hdr_bssid(unsigned char *pframe)
164 unsigned int to_fr_ds;
165 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) pframe;
167 to_fr_ds = (ieee80211_has_tods(hdr->frame_control) << 1) |
168 ieee80211_has_fromds(hdr->frame_control);
171 case 0x00: /* ToDs=0, FromDs=0 */
174 case 0x01: /* ToDs=0, FromDs=1 */
177 case 0x02: /* ToDs=1, FromDs=0 */
180 case 0x03: /* ToDs=1, FromDs=1 */
190 /*-----------------------------------------------------------------------------
191 Below is for the security related definition
192 ------------------------------------------------------------------------------*/
193 #define _RESERVED_FRAME_TYPE_ 0
194 #define _SKB_FRAME_TYPE_ 2
195 #define _PRE_ALLOCMEM_ 1
196 #define _PRE_ALLOCHDR_ 3
197 #define _PRE_ALLOCLLCHDR_ 4
198 #define _PRE_ALLOCICVHDR_ 5
199 #define _PRE_ALLOCMICHDR_ 6
202 ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11A) ? 16 : 10)
203 #define _ACKCTSLNG_ 14 /* 14 bytes long, including crclng */
206 #define _ASOCREQ_IE_OFFSET_ 4 /* excluding wlan_hdr */
207 #define _ASOCRSP_IE_OFFSET_ 6
208 #define _REASOCREQ_IE_OFFSET_ 10
209 #define _REASOCRSP_IE_OFFSET_ 6
210 #define _PROBEREQ_IE_OFFSET_ 0
211 #define _PROBERSP_IE_OFFSET_ 12
212 #define _AUTH_IE_OFFSET_ 6
213 #define _DEAUTH_IE_OFFSET_ 0
214 #define _BEACON_IE_OFFSET_ 12
215 #define _PUBLIC_ACTION_IE_OFFSET_ 8
217 #define _FIXED_IE_LENGTH_ _BEACON_IE_OFFSET_
220 #define EID_BSSIntolerantChlReport 73
222 /* ---------------------------------------------------------------------------
223 Below is the fixed elements...
224 -----------------------------------------------------------------------------*/
225 #define _AUTH_ALGM_NUM_ 2
226 #define _AUTH_SEQ_NUM_ 2
227 #define _BEACON_ITERVAL_ 2
228 #define _CAPABILITY_ 2
229 #define _CURRENT_APADDR_ 6
230 #define _LISTEN_INTERVAL_ 2
232 #define _STATUS_CODE_ 2
233 #define _TIMESTAMP_ 8
235 #define AUTH_ODD_TO 0
236 #define AUTH_EVEN_TO 1
238 #define WLAN_ETHCONV_ENCAP 1
239 #define WLAN_ETHCONV_RFC1042 2
240 #define WLAN_ETHCONV_8021h 3
242 #define cap_ESS BIT(0)
243 #define cap_IBSS BIT(1)
244 #define cap_CFPollable BIT(2)
245 #define cap_CFRequest BIT(3)
246 #define cap_Privacy BIT(4)
247 #define cap_ShortPremble BIT(5)
248 #define cap_PBCC BIT(6)
249 #define cap_ChAgility BIT(7)
250 #define cap_SpecMgmt BIT(8)
251 #define cap_QoS BIT(9)
252 #define cap_ShortSlot BIT(10)
254 /*-----------------------------------------------------------------------------
255 Below is the definition for 802.11i / 802.1x
256 ------------------------------------------------------------------------------*/
257 #define _IEEE8021X_MGT_ 1 /* WPA */
258 #define _IEEE8021X_PSK_ 2 /* WPA with pre-shared key */
261 #define _NO_PRIVACY_ 0
262 #define _WEP_40_PRIVACY_ 1
263 #define _TKIP_PRIVACY_ 2
264 #define _WRAP_PRIVACY_ 3
265 #define _CCMP_PRIVACY_ 4
266 #define _WEP_104_PRIVACY_ 5
267 #define _WEP_WPA_MIXED_PRIVACY_ 6 WEP + WPA
270 /*-----------------------------------------------------------------------------
271 Below is the definition for WMM
272 ------------------------------------------------------------------------------*/
273 #define _WMM_IE_Length_ 7 /* for WMM STA */
274 #define _WMM_Para_Element_Length_ 24
277 /*-----------------------------------------------------------------------------
278 Below is the definition for 802.11n
279 ------------------------------------------------------------------------------*/
281 #define SetOrderBit(pbuf) \
282 (*(unsigned short *)(pbuf) |= cpu_to_le16(_ORDER_))
284 #define GetOrderBit(pbuf) \
285 (((*(unsigned short *)(pbuf)) & le16_to_cpu(_ORDER_)) != 0)
288 /* struct rtw_ieee80211_ht_cap - HT additional information
290 * This structure refers to "HT information element" as
291 * described in 802.11n draft section 7.3.2.53
293 struct ieee80211_ht_addt_info {
294 unsigned char control_chan;
295 unsigned char ht_param;
296 unsigned short operation_mode;
297 unsigned short stbc_param;
298 unsigned char basic_set[16];
301 struct HT_caps_element {
304 unsigned short HT_caps_info;
305 unsigned char AMPDU_para;
306 unsigned char MCS_rate[16];
307 unsigned short HT_ext_caps;
308 unsigned int Beamforming_caps;
309 unsigned char ASEL_caps;
311 unsigned char HT_cap[26];
315 struct HT_info_element {
316 unsigned char primary_channel;
317 unsigned char infos[5];
318 unsigned char MCS_rate[16];
322 unsigned char ACI_AIFSN;
324 unsigned short TXOP_limit;
327 struct WMM_para_element {
328 unsigned char QoS_info;
329 unsigned char reserved;
330 struct AC_param ac_param[4];
333 struct ADDBA_request {
334 unsigned char dialog_token;
335 unsigned short BA_para_set;
336 unsigned short BA_timeout_value;
337 unsigned short BA_starting_seqctrl;
341 #define OP_MODE_PURE 0
342 #define OP_MODE_MAY_BE_LEGACY_STAS 1
343 #define OP_MODE_20MHZ_HT_STA_ASSOCED 2
344 #define OP_MODE_MIXED 3
346 #define HT_INFO_HT_PARAM_SECONDARY_CHNL_OFF_MASK ((u8) BIT(0) | BIT(1))
347 #define HT_INFO_HT_PARAM_SECONDARY_CHNL_ABOVE ((u8) BIT(0))
348 #define HT_INFO_HT_PARAM_SECONDARY_CHNL_BELOW ((u8) BIT(0) | BIT(1))
349 #define HT_INFO_HT_PARAM_REC_TRANS_CHNL_WIDTH ((u8) BIT(2))
350 #define HT_INFO_HT_PARAM_RIFS_MODE ((u8) BIT(3))
351 #define HT_INFO_HT_PARAM_CTRL_ACCESS_ONLY ((u8) BIT(4))
352 #define HT_INFO_HT_PARAM_SRV_INTERVAL_GRANULARITY ((u8) BIT(5))
354 #define HT_INFO_OPERATION_MODE_OP_MODE_MASK \
355 ((u16) (0x0001 | 0x0002))
356 #define HT_INFO_OPERATION_MODE_OP_MODE_OFFSET 0
357 #define HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT ((u8) BIT(2))
358 #define HT_INFO_OPERATION_MODE_TRANSMIT_BURST_LIMIT ((u8) BIT(3))
359 #define HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT ((u8) BIT(4))
361 #define HT_INFO_STBC_PARAM_DUAL_BEACON ((u16) BIT(6))
362 #define HT_INFO_STBC_PARAM_DUAL_STBC_PROTECT ((u16) BIT(7))
363 #define HT_INFO_STBC_PARAM_SECONDARY_BCN ((u16) BIT(8))
364 #define HT_INFO_STBC_PARAM_LSIG_TXOP_PROTECT_ALLOWED ((u16) BIT(9))
365 #define HT_INFO_STBC_PARAM_PCO_ACTIVE ((u16) BIT(10))
366 #define HT_INFO_STBC_PARAM_PCO_PHASE ((u16) BIT(11))
370 /* ===============WPS Section=============== */
372 #define WPSOUI 0x0050f204
373 /* WPS attribute ID */
374 #define WPS_ATTR_VER1 0x104A
375 #define WPS_ATTR_SIMPLE_CONF_STATE 0x1044
376 #define WPS_ATTR_RESP_TYPE 0x103B
377 #define WPS_ATTR_UUID_E 0x1047
378 #define WPS_ATTR_MANUFACTURER 0x1021
379 #define WPS_ATTR_MODEL_NAME 0x1023
380 #define WPS_ATTR_MODEL_NUMBER 0x1024
381 #define WPS_ATTR_SERIAL_NUMBER 0x1042
382 #define WPS_ATTR_PRIMARY_DEV_TYPE 0x1054
383 #define WPS_ATTR_SEC_DEV_TYPE_LIST 0x1055
384 #define WPS_ATTR_DEVICE_NAME 0x1011
385 #define WPS_ATTR_CONF_METHOD 0x1008
386 #define WPS_ATTR_RF_BANDS 0x103C
387 #define WPS_ATTR_DEVICE_PWID 0x1012
388 #define WPS_ATTR_REQUEST_TYPE 0x103A
389 #define WPS_ATTR_ASSOCIATION_STATE 0x1002
390 #define WPS_ATTR_CONFIG_ERROR 0x1009
391 #define WPS_ATTR_VENDOR_EXT 0x1049
392 #define WPS_ATTR_SELECTED_REGISTRAR 0x1041
394 /* Value of WPS attribute "WPS_ATTR_DEVICE_NAME */
395 #define WPS_MAX_DEVICE_NAME_LEN 32
397 /* Value of WPS Request Type Attribute */
398 #define WPS_REQ_TYPE_ENROLLEE_INFO_ONLY 0x00
399 #define WPS_REQ_TYPE_ENROLLEE_OPEN_8021X 0x01
400 #define WPS_REQ_TYPE_REGISTRAR 0x02
401 #define WPS_REQ_TYPE_WLAN_MANAGER_REGISTRAR 0x03
403 /* Value of WPS Response Type Attribute */
404 #define WPS_RESPONSE_TYPE_INFO_ONLY 0x00
405 #define WPS_RESPONSE_TYPE_8021X 0x01
406 #define WPS_RESPONSE_TYPE_REGISTRAR 0x02
407 #define WPS_RESPONSE_TYPE_AP 0x03
409 /* Value of WPS WiFi Simple Configuration State Attribute */
410 #define WPS_WSC_STATE_NOT_CONFIG 0x01
411 #define WPS_WSC_STATE_CONFIG 0x02
413 /* Value of WPS Version Attribute */
414 #define WPS_VERSION_1 0x10
416 /* Value of WPS Configuration Method Attribute */
417 #define WPS_CONFIG_METHOD_FLASH 0x0001
418 #define WPS_CONFIG_METHOD_ETHERNET 0x0002
419 #define WPS_CONFIG_METHOD_LABEL 0x0004
420 #define WPS_CONFIG_METHOD_DISPLAY 0x0008
421 #define WPS_CONFIG_METHOD_E_NFC 0x0010
422 #define WPS_CONFIG_METHOD_I_NFC 0x0020
423 #define WPS_CONFIG_METHOD_NFC 0x0040
424 #define WPS_CONFIG_METHOD_PBC 0x0080
425 #define WPS_CONFIG_METHOD_KEYPAD 0x0100
426 #define WPS_CONFIG_METHOD_VPBC 0x0280
427 #define WPS_CONFIG_METHOD_PPBC 0x0480
428 #define WPS_CONFIG_METHOD_VDISPLAY 0x2008
429 #define WPS_CONFIG_METHOD_PDISPLAY 0x4008
431 /* Value of Category ID of WPS Primary Device Type Attribute */
432 #define WPS_PDT_CID_DISPLAYS 0x0007
433 #define WPS_PDT_CID_MULIT_MEDIA 0x0008
434 #define WPS_PDT_CID_RTK_WIDI WPS_PDT_CID_MULIT_MEDIA
436 /* Value of Sub Category ID of WPS Primary Device Type Attribute */
437 #define WPS_PDT_SCID_MEDIA_SERVER 0x0005
438 #define WPS_PDT_SCID_RTK_DMP WPS_PDT_SCID_MEDIA_SERVER
440 /* Value of Device Password ID */
441 #define WPS_DPID_PIN 0x0000
442 #define WPS_DPID_USER_SPEC 0x0001
443 #define WPS_DPID_MACHINE_SPEC 0x0002
444 #define WPS_DPID_REKEY 0x0003
445 #define WPS_DPID_PBC 0x0004
446 #define WPS_DPID_REGISTRAR_SPEC 0x0005
448 /* Value of WPS RF Bands Attribute */
449 #define WPS_RF_BANDS_2_4_GHZ 0x01
450 #define WPS_RF_BANDS_5_GHZ 0x02
452 /* Value of WPS Association State Attribute */
453 #define WPS_ASSOC_STATE_NOT_ASSOCIATED 0x00
454 #define WPS_ASSOC_STATE_CONNECTION_SUCCESS 0x01
455 #define WPS_ASSOC_STATE_CONFIGURATION_FAILURE 0x02
456 #define WPS_ASSOC_STATE_ASSOCIATION_FAILURE 0x03
457 #define WPS_ASSOC_STATE_IP_FAILURE 0x04
459 /* P2P Public Action Frame ( Management Frame ) */
460 #define P2P_PUB_ACTION_ACTION 0x09
462 /* P2P Public Action Frame Type */
463 #define P2P_GO_NEGO_REQ 0
464 #define P2P_GO_NEGO_RESP 1
465 #define P2P_GO_NEGO_CONF 2
466 #define P2P_INVIT_REQ 3
467 #define P2P_INVIT_RESP 4
468 #define P2P_DEVDISC_REQ 5
469 #define P2P_DEVDISC_RESP 6
470 #define P2P_PROVISION_DISC_REQ 7
471 #define P2P_PROVISION_DISC_RESP 8
473 /* WPS Configuration Method */
474 #define WPS_CM_NONE 0x0000
475 #define WPS_CM_LABEL 0x0004
476 #define WPS_CM_DISPLYA 0x0008
477 #define WPS_CM_EXTERNAL_NFC_TOKEN 0x0010
478 #define WPS_CM_INTEGRATED_NFC_TOKEN 0x0020
479 #define WPS_CM_NFC_INTERFACE 0x0040
480 #define WPS_CM_PUSH_BUTTON 0x0080
481 #define WPS_CM_KEYPAD 0x0100
482 #define WPS_CM_SW_PUHS_BUTTON 0x0280
483 #define WPS_CM_HW_PUHS_BUTTON 0x0480
484 #define WPS_CM_SW_DISPLAY_PIN 0x2008
485 #define WPS_CM_LCD_DISPLAY_PIN 0x4008
487 #endif /* _WIFI_H_ */