xref: /freebsd/contrib/wpa/src/drivers/driver_hostap.h (revision 4b72b91a7132df1f77bbae194e1071ac621f1edb)
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