1/****************************************************************************
2 ****************************************************************************
3 ***
4 ***   This header was automatically generated from a Linux kernel header
5 ***   of the same name, to make information necessary for userspace to
6 ***   call into the kernel available to libc.  It contains only constants,
7 ***   structures, and macros generated from the original header, and thus,
8 ***   contains no copyrightable information.
9 ***
10 ****************************************************************************
11 ****************************************************************************/
12#ifndef _LINUX_WIRELESS_H
13#define _LINUX_WIRELESS_H
14
15#include <linux/types.h>
16#include <linux/socket.h>
17#include <linux/if.h>
18
19#define WIRELESS_EXT 20
20
21#define SIOCSIWCOMMIT 0x8B00
22#define SIOCGIWNAME 0x8B01
23
24#define SIOCSIWNWID 0x8B02
25#define SIOCGIWNWID 0x8B03
26#define SIOCSIWFREQ 0x8B04
27#define SIOCGIWFREQ 0x8B05
28#define SIOCSIWMODE 0x8B06
29#define SIOCGIWMODE 0x8B07
30#define SIOCSIWSENS 0x8B08
31#define SIOCGIWSENS 0x8B09
32
33#define SIOCSIWRANGE 0x8B0A
34#define SIOCGIWRANGE 0x8B0B
35#define SIOCSIWPRIV 0x8B0C
36#define SIOCGIWPRIV 0x8B0D
37#define SIOCSIWSTATS 0x8B0E
38#define SIOCGIWSTATS 0x8B0F
39
40#define SIOCSIWSPY 0x8B10
41#define SIOCGIWSPY 0x8B11
42#define SIOCSIWTHRSPY 0x8B12
43#define SIOCGIWTHRSPY 0x8B13
44
45#define SIOCSIWAP 0x8B14
46#define SIOCGIWAP 0x8B15
47#define SIOCGIWAPLIST 0x8B17
48#define SIOCSIWSCAN 0x8B18
49#define SIOCGIWSCAN 0x8B19
50
51#define SIOCSIWESSID 0x8B1A
52#define SIOCGIWESSID 0x8B1B
53#define SIOCSIWNICKN 0x8B1C
54#define SIOCGIWNICKN 0x8B1D
55
56#define SIOCSIWRATE 0x8B20
57#define SIOCGIWRATE 0x8B21
58#define SIOCSIWRTS 0x8B22
59#define SIOCGIWRTS 0x8B23
60#define SIOCSIWFRAG 0x8B24
61#define SIOCGIWFRAG 0x8B25
62#define SIOCSIWTXPOW 0x8B26
63#define SIOCGIWTXPOW 0x8B27
64#define SIOCSIWRETRY 0x8B28
65#define SIOCGIWRETRY 0x8B29
66
67#define SIOCSIWENCODE 0x8B2A
68#define SIOCGIWENCODE 0x8B2B
69
70#define SIOCSIWPOWER 0x8B2C
71#define SIOCGIWPOWER 0x8B2D
72
73#define SIOCSIWGENIE 0x8B30
74#define SIOCGIWGENIE 0x8B31
75
76#define SIOCSIWMLME 0x8B16
77
78#define SIOCSIWAUTH 0x8B32
79#define SIOCGIWAUTH 0x8B33
80
81#define SIOCSIWENCODEEXT 0x8B34
82#define SIOCGIWENCODEEXT 0x8B35
83
84#define SIOCSIWPMKSA 0x8B36
85
86#define SIOCIWFIRSTPRIV 0x8BE0
87#define SIOCIWLASTPRIV 0x8BFF
88
89#define SIOCIWFIRST 0x8B00
90#define SIOCIWLAST SIOCIWLASTPRIV
91#define IW_IOCTL_IDX(cmd) ((cmd) - SIOCIWFIRST)
92
93#define IW_IS_SET(cmd) (!((cmd) & 0x1))
94#define IW_IS_GET(cmd) ((cmd) & 0x1)
95
96#define IWEVTXDROP 0x8C00
97#define IWEVQUAL 0x8C01
98#define IWEVCUSTOM 0x8C02
99#define IWEVREGISTERED 0x8C03
100#define IWEVEXPIRED 0x8C04
101#define IWEVGENIE 0x8C05
102#define IWEVMICHAELMICFAILURE 0x8C06
103#define IWEVASSOCREQIE 0x8C07
104#define IWEVASSOCRESPIE 0x8C08
105#define IWEVPMKIDCAND 0x8C09
106
107#define IWEVFIRST 0x8C00
108#define IW_EVENT_IDX(cmd) ((cmd) - IWEVFIRST)
109
110#define IW_PRIV_TYPE_MASK 0x7000
111#define IW_PRIV_TYPE_NONE 0x0000
112#define IW_PRIV_TYPE_BYTE 0x1000
113#define IW_PRIV_TYPE_CHAR 0x2000
114#define IW_PRIV_TYPE_INT 0x4000
115#define IW_PRIV_TYPE_FLOAT 0x5000
116#define IW_PRIV_TYPE_ADDR 0x6000
117
118#define IW_PRIV_SIZE_FIXED 0x0800
119
120#define IW_PRIV_SIZE_MASK 0x07FF
121
122#define IW_MAX_FREQUENCIES 32
123
124#define IW_MAX_BITRATES 32
125
126#define IW_MAX_TXPOWER 8
127
128#define IW_MAX_SPY 8
129
130#define IW_MAX_AP 64
131
132#define IW_ESSID_MAX_SIZE 32
133
134#define IW_MODE_AUTO 0
135#define IW_MODE_ADHOC 1
136#define IW_MODE_INFRA 2
137#define IW_MODE_MASTER 3
138#define IW_MODE_REPEAT 4
139#define IW_MODE_SECOND 5
140#define IW_MODE_MONITOR 6
141
142#define IW_QUAL_QUAL_UPDATED 0x01
143#define IW_QUAL_LEVEL_UPDATED 0x02
144#define IW_QUAL_NOISE_UPDATED 0x04
145#define IW_QUAL_ALL_UPDATED 0x07
146#define IW_QUAL_DBM 0x08
147#define IW_QUAL_QUAL_INVALID 0x10
148#define IW_QUAL_LEVEL_INVALID 0x20
149#define IW_QUAL_NOISE_INVALID 0x40
150#define IW_QUAL_ALL_INVALID 0x70
151
152#define IW_FREQ_AUTO 0x00
153#define IW_FREQ_FIXED 0x01
154
155#define IW_MAX_ENCODING_SIZES 8
156
157#define IW_ENCODING_TOKEN_MAX 64
158
159#define IW_ENCODE_INDEX 0x00FF
160#define IW_ENCODE_FLAGS 0xFF00
161#define IW_ENCODE_MODE 0xF000
162#define IW_ENCODE_DISABLED 0x8000
163#define IW_ENCODE_ENABLED 0x0000
164#define IW_ENCODE_RESTRICTED 0x4000
165#define IW_ENCODE_OPEN 0x2000
166#define IW_ENCODE_NOKEY 0x0800
167#define IW_ENCODE_TEMP 0x0400
168
169#define IW_POWER_ON 0x0000
170#define IW_POWER_TYPE 0xF000
171#define IW_POWER_PERIOD 0x1000
172#define IW_POWER_TIMEOUT 0x2000
173#define IW_POWER_MODE 0x0F00
174#define IW_POWER_UNICAST_R 0x0100
175#define IW_POWER_MULTICAST_R 0x0200
176#define IW_POWER_ALL_R 0x0300
177#define IW_POWER_FORCE_S 0x0400
178#define IW_POWER_REPEATER 0x0800
179#define IW_POWER_MODIFIER 0x000F
180#define IW_POWER_MIN 0x0001
181#define IW_POWER_MAX 0x0002
182#define IW_POWER_RELATIVE 0x0004
183
184#define IW_TXPOW_TYPE 0x00FF
185#define IW_TXPOW_DBM 0x0000
186#define IW_TXPOW_MWATT 0x0001
187#define IW_TXPOW_RELATIVE 0x0002
188#define IW_TXPOW_RANGE 0x1000
189
190#define IW_RETRY_ON 0x0000
191#define IW_RETRY_TYPE 0xF000
192#define IW_RETRY_LIMIT 0x1000
193#define IW_RETRY_LIFETIME 0x2000
194#define IW_RETRY_MODIFIER 0x000F
195#define IW_RETRY_MIN 0x0001
196#define IW_RETRY_MAX 0x0002
197#define IW_RETRY_RELATIVE 0x0004
198
199#define IW_SCAN_DEFAULT 0x0000
200#define IW_SCAN_ALL_ESSID 0x0001
201#define IW_SCAN_THIS_ESSID 0x0002
202#define IW_SCAN_ALL_FREQ 0x0004
203#define IW_SCAN_THIS_FREQ 0x0008
204#define IW_SCAN_ALL_MODE 0x0010
205#define IW_SCAN_THIS_MODE 0x0020
206#define IW_SCAN_ALL_RATE 0x0040
207#define IW_SCAN_THIS_RATE 0x0080
208
209#define IW_SCAN_TYPE_ACTIVE 0
210#define IW_SCAN_TYPE_PASSIVE 1
211
212#define IW_SCAN_MAX_DATA 4096
213
214#define IW_CUSTOM_MAX 256
215
216#define IW_GENERIC_IE_MAX 1024
217
218#define IW_MLME_DEAUTH 0
219#define IW_MLME_DISASSOC 1
220
221#define IW_AUTH_INDEX 0x0FFF
222#define IW_AUTH_FLAGS 0xF000
223
224#define IW_AUTH_WPA_VERSION 0
225#define IW_AUTH_CIPHER_PAIRWISE 1
226#define IW_AUTH_CIPHER_GROUP 2
227#define IW_AUTH_KEY_MGMT 3
228#define IW_AUTH_TKIP_COUNTERMEASURES 4
229#define IW_AUTH_DROP_UNENCRYPTED 5
230#define IW_AUTH_80211_AUTH_ALG 6
231#define IW_AUTH_WPA_ENABLED 7
232#define IW_AUTH_RX_UNENCRYPTED_EAPOL 8
233#define IW_AUTH_ROAMING_CONTROL 9
234#define IW_AUTH_PRIVACY_INVOKED 10
235
236#define IW_AUTH_WPA_VERSION_DISABLED 0x00000001
237#define IW_AUTH_WPA_VERSION_WPA 0x00000002
238#define IW_AUTH_WPA_VERSION_WPA2 0x00000004
239
240#define IW_AUTH_CIPHER_NONE 0x00000001
241#define IW_AUTH_CIPHER_WEP40 0x00000002
242#define IW_AUTH_CIPHER_TKIP 0x00000004
243#define IW_AUTH_CIPHER_CCMP 0x00000008
244#define IW_AUTH_CIPHER_WEP104 0x00000010
245
246#define IW_AUTH_KEY_MGMT_802_1X 1
247#define IW_AUTH_KEY_MGMT_PSK 2
248
249#define IW_AUTH_ALG_OPEN_SYSTEM 0x00000001
250#define IW_AUTH_ALG_SHARED_KEY 0x00000002
251#define IW_AUTH_ALG_LEAP 0x00000004
252
253#define IW_AUTH_ROAMING_ENABLE 0
254#define IW_AUTH_ROAMING_DISABLE 1
255
256#define IW_ENCODE_SEQ_MAX_SIZE 8
257
258#define IW_ENCODE_ALG_NONE 0
259#define IW_ENCODE_ALG_WEP 1
260#define IW_ENCODE_ALG_TKIP 2
261#define IW_ENCODE_ALG_CCMP 3
262
263#define IW_ENCODE_EXT_TX_SEQ_VALID 0x00000001
264#define IW_ENCODE_EXT_RX_SEQ_VALID 0x00000002
265#define IW_ENCODE_EXT_GROUP_KEY 0x00000004
266#define IW_ENCODE_EXT_SET_TX_KEY 0x00000008
267
268#define IW_MICFAILURE_KEY_ID 0x00000003
269#define IW_MICFAILURE_GROUP 0x00000004
270#define IW_MICFAILURE_PAIRWISE 0x00000008
271#define IW_MICFAILURE_STAKEY 0x00000010
272#define IW_MICFAILURE_COUNT 0x00000060
273
274#define IW_ENC_CAPA_WPA 0x00000001
275#define IW_ENC_CAPA_WPA2 0x00000002
276#define IW_ENC_CAPA_CIPHER_TKIP 0x00000004
277#define IW_ENC_CAPA_CIPHER_CCMP 0x00000008
278
279#define IW_EVENT_CAPA_BASE(cmd) ((cmd >= SIOCIWFIRSTPRIV) ?   (cmd - SIOCIWFIRSTPRIV + 0x60) :   (cmd - SIOCSIWCOMMIT))
280#define IW_EVENT_CAPA_INDEX(cmd) (IW_EVENT_CAPA_BASE(cmd) >> 5)
281#define IW_EVENT_CAPA_MASK(cmd) (1 << (IW_EVENT_CAPA_BASE(cmd) & 0x1F))
282
283#define IW_EVENT_CAPA_K_0 (IW_EVENT_CAPA_MASK(0x8B04) |   IW_EVENT_CAPA_MASK(0x8B06) |   IW_EVENT_CAPA_MASK(0x8B1A))
284#define IW_EVENT_CAPA_K_1 (IW_EVENT_CAPA_MASK(0x8B2A))
285
286#define IW_EVENT_CAPA_SET(event_capa, cmd) (event_capa[IW_EVENT_CAPA_INDEX(cmd)] |= IW_EVENT_CAPA_MASK(cmd))
287#define IW_EVENT_CAPA_SET_KERNEL(event_capa) {event_capa[0] |= IW_EVENT_CAPA_K_0; event_capa[1] |= IW_EVENT_CAPA_K_1; }
288
289struct iw_param
290{
291 __s32 value;
292 __u8 fixed;
293 __u8 disabled;
294 __u16 flags;
295};
296
297struct iw_point
298{
299 void __user *pointer;
300 __u16 length;
301 __u16 flags;
302};
303
304struct iw_freq
305{
306 __s32 m;
307 __s16 e;
308 __u8 i;
309 __u8 flags;
310};
311
312struct iw_quality
313{
314 __u8 qual;
315 __u8 level;
316 __u8 noise;
317 __u8 updated;
318};
319
320struct iw_discarded
321{
322 __u32 nwid;
323 __u32 code;
324 __u32 fragment;
325 __u32 retries;
326 __u32 misc;
327};
328
329struct iw_missed
330{
331 __u32 beacon;
332};
333
334struct iw_thrspy
335{
336 struct sockaddr addr;
337 struct iw_quality qual;
338 struct iw_quality low;
339 struct iw_quality high;
340};
341
342struct iw_scan_req
343{
344 __u8 scan_type;
345 __u8 essid_len;
346 __u8 num_channels;
347 __u8 flags;
348 struct sockaddr bssid;
349
350 __u8 essid[IW_ESSID_MAX_SIZE];
351
352 __u32 min_channel_time;
353 __u32 max_channel_time;
354
355 struct iw_freq channel_list[IW_MAX_FREQUENCIES];
356};
357
358struct iw_encode_ext
359{
360 __u32 ext_flags;
361 __u8 tx_seq[IW_ENCODE_SEQ_MAX_SIZE];
362 __u8 rx_seq[IW_ENCODE_SEQ_MAX_SIZE];
363 struct sockaddr addr;
364 __u16 alg;
365 __u16 key_len;
366 __u8 key[0];
367};
368
369struct iw_mlme
370{
371 __u16 cmd;
372 __u16 reason_code;
373 struct sockaddr addr;
374};
375
376#define IW_PMKSA_ADD 1
377#define IW_PMKSA_REMOVE 2
378#define IW_PMKSA_FLUSH 3
379
380#define IW_PMKID_LEN 16
381
382struct iw_pmksa
383{
384 __u32 cmd;
385 struct sockaddr bssid;
386 __u8 pmkid[IW_PMKID_LEN];
387};
388
389struct iw_michaelmicfailure
390{
391 __u32 flags;
392 struct sockaddr src_addr;
393 __u8 tsc[IW_ENCODE_SEQ_MAX_SIZE];
394};
395
396#define IW_PMKID_CAND_PREAUTH 0x00000001
397struct iw_pmkid_cand
398{
399 __u32 flags;
400 __u32 index;
401 struct sockaddr bssid;
402};
403
404struct iw_statistics
405{
406 __u16 status;
407
408 struct iw_quality qual;
409 struct iw_discarded discard;
410 struct iw_missed miss;
411};
412
413union iwreq_data
414{
415
416 char name[IFNAMSIZ];
417
418 struct iw_point essid;
419 struct iw_param nwid;
420 struct iw_freq freq;
421
422 struct iw_param sens;
423 struct iw_param bitrate;
424 struct iw_param txpower;
425 struct iw_param rts;
426 struct iw_param frag;
427 __u32 mode;
428 struct iw_param retry;
429
430 struct iw_point encoding;
431 struct iw_param power;
432 struct iw_quality qual;
433
434 struct sockaddr ap_addr;
435 struct sockaddr addr;
436
437 struct iw_param param;
438 struct iw_point data;
439};
440
441struct iwreq
442{
443 union
444 {
445 char ifrn_name[IFNAMSIZ];
446 } ifr_ifrn;
447
448 union iwreq_data u;
449};
450
451struct iw_range
452{
453
454 __u32 throughput;
455
456 __u32 min_nwid;
457 __u32 max_nwid;
458
459 __u16 old_num_channels;
460 __u8 old_num_frequency;
461
462 __u32 event_capa[6];
463
464 __s32 sensitivity;
465
466 struct iw_quality max_qual;
467
468 struct iw_quality avg_qual;
469
470 __u8 num_bitrates;
471 __s32 bitrate[IW_MAX_BITRATES];
472
473 __s32 min_rts;
474 __s32 max_rts;
475
476 __s32 min_frag;
477 __s32 max_frag;
478
479 __s32 min_pmp;
480 __s32 max_pmp;
481 __s32 min_pmt;
482 __s32 max_pmt;
483 __u16 pmp_flags;
484 __u16 pmt_flags;
485 __u16 pm_capa;
486
487 __u16 encoding_size[IW_MAX_ENCODING_SIZES];
488 __u8 num_encoding_sizes;
489 __u8 max_encoding_tokens;
490
491 __u8 encoding_login_index;
492
493 __u16 txpower_capa;
494 __u8 num_txpower;
495 __s32 txpower[IW_MAX_TXPOWER];
496
497 __u8 we_version_compiled;
498 __u8 we_version_source;
499
500 __u16 retry_capa;
501 __u16 retry_flags;
502 __u16 r_time_flags;
503 __s32 min_retry;
504 __s32 max_retry;
505 __s32 min_r_time;
506 __s32 max_r_time;
507
508 __u16 num_channels;
509 __u8 num_frequency;
510 struct iw_freq freq[IW_MAX_FREQUENCIES];
511
512 __u32 enc_capa;
513};
514
515struct iw_priv_args
516{
517 __u32 cmd;
518 __u16 set_args;
519 __u16 get_args;
520 char name[IFNAMSIZ];
521};
522
523struct iw_event
524{
525 __u16 len;
526 __u16 cmd;
527 union iwreq_data u;
528};
529
530#define IW_EV_LCP_LEN (sizeof(struct iw_event) - sizeof(union iwreq_data))
531
532#define IW_EV_CHAR_LEN (IW_EV_LCP_LEN + IFNAMSIZ)
533#define IW_EV_UINT_LEN (IW_EV_LCP_LEN + sizeof(__u32))
534#define IW_EV_FREQ_LEN (IW_EV_LCP_LEN + sizeof(struct iw_freq))
535#define IW_EV_PARAM_LEN (IW_EV_LCP_LEN + sizeof(struct iw_param))
536#define IW_EV_ADDR_LEN (IW_EV_LCP_LEN + sizeof(struct sockaddr))
537#define IW_EV_QUAL_LEN (IW_EV_LCP_LEN + sizeof(struct iw_quality))
538
539#define IW_EV_POINT_OFF (((char *) &(((struct iw_point *) NULL)->length)) -   (char *) NULL)
540#define IW_EV_POINT_LEN (IW_EV_LCP_LEN + sizeof(struct iw_point) -   IW_EV_POINT_OFF)
541
542#endif
543