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