Home | History | Annotate | Download | only in wps
      1 /*
      2  * Wi-Fi Protected Setup - message definitions
      3  * Copyright (c) 2008, Jouni Malinen <j (at) 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 };
    220 
    221 /* Vendor specific Error Indication for WPS event messages */
    222 enum wps_error_indication {
    223 	WPS_EI_NO_ERROR,
    224 	WPS_EI_SECURITY_TKIP_ONLY_PROHIBITED,
    225 	WPS_EI_SECURITY_WEP_PROHIBITED,
    226 	WPS_EI_AUTH_FAILURE,
    227 	NUM_WPS_EI_VALUES
    228 };
    229 
    230 /* RF Bands */
    231 #define WPS_RF_24GHZ 0x01
    232 #define WPS_RF_50GHZ 0x02
    233 
    234 /* Config Methods */
    235 #define WPS_CONFIG_USBA 0x0001
    236 #define WPS_CONFIG_ETHERNET 0x0002
    237 #define WPS_CONFIG_LABEL 0x0004
    238 #define WPS_CONFIG_DISPLAY 0x0008
    239 #define WPS_CONFIG_EXT_NFC_TOKEN 0x0010
    240 #define WPS_CONFIG_INT_NFC_TOKEN 0x0020
    241 #define WPS_CONFIG_NFC_INTERFACE 0x0040
    242 #define WPS_CONFIG_PUSHBUTTON 0x0080
    243 #define WPS_CONFIG_KEYPAD 0x0100
    244 #ifdef CONFIG_WPS2
    245 #define WPS_CONFIG_VIRT_PUSHBUTTON 0x0280
    246 #define WPS_CONFIG_PHY_PUSHBUTTON 0x0480
    247 #define WPS_CONFIG_VIRT_DISPLAY 0x2008
    248 #define WPS_CONFIG_PHY_DISPLAY 0x4008
    249 #endif /* CONFIG_WPS2 */
    250 
    251 /* Connection Type Flags */
    252 #define WPS_CONN_ESS 0x01
    253 #define WPS_CONN_IBSS 0x02
    254 
    255 /* Wi-Fi Protected Setup State */
    256 enum wps_state {
    257 	WPS_STATE_NOT_CONFIGURED = 1,
    258 	WPS_STATE_CONFIGURED = 2
    259 };
    260 
    261 /* Association State */
    262 enum wps_assoc_state {
    263 	WPS_ASSOC_NOT_ASSOC = 0,
    264 	WPS_ASSOC_CONN_SUCCESS = 1,
    265 	WPS_ASSOC_CFG_FAILURE = 2,
    266 	WPS_ASSOC_FAILURE = 3,
    267 	WPS_ASSOC_IP_FAILURE = 4
    268 };
    269 
    270 
    271 #define WPS_DEV_OUI_WFA 0x0050f204
    272 
    273 enum wps_dev_categ {
    274 	WPS_DEV_COMPUTER = 1,
    275 	WPS_DEV_INPUT = 2,
    276 	WPS_DEV_PRINTER = 3,
    277 	WPS_DEV_CAMERA = 4,
    278 	WPS_DEV_STORAGE = 5,
    279 	WPS_DEV_NETWORK_INFRA = 6,
    280 	WPS_DEV_DISPLAY = 7,
    281 	WPS_DEV_MULTIMEDIA = 8,
    282 	WPS_DEV_GAMING = 9,
    283 	WPS_DEV_PHONE = 10
    284 };
    285 
    286 enum wps_dev_subcateg {
    287 	WPS_DEV_COMPUTER_PC = 1,
    288 	WPS_DEV_COMPUTER_SERVER = 2,
    289 	WPS_DEV_COMPUTER_MEDIA_CENTER = 3,
    290 	WPS_DEV_PRINTER_PRINTER = 1,
    291 	WPS_DEV_PRINTER_SCANNER = 2,
    292 	WPS_DEV_CAMERA_DIGITAL_STILL_CAMERA = 1,
    293 	WPS_DEV_STORAGE_NAS = 1,
    294 	WPS_DEV_NETWORK_INFRA_AP = 1,
    295 	WPS_DEV_NETWORK_INFRA_ROUTER = 2,
    296 	WPS_DEV_NETWORK_INFRA_SWITCH = 3,
    297 	WPS_DEV_DISPLAY_TV = 1,
    298 	WPS_DEV_DISPLAY_PICTURE_FRAME = 2,
    299 	WPS_DEV_DISPLAY_PROJECTOR = 3,
    300 	WPS_DEV_MULTIMEDIA_DAR = 1,
    301 	WPS_DEV_MULTIMEDIA_PVR = 2,
    302 	WPS_DEV_MULTIMEDIA_MCX = 3,
    303 	WPS_DEV_GAMING_XBOX = 1,
    304 	WPS_DEV_GAMING_XBOX360 = 2,
    305 	WPS_DEV_GAMING_PLAYSTATION = 3,
    306 	WPS_DEV_PHONE_WINDOWS_MOBILE = 1
    307 };
    308 
    309 
    310 /* Request Type */
    311 enum wps_request_type {
    312 	WPS_REQ_ENROLLEE_INFO = 0,
    313 	WPS_REQ_ENROLLEE = 1,
    314 	WPS_REQ_REGISTRAR = 2,
    315 	WPS_REQ_WLAN_MANAGER_REGISTRAR = 3
    316 };
    317 
    318 /* Response Type */
    319 enum wps_response_type {
    320 	WPS_RESP_ENROLLEE_INFO = 0,
    321 	WPS_RESP_ENROLLEE = 1,
    322 	WPS_RESP_REGISTRAR = 2,
    323 	WPS_RESP_AP = 3
    324 };
    325 
    326 /* Walk Time for push button configuration (in seconds) */
    327 #define WPS_PBC_WALK_TIME 120
    328 
    329 #define WPS_MAX_AUTHORIZED_MACS 5
    330 
    331 #endif /* WPS_DEFS_H */
    332