Commit 72f70c37 authored by Jean Tourrilhes's avatar Jean Tourrilhes Committed by Linus Torvalds

[PATCH] Wireless Extension 16

        This patch for 2.5.68-bk11 will update Wireless Extension to
version 16 :
        o increase bitrate and frequency number for 802.11g/802.11a
        o enhanced iwspy support
        o minor tweaks and cleanups

        This patch is only for the core of WE. The patches for the
individual drivers have been sent to their respective maintainers.
	Compared to the previous version I sent you a few weeks ago,
I've just updated to the latest kernel.
parent 5e556524
/* /*
* This file define a set of standard wireless extensions * This file define a set of standard wireless extensions
* *
* Version : 15 12.7.02 * Version : 16 2.4.03
* *
* 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-2002 Jean Tourrilhes, All Rights Reserved.
...@@ -69,6 +69,8 @@ ...@@ -69,6 +69,8 @@
/***************************** INCLUDES *****************************/ /***************************** INCLUDES *****************************/
/* To minimise problems in user space, I might remove those headers
* at some point. Jean II */
#include <linux/types.h> /* for "caddr_t" et al */ #include <linux/types.h> /* for "caddr_t" et al */
#include <linux/socket.h> /* for "struct sockaddr" et al */ #include <linux/socket.h> /* for "struct sockaddr" et al */
#include <linux/if.h> /* for IFNAMSIZ and co... */ #include <linux/if.h> /* for IFNAMSIZ and co... */
...@@ -80,7 +82,7 @@ ...@@ -80,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 15 #define WIRELESS_EXT 16
/* /*
* Changes : * Changes :
...@@ -163,6 +165,16 @@ ...@@ -163,6 +165,16 @@
* - Add IW_TXPOW_RANGE for range of Tx Powers * - Add IW_TXPOW_RANGE for range of Tx Powers
* - Add IWEVREGISTERED & IWEVEXPIRED events for Access Points * - Add IWEVREGISTERED & IWEVEXPIRED events for Access Points
* - Add IW_MODE_MONITOR for passive monitor * - Add IW_MODE_MONITOR for passive monitor
*
* V15 to V16
* ----------
* - Increase the number of bitrates in iw_range to 32 (for 802.11g)
* - Increase the number of frequencies in iw_range to 32 (for 802.11b+a)
* - Reshuffle struct iw_range for increases, add filler
* - Increase IW_MAX_AP to 64 for driver returning a lot of addresses
* - Remove IW_MAX_GET_SPY because conflict with enhanced spy support
* - Add SIOCSIWTHRSPY/SIOCGIWTHRSPY and "struct iw_thrspy"
* - Add IW_ENCODE_TEMP and iw_range->encoding_login_index
*/ */
/**************************** CONSTANTS ****************************/ /**************************** CONSTANTS ****************************/
...@@ -196,9 +208,11 @@ ...@@ -196,9 +208,11 @@
/* SIOCGIWSTATS is strictly used between user space and the kernel, and /* SIOCGIWSTATS is strictly used between user space and the kernel, and
* is never passed to the driver (i.e. the driver will never see it). */ * is never passed to the driver (i.e. the driver will never see it). */
/* Mobile IP support (statistics per MAC address) */ /* Spy support (statistics per MAC address - used for Mobile IP support) */
#define SIOCSIWSPY 0x8B10 /* set spy addresses */ #define SIOCSIWSPY 0x8B10 /* set spy addresses */
#define SIOCGIWSPY 0x8B11 /* get spy info (quality of link) */ #define SIOCGIWSPY 0x8B11 /* get spy info (quality of link) */
#define SIOCSIWTHRSPY 0x8B12 /* set spy threshold (spy event) */
#define SIOCGIWTHRSPY 0x8B13 /* get spy threshold */
/* Access Point manipulation */ /* Access Point manipulation */
#define SIOCSIWAP 0x8B14 /* set access point MAC addresses */ #define SIOCSIWAP 0x8B14 /* set access point MAC addresses */
...@@ -306,13 +320,13 @@ ...@@ -306,13 +320,13 @@
/* ----------------------- OTHER CONSTANTS ----------------------- */ /* ----------------------- OTHER CONSTANTS ----------------------- */
/* Maximum frequencies in the range struct */ /* Maximum frequencies in the range struct */
#define IW_MAX_FREQUENCIES 16 #define IW_MAX_FREQUENCIES 32
/* Note : if you have something like 80 frequencies, /* Note : if you have something like 80 frequencies,
* don't increase this constant and don't fill the frequency list. * don't increase this constant and don't fill the frequency list.
* The user will be able to set by channel anyway... */ * The user will be able to set by channel anyway... */
/* Maximum bit rates in the range struct */ /* Maximum bit rates in the range struct */
#define IW_MAX_BITRATES 8 #define IW_MAX_BITRATES 32
/* Maximum tx powers in the range struct */ /* Maximum tx powers in the range struct */
#define IW_MAX_TXPOWER 8 #define IW_MAX_TXPOWER 8
...@@ -320,12 +334,11 @@ ...@@ -320,12 +334,11 @@
* a few of them in the struct iw_range. */ * a few of them in the struct iw_range. */
/* Maximum of address that you may set with SPY */ /* Maximum of address that you may set with SPY */
#define IW_MAX_SPY 8 /* set */ #define IW_MAX_SPY 8
#define IW_MAX_GET_SPY 64 /* get */
/* Maximum of address that you may get in the /* Maximum of address that you may get in the
list of access points in range */ list of access points in range */
#define IW_MAX_AP 8 #define IW_MAX_AP 64
/* Maximum size of the ESSID and NICKN strings */ /* Maximum size of the ESSID and NICKN strings */
#define IW_ESSID_MAX_SIZE 32 #define IW_ESSID_MAX_SIZE 32
...@@ -355,6 +368,7 @@ ...@@ -355,6 +368,7 @@
#define IW_ENCODE_RESTRICTED 0x4000 /* Refuse non-encoded packets */ #define IW_ENCODE_RESTRICTED 0x4000 /* Refuse non-encoded packets */
#define IW_ENCODE_OPEN 0x2000 /* Accept non-encoded packets */ #define IW_ENCODE_OPEN 0x2000 /* Accept non-encoded packets */
#define IW_ENCODE_NOKEY 0x0800 /* Key is write only, so not present */ #define IW_ENCODE_NOKEY 0x0800 /* Key is write only, so not present */
#define IW_ENCODE_TEMP 0x0400 /* Temporary key */
/* Power management flags available (along with the value, if any) */ /* Power management flags available (along with the value, if any) */
#define IW_POWER_ON 0x0000 /* No details... */ #define IW_POWER_ON 0x0000 /* No details... */
...@@ -482,6 +496,17 @@ struct iw_missed ...@@ -482,6 +496,17 @@ struct iw_missed
__u32 beacon; /* Missed beacons/superframe */ __u32 beacon; /* Missed beacons/superframe */
}; };
/*
* Quality range (for spy threshold)
*/
struct iw_thrspy
{
struct sockaddr addr; /* Source address (hw/mac) */
struct iw_quality qual; /* Quality of the link */
struct iw_quality low; /* Low threshold */
struct iw_quality high; /* High threshold */
};
/* ------------------------ WIRELESS STATS ------------------------ */ /* ------------------------ WIRELESS STATS ------------------------ */
/* /*
* Wireless statistics (used for /proc/net/wireless) * Wireless statistics (used for /proc/net/wireless)
...@@ -534,7 +559,7 @@ union iwreq_data ...@@ -534,7 +559,7 @@ union iwreq_data
struct iw_quality qual; /* Quality part of statistics */ struct iw_quality qual; /* Quality part of statistics */
struct sockaddr ap_addr; /* Access point address */ struct sockaddr ap_addr; /* Access point address */
struct sockaddr addr; /* Destination address (hw) */ struct sockaddr addr; /* Destination address (hw/mac) */
struct iw_param param; /* Other small parameters */ struct iw_param param; /* Other small parameters */
struct iw_point data; /* Other large parameters */ struct iw_point data; /* Other large parameters */
...@@ -582,17 +607,31 @@ struct iw_range ...@@ -582,17 +607,31 @@ struct iw_range
__u32 min_nwid; /* Minimal NWID we are able to set */ __u32 min_nwid; /* Minimal NWID we are able to set */
__u32 max_nwid; /* Maximal NWID we are able to set */ __u32 max_nwid; /* Maximal NWID we are able to set */
/* Frequency */ /* Old Frequency (backward compat - moved lower ) */
__u16 num_channels; /* Number of channels [0; num - 1] */ __u16 old_num_channels;
__u8 num_frequency; /* Number of entry in the list */ __u8 old_num_frequency;
struct iw_freq freq[IW_MAX_FREQUENCIES]; /* list */ /* Filler to keep "version" at the same offset */
/* Note : this frequency list doesn't need to fit channel numbers */ __s32 old_freq[6];
/* signal level threshold range */ /* signal level threshold range */
__s32 sensitivity; __s32 sensitivity;
/* Quality of link & SNR stuff */ /* Quality of link & SNR stuff */
/* Quality range (link, level, noise)
* If the quality is absolute, it will be in the range [0 ; max_qual],
* if the quality is dBm, it will be in the range [max_qual ; 0].
* Don't forget that we use 8 bit arithmetics... */
struct iw_quality max_qual; /* Quality of the link */ struct iw_quality max_qual; /* Quality of the link */
/* This should contain the average/typical values of the quality
* indicator. This should be the threshold between a "good" and
* a "bad" link (example : monitor going from green to orange).
* Currently, user space apps like quality monitors don't have any
* way to calibrate the measurement. With this, they can split
* the range between 0 and max_qual in different quality level
* (using a geometric subdivision centered on the average).
* I expect that people doing the user space apps will feedback
* us on which value we need to put in each driver... */
struct iw_quality avg_qual; /* Quality of the link */
/* Rates */ /* Rates */
__u8 num_bitrates; /* Number of entries in the list */ __u8 num_bitrates; /* Number of entries in the list */
...@@ -619,6 +658,8 @@ struct iw_range ...@@ -619,6 +658,8 @@ struct iw_range
__u16 encoding_size[IW_MAX_ENCODING_SIZES]; /* Different token sizes */ __u16 encoding_size[IW_MAX_ENCODING_SIZES]; /* Different token sizes */
__u8 num_encoding_sizes; /* Number of entry in the list */ __u8 num_encoding_sizes; /* Number of entry in the list */
__u8 max_encoding_tokens; /* Max number of tokens */ __u8 max_encoding_tokens; /* Max number of tokens */
/* For drivers that need a "login/passwd" form */
__u8 encoding_login_index; /* token index for login token */
/* Transmit power */ /* Transmit power */
__u16 txpower_capa; /* What options are supported */ __u16 txpower_capa; /* What options are supported */
...@@ -638,18 +679,12 @@ struct iw_range ...@@ -638,18 +679,12 @@ struct iw_range
__s32 min_r_time; /* Minimal retry lifetime */ __s32 min_r_time; /* Minimal retry lifetime */
__s32 max_r_time; /* Maximal retry lifetime */ __s32 max_r_time; /* Maximal retry lifetime */
/* Average quality of link & SNR */ /* Frequency */
struct iw_quality avg_qual; /* Quality of the link */ __u16 num_channels; /* Number of channels [0; num - 1] */
/* This should contain the average/typical values of the quality __u8 num_frequency; /* Number of entry in the list */
* indicator. This should be the threshold between a "good" and struct iw_freq freq[IW_MAX_FREQUENCIES]; /* list */
* a "bad" link (example : monitor going from green to orange). /* Note : this frequency list doesn't need to fit channel numbers,
* Currently, user space apps like quality monitors don't have any * because each entry contain its channel index */
* way to calibrate the measurement. With this, they can split
* the range between 0 and max_qual in different quality level
* (using a geometric subdivision centered on the average).
* I expect that people doing the user space apps will feedback
* us on which value we need to put in each driver...
*/
}; };
/* /*
......
/* /*
* This file define the new driver API for Wireless Extensions * This file define the new driver API for Wireless Extensions
* *
* Version : 4 21.6.02 * Version : 5 4.12.02
* *
* 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-2002 Jean Tourrilhes, All Rights Reserved.
...@@ -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 4 #define IW_HANDLER_VERSION 5
/* /*
* Changes : * Changes :
...@@ -220,10 +220,18 @@ ...@@ -220,10 +220,18 @@
* V3 to V4 * V3 to V4
* -------- * --------
* - Reshuffle IW_HEADER_TYPE_XXX to map IW_PRIV_TYPE_XXX changes * - Reshuffle IW_HEADER_TYPE_XXX to map IW_PRIV_TYPE_XXX changes
*
* V4 to V5
* --------
* - Add new spy support : struct iw_spy_data & prototypes
*/ */
/**************************** CONSTANTS ****************************/ /**************************** CONSTANTS ****************************/
/* Enable enhanced spy support. Disable to reduce footprint */
#define IW_WIRELESS_SPY
#define IW_WIRELESS_THRSPY
/* Special error message for the driver to indicate that we /* Special error message for the driver to indicate that we
* should do a commit after return from the iw_handler */ * should do a commit after return from the iw_handler */
#define EIWCOMMIT EINPROGRESS #define EIWCOMMIT EINPROGRESS
...@@ -315,6 +323,9 @@ struct iw_handler_def ...@@ -315,6 +323,9 @@ struct iw_handler_def
* We will automatically export that to user space... */ * We will automatically export that to user space... */
struct iw_priv_args * private_args; struct iw_priv_args * private_args;
/* Driver enhanced spy support */
long spy_offset; /* Spy data offset */
/* In the long term, get_wireless_stats will move from /* In the long term, get_wireless_stats will move from
* 'struct net_device' to here, to minimise bloat. */ * 'struct net_device' to here, to minimise bloat. */
}; };
...@@ -350,6 +361,33 @@ struct iw_ioctl_description ...@@ -350,6 +361,33 @@ struct iw_ioctl_description
/* Need to think of short header translation table. Later. */ /* Need to think of short header translation table. Later. */
/* --------------------- ENHANCED SPY SUPPORT --------------------- */
/*
* In the old days, the driver was handling spy support all by itself.
* Now, the driver can delegate this task to Wireless Extensions.
* It needs to include this struct in its private part and use the
* standard spy iw_handler.
*/
/*
* Instance specific spy data, i.e. addresses spied and quality for them.
*/
struct iw_spy_data
{
#ifdef IW_WIRELESS_SPY
/* --- Standard spy support --- */
int spy_number;
u_char spy_address[IW_MAX_SPY][ETH_ALEN];
struct iw_quality spy_stat[IW_MAX_SPY];
#ifdef IW_WIRELESS_THRSPY
/* --- Enhanced spy support (event) */
struct iw_quality spy_thr_low; /* Low threshold */
struct iw_quality spy_thr_high; /* High threshold */
u_char spy_thr_under[IW_MAX_SPY];
#endif /* IW_WIRELESS_THRSPY */
#endif /* IW_WIRELESS_SPY */
};
/**************************** PROTOTYPES ****************************/ /**************************** PROTOTYPES ****************************/
/* /*
* Functions part of the Wireless Extensions (defined in net/core/wireless.c). * Functions part of the Wireless Extensions (defined in net/core/wireless.c).
...@@ -376,6 +414,31 @@ extern void wireless_send_event(struct net_device * dev, ...@@ -376,6 +414,31 @@ extern void wireless_send_event(struct net_device * dev,
/* We may need a function to send a stream of events to user space. /* We may need a function to send a stream of events to user space.
* More on that later... */ * More on that later... */
/* Standard handler for SIOCSIWSPY */
extern int iw_handler_set_spy(struct net_device * dev,
struct iw_request_info * info,
union iwreq_data * wrqu,
char * extra);
/* Standard handler for SIOCGIWSPY */
extern int iw_handler_get_spy(struct net_device * dev,
struct iw_request_info * info,
union iwreq_data * wrqu,
char * extra);
/* Standard handler for SIOCSIWTHRSPY */
extern int iw_handler_set_thrspy(struct net_device * dev,
struct iw_request_info *info,
union iwreq_data * wrqu,
char * extra);
/* Standard handler for SIOCGIWTHRSPY */
extern int iw_handler_get_thrspy(struct net_device * dev,
struct iw_request_info *info,
union iwreq_data * wrqu,
char * extra);
/* Driver call to update spy records */
extern void wireless_spy_update(struct net_device * dev,
unsigned char * address,
struct iw_quality * wstats);
/************************* INLINE FUNTIONS *************************/ /************************* INLINE FUNTIONS *************************/
/* /*
* Function that are so simple that it's more efficient inlining them * Function that are so simple that it's more efficient inlining them
......
This diff is collapsed.
...@@ -666,10 +666,13 @@ EXPORT_SYMBOL(register_gifconf); ...@@ -666,10 +666,13 @@ EXPORT_SYMBOL(register_gifconf);
EXPORT_SYMBOL(softnet_data); EXPORT_SYMBOL(softnet_data);
#ifdef CONFIG_NET_RADIO #ifdef CONFIG_NET_RADIO
/* Don't include the whole header mess for a single function */ #include <net/iw_handler.h> /* Wireless Extensions driver API */
union iwreq_data;
extern void wireless_send_event(struct net_device *dev, unsigned int cmd, union iwreq_data *wrqu, char *extra);
EXPORT_SYMBOL(wireless_send_event); EXPORT_SYMBOL(wireless_send_event);
EXPORT_SYMBOL(iw_handler_set_spy);
EXPORT_SYMBOL(iw_handler_get_spy);
EXPORT_SYMBOL(iw_handler_set_thrspy);
EXPORT_SYMBOL(iw_handler_get_thrspy);
EXPORT_SYMBOL(wireless_spy_update);
#endif /* CONFIG_NET_RADIO */ #endif /* CONFIG_NET_RADIO */
EXPORT_SYMBOL(linkwatch_fire_event); EXPORT_SYMBOL(linkwatch_fire_event);
......
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