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

[PATCH] wireless-drivers-update-for-we-17.patch

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

	This patch complement the main WE-17 patch I just sent you. It
updates a few driver to take advantage of WE-17. You should queue it
along with the other patch.

	o Aironet driver :
		o iwspy data can be shared between eth0 and wifi0 if needed
		o allow arbitrarily large scan results (no longer limited)
		o export wireless event capabilities
	o Wavelan drivers :
		o export wireless event capabilities
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
parent c77821cb
...@@ -1188,6 +1188,7 @@ struct airo_info { ...@@ -1188,6 +1188,7 @@ struct airo_info {
struct iw_statistics wstats; // wireless stats struct iw_statistics wstats; // wireless stats
unsigned long scan_timestamp; /* Time started to scan */ unsigned long scan_timestamp; /* Time started to scan */
struct iw_spy_data spy_data; struct iw_spy_data spy_data;
struct iw_public_data wireless_data;
#endif /* WIRELESS_EXT */ #endif /* WIRELESS_EXT */
#ifdef MICSUPPORT #ifdef MICSUPPORT
/* MIC stuff */ /* MIC stuff */
...@@ -2626,8 +2627,7 @@ static void wifi_setup(struct net_device *dev) ...@@ -2626,8 +2627,7 @@ static void wifi_setup(struct net_device *dev)
dev->set_mac_address = &airo_set_mac_address; dev->set_mac_address = &airo_set_mac_address;
dev->do_ioctl = &airo_ioctl; dev->do_ioctl = &airo_ioctl;
#ifdef WIRELESS_EXT #ifdef WIRELESS_EXT
dev->get_wireless_stats = airo_get_wireless_stats; dev->wireless_handlers = &airo_handler_def;
dev->wireless_handlers = (struct iw_handler_def *)&airo_handler_def;
#endif /* WIRELESS_EXT */ #endif /* WIRELESS_EXT */
dev->change_mtu = &airo_change_mtu; dev->change_mtu = &airo_change_mtu;
dev->open = &airo_open; dev->open = &airo_open;
...@@ -2654,6 +2654,9 @@ static struct net_device *init_wifidev(struct airo_info *ai, ...@@ -2654,6 +2654,9 @@ static struct net_device *init_wifidev(struct airo_info *ai,
dev->priv = ethdev->priv; dev->priv = ethdev->priv;
dev->irq = ethdev->irq; dev->irq = ethdev->irq;
dev->base_addr = ethdev->base_addr; dev->base_addr = ethdev->base_addr;
#ifdef WIRELESS_EXT
dev->wireless_data = ethdev->wireless_data;
#endif /* WIRELESS_EXT */
memcpy(dev->dev_addr, ethdev->dev_addr, dev->addr_len); memcpy(dev->dev_addr, ethdev->dev_addr, dev->addr_len);
err = register_netdev(dev); err = register_netdev(dev);
if (err<0) { if (err<0) {
...@@ -2733,8 +2736,9 @@ struct net_device *_init_airo_card( unsigned short irq, int port, ...@@ -2733,8 +2736,9 @@ struct net_device *_init_airo_card( unsigned short irq, int port,
dev->set_mac_address = &airo_set_mac_address; dev->set_mac_address = &airo_set_mac_address;
dev->do_ioctl = &airo_ioctl; dev->do_ioctl = &airo_ioctl;
#ifdef WIRELESS_EXT #ifdef WIRELESS_EXT
dev->get_wireless_stats = airo_get_wireless_stats; dev->wireless_handlers = &airo_handler_def;
dev->wireless_handlers = (struct iw_handler_def *)&airo_handler_def; ai->wireless_data.spy_data = &ai->spy_data;
dev->wireless_data = &ai->wireless_data;
#endif /* WIRELESS_EXT */ #endif /* WIRELESS_EXT */
dev->change_mtu = &airo_change_mtu; dev->change_mtu = &airo_change_mtu;
dev->open = &airo_open; dev->open = &airo_open;
...@@ -3217,7 +3221,7 @@ static irqreturn_t airo_interrupt ( int irq, void* dev_id, struct pt_regs *regs) ...@@ -3217,7 +3221,7 @@ static irqreturn_t airo_interrupt ( int irq, void* dev_id, struct pt_regs *regs)
goto exitrx; goto exitrx;
} }
} }
#ifdef IW_WIRELESS_SPY /* defined in iw_handler.h */ #ifdef WIRELESS_SPY
if (apriv->spy_data.spy_number > 0) { if (apriv->spy_data.spy_number > 0) {
char *sa; char *sa;
struct iw_quality wstats; struct iw_quality wstats;
...@@ -3237,7 +3241,7 @@ static irqreturn_t airo_interrupt ( int irq, void* dev_id, struct pt_regs *regs) ...@@ -3237,7 +3241,7 @@ static irqreturn_t airo_interrupt ( int irq, void* dev_id, struct pt_regs *regs)
/* Update spy records */ /* Update spy records */
wireless_spy_update(dev, sa, &wstats); wireless_spy_update(dev, sa, &wstats);
} }
#endif /* IW_WIRELESS_SPY */ #endif /* WIRELESS_SPY */
OUT4500( apriv, EVACK, EV_RX); OUT4500( apriv, EVACK, EV_RX);
if (test_bit(FLAG_802_11, &apriv->flags)) { if (test_bit(FLAG_802_11, &apriv->flags)) {
...@@ -3467,7 +3471,7 @@ static void mpi_receive_802_3(struct airo_info *ai) ...@@ -3467,7 +3471,7 @@ static void mpi_receive_802_3(struct airo_info *ai)
#else #else
memcpy(buffer, ai->rxfids[0].virtual_host_addr, len); memcpy(buffer, ai->rxfids[0].virtual_host_addr, len);
#endif #endif
#ifdef IW_WIRELESS_SPY /* defined in iw_handler.h */ #ifdef WIRELESS_SPY
if (ai->spy_data.spy_number > 0) { if (ai->spy_data.spy_number > 0) {
char *sa; char *sa;
struct iw_quality wstats; struct iw_quality wstats;
...@@ -3479,7 +3483,7 @@ static void mpi_receive_802_3(struct airo_info *ai) ...@@ -3479,7 +3483,7 @@ static void mpi_receive_802_3(struct airo_info *ai)
/* Update spy records */ /* Update spy records */
wireless_spy_update(ai->dev, sa, &wstats); wireless_spy_update(ai->dev, sa, &wstats);
} }
#endif /* IW_WIRELESS_SPY */ #endif /* WIRELESS_SPY */
skb->dev = ai->dev; skb->dev = ai->dev;
skb->ip_summed = CHECKSUM_NONE; skb->ip_summed = CHECKSUM_NONE;
...@@ -6505,6 +6509,13 @@ static int airo_get_range(struct net_device *dev, ...@@ -6505,6 +6509,13 @@ static int airo_get_range(struct net_device *dev,
range->avg_qual.level = 176; /* -80 dBm */ range->avg_qual.level = 176; /* -80 dBm */
range->avg_qual.noise = 0; range->avg_qual.noise = 0;
/* Event capability (kernel + driver) */
range->event_capa[0] = (IW_EVENT_CAPA_K_0 |
IW_EVENT_CAPA_MASK(SIOCGIWTHRSPY) |
IW_EVENT_CAPA_MASK(SIOCGIWAP) |
IW_EVENT_CAPA_MASK(SIOCGIWSCAN));
range->event_capa[1] = IW_EVENT_CAPA_K_1;
range->event_capa[4] = IW_EVENT_CAPA_MASK(IWEVTXDROP);
return 0; return 0;
} }
...@@ -6872,9 +6883,15 @@ static int airo_get_scan(struct net_device *dev, ...@@ -6872,9 +6883,15 @@ static int airo_get_scan(struct net_device *dev,
while((!rc) && (BSSList.index != 0xffff)) { while((!rc) && (BSSList.index != 0xffff)) {
/* Translate to WE format this entry */ /* Translate to WE format this entry */
current_ev = airo_translate_scan(dev, current_ev, current_ev = airo_translate_scan(dev, current_ev,
extra + IW_SCAN_MAX_DATA, extra + dwrq->length,
&BSSList); &BSSList);
/* Check if there is space for one more entry */
if((extra + dwrq->length - current_ev) <= IW_EV_ADDR_LEN) {
/* Ask user space to try again with a bigger buffer */
return -E2BIG;
}
/* Read next entry */ /* Read next entry */
rc = PC4500_readrid(ai, RID_BSSLISTNEXT, rc = PC4500_readrid(ai, RID_BSSLISTNEXT,
&BSSList, sizeof(BSSList), 1); &BSSList, sizeof(BSSList), 1);
...@@ -7010,12 +7027,10 @@ static const struct iw_handler_def airo_handler_def = ...@@ -7010,12 +7027,10 @@ static const struct iw_handler_def airo_handler_def =
.num_standard = sizeof(airo_handler)/sizeof(iw_handler), .num_standard = sizeof(airo_handler)/sizeof(iw_handler),
.num_private = sizeof(airo_private_handler)/sizeof(iw_handler), .num_private = sizeof(airo_private_handler)/sizeof(iw_handler),
.num_private_args = sizeof(airo_private_args)/sizeof(struct iw_priv_args), .num_private_args = sizeof(airo_private_args)/sizeof(struct iw_priv_args),
.standard = (iw_handler *) airo_handler, .standard = airo_handler,
.private = (iw_handler *) airo_private_handler, .private = airo_private_handler,
.private_args = (struct iw_priv_args *) airo_private_args, .private_args = airo_private_args,
.spy_offset = ((void *) (&((struct airo_info *) NULL)->spy_data) - .get_wireless_stats = airo_get_wireless_stats,
(void *) NULL),
}; };
#endif /* WIRELESS_EXT */ #endif /* WIRELESS_EXT */
......
...@@ -2172,6 +2172,11 @@ static int wavelan_get_range(struct net_device *dev, ...@@ -2172,6 +2172,11 @@ static int wavelan_get_range(struct net_device *dev,
range->num_bitrates = 1; range->num_bitrates = 1;
range->bitrate[0] = 2000000; /* 2 Mb/s */ range->bitrate[0] = 2000000; /* 2 Mb/s */
/* Event capability (kernel + driver) */
range->event_capa[0] = (IW_EVENT_CAPA_MASK(0x8B02) |
IW_EVENT_CAPA_MASK(0x8B04));
range->event_capa[1] = IW_EVENT_CAPA_K_1;
/* Disable interrupts and save flags. */ /* Disable interrupts and save flags. */
spin_lock_irqsave(&lp->spinlock, flags); spin_lock_irqsave(&lp->spinlock, flags);
...@@ -2403,11 +2408,10 @@ static const struct iw_handler_def wavelan_handler_def = ...@@ -2403,11 +2408,10 @@ static const struct iw_handler_def wavelan_handler_def =
.num_standard = sizeof(wavelan_handler)/sizeof(iw_handler), .num_standard = sizeof(wavelan_handler)/sizeof(iw_handler),
.num_private = sizeof(wavelan_private_handler)/sizeof(iw_handler), .num_private = sizeof(wavelan_private_handler)/sizeof(iw_handler),
.num_private_args = sizeof(wavelan_private_args)/sizeof(struct iw_priv_args), .num_private_args = sizeof(wavelan_private_args)/sizeof(struct iw_priv_args),
.standard = (iw_handler *) wavelan_handler, .standard = wavelan_handler,
.private = (iw_handler *) wavelan_private_handler, .private = wavelan_private_handler,
.private_args = (struct iw_priv_args *) wavelan_private_args, .private_args = wavelan_private_args,
.spy_offset = ((void *) (&((net_local *) NULL)->spy_data) - .get_wireless_stats = wavelan_get_wireless_stats,
(void *) NULL),
}; };
/*------------------------------------------------------------------*/ /*------------------------------------------------------------------*/
...@@ -4190,8 +4194,9 @@ static int __init wavelan_config(struct net_device *dev, unsigned short ioaddr) ...@@ -4190,8 +4194,9 @@ static int __init wavelan_config(struct net_device *dev, unsigned short ioaddr)
#endif /* SET_MAC_ADDRESS */ #endif /* SET_MAC_ADDRESS */
#ifdef WIRELESS_EXT /* if wireless extension exists in the kernel */ #ifdef WIRELESS_EXT /* if wireless extension exists in the kernel */
dev->get_wireless_stats = wavelan_get_wireless_stats; dev->wireless_handlers = &wavelan_handler_def;
dev->wireless_handlers = (struct iw_handler_def *)&wavelan_handler_def; lp->wireless_data.spy_data = &lp->spy_data;
dev->wireless_data = &lp->wireless_data;
#endif #endif
dev->mtu = WAVELAN_MTU; dev->mtu = WAVELAN_MTU;
......
...@@ -510,6 +510,7 @@ struct net_local ...@@ -510,6 +510,7 @@ struct net_local
iw_stats wstats; /* Wireless-specific statistics */ iw_stats wstats; /* Wireless-specific statistics */
struct iw_spy_data spy_data; struct iw_spy_data spy_data;
struct iw_public_data wireless_data;
#endif #endif
#ifdef HISTOGRAM #ifdef HISTOGRAM
...@@ -614,6 +615,8 @@ static inline void ...@@ -614,6 +615,8 @@ static inline void
/* ------------------- IOCTL, STATS & RECONFIG ------------------- */ /* ------------------- IOCTL, STATS & RECONFIG ------------------- */
static en_stats * static en_stats *
wavelan_get_stats(struct net_device *); /* Give stats /proc/net/dev */ wavelan_get_stats(struct net_device *); /* Give stats /proc/net/dev */
static iw_stats *
wavelan_get_wireless_stats(struct net_device *);
static void static void
wavelan_set_multicast_list(struct net_device *); wavelan_set_multicast_list(struct net_device *);
/* ----------------------- PACKET RECEPTION ----------------------- */ /* ----------------------- PACKET RECEPTION ----------------------- */
......
...@@ -1550,7 +1550,6 @@ wavelan_set_mac_address(struct net_device * dev, ...@@ -1550,7 +1550,6 @@ wavelan_set_mac_address(struct net_device * dev,
/* /*
* Frequency setting (for hardware able of it) * Frequency setting (for hardware able of it)
* It's a bit complicated and you don't really want to look into it... * It's a bit complicated and you don't really want to look into it...
* (called in wavelan_ioctl)
*/ */
static inline int static inline int
wv_set_frequency(u_long base, /* i/o port of the card */ wv_set_frequency(u_long base, /* i/o port of the card */
...@@ -2438,6 +2437,12 @@ static int wavelan_get_range(struct net_device *dev, ...@@ -2438,6 +2437,12 @@ static int wavelan_get_range(struct net_device *dev,
range->num_bitrates = 1; range->num_bitrates = 1;
range->bitrate[0] = 2000000; /* 2 Mb/s */ range->bitrate[0] = 2000000; /* 2 Mb/s */
/* Event capability (kernel + driver) */
range->event_capa[0] = (IW_EVENT_CAPA_MASK(0x8B02) |
IW_EVENT_CAPA_MASK(0x8B04) |
IW_EVENT_CAPA_MASK(0x8B06));
range->event_capa[1] = IW_EVENT_CAPA_K_1;
/* Disable interrupts and save flags. */ /* Disable interrupts and save flags. */
spin_lock_irqsave(&lp->spinlock, flags); spin_lock_irqsave(&lp->spinlock, flags);
...@@ -2737,11 +2742,10 @@ static const struct iw_handler_def wavelan_handler_def = ...@@ -2737,11 +2742,10 @@ static const struct iw_handler_def wavelan_handler_def =
.num_standard = sizeof(wavelan_handler)/sizeof(iw_handler), .num_standard = sizeof(wavelan_handler)/sizeof(iw_handler),
.num_private = sizeof(wavelan_private_handler)/sizeof(iw_handler), .num_private = sizeof(wavelan_private_handler)/sizeof(iw_handler),
.num_private_args = sizeof(wavelan_private_args)/sizeof(struct iw_priv_args), .num_private_args = sizeof(wavelan_private_args)/sizeof(struct iw_priv_args),
.standard = (iw_handler *) wavelan_handler, .standard = wavelan_handler,
.private = (iw_handler *) wavelan_private_handler, .private = wavelan_private_handler,
.private_args = (struct iw_priv_args *) wavelan_private_args, .private_args = wavelan_private_args,
.spy_offset = ((void *) (&((net_local *) NULL)->spy_data) - .get_wireless_stats = wavelan_get_wireless_stats,
(void *) NULL),
}; };
/*------------------------------------------------------------------*/ /*------------------------------------------------------------------*/
...@@ -4720,9 +4724,10 @@ wavelan_attach(void) ...@@ -4720,9 +4724,10 @@ wavelan_attach(void)
dev->watchdog_timeo = WATCHDOG_JIFFIES; dev->watchdog_timeo = WATCHDOG_JIFFIES;
#ifdef WIRELESS_EXT /* If wireless extension exist in the kernel */ #ifdef WIRELESS_EXT /* If wireless extension exist in the kernel */
dev->wireless_handlers = (struct iw_handler_def *)&wavelan_handler_def; dev->wireless_handlers = &wavelan_handler_def;
dev->do_ioctl = wavelan_ioctl; /* old wireless extensions */ dev->do_ioctl = wavelan_ioctl; /* ethtool */
dev->get_wireless_stats = wavelan_get_wireless_stats; lp->wireless_data.spy_data = &lp->spy_data;
dev->wireless_data = &lp->wireless_data;
#endif #endif
/* Other specific data */ /* Other specific data */
......
...@@ -629,6 +629,7 @@ struct net_local ...@@ -629,6 +629,7 @@ struct net_local
iw_stats wstats; /* Wireless specific stats */ iw_stats wstats; /* Wireless specific stats */
struct iw_spy_data spy_data; struct iw_spy_data spy_data;
struct iw_public_data wireless_data;
#endif #endif
#ifdef HISTOGRAM #ifdef HISTOGRAM
...@@ -725,6 +726,8 @@ static inline void ...@@ -725,6 +726,8 @@ static inline void
/* ------------------- IOCTL, STATS & RECONFIG ------------------- */ /* ------------------- IOCTL, STATS & RECONFIG ------------------- */
static en_stats * static en_stats *
wavelan_get_stats(struct net_device *); /* Give stats /proc/net/dev */ wavelan_get_stats(struct net_device *); /* Give stats /proc/net/dev */
static iw_stats *
wavelan_get_wireless_stats(struct net_device *);
/* ----------------------- PACKET RECEPTION ----------------------- */ /* ----------------------- PACKET RECEPTION ----------------------- */
static inline int static inline int
wv_start_of_frame(struct net_device *, /* Seek beggining of current frame */ wv_start_of_frame(struct net_device *, /* Seek beggining of current frame */
......
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