1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
|
/* $OpenBSD: ieee80211_ioctl.h,v 1.37 2019/02/19 08:12:30 stsp Exp $ */
/* $NetBSD: ieee80211_ioctl.h,v 1.7 2004/04/30 22:51:04 dyoung Exp $ */
/*-
* Copyright (c) 2001 Atsushi Onoe
* Copyright (c) 2002, 2003 Sam Leffler, Errno Consulting
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* $FreeBSD: src/sys/net80211/ieee80211_ioctl.h,v 1.5 2004/03/30 22:57:57 sam Exp $
*/
#ifndef _NET80211_IEEE80211_IOCTL_H_
#define _NET80211_IEEE80211_IOCTL_H_
/*
* IEEE 802.11 ioctls.
*/
/* per-interface statistics */
struct ieee80211_stats {
u_int32_t is_rx_badversion; /* rx frame with bad version */
u_int32_t is_rx_tooshort; /* rx frame too short */
u_int32_t is_rx_wrongbss; /* rx from wrong bssid */
u_int32_t is_rx_dup; /* rx discard 'cuz dup */
u_int32_t is_rx_wrongdir; /* rx w/ wrong direction */
u_int32_t is_rx_mcastecho; /* rx discard 'cuz mcast echo */
u_int32_t is_rx_notassoc; /* rx discard 'cuz sta !assoc */
u_int32_t is_rx_nowep; /* rx w/ wep but wep !config */
u_int32_t is_rx_unencrypted; /* rx w/o wep but wep config */
u_int32_t is_rx_wepfail; /* rx wep processing failed */
u_int32_t is_rx_decap; /* rx decapsulation failed */
u_int32_t is_rx_mgtdiscard; /* rx discard mgt frames */
u_int32_t is_rx_ctl; /* rx discard ctrl frames */
u_int32_t is_rx_rstoobig; /* rx rate set truncated */
u_int32_t is_rx_elem_missing; /* rx required element missing*/
u_int32_t is_rx_elem_toobig; /* rx element too big */
u_int32_t is_rx_elem_toosmall; /* rx element too small */
u_int32_t is_rx_badchan; /* rx frame w/ invalid chan */
u_int32_t is_rx_chanmismatch; /* rx frame chan mismatch */
u_int32_t is_rx_nodealloc; /* rx frame dropped */
u_int32_t is_rx_ssidmismatch; /* rx frame ssid mismatch */
u_int32_t is_rx_auth_unsupported; /* rx w/ unsupported auth alg */
u_int32_t is_rx_auth_fail; /* rx sta auth failure */
u_int32_t is_rx_assoc_bss; /* rx assoc from wrong bssid */
u_int32_t is_rx_assoc_notauth; /* rx assoc w/o auth */
u_int32_t is_rx_assoc_capmismatch;/* rx assoc w/ cap mismatch */
u_int32_t is_rx_assoc_norate; /* rx assoc w/ no rate match */
u_int32_t is_rx_deauth; /* rx deauthentication */
u_int32_t is_rx_disassoc; /* rx disassociation */
u_int32_t is_rx_badsubtype; /* rx frame w/ unknown subtype*/
u_int32_t is_rx_nombuf; /* rx failed for lack of mbuf */
u_int32_t is_rx_decryptcrc; /* rx decrypt failed on crc */
u_int32_t is_rx_ahdemo_mgt; /* rx discard ahdemo mgt frame*/
u_int32_t is_rx_bad_auth; /* rx bad auth request */
u_int32_t is_tx_nombuf; /* tx failed for lack of mbuf */
u_int32_t is_tx_nonode; /* tx failed for no node */
u_int32_t is_tx_unknownmgt; /* tx of unknown mgt frame */
u_int32_t is_scan_active; /* active scans started */
u_int32_t is_scan_passive; /* passive scans started */
u_int32_t is_node_timeout; /* nodes timed out inactivity */
u_int32_t is_crypto_nomem; /* no memory for crypto ctx */
u_int32_t is_rx_assoc_badrsnie; /* rx assoc w/ bad RSN IE */
u_int32_t is_rx_unauth; /* rx port not valid */
u_int32_t is_tx_noauth; /* tx port not valid */
u_int32_t is_rx_eapol_key; /* rx eapol-key frames */
u_int32_t is_rx_eapol_replay; /* rx replayed eapol frames */
u_int32_t is_rx_eapol_badmic; /* rx eapol frames w/ bad mic */
u_int32_t is_rx_remmicfail; /* rx tkip remote mic fails */
u_int32_t is_rx_locmicfail; /* rx tkip local mic fails */
u_int32_t is_tkip_replays;
u_int32_t is_tkip_icv_errs;
u_int32_t is_ccmp_replays;
u_int32_t is_ccmp_dec_errs;
u_int32_t is_cmac_replays;
u_int32_t is_cmac_icv_errs;
u_int32_t is_pbac_errs;
u_int32_t is_ht_nego_no_mandatory_mcs;
u_int32_t is_ht_nego_no_basic_mcs;
u_int32_t is_ht_nego_bad_crypto;
u_int32_t is_ht_prot_change;
u_int32_t is_ht_rx_ba_agreements;
u_int32_t is_ht_tx_ba_agreements;
u_int32_t is_ht_rx_frame_below_ba_winstart;
u_int32_t is_ht_rx_frame_above_ba_winend;
u_int32_t is_ht_rx_ba_window_slide;
u_int32_t is_ht_rx_ba_window_jump;
u_int32_t is_ht_rx_ba_no_buf;
u_int32_t is_ht_rx_ba_frame_lost;
u_int32_t is_ht_rx_ba_window_gap_timeout;
u_int32_t is_ht_rx_ba_timeout;
u_int32_t is_ht_tx_ba_timeout;
};
#define SIOCG80211STATS _IOWR('i', 242, struct ifreq)
/* network identifier (ESSID), nwid is pointed at by ifr.ifr_data */
struct ieee80211_nwid {
u_int8_t i_len;
u_int8_t i_nwid[IEEE80211_NWID_LEN];
};
#define SIOCS80211NWID _IOWR('i', 230, struct ifreq)
#define SIOCG80211NWID _IOWR('i', 231, struct ifreq)
/* network key (WEP), the first member must be matched with struct ifreq */
struct ieee80211_nwkey {
char i_name[IFNAMSIZ]; /* if_name, e.g. "wi0" */
int i_wepon; /* wep enabled flag */
int i_defkid; /* default encrypt key id */
struct {
int i_keylen;
u_int8_t *i_keydat;
} i_key[IEEE80211_WEP_NKID];
};
#define IEEE80211_NWKEY_OPEN 0 /* No privacy */
#define IEEE80211_NWKEY_WEP 1 /* WEP enabled */
#define IEEE80211_NWKEY_EAP 2 /* EAP enabled */
#define IEEE80211_NWKEY_PERSIST 0x100 /* designate persist keyset */
#define SIOCS80211NWKEY _IOW('i', 232, struct ieee80211_nwkey)
#define SIOCG80211NWKEY _IOWR('i', 233, struct ieee80211_nwkey)
/* power management parameters */
struct ieee80211_power {
char i_name[IFNAMSIZ]; /* if_name, e.g. "wi0" */
int i_enabled; /* 1 == on, 0 == off */
int i_maxsleep; /* max sleep in ms */
};
#define SIOCS80211POWER _IOW('i', 234, struct ieee80211_power)
#define SIOCG80211POWER _IOWR('i', 235, struct ieee80211_power)
#define IEEE80211_AUTH_NONE 0
#define IEEE80211_AUTH_OPEN 1
#define IEEE80211_AUTH_SHARED 2
/* channel request */
struct ieee80211chanreq {
char i_name[IFNAMSIZ]; /* if_name, e.g. "wi0" */
u_int16_t i_channel;
};
#ifndef _KERNEL
/*
* Channels are specified by frequency and attributes.
*/
struct ieee80211_channel {
u_int16_t ic_freq; /* setting in MHz */
u_int16_t ic_flags; /* see below */
};
/*
* Channel attributes (XXX must keep in sync with radiotap flags).
*/
#define IEEE80211_CHAN_CCK 0x0020 /* CCK channel */
#define IEEE80211_CHAN_OFDM 0x0040 /* OFDM channel */
#define IEEE80211_CHAN_2GHZ 0x0080 /* 2 GHz spectrum channel */
#define IEEE80211_CHAN_5GHZ 0x0100 /* 5 GHz spectrum channel */
#define IEEE80211_CHAN_PASSIVE 0x0200 /* Only passive scan allowed */
#define IEEE80211_CHAN_DYN 0x0400 /* Dynamic CCK-OFDM channel */
#define IEEE80211_CHAN_XR 0x1000 /* Extended range OFDM channel */
#define IEEE80211_CHAN_HT 0x2000 /* 11n/HT channel */
#endif /* !_KERNEL */
struct ieee80211_chanreq_all {
char i_name[IFNAMSIZ]; /* if_name, e.g. "wi0" */
struct ieee80211_channel *i_chans;
};
#ifndef IEEE80211_CHAN_ANY
#define IEEE80211_CHAN_ANY 0xffff
#endif
#define SIOCS80211CHANNEL _IOW('i', 238, struct ieee80211chanreq)
#define SIOCG80211CHANNEL _IOWR('i', 239, struct ieee80211chanreq)
#define SIOCG80211ALLCHANS _IOWR('i', 215, struct ieee80211_chanreq_all)
/* BSS identifier */
struct ieee80211_bssid {
char i_name[IFNAMSIZ]; /* if_name, e.g. "wi0" */
u_int8_t i_bssid[IEEE80211_ADDR_LEN];
};
#define SIOCS80211BSSID _IOW('i', 240, struct ieee80211_bssid)
#define SIOCG80211BSSID _IOWR('i', 241, struct ieee80211_bssid)
/* transmit power */
struct ieee80211_txpower {
char i_name[IFNAMSIZ]; /* if_name, e.g. "wi0" */
int i_mode; /* auto, manual */
int16_t i_val; /* dBm */
};
#define SIOCS80211TXPOWER _IOW('i', 243, struct ieee80211_txpower)
#define SIOCG80211TXPOWER _IOWR('i', 244, struct ieee80211_txpower)
#define IEEE80211_TXPOWER_MODE_FIXED 0 /* fixed tx power value */
#define IEEE80211_TXPOWER_MODE_AUTO 1 /* auto level control */
struct ieee80211_wpapsk {
char i_name[IFNAMSIZ]; /* if_name, e.g. "wi0" */
int i_enabled;
u_int8_t i_psk[32];
};
#define SIOCS80211WPAPSK _IOW('i', 245, struct ieee80211_wpapsk)
#define SIOCG80211WPAPSK _IOWR('i', 246, struct ieee80211_wpapsk)
#define IEEE80211_WPA_PROTO_WPA1 0x01
#define IEEE80211_WPA_PROTO_WPA2 0x02
#define IEEE80211_WPA_CIPHER_NONE 0x00
#define IEEE80211_WPA_CIPHER_USEGROUP 0x01
#define IEEE80211_WPA_CIPHER_WEP40 0x02
#define IEEE80211_WPA_CIPHER_TKIP 0x04
#define IEEE80211_WPA_CIPHER_CCMP 0x08
#define IEEE80211_WPA_CIPHER_WEP104 0x10
#define IEEE80211_WPA_CIPHER_BIP 0x20
#define IEEE80211_WPA_AKM_PSK 0x01
#define IEEE80211_WPA_AKM_8021X 0x02
#define IEEE80211_WPA_AKM_SHA256_PSK 0x04
#define IEEE80211_WPA_AKM_SHA256_8021X 0x08
struct ieee80211_wpaparams {
char i_name[IFNAMSIZ]; /* if_name, e.g. "wi0" */
int i_enabled;
u_int i_protos;
u_int i_akms;
u_int i_ciphers;
u_int i_groupcipher;
};
#define SIOCS80211WPAPARMS _IOW('i', 247, struct ieee80211_wpaparams)
#define SIOCG80211WPAPARMS _IOWR('i', 248, struct ieee80211_wpaparams)
struct ieee80211_keyavail {
char i_name[IFNAMSIZ]; /* if_name, e.g. "wi0" */
u_int8_t i_macaddr[IEEE80211_ADDR_LEN];
u_int8_t i_key[32];
u_int32_t i_lifetime;
};
struct ieee80211_keyrun {
char i_name[IFNAMSIZ]; /* if_name, e.g. "wi0" */
u_int8_t i_macaddr[IEEE80211_ADDR_LEN];
};
#define SIOCS80211KEYAVAIL _IOW('i', 251, struct ieee80211_keyavail)
#define SIOCS80211KEYRUN _IOW('i', 252, struct ieee80211_keyrun)
/* scan request (will block) */
#define IEEE80211_SCAN_TIMEOUT 30 /* timeout in seconds */
#define SIOCS80211SCAN _IOW('i', 210, struct ifreq)
#define SIOCG80211JOINALL _IOWR('i', 218, struct ieee80211_joinreq_all)
#define SIOCS80211JOIN _IOWR('i', 255, struct ifreq)
#define SIOCG80211JOIN _IOWR('i', 256, struct ifreq)
/* join is pointed at by ifr.ifr_data */
struct ieee80211_join {
u_int8_t i_len; /* length of i_nwid */
u_int8_t i_nwid[IEEE80211_NWID_LEN];
u_int32_t i_flags;
struct ieee80211_wpaparams i_wpaparams;
struct ieee80211_wpapsk i_wpapsk;
struct ieee80211_nwkey i_nwkey;
};
struct ieee80211_joinreq_all {
char ja_ifname[IFNAMSIZ];
int ja_nodes; /* returned count */
size_t ja_size; /* size of node buffer */
struct ieee80211_join *ja_node; /* allocated node buffer */
};
#define IEEE80211_JOIN_SHOW 0x01
#define IEEE80211_JOIN_FOUND 0x02
#define IEEE80211_JOIN_DEL 0x04
#define IEEE80211_JOIN_NWKEY 0x08
#define IEEE80211_JOIN_WPA 0x10
#define IEEE80211_JOIN_WPAPSK 0x20
#define IEEE80211_JOIN_8021X 0x40
#define IEEE80211_JOIN_ANY 0x80
#define IEEE80211_JOIN_DEL_ALL 0x100
/* node and requests */
struct ieee80211_nodereq {
char nr_ifname[IFNAMSIZ]; /* e.g. "ath0" */
/* Node address and name information */
u_int8_t nr_macaddr[IEEE80211_ADDR_LEN]; /* node lladdr */
u_int8_t nr_bssid[IEEE80211_ADDR_LEN]; /* bssid */
u_int8_t nr_nwid_len; /* ESSID length */
u_int8_t nr_nwid[IEEE80211_NWID_LEN]; /* ESSID */
/* Channel and rates */
u_int16_t nr_channel; /* last channel */
u_int16_t nr_chan_flags; /* channel flags */
u_int8_t nr_nrates; /* rate count */
u_int8_t nr_rates[IEEE80211_RATE_MAXSIZE]; /* rate set */
/* Node status information */
int8_t nr_rssi; /* received signal strength */
int8_t nr_max_rssi; /* maximum rssi */
u_int8_t nr_tstamp[8]; /* from last received beacon */
u_int16_t nr_intval; /* beacon interval */
u_int16_t nr_capinfo; /* capabilities */
u_int8_t nr_erp; /* 11g only */
u_int8_t nr_pwrsave; /* power saving mode */
u_int16_t nr_associd; /* assoc response */
u_int16_t nr_txseq; /* seq to be transmitted */
u_int16_t nr_rxseq; /* seq previous received */
u_int32_t nr_fails; /* failure count to associate */
u_int32_t nr_inact; /* inactivity mark count */
u_int8_t nr_txrate; /* index to nr_rates[] */
u_int16_t nr_state; /* node state in the cache */
/* RSN */
u_int nr_rsnprotos;
u_int nr_rsnciphers;
u_int nr_rsnakms;
/* Node flags */
u_int8_t nr_flags;
/* HT */
uint16_t nr_htcaps;
uint8_t nr_rxmcs[howmany(80,NBBY)];
uint16_t nr_max_rxrate; /* in Mb/s, 0 <= rate <= 1023 */
uint8_t nr_tx_mcs_set;
/* HT / VHT */
uint8_t nr_txmcs;
/* VHT */
uint8_t nr_vht_ss;
};
#define IEEE80211_NODEREQ_STATE(_s) (1 << _s)
#define IEEE80211_NODEREQ_STATE_BITS \
"\20\01CACHE\02BSS\03AUTH\04ASSOC\05COLLECT"
#define IEEE80211_NODEREQ_RSSI(_nr) \
((u_int)(((float)(_nr)->nr_rssi / (_nr)->nr_max_rssi) * 100))
#define IEEE80211_NODEREQ_STA 0x00 /* station */
#define IEEE80211_NODEREQ_AP 0x01 /* access point */
#define IEEE80211_NODEREQ_AP_BSS 0x02 /* current bss access point */
#define IEEE80211_NODEREQ_COPY 0x04 /* add node with flags */
#define IEEE80211_NODEREQ_HT 0x08 /* HT negotiated */
#define IEEE80211_NODEREQ_VHT 0x10 /* VHT negotiated */
#define SIOCG80211NODE _IOWR('i', 211, struct ieee80211_nodereq)
#define SIOCS80211NODE _IOW('i', 212, struct ieee80211_nodereq)
#define SIOCS80211DELNODE _IOW('i', 213, struct ieee80211_nodereq)
/* get the entire node cache */
struct ieee80211_nodereq_all {
char na_ifname[IFNAMSIZ]; /* e.g. "ath0" */
int na_nodes; /* returned count */
size_t na_size; /* size of node buffer */
struct ieee80211_nodereq *na_node; /* allocated node buffer */
/* Match nodes by flag */
u_int8_t na_flags; /* IEEE80211_NODEREQ_* */
};
#define SIOCG80211ALLNODES _IOWR('i', 214, struct ieee80211_nodereq_all)
/* net80211 specific interface flags */
#define IEEE80211_F_HIDENWID 0x10000000 /* CONF: hidden ssid mode */
#define IEEE80211_F_NOBRIDGE 0x20000000 /* CONF: no internal bridging */
#define IEEE80211_F_HOSTAPMASK 0x30000000
#define IEEE80211_F_USERSHIFT 28
#define IEEE80211_F_USERBITS "\20\01HIDENWID\02NOBRIDGE"
struct ieee80211_flags {
const char *f_name;
u_int f_flag;
};
#define IEEE80211_FLAGS { \
{ "hidenwid", IEEE80211_F_HIDENWID >> IEEE80211_F_USERSHIFT }, \
{ "nobridge", IEEE80211_F_NOBRIDGE >> IEEE80211_F_USERSHIFT } \
}
#define SIOCG80211FLAGS _IOWR('i', 216, struct ifreq)
#define SIOCS80211FLAGS _IOW('i', 217, struct ifreq)
#endif /* _NET80211_IEEE80211_IOCTL_H_ */
|