1*c1d255d3SCy Schubert /* 2*c1d255d3SCy Schubert * Driver interaction with Linux Host AP driver 3*c1d255d3SCy Schubert * Copyright (c) 2002-2006, Jouni Malinen <j@w1.fi> 4*c1d255d3SCy Schubert * 5*c1d255d3SCy Schubert * This software may be distributed under the terms of the BSD license. 6*c1d255d3SCy Schubert * See README for more details. 7*c1d255d3SCy Schubert */ 8*c1d255d3SCy Schubert 9*c1d255d3SCy Schubert #ifndef HOSTAP_DRIVER_H 10*c1d255d3SCy Schubert #define HOSTAP_DRIVER_H 11*c1d255d3SCy Schubert 12*c1d255d3SCy Schubert /* netdevice private ioctls (used, e.g., with iwpriv from user space) */ 13*c1d255d3SCy Schubert 14*c1d255d3SCy Schubert /* New wireless extensions API - SET/GET convention (even ioctl numbers are 15*c1d255d3SCy Schubert * root only) 16*c1d255d3SCy Schubert */ 17*c1d255d3SCy Schubert #define PRISM2_IOCTL_PRISM2_PARAM (SIOCIWFIRSTPRIV + 0) 18*c1d255d3SCy Schubert #define PRISM2_IOCTL_GET_PRISM2_PARAM (SIOCIWFIRSTPRIV + 1) 19*c1d255d3SCy Schubert #define PRISM2_IOCTL_WRITEMIF (SIOCIWFIRSTPRIV + 2) 20*c1d255d3SCy Schubert #define PRISM2_IOCTL_READMIF (SIOCIWFIRSTPRIV + 3) 21*c1d255d3SCy Schubert #define PRISM2_IOCTL_MONITOR (SIOCIWFIRSTPRIV + 4) 22*c1d255d3SCy Schubert #define PRISM2_IOCTL_RESET (SIOCIWFIRSTPRIV + 6) 23*c1d255d3SCy Schubert #define PRISM2_IOCTL_INQUIRE (SIOCIWFIRSTPRIV + 8) 24*c1d255d3SCy Schubert #define PRISM2_IOCTL_WDS_ADD (SIOCIWFIRSTPRIV + 10) 25*c1d255d3SCy Schubert #define PRISM2_IOCTL_WDS_DEL (SIOCIWFIRSTPRIV + 12) 26*c1d255d3SCy Schubert #define PRISM2_IOCTL_SET_RID_WORD (SIOCIWFIRSTPRIV + 14) 27*c1d255d3SCy Schubert #define PRISM2_IOCTL_MACCMD (SIOCIWFIRSTPRIV + 16) 28*c1d255d3SCy Schubert #define PRISM2_IOCTL_ADDMAC (SIOCIWFIRSTPRIV + 18) 29*c1d255d3SCy Schubert #define PRISM2_IOCTL_DELMAC (SIOCIWFIRSTPRIV + 20) 30*c1d255d3SCy Schubert #define PRISM2_IOCTL_KICKMAC (SIOCIWFIRSTPRIV + 22) 31*c1d255d3SCy Schubert 32*c1d255d3SCy Schubert /* following are not in SIOCGIWPRIV list; check permission in the driver code 33*c1d255d3SCy Schubert */ 34*c1d255d3SCy Schubert #define PRISM2_IOCTL_DOWNLOAD (SIOCDEVPRIVATE + 13) 35*c1d255d3SCy Schubert #define PRISM2_IOCTL_HOSTAPD (SIOCDEVPRIVATE + 14) 36*c1d255d3SCy Schubert 37*c1d255d3SCy Schubert 38*c1d255d3SCy Schubert /* PRISM2_IOCTL_PRISM2_PARAM ioctl() subtypes: */ 39*c1d255d3SCy Schubert enum { 40*c1d255d3SCy Schubert /* PRISM2_PARAM_PTYPE = 1, */ /* REMOVED 2003-10-22 */ 41*c1d255d3SCy Schubert PRISM2_PARAM_TXRATECTRL = 2, 42*c1d255d3SCy Schubert PRISM2_PARAM_BEACON_INT = 3, 43*c1d255d3SCy Schubert PRISM2_PARAM_PSEUDO_IBSS = 4, 44*c1d255d3SCy Schubert PRISM2_PARAM_ALC = 5, 45*c1d255d3SCy Schubert /* PRISM2_PARAM_TXPOWER = 6, */ /* REMOVED 2003-10-22 */ 46*c1d255d3SCy Schubert PRISM2_PARAM_DUMP = 7, 47*c1d255d3SCy Schubert PRISM2_PARAM_OTHER_AP_POLICY = 8, 48*c1d255d3SCy Schubert PRISM2_PARAM_AP_MAX_INACTIVITY = 9, 49*c1d255d3SCy Schubert PRISM2_PARAM_AP_BRIDGE_PACKETS = 10, 50*c1d255d3SCy Schubert PRISM2_PARAM_DTIM_PERIOD = 11, 51*c1d255d3SCy Schubert PRISM2_PARAM_AP_NULLFUNC_ACK = 12, 52*c1d255d3SCy Schubert PRISM2_PARAM_MAX_WDS = 13, 53*c1d255d3SCy Schubert PRISM2_PARAM_AP_AUTOM_AP_WDS = 14, 54*c1d255d3SCy Schubert PRISM2_PARAM_AP_AUTH_ALGS = 15, 55*c1d255d3SCy Schubert PRISM2_PARAM_MONITOR_ALLOW_FCSERR = 16, 56*c1d255d3SCy Schubert PRISM2_PARAM_HOST_ENCRYPT = 17, 57*c1d255d3SCy Schubert PRISM2_PARAM_HOST_DECRYPT = 18, 58*c1d255d3SCy Schubert PRISM2_PARAM_HOST_ROAMING = 21, 59*c1d255d3SCy Schubert PRISM2_PARAM_BCRX_STA_KEY = 22, 60*c1d255d3SCy Schubert PRISM2_PARAM_IEEE_802_1X = 23, 61*c1d255d3SCy Schubert PRISM2_PARAM_ANTSEL_TX = 24, 62*c1d255d3SCy Schubert PRISM2_PARAM_ANTSEL_RX = 25, 63*c1d255d3SCy Schubert PRISM2_PARAM_MONITOR_TYPE = 26, 64*c1d255d3SCy Schubert PRISM2_PARAM_WDS_TYPE = 27, 65*c1d255d3SCy Schubert PRISM2_PARAM_HOSTSCAN = 28, 66*c1d255d3SCy Schubert PRISM2_PARAM_AP_SCAN = 29, 67*c1d255d3SCy Schubert PRISM2_PARAM_ENH_SEC = 30, 68*c1d255d3SCy Schubert PRISM2_PARAM_IO_DEBUG = 31, 69*c1d255d3SCy Schubert PRISM2_PARAM_BASIC_RATES = 32, 70*c1d255d3SCy Schubert PRISM2_PARAM_OPER_RATES = 33, 71*c1d255d3SCy Schubert PRISM2_PARAM_HOSTAPD = 34, 72*c1d255d3SCy Schubert PRISM2_PARAM_HOSTAPD_STA = 35, 73*c1d255d3SCy Schubert PRISM2_PARAM_WPA = 36, 74*c1d255d3SCy Schubert PRISM2_PARAM_PRIVACY_INVOKED = 37, 75*c1d255d3SCy Schubert PRISM2_PARAM_TKIP_COUNTERMEASURES = 38, 76*c1d255d3SCy Schubert PRISM2_PARAM_DROP_UNENCRYPTED = 39, 77*c1d255d3SCy Schubert PRISM2_PARAM_SCAN_CHANNEL_MASK = 40, 78*c1d255d3SCy Schubert }; 79*c1d255d3SCy Schubert 80*c1d255d3SCy Schubert enum { HOSTAP_ANTSEL_DO_NOT_TOUCH = 0, HOSTAP_ANTSEL_DIVERSITY = 1, 81*c1d255d3SCy Schubert HOSTAP_ANTSEL_LOW = 2, HOSTAP_ANTSEL_HIGH = 3 }; 82*c1d255d3SCy Schubert 83*c1d255d3SCy Schubert 84*c1d255d3SCy Schubert /* PRISM2_IOCTL_MACCMD ioctl() subcommands: */ 85*c1d255d3SCy Schubert enum { AP_MAC_CMD_POLICY_OPEN = 0, AP_MAC_CMD_POLICY_ALLOW = 1, 86*c1d255d3SCy Schubert AP_MAC_CMD_POLICY_DENY = 2, AP_MAC_CMD_FLUSH = 3, 87*c1d255d3SCy Schubert AP_MAC_CMD_KICKALL = 4 }; 88*c1d255d3SCy Schubert 89*c1d255d3SCy Schubert 90*c1d255d3SCy Schubert /* PRISM2_IOCTL_DOWNLOAD ioctl() dl_cmd: */ 91*c1d255d3SCy Schubert enum { 92*c1d255d3SCy Schubert PRISM2_DOWNLOAD_VOLATILE = 1 /* RAM */, 93*c1d255d3SCy Schubert /* Note! Old versions of prism2_srec have a fatal error in CRC-16 94*c1d255d3SCy Schubert * calculation, which will corrupt all non-volatile downloads. 95*c1d255d3SCy Schubert * PRISM2_DOWNLOAD_NON_VOLATILE used to be 2, but it is now 3 to 96*c1d255d3SCy Schubert * prevent use of old versions of prism2_srec for non-volatile 97*c1d255d3SCy Schubert * download. */ 98*c1d255d3SCy Schubert PRISM2_DOWNLOAD_NON_VOLATILE = 3 /* FLASH */, 99*c1d255d3SCy Schubert PRISM2_DOWNLOAD_VOLATILE_GENESIS = 4 /* RAM in Genesis mode */, 100*c1d255d3SCy Schubert /* Persistent versions of volatile download commands (keep firmware 101*c1d255d3SCy Schubert * data in memory and automatically re-download after hw_reset */ 102*c1d255d3SCy Schubert PRISM2_DOWNLOAD_VOLATILE_PERSISTENT = 5, 103*c1d255d3SCy Schubert PRISM2_DOWNLOAD_VOLATILE_GENESIS_PERSISTENT = 6, 104*c1d255d3SCy Schubert }; 105*c1d255d3SCy Schubert 106*c1d255d3SCy Schubert struct prism2_download_param { 107*c1d255d3SCy Schubert u32 dl_cmd; 108*c1d255d3SCy Schubert u32 start_addr; 109*c1d255d3SCy Schubert u32 num_areas; 110*c1d255d3SCy Schubert struct prism2_download_area { 111*c1d255d3SCy Schubert u32 addr; /* wlan card address */ 112*c1d255d3SCy Schubert u32 len; 113*c1d255d3SCy Schubert caddr_t ptr; /* pointer to data in user space */ 114*c1d255d3SCy Schubert } data[0]; 115*c1d255d3SCy Schubert }; 116*c1d255d3SCy Schubert 117*c1d255d3SCy Schubert #define PRISM2_MAX_DOWNLOAD_AREA_LEN 131072 118*c1d255d3SCy Schubert #define PRISM2_MAX_DOWNLOAD_LEN 262144 119*c1d255d3SCy Schubert 120*c1d255d3SCy Schubert 121*c1d255d3SCy Schubert /* PRISM2_IOCTL_HOSTAPD ioctl() cmd: */ 122*c1d255d3SCy Schubert enum { 123*c1d255d3SCy Schubert PRISM2_HOSTAPD_FLUSH = 1, 124*c1d255d3SCy Schubert PRISM2_HOSTAPD_ADD_STA = 2, 125*c1d255d3SCy Schubert PRISM2_HOSTAPD_REMOVE_STA = 3, 126*c1d255d3SCy Schubert PRISM2_HOSTAPD_GET_INFO_STA = 4, 127*c1d255d3SCy Schubert /* REMOVED: PRISM2_HOSTAPD_RESET_TXEXC_STA = 5, */ 128*c1d255d3SCy Schubert PRISM2_SET_ENCRYPTION = 6, 129*c1d255d3SCy Schubert PRISM2_GET_ENCRYPTION = 7, 130*c1d255d3SCy Schubert PRISM2_HOSTAPD_SET_FLAGS_STA = 8, 131*c1d255d3SCy Schubert PRISM2_HOSTAPD_GET_RID = 9, 132*c1d255d3SCy Schubert PRISM2_HOSTAPD_SET_RID = 10, 133*c1d255d3SCy Schubert PRISM2_HOSTAPD_SET_ASSOC_AP_ADDR = 11, 134*c1d255d3SCy Schubert PRISM2_HOSTAPD_SET_GENERIC_ELEMENT = 12, 135*c1d255d3SCy Schubert PRISM2_HOSTAPD_MLME = 13, 136*c1d255d3SCy Schubert PRISM2_HOSTAPD_SCAN_REQ = 14, 137*c1d255d3SCy Schubert PRISM2_HOSTAPD_STA_CLEAR_STATS = 15, 138*c1d255d3SCy Schubert }; 139*c1d255d3SCy Schubert 140*c1d255d3SCy Schubert #define PRISM2_HOSTAPD_MAX_BUF_SIZE 1024 141*c1d255d3SCy Schubert #define PRISM2_HOSTAPD_RID_HDR_LEN \ 142*c1d255d3SCy Schubert ((size_t) (&((struct prism2_hostapd_param *) 0)->u.rid.data)) 143*c1d255d3SCy Schubert #define PRISM2_HOSTAPD_GENERIC_ELEMENT_HDR_LEN \ 144*c1d255d3SCy Schubert ((size_t) (&((struct prism2_hostapd_param *) 0)->u.generic_elem.data)) 145*c1d255d3SCy Schubert 146*c1d255d3SCy Schubert /* Maximum length for algorithm names (-1 for nul termination) used in ioctl() 147*c1d255d3SCy Schubert */ 148*c1d255d3SCy Schubert #define HOSTAP_CRYPT_ALG_NAME_LEN 16 149*c1d255d3SCy Schubert 150*c1d255d3SCy Schubert 151*c1d255d3SCy Schubert struct prism2_hostapd_param { 152*c1d255d3SCy Schubert u32 cmd; 153*c1d255d3SCy Schubert u8 sta_addr[ETH_ALEN]; 154*c1d255d3SCy Schubert union { 155*c1d255d3SCy Schubert struct { 156*c1d255d3SCy Schubert u16 aid; 157*c1d255d3SCy Schubert u16 capability; 158*c1d255d3SCy Schubert u8 tx_supp_rates; 159*c1d255d3SCy Schubert } add_sta; 160*c1d255d3SCy Schubert struct { 161*c1d255d3SCy Schubert u32 inactive_sec; 162*c1d255d3SCy Schubert } get_info_sta; 163*c1d255d3SCy Schubert struct { 164*c1d255d3SCy Schubert u8 alg[HOSTAP_CRYPT_ALG_NAME_LEN]; 165*c1d255d3SCy Schubert u32 flags; 166*c1d255d3SCy Schubert u32 err; 167*c1d255d3SCy Schubert u8 idx; 168*c1d255d3SCy Schubert u8 seq[8]; /* sequence counter (set: RX, get: TX) */ 169*c1d255d3SCy Schubert u16 key_len; 170*c1d255d3SCy Schubert u8 key[0]; 171*c1d255d3SCy Schubert } crypt; 172*c1d255d3SCy Schubert struct { 173*c1d255d3SCy Schubert u32 flags_and; 174*c1d255d3SCy Schubert u32 flags_or; 175*c1d255d3SCy Schubert } set_flags_sta; 176*c1d255d3SCy Schubert struct { 177*c1d255d3SCy Schubert u16 rid; 178*c1d255d3SCy Schubert u16 len; 179*c1d255d3SCy Schubert u8 data[0]; 180*c1d255d3SCy Schubert } rid; 181*c1d255d3SCy Schubert struct { 182*c1d255d3SCy Schubert u8 len; 183*c1d255d3SCy Schubert u8 data[0]; 184*c1d255d3SCy Schubert } generic_elem; 185*c1d255d3SCy Schubert struct { 186*c1d255d3SCy Schubert #define MLME_STA_DEAUTH 0 187*c1d255d3SCy Schubert #define MLME_STA_DISASSOC 1 188*c1d255d3SCy Schubert u16 cmd; 189*c1d255d3SCy Schubert u16 reason_code; 190*c1d255d3SCy Schubert } mlme; 191*c1d255d3SCy Schubert struct { 192*c1d255d3SCy Schubert u8 ssid_len; 193*c1d255d3SCy Schubert u8 ssid[SSID_MAX_LEN]; 194*c1d255d3SCy Schubert } scan_req; 195*c1d255d3SCy Schubert } u; 196*c1d255d3SCy Schubert }; 197*c1d255d3SCy Schubert 198*c1d255d3SCy Schubert #define HOSTAP_CRYPT_FLAG_SET_TX_KEY BIT(0) 199*c1d255d3SCy Schubert #define HOSTAP_CRYPT_FLAG_PERMANENT BIT(1) 200*c1d255d3SCy Schubert 201*c1d255d3SCy Schubert #define HOSTAP_CRYPT_ERR_UNKNOWN_ALG 2 202*c1d255d3SCy Schubert #define HOSTAP_CRYPT_ERR_UNKNOWN_ADDR 3 203*c1d255d3SCy Schubert #define HOSTAP_CRYPT_ERR_CRYPT_INIT_FAILED 4 204*c1d255d3SCy Schubert #define HOSTAP_CRYPT_ERR_KEY_SET_FAILED 5 205*c1d255d3SCy Schubert #define HOSTAP_CRYPT_ERR_TX_KEY_SET_FAILED 6 206*c1d255d3SCy Schubert #define HOSTAP_CRYPT_ERR_CARD_CONF_FAILED 7 207*c1d255d3SCy Schubert 208*c1d255d3SCy Schubert #endif /* HOSTAP_DRIVER_H */ 209