xref: /haiku/src/libs/compat/freebsd_wlan/net80211/ieee80211_ioctl.h (revision 1a76488fc88584bf66b9751d7fb9b6527ac20d87)
1 /*-
2  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
3  *
4  * Copyright (c) 2001 Atsushi Onoe
5  * Copyright (c) 2002-2009 Sam Leffler, Errno Consulting
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  * 1. Redistributions of source code must retain the above copyright
12  *    notice, this list of conditions and the following disclaimer.
13  * 2. Redistributions in binary form must reproduce the above copyright
14  *    notice, this list of conditions and the following disclaimer in the
15  *    documentation and/or other materials provided with the distribution.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  *
28  * $FreeBSD: releng/12.0/sys/net80211/ieee80211_ioctl.h 326272 2017-11-27 15:23:17Z pfg $
29  */
30 #ifndef _NET80211_IEEE80211_IOCTL_H_
31 #define _NET80211_IEEE80211_IOCTL_H_
32 
33 #ifndef IEEE80211_IOCTLS_ABBREVIATED
34 /*
35  * IEEE 802.11 ioctls.
36  */
37 #include <net80211/_ieee80211.h>
38 #include <net80211/ieee80211.h>
39 #include <net80211/ieee80211_crypto.h>
40 
41 /*
42  * Per/node (station) statistics.
43  */
44 struct ieee80211_nodestats {
45 	uint32_t	ns_rx_data;		/* rx data frames */
46 	uint32_t	ns_rx_mgmt;		/* rx management frames */
47 	uint32_t	ns_rx_ctrl;		/* rx control frames */
48 	uint32_t	ns_rx_ucast;		/* rx unicast frames */
49 	uint32_t	ns_rx_mcast;		/* rx multi/broadcast frames */
50 	uint64_t	ns_rx_bytes;		/* rx data count (bytes) */
51 	uint64_t	ns_rx_beacons;		/* rx beacon frames */
52 	uint32_t	ns_rx_proberesp;	/* rx probe response frames */
53 
54 	uint32_t	ns_rx_dup;		/* rx discard 'cuz dup */
55 	uint32_t	ns_rx_noprivacy;	/* rx w/ wep but privacy off */
56 	uint32_t	ns_rx_wepfail;		/* rx wep processing failed */
57 	uint32_t	ns_rx_demicfail;	/* rx demic failed */
58 	uint32_t	ns_rx_decap;		/* rx decapsulation failed */
59 	uint32_t	ns_rx_defrag;		/* rx defragmentation failed */
60 	uint32_t	ns_rx_disassoc;		/* rx disassociation */
61 	uint32_t	ns_rx_deauth;		/* rx deauthentication */
62 	uint32_t	ns_rx_action;		/* rx action */
63 	uint32_t	ns_rx_decryptcrc;	/* rx decrypt failed on crc */
64 	uint32_t	ns_rx_unauth;		/* rx on unauthorized port */
65 	uint32_t	ns_rx_unencrypted;	/* rx unecrypted w/ privacy */
66 	uint32_t	ns_rx_drop;		/* rx discard other reason */
67 
68 	uint32_t	ns_tx_data;		/* tx data frames */
69 	uint32_t	ns_tx_mgmt;		/* tx management frames */
70 	uint32_t	ns_tx_ctrl;		/* tx control frames */
71 	uint32_t	ns_tx_ucast;		/* tx unicast frames */
72 	uint32_t	ns_tx_mcast;		/* tx multi/broadcast frames */
73 	uint64_t	ns_tx_bytes;		/* tx data count (bytes) */
74 	uint32_t	ns_tx_probereq;		/* tx probe request frames */
75 
76 	uint32_t	ns_tx_novlantag;	/* tx discard 'cuz no tag */
77 	uint32_t	ns_tx_vlanmismatch;	/* tx discard 'cuz bad tag */
78 
79 	uint32_t	ns_ps_discard;		/* ps discard 'cuz of age */
80 
81 	/* MIB-related state */
82 	uint32_t	ns_tx_assoc;		/* [re]associations */
83 	uint32_t	ns_tx_assoc_fail;	/* [re]association failures */
84 	uint32_t	ns_tx_auth;		/* [re]authentications */
85 	uint32_t	ns_tx_auth_fail;	/* [re]authentication failures*/
86 	uint32_t	ns_tx_deauth;		/* deauthentications */
87 	uint32_t	ns_tx_deauth_code;	/* last deauth reason */
88 	uint32_t	ns_tx_disassoc;		/* disassociations */
89 	uint32_t	ns_tx_disassoc_code;	/* last disassociation reason */
90 
91 	/* Hardware A-MSDU decode */
92 	uint32_t	ns_rx_amsdu_more;	/* RX decap A-MSDU, more coming from A-MSDU */
93 	uint32_t	ns_rx_amsdu_more_end;	/* RX decap A-MSDU (or any other frame), no more coming */
94 	uint32_t	ns_spare[6];
95 };
96 
97 /*
98  * Summary statistics.
99  */
100 struct ieee80211_stats {
101 	uint32_t	is_rx_badversion;	/* rx frame with bad version */
102 	uint32_t	is_rx_tooshort;		/* rx frame too short */
103 	uint32_t	is_rx_wrongbss;		/* rx from wrong bssid */
104 	uint32_t	is_rx_dup;		/* rx discard 'cuz dup */
105 	uint32_t	is_rx_wrongdir;		/* rx w/ wrong direction */
106 	uint32_t	is_rx_mcastecho;	/* rx discard 'cuz mcast echo */
107 	uint32_t	is_rx_notassoc;		/* rx discard 'cuz sta !assoc */
108 	uint32_t	is_rx_noprivacy;	/* rx w/ wep but privacy off */
109 	uint32_t	is_rx_unencrypted;	/* rx w/o wep and privacy on */
110 	uint32_t	is_rx_wepfail;		/* rx wep processing failed */
111 	uint32_t	is_rx_decap;		/* rx decapsulation failed */
112 	uint32_t	is_rx_mgtdiscard;	/* rx discard mgt frames */
113 	uint32_t	is_rx_ctl;		/* rx ctrl frames */
114 	uint32_t	is_rx_beacon;		/* rx beacon frames */
115 	uint32_t	is_rx_rstoobig;		/* rx rate set truncated */
116 	uint32_t	is_rx_elem_missing;	/* rx required element missing*/
117 	uint32_t	is_rx_elem_toobig;	/* rx element too big */
118 	uint32_t	is_rx_elem_toosmall;	/* rx element too small */
119 	uint32_t	is_rx_elem_unknown;	/* rx element unknown */
120 	uint32_t	is_rx_badchan;		/* rx frame w/ invalid chan */
121 	uint32_t	is_rx_chanmismatch;	/* rx frame chan mismatch */
122 	uint32_t	is_rx_nodealloc;	/* rx frame dropped */
123 	uint32_t	is_rx_ssidmismatch;	/* rx frame ssid mismatch  */
124 	uint32_t	is_rx_auth_unsupported;	/* rx w/ unsupported auth alg */
125 	uint32_t	is_rx_auth_fail;	/* rx sta auth failure */
126 	uint32_t	is_rx_auth_countermeasures;/* rx auth discard 'cuz CM */
127 	uint32_t	is_rx_assoc_bss;	/* rx assoc from wrong bssid */
128 	uint32_t	is_rx_assoc_notauth;	/* rx assoc w/o auth */
129 	uint32_t	is_rx_assoc_capmismatch;/* rx assoc w/ cap mismatch */
130 	uint32_t	is_rx_assoc_norate;	/* rx assoc w/ no rate match */
131 	uint32_t	is_rx_assoc_badwpaie;	/* rx assoc w/ bad WPA IE */
132 	uint32_t	is_rx_deauth;		/* rx deauthentication */
133 	uint32_t	is_rx_disassoc;		/* rx disassociation */
134 	uint32_t	is_rx_badsubtype;	/* rx frame w/ unknown subtype*/
135 	uint32_t	is_rx_nobuf;		/* rx failed for lack of buf */
136 	uint32_t	is_rx_decryptcrc;	/* rx decrypt failed on crc */
137 	uint32_t	is_rx_ahdemo_mgt;	/* rx discard ahdemo mgt frame*/
138 	uint32_t	is_rx_bad_auth;		/* rx bad auth request */
139 	uint32_t	is_rx_unauth;		/* rx on unauthorized port */
140 	uint32_t	is_rx_badkeyid;		/* rx w/ incorrect keyid */
141 	uint32_t	is_rx_ccmpreplay;	/* rx seq# violation (CCMP) */
142 	uint32_t	is_rx_ccmpformat;	/* rx format bad (CCMP) */
143 	uint32_t	is_rx_ccmpmic;		/* rx MIC check failed (CCMP) */
144 	uint32_t	is_rx_tkipreplay;	/* rx seq# violation (TKIP) */
145 	uint32_t	is_rx_tkipformat;	/* rx format bad (TKIP) */
146 	uint32_t	is_rx_tkipmic;		/* rx MIC check failed (TKIP) */
147 	uint32_t	is_rx_tkipicv;		/* rx ICV check failed (TKIP) */
148 	uint32_t	is_rx_badcipher;	/* rx failed 'cuz key type */
149 	uint32_t	is_rx_nocipherctx;	/* rx failed 'cuz key !setup */
150 	uint32_t	is_rx_acl;		/* rx discard 'cuz acl policy */
151 	uint32_t	is_tx_nobuf;		/* tx failed for lack of buf */
152 	uint32_t	is_tx_nonode;		/* tx failed for no node */
153 	uint32_t	is_tx_unknownmgt;	/* tx of unknown mgt frame */
154 	uint32_t	is_tx_badcipher;	/* tx failed 'cuz key type */
155 	uint32_t	is_tx_nodefkey;		/* tx failed 'cuz no defkey */
156 	uint32_t	is_tx_noheadroom;	/* tx failed 'cuz no space */
157 	uint32_t	is_tx_fragframes;	/* tx frames fragmented */
158 	uint32_t	is_tx_frags;		/* tx fragments created */
159 	uint32_t	is_scan_active;		/* active scans started */
160 	uint32_t	is_scan_passive;	/* passive scans started */
161 	uint32_t	is_node_timeout;	/* nodes timed out inactivity */
162 	uint32_t	is_crypto_nomem;	/* no memory for crypto ctx */
163 	uint32_t	is_crypto_tkip;		/* tkip crypto done in s/w */
164 	uint32_t	is_crypto_tkipenmic;	/* tkip en-MIC done in s/w */
165 	uint32_t	is_crypto_tkipdemic;	/* tkip de-MIC done in s/w */
166 	uint32_t	is_crypto_tkipcm;	/* tkip counter measures */
167 	uint32_t	is_crypto_ccmp;		/* ccmp crypto done in s/w */
168 	uint32_t	is_crypto_wep;		/* wep crypto done in s/w */
169 	uint32_t	is_crypto_setkey_cipher;/* cipher rejected key */
170 	uint32_t	is_crypto_setkey_nokey;	/* no key index for setkey */
171 	uint32_t	is_crypto_delkey;	/* driver key delete failed */
172 	uint32_t	is_crypto_badcipher;	/* unknown cipher */
173 	uint32_t	is_crypto_nocipher;	/* cipher not available */
174 	uint32_t	is_crypto_attachfail;	/* cipher attach failed */
175 	uint32_t	is_crypto_swfallback;	/* cipher fallback to s/w */
176 	uint32_t	is_crypto_keyfail;	/* driver key alloc failed */
177 	uint32_t	is_crypto_enmicfail;	/* en-MIC failed */
178 	uint32_t	is_ibss_capmismatch;	/* merge failed-cap mismatch */
179 	uint32_t	is_ibss_norate;		/* merge failed-rate mismatch */
180 	uint32_t	is_ps_unassoc;		/* ps-poll for unassoc. sta */
181 	uint32_t	is_ps_badaid;		/* ps-poll w/ incorrect aid */
182 	uint32_t	is_ps_qempty;		/* ps-poll w/ nothing to send */
183 	uint32_t	is_ff_badhdr;		/* fast frame rx'd w/ bad hdr */
184 	uint32_t	is_ff_tooshort;		/* fast frame rx decap error */
185 	uint32_t	is_ff_split;		/* fast frame rx split error */
186 	uint32_t	is_ff_decap;		/* fast frames decap'd */
187 	uint32_t	is_ff_encap;		/* fast frames encap'd for tx */
188 	uint32_t	is_rx_badbintval;	/* rx frame w/ bogus bintval */
189 	uint32_t	is_rx_demicfail;	/* rx demic failed */
190 	uint32_t	is_rx_defrag;		/* rx defragmentation failed */
191 	uint32_t	is_rx_mgmt;		/* rx management frames */
192 	uint32_t	is_rx_action;		/* rx action mgt frames */
193 	uint32_t	is_amsdu_tooshort;	/* A-MSDU rx decap error */
194 	uint32_t	is_amsdu_split;		/* A-MSDU rx split error */
195 	uint32_t	is_amsdu_decap;		/* A-MSDU decap'd */
196 	uint32_t	is_amsdu_encap;		/* A-MSDU encap'd for tx */
197 	uint32_t	is_ampdu_bar_bad;	/* A-MPDU BAR out of window */
198 	uint32_t	is_ampdu_bar_oow;	/* A-MPDU BAR before ADDBA */
199 	uint32_t	is_ampdu_bar_move;	/* A-MPDU BAR moved window */
200 	uint32_t	is_ampdu_bar_rx;	/* A-MPDU BAR frames handled */
201 	uint32_t	is_ampdu_rx_flush;	/* A-MPDU frames flushed */
202 	uint32_t	is_ampdu_rx_oor;	/* A-MPDU frames out-of-order */
203 	uint32_t	is_ampdu_rx_copy;	/* A-MPDU frames copied down */
204 	uint32_t	is_ampdu_rx_drop;	/* A-MPDU frames dropped */
205 	uint32_t	is_tx_badstate;		/* tx discard state != RUN */
206 	uint32_t	is_tx_notassoc;		/* tx failed, sta not assoc */
207 	uint32_t	is_tx_classify;		/* tx classification failed */
208 	uint32_t	is_dwds_mcast;		/* discard mcast over dwds */
209 	uint32_t	is_dwds_qdrop;		/* dwds pending frame q full */
210 	uint32_t	is_ht_assoc_nohtcap;	/* non-HT sta rejected */
211 	uint32_t	is_ht_assoc_downgrade;	/* HT sta forced to legacy */
212 	uint32_t	is_ht_assoc_norate;	/* HT assoc w/ rate mismatch */
213 	uint32_t	is_ampdu_rx_age;	/* A-MPDU sent up 'cuz of age */
214 	uint32_t	is_ampdu_rx_move;	/* A-MPDU MSDU moved window */
215 	uint32_t	is_addba_reject;	/* ADDBA reject 'cuz disabled */
216 	uint32_t	is_addba_norequest;	/* ADDBA response w/o ADDBA */
217 	uint32_t	is_addba_badtoken;	/* ADDBA response w/ wrong
218 						   dialogtoken */
219 	uint32_t	is_addba_badpolicy;	/* ADDBA resp w/ wrong policy */
220 	uint32_t	is_ampdu_stop;		/* A-MPDU stream stopped */
221 	uint32_t	is_ampdu_stop_failed;	/* A-MPDU stream not running */
222 	uint32_t	is_ampdu_rx_reorder;	/* A-MPDU held for rx reorder */
223 	uint32_t	is_scan_bg;		/* background scans started */
224 	uint8_t		is_rx_deauth_code;	/* last rx'd deauth reason */
225 	uint8_t		is_rx_disassoc_code;	/* last rx'd disassoc reason */
226 	uint8_t		is_rx_authfail_code;	/* last rx'd auth fail reason */
227 	uint32_t	is_beacon_miss;		/* beacon miss notification */
228 	uint32_t	is_rx_badstate;		/* rx discard state != RUN */
229 	uint32_t	is_ff_flush;		/* ff's flush'd from stageq */
230 	uint32_t	is_tx_ctl;		/* tx ctrl frames */
231 	uint32_t	is_ampdu_rexmt;		/* A-MPDU frames rexmt ok */
232 	uint32_t	is_ampdu_rexmt_fail;	/* A-MPDU frames rexmt fail */
233 
234 	uint32_t	is_mesh_wrongmesh;	/* dropped 'cuz not mesh sta*/
235 	uint32_t	is_mesh_nolink;		/* dropped 'cuz link not estab*/
236 	uint32_t	is_mesh_fwd_ttl;	/* mesh not fwd'd 'cuz ttl 0 */
237 	uint32_t	is_mesh_fwd_nobuf;	/* mesh not fwd'd 'cuz no mbuf*/
238 	uint32_t	is_mesh_fwd_tooshort;	/* mesh not fwd'd 'cuz no hdr */
239 	uint32_t	is_mesh_fwd_disabled;	/* mesh not fwd'd 'cuz disabled */
240 	uint32_t	is_mesh_fwd_nopath;	/* mesh not fwd'd 'cuz path unknown */
241 
242 	uint32_t	is_hwmp_wrongseq;	/* wrong hwmp seq no. */
243 	uint32_t	is_hwmp_rootreqs;	/* root PREQs sent */
244 	uint32_t	is_hwmp_rootrann;	/* root RANNs sent */
245 
246 	uint32_t	is_mesh_badae;		/* dropped 'cuz invalid AE */
247 	uint32_t	is_mesh_rtaddfailed;	/* route add failed */
248 	uint32_t	is_mesh_notproxy;	/* dropped 'cuz not proxying */
249 	uint32_t	is_rx_badalign;		/* dropped 'cuz misaligned */
250 	uint32_t	is_hwmp_proxy;		/* PREP for proxy route */
251 	uint32_t	is_beacon_bad;		/* Number of bad beacons */
252 	uint32_t	is_ampdu_bar_tx;	/* A-MPDU BAR frames TXed */
253 	uint32_t	is_ampdu_bar_tx_retry;	/* A-MPDU BAR frames TX rtry */
254 	uint32_t	is_ampdu_bar_tx_fail;	/* A-MPDU BAR frames TX fail */
255 
256 	uint32_t	is_ff_encapfail;	/* failed FF encap */
257 	uint32_t	is_amsdu_encapfail;	/* failed A-MSDU encap */
258 
259 	uint32_t	is_spare[5];
260 };
261 
262 /*
263  * Max size of optional information elements.  We artificially
264  * constrain this; it's limited only by the max frame size (and
265  * the max parameter size of the wireless extensions).
266  */
267 #define	IEEE80211_MAX_OPT_IE	256
268 
269 /*
270  * WPA/RSN get/set key request.  Specify the key/cipher
271  * type and whether the key is to be used for sending and/or
272  * receiving.  The key index should be set only when working
273  * with global keys (use IEEE80211_KEYIX_NONE for ``no index'').
274  * Otherwise a unicast/pairwise key is specified by the bssid
275  * (on a station) or mac address (on an ap).  They key length
276  * must include any MIC key data; otherwise it should be no
277  * more than IEEE80211_KEYBUF_SIZE.
278  */
279 struct ieee80211req_key {
280 	uint8_t		ik_type;	/* key/cipher type */
281 	uint8_t		ik_pad;
282 	uint16_t	ik_keyix;	/* key index */
283 	uint8_t		ik_keylen;	/* key length in bytes */
284 	uint8_t		ik_flags;
285 /* NB: IEEE80211_KEY_XMIT and IEEE80211_KEY_RECV defined elsewhere */
286 #define	IEEE80211_KEY_DEFAULT	0x80	/* default xmit key */
287 	uint8_t		ik_macaddr[IEEE80211_ADDR_LEN];
288 	uint64_t	ik_keyrsc;	/* key receive sequence counter */
289 	uint64_t	ik_keytsc;	/* key transmit sequence counter */
290 	uint8_t		ik_keydata[IEEE80211_KEYBUF_SIZE+IEEE80211_MICBUF_SIZE];
291 };
292 
293 /*
294  * Delete a key either by index or address.  Set the index
295  * to IEEE80211_KEYIX_NONE when deleting a unicast key.
296  */
297 struct ieee80211req_del_key {
298 	uint8_t		idk_keyix;	/* key index */
299 	uint8_t		idk_macaddr[IEEE80211_ADDR_LEN];
300 };
301 
302 #endif /* IEEE80211_IOCTLS_ABBREVIATED */
303 
304 /*
305  * MLME state manipulation request.  IEEE80211_MLME_ASSOC
306  * only makes sense when operating as a station.  The other
307  * requests can be used when operating as a station or an
308  * ap (to effect a station).
309  */
310 struct ieee80211req_mlme {
311 	uint8_t		im_op;		/* operation to perform */
312 #define	IEEE80211_MLME_ASSOC		1	/* associate station */
313 #define	IEEE80211_MLME_DISASSOC		2	/* disassociate station */
314 #define	IEEE80211_MLME_DEAUTH		3	/* deauthenticate station */
315 #define	IEEE80211_MLME_AUTHORIZE	4	/* authorize station */
316 #define	IEEE80211_MLME_UNAUTHORIZE	5	/* unauthorize station */
317 #define	IEEE80211_MLME_AUTH		6	/* authenticate station */
318 	uint8_t		im_ssid_len;	/* length of optional ssid */
319 	uint16_t	im_reason;	/* 802.11 reason code */
320 	uint8_t		im_macaddr[IEEE80211_ADDR_LEN];
321 	uint8_t		im_ssid[IEEE80211_NWID_LEN];
322 };
323 
324 #ifndef IEEE80211_IOCTLS_ABBREVIATED
325 
326 /*
327  * MAC ACL operations.
328  */
329 enum {
330 	IEEE80211_MACCMD_POLICY_OPEN	= 0,	/* set policy: no ACL's */
331 	IEEE80211_MACCMD_POLICY_ALLOW	= 1,	/* set policy: allow traffic */
332 	IEEE80211_MACCMD_POLICY_DENY	= 2,	/* set policy: deny traffic */
333 	IEEE80211_MACCMD_FLUSH		= 3,	/* flush ACL database */
334 	IEEE80211_MACCMD_DETACH		= 4,	/* detach ACL policy */
335 	IEEE80211_MACCMD_POLICY		= 5,	/* get ACL policy */
336 	IEEE80211_MACCMD_LIST		= 6,	/* get ACL database */
337 	IEEE80211_MACCMD_POLICY_RADIUS	= 7,	/* set policy: RADIUS managed */
338 };
339 
340 struct ieee80211req_maclist {
341 	uint8_t		ml_macaddr[IEEE80211_ADDR_LEN];
342 } __packed;
343 
344 /*
345  * Mesh Routing Table Operations.
346  */
347 enum {
348 	IEEE80211_MESH_RTCMD_LIST   = 0, /* list HWMP routing table */
349 	IEEE80211_MESH_RTCMD_FLUSH  = 1, /* flush HWMP routing table */
350 	IEEE80211_MESH_RTCMD_ADD    = 2, /* add entry to the table */
351 	IEEE80211_MESH_RTCMD_DELETE = 3, /* delete an entry from the table */
352 };
353 
354 struct ieee80211req_mesh_route {
355 	uint8_t		imr_flags;
356 #define	IEEE80211_MESHRT_FLAGS_DISCOVER	0x01
357 #define	IEEE80211_MESHRT_FLAGS_VALID	0x02
358 #define	IEEE80211_MESHRT_FLAGS_PROXY	0x04
359 #define	IEEE80211_MESHRT_FLAGS_GATE	0x08
360 	uint8_t		imr_dest[IEEE80211_ADDR_LEN];
361 	uint8_t		imr_nexthop[IEEE80211_ADDR_LEN];
362 	uint16_t	imr_nhops;
363 	uint8_t		imr_pad;
364 	uint32_t	imr_metric;
365 	uint32_t	imr_lifetime;
366 	uint32_t	imr_lastmseq;
367 };
368 
369 /*
370  * HWMP root modes
371  */
372 enum {
373 	IEEE80211_HWMP_ROOTMODE_DISABLED	= 0, 	/* disabled */
374 	IEEE80211_HWMP_ROOTMODE_NORMAL		= 1,	/* normal PREPs */
375 	IEEE80211_HWMP_ROOTMODE_PROACTIVE	= 2,	/* proactive PREPS */
376 	IEEE80211_HWMP_ROOTMODE_RANN		= 3,	/* use RANN elemid */
377 };
378 
379 /*
380  * Set the active channel list by IEEE channel #: each channel
381  * to be marked active is set in a bit vector.  Note this list is
382  * intersected with the available channel list in calculating
383  * the set of channels actually used in scanning.
384  */
385 struct ieee80211req_chanlist {
386 	uint8_t		ic_channels[32];	/* NB: can be variable length */
387 };
388 
389 /*
390  * Get the active channel list info.
391  */
392 struct ieee80211req_chaninfo {
393 	u_int	ic_nchans;
394 	struct ieee80211_channel ic_chans[1];	/* NB: variable length */
395 };
396 #define	IEEE80211_CHANINFO_SIZE(_nchan) \
397 	(sizeof(struct ieee80211req_chaninfo) + \
398 	 (((_nchan)-1) * sizeof(struct ieee80211_channel)))
399 #define	IEEE80211_CHANINFO_SPACE(_ci) \
400 	IEEE80211_CHANINFO_SIZE((_ci)->ic_nchans)
401 
402 /*
403  * Retrieve the WPA/RSN information element for an associated station.
404  */
405 struct ieee80211req_wpaie {	/* old version w/ only one ie */
406 	uint8_t		wpa_macaddr[IEEE80211_ADDR_LEN];
407 	uint8_t		wpa_ie[IEEE80211_MAX_OPT_IE];
408 };
409 struct ieee80211req_wpaie2 {
410 	uint8_t		wpa_macaddr[IEEE80211_ADDR_LEN];
411 	uint8_t		wpa_ie[IEEE80211_MAX_OPT_IE];
412 	uint8_t		rsn_ie[IEEE80211_MAX_OPT_IE];
413 };
414 
415 /*
416  * Retrieve per-node statistics.
417  */
418 struct ieee80211req_sta_stats {
419 	union {
420 		/* NB: explicitly force 64-bit alignment */
421 		uint8_t		macaddr[IEEE80211_ADDR_LEN];
422 		uint64_t	pad;
423 	} is_u;
424 	struct ieee80211_nodestats is_stats;
425 };
426 #endif
427 
428 /*
429  * Station information block; the mac address is used
430  * to retrieve other data like stats, unicast key, etc.
431  */
432 struct ieee80211req_sta_info {
433 	uint16_t	isi_len;		/* total length (mult of 4) */
434 	uint16_t	isi_ie_off;		/* offset to IE data */
435 	uint16_t	isi_ie_len;		/* IE length */
436 	uint16_t	isi_freq;		/* MHz */
437 	uint32_t	isi_flags;		/* channel flags */
438 	uint32_t	isi_state;		/* state flags */
439 	uint8_t		isi_authmode;		/* authentication algorithm */
440 	int8_t		isi_rssi;		/* receive signal strength */
441 	int8_t		isi_noise;		/* noise floor */
442 	uint8_t		isi_capinfo;		/* capabilities */
443 	uint8_t		isi_erp;		/* ERP element */
444 	uint8_t		isi_macaddr[IEEE80211_ADDR_LEN];
445 	uint8_t		isi_nrates;
446 						/* negotiated rates */
447 	uint8_t		isi_rates[IEEE80211_RATE_MAXSIZE];
448 	uint8_t		isi_txrate;		/* legacy/IEEE rate or MCS */
449 	uint16_t	isi_associd;		/* assoc response */
450 	uint16_t	isi_txpower;		/* current tx power */
451 	uint16_t	isi_vlan;		/* vlan tag */
452 #ifndef IEEE80211_IOCTLS_ABBREVIATED
453 	/* NB: [IEEE80211_NONQOS_TID] holds seq#'s for non-QoS stations */
454 	uint16_t	isi_txseqs[IEEE80211_TID_SIZE];/* tx seq #/TID */
455 	uint16_t	isi_rxseqs[IEEE80211_TID_SIZE];/* rx seq#/TID */
456 	uint16_t	isi_inact;		/* inactivity timer */
457 	uint16_t	isi_txmbps;		/* current tx rate in .5 Mb/s */
458 	uint16_t	isi_pad;
459 	uint32_t	isi_jointime;		/* time of assoc/join */
460 	struct ieee80211_mimo_info isi_mimo;	/* MIMO info for 11n sta's */
461 	/* 11s info */
462 	uint16_t	isi_peerid;
463 	uint16_t	isi_localid;
464 	uint8_t		isi_peerstate;
465 	/* XXX frag state? */
466 #endif
467 	/* variable length IE data */
468 };
469 
470 /*
471  * Retrieve per-station information; to retrieve all
472  * specify a mac address of ff:ff:ff:ff:ff:ff.
473  */
474 struct ieee80211req_sta_req {
475 	union {
476 		/* NB: explicitly force 64-bit alignment */
477 		uint8_t		macaddr[IEEE80211_ADDR_LEN];
478 		uint64_t	pad;
479 	} is_u;
480 	struct ieee80211req_sta_info info[1];	/* variable length */
481 };
482 
483 /*
484  * Get/set per-station tx power cap.
485  */
486 struct ieee80211req_sta_txpow {
487 	uint8_t		it_macaddr[IEEE80211_ADDR_LEN];
488 	uint8_t		it_txpow;
489 };
490 
491 /*
492  * WME parameters manipulated with IEEE80211_IOC_WME_CWMIN
493  * through IEEE80211_IOC_WME_ACKPOLICY are set and return
494  * using i_val and i_len.  i_val holds the value itself.
495  * i_len specifies the AC and, as appropriate, then high bit
496  * specifies whether the operation is to be applied to the
497  * BSS or ourself.
498  */
499 #define	IEEE80211_WMEPARAM_SELF	0x0000		/* parameter applies to self */
500 #define	IEEE80211_WMEPARAM_BSS	0x8000		/* parameter applies to BSS */
501 #define	IEEE80211_WMEPARAM_VAL	0x7fff		/* parameter value */
502 
503 /*
504  * Application Information Elements can be appended to a variety
505  * of frames with the IEE80211_IOC_APPIE request.  This request
506  * piggybacks on a normal ieee80211req; the frame type is passed
507  * in i_val as the 802.11 FC0 bytes and the length of the IE data
508  * is passed in i_len.  The data is referenced in i_data.  If i_len
509  * is zero then any previously configured IE data is removed.  At
510  * most IEEE80211_MAX_APPIE data be appened.  Note that multiple
511  * IE's can be supplied; the data is treated opaquely.
512  */
513 #define	IEEE80211_MAX_APPIE	1024		/* max app IE data */
514 /*
515  * Hack: the WPA authenticator uses this mechanism to specify WPA
516  * ie's that are used instead of the ones normally constructed using
517  * the cipher state setup with separate ioctls.  This avoids issues
518  * like the authenticator ordering ie data differently than the
519  * net80211 layer and needing to keep separate state for WPA and RSN.
520  */
521 #define	IEEE80211_APPIE_WPA \
522 	(IEEE80211_FC0_TYPE_MGT | IEEE80211_FC0_SUBTYPE_BEACON | \
523 	 IEEE80211_FC0_SUBTYPE_PROBE_RESP)
524 
525 #ifndef IEEE80211_IOCTLS_ABBREVIATED
526 /*
527  * Station mode roaming parameters.  These are maintained
528  * per band/mode and control the roaming algorithm.
529  */
530 struct ieee80211_roamparams_req {
531 	struct ieee80211_roamparam params[IEEE80211_MODE_MAX];
532 };
533 
534 /*
535  * Transmit parameters.  These can be used to set fixed transmit
536  * rate for each operating mode when operating as client or on a
537  * per-client basis according to the capabilities of the client
538  * (e.g. an 11b client associated to an 11g ap) when operating as
539  * an ap.
540  *
541  * MCS are distinguished from legacy rates by or'ing in 0x80.
542  */
543 struct ieee80211_txparams_req {
544 	struct ieee80211_txparam params[IEEE80211_MODE_MAX];
545 };
546 
547 /*
548  * Set regulatory domain state with IEEE80211_IOC_REGDOMAIN.
549  * Note this is both the regulatory description and the channel
550  * list.  The get request for IEEE80211_IOC_REGDOMAIN returns
551  * only the regdomain info; the channel list is obtained
552  * separately with IEEE80211_IOC_CHANINFO.
553  */
554 struct ieee80211_regdomain_req {
555 	struct ieee80211_regdomain	rd;
556 	struct ieee80211req_chaninfo	chaninfo;
557 };
558 #define	IEEE80211_REGDOMAIN_SIZE(_nchan) \
559 	(sizeof(struct ieee80211_regdomain_req) + \
560 	 (((_nchan)-1) * sizeof(struct ieee80211_channel)))
561 #define	IEEE80211_REGDOMAIN_SPACE(_req) \
562 	IEEE80211_REGDOMAIN_SIZE((_req)->chaninfo.ic_nchans)
563 
564 /*
565  * Get driver capabilities.  Driver, hardware crypto, and
566  * HT/802.11n capabilities, and a table that describes what
567  * the radio can do.
568  */
569 struct ieee80211_devcaps_req {
570 	uint32_t	dc_drivercaps;		/* general driver caps */
571 	uint32_t	dc_cryptocaps;		/* hardware crypto support */
572 	uint32_t	dc_htcaps;		/* HT/802.11n support */
573 	uint32_t	dc_vhtcaps;		/* VHT/802.11ac capabilities */
574 	struct ieee80211req_chaninfo dc_chaninfo;
575 };
576 #define	IEEE80211_DEVCAPS_SIZE(_nchan) \
577 	(sizeof(struct ieee80211_devcaps_req) + \
578 	 (((_nchan)-1) * sizeof(struct ieee80211_channel)))
579 #define	IEEE80211_DEVCAPS_SPACE(_dc) \
580 	IEEE80211_DEVCAPS_SIZE((_dc)->dc_chaninfo.ic_nchans)
581 #endif
582 
583 struct ieee80211_chanswitch_req {
584 	struct ieee80211_channel csa_chan;	/* new channel */
585 	int		csa_mode;		/* CSA mode */
586 	int		csa_count;		/* beacon count to switch */
587 };
588 
589 /*
590  * Get/set per-station vlan tag.
591  */
592 struct ieee80211req_sta_vlan {
593 	uint8_t		sv_macaddr[IEEE80211_ADDR_LEN];
594 	uint16_t	sv_vlan;
595 };
596 
597 #if defined(__FreeBSD__) || defined(__HAIKU__)
598 /*
599  * FreeBSD-style ioctls.
600  */
601 /* the first member must be matched with struct ifreq */
602 struct ieee80211req {
603 	char		i_name[IFNAMSIZ];	/* if_name, e.g. "wi0" */
604 	uint16_t	i_type;			/* req type */
605 	int16_t		i_val;			/* Index or simple value */
606 	uint16_t	i_len;			/* Index or simple value */
607 	void		*i_data;		/* Extra data */
608 };
609 #define	SIOCS80211		 _IOW('i', 234, struct ieee80211req)
610 #define	SIOCG80211		_IOWR('i', 235, struct ieee80211req)
611 #define	SIOCG80211STATS		_IOWR('i', 236, struct ifreq)
612 
613 #define IEEE80211_IOC_SSID		1
614 #define IEEE80211_IOC_NUMSSIDS		2
615 #define IEEE80211_IOC_WEP		3
616 #define 	IEEE80211_WEP_NOSUP	-1
617 #define 	IEEE80211_WEP_OFF	0
618 #define 	IEEE80211_WEP_ON	1
619 #define 	IEEE80211_WEP_MIXED	2
620 #define IEEE80211_IOC_WEPKEY		4
621 #define IEEE80211_IOC_NUMWEPKEYS	5
622 #define IEEE80211_IOC_WEPTXKEY		6
623 #define IEEE80211_IOC_AUTHMODE		7
624 #define IEEE80211_IOC_STATIONNAME	8
625 #define IEEE80211_IOC_CHANNEL		9
626 #define IEEE80211_IOC_POWERSAVE		10
627 #define 	IEEE80211_POWERSAVE_NOSUP	-1
628 #define 	IEEE80211_POWERSAVE_OFF		0
629 #define 	IEEE80211_POWERSAVE_CAM		1
630 #define 	IEEE80211_POWERSAVE_PSP		2
631 #define 	IEEE80211_POWERSAVE_PSP_CAM	3
632 #define 	IEEE80211_POWERSAVE_ON		IEEE80211_POWERSAVE_CAM
633 #define IEEE80211_IOC_POWERSAVESLEEP	11
634 #define	IEEE80211_IOC_RTSTHRESHOLD	12
635 #define IEEE80211_IOC_PROTMODE		13
636 #define 	IEEE80211_PROTMODE_OFF		0
637 #define 	IEEE80211_PROTMODE_CTS		1
638 #define 	IEEE80211_PROTMODE_RTSCTS	2
639 #define	IEEE80211_IOC_TXPOWER		14	/* global tx power limit */
640 #define	IEEE80211_IOC_BSSID		15
641 #define	IEEE80211_IOC_ROAMING		16	/* roaming mode */
642 #define	IEEE80211_IOC_PRIVACY		17	/* privacy invoked */
643 #define	IEEE80211_IOC_DROPUNENCRYPTED	18	/* discard unencrypted frames */
644 #define	IEEE80211_IOC_WPAKEY		19
645 #define	IEEE80211_IOC_DELKEY		20
646 #define	IEEE80211_IOC_MLME		21
647 /* 22 was IEEE80211_IOC_OPTIE, replaced by IEEE80211_IOC_APPIE */
648 /* 23 was IEEE80211_IOC_SCAN_REQ */
649 /* 24 was IEEE80211_IOC_SCAN_RESULTS */
650 #define	IEEE80211_IOC_COUNTERMEASURES	25	/* WPA/TKIP countermeasures */
651 #define	IEEE80211_IOC_WPA		26	/* WPA mode (0,1,2) */
652 #define	IEEE80211_IOC_CHANLIST		27	/* channel list */
653 #define	IEEE80211_IOC_WME		28	/* WME mode (on, off) */
654 #define	IEEE80211_IOC_HIDESSID		29	/* hide SSID mode (on, off) */
655 #define	IEEE80211_IOC_APBRIDGE		30	/* AP inter-sta bridging */
656 /* 31-35,37-38 were for WPA authenticator settings */
657 /* 36 was IEEE80211_IOC_DRIVER_CAPS */
658 #define	IEEE80211_IOC_WPAIE		39	/* WPA information element */
659 #define	IEEE80211_IOC_STA_STATS		40	/* per-station statistics */
660 #define	IEEE80211_IOC_MACCMD		41	/* MAC ACL operation */
661 #define	IEEE80211_IOC_CHANINFO		42	/* channel info list */
662 #define	IEEE80211_IOC_TXPOWMAX		43	/* max tx power for channel */
663 #define	IEEE80211_IOC_STA_TXPOW		44	/* per-station tx power limit */
664 /* 45 was IEEE80211_IOC_STA_INFO */
665 #define	IEEE80211_IOC_WME_CWMIN		46	/* WME: ECWmin */
666 #define	IEEE80211_IOC_WME_CWMAX		47	/* WME: ECWmax */
667 #define	IEEE80211_IOC_WME_AIFS		48	/* WME: AIFSN */
668 #define	IEEE80211_IOC_WME_TXOPLIMIT	49	/* WME: txops limit */
669 #define	IEEE80211_IOC_WME_ACM		50	/* WME: ACM (bss only) */
670 #define	IEEE80211_IOC_WME_ACKPOLICY	51	/* WME: ACK policy (!bss only)*/
671 #define	IEEE80211_IOC_DTIM_PERIOD	52	/* DTIM period (beacons) */
672 #define	IEEE80211_IOC_BEACON_INTERVAL	53	/* beacon interval (ms) */
673 #define	IEEE80211_IOC_ADDMAC		54	/* add sta to MAC ACL table */
674 #define	IEEE80211_IOC_DELMAC		55	/* del sta from MAC ACL table */
675 #define	IEEE80211_IOC_PUREG		56	/* pure 11g (no 11b stations) */
676 #define	IEEE80211_IOC_FF		57	/* ATH fast frames (on, off) */
677 #define	IEEE80211_IOC_TURBOP		58	/* ATH turbo' (on, off) */
678 #define	IEEE80211_IOC_BGSCAN		59	/* bg scanning (on, off) */
679 #define	IEEE80211_IOC_BGSCAN_IDLE	60	/* bg scan idle threshold */
680 #define	IEEE80211_IOC_BGSCAN_INTERVAL	61	/* bg scan interval */
681 #define	IEEE80211_IOC_SCANVALID		65	/* scan cache valid threshold */
682 /* 66-72 were IEEE80211_IOC_ROAM_* and IEEE80211_IOC_MCAST_RATE */
683 #define	IEEE80211_IOC_FRAGTHRESHOLD	73	/* tx fragmentation threshold */
684 #define	IEEE80211_IOC_BURST		75	/* packet bursting */
685 #define	IEEE80211_IOC_SCAN_RESULTS	76	/* get scan results */
686 #define	IEEE80211_IOC_BMISSTHRESHOLD	77	/* beacon miss threshold */
687 #define	IEEE80211_IOC_STA_INFO		78	/* station/neighbor info */
688 #define	IEEE80211_IOC_WPAIE2		79	/* WPA+RSN info elements */
689 #define	IEEE80211_IOC_CURCHAN		80	/* current channel */
690 #define	IEEE80211_IOC_SHORTGI		81	/* 802.11n half GI */
691 #define	IEEE80211_IOC_AMPDU		82	/* 802.11n A-MPDU (on, off) */
692 #define	IEEE80211_IOC_AMPDU_LIMIT	83	/* A-MPDU length limit */
693 #define	IEEE80211_IOC_AMPDU_DENSITY	84	/* A-MPDU density */
694 #define	IEEE80211_IOC_AMSDU		85	/* 802.11n A-MSDU (on, off) */
695 #define	IEEE80211_IOC_AMSDU_LIMIT	86	/* A-MSDU length limit */
696 #define	IEEE80211_IOC_PUREN		87	/* pure 11n (no legacy sta's) */
697 #define	IEEE80211_IOC_DOTH		88	/* 802.11h (on, off) */
698 /* 89-91 were regulatory items */
699 #define	IEEE80211_IOC_HTCOMPAT		92	/* support pre-D1.10 HT ie's */
700 #define	IEEE80211_IOC_DWDS		93	/* DWDS/4-address handling */
701 #define	IEEE80211_IOC_INACTIVITY	94	/* sta inactivity handling */
702 #define	IEEE80211_IOC_APPIE		95	/* application IE's */
703 #define	IEEE80211_IOC_WPS		96	/* WPS operation */
704 #define	IEEE80211_IOC_TSN		97	/* TSN operation */
705 #define	IEEE80211_IOC_DEVCAPS		98	/* driver+device capabilities */
706 #define	IEEE80211_IOC_CHANSWITCH	99	/* start 11h channel switch */
707 #define	IEEE80211_IOC_DFS		100	/* DFS (on, off) */
708 #define	IEEE80211_IOC_DOTD		101	/* 802.11d (on, off) */
709 #define IEEE80211_IOC_HTPROTMODE	102	/* HT protection (off, rts) */
710 #define	IEEE80211_IOC_SCAN_REQ		103	/* scan w/ specified params */
711 #define	IEEE80211_IOC_SCAN_CANCEL	104	/* cancel ongoing scan */
712 #define	IEEE80211_IOC_HTCONF		105	/* HT config (off, HT20, HT40)*/
713 #define	IEEE80211_IOC_REGDOMAIN		106	/* regulatory domain info */
714 #define	IEEE80211_IOC_ROAM		107	/* roaming params en masse */
715 #define	IEEE80211_IOC_TXPARAMS		108	/* tx parameters */
716 #define	IEEE80211_IOC_STA_VLAN		109	/* per-station vlan tag */
717 #define	IEEE80211_IOC_SMPS		110	/* MIMO power save */
718 #define	IEEE80211_IOC_RIFS		111	/* RIFS config (on, off) */
719 #define	IEEE80211_IOC_GREENFIELD	112	/* Greenfield (on, off) */
720 #define	IEEE80211_IOC_STBC		113	/* STBC Tx/RX (on, off) */
721 #define	IEEE80211_IOC_LDPC		114	/* LDPC Tx/RX (on, off) */
722 #define	IEEE80211_IOC_UAPSD		115	/* UAPSD (on, off) */
723 #define	IEEE80211_IOC_UAPSD_INFO	116	/* UAPSD (SP, per-AC enable) */
724 
725 /* VHT */
726 #define	IEEE80211_IOC_VHTCONF		130	/* VHT config (off, on; widths) */
727 
728 #define	IEEE80211_IOC_MESH_ID		170	/* mesh identifier */
729 #define	IEEE80211_IOC_MESH_AP		171	/* accepting peerings */
730 #define	IEEE80211_IOC_MESH_FWRD		172	/* forward frames */
731 #define	IEEE80211_IOC_MESH_PROTO	173	/* mesh protocols */
732 #define	IEEE80211_IOC_MESH_TTL		174	/* mesh TTL */
733 #define	IEEE80211_IOC_MESH_RTCMD	175	/* mesh routing table commands*/
734 #define	IEEE80211_IOC_MESH_PR_METRIC	176	/* mesh metric protocol */
735 #define	IEEE80211_IOC_MESH_PR_PATH	177	/* mesh path protocol */
736 #define	IEEE80211_IOC_MESH_PR_SIG	178	/* mesh sig protocol */
737 #define	IEEE80211_IOC_MESH_PR_CC	179	/* mesh congestion protocol */
738 #define	IEEE80211_IOC_MESH_PR_AUTH	180	/* mesh auth protocol */
739 #define	IEEE80211_IOC_MESH_GATE		181	/* mesh gate XXX: 173? */
740 
741 #define	IEEE80211_IOC_HWMP_ROOTMODE	190	/* HWMP root mode */
742 #define	IEEE80211_IOC_HWMP_MAXHOPS	191	/* number of hops before drop */
743 #define	IEEE80211_IOC_HWMP_TTL		192	/* HWMP TTL */
744 
745 #define	IEEE80211_IOC_TDMA_SLOT		201	/* TDMA: assigned slot */
746 #define	IEEE80211_IOC_TDMA_SLOTCNT	202	/* TDMA: slots in bss */
747 #define	IEEE80211_IOC_TDMA_SLOTLEN	203	/* TDMA: slot length (usecs) */
748 #define	IEEE80211_IOC_TDMA_BINTERVAL	204	/* TDMA: beacon intvl (slots) */
749 
750 #define	IEEE80211_IOC_QUIET		205	/* Quiet Enable/Disable */
751 #define	IEEE80211_IOC_QUIET_PERIOD	206	/* Quiet Period */
752 #define	IEEE80211_IOC_QUIET_OFFSET	207	/* Quiet Offset */
753 #define	IEEE80211_IOC_QUIET_DUR		208	/* Quiet Duration */
754 #define	IEEE80211_IOC_QUIET_COUNT	209	/* Quiet Count */
755 
756 #define	IEEE80211_IOC_IC_NAME		210	/* HW device name. */
757 
758 
759 #ifdef __HAIKU__
760 /*
761 	These are here to allow overcoming a difference between Haiku and
762 	FreeBSD drivers. In FreeBSD a device can be set into the down state
763 	but is still fully configurable using the ioctl interface. The Haiku
764 	network stack on the other hand opens and closes the driver on the
765 	transition form up to down and vice versa. This difference can become
766 	problematic with ported software that depends on the original behaviour.
767 	Therefore IEEE80211_IOC_HAIKU_COMPAT_WLAN_{UP|DOWN} provide a way to
768 	achieve the behaviour of setting and clearing IFF_UP without opening
769 	or closing the driver itself.
770 */
771 #define IEEE80211_IOC_HAIKU_COMPAT_WLAN_UP		0x6000
772 #define IEEE80211_IOC_HAIKU_COMPAT_WLAN_DOWN	0x6001
773 
774 /*
775 	Haiku extension: initiate join of network, potentially encrypted.
776 */
777 #define IEEE80211_IOC_HAIKU_JOIN				0x6002
778 struct ieee80211_haiku_join_req {
779 	uint8 i_nwid[IEEE80211_NWID_LEN];
780 	uint8 i_nwid_len;
781 
782 	uint32 i_authentication_mode;
783 	uint32 i_ciphers;
784 	uint32 i_group_ciphers;
785 	uint32 i_key_mode;
786 
787 	uint32 i_key_len;
788 	uint8 i_key[];
789 };
790 #endif /* __HAIKU__ */
791 
792 /*
793  * Parameters for controlling a scan requested with
794  * IEEE80211_IOC_SCAN_REQ.
795  *
796  * Active scans cause ProbeRequest frames to be issued for each
797  * specified ssid and, by default, a broadcast ProbeRequest frame.
798  * The set of ssid's is specified in the request.
799  *
800  * By default the scan will cause a BSS to be joined (in station/adhoc
801  * mode) or a channel to be selected for operation (hostap mode).
802  * To disable that specify IEEE80211_IOC_SCAN_NOPICK and if the
803  *
804  * If the station is currently associated to an AP then a scan request
805  * will cause the station to leave the current channel and potentially
806  * miss frames from the AP.  Alternatively the station may notify the
807  * AP that it is going into power save mode before it leaves the channel.
808  * This ensures frames for the station are buffered by the AP.  This is
809  * termed a ``bg scan'' and is requested with the IEEE80211_IOC_SCAN_BGSCAN
810  * flag.  Background scans may take longer than foreground scans and may
811  * be preempted by traffic.  If a station is not associated to an AP
812  * then a request for a background scan is automatically done in the
813  * foreground.
814  *
815  * The results of the scan request are cached by the system.  This
816  * information is aged out and/or invalidated based on events like not
817  * being able to associated to an AP.  To flush the current cache
818  * contents before doing a scan the IEEE80211_IOC_SCAN_FLUSH flag may
819  * be specified.
820  *
821  * By default the scan will be done until a suitable AP is located
822  * or a channel is found for use.  A scan can also be constrained
823  * to be done once (IEEE80211_IOC_SCAN_ONCE) or to last for no more
824  * than a specified duration.
825  */
826 struct ieee80211_scan_req {
827 	int		sr_flags;
828 #define	IEEE80211_IOC_SCAN_NOPICK	0x00001	/* scan only, no selection */
829 #define	IEEE80211_IOC_SCAN_ACTIVE	0x00002	/* active scan (probe req) */
830 #define	IEEE80211_IOC_SCAN_PICK1ST	0x00004	/* ``hey sailor'' mode */
831 #define	IEEE80211_IOC_SCAN_BGSCAN	0x00008	/* bg scan, exit ps at end */
832 #define	IEEE80211_IOC_SCAN_ONCE		0x00010	/* do one complete pass */
833 #define	IEEE80211_IOC_SCAN_NOBCAST	0x00020	/* don't send bcast probe req */
834 #define	IEEE80211_IOC_SCAN_NOJOIN	0x00040	/* no auto-sequencing */
835 #define	IEEE80211_IOC_SCAN_FLUSH	0x10000	/* flush scan cache first */
836 #define	IEEE80211_IOC_SCAN_CHECK	0x20000	/* check scan cache first */
837 	u_int		sr_duration;		/* duration (ms) */
838 #define	IEEE80211_IOC_SCAN_DURATION_MIN	1
839 #define	IEEE80211_IOC_SCAN_DURATION_MAX	0x7fffffff
840 #define	IEEE80211_IOC_SCAN_FOREVER	IEEE80211_IOC_SCAN_DURATION_MAX
841 	u_int		sr_mindwell;		/* min channel dwelltime (ms) */
842 	u_int		sr_maxdwell;		/* max channel dwelltime (ms) */
843 	int		sr_nssid;
844 #define	IEEE80211_IOC_SCAN_MAX_SSID	3
845 	struct {
846 		int	 len;				/* length in bytes */
847 		uint8_t ssid[IEEE80211_NWID_LEN];	/* ssid contents */
848 	} sr_ssid[IEEE80211_IOC_SCAN_MAX_SSID];
849 };
850 
851 /*
852  * Scan result data returned for IEEE80211_IOC_SCAN_RESULTS.
853  * Each result is a fixed size structure followed by a variable
854  * length SSID and one or more variable length information elements.
855  * The size of each variable length item is found in the fixed
856  * size structure and the entire length of the record is specified
857  * in isr_len.  Result records are rounded to a multiple of 4 bytes.
858  */
859 struct ieee80211req_scan_result {
860 	uint16_t	isr_len;		/* total length (mult of 4) */
861 	uint16_t	isr_ie_off;		/* offset to SSID+IE data */
862 	uint16_t	isr_ie_len;		/* IE length */
863 	uint16_t	isr_freq;		/* MHz */
864 	uint16_t	isr_flags;		/* channel flags */
865 	int8_t		isr_noise;
866 	int8_t		isr_rssi;
867 	uint16_t	isr_intval;		/* beacon interval */
868 	uint8_t		isr_capinfo;		/* capabilities */
869 	uint8_t		isr_erp;		/* ERP element */
870 	uint8_t		isr_bssid[IEEE80211_ADDR_LEN];
871 	uint8_t		isr_nrates;
872 	uint8_t		isr_rates[IEEE80211_RATE_MAXSIZE];
873 #if defined(__HAIKU__) && defined(_KERNEL_MODE)
874 STATIC_ASSERT(IEEE80211_RATE_MAXSIZE == 15);
875 #endif
876 	uint8_t		isr_ssid_len;		/* SSID length */
877 	uint8_t		isr_meshid_len;		/* MESH ID length */
878 	/* variable length SSID, followed by variable length MESH ID,
879 	  followed by IE data */
880 };
881 
882 /*
883  * Virtual AP cloning parameters.  The parent device must
884  * be a vap-capable device.  All parameters specified with
885  * the clone request are fixed for the lifetime of the vap.
886  *
887  * There are two flavors of WDS vaps: legacy and dynamic.
888  * Legacy WDS operation implements a static binding between
889  * two stations encapsulating traffic in 4-address frames.
890  * Dynamic WDS vaps are created when a station associates to
891  * an AP and sends a 4-address frame.  If the AP vap is
892  * configured to support WDS then this will generate an
893  * event to user programs listening on the routing socket
894  * and a Dynamic WDS vap will be created to handle traffic
895  * to/from that station.  In both cases the bssid of the
896  * peer must be specified when creating the vap.
897  *
898  * By default a vap will inherit the mac address/bssid of
899  * the underlying device.  To request a unique address the
900  * IEEE80211_CLONE_BSSID flag should be supplied.  This is
901  * meaningless for WDS vaps as they share the bssid of an
902  * AP vap that must otherwise exist.  Note that some devices
903  * may not be able to support multiple addresses.
904  *
905  * Station mode vap's normally depend on the device to notice
906  * when the AP stops sending beacon frames.  If IEEE80211_CLONE_NOBEACONS
907  * is specified the net80211 layer will do this in s/w.  This
908  * is mostly useful when setting up a WDS repeater/extender where
909  * an AP vap is combined with a sta vap and the device isn't able
910  * to track beacon frames in hardware.
911  */
912 struct ieee80211_clone_params {
913 	char	icp_parent[IFNAMSIZ];		/* parent device */
914 	uint16_t icp_opmode;			/* operating mode */
915 	uint16_t icp_flags;			/* see below */
916 	uint8_t	icp_bssid[IEEE80211_ADDR_LEN];	/* for WDS links */
917 	uint8_t	icp_macaddr[IEEE80211_ADDR_LEN];/* local address */
918 };
919 #define	IEEE80211_CLONE_BSSID		0x0001	/* allocate unique mac/bssid */
920 #define	IEEE80211_CLONE_NOBEACONS	0x0002	/* don't setup beacon timers */
921 #define	IEEE80211_CLONE_WDSLEGACY	0x0004	/* legacy WDS processing */
922 #define	IEEE80211_CLONE_MACADDR		0x0008	/* use specified mac addr */
923 #define	IEEE80211_CLONE_TDMA		0x0010	/* operate in TDMA mode */
924 #endif /* __FreeBSD__ */
925 
926 #endif /* _NET80211_IEEE80211_IOCTL_H_ */
927