• R/O
  • HTTP
  • SSH
  • HTTPS

Commit

Frequently used words (click to add to your profile)

javac++androidlinuxc#windowsobjective-ccocoa誰得qtpythonphprubygameguibathyscaphec計画中(planning stage)翻訳omegatframeworktwitterdomtestvb.netdirectxゲームエンジンbtronarduinopreviewer

external/wireless-tools


Commit MetaInfo

Revisionbcc23ab3dacbe0d30b7b5e8adb7badbe2e254a7d (tree)
Time2016-10-12 05:49:10
Authorchris-kirby <chris.kirby@hpe....>
Commiterchris-kirby

Log Message

v20

Change Summary

Incremental Difference

--- a/wireless_tools/INSTALL
+++ b/wireless_tools/INSTALL
@@ -1,35 +1,66 @@
1+Very important note :
2+-------------------
3+ This release of the Wireless Tools is not compatible with Wireless
4+ Extensions earlier than 9.
5+ Kernels that support this version of the Wireless Tools are listed
6+ below. For all kernels before that, please use the version v19 of
7+ the Wireless Tools.
8+ If your kernel has the relevant Wireless Extensions but the tools
9+ refuse to compile, then your kernel headers in /usr/include are
10+ pointing to the wrong place (very common with Debian).
11+
112 You need :
213 --------
3- o A kernel supporting wireless extensions
4- -> from 2.1.17 onward
5- -> from 2.0.30 onward
6- -> patch available for 1.2.13
14+ o Compiler and development environment
15+ o A kernel supporting wireless extensions version 9 or higher
16+ -> from 2.2.14 onward
17+ -> from 2.3.24 onward
718 Note : CONFIG_NET_RADIO must be enabled
8- o Driver supporting wireless extensions
9- -> Wavelan isa from kernel 2.1.17 onward
10- -> Wavelan pcmcia from pcmcia 2.9.2 onward
11- -> Netwave pcmcia from pcmcia 2.9.12 onward
19+ o A driver supporting wireless extensions
20+ -> Wavelan isa from kernels above
21+ -> Wavelan pcmcia from pcmcia 3.1.2 onward
22+ -> Netwave pcmcia from pcmcia 3.1.2 onward
1223 -> Wavelan IEEE pcmcia drivers
1324 -> Proxim RangeLan2/Symphony driver
1425 -> Patch your favourite driver
1526 Note : more recent kernels and drivers are likely to support
1627 more wireless extension features...
1728
29+Recommended versions :
30+--------------------
31+ This are the latest updates of the Wireless Extensions :
32+ o Kernel (wireless extension definition) :
33+ -> Kernel 2.2.14 onward
34+ -> Kernel 2.3.24 onward
35+ o Drivers with wireless extension support :
36+ -> Wavelan isa from kernels above
37+ -> Wavelan pcmcia from pcmcia 3.1.1 onward
38+ -> Netwave pcmcia from pcmcia 3.1.2 onward
39+ -> Wavelan IEEE pcmcia GPL driver (wvlan) 1.0.1 onward
40+ -> Wavelan IEEE pcmcia binary driver (wavelan2) v4.00 onward
41+ -> Proxim RangeLan2/Symphony driver 1.4.3 onward
42+
1843 Compile wireless tools :
1944 ----------------------
20- In theory, a make should suffice.
21- In practice, there is big troubles with the headers. Depending
22-on which version of the kernel headers (might be different from
23-kernel) and library headers you have, you need to play with the
24-options buried in iwcommon.h.
45+ In theory, a "make" should suffice.
46+ In practice, there is big troubles with the headers. If you
47+have glibc and kernel 2.2.X headers, that should be all
48+right. Depending on which version of the kernel headers (might be
49+different from kernel) and library headers you have, you need to play
50+with the options buried in iwcommon.h.
51+ Note : as some internal data structures change from kernel to
52+kernel, you are advised to not use the precompiled version but to
53+recompile your own.
54+ "xwireless" is not currently in a compilable state.
2555
56+Installation :
57+------------
58+ I advise to copy the executable (iwconfig, iwspy and iwpriv)
59+in /usr/local/bin or /usr/local/sbin. The man pages (iwconfig.8,
60+iwspy.8 and iwpriv.8) should be copied in /usr/local/man/man8 or
61+/usr/man/man8.
2662
27-This package was originally created by:
28-
29- Jean <jt@hpl.hp.com>
3063
31-And is now being maintained by:
32- Justin Seger <jseger@media.mit.edu>
64+List of contributors and changelog is in iwcommon.h.
3365
34-It seem that I've been taking over !
3566 Jean <jt@hpl.hp.com>
--- a/wireless_tools/README
+++ b/wireless_tools/README
@@ -3,29 +3,47 @@ the Wireless Extensions. The Wireless Extension is an interface
33 allowing you to set Wireless LAN specific parameters and get the
44 specific stats.
55
6+INSTALL
7+-------
8+ Installation instruction and requirements.
9+
10+man pages (iwconfig.8, iwpriv.8, iwspy.8)
11+---------
12+ As far as I know, the man pages are the most complete, up to
13+date and accurate documentation of the wireless tools, and you really
14+should read them.
15+ They can either be copied in a location where the command
16+"man" will find them, or can be read with the command :
17+ nroff -man xxx.8 | more
18+
19+web page
20+--------
21+ You'll find a lot of useful info on :
22+ http://web.hpl.hp.com/personal/Jean_Tourrilhes/Linux/
23+
624 iwconfig.c
725 ----------
8- The main wireless tool. Used for device configuration.
9- You need of course to compile it.
10- This also includes the functionality previously contained in iwpriv.c.
11- It allows you to access device specific extensions.
26+ The main wireless tool. Used for device configuration and to see
27+ the most common parameters.
1228
1329 iwspy.c
1430 -------
1531 Mobile IP support test and allow get get stats per MAC address
16- (instead of globally).
32+ (instead of globally). Also display available bit rates and
33+ frequencies.
1734
1835 iwpriv.c
1936 --------
20- Manipulate driver private ioctls.
37+ Manipulate driver private ioctls (all that is not available in
38+ iwconfig). These are device specific parameters.
2139
2240 xwireless.c
2341 -----------
2442 Graphical tool for the Netwave created by Dag Brattli <dagb@cs.uit.no>
2543
2644
27- The man page should describe adequately the behaviour of the tools.
2845 The list of changes, credits and errata notes are in
29-iwcommon.h. Compilation might be tricky.
46+iwcommon.h. Compilation might be tricky, see iwcommon.h for header
47+problems...
3048
3149 Jean <jt@hpl.hp.com>
--- a/wireless_tools/compat.h
+++ /dev/null
@@ -1,96 +0,0 @@
1-/* This whole file is flaky */
2-/* This is all we need to compile and can't find only in linux headers.
3- * So, I did copy past here...
4- */
5-#define __u8 unsigned char
6-#define __u16 unsigned short
7-#define __u32 unsigned long /* Hum, and on Alpha ? */
8-#define __u64 unsigned long long /* Unsure about this one */
9-
10-#define IFNAMSIZ 16
11-#define ARPHRD_ETHER 1 /* Ethernet 10Mbps */
12-#define ETH_ALEN 6 /* Octets in one ethernet addr */
13-
14-/*
15- * Interface request structure used for socket
16- * ioctl's. All interface ioctl's must have parameter
17- * definitions which begin with ifr_name. The
18- * remainder may be interface specific.
19- */
20-struct ifreq
21-{
22-#define IFHWADDRLEN 6
23-#define IFNAMSIZ 16
24- union
25- {
26- char ifrn_name[IFNAMSIZ]; /* if name, e.g. "en0" */
27- } ifr_ifrn;
28-
29- union {
30- struct sockaddr ifru_addr;
31- struct sockaddr ifru_dstaddr;
32- struct sockaddr ifru_broadaddr;
33- struct sockaddr ifru_netmask;
34- struct sockaddr ifru_hwaddr;
35- short ifru_flags;
36- int ifru_metric;
37- int ifru_mtu;
38-#if 0
39- struct ifmap ifru_map;
40-#endif
41- char ifru_slave[IFNAMSIZ]; /* Just fits the size */
42- caddr_t ifru_data;
43- } ifr_ifru;
44-};
45-#define ifr_name ifr_ifrn.ifrn_name /* interface name */
46-#define ifr_hwaddr ifr_ifru.ifru_hwaddr /* MAC address */
47-#define ifr_addr ifr_ifru.ifru_addr /* address */
48-
49-/*
50- * Structure used in SIOCGIFCONF request.
51- * Used to retrieve interface configuration
52- * for machine (useful for programs which
53- * must know all networks accessible).
54- */
55-struct ifconf
56-{
57- int ifc_len; /* size of buffer */
58- union
59- {
60- caddr_t ifcu_buf;
61- struct ifreq *ifcu_req;
62- } ifc_ifcu;
63-};
64-#define ifc_buf ifc_ifcu.ifcu_buf /* buffer address */
65-#define ifc_req ifc_ifcu.ifcu_req /* array of structures */
66-
67-/* Internet address. */
68-struct in_addr {
69- __u32 s_addr;
70-};
71-
72-/* Address to accept any incoming messages. */
73-#define INADDR_ANY ((unsigned long int) 0x00000000)
74-
75-/* Structure describing an Internet (IP) socket address. */
76-#define __SOCK_SIZE__ 16 /* sizeof(struct sockaddr) */
77-struct sockaddr_in {
78- short int sin_family; /* Address family */
79- unsigned short int sin_port; /* Port number */
80- struct in_addr sin_addr; /* Internet address */
81-
82- /* Pad to size of `struct sockaddr'. */
83- unsigned char __pad[__SOCK_SIZE__ - sizeof(short int) -
84- sizeof(unsigned short int) - sizeof(struct in_addr)];
85-};
86-
87-#define ATF_COM 0x02 /* completed entry (ha valid) */
88-/* ARP ioctl request. */
89-struct arpreq {
90- struct sockaddr arp_pa; /* protocol address */
91- struct sockaddr arp_ha; /* hardware address */
92- int arp_flags; /* flags */
93- struct sockaddr arp_netmask; /* netmask (only for proxy arps) */
94- char arp_dev[16];
95-};
96-
--- a/wireless_tools/iwcommon.h
+++ b/wireless_tools/iwcommon.h
@@ -68,6 +68,27 @@
6868 * o I think I now got set/get char strings right in [iwpriv]
6969 * (From Thomas Ekstrom <tomeck@thelogic.com>)
7070 * o Fix a very obscure bug in [iwspy]
71+ *
72+ * wireless 20 :
73+ * -----------
74+ * (From Jean Tourrilhes)
75+ * o Remove all #ifdef WIRELESS ugliness, but add a #error :
76+ * we require Wireless Extensions 9 or nothing ! [all]
77+ * o Switch to new 'nwid' definition (specific -> iw_param) [iwconfig]
78+ * o Rewriten totally the encryption support [iwconfig]
79+ * - Multiple keys, through key index
80+ * - Flexible/multiple key size, and remove 64bits upper limit
81+ * - Open/Restricted modes
82+ * - Enter keys as ASCII strings
83+ * o List key sizes supported and all keys in [iwspy]
84+ * o Mode of operation support (ad-hoc, managed...) [iwconfig]
85+ * o Use '=' to indicate fixed instead of ugly '(f)' [iwconfig]
86+ * o Ability to disable RTS & frag (off), now the right way [iwconfig]
87+ * o Auto as an input modifier for bitrate [iwconfig]
88+ * o Power Management support [iwconfig]
89+ * - set timeout or period and its value
90+ * - Reception mode (unicast/multicast/all)
91+ * o Updated man pages with all that ;-)
7192 */
7293
7394 /* ----------------------------- TODO ----------------------------- */
@@ -76,11 +97,14 @@
7697 *
7798 * iwconfig :
7899 * --------
79- * Use new 802.11 parameters (rate, rts, frag)...
100+ * Make disable a per encryption key modifier if some hardware
101+ * requires it.
102+ * Should not mention "Access Point" but something different when
103+ * in ad-hoc mode.
80104 *
81105 * iwpriv :
82106 * ------
83- * ?
107+ * Remove 'port' and 'roam' cruft now that we have mode in iwconfig
84108 *
85109 * iwspy :
86110 * -----
@@ -88,7 +112,11 @@
88112 *
89113 * Doc & man pages :
90114 * ---------------
91- * ?
115+ * Update main doc.
116+ *
117+ * Other :
118+ * -----
119+ * What about some graphical tools ?
92120 */
93121
94122 /***************************** INCLUDES *****************************/
@@ -109,53 +137,39 @@
109137 /* This is our header selection. Try to hide the mess and the misery :-(
110138 * Please choose only one of the define...
111139 */
112-#define KER2_2_HEADERS /* Kernel 2.2.X + Glibc - ok for most people */
113-#undef LINUX_HEADERS /* Kernel 2.0.X + Glibc - Debian 2.0, RH5 */
114-#undef LIBC5_HEADERS /* Kernel 2.0.X + libc5 - old systems */
115-#undef PRIVATE_HEADERS /* Ugly last resort case */
140+/* Kernel headers 2.0.X + Glibc 2.0 - Debian 2.0, RH5
141+ * Kernel headers 2.2.X + Glibc 2.1 - Debian 2.2, RH6.1 */
142+#define GLIBC_HEADERS
116143
117-#ifdef KER2_2_HEADERS
118-#include <socketbits.h>
119-#include <linux/if_arp.h> /* For ARPHRD_ETHER */
120-#include <linux/socket.h> /* For AF_INET & struct sockaddr */
121-#include <linux/in.h> /* For struct sockaddr_in */
144+/* Kernel headers 2.2.X + Glibc 2.0 - Debian 2.1 */
145+#undef KLUDGE_HEADERS
122146
123-/* Wireless extensions */
124-#include <linux/wireless.h>
147+/* Kernel headers 2.0.X + libc5 - old systems */
148+#undef LIBC5_HEADERS
125149
126-#endif /* KER2_2_HEADERS */
150+#ifdef KLUDGE_HEADERS
151+#include <socketbits.h>
152+#endif /* KLUDGE_HEADERS */
127153
128-#ifdef LINUX_HEADERS
154+#if defined(KLUDGE_HEADERS) || defined(GLIBC_HEADERS)
129155 #include <linux/if_arp.h> /* For ARPHRD_ETHER */
130156 #include <linux/socket.h> /* For AF_INET & struct sockaddr */
131157 #include <linux/in.h> /* For struct sockaddr_in */
132-
133-/* Wireless extensions */
134-#include <linux/wireless.h>
135-
136-#endif /* LINUX_HEADERS */
158+#endif /* KLUDGE_HEADERS || GLIBC_HEADERS */
137159
138160 #ifdef LIBC5_HEADERS
139161 #include <sys/socket.h> /* For AF_INET & struct sockaddr & socket() */
140162 #include <linux/if_arp.h> /* For ARPHRD_ETHER */
141163 #include <linux/in.h> /* For struct sockaddr_in */
142-
143-/* Wireless extensions */
144-#include <linux/wireless.h>
145-
146164 #endif /* LIBC5_HEADERS */
147165
148-#ifdef PRIVATE_HEADERS
149-#include <sys/types.h>
150-#include <sys/socket.h>
151-#include <socketbits.h>
152-#include "compat.h" /* Don't ask ! */
153-
154166 /* Wireless extensions */
155-#include "wireless.h"
156-
157-#endif /* PRIVATE_HEADERS */
167+#include <linux/wireless.h>
158168
169+#if WIRELESS_EXT < 8
170+#error "Wireless Extension v9 or newer required :-(\n\
171+Use Wireless Tools v19 or update your kernel headers"
172+#endif
159173
160174 /****************************** DEBUG ******************************/
161175
@@ -167,19 +181,12 @@
167181 #define MEGA 1e6
168182 #define GIGA 1e9
169183
170-/* Some hack */
171-#ifndef IW_ESSID_MAX_SIZE
172-#define IW_ESSID_MAX_SIZE 32 /* Should be in wireless.h */
173-#endif
174-#ifndef IW_MAX_AP
175-#define IW_MAX_AP 8 /* Should be in wireless.h */
176-#endif
177-
178184 /****************************** TYPES ******************************/
179185
180186 /* Shortcuts */
181187 typedef struct iw_statistics iwstats;
182188 typedef struct iw_range iwrange;
189+typedef struct iw_param iwparam;
183190 typedef struct iw_freq iwfreq;
184191 typedef struct iw_priv_args iwprivargs;
185192 typedef struct sockaddr sockaddr;
@@ -189,15 +196,15 @@ typedef struct wireless_info
189196 {
190197 char name[IFNAMSIZ]; /* Wireless/protocol name */
191198 int has_nwid;
192- int nwid_on;
193- u_long nwid; /* Network ID */
199+ iwparam nwid; /* Network ID */
194200 int has_freq;
195201 float freq; /* Frequency/channel */
196202 int has_sens;
197- int sens; /* sensitivity */
198- int has_enc;
199- int enc_method; /* encoding method or off */
200- long long enc_key; /* key used */
203+ iwparam sens; /* sensitivity */
204+ int has_key;
205+ unsigned char key[IW_ENCODING_TOKEN_MAX]; /* Encoding key used */
206+ int key_size; /* Number of bytes */
207+ int key_flags; /* Various flags */
201208 int has_essid;
202209 int essid_on;
203210 char essid[IW_ESSID_MAX_SIZE + 1]; /* ESSID (extended network) */
@@ -206,14 +213,15 @@ typedef struct wireless_info
206213 int has_ap_addr;
207214 sockaddr ap_addr; /* Access point address */
208215 int has_bitrate;
209- long bitrate; /* Bit rate in bps */
210- int bitrate_fixed; /* Fixed or auto */
216+ iwparam bitrate; /* Bit rate in bps */
211217 int has_rts;
212- long rts; /* RTS threshold in bytes */
213- int rts_fixed; /* Fixed or auto */
218+ iwparam rts; /* RTS threshold in bytes */
214219 int has_frag;
215- long frag; /* Fragmentation threshold in bytes */
216- int frag_fixed; /* Fixed or auto */
220+ iwparam frag; /* Fragmentation threshold in bytes */
221+ int has_mode;
222+ int mode; /* Operation mode */
223+ int has_power;
224+ iwparam power; /* Power management parameters */
217225
218226 /* Stats */
219227 iwstats stats;
Binary files a/wireless_tools/iwconfig and /dev/null differ
--- a/wireless_tools/iwconfig.8
+++ b/wireless_tools/iwconfig.8
@@ -15,9 +15,11 @@ iwconfig \- configure a wireless network interface
1515 .br
1616 .BI "iwconfig " interface " [essid " X "] [nwid " N "] [freq " F "] [channel " C ]
1717 .br
18-.BI " [sens " S "] [enc " E "] [ap " A "] [nick " NN ]
18+.BI " [sens " S "] [mode " M "] [ap " A "] [nick " NN ]
1919 .br
2020 .BI " [rate " R "] [rts " RT "] [frag " FT ]
21+.br
22+.BI " [enc " E "] [key " K "] [power " P ]
2123 .\"
2224 .\" DESCRIPTION part
2325 .\"
@@ -51,8 +53,14 @@ As opposed to the NWID which defines a single cell, the ESSID defines
5153 a group of cell connected via repeaters or infrastructure, where the
5254 user may roam. With some card, you may disable the ESSID checking
5355 (ESSID promiscuous) with
54-.IR off " (and " on
56+.IR off " or " any " (and " on
5557 to reenable it).
58+.br
59+.B Examples :
60+.br
61+.I " iwconfig eth0 essid any"
62+.br
63+.I " iwconfig eth0 essid ""My Network""
5664 .TP
5765 .BR nwid / domain
5866 Set the Network ID (in some products it is also called Domain ID). As
@@ -62,11 +70,17 @@ identify nodes belonguing to the same cell. With some card, you may
6270 disable the Network ID checking (NWID promiscuous) with
6371 .IR off " (and " on
6472 to reenable it).
73+.br
74+.B Examples :
75+.br
76+.I " iwconfig eth0 nwid AB34
77+.br
78+.I " iwconfig eth0 nwid off"
6579 .TP
6680 .BR freq / channel
6781 Set the operating frequency or channel in the device. Value below 1000
6882 are the channel number, value over this is the frequency in Hz. You
69-must prepend the suffix k, M or G to the value (for example, "2.46G"
83+must append the suffix k, M or G to the value (for example, "2.46G"
7084 for 2.46 GHz frequency), or add enough '0'.
7185 .br
7286 Channels are usually numbered starting at 1,
@@ -75,6 +89,12 @@ and you may use
7589 to get the total number of channels and list the available
7690 frequencies. Depending on regulations, some frequencies/channels may
7791 not be available.
92+.br
93+.B Examples :
94+.br
95+.I " iwconfig eth0 freq 2.422G"
96+.br
97+.I " iwconfig eth0 channel 3"
7898 .TP
7999 .B sens
80100 Set the sensitivity threshold. This is the lowest signal level for
@@ -88,40 +108,73 @@ With some hardware, this parameter also control the defer threshold
88108 (lowest signal level for which we consider the channel busy) and the
89109 handover threshold (lowest signal level where we stay associated with
90110 the current access point).
111+.br
112+.B Example :
113+.br
114+.I " iwconfig eth0 sens -80"
91115 .TP
92-.B enc
93-Set the encryption or scrambing key (the syntax is
94-.IR XXXX-XXXX-XXXX-XXXX " or " XXXXXXXX ).
95-Used also to control the encryption feature
96-.RI ( on / off ).
116+.B mode
117+Set the operating mode of the device, which depends on the network
118+topology. The mode can be
119+.I Ad-hoc
120+(network composed of only one cell and without Access Point),
121+.I Managed
122+(network composed of many cells, with roaming or with an Access Point),
123+.I Master
124+(the node is the synchronisation master or act as an Access Point),
125+.I Repeater
126+(the node forward packets on the air),
127+.I Secondary
128+(the node act as a backup master/repeater) or
129+.IR Auto .
130+.br
131+.B Example :
132+.br
133+.I " iwconfig eth0 mode Managed"
97134 .TP
98135 .B ap
99136 Register to the Access Point given by the address, if it is
100137 possible. When the quality of the connection goes too low, the driver
101138 may revert back to automatic mode.
139+.br
140+.B Example :
141+.br
142+.I " iwconfig eth0 ap 00:60:1D:01:23:45"
102143 .TP
103-.BR nick [ name ]
144+.BR nick [name]
104145 Set the nickname, or the station name. Most 802.11 products do define
105146 it, but this is not used as far as the protocols (MAC, IP, TCP) are
106147 concerned and completely accessory as far as configuration goes. In
107148 fact only some diagnostic tools may use it.
149+.br
150+.B Example :
151+.br
152+.I " iwconfig eth0 nickname ""My Linux Node""
108153 .TP
109-.BR rate / bit [ rate ]
154+.BR rate / bit [rate]
110155 For cards supporting multiple bit rates, set the bit-rate in b/s. The
111156 bit-rate is the speed at which bits are transmitted over the medium,
112157 the user speed of the link is lower due to medium sharing and
113158 overhead.
114159 .br
115-You must prepend the suffix k, M or G to the value (decimal multiplier
160+You must append the suffix k, M or G to the value (decimal multiplier
116161 : 10^3, 10^6 and 10^9 b/s), or add enough '0'. Values below 1000 are
117162 card specific, usually an index in the bit-rate list. Use
118163 .I auto
119164 to select the automatic bit-rate mode (fallback to lower rate on noisy
120165 channels), which is the default for most cards, and
121166 .I fixed
122-to revert back to fixed setting.
167+to revert back to fixed setting. If you specify a bit-rate value and append
168+.IR auto ,
169+the driver will use all bit lower and equal than this value.
170+.br
171+.B Examples :
172+.br
173+.I " iwconfig eth0 rate 11M"
174+.br
175+.I " iwconfig eth0 rate auto"
123176 .TP
124-.BR rts [ _threshold ]
177+.BR rts [_threshold]
125178 RTS/CTS adds a handshake before each packet transmission to make sure
126179 that the channel is clear. This adds overhead, but increase
127180 performance in case of hidden nodes or large number of active
@@ -129,14 +182,89 @@ nodes. This parameters set the size of the smallest packet for which
129182 the node sends RTS, a value equal to the maximum packet size disable
130183 the scheme. You may also set this parameter to
131184 .IR auto ", " fixed " or " off .
185+.br
186+.B Examples :
187+.br
188+.I " iwconfig eth0 rts 250"
189+.br
190+.I " iwconfig eth0 rts off"
132191 .TP
133-.BR frag [ mentation_threshold ]
192+.BR frag [mentation_threshold]
134193 Fragmentation allow to split a IP packet in a burst of smaller
135194 fragments transmitted on the medium. In most cases this adds overhead,
136195 but in very noisy environment this reduce the error penalty. This
137196 parameter set the maximum fragment size, a value equal to the maximum
138197 packet size disable the scheme. You may also set this parameter to
139198 .IR auto ", " fixed " or " off .
199+.br
200+.B Examples :
201+.br
202+.I " iwconfig eth0 frag 512"
203+.br
204+.I " iwconfig eth0 frag off"
205+.TP
206+.BR key / enc [ryption]
207+Used to manipulate encryption or scrambling keys and encryption mode.
208+.br
209+To set the current encryption key, just enter the key in hex digits as
210+.IR XXXX-XXXX-XXXX-XXXX " or " XXXXXXXX .
211+To set a key other than the current key, append
212+.I [index]
213+to the key itself. You can also enter the key as an ASCII string by
214+using the
215+.I s:
216+prefix.
217+.br
218+To change which key is the current active key, just enter
219+.I [index]
220+(without entering any key value).
221+.br
222+.IR off " and " on
223+disable and reenable encryption,
224+.I open
225+set the system in open mode (accept non-encrypted packets) and
226+.I restricted
227+discard non-encrypted packets.
228+.br
229+.B Examples :
230+.br
231+.I " iwconfig eth0 key 0123-4567-89"
232+.br
233+.I " iwconfig eth0 key s:password [2]"
234+.br
235+.I " iwconfig eth0 key [2] open"
236+.br
237+.I " iwconfig eth0 key off"
238+.TP
239+.BR power
240+Used to manipulate power management scheme parameters and mode.
241+.br
242+To set the period between wake up, enter
243+.IR "period `value'" .
244+To set the timeout before going back to sleep, enter
245+.IR "timeout `value'" .
246+By defaults, those values are in seconds, append the suffix m or u to
247+specify values un milliseconds or microseconds.
248+.br
249+.IR off " and " on
250+disable and reenable power management. Finally, you may set the power
251+management mode to
252+.I all
253+(receive all packets),
254+.I unicast
255+(receive unicast packets only, discard multicast and broadcast) and
256+.I multicast
257+(receive multicast and broadcast only, discard unicast packets).
258+.br
259+.B Examples :
260+.br
261+.I " iwconfig eth0 power period 2"
262+.br
263+.I " iwconfig eth0 power 500m unicast"
264+.br
265+.I " iwconfig eth0 power timeout 300u all"
266+.br
267+.I " iwconfig eth0 power off"
140268 .\"
141269 .\" DISPLAY part
142270 .\"
@@ -154,16 +282,27 @@ the
154282 (or channel), the
155283 .BR sensitivity ,
156284 the
285+.B mode
286+of operation, the
157287 .B Access Point
158288 address, the
159289 .B bit-rate
160-(with
161-.B (f)
162-if fixed), the
290+the
163291 .BR "RTS threshold" ", the " "fragmentation threshold" ,
164-and the
292+the
165293 .B encryption key
166-(depending on availability). See above for explanations.
294+and the
295+.B power management
296+settings (depending on availability).
297+.br
298+See above for explanations of what these parameters mean.
299+.br
300+If the label for bitrate is followed by
301+.RB ` = ',
302+it means that the parameter is fixed and forced to that value, if it
303+is followed by
304+.RB ` : '
305+it is only the current value (device in normal auto mode).
167306 .PP
168307 If
169308 .I /proc/net/wireless
@@ -172,7 +311,8 @@ exists,
172311 will also display its content :
173312 .TP
174313 .B Link quality
175-Quality of the link or the modulation (how good the received signal is).
314+Quality of the link or the modulation (what is the level of contention
315+or interference, or how good the received signal is).
176316 .TP
177317 .B Signal level
178318 Received signal strength (how strong the received signal is).
@@ -193,7 +333,7 @@ Other packets lost in relation with specific wireless operations.
193333 .\" AUTHOR part
194334 .\"
195335 .SH AUTHOR
196-Jean Tourrilhes \- jt@hplb.hpl.hp.com
336+Jean Tourrilhes \- jt@hpl.hp.com
197337 .\"
198338 .\" FILES part
199339 .\"
--- a/wireless_tools/iwconfig.c
+++ b/wireless_tools/iwconfig.c
@@ -10,6 +10,14 @@
1010
1111 #include "iwcommon.h" /* Header */
1212
13+/**************************** VARIABLES ****************************/
14+char * operation_mode[] = { "Auto",
15+ "Ad-Hoc",
16+ "Managed",
17+ "Master",
18+ "Repeater",
19+ "Secondary" };
20+
1321 /************************* MISC SUBROUTINES **************************/
1422
1523 /*------------------------------------------------------------------*/
@@ -43,40 +51,59 @@ static int
4351 iw_getstats(char * ifname,
4452 iwstats * stats)
4553 {
46- FILE *f=fopen("/proc/net/wireless","r");
47- char buf[256];
48- char *bp;
54+ FILE * f=fopen("/proc/net/wireless","r");
55+ char buf[256];
56+ char * bp;
57+ int t;
4958 if(f==NULL)
50- return -1;
59+ return -1;
60+ /* Loop on all devices */
5161 while(fgets(buf,255,f))
52- {
53- bp=buf;
54- while(*bp&&isspace(*bp))
55- bp++;
56- if(strncmp(bp,ifname,strlen(ifname))==0 && bp[strlen(ifname)]==':')
62+ {
63+ bp=buf;
64+ while(*bp&&isspace(*bp))
65+ bp++;
66+ /* Is it the good device ? */
67+ if(strncmp(bp,ifname,strlen(ifname))==0 && bp[strlen(ifname)]==':')
5768 {
58- bp=strchr(bp,':');
59- bp++;
60- bp = strtok(bp, " .");
61- sscanf(bp, "%X", (unsigned int *)&stats->status);
62- bp = strtok(NULL, " .");
63- sscanf(bp, "%d", (unsigned int *)&stats->qual.qual);
64- bp = strtok(NULL, " .");
65- sscanf(bp, "%d", (unsigned int *)&stats->qual.level);
66- bp = strtok(NULL, " .");
67- sscanf(bp, "%d", (unsigned int *)&stats->qual.noise);
68- bp = strtok(NULL, " .");
69- sscanf(bp, "%d", &stats->discard.nwid);
70- bp = strtok(NULL, " .");
71- sscanf(bp, "%d", &stats->discard.code);
72- bp = strtok(NULL, " .");
73- sscanf(bp, "%d", &stats->discard.misc);
74- fclose(f);
75- return 0;
69+ /* Skip ethX: */
70+ bp=strchr(bp,':');
71+ bp++;
72+ /* -- status -- */
73+ bp = strtok(bp, " ");
74+ sscanf(bp, "%X", &t);
75+ stats->status = (unsigned short) t;
76+ /* -- link quality -- */
77+ bp = strtok(NULL, " ");
78+ if(strchr(bp,'.') != NULL)
79+ stats->qual.updated |= 1;
80+ sscanf(bp, "%d", &t);
81+ stats->qual.qual = (unsigned char) t;
82+ /* -- signal level -- */
83+ bp = strtok(NULL, " ");
84+ if(strchr(bp,'.') != NULL)
85+ stats->qual.updated |= 2;
86+ sscanf(bp, "%d", &t);
87+ stats->qual.level = (unsigned char) t;
88+ /* -- noise level -- */
89+ bp = strtok(NULL, " ");
90+ if(strchr(bp,'.') != NULL)
91+ stats->qual.updated += 4;
92+ sscanf(bp, "%d", &t);
93+ stats->qual.noise = (unsigned char) t;
94+ /* -- discarded packets -- */
95+ bp = strtok(NULL, " ");
96+ sscanf(bp, "%d", &stats->discard.nwid);
97+ bp = strtok(NULL, " ");
98+ sscanf(bp, "%d", &stats->discard.code);
99+ bp = strtok(NULL, " ");
100+ sscanf(bp, "%d", &stats->discard.misc);
101+ fclose(f);
102+ return 0;
76103 }
77- }
104+ }
78105 fclose(f);
79- return 0;
106+ return -1;
80107 }
81108
82109 /*------------------------------------------------------------------*/
@@ -107,8 +134,7 @@ get_info(int skfd,
107134 if(ioctl(skfd, SIOCGIWNWID, &wrq) >= 0)
108135 {
109136 info->has_nwid = 1;
110- info->nwid_on = wrq.u.nwid.on;
111- info->nwid = wrq.u.nwid.nwid;
137+ memcpy(&(info->nwid), &(wrq.u.nwid), sizeof(iwparam));
112138 }
113139
114140 /* Get frequency / channel */
@@ -124,24 +150,26 @@ get_info(int skfd,
124150 if(ioctl(skfd, SIOCGIWSENS, &wrq) >= 0)
125151 {
126152 info->has_sens = 1;
127- info->sens = wrq.u.sensitivity;
153+ memcpy(&(info->sens), &(wrq.u.sens), sizeof(iwparam));
128154 }
129155
130- /* Get encryption information */
131- strcpy(wrq.ifr_name, ifname);
132- if(ioctl(skfd, SIOCGIWENCODE, &wrq) >= 0)
133- {
134- info->has_enc = 1;
135- info->enc_method = wrq.u.encoding.method;
136- info->enc_key = wrq.u.encoding.code;
137- }
138-
139-#if WIRELESS_EXT > 5
140- /* Get ESSID */
156+ /* Get encryption information */
141157 strcpy(wrq.ifr_name, ifname);
142- wrq.u.data.pointer = (caddr_t) info->essid;
158+ wrq.u.data.pointer = (caddr_t) info->key;
143159 wrq.u.data.length = 0;
144160 wrq.u.data.flags = 0;
161+ if(ioctl(skfd, SIOCGIWENCODE, &wrq) >= 0)
162+ {
163+ info->has_key = 1;
164+ info->key_size = wrq.u.data.length;
165+ info->key_flags = wrq.u.data.flags;
166+ }
167+
168+ /* Get ESSID */
169+ strcpy(wrq.ifr_name, ifname);
170+ wrq.u.essid.pointer = (caddr_t) info->essid;
171+ wrq.u.essid.length = 0;
172+ wrq.u.essid.flags = 0;
145173 if(ioctl(skfd, SIOCGIWESSID, &wrq) >= 0)
146174 {
147175 info->has_essid = 1;
@@ -155,14 +183,12 @@ get_info(int skfd,
155183 info->has_ap_addr = 1;
156184 memcpy(&(info->ap_addr), &(wrq.u.ap_addr), sizeof (sockaddr));
157185 }
158-#endif /* WIRELESS_EXT > 5 */
159186
160-#if WIRELESS_EXT > 7
161187 /* Get NickName */
162188 strcpy(wrq.ifr_name, ifname);
163- wrq.u.data.pointer = (caddr_t) info->nickname;
164- wrq.u.data.length = 0;
165- wrq.u.data.flags = 0;
189+ wrq.u.essid.pointer = (caddr_t) info->nickname;
190+ wrq.u.essid.length = 0;
191+ wrq.u.essid.flags = 0;
166192 if(ioctl(skfd, SIOCGIWNICKN, &wrq) >= 0)
167193 if(wrq.u.data.length > 1)
168194 info->has_nickname = 1;
@@ -172,8 +198,7 @@ get_info(int skfd,
172198 if(ioctl(skfd, SIOCGIWRATE, &wrq) >= 0)
173199 {
174200 info->has_bitrate = 1;
175- info->bitrate_fixed = wrq.u.bitrate.fixed;
176- info->bitrate = wrq.u.bitrate.value;
201+ memcpy(&(info->bitrate), &(wrq.u.bitrate), sizeof(iwparam));
177202 }
178203
179204 /* Get RTS threshold */
@@ -181,22 +206,36 @@ get_info(int skfd,
181206 if(ioctl(skfd, SIOCGIWRTS, &wrq) >= 0)
182207 {
183208 info->has_rts = 1;
184- info->rts_fixed = wrq.u.rts.fixed;
185- info->rts = wrq.u.rts.value;
209+ memcpy(&(info->rts), &(wrq.u.rts), sizeof(iwparam));
186210 }
187211
188- /* Get fragmentation thershold */
212+ /* Get fragmentation threshold */
189213 strcpy(wrq.ifr_name, ifname);
190214 if(ioctl(skfd, SIOCGIWFRAG, &wrq) >= 0)
191215 {
192216 info->has_frag = 1;
193- info->frag_fixed = wrq.u.frag.fixed;
194- info->frag = wrq.u.frag.value;
217+ memcpy(&(info->frag), &(wrq.u.frag), sizeof(iwparam));
218+ }
219+
220+ /* Get operation mode */
221+ strcpy(wrq.ifr_name, ifname);
222+ if(ioctl(skfd, SIOCGIWMODE, &wrq) >= 0)
223+ {
224+ if((wrq.u.mode < 6) && (wrq.u.mode >= 0))
225+ info->has_mode = 1;
226+ info->mode = wrq.u.mode;
227+ }
228+
229+ /* Get Power Management settings */
230+ strcpy(wrq.ifr_name, ifname);
231+ if(ioctl(skfd, SIOCGIWPOWER, &wrq) >= 0)
232+ {
233+ info->has_power = 1;
234+ memcpy(&(info->power), &(wrq.u.power), sizeof(iwparam));
195235 }
196-#endif /* WIRELESS_EXT > 7 */
197236
198237 /* Get stats */
199- if(iw_getstats(ifname, &(info->stats)) == 0)
238+ if(iw_getstats(ifname, &(info->stats)) >= 0)
200239 {
201240 info->has_stats = 1;
202241 }
@@ -242,10 +281,10 @@ display_info(struct wireless_info * info,
242281 {
243282 /* Note : should display right number of digit according to info
244283 * in range structure */
245- if(info->nwid_on)
246- printf("NWID:%lX ", info->nwid);
247- else
284+ if(info->nwid.disabled)
248285 printf("NWID:off/any ");
286+ else
287+ printf("NWID:%X ", info->nwid.value);
249288 }
250289
251290 /* Display frequency / channel */
@@ -270,14 +309,31 @@ display_info(struct wireless_info * info,
270309 /* Display sensitivity */
271310 if(info->has_sens)
272311 {
312+ /* Fixed ? */
313+ if(info->sens.fixed)
314+ printf("Sensitivity=");
315+ else
316+ printf("Sensitivity:");
317+
273318 if(info->has_range)
274319 /* Display in dBm ? */
275- if(info->sens < 0)
276- printf("Sensitivity:%d dBm ", info->sens);
320+ if(info->sens.value < 0)
321+ printf("%d dBm ", info->sens.value);
277322 else
278- printf("Sensitivity:%d/%d ", info->sens, info->range.sensitivity);
323+ printf("%d/%d ", info->sens.value, info->range.sensitivity);
279324 else
280- printf("Sensitivity:%d ", info->sens);
325+ printf("%d ", info->sens.value);
326+ }
327+
328+ /* Display the current mode of operation */
329+ if(info->has_mode)
330+ {
331+ /* A bit of clever formatting */
332+ if((info->has_nwid + 2*info->has_freq + 2*info->has_sens
333+ + !info->has_essid) > 4)
334+ printf("\n ");
335+
336+ printf("Mode:%s ", operation_mode[info->mode]);
281337 }
282338
283339 /* Display the address of the current Access Point */
@@ -285,7 +341,7 @@ display_info(struct wireless_info * info,
285341 {
286342 /* A bit of clever formatting */
287343 if((info->has_nwid + 2*info->has_freq + 2*info->has_sens
288- + !info->has_essid) > 3)
344+ + info->has_mode + !info->has_essid) > 3)
289345 printf("\n ");
290346
291347 printf("Access Point: %s", pr_ether(info->ap_addr.sa_data));
@@ -296,78 +352,148 @@ display_info(struct wireless_info * info,
296352 /* Display the currently used/set bit-rate */
297353 if(info->has_bitrate)
298354 {
299- printf("Bit Rate:");
300- if(info->bitrate >= GIGA)
301- printf("%g Gb/s", info->bitrate / GIGA);
355+ /* Fixed ? */
356+ if(info->bitrate.fixed)
357+ printf("Bit Rate=");
302358 else
303- if(info->bitrate >= MEGA)
304- printf("%g Mb/s", info->bitrate / MEGA);
305- else
306- printf("%g kb/s", info->bitrate / KILO);
359+ printf("Bit Rate:");
307360
308- /* Fixed ? */
309- if(info->bitrate_fixed)
310- printf(" (f) ");
361+ if(info->bitrate.value >= GIGA)
362+ printf("%gGb/s", info->bitrate.value / GIGA);
311363 else
312- printf(" ");
364+ if(info->bitrate.value >= MEGA)
365+ printf("%gMb/s", info->bitrate.value / MEGA);
366+ else
367+ printf("%gkb/s", info->bitrate.value / KILO);
368+ printf(" ");
313369 }
314370
315371 /* Display the RTS threshold */
316372 if(info->has_rts)
317373 {
318- printf("RTS thr:%ld B", info->rts);
319-
320- /* Fixed ? */
321- if(info->rts_fixed)
322- printf(" (f) ");
374+ /* Disabled ? */
375+ if(info->rts.disabled)
376+ printf("RTS thr:off ");
323377 else
324- printf(" ");
378+ {
379+ /* Fixed ? */
380+ if(info->rts.fixed)
381+ printf("RTS thr=");
382+ else
383+ printf("RTS thr:");
384+
385+ printf("%d B ", info->rts.value);
386+ }
325387 }
326388
327389 /* Display the fragmentation threshold */
328- if(info->has_bitrate)
390+ if(info->has_frag)
329391 {
330- printf("Frag thr:%ld B", info->frag);
331-
332- /* Fixed ? */
333- if(info->frag_fixed)
334- printf(" (f) ");
392+ /* Disabled ? */
393+ if(info->frag.disabled)
394+ printf("Fragment thr:off ");
335395 else
336- printf(" ");
396+ {
397+ /* Fixed ? */
398+ if(info->frag.fixed)
399+ printf("Fragment thr=");
400+ else
401+ printf("Fragment thr:");
402+
403+ printf("%d B ", info->frag.value);
404+ }
337405 }
338406
339407 /* Formating */
340408 if((info->has_bitrate) || (info->has_rts) || (info->has_bitrate))
341409 printf("\n ");
342410
343- if(info->has_enc)
411+ /* Display encryption information */
412+ /* Note : we display only the "current" key, use iwspy to list all keys */
413+ if(info->has_key)
344414 {
345415 printf("Encryption key:");
346- if(info->enc_method)
416+ if((info->key_flags & IW_ENCODE_DISABLED) || (info->key_size == 0))
417+ printf("off\n ");
418+ else
347419 {
348- int i = 0;
349- u_short parts[4];
350- long long key = info->enc_key;
420+ int i;
351421
352- for(i = 3; i >= 0; i--)
422+ printf("%.2X", info->key[0]);
423+ for(i = 1; i < info->key_size; i++)
353424 {
354- parts[i] = key & 0xFFFF;
355- key >>= 16;
425+ if((i & 0x1) == 0)
426+ printf("-");
427+ printf("%.2X", info->key[i]);
356428 }
357429
358- i = 0;
359- while((parts[i] == 0) && (i < 3))
360- i++;
361- for(; i < 3; i++)
362- printf("%.4X-", parts[i]);
363- printf("%.4X", parts[3]);
364-
365- if(info->enc_method > 1)
366- printf(" (%d)", info->enc_method);
430+ /* Other info... */
431+ if((info->key_flags & IW_ENCODE_INDEX) > 1)
432+ printf(" [%d]", info->key_flags & IW_ENCODE_INDEX);
433+ if(info->key_flags & IW_ENCODE_RESTRICTED)
434+ printf(" Encryption mode:restricted");
435+ if(info->key_flags & IW_ENCODE_OPEN)
436+ printf(" Encryption mode:open");
367437 printf("\n ");
368438 }
439+ }
440+
441+ /* Display Power Management information */
442+ /* Note : we display only one parameter, period or timeout. If a device
443+ * (such as HiperLan) has both, we would need to be a bit more clever... */
444+ if(info->has_power) /* I hope the device has power ;-) */
445+ {
446+ printf("Power Management");
447+ /* Disabled ? */
448+ if(info->power.disabled)
449+ printf(":off\n ");
369450 else
370- printf("off\n ");
451+ {
452+ /* Let's check the value and its type */
453+ if(info->power.flags & IW_POWER_TYPE)
454+ {
455+ /* Type */
456+ if(info->power.flags & IW_POWER_TIMEOUT)
457+ printf(" timeout:");
458+ else
459+ printf(" period:");
460+
461+ /* Display value with units */
462+ if(info->power.value >= (int) MEGA)
463+ printf("%gs ", ((double) info->power.value) / MEGA);
464+ else
465+ if(info->power.value >= (int) KILO)
466+ printf("%gms ", ((double) info->power.value) / KILO);
467+ else
468+ printf("%dus ", info->power.value);
469+ }
470+
471+ /* Let's check the mode */
472+ switch(info->power.flags & IW_POWER_MODE)
473+ {
474+ case IW_POWER_UNICAST_R:
475+ printf(" mode:Unicast received");
476+ break;
477+ case IW_POWER_MULTICAST_R:
478+ printf(" mode:Multicast received");
479+ break;
480+ case IW_POWER_ALL_R:
481+ printf(" mode:All packets received");
482+ break;
483+ case IW_POWER_FORCE_S:
484+ printf(" mode:Force sending");
485+ break;
486+ case IW_POWER_REPEATER:
487+ printf(" mode:Repeat multicasts");
488+ break;
489+ default:
490+ }
491+
492+ /* Let's check if nothing (simply on) */
493+ if(info->power.flags == IW_POWER_ON)
494+ printf(":on");
495+ printf("\n ");
496+ }
371497 }
372498
373499 if(info->has_stats)
@@ -487,7 +613,7 @@ set_info(int skfd, /* The socket */
487613 iw_usage();
488614 if((!strcasecmp(args[i], "off")) ||
489615 (!strcasecmp(args[i], "any")))
490- wrq.u.nwid.on = 0;
616+ wrq.u.nwid.disabled = 1;
491617 else
492618 if(!strcasecmp(args[i], "on"))
493619 {
@@ -498,14 +624,15 @@ set_info(int skfd, /* The socket */
498624 return(-1);
499625 }
500626 strcpy(wrq.ifr_name, ifname);
501- wrq.u.nwid.on = 1;
627+ wrq.u.nwid.disabled = 0;
502628 }
503629 else
504- if(sscanf(args[i], "%lX", (unsigned long *) &(wrq.u.nwid.nwid))
630+ if(sscanf(args[i], "%lX", (unsigned long *) &(wrq.u.nwid.value))
505631 != 1)
506632 iw_usage();
507633 else
508- wrq.u.nwid.on = 1;
634+ wrq.u.nwid.disabled = 0;
635+ wrq.u.nwid.fixed = 1;
509636
510637 if(ioctl(skfd, SIOCSIWNWID, &wrq) < 0)
511638 {
@@ -544,7 +671,7 @@ set_info(int skfd, /* The socket */
544671 {
545672 if(++i >= count)
546673 iw_usage();
547- if(sscanf(args[i], "%d", &(wrq.u.sensitivity)) != 1)
674+ if(sscanf(args[i], "%d", &(wrq.u.sens.value)) != 1)
548675 iw_usage();
549676
550677 if(ioctl(skfd, SIOCSIWSENS, &wrq) < 0)
@@ -556,51 +683,111 @@ set_info(int skfd, /* The socket */
556683 }
557684
558685 /* ---------- Set encryption stuff ---------- */
559- if(!strncmp(args[i], "enc", 3 ))
686+ if((!strncmp(args[i], "enc", 3)) ||
687+ (!strcmp(args[i], "key")))
560688 {
561- unsigned long long key = 0;
689+ unsigned char key[IW_ENCODING_TOKEN_MAX];
562690
563691 if(++i >= count)
564692 iw_usage();
565693
566- if(!strcasecmp(args[i], "off"))
567- wrq.u.encoding.method = 0;
694+ if(!strcasecmp(args[i], "on"))
695+ {
696+ /* Get old encryption information */
697+ wrq.u.data.pointer = (caddr_t) key;
698+ wrq.u.data.length = 0;
699+ wrq.u.data.flags = 0;
700+ if(ioctl(skfd, SIOCGIWENCODE, &wrq) < 0)
701+ {
702+ fprintf(stderr, "SIOCGIWENCODE: %s\n", strerror(errno));
703+ return(-1);
704+ }
705+ strcpy(wrq.ifr_name, ifname);
706+ wrq.u.data.flags &= ~IW_ENCODE_DISABLED; /* Enable */
707+ }
568708 else
569709 {
570- if(!strcasecmp(args[i], "on"))
710+ char * buff;
711+ char * p;
712+ int temp;
713+ int k = 0;
714+ int gotone = 1;
715+
716+ wrq.u.data.pointer = (caddr_t) NULL;
717+ wrq.u.data.flags = 0;
718+ wrq.u.data.length = 0;
719+
720+ /* -- Check for the key -- */
721+ if(!strncmp(args[i], "s:", 2))
571722 {
572- /* Get old encryption information */
573- if(ioctl(skfd, SIOCGIWENCODE, &wrq) < 0)
574- {
575- fprintf(stderr, "SIOCGIWENCODE: %s\n", strerror(errno));
576- return(-1);
577- }
578- strcpy(wrq.ifr_name, ifname);
723+ /* First case : as an ASCII string */
724+ wrq.u.data.length = strlen(args[i] + 2);
725+ if(wrq.u.data.length > IW_ENCODING_TOKEN_MAX)
726+ wrq.u.data.length = IW_ENCODING_TOKEN_MAX;
727+ strncpy(key, args[i] + 2, wrq.u.data.length);
728+ wrq.u.data.pointer = (caddr_t) key;
729+ ++i;
730+ gotone = 1;
579731 }
580732 else
581733 {
582- char * buff;
583- char * p;
584- u_long temp;
585-
586- p = buff = malloc(strlen(args[i] + 1));
734+ /* Second case : has hexadecimal digits */
735+ p = buff = malloc(strlen(args[i]) + 1);
587736 strcpy(buff, args[i]);
588737
589- p = strtok(buff, "-:;.,*#");
738+ p = strtok(buff, "-:;.,");
590739 while(p != (char *) NULL)
591740 {
592- key = key << 16;
593- if(sscanf(p, "%lX", &temp) != 1)
594- iw_usage();
595- key += temp;
596- p = strtok((char *) NULL, "-:;.,*#");
741+ if(sscanf(p, "%2X", &temp) != 1)
742+ {
743+ gotone = 0;
744+ break;
745+ }
746+ key[k++] = (unsigned char) (temp & 0xFF);
747+ if(strlen(p) > 2) /* Token not finished yet */
748+ p += 2;
749+ else
750+ p = strtok((char *) NULL, "-:;.,");
597751 }
598-
599752 free(buff);
600- wrq.u.encoding.code = key;
753+
754+ if(gotone)
755+ {
756+ ++i;
757+ wrq.u.data.length = k;
758+ wrq.u.data.pointer = (caddr_t) key;
759+ }
601760 }
602- /* TODO : check for "(method)" in args list */
603- wrq.u.encoding.method = 1;
761+
762+ /* -- Check for token index -- */
763+ if((i < count) &&
764+ (sscanf(args[i], "[%d]", &temp) == 1) &&
765+ (temp > 0) && (temp < IW_ENCODE_INDEX))
766+ {
767+ wrq.u.encoding.flags |= temp;
768+ ++i;
769+ gotone = 1;
770+ }
771+
772+ /* -- Check the various flags -- */
773+ if(i < count)
774+ {
775+ if(!strcasecmp(args[i], "off"))
776+ wrq.u.data.flags |= IW_ENCODE_DISABLED;
777+ if(!strcasecmp(args[i], "open"))
778+ wrq.u.data.flags |= IW_ENCODE_OPEN;
779+ if(!strncasecmp(args[i], "restricted", 5))
780+ wrq.u.data.flags |= IW_ENCODE_RESTRICTED;
781+ if(wrq.u.data.flags & IW_ENCODE_FLAGS)
782+ {
783+ ++i;
784+ gotone = 1;
785+ }
786+ }
787+
788+ if(!gotone)
789+ iw_usage();
790+ --i;
604791 }
605792
606793 if(ioctl(skfd, SIOCSIWENCODE, &wrq) < 0)
@@ -612,7 +799,6 @@ set_info(int skfd, /* The socket */
612799 continue;
613800 }
614801
615-#if WIRELESS_EXT > 5
616802 /* ---------- Set ESSID ---------- */
617803 if(!strcasecmp(args[i], "essid"))
618804 {
@@ -624,23 +810,23 @@ set_info(int skfd, /* The socket */
624810 if((!strcasecmp(args[i], "off")) ||
625811 (!strcasecmp(args[i], "any")))
626812 {
627- wrq.u.data.flags = 0;
813+ wrq.u.essid.flags = 0;
628814 essid[0] = '\0';
629815 }
630816 else
631817 if(!strcasecmp(args[i], "on"))
632818 {
633819 /* Get old essid */
634- wrq.u.data.pointer = (caddr_t) essid;
635- wrq.u.data.length = 0;
636- wrq.u.data.flags = 0;
820+ wrq.u.essid.pointer = (caddr_t) essid;
821+ wrq.u.essid.length = 0;
822+ wrq.u.essid.flags = 0;
637823 if(ioctl(skfd, SIOCGIWESSID, &wrq) < 0)
638824 {
639825 fprintf(stderr, "SIOCGIWESSID: %s\n", strerror(errno));
640826 return(-1);
641827 }
642828 strcpy(wrq.ifr_name, ifname);
643- wrq.u.data.flags = 1;
829+ wrq.u.essid.flags = 1;
644830 }
645831 else
646832 if(strlen(args[i]) > IW_ESSID_MAX_SIZE)
@@ -651,12 +837,12 @@ set_info(int skfd, /* The socket */
651837 }
652838 else
653839 {
654- wrq.u.data.flags = 1;
840+ wrq.u.essid.flags = 1;
655841 strcpy(essid, args[i]);
656842 }
657843
658- wrq.u.data.pointer = (caddr_t) essid;
659- wrq.u.data.length = strlen(essid) + 1;
844+ wrq.u.essid.pointer = (caddr_t) essid;
845+ wrq.u.essid.length = strlen(essid) + 1;
660846 if(ioctl(skfd, SIOCSIWESSID, &wrq) < 0)
661847 {
662848 fprintf(stderr, "SIOCSIWESSID: %s\n", strerror(errno));
@@ -689,9 +875,7 @@ set_info(int skfd, /* The socket */
689875 }
690876 continue;
691877 }
692-#endif /* WIRELESS_EXT > 5 */
693878
694-#if WIRELESS_EXT > 7
695879 /* ---------- Set NickName ---------- */
696880 if(!strncmp(args[i], "nick", 4))
697881 {
@@ -705,8 +889,8 @@ set_info(int skfd, /* The socket */
705889 iw_usage();
706890 }
707891
708- wrq.u.data.pointer = (caddr_t) args[i];
709- wrq.u.data.length = strlen(args[i]) + 1;
892+ wrq.u.essid.pointer = (caddr_t) args[i];
893+ wrq.u.essid.length = strlen(args[i]) + 1;
710894 if(ioctl(skfd, SIOCSIWNICKN, &wrq) < 0)
711895 {
712896 fprintf(stderr, "SIOCSIWNICKN: %s\n", strerror(errno));
@@ -719,8 +903,7 @@ set_info(int skfd, /* The socket */
719903 if((!strncmp(args[i], "bit", 3)) ||
720904 (!strcmp(args[i], "rate")))
721905 {
722- i++;
723- if(i >= count)
906+ if(++i >= count)
724907 iw_usage();
725908 if(!strcasecmp(args[i], "auto"))
726909 {
@@ -738,6 +921,7 @@ set_info(int skfd, /* The socket */
738921 return(-1);
739922 }
740923 strcpy(wrq.ifr_name, ifname);
924+ wrq.u.bitrate.fixed = 1;
741925 }
742926 else /* Should be a numeric value */
743927 {
@@ -749,8 +933,16 @@ set_info(int skfd, /* The socket */
749933 if(index(args[i], 'M')) brate *= MEGA;
750934 if(index(args[i], 'k')) brate *= KILO;
751935 wrq.u.bitrate.value = (long) brate;
936+ wrq.u.bitrate.fixed = 1;
937+
938+ /* Check for an additional argument */
939+ if(((i+1) < count) &&
940+ (!strcasecmp(args[i+1], "auto")))
941+ {
942+ wrq.u.bitrate.fixed = 0;
943+ ++i;
944+ }
752945 }
753- wrq.u.bitrate.fixed = 1;
754946 }
755947
756948 if(ioctl(skfd, SIOCSIWRATE, &wrq) < 0)
@@ -762,37 +954,36 @@ set_info(int skfd, /* The socket */
762954 }
763955
764956 /* ---------- Set RTS threshold ---------- */
765- if(!strncmp(args[i], "rts", 3))
957+ if(!strncasecmp(args[i], "rts", 3))
766958 {
767959 i++;
768960 if(i >= count)
769961 iw_usage();
770- if(!strcasecmp(args[i], "auto"))
771- {
772- wrq.u.rts.value = -1;
773- wrq.u.rts.fixed = 0;
774- }
962+ wrq.u.rts.value = -1;
963+ wrq.u.rts.fixed = 1;
964+ wrq.u.rts.disabled = 0;
965+ if(!strcasecmp(args[i], "off"))
966+ wrq.u.rts.disabled = 1; /* i.e. max size */
775967 else
776- {
777- if(!strcasecmp(args[i], "fixed"))
778- {
779- /* Get old RTS threshold */
780- if(ioctl(skfd, SIOCGIWRTS, &wrq) < 0)
781- {
782- fprintf(stderr, "SIOCGIWRTS: %s\n", strerror(errno));
783- return(-1);
784- }
785- strcpy(wrq.ifr_name, ifname);
786- }
787- else
788- if(!strcasecmp(args[i], "off"))
789- wrq.u.rts.value = -1; /* i.e. max size */
968+ if(!strcasecmp(args[i], "auto"))
969+ wrq.u.rts.fixed = 0;
970+ else
971+ {
972+ if(!strcasecmp(args[i], "fixed"))
973+ {
974+ /* Get old RTS threshold */
975+ if(ioctl(skfd, SIOCGIWRTS, &wrq) < 0)
976+ {
977+ fprintf(stderr, "SIOCGIWRTS: %s\n", strerror(errno));
978+ return(-1);
979+ }
980+ strcpy(wrq.ifr_name, ifname);
981+ wrq.u.rts.fixed = 1;
982+ }
790983 else /* Should be a numeric value */
791984 if(sscanf(args[i], "%ld", (unsigned long *) &(wrq.u.rts.value))
792985 != 1)
793986 iw_usage();
794-
795- wrq.u.rts.fixed = 1;
796987 }
797988
798989 if(ioctl(skfd, SIOCSIWRTS, &wrq) < 0)
@@ -809,32 +1000,31 @@ set_info(int skfd, /* The socket */
8091000 i++;
8101001 if(i >= count)
8111002 iw_usage();
812- if(!strcasecmp(args[i], "auto"))
813- {
814- wrq.u.frag.value = -1;
815- wrq.u.frag.fixed = 0;
816- }
1003+ wrq.u.frag.value = -1;
1004+ wrq.u.frag.fixed = 1;
1005+ wrq.u.frag.disabled = 0;
1006+ if(!strcasecmp(args[i], "off"))
1007+ wrq.u.frag.disabled = 1; /* i.e. max size */
8171008 else
818- {
819- if(!strcasecmp(args[i], "fixed"))
820- {
821- /* Get old fragmentation threshold */
822- if(ioctl(skfd, SIOCGIWFRAG, &wrq) < 0)
823- {
824- fprintf(stderr, "SIOCGIWFRAG: %s\n", strerror(errno));
825- return(-1);
826- }
827- strcpy(wrq.ifr_name, ifname);
828- }
829- else
830- if(!strcasecmp(args[i], "off"))
831- wrq.u.frag.value = -1; /* i.e. max size */
1009+ if(!strcasecmp(args[i], "auto"))
1010+ wrq.u.frag.fixed = 0;
1011+ else
1012+ {
1013+ if(!strcasecmp(args[i], "fixed"))
1014+ {
1015+ /* Get old fragmentation threshold */
1016+ if(ioctl(skfd, SIOCGIWFRAG, &wrq) < 0)
1017+ {
1018+ fprintf(stderr, "SIOCGIWFRAG: %s\n", strerror(errno));
1019+ return(-1);
1020+ }
1021+ strcpy(wrq.ifr_name, ifname);
1022+ wrq.u.frag.fixed = 1;
1023+ }
8321024 else /* Should be a numeric value */
8331025 if(sscanf(args[i], "%ld", (unsigned long *) &(wrq.u.frag.value))
8341026 != 1)
8351027 iw_usage();
836-
837- wrq.u.frag.fixed = 1;
8381028 }
8391029
8401030 if(ioctl(skfd, SIOCSIWFRAG, &wrq) < 0)
@@ -844,8 +1034,124 @@ set_info(int skfd, /* The socket */
8441034 }
8451035 continue;
8461036 }
847-#endif /* WIRELESS_EXT > 7 */
8481037
1038+ /* ---------- Set operation mode ---------- */
1039+ if(!strcmp(args[i], "mode"))
1040+ {
1041+ int k;
1042+
1043+ i++;
1044+ if(i >= count)
1045+ iw_usage();
1046+
1047+ if(sscanf(args[i], "%d", &k) != 1)
1048+ {
1049+ k = 0;
1050+ while(k < 6 && strncasecmp(args[i], operation_mode[k], 3))
1051+ k++;
1052+ }
1053+ if((k > 5) || (k < 0))
1054+ iw_usage();
1055+
1056+ wrq.u.mode = k;
1057+ if(ioctl(skfd, SIOCSIWMODE, &wrq) < 0)
1058+ {
1059+ fprintf(stderr, "SIOCSIWMODE: %s\n", strerror(errno));
1060+ return(-1);
1061+ }
1062+ continue;
1063+ }
1064+
1065+ /* ---------- Set Power Management ---------- */
1066+ if(!strncmp(args[i], "power", 3))
1067+ {
1068+ if(++i >= count)
1069+ iw_usage();
1070+
1071+ if(!strcasecmp(args[i], "off"))
1072+ wrq.u.power.disabled = 1; /* i.e. max size */
1073+ else
1074+ if(!strcasecmp(args[i], "on"))
1075+ {
1076+ /* Get old Power info */
1077+ if(ioctl(skfd, SIOCGIWPOWER, &wrq) < 0)
1078+ {
1079+ fprintf(stderr, "SIOCGIWFRAG: %s\n", strerror(errno));
1080+ return(-1);
1081+ }
1082+ strcpy(wrq.ifr_name, ifname);
1083+ wrq.u.power.disabled = 0;
1084+ }
1085+ else
1086+ {
1087+ double temp;
1088+ int gotone = 0;
1089+ /* Default - nope */
1090+ wrq.u.power.flags = IW_POWER_ON;
1091+ wrq.u.power.disabled = 0;
1092+
1093+ /* Check value modifier */
1094+ if(!strcasecmp(args[i], "period"))
1095+ {
1096+ wrq.u.power.flags = IW_POWER_PERIOD;
1097+ if(++i >= count)
1098+ iw_usage();
1099+ }
1100+ else
1101+ if(!strcasecmp(args[i], "timeout"))
1102+ {
1103+ wrq.u.power.flags = IW_POWER_TIMEOUT;
1104+ if(++i >= count)
1105+ iw_usage();
1106+ }
1107+
1108+ /* Is there any value to grab ? */
1109+ if(sscanf(args[i], "%lg", &(temp)) == 1)
1110+ {
1111+ temp *= MEGA; /* default = s */
1112+ if(index(args[i], 'u')) temp /= MEGA;
1113+ if(index(args[i], 'm')) temp /= KILO;
1114+ wrq.u.power.value = (long) temp;
1115+ if(wrq.u.power.flags == IW_POWER_ON)
1116+ wrq.u.power.flags = IW_POWER_PERIOD;
1117+ ++i;
1118+ gotone = 1;
1119+ }
1120+
1121+ /* Now, check the mode */
1122+ if(i < count)
1123+ {
1124+ if(!strcasecmp(args[i], "all"))
1125+ wrq.u.power.flags |= IW_POWER_ALL_R;
1126+ if(!strncasecmp(args[i], "unicast", 4))
1127+ wrq.u.power.flags |= IW_POWER_UNICAST_R;
1128+ if(!strncasecmp(args[i], "multicast", 5))
1129+ wrq.u.power.flags |= IW_POWER_MULTICAST_R;
1130+ if(!strncasecmp(args[i], "force", 5))
1131+ wrq.u.power.flags |= IW_POWER_FORCE_S;
1132+ if(!strcasecmp(args[i], "repeat"))
1133+ wrq.u.power.flags |= IW_POWER_REPEATER;
1134+ if(wrq.u.power.flags & IW_POWER_MODE)
1135+ {
1136+ ++i;
1137+ gotone = 1;
1138+ }
1139+ }
1140+ if(!gotone)
1141+ iw_usage();
1142+ --i;
1143+ }
1144+
1145+ if(ioctl(skfd, SIOCSIWPOWER, &wrq) < 0)
1146+ {
1147+ fprintf(stderr, "SIOCSIWPOWER(%d): %s\n",
1148+ errno, strerror(errno));
1149+ return(-1);
1150+ }
1151+ continue;
1152+ }
1153+
1154+ /* ---------- Other ---------- */
8491155 /* Here we have an unrecognised arg... */
8501156 fprintf(stderr, "Invalid argument : %s\n", args[i]);
8511157 iw_usage();
Binary files a/wireless_tools/iwpriv and /dev/null differ
--- a/wireless_tools/iwpriv.8
+++ b/wireless_tools/iwpriv.8
@@ -18,7 +18,7 @@ network interface
1818 .br
1919 .BI "iwpriv " interface " roam " {on,off}
2020 .br
21-.BI "iwpriv " interface " port " [ N ]
21+.BI "iwpriv " interface " port " {ad-hoc,managed,N}
2222 .\"
2323 .\" DESCRIPTION part
2424 .\"
@@ -55,8 +55,8 @@ driver.
5555 .TP
5656 .B port
5757 Read or configure the port type. Call the private commands
58-.IR gport_type " and " sport_type .
59-Found in the
58+.IR gport_type ", " sport_type ", " get_port " or " set_port
59+found in the
6060 .IR wavelan2_cs " and " wvlan_cs " drivers."
6161 .TP
6262 .I private-command
--- a/wireless_tools/iwpriv.c
+++ b/wireless_tools/iwpriv.c
@@ -21,7 +21,7 @@ iw_usage(void)
2121 {
2222 fprintf(stderr, "Usage: iwpriv interface [private-command [private-arguments]]\n");
2323 fprintf(stderr, " interface [roam {on|off}]\n");
24- fprintf(stderr, " interface [port [n]]\n");
24+ fprintf(stderr, " interface [port {ad-hoc|managed|N}]\n");
2525 exit(1);
2626 }
2727
@@ -386,6 +386,7 @@ port_type(int skfd, /* Socket */
386386 iwprivargs priv[16];
387387 int number;
388388 char ptype = 0;
389+ char * modes[] = { "invalid", "managed (BSS)", "reserved", "ad-hoc" };
389390
390391 /* Read the private ioctls */
391392 number = get_priv_info(skfd, ifname, priv);
@@ -403,7 +404,8 @@ port_type(int skfd, /* Socket */
403404 {
404405 /* So, we just want to see the current value... */
405406 k = -1;
406- while((++k < number) && strcmp(priv[k].name, "gport_type"));
407+ while((++k < number) && strcmp(priv[k].name, "gport_type") &&
408+ strcmp(priv[k].name, "get_port"));
407409 if(k == number)
408410 {
409411 fprintf(stderr, "This device doesn't support getting port type\n");
@@ -420,7 +422,8 @@ port_type(int skfd, /* Socket */
420422 ptype = *wrq.u.name;
421423
422424 /* Display it */
423- printf("%-8.8s Port type is %d.\n\n", ifname, ptype);
425+ printf("%-8.8s Current port mode is %s <port type is %d>.\n\n",
426+ ifname, modes[(int) ptype], ptype);
424427
425428 return(0);
426429 }
@@ -429,11 +432,20 @@ port_type(int skfd, /* Socket */
429432 iw_usage();
430433
431434 /* Read it */
432- if(sscanf(args[i], "%d", (int *) &ptype) != 1)
433- iw_usage();
435+ /* As a string... */
436+ k = 0;
437+ while((k < 4) && strncasecmp(args[i], modes[k], 2))
438+ k++;
439+ if(k < 4)
440+ ptype = k;
441+ else
442+ /* ...or as an integer */
443+ if(sscanf(args[i], "%d", (int *) &ptype) != 1)
444+ iw_usage();
434445
435446 k = -1;
436- while((++k < number) && strcmp(priv[k].name, "sport_type"));
447+ while((++k < number) && strcmp(priv[k].name, "sport_type") &&
448+ strcmp(priv[k].name, "set_port"));
437449 if(k == number)
438450 {
439451 fprintf(stderr, "This device doesn't support setting port type\n");
@@ -445,7 +457,7 @@ port_type(int skfd, /* Socket */
445457
446458 if(ioctl(skfd, priv[k].cmd, &wrq) < 0)
447459 {
448- fprintf(stderr, "Invalid port type\n");
460+ fprintf(stderr, "Invalid port type (or setting not allowed)\n");
449461 exit(0);
450462 }
451463
Binary files a/wireless_tools/iwspy and /dev/null differ
--- a/wireless_tools/iwspy.8
+++ b/wireless_tools/iwspy.8
@@ -22,6 +22,8 @@ iwspy \- Get wireless statistics from specific nodes
2222 .BI "iwspy " interface " ap"
2323 .br
2424 .BI "iwspy " interface " rate"
25+.br
26+.BI "iwspy " interface " keys"
2527 .\"
2628 .\" DESCRIPTION part
2729 .\"
@@ -82,8 +84,12 @@ displayed and channel numbers.
8284 Give the list of Access Points in range, and optionally the quality of
8385 link to them.
8486 .TP
85-.BR rate / bit [ rate ]
87+.BR rate / bit [rate]
8688 List the bit-rates supported by the device.
89+.TP
90+.BR keys / enc [ryption]
91+List the encryption key sizes supported and display all the encryption
92+keys availables in the device.
8793 .\"
8894 .\" FILES part
8995 .\"
--- a/wireless_tools/iwspy.c
+++ b/wireless_tools/iwspy.c
@@ -150,11 +150,7 @@ print_freq_info(int skfd,
150150 /* Print them all */
151151 for(k = 0; k < range.num_frequency; k++)
152152 {
153-#if WIRELESS_EXT > 7
154- printf("\t Channel %.2d : ", range.freq[k].i);
155-#else
156- printf("\t ");
157-#endif
153+ printf("\t Channel %.2d : ", range.freq[k].i);
158154 freq = freq2float(&(range.freq[k]));
159155 if(freq >= GIGA)
160156 printf("%g GHz\n", freq / GIGA);
@@ -199,7 +195,6 @@ print_freq_devices(int skfd)
199195 print_freq_info(skfd, ifr->ifr_name);
200196 }
201197
202-#if WIRELESS_EXT > 5
203198 /*------------------------------------------------------------------*/
204199 /*
205200 * Display the list of ap addresses and the associated stats
@@ -310,9 +305,7 @@ print_ap_devices(int skfd)
310305 for(i = ifc.ifc_len / sizeof(struct ifreq); --i >= 0; ifr++)
311306 print_ap_info(skfd, ifr->ifr_name);
312307 }
313-#endif /* WIRELESS_EXT > 5 */
314308
315-#if WIRELESS_EXT > 7
316309 /*------------------------------------------------------------------*/
317310 /*
318311 * Print the number of available bitrates for the device
@@ -385,7 +378,103 @@ print_bitrate_devices(int skfd)
385378 for(i = ifc.ifc_len / sizeof(struct ifreq); --i >= 0; ifr++)
386379 print_bitrate_info(skfd, ifr->ifr_name);
387380 }
388-#endif /* WIRELESS_EXT > 7 */
381+
382+/*------------------------------------------------------------------*/
383+/*
384+ * Print the number of available bitrates for the device
385+ */
386+static void
387+print_keys_info(int skfd,
388+ char * ifname)
389+{
390+ struct iwreq wrq;
391+ struct iw_range range;
392+ unsigned char key[IW_ENCODING_TOKEN_MAX];
393+ int k;
394+
395+ strncpy(wrq.ifr_name, ifname, IFNAMSIZ);
396+ wrq.u.data.pointer = (caddr_t) &range;
397+ wrq.u.data.length = 0;
398+ wrq.u.data.flags = 0;
399+ if(ioctl(skfd, SIOCGIWRANGE, &wrq) < 0)
400+ fprintf(stderr, "%-8.8s no encryption keys information.\n\n",
401+ ifname);
402+ else
403+ {
404+ printf("%-8.8s ", ifname);
405+ if((range.num_encoding_sizes > 0) &&
406+ (range.num_encoding_sizes < IW_MAX_ENCODING_SIZES))
407+ {
408+ printf("%d key sizes : %d", range.num_encoding_sizes,
409+ range.encoding_size[0] * 8);
410+ /* Print them all */
411+ for(k = 1; k < range.num_encoding_sizes; k++)
412+ printf(", %d", range.encoding_size[k] * 8);
413+ printf("bits\n ");
414+ }
415+ printf("%d keys available :\n", range.max_encoding_tokens);
416+ for(k = 1; k <= range.max_encoding_tokens; k++)
417+ {
418+ strcpy(wrq.ifr_name, ifname);
419+ wrq.u.data.pointer = (caddr_t) key;
420+ wrq.u.data.length = 0;
421+ wrq.u.data.flags = k;
422+ if(ioctl(skfd, SIOCGIWENCODE, &wrq) < 0)
423+ {
424+ fprintf(stderr, "SIOCGIWENCODE: %s\n", strerror(errno));
425+ break;
426+ }
427+ if((wrq.u.data.flags & IW_ENCODE_DISABLED) ||
428+ (wrq.u.data.length == 0))
429+ printf("\t\t[%d]: off\n", k);
430+ else
431+ {
432+ int i;
433+
434+ printf("\t\t[%d]: %.2X", k, key[0]);
435+ for(i = 1; i < wrq.u.data.length; i++)
436+ {
437+ if((i & 0x1) == 0)
438+ printf("-");
439+ printf("%.2X", key[i]);
440+ }
441+
442+ /* Other info... */
443+ printf(" (%d bits)", wrq.u.data.length * 8);
444+ printf("\n");
445+ }
446+ }
447+
448+ printf("\n\n");
449+ }
450+}
451+
452+/*------------------------------------------------------------------*/
453+/*
454+ * Get bit-rate info on all devices and print it on the screen
455+ */
456+static void
457+print_keys_devices(int skfd)
458+{
459+ char buff[1024];
460+ struct ifconf ifc;
461+ struct ifreq *ifr;
462+ int i;
463+
464+ /* Get list of active devices */
465+ ifc.ifc_len = sizeof(buff);
466+ ifc.ifc_buf = buff;
467+ if(ioctl(skfd, SIOCGIFCONF, &ifc) < 0)
468+ {
469+ fprintf(stderr, "SIOCGIFCONF: %s\n", strerror(errno));
470+ return;
471+ }
472+ ifr = ifc.ifc_req;
473+
474+ /* Print them */
475+ for(i = ifc.ifc_len / sizeof(struct ifreq); --i >= 0; ifr++)
476+ print_keys_info(skfd, ifr->ifr_name);
477+}
389478
390479 /************************* SETTING ROUTINES **************************/
391480
@@ -528,7 +617,6 @@ main(int argc,
528617 exit(0);
529618 }
530619
531-#if WIRELESS_EXT > 5
532620 /* Access Point list */
533621 if(!strcasecmp(argv[1], "ap"))
534622 {
@@ -536,9 +624,7 @@ main(int argc,
536624 close(skfd);
537625 exit(0);
538626 }
539-#endif /* WIRELESS_EXT > 5 */
540627
541-#if WIRELESS_EXT > 7
542628 /* Bit-rate list */
543629 if((!strncmp(argv[1], "bit", 3)) ||
544630 (!strcmp(argv[1], "rate")))
@@ -547,7 +633,15 @@ main(int argc,
547633 close(skfd);
548634 exit(0);
549635 }
550-#endif /* WIRELESS_EXT > 7 */
636+
637+ /* Encryption key list */
638+ if((!strncmp(argv[1], "enc", 3)) ||
639+ (!strncmp(argv[1], "key", 3)))
640+ {
641+ print_keys_devices(skfd);
642+ close(skfd);
643+ exit(0);
644+ }
551645
552646 /* The device name must be the first argument */
553647 /* Name only : show spy list for that device only */
@@ -568,7 +662,6 @@ main(int argc,
568662 exit(0);
569663 }
570664
571-#if WIRELESS_EXT > 5
572665 /* Access Point list */
573666 if(!strcasecmp(argv[2], "ap"))
574667 {
@@ -576,9 +669,7 @@ main(int argc,
576669 close(skfd);
577670 exit(0);
578671 }
579-#endif /* WIRELESS_EXT > 5 */
580672
581-#if WIRELESS_EXT > 7
582673 /* Access Point list */
583674 if((!strncmp(argv[2], "bit", 3)) ||
584675 (!strcmp(argv[2], "rate")))
@@ -587,7 +678,15 @@ main(int argc,
587678 close(skfd);
588679 exit(0);
589680 }
590-#endif /* WIRELESS_EXT > 7 */
681+
682+ /* Access Point list */
683+ if((!strncmp(argv[2], "enc", 3)) ||
684+ (!strncmp(argv[2], "key", 3)))
685+ {
686+ print_keys_info(skfd, argv[1]);
687+ close(skfd);
688+ exit(0);
689+ }
591690
592691 /* Otherwise, it's a list of address to set in the spy list */
593692 goterr = set_spy_info(skfd, argv + 2, argc - 2, argv[1]);
--- /dev/null
+++ b/wireless_tools/sample_enc_cs.c
@@ -0,0 +1,105 @@
1+#define MAX_KEY_SIZE 16
2+#define MAX_KEYS 8
3+int key_on = 0;
4+int key_open = 1;
5+int key_current = 0;
6+char key_table[MAX_KEYS][MAX_KEY_SIZE];
7+int key_size[MAX_KEYS];
8+
9+#if WIRELESS_EXT > 8
10+ case SIOCSIWENCODE:
11+ /* Basic checking... */
12+ if(wrq->u.encoding.pointer != (caddr_t) 0)
13+ {
14+ int index = (wrq->u.encoding.flags & IW_ENCODE_INDEX) - 1;
15+
16+ /* Check the size of the key */
17+ if(wrq->u.encoding.length > MAX_KEY_SIZE)
18+ {
19+ ret = -EINVAL;
20+ break;
21+ }
22+
23+ /* Check the index */
24+ if((index < 0) || (index >= MAX_KEYS))
25+ index = key_current;
26+
27+ /* Copy the key in the driver */
28+ if(copy_from_user(key_table[index], wrq->u.encoding.pointer,
29+ wrq->u.encoding.length))
30+ {
31+ key_size[index] = 0;
32+ ret = -EFAULT;
33+ break;
34+ }
35+ key_size[index] = wrq->u.encoding.length;
36+ key_on = 1;
37+ }
38+ else
39+ {
40+ int index = (wrq->u.encoding.flags & IW_ENCODE_INDEX) - 1;
41+ /* Do we want to just set the current key ? */
42+ if((index >= 0) && (index < MAX_KEYS))
43+ {
44+ if(key_size[index] > 0)
45+ {
46+ key_current = index;
47+ key_on = 1;
48+ }
49+ else
50+ ret = -EINVAL;
51+ }
52+ }
53+
54+ /* Read the flags */
55+ if(wrq->u.encoding.flags & IW_ENCODE_DISABLED)
56+ key_on = 0; /* disable encryption */
57+ if(wrq->u.encoding.flags & IW_ENCODE_RESTRICTED)
58+ key_open = 0; /* disable open mode */
59+ if(wrq->u.encoding.flags & IW_ENCODE_OPEN)
60+ key_open = 1; /* enable open mode */
61+
62+ break;
63+
64+ case SIOCGIWENCODE:
65+ /* only super-user can see encryption key */
66+ if(!suser())
67+ {
68+ ret = -EPERM;
69+ break;
70+ }
71+
72+ /* Basic checking... */
73+ if(wrq->u.encoding.pointer != (caddr_t) 0)
74+ {
75+ int index = (wrq->u.encoding.flags & IW_ENCODE_INDEX) - 1;
76+
77+ /* Set the flags */
78+ wrq->u.encoding.flags = 0;
79+ if(key_on == 0)
80+ wrq->u.encoding.flags |= IW_ENCODE_DISABLED;
81+ if(key_open == 0)
82+ wrq->u.encoding.flags |= IW_ENCODE_RESTRICTED;
83+ else
84+ wrq->u.encoding.flags |= IW_ENCODE_OPEN;
85+
86+ /* Which key do we want */
87+ if((index < 0) || (index >= MAX_KEYS))
88+ index = key_current;
89+ wrq->u.encoding.flags |= index + 1;
90+
91+ /* Copy the key to the user buffer */
92+ wrq->u.encoding.length = key_size[index];
93+ if(copy_to_user(wrq->u.encoding.pointer, key_table[index],
94+ key_size[index]))
95+ ret = -EFAULT;
96+ }
97+ break;
98+#endif /* WIRELESS_EXT > 8 */
99+
100+#if WIRELESS_EXT > 8
101+ range.encoding_size[0] = 8; /* DES = 64 bits key */
102+ range.encoding_size[1] = 16;
103+ range.num_encoding_sizes = 2;
104+ range.max_encoding_tokens = 8;
105+#endif /* WIRELESS_EXT > 8 */
--- a/wireless_tools/wireless.h
+++ /dev/null
@@ -1,347 +0,0 @@
1-/*
2- * This file define a set of standard wireless extensions
3- *
4- * Version : 7 23.4.99
5- *
6- * Authors : Jean Tourrilhes - HPLB - <jt@hplb.hpl.hp.com>
7- */
8-
9-#ifndef _LINUX_WIRELESS_H
10-#define _LINUX_WIRELESS_H
11-
12-/************************** DOCUMENTATION **************************/
13-/*
14- * Basically, the wireless extensions are for now a set of standard ioctl
15- * call + /proc/net/wireless
16- *
17- * The entry /proc/net/wireless give statistics and information on the
18- * driver.
19- * This is better than having each driver having its entry because
20- * its centralised and we may remove the driver module safely.
21- *
22- * Ioctl are used to configure the driver and issue commands. This is
23- * better than command line options of insmod because we may want to
24- * change dynamically (while the driver is running) some parameters.
25- *
26- * The ioctl mechanimsm are copied from standard devices ioctl.
27- * We have the list of command plus a structure descibing the
28- * data exchanged...
29- * Note that to add these ioctl, I was obliged to modify :
30- * net/core/dev.c (two place + add include)
31- * net/ipv4/af_inet.c (one place + add include)
32- *
33- * /proc/net/wireless is a copy of /proc/net/dev.
34- * We have a structure for data passed from the driver to /proc/net/wireless
35- * Too add this, I've modified :
36- * net/core/dev.c (two other places)
37- * include/linux/netdevice.h (one place)
38- * include/linux/proc_fs.h (one place)
39- *
40- * Do not add here things that are redundant with other mechanisms
41- * (drivers init, ifconfig, /proc/net/dev, ...) and with are not
42- * wireless specific.
43- *
44- * These wireless extensions are not magic : each driver has to provide
45- * support for them...
46- *
47- * IMPORTANT NOTE : As everything in the kernel, this is very much a
48- * work in progress. Contact me if you have ideas of improvements...
49- */
50-
51-/***************************** INCLUDES *****************************/
52-
53-#if 0
54-#include <linux/types.h> /* for "caddr_t" et al */
55-#include <linux/socket.h> /* for "struct sockaddr" et al */
56-#include <linux/if.h> /* for IFNAMSIZ and co... */
57-#endif
58-
59-/**************************** CONSTANTS ****************************/
60-
61-/* --------------------------- VERSION --------------------------- */
62-/*
63- * This constant is used to know the availability of the wireless
64- * extensions and to know which version of wireless extensions it is
65- * (there is some stuff that will be added in the future...)
66- * I just plan to increment with each new version.
67- */
68-#define WIRELESS_EXT 6
69-
70-/*
71- * Changes :
72- *
73- * V2 to V3
74- * --------
75- * Alan Cox start some incompatibles changes. I've integrated a bit more.
76- * - Encryption renamed to Encode to avoid US regulation problems
77- * - Frequency changed from float to struct to avoid problems on old 386
78- *
79- * V3 to V4
80- * --------
81- * - Add sensitivity
82- *
83- * V4 to V5
84- * --------
85- * - Missing encoding definitions in range
86- * - Access points stuff
87- *
88- * V5 to V6
89- * --------
90- * - 802.11 support (ESSID ioctls)
91- *
92- * V6 to V7
93- * --------
94- * - define IW_ESSID_MAX_SIZE and IW_MAX_AP
95- */
96-
97-/* -------------------------- IOCTL LIST -------------------------- */
98-
99-/* Basic operations */
100-#define SIOCSIWNAME 0x8B00 /* Unused ??? */
101-#define SIOCGIWNAME 0x8B01 /* get name */
102-#define SIOCSIWNWID 0x8B02 /* set network id */
103-#define SIOCGIWNWID 0x8B03 /* get network id */
104-#define SIOCSIWFREQ 0x8B04 /* set channel/frequency */
105-#define SIOCGIWFREQ 0x8B05 /* get channel/frequency */
106-#define SIOCSIWENCODE 0x8B06 /* set encoding info */
107-#define SIOCGIWENCODE 0x8B07 /* get encoding info */
108-#define SIOCSIWSENS 0x8B08 /* set sensitivity */
109-#define SIOCGIWSENS 0x8B09 /* get sensitivity */
110-
111-/* Informative stuff */
112-#define SIOCSIWRANGE 0x8B0A /* Unused ??? */
113-#define SIOCGIWRANGE 0x8B0B /* Get range of parameters */
114-#define SIOCSIWPRIV 0x8B0C /* Unused ??? */
115-#define SIOCGIWPRIV 0x8B0D /* get private ioctl interface info */
116-
117-/* Mobile IP support */
118-#define SIOCSIWSPY 0x8B10 /* set spy addresses */
119-#define SIOCGIWSPY 0x8B11 /* get spy info (quality of link) */
120-
121-/* Access Point manipulation */
122-#define SIOCSIWAP 0x8B14 /* set access point hardware addresses */
123-#define SIOCGIWAP 0x8B15 /* get access point hardware addresses */
124-#define SIOCGIWAPLIST 0x8B17 /* get list of access point in range */
125-
126-/* 802.11 specific support */
127-#define SIOCSIWESSID 0x8B1A /* set ESSID (network name) */
128-#define SIOCGIWESSID 0x8B1B /* get ESSID */
129-/* As the ESSID is a string up to 32 bytes long, it doesn't fit within the
130- * 'iwreq' structure, so we need to use the 'data' member to point to a
131- * string in user space, like it is done for RANGE...
132- * The "flags" member indicate if the ESSID is active or not.
133- */
134-
135-/* ------------------------- IOCTL STUFF ------------------------- */
136-
137-/* The first and the last (range) */
138-#define SIOCIWFIRST 0x8B00
139-#define SIOCIWLAST 0x8B1B
140-
141-/* Even : get (world access), odd : set (root access) */
142-#define IW_IS_SET(cmd) (!((cmd) & 0x1))
143-#define IW_IS_GET(cmd) ((cmd) & 0x1)
144-
145-/* ------------------------- PRIVATE INFO ------------------------- */
146-/*
147- * The following is used with SIOCGIWPRIV. It allow a driver to define
148- * the interface (name, type of data) for its private ioctl.
149- * Privates ioctl are SIOCDEVPRIVATE -> SIOCDEVPRIVATE + 0xF
150- */
151-
152-#define IW_PRIV_TYPE_MASK 0x7000 /* Type of arguments */
153-#define IW_PRIV_TYPE_NONE 0x0000
154-#define IW_PRIV_TYPE_BYTE 0x1000 /* Char as number */
155-#define IW_PRIV_TYPE_CHAR 0x2000 /* Char as character */
156-#define IW_PRIV_TYPE_INT 0x4000 /* 32 bits int */
157-#define IW_PRIV_TYPE_FLOAT 0x5000
158-
159-#define IW_PRIV_SIZE_FIXED 0x0800 /* Variable or fixed nuber of args */
160-
161-#define IW_PRIV_SIZE_MASK 0x07FF /* Max number of those args */
162-
163-/*
164- * Note : if the number of args is fixed and the size < 16 octets,
165- * instead of passing a pointer we will put args in the iwreq struct...
166- */
167-
168-/* ----------------------- OTHER CONSTANTS ----------------------- */
169-
170-/* Maximum frequencies in the range struct */
171-#define IW_MAX_FREQUENCIES 16
172-/* Note : if you have something like 80 frequencies,
173- * don't increase this constant and don't fill the frequency list.
174- * The user will be able to set by channel anyway... */
175-
176-/* Maximum of address that you may set with SPY */
177-#define IW_MAX_SPY 8
178-
179-/* Maximum of address that you may get in the
180- list of access points in range */
181-#define IW_MAX_AP 8
182-
183-/* Maximum size of the ESSID string */
184-#define IW_ESSID_MAX_SIZE 32
185-
186-/****************************** TYPES ******************************/
187-
188-/* --------------------------- SUBTYPES --------------------------- */
189-/*
190- * A frequency
191- * For numbers lower than 10^9, we encode the number in 'mant' and
192- * set 'exp' to 0
193- * For number greater than 10^9, we divide it by a power of 10.
194- * The power of 10 is in 'exp', the result is in 'mant'.
195- */
196-struct iw_freq
197-{
198- __u32 m; /* Mantissa */
199- __u16 e; /* Exponent */
200-};
201-
202-/*
203- * Quality of the link
204- */
205-struct iw_quality
206-{
207- __u8 qual; /* link quality (SNR or better...) */
208- __u8 level; /* signal level */
209- __u8 noise; /* noise level */
210- __u8 updated; /* Flags to know if updated */
211-};
212-
213-/*
214- * Packet discarded in the wireless adapter due to
215- * "wireless" specific problems...
216- */
217-struct iw_discarded
218-{
219- __u32 nwid; /* Wrong nwid */
220- __u32 code; /* Unable to code/decode */
221- __u32 misc; /* Others cases */
222-};
223-
224-/*
225- * Encoding information (setting and so on)
226- * Encoding might be hardware encryption, scrambing or others
227- */
228-struct iw_encoding
229-{
230- __u8 method; /* Algorithm number / key used */
231- __u64 code; /* Data/key used for algorithm */
232-};
233-
234-
235-/* ------------------------ WIRELESS STATS ------------------------ */
236-/*
237- * Wireless statistics (used for /proc/net/wireless)
238- */
239-struct iw_statistics
240-{
241- __u8 status; /* Status
242- * - device dependent for now */
243-
244- struct iw_quality qual; /* Quality of the link
245- * (instant/mean/max) */
246- struct iw_discarded discard; /* Packet discarded counts */
247-};
248-
249-/* ------------------------ IOCTL REQUEST ------------------------ */
250-/*
251- * The structure to exchange data for ioctl.
252- * This structure is the same as 'struct ifreq', but (re)defined for
253- * convenience...
254- *
255- * Note that it should fit on the same memory footprint !
256- * You should check this when increasing the above structures (16 octets)
257- * 16 octets = 128 bits. Warning, pointers might be 64 bits wide...
258- */
259-struct iwreq
260-{
261- union
262- {
263- char ifrn_name[IFNAMSIZ]; /* if name, e.g. "en0" */
264- } ifr_ifrn;
265-
266- /* Data part */
267- union
268- {
269- /* Config - generic */
270- char name[IFNAMSIZ];
271- /* Name : used to verify the presence of wireless extensions.
272- * Name of the protocol/provider... */
273-
274- struct /* network id (or domain) : used to to */
275- { /* create logical channels on the air */
276- __u32 nwid; /* value */
277- __u8 on; /* active/unactive nwid */
278- } nwid;
279-
280- struct iw_freq freq; /* frequency or channel :
281- * 0-1000 = channel
282- * > 1000 = frequency in Hz */
283-
284- struct iw_encoding encoding; /* Encoding stuff */
285-
286- __u32 sensitivity; /* signal level threshold */
287-
288- struct sockaddr ap_addr; /* Access point address */
289-
290- struct /* For all data bigger than 16 octets */
291- {
292- caddr_t pointer; /* Pointer to the data
293- * (in user space) */
294- __u16 length; /* fields or byte size */
295- __u16 flags; /* Optional params */
296- } data;
297- } u;
298-};
299-
300-/* -------------------------- IOCTL DATA -------------------------- */
301-/*
302- * For those ioctl which want to exchange mode data that what could
303- * fit in the above structure...
304- */
305-
306-/*
307- * Range of parameters
308- */
309-
310-struct iw_range
311-{
312- /* Informative stuff (to choose between different interface) */
313- __u32 throughput; /* To give an idea... */
314-
315- /* NWID (or domain id) */
316- __u32 min_nwid; /* Minimal NWID we are able to set */
317- __u32 max_nwid; /* Maximal NWID we are able to set */
318-
319- /* Frequency */
320- __u16 num_channels; /* Number of channels [0; num - 1] */
321- __u8 num_frequency; /* Number of entry in the list */
322- struct iw_freq freq[IW_MAX_FREQUENCIES]; /* list */
323- /* Note : this frequency list doesn't need to fit channel numbers */
324-
325- /* signal level threshold range */
326- __u32 sensitivity;
327-
328- /* Quality of link & SNR stuff */
329- struct iw_quality max_qual; /* Quality of the link */
330-
331- /* Encoder stuff */
332- struct iw_encoding max_encoding; /* Encoding max range */
333-};
334-
335-/*
336- * Private ioctl interface information
337- */
338-
339-struct iw_priv_args
340-{
341- __u32 cmd; /* Number of the ioctl to issue */
342- __u16 set_args; /* Type and number of args */
343- __u16 get_args; /* Type and number of args */
344- char name[IFNAMSIZ]; /* Name of the extension */
345-};
346-
347-#endif /* _LINUX_WIRELESS_H */