]> git.karo-electronics.de Git - karo-tx-linux.git/blob - drivers/staging/rtl8723au/include/wifi.h
staging: rtl8723au: Remove to_fr_ds packet attribute
[karo-tx-linux.git] / drivers / staging / rtl8723au / include / wifi.h
1 /******************************************************************************
2  *
3  * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
4  *
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.
8  *
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
12  * more details.
13  *
14  ******************************************************************************/
15 #ifndef _WIFI_H_
16 #define _WIFI_H_
17
18 #define P80211CAPTURE_VERSION   0x80211001
19
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.
23  */
24 #define WiFiNavUpperUs          30000   /*  30 ms */
25
26 enum WIFI_FRAME_TYPE {
27         WIFI_MGT_TYPE  =        (0),
28         WIFI_CTRL_TYPE =        (BIT(2)),
29         WIFI_DATA_TYPE =        (BIT(3)),
30         WIFI_QOS_DATA_TYPE      = (BIT(7)|BIT(3)),      /*  QoS Data */
31 };
32
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),
47
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),
55
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),
66 };
67
68
69 enum WIFI_REG_DOMAIN {
70         DOMAIN_FCC              = 1,
71         DOMAIN_IC               = 2,
72         DOMAIN_ETSI             = 3,
73         DOMAIN_SPAIN            = 4,
74         DOMAIN_FRANCE           = 5,
75         DOMAIN_MKK              = 6,
76         DOMAIN_ISRAEL           = 7,
77         DOMAIN_MKK1             = 8,
78         DOMAIN_MKK2             = 9,
79         DOMAIN_MKK3             = 10,
80         DOMAIN_MAX
81 };
82
83
84 #define SetToDs(pbuf)   \
85         (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_TODS))
86
87 #define SetFrDs(pbuf)   \
88         (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_FROMDS))
89
90 #define SetMFrag(pbuf)  \
91         (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_MOREFRAGS))
92
93 #define ClearMFrag(pbuf)        \
94         (*(__le16 *)(pbuf) &= (~cpu_to_le16(IEEE80211_FCTL_MOREFRAGS)))
95
96 #define SetRetry(pbuf)  \
97         (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_RETRY))
98
99 #define SetPwrMgt(pbuf) \
100         (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_PM))
101
102 #define SetMData(pbuf)  \
103         (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_MOREDATA))
104
105 #define SetPrivacy(pbuf)        \
106         (*(__le16 *)(pbuf) |= cpu_to_le16(IEEE80211_FCTL_PROTECTED))
107
108 #define SetFrameType(pbuf, type)        \
109         do {    \
110                 *(__le16 *)(pbuf) &= __constant_cpu_to_le16(~(BIT(3) | BIT(2))); \
111                 *(__le16 *)(pbuf) |= __constant_cpu_to_le16(type); \
112         } while (0)
113
114 #define SetFrameSubType(pbuf, type) \
115         do {    \
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); \
118         } while (0)
119
120 #define GetTupleCache(pbuf)     (cpu_to_le16(*(unsigned short *)((unsigned long)(pbuf) + 22)))
121
122 #define SetFragNum(pbuf, num) \
123         do {    \
124                 *(unsigned short *)((unsigned long)(pbuf) + 22) = \
125                         ((*(unsigned short *)((unsigned long)(pbuf) + 22)) & le16_to_cpu(~(0x000f))) | \
126                         cpu_to_le16(0x0f & (num));     \
127         } while (0)
128
129 #define SetSeqNum(pbuf, num) \
130         do {    \
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))); \
134         } while (0)
135
136 #define SetDuration(pbuf, dur) \
137         (*(__le16 *)((unsigned long)(pbuf) + 2) =               \
138          cpu_to_le16(0xffff & (dur)))
139
140 #define SetPriority(pbuf, tid)  \
141         (*(__le16 *)(pbuf) |= cpu_to_le16(tid & 0xf))
142
143 #define SetEOSP(pbuf, eosp)     \
144         (*(__le16 *)(pbuf) |= cpu_to_le16((eosp & 1) << 4))
145
146 #define SetAckpolicy(pbuf, ack) \
147         (*(__le16 *)(pbuf) |= cpu_to_le16((ack & 3) << 5))
148
149 #define SetAMsdu(pbuf, amsdu)   \
150         (*(__le16 *)(pbuf) |= cpu_to_le16((amsdu & 1) << 7))
151
152 #define GetAid(pbuf)                                                    \
153         (cpu_to_le16(*(unsigned short *)((unsigned long)(pbuf) + 2)) &  \
154          0x3fff)
155
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)
160
161 static inline unsigned char *get_hdr_bssid(unsigned char *pframe)
162 {
163         unsigned char   *sa;
164         unsigned int    to_fr_ds;
165         struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) pframe;
166
167         to_fr_ds = (ieee80211_has_tods(hdr->frame_control) << 1) |
168                     ieee80211_has_fromds(hdr->frame_control);
169
170         switch (to_fr_ds) {
171         case 0x00:      /*  ToDs=0, FromDs=0 */
172                 sa = hdr->addr3;
173                 break;
174         case 0x01:      /*  ToDs=0, FromDs=1 */
175                 sa = hdr->addr2;
176                 break;
177         case 0x02:      /*  ToDs=1, FromDs=0 */
178                 sa = hdr->addr1;
179                 break;
180         case 0x03:      /*  ToDs=1, FromDs=1 */
181                 sa = hdr->addr1;
182                 break;
183         default:
184                 sa = NULL; /*  */
185                 break;
186         }
187         return sa;
188 }
189
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
200
201 #define _SIFSTIME_                                      \
202         ((priv->pmib->dot11BssType.net_work_type & WIRELESS_11A) ? 16 : 10)
203 #define _ACKCTSLNG_                     14      /* 14 bytes long, including crclng */
204 #define _CRCLNG_                        4
205
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
216
217 #define _FIXED_IE_LENGTH_               _BEACON_IE_OFFSET_
218
219
220 #define EID_BSSIntolerantChlReport      73
221
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
231 #define _ASOC_ID_               2
232 #define _STATUS_CODE_           2
233 #define _TIMESTAMP_             8
234
235 #define AUTH_ODD_TO             0
236 #define AUTH_EVEN_TO            1
237
238 #define WLAN_ETHCONV_ENCAP      1
239 #define WLAN_ETHCONV_RFC1042    2
240 #define WLAN_ETHCONV_8021h      3
241
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)
253
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 */
259
260 /*
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
268 */
269
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
275
276
277 /*-----------------------------------------------------------------------------
278                                 Below is the definition for 802.11n
279 ------------------------------------------------------------------------------*/
280
281 #define SetOrderBit(pbuf)                                               \
282         (*(unsigned short *)(pbuf) |= cpu_to_le16(_ORDER_))
283
284 #define GetOrderBit(pbuf)               \
285         (((*(unsigned short *)(pbuf)) & le16_to_cpu(_ORDER_)) != 0)
286
287
288 /* struct rtw_ieee80211_ht_cap - HT additional information
289  *
290  * This structure refers to "HT information element" as
291  * described in 802.11n draft section 7.3.2.53
292  */
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];
299 } __packed;
300
301 struct HT_caps_element {
302         union {
303                 struct {
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;
310                 } HT_cap_element;
311                 unsigned char HT_cap[26];
312         } u;
313 } __packed;
314
315 struct HT_info_element {
316         unsigned char   primary_channel;
317         unsigned char   infos[5];
318         unsigned char   MCS_rate[16];
319 }  __packed;
320
321 struct AC_param {
322         unsigned char           ACI_AIFSN;
323         unsigned char           CW;
324         unsigned short  TXOP_limit;
325 }  __packed;
326
327 struct WMM_para_element {
328         unsigned char           QoS_info;
329         unsigned char           reserved;
330         struct AC_param ac_param[4];
331 }  __packed;
332
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;
338 }  __packed;
339
340
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
345
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))
353
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))
360
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))
367
368
369
370 /*      ===============WPS Section=============== */
371 /*      For WPSv1.0 */
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
393
394 /*      Value of WPS attribute "WPS_ATTR_DEVICE_NAME */
395 #define WPS_MAX_DEVICE_NAME_LEN                 32
396
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
402
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
408
409 /*      Value of WPS WiFi Simple Configuration State Attribute */
410 #define WPS_WSC_STATE_NOT_CONFIG                0x01
411 #define WPS_WSC_STATE_CONFIG                    0x02
412
413 /*      Value of WPS Version Attribute */
414 #define WPS_VERSION_1                           0x10
415
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
430
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
435
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
439
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
447
448 /*      Value of WPS RF Bands Attribute */
449 #define WPS_RF_BANDS_2_4_GHZ                    0x01
450 #define WPS_RF_BANDS_5_GHZ                      0x02
451
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
458
459 /*      P2P Public Action Frame ( Management Frame ) */
460 #define P2P_PUB_ACTION_ACTION                   0x09
461
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
472
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
486
487 #endif /*  _WIFI_H_ */