Commit c77821cb authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] wireless-extension-v17-for-linus.patch

From: Jean Tourrilhes <jt@bougret.hpl.hp.com>

	This is the patch to migrate Wireless Extension from WE-16 to
WE-17 for kernel 2.6.X. I would like you to queue that patch and
submit it to Linus as soon as 2.6.8 is released (so it can be fully
tested during 2.6.9). If you want, I can resend that as soon as 2.6.8
is released.

	The patch is basically unchanged compared to the version
posted to the netdev list and my web page one month ago, I just
re-diff to the latest kernel (2.6.8-rc2-bk12). The patch already
included feedback from various driver maintainers, and nobody else
complained, so I guess it's ready.
	The patch for some drivers inside the kernel will follow
(airo.c, wavelan.c, wavelan_cs). Patch for various other drivers
(orinoco, hostap, prism54) have been sent already to their maintainers
(one month ago) and basically waiting for this patch.

	Changelog :
 *	- Add flags to frequency -> auto/fixed
 *	- Document (struct iw_quality *)->updated, add new flags (INVALID)
 *	- Wireless Event capability in struct iw_range
 *	- Add support for relative TxPower (yick !)
 *	- Change the way we get to spy_data method for added safety and hostap
 *	- Remove spy #ifdef, they are always on -> cleaner code
 *	- Allow any size GET request if user specifies length > max
 *	- Start migrating get_wireless_stats to struct iw_handler_def
 * Based on patch from Pavel Roskin <proski@gnu.org> :
 *	- Fix kernel data leak to user space in private handler handling

	I also added on my page a version of Wireless Tools that use
RtNetlink instead of ioctls. This is not as clean as I would like, but
is fully functional (if you have WE-19). I know that you were
interested, so feel free to send feedback on that...
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
parent 2ac5f852
...@@ -304,7 +304,9 @@ struct net_device ...@@ -304,7 +304,9 @@ struct net_device
/* List of functions to handle Wireless Extensions (instead of ioctl). /* List of functions to handle Wireless Extensions (instead of ioctl).
* See <net/iw_handler.h> for details. Jean II */ * See <net/iw_handler.h> for details. Jean II */
struct iw_handler_def * wireless_handlers; const struct iw_handler_def * wireless_handlers;
/* Instance data managed by the core of Wireless Extensions. */
struct iw_public_data * wireless_data;
struct ethtool_ops *ethtool_ops; struct ethtool_ops *ethtool_ops;
......
/* /*
* This file define a set of standard wireless extensions * This file define a set of standard wireless extensions
* *
* Version : 16 2.4.03 * Version : 17 21.6.04
* *
* Authors : Jean Tourrilhes - HPL - <jt@hpl.hp.com> * Authors : Jean Tourrilhes - HPL - <jt@hpl.hp.com>
* Copyright (c) 1997-2002 Jean Tourrilhes, All Rights Reserved. * Copyright (c) 1997-2004 Jean Tourrilhes, All Rights Reserved.
*/ */
#ifndef _LINUX_WIRELESS_H #ifndef _LINUX_WIRELESS_H
...@@ -47,12 +47,12 @@ ...@@ -47,12 +47,12 @@
* # include/net/iw_handler.h * # include/net/iw_handler.h
* *
* Note as well that /proc/net/wireless implementation has now moved in : * Note as well that /proc/net/wireless implementation has now moved in :
* # include/linux/wireless.c * # net/core/wireless.c
* *
* Wireless Events (2002 -> onward) : * Wireless Events (2002 -> onward) :
* -------------------------------- * --------------------------------
* Events are defined at the end of this file, and implemented in : * Events are defined at the end of this file, and implemented in :
* # include/linux/wireless.c * # net/core/wireless.c
* *
* Other comments : * Other comments :
* -------------- * --------------
...@@ -82,7 +82,7 @@ ...@@ -82,7 +82,7 @@
* (there is some stuff that will be added in the future...) * (there is some stuff that will be added in the future...)
* I just plan to increment with each new version. * I just plan to increment with each new version.
*/ */
#define WIRELESS_EXT 16 #define WIRELESS_EXT 17
/* /*
* Changes : * Changes :
...@@ -175,6 +175,13 @@ ...@@ -175,6 +175,13 @@
* - Remove IW_MAX_GET_SPY because conflict with enhanced spy support * - Remove IW_MAX_GET_SPY because conflict with enhanced spy support
* - Add SIOCSIWTHRSPY/SIOCGIWTHRSPY and "struct iw_thrspy" * - Add SIOCSIWTHRSPY/SIOCGIWTHRSPY and "struct iw_thrspy"
* - Add IW_ENCODE_TEMP and iw_range->encoding_login_index * - Add IW_ENCODE_TEMP and iw_range->encoding_login_index
*
* V16 to V17
* ----------
* - Add flags to frequency -> auto/fixed
* - Document (struct iw_quality *)->updated, add new flags (INVALID)
* - Wireless Event capability in struct iw_range
* - Add support for relative TxPower (yick !)
*/ */
/**************************** CONSTANTS ****************************/ /**************************** CONSTANTS ****************************/
...@@ -251,7 +258,7 @@ ...@@ -251,7 +258,7 @@
/* -------------------- DEV PRIVATE IOCTL LIST -------------------- */ /* -------------------- DEV PRIVATE IOCTL LIST -------------------- */
/* These 16 ioctl are wireless device private. /* These 32 ioctl are wireless device private, for 16 commands.
* Each driver is free to use them for whatever purpose it chooses, * Each driver is free to use them for whatever purpose it chooses,
* however the driver *must* export the description of those ioctls * however the driver *must* export the description of those ioctls
* with SIOCGIWPRIV and *must* use arguments as defined below. * with SIOCGIWPRIV and *must* use arguments as defined below.
...@@ -266,8 +273,8 @@ ...@@ -266,8 +273,8 @@
* We now have 32 commands, so a bit more space ;-). * We now have 32 commands, so a bit more space ;-).
* Also, all 'odd' commands are only usable by root and don't return the * Also, all 'odd' commands are only usable by root and don't return the
* content of ifr/iwr to user (but you are not obliged to use the set/get * content of ifr/iwr to user (but you are not obliged to use the set/get
* convention, just use every other two command). * convention, just use every other two command). More details in iwpriv.c.
* And I repeat : you are not obliged to use them with iwspy, but you * And I repeat : you are not forced to use them with iwpriv, but you
* must be compliant with it. * must be compliant with it.
*/ */
...@@ -352,6 +359,18 @@ ...@@ -352,6 +359,18 @@
#define IW_MODE_SECOND 5 /* Secondary master/repeater (backup) */ #define IW_MODE_SECOND 5 /* Secondary master/repeater (backup) */
#define IW_MODE_MONITOR 6 /* Passive monitor (listen only) */ #define IW_MODE_MONITOR 6 /* Passive monitor (listen only) */
/* Statistics flags (bitmask in updated) */
#define IW_QUAL_QUAL_UPDATED 0x1 /* Value was updated since last read */
#define IW_QUAL_LEVEL_UPDATED 0x2
#define IW_QUAL_NOISE_UPDATED 0x4
#define IW_QUAL_QUAL_INVALID 0x10 /* Driver doesn't provide value */
#define IW_QUAL_LEVEL_INVALID 0x20
#define IW_QUAL_NOISE_INVALID 0x40
/* Frequency flags */
#define IW_FREQ_AUTO 0x00 /* Let the driver decides */
#define IW_FREQ_FIXED 0x01 /* Force a specific value */
/* Maximum number of size of encoding token available /* Maximum number of size of encoding token available
* they are listed in the range structure */ * they are listed in the range structure */
#define IW_MAX_ENCODING_SIZES 8 #define IW_MAX_ENCODING_SIZES 8
...@@ -390,6 +409,7 @@ ...@@ -390,6 +409,7 @@
#define IW_TXPOW_TYPE 0x00FF /* Type of value */ #define IW_TXPOW_TYPE 0x00FF /* Type of value */
#define IW_TXPOW_DBM 0x0000 /* Value is in dBm */ #define IW_TXPOW_DBM 0x0000 /* Value is in dBm */
#define IW_TXPOW_MWATT 0x0001 /* Value is in mW */ #define IW_TXPOW_MWATT 0x0001 /* Value is in mW */
#define IW_TXPOW_RELATIVE 0x0002 /* Value is in arbitrary units */
#define IW_TXPOW_RANGE 0x1000 /* Range of value between min/max */ #define IW_TXPOW_RANGE 0x1000 /* Range of value between min/max */
/* Retry limits and lifetime flags available */ /* Retry limits and lifetime flags available */
...@@ -418,6 +438,25 @@ ...@@ -418,6 +438,25 @@
/* Max number of char in custom event - use multiple of them if needed */ /* Max number of char in custom event - use multiple of them if needed */
#define IW_CUSTOM_MAX 256 /* In bytes */ #define IW_CUSTOM_MAX 256 /* In bytes */
/* Event capability macros - in (struct iw_range *)->event_capa
* Because we have more than 32 possible events, we use an array of
* 32 bit bitmasks. Note : 32 bits = 0x20 = 2^5. */
#define IW_EVENT_CAPA_BASE(cmd) ((cmd >= SIOCIWFIRSTPRIV) ? \
(cmd - SIOCIWFIRSTPRIV + 0x60) : \
(cmd - SIOCSIWCOMMIT))
#define IW_EVENT_CAPA_INDEX(cmd) (IW_EVENT_CAPA_BASE(cmd) >> 5)
#define IW_EVENT_CAPA_MASK(cmd) (1 << (IW_EVENT_CAPA_BASE(cmd) & 0x1F))
/* Event capability constants - event autogenerated by the kernel
* This list is valid for most 802.11 devices, customise as needed... */
#define IW_EVENT_CAPA_K_0 (IW_EVENT_CAPA_MASK(0x8B04) | \
IW_EVENT_CAPA_MASK(0x8B06) | \
IW_EVENT_CAPA_MASK(0x8B1A))
#define IW_EVENT_CAPA_K_1 (IW_EVENT_CAPA_MASK(0x8B2A))
/* "Easy" macro to set events in iw_range (less efficient) */
#define IW_EVENT_CAPA_SET(event_capa, cmd) (event_capa[IW_EVENT_CAPA_INDEX(cmd)] |= IW_EVENT_CAPA_MASK(cmd))
#define IW_EVENT_CAPA_SET_KERNEL(event_capa) {event_capa[0] |= IW_EVENT_CAPA_K_0; event_capa[1] |= IW_EVENT_CAPA_K_1; }
/****************************** TYPES ******************************/ /****************************** TYPES ******************************/
/* --------------------------- SUBTYPES --------------------------- */ /* --------------------------- SUBTYPES --------------------------- */
...@@ -456,7 +495,7 @@ struct iw_freq ...@@ -456,7 +495,7 @@ struct iw_freq
__s32 m; /* Mantissa */ __s32 m; /* Mantissa */
__s16 e; /* Exponent */ __s16 e; /* Exponent */
__u8 i; /* List index (when in range struct) */ __u8 i; /* List index (when in range struct) */
__u8 pad; /* Unused - just for alignement */ __u8 flags; /* Flags (fixed/auto) */
}; };
/* /*
...@@ -610,8 +649,9 @@ struct iw_range ...@@ -610,8 +649,9 @@ struct iw_range
/* Old Frequency (backward compat - moved lower ) */ /* Old Frequency (backward compat - moved lower ) */
__u16 old_num_channels; __u16 old_num_channels;
__u8 old_num_frequency; __u8 old_num_frequency;
/* Filler to keep "version" at the same offset */
__s32 old_freq[6]; /* Wireless event capability bitmasks */
__u32 event_capa[6];
/* signal level threshold range */ /* signal level threshold range */
__s32 sensitivity; __s32 sensitivity;
......
/* /*
* This file define the new driver API for Wireless Extensions * This file define the new driver API for Wireless Extensions
* *
* Version : 5 4.12.02 * Version : 6 21.6.04
* *
* Authors : Jean Tourrilhes - HPL - <jt@hpl.hp.com> * Authors : Jean Tourrilhes - HPL - <jt@hpl.hp.com>
* Copyright (c) 2001-2002 Jean Tourrilhes, All Rights Reserved. * Copyright (c) 2001-2004 Jean Tourrilhes, All Rights Reserved.
*/ */
#ifndef _IW_HANDLER_H #ifndef _IW_HANDLER_H
...@@ -206,7 +206,7 @@ ...@@ -206,7 +206,7 @@
* will be needed... * will be needed...
* I just plan to increment with each new version. * I just plan to increment with each new version.
*/ */
#define IW_HANDLER_VERSION 5 #define IW_HANDLER_VERSION 6
/* /*
* Changes : * Changes :
...@@ -224,11 +224,18 @@ ...@@ -224,11 +224,18 @@
* V4 to V5 * V4 to V5
* -------- * --------
* - Add new spy support : struct iw_spy_data & prototypes * - Add new spy support : struct iw_spy_data & prototypes
*
* V5 to V6
* --------
* - Change the way we get to spy_data method for added safety
* - Remove spy #ifdef, they are always on -> cleaner code
* - Add IW_DESCR_FLAG_NOMAX flag for very large requests
* - Start migrating get_wireless_stats to struct iw_handler_def
*/ */
/**************************** CONSTANTS ****************************/ /**************************** CONSTANTS ****************************/
/* Enable enhanced spy support. Disable to reduce footprint */ /* Enhanced spy support available */
#define IW_WIRELESS_SPY #define IW_WIRELESS_SPY
#define IW_WIRELESS_THRSPY #define IW_WIRELESS_THRSPY
...@@ -258,6 +265,7 @@ ...@@ -258,6 +265,7 @@
#define IW_DESCR_FLAG_EVENT 0x0002 /* Generate an event on SET */ #define IW_DESCR_FLAG_EVENT 0x0002 /* Generate an event on SET */
#define IW_DESCR_FLAG_RESTRICT 0x0004 /* GET : request is ROOT only */ #define IW_DESCR_FLAG_RESTRICT 0x0004 /* GET : request is ROOT only */
/* SET : Omit payload from generated iwevent */ /* SET : Omit payload from generated iwevent */
#define IW_DESCR_FLAG_NOMAX 0x0008 /* GET : no limit on request size */
/* Driver level flags */ /* Driver level flags */
#define IW_DESCR_FLAG_WAIT 0x0100 /* Wait for driver event */ #define IW_DESCR_FLAG_WAIT 0x0100 /* Wait for driver event */
...@@ -303,31 +311,33 @@ struct iw_handler_def ...@@ -303,31 +311,33 @@ struct iw_handler_def
{ {
/* Number of handlers defined (more precisely, index of the /* Number of handlers defined (more precisely, index of the
* last defined handler + 1) */ * last defined handler + 1) */
__u16 num_standard; const __u16 num_standard;
__u16 num_private; const __u16 num_private;
/* Number of private arg description */ /* Number of private arg description */
__u16 num_private_args; const __u16 num_private_args;
/* Array of handlers for standard ioctls /* Array of handlers for standard ioctls
* We will call dev->wireless_handlers->standard[ioctl - SIOCSIWNAME] * We will call dev->wireless_handlers->standard[ioctl - SIOCSIWNAME]
*/ */
iw_handler * standard; const iw_handler * standard;
/* Array of handlers for private ioctls /* Array of handlers for private ioctls
* Will call dev->wireless_handlers->private[ioctl - SIOCIWFIRSTPRIV] * Will call dev->wireless_handlers->private[ioctl - SIOCIWFIRSTPRIV]
*/ */
iw_handler * private; const iw_handler * private;
/* Arguments of private handler. This one is just a list, so you /* Arguments of private handler. This one is just a list, so you
* can put it in any order you want and should not leave holes... * can put it in any order you want and should not leave holes...
* We will automatically export that to user space... */ * We will automatically export that to user space... */
struct iw_priv_args * private_args; const struct iw_priv_args * private_args;
/* Driver enhanced spy support */ /* This field will be *removed* in the next version of WE */
long spy_offset; /* Spy data offset */ const long spy_offset; /* DO NOT USE */
/* In the long term, get_wireless_stats will move from /* New location of get_wireless_stats, to de-bloat struct net_device.
* 'struct net_device' to here, to minimise bloat. */ * The old pointer in struct net_device will be gradually phased
* out, and drivers are encouraged to use this one... */
struct iw_statistics* (*get_wireless_stats)(struct net_device *dev);
}; };
/* ---------------------- IOCTL DESCRIPTION ---------------------- */ /* ---------------------- IOCTL DESCRIPTION ---------------------- */
...@@ -374,18 +384,29 @@ struct iw_ioctl_description ...@@ -374,18 +384,29 @@ struct iw_ioctl_description
*/ */
struct iw_spy_data struct iw_spy_data
{ {
#ifdef IW_WIRELESS_SPY
/* --- Standard spy support --- */ /* --- Standard spy support --- */
int spy_number; int spy_number;
u_char spy_address[IW_MAX_SPY][ETH_ALEN]; u_char spy_address[IW_MAX_SPY][ETH_ALEN];
struct iw_quality spy_stat[IW_MAX_SPY]; struct iw_quality spy_stat[IW_MAX_SPY];
#ifdef IW_WIRELESS_THRSPY
/* --- Enhanced spy support (event) */ /* --- Enhanced spy support (event) */
struct iw_quality spy_thr_low; /* Low threshold */ struct iw_quality spy_thr_low; /* Low threshold */
struct iw_quality spy_thr_high; /* High threshold */ struct iw_quality spy_thr_high; /* High threshold */
u_char spy_thr_under[IW_MAX_SPY]; u_char spy_thr_under[IW_MAX_SPY];
#endif /* IW_WIRELESS_THRSPY */ };
#endif /* IW_WIRELESS_SPY */
/* --------------------- DEVICE WIRELESS DATA --------------------- */
/*
* This is all the wireless data specific to a device instance that
* is managed by the core of Wireless Extensions.
* We only keep pointer to those structures, so that a driver is free
* to share them between instances.
* This structure should be initialised before registering the device.
* Access to this data follow the same rules as any other struct net_device
* data (i.e. valid as long as struct net_device exist, same locking rules).
*/
struct iw_public_data {
/* Driver enhanced spy support */
struct iw_spy_data * spy_data;
}; };
/**************************** PROTOTYPES ****************************/ /**************************** PROTOTYPES ****************************/
...@@ -394,6 +415,9 @@ struct iw_spy_data ...@@ -394,6 +415,9 @@ struct iw_spy_data
* Those may be called only within the kernel. * Those may be called only within the kernel.
*/ */
/* Data needed by fs/compat_ioctl.c for 32->64 bit conversion */
extern const char iw_priv_type_size[];
/* First : function strictly used inside the kernel */ /* First : function strictly used inside the kernel */
/* Handle /proc/net/wireless, called in net/code/dev.c */ /* Handle /proc/net/wireless, called in net/code/dev.c */
......
...@@ -2771,7 +2771,7 @@ int dev_ioctl(unsigned int cmd, void __user *arg) ...@@ -2771,7 +2771,7 @@ int dev_ioctl(unsigned int cmd, void __user *arg)
/* Follow me in net/core/wireless.c */ /* Follow me in net/core/wireless.c */
ret = wireless_process_ioctl(&ifr, cmd); ret = wireless_process_ioctl(&ifr, cmd);
rtnl_unlock(); rtnl_unlock();
if (!ret && IW_IS_GET(cmd) && if (IW_IS_GET(cmd) &&
copy_to_user(arg, &ifr, copy_to_user(arg, &ifr,
sizeof(struct ifreq))) sizeof(struct ifreq)))
ret = -EFAULT; ret = -EFAULT;
......
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment