Staging: wlan-ng: p80211netdev.c: Coding style cleanups
Signed-off-by: Moritz Muehlenhoff <jmm@debian.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
f342288244
commit
b4b3f0da84
1 changed files with 128 additions and 167 deletions
|
@ -49,13 +49,7 @@
|
||||||
* --------------------------------------------------------------------
|
* --------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/*================================================================*/
|
|
||||||
/* System Includes */
|
|
||||||
|
|
||||||
|
|
||||||
#include <linux/version.h>
|
#include <linux/version.h>
|
||||||
|
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
|
@ -72,9 +66,8 @@
|
||||||
#include <linux/etherdevice.h>
|
#include <linux/etherdevice.h>
|
||||||
#include <linux/if_ether.h>
|
#include <linux/if_ether.h>
|
||||||
#include <linux/byteorder/generic.h>
|
#include <linux/byteorder/generic.h>
|
||||||
|
#include <linux/bitops.h>
|
||||||
#include <asm/bitops.h>
|
#include <linux/uaccess.h>
|
||||||
#include <asm/uaccess.h>
|
|
||||||
#include <asm/byteorder.h>
|
#include <asm/byteorder.h>
|
||||||
|
|
||||||
#ifdef SIOCETHTOOL
|
#ifdef SIOCETHTOOL
|
||||||
|
@ -99,33 +92,22 @@
|
||||||
#include "p80211metastruct.h"
|
#include "p80211metastruct.h"
|
||||||
#include "p80211metadef.h"
|
#include "p80211metadef.h"
|
||||||
|
|
||||||
/*================================================================*/
|
|
||||||
/* Local Constants */
|
|
||||||
|
|
||||||
/*================================================================*/
|
|
||||||
/* Local Macros */
|
|
||||||
|
|
||||||
|
|
||||||
/*================================================================*/
|
|
||||||
/* Local Types */
|
|
||||||
|
|
||||||
/*================================================================*/
|
|
||||||
/* Local Function Declarations */
|
|
||||||
|
|
||||||
/* Support functions */
|
/* Support functions */
|
||||||
static void p80211netdev_rx_bh(unsigned long arg);
|
static void p80211netdev_rx_bh(unsigned long arg);
|
||||||
|
|
||||||
/* netdevice method functions */
|
/* netdevice method functions */
|
||||||
static int p80211knetdev_init( netdevice_t *netdev);
|
static int p80211knetdev_init(netdevice_t *netdev);
|
||||||
static struct net_device_stats* p80211knetdev_get_stats(netdevice_t *netdev);
|
static struct net_device_stats *p80211knetdev_get_stats(netdevice_t *netdev);
|
||||||
static int p80211knetdev_open( netdevice_t *netdev);
|
static int p80211knetdev_open(netdevice_t *netdev);
|
||||||
static int p80211knetdev_stop( netdevice_t *netdev );
|
static int p80211knetdev_stop(netdevice_t *netdev);
|
||||||
static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netdev);
|
static int p80211knetdev_hard_start_xmit(struct sk_buff *skb,
|
||||||
|
netdevice_t *netdev);
|
||||||
static void p80211knetdev_set_multicast_list(netdevice_t *dev);
|
static void p80211knetdev_set_multicast_list(netdevice_t *dev);
|
||||||
static int p80211knetdev_do_ioctl(netdevice_t *dev, struct ifreq *ifr, int cmd);
|
static int p80211knetdev_do_ioctl(netdevice_t *dev, struct ifreq *ifr,
|
||||||
|
int cmd);
|
||||||
static int p80211knetdev_set_mac_address(netdevice_t *dev, void *addr);
|
static int p80211knetdev_set_mac_address(netdevice_t *dev, void *addr);
|
||||||
static void p80211knetdev_tx_timeout(netdevice_t *netdev);
|
static void p80211knetdev_tx_timeout(netdevice_t *netdev);
|
||||||
static int p80211_rx_typedrop( wlandevice_t *wlandev, u16 fc);
|
static int p80211_rx_typedrop(wlandevice_t *wlandev, u16 fc);
|
||||||
|
|
||||||
int wlan_watchdog = 5000;
|
int wlan_watchdog = 5000;
|
||||||
module_param(wlan_watchdog, int, 0644);
|
module_param(wlan_watchdog, int, 0644);
|
||||||
|
@ -135,9 +117,6 @@ int wlan_wext_write = 1;
|
||||||
module_param(wlan_wext_write, int, 0644);
|
module_param(wlan_wext_write, int, 0644);
|
||||||
MODULE_PARM_DESC(wlan_wext_write, "enable write wireless extensions");
|
MODULE_PARM_DESC(wlan_wext_write, "enable write wireless extensions");
|
||||||
|
|
||||||
/*================================================================*/
|
|
||||||
/* Function Definitions */
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* p80211knetdev_init
|
* p80211knetdev_init
|
||||||
*
|
*
|
||||||
|
@ -150,7 +129,7 @@ MODULE_PARM_DESC(wlan_wext_write, "enable write wireless extensions");
|
||||||
* Returns:
|
* Returns:
|
||||||
* nothing
|
* nothing
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
static int p80211knetdev_init( netdevice_t *netdev)
|
static int p80211knetdev_init(netdevice_t *netdev)
|
||||||
{
|
{
|
||||||
/* Called in response to register_netdev */
|
/* Called in response to register_netdev */
|
||||||
/* This is usually the probe function, but the probe has */
|
/* This is usually the probe function, but the probe has */
|
||||||
|
@ -159,7 +138,6 @@ static int p80211knetdev_init( netdevice_t *netdev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* p80211knetdev_get_stats
|
* p80211knetdev_get_stats
|
||||||
*
|
*
|
||||||
|
@ -174,18 +152,16 @@ static int p80211knetdev_init( netdevice_t *netdev)
|
||||||
* Returns:
|
* Returns:
|
||||||
* the address of the statistics structure
|
* the address of the statistics structure
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
static struct net_device_stats*
|
static struct net_device_stats *p80211knetdev_get_stats(netdevice_t *netdev)
|
||||||
p80211knetdev_get_stats(netdevice_t *netdev)
|
|
||||||
{
|
{
|
||||||
wlandevice_t *wlandev = netdev->ml_priv;
|
wlandevice_t *wlandev = netdev->ml_priv;
|
||||||
|
|
||||||
/* TODO: review the MIB stats for items that correspond to
|
/* TODO: review the MIB stats for items that correspond to
|
||||||
linux stats */
|
linux stats */
|
||||||
|
|
||||||
return &(wlandev->linux_stats);
|
return &(wlandev->linux_stats);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* p80211knetdev_open
|
* p80211knetdev_open
|
||||||
*
|
*
|
||||||
|
@ -200,20 +176,19 @@ p80211knetdev_get_stats(netdevice_t *netdev)
|
||||||
* Returns:
|
* Returns:
|
||||||
* zero on success, non-zero otherwise
|
* zero on success, non-zero otherwise
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
static int p80211knetdev_open( netdevice_t *netdev )
|
static int p80211knetdev_open(netdevice_t *netdev)
|
||||||
{
|
{
|
||||||
int result = 0; /* success */
|
int result = 0; /* success */
|
||||||
wlandevice_t *wlandev = netdev->ml_priv;
|
wlandevice_t *wlandev = netdev->ml_priv;
|
||||||
|
|
||||||
/* Check to make sure the MSD is running */
|
/* Check to make sure the MSD is running */
|
||||||
if ( wlandev->msdstate != WLAN_MSD_RUNNING ) {
|
if (wlandev->msdstate != WLAN_MSD_RUNNING)
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
}
|
|
||||||
|
|
||||||
/* Tell the MSD to open */
|
/* Tell the MSD to open */
|
||||||
if ( wlandev->open != NULL) {
|
if (wlandev->open != NULL) {
|
||||||
result = wlandev->open(wlandev);
|
result = wlandev->open(wlandev);
|
||||||
if ( result == 0 ) {
|
if (result == 0) {
|
||||||
netif_start_queue(wlandev->netdev);
|
netif_start_queue(wlandev->netdev);
|
||||||
wlandev->state = WLAN_DEVICE_OPEN;
|
wlandev->state = WLAN_DEVICE_OPEN;
|
||||||
}
|
}
|
||||||
|
@ -224,7 +199,6 @@ static int p80211knetdev_open( netdevice_t *netdev )
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* p80211knetdev_stop
|
* p80211knetdev_stop
|
||||||
*
|
*
|
||||||
|
@ -237,14 +211,13 @@ static int p80211knetdev_open( netdevice_t *netdev )
|
||||||
* Returns:
|
* Returns:
|
||||||
* zero on success, non-zero otherwise
|
* zero on success, non-zero otherwise
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
static int p80211knetdev_stop( netdevice_t *netdev )
|
static int p80211knetdev_stop(netdevice_t *netdev)
|
||||||
{
|
{
|
||||||
int result = 0;
|
int result = 0;
|
||||||
wlandevice_t *wlandev = netdev->ml_priv;
|
wlandevice_t *wlandev = netdev->ml_priv;
|
||||||
|
|
||||||
if ( wlandev->close != NULL ) {
|
if (wlandev->close != NULL)
|
||||||
result = wlandev->close(wlandev);
|
result = wlandev->close(wlandev);
|
||||||
}
|
|
||||||
|
|
||||||
netif_stop_queue(wlandev->netdev);
|
netif_stop_queue(wlandev->netdev);
|
||||||
wlandev->state = WLAN_DEVICE_CLOSED;
|
wlandev->state = WLAN_DEVICE_CLOSED;
|
||||||
|
@ -265,8 +238,7 @@ static int p80211knetdev_stop( netdevice_t *netdev )
|
||||||
* Side effects:
|
* Side effects:
|
||||||
*
|
*
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
void
|
void p80211netdev_rx(wlandevice_t *wlandev, struct sk_buff *skb)
|
||||||
p80211netdev_rx(wlandevice_t *wlandev, struct sk_buff *skb )
|
|
||||||
{
|
{
|
||||||
/* Enqueue for post-irq processing */
|
/* Enqueue for post-irq processing */
|
||||||
skb_queue_tail(&wlandev->nsd_rxq, skb);
|
skb_queue_tail(&wlandev->nsd_rxq, skb);
|
||||||
|
@ -293,17 +265,17 @@ static void p80211netdev_rx_bh(unsigned long arg)
|
||||||
{
|
{
|
||||||
wlandevice_t *wlandev = (wlandevice_t *) arg;
|
wlandevice_t *wlandev = (wlandevice_t *) arg;
|
||||||
struct sk_buff *skb = NULL;
|
struct sk_buff *skb = NULL;
|
||||||
netdevice_t *dev = wlandev->netdev;
|
netdevice_t *dev = wlandev->netdev;
|
||||||
p80211_hdr_a3_t *hdr;
|
p80211_hdr_a3_t *hdr;
|
||||||
u16 fc;
|
u16 fc;
|
||||||
|
|
||||||
/* Let's empty our our queue */
|
/* Let's empty our our queue */
|
||||||
while ( (skb = skb_dequeue(&wlandev->nsd_rxq)) ) {
|
while ((skb = skb_dequeue(&wlandev->nsd_rxq))) {
|
||||||
if (wlandev->state == WLAN_DEVICE_OPEN) {
|
if (wlandev->state == WLAN_DEVICE_OPEN) {
|
||||||
|
|
||||||
if (dev->type != ARPHRD_ETHER) {
|
if (dev->type != ARPHRD_ETHER) {
|
||||||
/* RAW frame; we shouldn't convert it */
|
/* RAW frame; we shouldn't convert it */
|
||||||
// XXX Append the Prism Header here instead.
|
/* XXX Append the Prism Header here instead. */
|
||||||
|
|
||||||
/* set up various data fields */
|
/* set up various data fields */
|
||||||
skb->dev = dev;
|
skb->dev = dev;
|
||||||
|
@ -318,7 +290,7 @@ static void p80211netdev_rx_bh(unsigned long arg)
|
||||||
netif_rx_ni(skb);
|
netif_rx_ni(skb);
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
hdr = (p80211_hdr_a3_t *)skb->data;
|
hdr = (p80211_hdr_a3_t *) skb->data;
|
||||||
fc = le16_to_cpu(hdr->fc);
|
fc = le16_to_cpu(hdr->fc);
|
||||||
if (p80211_rx_typedrop(wlandev, fc)) {
|
if (p80211_rx_typedrop(wlandev, fc)) {
|
||||||
dev_kfree_skb(skb);
|
dev_kfree_skb(skb);
|
||||||
|
@ -328,7 +300,9 @@ static void p80211netdev_rx_bh(unsigned long arg)
|
||||||
/* perform mcast filtering */
|
/* perform mcast filtering */
|
||||||
if (wlandev->netdev->flags & IFF_ALLMULTI) {
|
if (wlandev->netdev->flags & IFF_ALLMULTI) {
|
||||||
/* allow my local address through */
|
/* allow my local address through */
|
||||||
if (memcmp(hdr->a1, wlandev->netdev->dev_addr, ETH_ALEN) != 0) {
|
if (memcmp
|
||||||
|
(hdr->a1, wlandev->netdev->dev_addr,
|
||||||
|
ETH_ALEN) != 0) {
|
||||||
/* but reject anything else that isn't multicast */
|
/* but reject anything else that isn't multicast */
|
||||||
if (!(hdr->a1[0] & 0x01)) {
|
if (!(hdr->a1[0] & 0x01)) {
|
||||||
dev_kfree_skb(skb);
|
dev_kfree_skb(skb);
|
||||||
|
@ -337,21 +311,22 @@ static void p80211netdev_rx_bh(unsigned long arg)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( skb_p80211_to_ether(wlandev, wlandev->ethconv, skb) == 0 ) {
|
if (skb_p80211_to_ether
|
||||||
|
(wlandev, wlandev->ethconv, skb) == 0) {
|
||||||
skb->dev->last_rx = jiffies;
|
skb->dev->last_rx = jiffies;
|
||||||
wlandev->linux_stats.rx_packets++;
|
wlandev->linux_stats.rx_packets++;
|
||||||
wlandev->linux_stats.rx_bytes += skb->len;
|
wlandev->linux_stats.rx_bytes +=
|
||||||
|
skb->len;
|
||||||
netif_rx_ni(skb);
|
netif_rx_ni(skb);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
pr_debug( "p80211_to_ether failed.\n");
|
pr_debug("p80211_to_ether failed.\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
dev_kfree_skb(skb);
|
dev_kfree_skb(skb);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* p80211knetdev_hard_start_xmit
|
* p80211knetdev_hard_start_xmit
|
||||||
*
|
*
|
||||||
|
@ -371,19 +346,19 @@ static void p80211netdev_rx_bh(unsigned long arg)
|
||||||
* Returns:
|
* Returns:
|
||||||
* zero on success, non-zero on failure.
|
* zero on success, non-zero on failure.
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netdev)
|
static int p80211knetdev_hard_start_xmit(struct sk_buff *skb,
|
||||||
|
netdevice_t *netdev)
|
||||||
{
|
{
|
||||||
int result = 0;
|
int result = 0;
|
||||||
int txresult = -1;
|
int txresult = -1;
|
||||||
wlandevice_t *wlandev = netdev->ml_priv;
|
wlandevice_t *wlandev = netdev->ml_priv;
|
||||||
p80211_hdr_t p80211_hdr;
|
p80211_hdr_t p80211_hdr;
|
||||||
p80211_metawep_t p80211_wep;
|
p80211_metawep_t p80211_wep;
|
||||||
|
|
||||||
if (skb == NULL) {
|
if (skb == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
|
|
||||||
if (wlandev->state != WLAN_DEVICE_OPEN) {
|
if (wlandev->state != WLAN_DEVICE_OPEN) {
|
||||||
result = 1;
|
result = 1;
|
||||||
goto failed;
|
goto failed;
|
||||||
}
|
}
|
||||||
|
@ -391,7 +366,7 @@ static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netd
|
||||||
memset(&p80211_hdr, 0, sizeof(p80211_hdr_t));
|
memset(&p80211_hdr, 0, sizeof(p80211_hdr_t));
|
||||||
memset(&p80211_wep, 0, sizeof(p80211_metawep_t));
|
memset(&p80211_wep, 0, sizeof(p80211_metawep_t));
|
||||||
|
|
||||||
if ( netif_queue_stopped(netdev) ) {
|
if (netif_queue_stopped(netdev)) {
|
||||||
pr_debug("called when queue stopped.\n");
|
pr_debug("called when queue stopped.\n");
|
||||||
result = 1;
|
result = 1;
|
||||||
goto failed;
|
goto failed;
|
||||||
|
@ -400,7 +375,7 @@ static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netd
|
||||||
netif_stop_queue(netdev);
|
netif_stop_queue(netdev);
|
||||||
|
|
||||||
/* Check to see that a valid mode is set */
|
/* Check to see that a valid mode is set */
|
||||||
switch( wlandev->macmode ) {
|
switch (wlandev->macmode) {
|
||||||
case WLAN_MACMODE_IBSS_STA:
|
case WLAN_MACMODE_IBSS_STA:
|
||||||
case WLAN_MACMODE_ESS_STA:
|
case WLAN_MACMODE_ESS_STA:
|
||||||
case WLAN_MACMODE_ESS_AP:
|
case WLAN_MACMODE_ESS_AP:
|
||||||
|
@ -410,10 +385,10 @@ static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netd
|
||||||
* and return success .
|
* and return success .
|
||||||
* TODO: we need a saner way to handle this
|
* TODO: we need a saner way to handle this
|
||||||
*/
|
*/
|
||||||
if(skb->protocol != ETH_P_80211_RAW) {
|
if (skb->protocol != ETH_P_80211_RAW) {
|
||||||
netif_start_queue(wlandev->netdev);
|
netif_start_queue(wlandev->netdev);
|
||||||
printk(KERN_NOTICE
|
printk(KERN_NOTICE
|
||||||
"Tx attempt prior to association, frame dropped.\n");
|
"Tx attempt prior to association, frame dropped.\n");
|
||||||
wlandev->linux_stats.tx_dropped++;
|
wlandev->linux_stats.tx_dropped++;
|
||||||
result = 0;
|
result = 0;
|
||||||
goto failed;
|
goto failed;
|
||||||
|
@ -422,7 +397,7 @@ static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netd
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check for raw transmits */
|
/* Check for raw transmits */
|
||||||
if(skb->protocol == ETH_P_80211_RAW) {
|
if (skb->protocol == ETH_P_80211_RAW) {
|
||||||
if (!capable(CAP_NET_ADMIN)) {
|
if (!capable(CAP_NET_ADMIN)) {
|
||||||
result = 1;
|
result = 1;
|
||||||
goto failed;
|
goto failed;
|
||||||
|
@ -431,15 +406,17 @@ static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netd
|
||||||
memcpy(&p80211_hdr, skb->data, sizeof(p80211_hdr_t));
|
memcpy(&p80211_hdr, skb->data, sizeof(p80211_hdr_t));
|
||||||
skb_pull(skb, sizeof(p80211_hdr_t));
|
skb_pull(skb, sizeof(p80211_hdr_t));
|
||||||
} else {
|
} else {
|
||||||
if ( skb_ether_to_p80211(wlandev, wlandev->ethconv, skb, &p80211_hdr, &p80211_wep) != 0 ) {
|
if (skb_ether_to_p80211
|
||||||
|
(wlandev, wlandev->ethconv, skb, &p80211_hdr,
|
||||||
|
&p80211_wep) != 0) {
|
||||||
/* convert failed */
|
/* convert failed */
|
||||||
pr_debug("ether_to_80211(%d) failed.\n",
|
pr_debug("ether_to_80211(%d) failed.\n",
|
||||||
wlandev->ethconv);
|
wlandev->ethconv);
|
||||||
result = 1;
|
result = 1;
|
||||||
goto failed;
|
goto failed;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ( wlandev->txframe == NULL ) {
|
if (wlandev->txframe == NULL) {
|
||||||
result = 1;
|
result = 1;
|
||||||
goto failed;
|
goto failed;
|
||||||
}
|
}
|
||||||
|
@ -452,18 +429,18 @@ static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netd
|
||||||
|
|
||||||
txresult = wlandev->txframe(wlandev, skb, &p80211_hdr, &p80211_wep);
|
txresult = wlandev->txframe(wlandev, skb, &p80211_hdr, &p80211_wep);
|
||||||
|
|
||||||
if ( txresult == 0) {
|
if (txresult == 0) {
|
||||||
/* success and more buf */
|
/* success and more buf */
|
||||||
/* avail, re: hw_txdata */
|
/* avail, re: hw_txdata */
|
||||||
netif_wake_queue(wlandev->netdev);
|
netif_wake_queue(wlandev->netdev);
|
||||||
result = 0;
|
result = 0;
|
||||||
} else if ( txresult == 1 ) {
|
} else if (txresult == 1) {
|
||||||
/* success, no more avail */
|
/* success, no more avail */
|
||||||
pr_debug("txframe success, no more bufs\n");
|
pr_debug("txframe success, no more bufs\n");
|
||||||
/* netdev->tbusy = 1; don't set here, irqhdlr */
|
/* netdev->tbusy = 1; don't set here, irqhdlr */
|
||||||
/* may have already cleared it */
|
/* may have already cleared it */
|
||||||
result = 0;
|
result = 0;
|
||||||
} else if ( txresult == 2 ) {
|
} else if (txresult == 2) {
|
||||||
/* alloc failure, drop frame */
|
/* alloc failure, drop frame */
|
||||||
pr_debug("txframe returned alloc_fail\n");
|
pr_debug("txframe returned alloc_fail\n");
|
||||||
result = 1;
|
result = 1;
|
||||||
|
@ -473,7 +450,7 @@ static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netd
|
||||||
result = 1;
|
result = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
failed:
|
failed:
|
||||||
/* Free up the WEP buffer if it's not the same as the skb */
|
/* Free up the WEP buffer if it's not the same as the skb */
|
||||||
if ((p80211_wep.data) && (p80211_wep.data != skb->data))
|
if ((p80211_wep.data) && (p80211_wep.data != skb->data))
|
||||||
kfree(p80211_wep.data);
|
kfree(p80211_wep.data);
|
||||||
|
@ -485,7 +462,6 @@ static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netd
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* p80211knetdev_set_multicast_list
|
* p80211knetdev_set_multicast_list
|
||||||
*
|
*
|
||||||
|
@ -500,7 +476,7 @@ static int p80211knetdev_hard_start_xmit( struct sk_buff *skb, netdevice_t *netd
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
static void p80211knetdev_set_multicast_list(netdevice_t *dev)
|
static void p80211knetdev_set_multicast_list(netdevice_t *dev)
|
||||||
{
|
{
|
||||||
wlandevice_t *wlandev = dev->ml_priv;
|
wlandevice_t *wlandev = dev->ml_priv;
|
||||||
|
|
||||||
/* TODO: real multicast support as well */
|
/* TODO: real multicast support as well */
|
||||||
|
|
||||||
|
@ -531,9 +507,6 @@ static int p80211netdev_ethtool(wlandevice_t *wlandev, void __user *useraddr)
|
||||||
snprintf(info.version, sizeof(info.version), "%s",
|
snprintf(info.version, sizeof(info.version), "%s",
|
||||||
WLAN_RELEASE);
|
WLAN_RELEASE);
|
||||||
|
|
||||||
// info.fw_version
|
|
||||||
// info.bus_info
|
|
||||||
|
|
||||||
if (copy_to_user(useraddr, &info, sizeof(info)))
|
if (copy_to_user(useraddr, &info, sizeof(info)))
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -549,7 +522,7 @@ static int p80211netdev_ethtool(wlandevice_t *wlandev, void __user *useraddr)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (copy_to_user(useraddr, &edata, sizeof(edata)))
|
if (copy_to_user(useraddr, &edata, sizeof(edata)))
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -588,44 +561,45 @@ static int p80211netdev_ethtool(wlandevice_t *wlandev, void __user *useraddr)
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
static int p80211knetdev_do_ioctl(netdevice_t *dev, struct ifreq *ifr, int cmd)
|
static int p80211knetdev_do_ioctl(netdevice_t *dev, struct ifreq *ifr, int cmd)
|
||||||
{
|
{
|
||||||
int result = 0;
|
int result = 0;
|
||||||
p80211ioctl_req_t *req = (p80211ioctl_req_t*)ifr;
|
p80211ioctl_req_t *req = (p80211ioctl_req_t *) ifr;
|
||||||
wlandevice_t *wlandev = dev->ml_priv;
|
wlandevice_t *wlandev = dev->ml_priv;
|
||||||
u8 *msgbuf;
|
u8 *msgbuf;
|
||||||
|
|
||||||
pr_debug("rx'd ioctl, cmd=%d, len=%d\n", cmd, req->len);
|
pr_debug("rx'd ioctl, cmd=%d, len=%d\n", cmd, req->len);
|
||||||
|
|
||||||
#ifdef SIOCETHTOOL
|
#ifdef SIOCETHTOOL
|
||||||
if (cmd == SIOCETHTOOL) {
|
if (cmd == SIOCETHTOOL) {
|
||||||
result = p80211netdev_ethtool(wlandev, (void __user *) ifr->ifr_data);
|
result =
|
||||||
|
p80211netdev_ethtool(wlandev, (void __user *)ifr->ifr_data);
|
||||||
goto bail;
|
goto bail;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Test the magic, assume ifr is good if it's there */
|
/* Test the magic, assume ifr is good if it's there */
|
||||||
if ( req->magic != P80211_IOCTL_MAGIC ) {
|
if (req->magic != P80211_IOCTL_MAGIC) {
|
||||||
result = -ENOSYS;
|
result = -ENOSYS;
|
||||||
goto bail;
|
goto bail;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( cmd == P80211_IFTEST ) {
|
if (cmd == P80211_IFTEST) {
|
||||||
result = 0;
|
result = 0;
|
||||||
goto bail;
|
goto bail;
|
||||||
} else if ( cmd != P80211_IFREQ ) {
|
} else if (cmd != P80211_IFREQ) {
|
||||||
result = -ENOSYS;
|
result = -ENOSYS;
|
||||||
goto bail;
|
goto bail;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Allocate a buf of size req->len */
|
/* Allocate a buf of size req->len */
|
||||||
if ((msgbuf = kmalloc( req->len, GFP_KERNEL))) {
|
if ((msgbuf = kmalloc(req->len, GFP_KERNEL))) {
|
||||||
if ( copy_from_user( msgbuf, (void __user *) req->data, req->len) ) {
|
if (copy_from_user(msgbuf, (void __user *)req->data, req->len))
|
||||||
result = -EFAULT;
|
result = -EFAULT;
|
||||||
} else {
|
else
|
||||||
result = p80211req_dorequest( wlandev, msgbuf);
|
result = p80211req_dorequest(wlandev, msgbuf);
|
||||||
}
|
|
||||||
|
|
||||||
if ( result == 0 ) {
|
if (result == 0) {
|
||||||
if ( copy_to_user( (void __user *) req->data, msgbuf, req->len)) {
|
if (copy_to_user
|
||||||
|
((void __user *)req->data, msgbuf, req->len)) {
|
||||||
result = -EFAULT;
|
result = -EFAULT;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -634,7 +608,7 @@ static int p80211knetdev_do_ioctl(netdevice_t *dev, struct ifreq *ifr, int cmd)
|
||||||
result = -ENOMEM;
|
result = -ENOMEM;
|
||||||
}
|
}
|
||||||
bail:
|
bail:
|
||||||
return result; /* If allocate,copyfrom or copyto fails, return errno */
|
return result; /* If allocate,copyfrom or copyto fails, return errno */
|
||||||
}
|
}
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
|
@ -664,21 +638,20 @@ bail:
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
static int p80211knetdev_set_mac_address(netdevice_t *dev, void *addr)
|
static int p80211knetdev_set_mac_address(netdevice_t *dev, void *addr)
|
||||||
{
|
{
|
||||||
struct sockaddr *new_addr = addr;
|
struct sockaddr *new_addr = addr;
|
||||||
p80211msg_dot11req_mibset_t dot11req;
|
p80211msg_dot11req_mibset_t dot11req;
|
||||||
p80211item_unk392_t *mibattr;
|
p80211item_unk392_t *mibattr;
|
||||||
p80211item_pstr6_t *macaddr;
|
p80211item_pstr6_t *macaddr;
|
||||||
p80211item_uint32_t *resultcode;
|
p80211item_uint32_t *resultcode;
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
|
||||||
/* If we're running, we don't allow MAC address changes */
|
/* If we're running, we don't allow MAC address changes */
|
||||||
if (netif_running(dev)) {
|
if (netif_running(dev))
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
|
||||||
|
|
||||||
/* Set up some convenience pointers. */
|
/* Set up some convenience pointers. */
|
||||||
mibattr = &dot11req.mibattribute;
|
mibattr = &dot11req.mibattribute;
|
||||||
macaddr = (p80211item_pstr6_t*)&mibattr->data;
|
macaddr = (p80211item_pstr6_t *)&mibattr->data;
|
||||||
resultcode = &dot11req.resultcode;
|
resultcode = &dot11req.resultcode;
|
||||||
|
|
||||||
/* Set up a dot11req_mibset */
|
/* Set up a dot11req_mibset */
|
||||||
|
@ -686,8 +659,7 @@ static int p80211knetdev_set_mac_address(netdevice_t *dev, void *addr)
|
||||||
dot11req.msgcode = DIDmsg_dot11req_mibset;
|
dot11req.msgcode = DIDmsg_dot11req_mibset;
|
||||||
dot11req.msglen = sizeof(p80211msg_dot11req_mibset_t);
|
dot11req.msglen = sizeof(p80211msg_dot11req_mibset_t);
|
||||||
memcpy(dot11req.devname,
|
memcpy(dot11req.devname,
|
||||||
((wlandevice_t *)dev->ml_priv)->name,
|
((wlandevice_t *) dev->ml_priv)->name, WLAN_DEVNAMELEN_MAX - 1);
|
||||||
WLAN_DEVNAMELEN_MAX - 1);
|
|
||||||
|
|
||||||
/* Set up the mibattribute argument */
|
/* Set up the mibattribute argument */
|
||||||
mibattr->did = DIDmsg_dot11req_mibset_mibattribute;
|
mibattr->did = DIDmsg_dot11req_mibset_mibattribute;
|
||||||
|
@ -712,9 +684,9 @@ static int p80211knetdev_set_mac_address(netdevice_t *dev, void *addr)
|
||||||
/* If the request wasn't successful, report an error and don't
|
/* If the request wasn't successful, report an error and don't
|
||||||
* change the netdev address
|
* change the netdev address
|
||||||
*/
|
*/
|
||||||
if ( result != 0 || resultcode->data != P80211ENUM_resultcode_success) {
|
if (result != 0 || resultcode->data != P80211ENUM_resultcode_success) {
|
||||||
printk(KERN_ERR
|
printk(KERN_ERR
|
||||||
"Low-level driver failed dot11req_mibset(dot11MACAddress).\n");
|
"Low-level driver failed dot11req_mibset(dot11MACAddress).\n");
|
||||||
result = -EADDRNOTAVAIL;
|
result = -EADDRNOTAVAIL;
|
||||||
} else {
|
} else {
|
||||||
/* everything's ok, change the addr in netdev */
|
/* everything's ok, change the addr in netdev */
|
||||||
|
@ -726,18 +698,16 @@ static int p80211knetdev_set_mac_address(netdevice_t *dev, void *addr)
|
||||||
|
|
||||||
static int wlan_change_mtu(netdevice_t *dev, int new_mtu)
|
static int wlan_change_mtu(netdevice_t *dev, int new_mtu)
|
||||||
{
|
{
|
||||||
// 2312 is max 802.11 payload, 20 is overhead, (ether + llc +snap)
|
/* 2312 is max 802.11 payload, 20 is overhead, (ether + llc +snap)
|
||||||
// and another 8 for wep.
|
and another 8 for wep. */
|
||||||
if ( (new_mtu < 68) || (new_mtu > (2312 - 20 - 8)))
|
if ((new_mtu < 68) || (new_mtu > (2312 - 20 - 8)))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
dev->mtu = new_mtu;
|
dev->mtu = new_mtu;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* wlan_setup
|
* wlan_setup
|
||||||
*
|
*
|
||||||
|
@ -762,8 +732,8 @@ static int wlan_change_mtu(netdevice_t *dev, int new_mtu)
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
int wlan_setup(wlandevice_t *wlandev)
|
int wlan_setup(wlandevice_t *wlandev)
|
||||||
{
|
{
|
||||||
int result = 0;
|
int result = 0;
|
||||||
netdevice_t *dev;
|
netdevice_t *dev;
|
||||||
|
|
||||||
/* Set up the wlandev */
|
/* Set up the wlandev */
|
||||||
wlandev->state = WLAN_DEVICE_CLOSED;
|
wlandev->state = WLAN_DEVICE_CLOSED;
|
||||||
|
@ -773,28 +743,27 @@ int wlan_setup(wlandevice_t *wlandev)
|
||||||
/* Set up the rx queue */
|
/* Set up the rx queue */
|
||||||
skb_queue_head_init(&wlandev->nsd_rxq);
|
skb_queue_head_init(&wlandev->nsd_rxq);
|
||||||
tasklet_init(&wlandev->rx_bh,
|
tasklet_init(&wlandev->rx_bh,
|
||||||
p80211netdev_rx_bh,
|
p80211netdev_rx_bh, (unsigned long)wlandev);
|
||||||
(unsigned long)wlandev);
|
|
||||||
|
|
||||||
/* Allocate and initialize the struct device */
|
/* Allocate and initialize the struct device */
|
||||||
dev = alloc_netdev(0,"wlan%d",ether_setup);
|
dev = alloc_netdev(0, "wlan%d", ether_setup);
|
||||||
if ( dev == NULL ) {
|
if (dev == NULL) {
|
||||||
printk(KERN_ERR "Failed to alloc netdev.\n");
|
printk(KERN_ERR "Failed to alloc netdev.\n");
|
||||||
result = 1;
|
result = 1;
|
||||||
} else {
|
} else {
|
||||||
wlandev->netdev = dev;
|
wlandev->netdev = dev;
|
||||||
dev->ml_priv = wlandev;
|
dev->ml_priv = wlandev;
|
||||||
dev->hard_start_xmit = p80211knetdev_hard_start_xmit;
|
dev->hard_start_xmit = p80211knetdev_hard_start_xmit;
|
||||||
dev->get_stats = p80211knetdev_get_stats;
|
dev->get_stats = p80211knetdev_get_stats;
|
||||||
#ifdef HAVE_PRIVATE_IOCTL
|
#ifdef HAVE_PRIVATE_IOCTL
|
||||||
dev->do_ioctl = p80211knetdev_do_ioctl;
|
dev->do_ioctl = p80211knetdev_do_ioctl;
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_MULTICAST
|
#ifdef HAVE_MULTICAST
|
||||||
dev->set_multicast_list = p80211knetdev_set_multicast_list;
|
dev->set_multicast_list = p80211knetdev_set_multicast_list;
|
||||||
#endif
|
#endif
|
||||||
dev->init = p80211knetdev_init;
|
dev->init = p80211knetdev_init;
|
||||||
dev->open = p80211knetdev_open;
|
dev->open = p80211knetdev_open;
|
||||||
dev->stop = p80211knetdev_stop;
|
dev->stop = p80211knetdev_stop;
|
||||||
|
|
||||||
#if (WIRELESS_EXT < 21)
|
#if (WIRELESS_EXT < 21)
|
||||||
dev->get_wireless_stats = p80211wext_get_wireless_stats;
|
dev->get_wireless_stats = p80211wext_get_wireless_stats;
|
||||||
|
@ -806,11 +775,11 @@ int wlan_setup(wlandevice_t *wlandev)
|
||||||
dev->change_mtu = wlan_change_mtu;
|
dev->change_mtu = wlan_change_mtu;
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_SET_MAC_ADDR
|
#ifdef HAVE_SET_MAC_ADDR
|
||||||
dev->set_mac_address = p80211knetdev_set_mac_address;
|
dev->set_mac_address = p80211knetdev_set_mac_address;
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_TX_TIMEOUT
|
#ifdef HAVE_TX_TIMEOUT
|
||||||
dev->tx_timeout = &p80211knetdev_tx_timeout;
|
dev->tx_timeout = &p80211knetdev_tx_timeout;
|
||||||
dev->watchdog_timeo = (wlan_watchdog * HZ) / 1000;
|
dev->watchdog_timeo = (wlan_watchdog * HZ) / 1000;
|
||||||
#endif
|
#endif
|
||||||
netif_carrier_off(dev);
|
netif_carrier_off(dev);
|
||||||
}
|
}
|
||||||
|
@ -841,11 +810,11 @@ int wlan_setup(wlandevice_t *wlandev)
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
int wlan_unsetup(wlandevice_t *wlandev)
|
int wlan_unsetup(wlandevice_t *wlandev)
|
||||||
{
|
{
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
|
||||||
tasklet_kill(&wlandev->rx_bh);
|
tasklet_kill(&wlandev->rx_bh);
|
||||||
|
|
||||||
if (wlandev->netdev == NULL ) {
|
if (wlandev->netdev == NULL) {
|
||||||
printk(KERN_ERR "called without wlandev->netdev set.\n");
|
printk(KERN_ERR "called without wlandev->netdev set.\n");
|
||||||
result = 1;
|
result = 1;
|
||||||
} else {
|
} else {
|
||||||
|
@ -856,8 +825,6 @@ int wlan_unsetup(wlandevice_t *wlandev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* register_wlandev
|
* register_wlandev
|
||||||
*
|
*
|
||||||
|
@ -879,7 +846,7 @@ int wlan_unsetup(wlandevice_t *wlandev)
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
int register_wlandev(wlandevice_t *wlandev)
|
int register_wlandev(wlandevice_t *wlandev)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
i = register_netdev(wlandev->netdev);
|
i = register_netdev(wlandev->netdev);
|
||||||
if (i)
|
if (i)
|
||||||
|
@ -888,7 +855,6 @@ int register_wlandev(wlandevice_t *wlandev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* unregister_wlandev
|
* unregister_wlandev
|
||||||
*
|
*
|
||||||
|
@ -913,14 +879,12 @@ int unregister_wlandev(wlandevice_t *wlandev)
|
||||||
unregister_netdev(wlandev->netdev);
|
unregister_netdev(wlandev->netdev);
|
||||||
|
|
||||||
/* Now to clean out the rx queue */
|
/* Now to clean out the rx queue */
|
||||||
while ( (skb = skb_dequeue(&wlandev->nsd_rxq)) ) {
|
while ((skb = skb_dequeue(&wlandev->nsd_rxq)))
|
||||||
dev_kfree_skb(skb);
|
dev_kfree_skb(skb);
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* p80211netdev_hwremoved
|
* p80211netdev_hwremoved
|
||||||
*
|
*
|
||||||
|
@ -954,14 +918,12 @@ int unregister_wlandev(wlandevice_t *wlandev)
|
||||||
void p80211netdev_hwremoved(wlandevice_t *wlandev)
|
void p80211netdev_hwremoved(wlandevice_t *wlandev)
|
||||||
{
|
{
|
||||||
wlandev->hwremoved = 1;
|
wlandev->hwremoved = 1;
|
||||||
if ( wlandev->state == WLAN_DEVICE_OPEN) {
|
if (wlandev->state == WLAN_DEVICE_OPEN)
|
||||||
netif_stop_queue(wlandev->netdev);
|
netif_stop_queue(wlandev->netdev);
|
||||||
}
|
|
||||||
|
|
||||||
netif_device_detach(wlandev->netdev);
|
netif_device_detach(wlandev->netdev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------
|
/*----------------------------------------------------------------
|
||||||
* p80211_rx_typedrop
|
* p80211_rx_typedrop
|
||||||
*
|
*
|
||||||
|
@ -983,28 +945,27 @@ void p80211netdev_hwremoved(wlandevice_t *wlandev)
|
||||||
* Call context:
|
* Call context:
|
||||||
* interrupt
|
* interrupt
|
||||||
----------------------------------------------------------------*/
|
----------------------------------------------------------------*/
|
||||||
static int p80211_rx_typedrop( wlandevice_t *wlandev, u16 fc)
|
static int p80211_rx_typedrop(wlandevice_t *wlandev, u16 fc)
|
||||||
{
|
{
|
||||||
u16 ftype;
|
u16 ftype;
|
||||||
u16 fstype;
|
u16 fstype;
|
||||||
int drop = 0;
|
int drop = 0;
|
||||||
/* Classify frame, increment counter */
|
/* Classify frame, increment counter */
|
||||||
ftype = WLAN_GET_FC_FTYPE(fc);
|
ftype = WLAN_GET_FC_FTYPE(fc);
|
||||||
fstype = WLAN_GET_FC_FSTYPE(fc);
|
fstype = WLAN_GET_FC_FSTYPE(fc);
|
||||||
#if 0
|
#if 0
|
||||||
pr_debug(
|
pr_debug("rx_typedrop : ftype=%d fstype=%d.\n", ftype, fstype);
|
||||||
"rx_typedrop : ftype=%d fstype=%d.\n", ftype, fstype);
|
|
||||||
#endif
|
#endif
|
||||||
switch ( ftype ) {
|
switch (ftype) {
|
||||||
case WLAN_FTYPE_MGMT:
|
case WLAN_FTYPE_MGMT:
|
||||||
if ((wlandev->netdev->flags & IFF_PROMISC) ||
|
if ((wlandev->netdev->flags & IFF_PROMISC) ||
|
||||||
(wlandev->netdev->flags & IFF_ALLMULTI)) {
|
(wlandev->netdev->flags & IFF_ALLMULTI)) {
|
||||||
drop = 1;
|
drop = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
pr_debug("rx'd mgmt:\n");
|
pr_debug("rx'd mgmt:\n");
|
||||||
wlandev->rx.mgmt++;
|
wlandev->rx.mgmt++;
|
||||||
switch( fstype ) {
|
switch (fstype) {
|
||||||
case WLAN_FSTYPE_ASSOCREQ:
|
case WLAN_FSTYPE_ASSOCREQ:
|
||||||
/* printk("assocreq"); */
|
/* printk("assocreq"); */
|
||||||
wlandev->rx.assocreq++;
|
wlandev->rx.assocreq++;
|
||||||
|
@ -1060,13 +1021,13 @@ static int p80211_rx_typedrop( wlandevice_t *wlandev, u16 fc)
|
||||||
|
|
||||||
case WLAN_FTYPE_CTL:
|
case WLAN_FTYPE_CTL:
|
||||||
if ((wlandev->netdev->flags & IFF_PROMISC) ||
|
if ((wlandev->netdev->flags & IFF_PROMISC) ||
|
||||||
(wlandev->netdev->flags & IFF_ALLMULTI)) {
|
(wlandev->netdev->flags & IFF_ALLMULTI)) {
|
||||||
drop = 1;
|
drop = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
pr_debug("rx'd ctl:\n");
|
pr_debug("rx'd ctl:\n");
|
||||||
wlandev->rx.ctl++;
|
wlandev->rx.ctl++;
|
||||||
switch( fstype ) {
|
switch (fstype) {
|
||||||
case WLAN_FSTYPE_PSPOLL:
|
case WLAN_FSTYPE_PSPOLL:
|
||||||
/* printk("pspoll"); */
|
/* printk("pspoll"); */
|
||||||
wlandev->rx.pspoll++;
|
wlandev->rx.pspoll++;
|
||||||
|
@ -1102,7 +1063,7 @@ static int p80211_rx_typedrop( wlandevice_t *wlandev, u16 fc)
|
||||||
|
|
||||||
case WLAN_FTYPE_DATA:
|
case WLAN_FTYPE_DATA:
|
||||||
wlandev->rx.data++;
|
wlandev->rx.data++;
|
||||||
switch( fstype ) {
|
switch (fstype) {
|
||||||
case WLAN_FSTYPE_DATAONLY:
|
case WLAN_FSTYPE_DATAONLY:
|
||||||
wlandev->rx.dataonly++;
|
wlandev->rx.dataonly++;
|
||||||
break;
|
break;
|
||||||
|
@ -1142,15 +1103,15 @@ static int p80211_rx_typedrop( wlandevice_t *wlandev, u16 fc)
|
||||||
return drop;
|
return drop;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void p80211knetdev_tx_timeout( netdevice_t *netdev)
|
static void p80211knetdev_tx_timeout(netdevice_t *netdev)
|
||||||
{
|
{
|
||||||
wlandevice_t *wlandev = netdev->ml_priv;
|
wlandevice_t *wlandev = netdev->ml_priv;
|
||||||
|
|
||||||
if (wlandev->tx_timeout) {
|
if (wlandev->tx_timeout) {
|
||||||
wlandev->tx_timeout(wlandev);
|
wlandev->tx_timeout(wlandev);
|
||||||
} else {
|
} else {
|
||||||
printk(KERN_WARNING "Implement tx_timeout for %s\n",
|
printk(KERN_WARNING "Implement tx_timeout for %s\n",
|
||||||
wlandev->nsdname);
|
wlandev->nsdname);
|
||||||
netif_wake_queue(wlandev->netdev);
|
netif_wake_queue(wlandev->netdev);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue