WPS NFC: Send M2D with config error 20 on pkhash mismatch
[mech_eap.git] / src / wps / wps_defs.h
1 /*
2  * Wi-Fi Protected Setup - message definitions
3  * Copyright (c) 2008, Jouni Malinen <j@w1.fi>
4  *
5  * This software may be distributed under the terms of the BSD license.
6  * See README for more details.
7  */
8
9 #ifndef WPS_DEFS_H
10 #define WPS_DEFS_H
11
12 #ifdef CONFIG_WPS_TESTING
13
14 extern int wps_version_number;
15 extern int wps_testing_dummy_cred;
16 #define WPS_VERSION wps_version_number
17
18 #else /* CONFIG_WPS_TESTING */
19
20 #ifdef CONFIG_WPS2
21 #define WPS_VERSION 0x20
22 #else /* CONFIG_WPS2 */
23 #define WPS_VERSION 0x10
24 #endif /* CONFIG_WPS2 */
25
26 #endif /* CONFIG_WPS_TESTING */
27
28 /* Diffie-Hellman 1536-bit MODP Group; RFC 3526, Group 5 */
29 #define WPS_DH_GROUP 5
30
31 #define WPS_UUID_LEN 16
32 #define WPS_NONCE_LEN 16
33 #define WPS_AUTHENTICATOR_LEN 8
34 #define WPS_AUTHKEY_LEN 32
35 #define WPS_KEYWRAPKEY_LEN 16
36 #define WPS_EMSK_LEN 32
37 #define WPS_PSK_LEN 16
38 #define WPS_SECRET_NONCE_LEN 16
39 #define WPS_HASH_LEN 32
40 #define WPS_KWA_LEN 8
41 #define WPS_MGMTAUTHKEY_LEN 32
42 #define WPS_MGMTENCKEY_LEN 16
43 #define WPS_MGMT_KEY_ID_LEN 16
44 #define WPS_OOB_DEVICE_PASSWORD_MIN_LEN 16
45 #define WPS_OOB_DEVICE_PASSWORD_LEN 32
46 #define WPS_OOB_PUBKEY_HASH_LEN 20
47
48 /* Attribute Types */
49 enum wps_attribute {
50         ATTR_AP_CHANNEL = 0x1001,
51         ATTR_ASSOC_STATE = 0x1002,
52         ATTR_AUTH_TYPE = 0x1003,
53         ATTR_AUTH_TYPE_FLAGS = 0x1004,
54         ATTR_AUTHENTICATOR = 0x1005,
55         ATTR_CONFIG_METHODS = 0x1008,
56         ATTR_CONFIG_ERROR = 0x1009,
57         ATTR_CONFIRM_URL4 = 0x100a,
58         ATTR_CONFIRM_URL6 = 0x100b,
59         ATTR_CONN_TYPE = 0x100c,
60         ATTR_CONN_TYPE_FLAGS = 0x100d,
61         ATTR_CRED = 0x100e,
62         ATTR_ENCR_TYPE = 0x100f,
63         ATTR_ENCR_TYPE_FLAGS = 0x1010,
64         ATTR_DEV_NAME = 0x1011,
65         ATTR_DEV_PASSWORD_ID = 0x1012,
66         ATTR_E_HASH1 = 0x1014,
67         ATTR_E_HASH2 = 0x1015,
68         ATTR_E_SNONCE1 = 0x1016,
69         ATTR_E_SNONCE2 = 0x1017,
70         ATTR_ENCR_SETTINGS = 0x1018,
71         ATTR_ENROLLEE_NONCE = 0x101a,
72         ATTR_FEATURE_ID = 0x101b,
73         ATTR_IDENTITY = 0x101c,
74         ATTR_IDENTITY_PROOF = 0x101d,
75         ATTR_KEY_WRAP_AUTH = 0x101e,
76         ATTR_KEY_ID = 0x101f,
77         ATTR_MAC_ADDR = 0x1020,
78         ATTR_MANUFACTURER = 0x1021,
79         ATTR_MSG_TYPE = 0x1022,
80         ATTR_MODEL_NAME = 0x1023,
81         ATTR_MODEL_NUMBER = 0x1024,
82         ATTR_NETWORK_INDEX = 0x1026,
83         ATTR_NETWORK_KEY = 0x1027,
84         ATTR_NETWORK_KEY_INDEX = 0x1028,
85         ATTR_NEW_DEVICE_NAME = 0x1029,
86         ATTR_NEW_PASSWORD = 0x102a,
87         ATTR_OOB_DEVICE_PASSWORD = 0x102c,
88         ATTR_OS_VERSION = 0x102d,
89         ATTR_POWER_LEVEL = 0x102f,
90         ATTR_PSK_CURRENT = 0x1030,
91         ATTR_PSK_MAX = 0x1031,
92         ATTR_PUBLIC_KEY = 0x1032,
93         ATTR_RADIO_ENABLE = 0x1033,
94         ATTR_REBOOT = 0x1034,
95         ATTR_REGISTRAR_CURRENT = 0x1035,
96         ATTR_REGISTRAR_ESTABLISHED = 0x1036,
97         ATTR_REGISTRAR_LIST = 0x1037,
98         ATTR_REGISTRAR_MAX = 0x1038,
99         ATTR_REGISTRAR_NONCE = 0x1039,
100         ATTR_REQUEST_TYPE = 0x103a,
101         ATTR_RESPONSE_TYPE = 0x103b,
102         ATTR_RF_BANDS = 0x103c,
103         ATTR_R_HASH1 = 0x103d,
104         ATTR_R_HASH2 = 0x103e,
105         ATTR_R_SNONCE1 = 0x103f,
106         ATTR_R_SNONCE2 = 0x1040,
107         ATTR_SELECTED_REGISTRAR = 0x1041,
108         ATTR_SERIAL_NUMBER = 0x1042,
109         ATTR_WPS_STATE = 0x1044,
110         ATTR_SSID = 0x1045,
111         ATTR_TOTAL_NETWORKS = 0x1046,
112         ATTR_UUID_E = 0x1047,
113         ATTR_UUID_R = 0x1048,
114         ATTR_VENDOR_EXT = 0x1049,
115         ATTR_VERSION = 0x104a,
116         ATTR_X509_CERT_REQ = 0x104b,
117         ATTR_X509_CERT = 0x104c,
118         ATTR_EAP_IDENTITY = 0x104d,
119         ATTR_MSG_COUNTER = 0x104e,
120         ATTR_PUBKEY_HASH = 0x104f,
121         ATTR_REKEY_KEY = 0x1050,
122         ATTR_KEY_LIFETIME = 0x1051,
123         ATTR_PERMITTED_CFG_METHODS = 0x1052,
124         ATTR_SELECTED_REGISTRAR_CONFIG_METHODS = 0x1053,
125         ATTR_PRIMARY_DEV_TYPE = 0x1054,
126         ATTR_SECONDARY_DEV_TYPE_LIST = 0x1055,
127         ATTR_PORTABLE_DEV = 0x1056,
128         ATTR_AP_SETUP_LOCKED = 0x1057,
129         ATTR_APPLICATION_EXT = 0x1058,
130         ATTR_EAP_TYPE = 0x1059,
131         ATTR_IV = 0x1060,
132         ATTR_KEY_PROVIDED_AUTO = 0x1061,
133         ATTR_802_1X_ENABLED = 0x1062,
134         ATTR_APPSESSIONKEY = 0x1063,
135         ATTR_WEPTRANSMITKEY = 0x1064,
136         ATTR_REQUESTED_DEV_TYPE = 0x106a,
137         ATTR_EXTENSIBILITY_TEST = 0x10fa /* _NOT_ defined in the spec */
138 };
139
140 #define WPS_VENDOR_ID_WFA 14122
141
142 /* WFA Vendor Extension subelements */
143 enum {
144         WFA_ELEM_VERSION2 = 0x00,
145         WFA_ELEM_AUTHORIZEDMACS = 0x01,
146         WFA_ELEM_NETWORK_KEY_SHAREABLE = 0x02,
147         WFA_ELEM_REQUEST_TO_ENROLL = 0x03,
148         WFA_ELEM_SETTINGS_DELAY_TIME = 0x04
149 };
150
151 /* Device Password ID */
152 enum wps_dev_password_id {
153         DEV_PW_DEFAULT = 0x0000,
154         DEV_PW_USER_SPECIFIED = 0x0001,
155         DEV_PW_MACHINE_SPECIFIED = 0x0002,
156         DEV_PW_REKEY = 0x0003,
157         DEV_PW_PUSHBUTTON = 0x0004,
158         DEV_PW_REGISTRAR_SPECIFIED = 0x0005
159 };
160
161 /* Message Type */
162 enum wps_msg_type {
163         WPS_Beacon = 0x01,
164         WPS_ProbeRequest = 0x02,
165         WPS_ProbeResponse = 0x03,
166         WPS_M1 = 0x04,
167         WPS_M2 = 0x05,
168         WPS_M2D = 0x06,
169         WPS_M3 = 0x07,
170         WPS_M4 = 0x08,
171         WPS_M5 = 0x09,
172         WPS_M6 = 0x0a,
173         WPS_M7 = 0x0b,
174         WPS_M8 = 0x0c,
175         WPS_WSC_ACK = 0x0d,
176         WPS_WSC_NACK = 0x0e,
177         WPS_WSC_DONE = 0x0f
178 };
179
180 /* Authentication Type Flags */
181 #define WPS_AUTH_OPEN 0x0001
182 #define WPS_AUTH_WPAPSK 0x0002
183 #define WPS_AUTH_SHARED 0x0004
184 #define WPS_AUTH_WPA 0x0008
185 #define WPS_AUTH_WPA2 0x0010
186 #define WPS_AUTH_WPA2PSK 0x0020
187 #define WPS_AUTH_TYPES (WPS_AUTH_OPEN | WPS_AUTH_WPAPSK | WPS_AUTH_SHARED | \
188                         WPS_AUTH_WPA | WPS_AUTH_WPA2 | WPS_AUTH_WPA2PSK)
189
190 /* Encryption Type Flags */
191 #define WPS_ENCR_NONE 0x0001
192 #define WPS_ENCR_WEP 0x0002
193 #define WPS_ENCR_TKIP 0x0004
194 #define WPS_ENCR_AES 0x0008
195 #define WPS_ENCR_TYPES (WPS_ENCR_NONE | WPS_ENCR_WEP | WPS_ENCR_TKIP | \
196                         WPS_ENCR_AES)
197
198 /* Configuration Error */
199 enum wps_config_error {
200         WPS_CFG_NO_ERROR = 0,
201         WPS_CFG_OOB_IFACE_READ_ERROR = 1,
202         WPS_CFG_DECRYPTION_CRC_FAILURE = 2,
203         WPS_CFG_24_CHAN_NOT_SUPPORTED = 3,
204         WPS_CFG_50_CHAN_NOT_SUPPORTED = 4,
205         WPS_CFG_SIGNAL_TOO_WEAK = 5,
206         WPS_CFG_NETWORK_AUTH_FAILURE = 6,
207         WPS_CFG_NETWORK_ASSOC_FAILURE = 7,
208         WPS_CFG_NO_DHCP_RESPONSE = 8,
209         WPS_CFG_FAILED_DHCP_CONFIG = 9,
210         WPS_CFG_IP_ADDR_CONFLICT = 10,
211         WPS_CFG_NO_CONN_TO_REGISTRAR = 11,
212         WPS_CFG_MULTIPLE_PBC_DETECTED = 12,
213         WPS_CFG_ROGUE_SUSPECTED = 13,
214         WPS_CFG_DEVICE_BUSY = 14,
215         WPS_CFG_SETUP_LOCKED = 15,
216         WPS_CFG_MSG_TIMEOUT = 16,
217         WPS_CFG_REG_SESS_TIMEOUT = 17,
218         WPS_CFG_DEV_PASSWORD_AUTH_FAILURE = 18,
219         WPS_CFG_60G_CHAN_NOT_SUPPORTED = 19,
220         WPS_CFG_PUBLIC_KEY_HASH_MISMATCH = 20
221 };
222
223 /* Vendor specific Error Indication for WPS event messages */
224 enum wps_error_indication {
225         WPS_EI_NO_ERROR,
226         WPS_EI_SECURITY_TKIP_ONLY_PROHIBITED,
227         WPS_EI_SECURITY_WEP_PROHIBITED,
228         WPS_EI_AUTH_FAILURE,
229         NUM_WPS_EI_VALUES
230 };
231
232 /* RF Bands */
233 #define WPS_RF_24GHZ 0x01
234 #define WPS_RF_50GHZ 0x02
235
236 /* Config Methods */
237 #define WPS_CONFIG_USBA 0x0001
238 #define WPS_CONFIG_ETHERNET 0x0002
239 #define WPS_CONFIG_LABEL 0x0004
240 #define WPS_CONFIG_DISPLAY 0x0008
241 #define WPS_CONFIG_EXT_NFC_TOKEN 0x0010
242 #define WPS_CONFIG_INT_NFC_TOKEN 0x0020
243 #define WPS_CONFIG_NFC_INTERFACE 0x0040
244 #define WPS_CONFIG_PUSHBUTTON 0x0080
245 #define WPS_CONFIG_KEYPAD 0x0100
246 #ifdef CONFIG_WPS2
247 #define WPS_CONFIG_VIRT_PUSHBUTTON 0x0280
248 #define WPS_CONFIG_PHY_PUSHBUTTON 0x0480
249 #define WPS_CONFIG_VIRT_DISPLAY 0x2008
250 #define WPS_CONFIG_PHY_DISPLAY 0x4008
251 #endif /* CONFIG_WPS2 */
252
253 /* Connection Type Flags */
254 #define WPS_CONN_ESS 0x01
255 #define WPS_CONN_IBSS 0x02
256
257 /* Wi-Fi Protected Setup State */
258 enum wps_state {
259         WPS_STATE_NOT_CONFIGURED = 1,
260         WPS_STATE_CONFIGURED = 2
261 };
262
263 /* Association State */
264 enum wps_assoc_state {
265         WPS_ASSOC_NOT_ASSOC = 0,
266         WPS_ASSOC_CONN_SUCCESS = 1,
267         WPS_ASSOC_CFG_FAILURE = 2,
268         WPS_ASSOC_FAILURE = 3,
269         WPS_ASSOC_IP_FAILURE = 4
270 };
271
272
273 #define WPS_DEV_OUI_WFA 0x0050f204
274
275 enum wps_dev_categ {
276         WPS_DEV_COMPUTER = 1,
277         WPS_DEV_INPUT = 2,
278         WPS_DEV_PRINTER = 3,
279         WPS_DEV_CAMERA = 4,
280         WPS_DEV_STORAGE = 5,
281         WPS_DEV_NETWORK_INFRA = 6,
282         WPS_DEV_DISPLAY = 7,
283         WPS_DEV_MULTIMEDIA = 8,
284         WPS_DEV_GAMING = 9,
285         WPS_DEV_PHONE = 10
286 };
287
288 enum wps_dev_subcateg {
289         WPS_DEV_COMPUTER_PC = 1,
290         WPS_DEV_COMPUTER_SERVER = 2,
291         WPS_DEV_COMPUTER_MEDIA_CENTER = 3,
292         WPS_DEV_PRINTER_PRINTER = 1,
293         WPS_DEV_PRINTER_SCANNER = 2,
294         WPS_DEV_CAMERA_DIGITAL_STILL_CAMERA = 1,
295         WPS_DEV_STORAGE_NAS = 1,
296         WPS_DEV_NETWORK_INFRA_AP = 1,
297         WPS_DEV_NETWORK_INFRA_ROUTER = 2,
298         WPS_DEV_NETWORK_INFRA_SWITCH = 3,
299         WPS_DEV_DISPLAY_TV = 1,
300         WPS_DEV_DISPLAY_PICTURE_FRAME = 2,
301         WPS_DEV_DISPLAY_PROJECTOR = 3,
302         WPS_DEV_MULTIMEDIA_DAR = 1,
303         WPS_DEV_MULTIMEDIA_PVR = 2,
304         WPS_DEV_MULTIMEDIA_MCX = 3,
305         WPS_DEV_GAMING_XBOX = 1,
306         WPS_DEV_GAMING_XBOX360 = 2,
307         WPS_DEV_GAMING_PLAYSTATION = 3,
308         WPS_DEV_PHONE_WINDOWS_MOBILE = 1
309 };
310
311
312 /* Request Type */
313 enum wps_request_type {
314         WPS_REQ_ENROLLEE_INFO = 0,
315         WPS_REQ_ENROLLEE = 1,
316         WPS_REQ_REGISTRAR = 2,
317         WPS_REQ_WLAN_MANAGER_REGISTRAR = 3
318 };
319
320 /* Response Type */
321 enum wps_response_type {
322         WPS_RESP_ENROLLEE_INFO = 0,
323         WPS_RESP_ENROLLEE = 1,
324         WPS_RESP_REGISTRAR = 2,
325         WPS_RESP_AP = 3
326 };
327
328 /* Walk Time for push button configuration (in seconds) */
329 #define WPS_PBC_WALK_TIME 120
330
331 #define WPS_MAX_AUTHORIZED_MACS 5
332
333 #endif /* WPS_DEFS_H */