This patch fixes the following checkpatch.pl issues in wl_netdev.c: WARNING: please, no spaces at the start of a line ERROR: code indent should use tabs where possible Signed-off-by: Jelena Bjelja <jelena.bjelja.ing@xxxxxxxxx> --- drivers/staging/wlags49_h2/wl_netdev.c | 1635 ++++++++++++++++---------------- 1 file changed, 817 insertions(+), 818 deletions(-) diff --git a/drivers/staging/wlags49_h2/wl_netdev.c b/drivers/staging/wlags49_h2/wl_netdev.c index 965b1c0..d654cd0 100644 --- a/drivers/staging/wlags49_h2/wl_netdev.c +++ b/drivers/staging/wlags49_h2/wl_netdev.c @@ -129,9 +129,9 @@ * macros ******************************************************************************/ #define BLOCK_INPUT(buf, len) \ - desc->buf_addr = buf; \ - desc->BUF_SIZE = len; \ - status = hcf_rcv_msg(&(lp->hcfCtx), desc, 0) + desc->buf_addr = buf; \ + desc->BUF_SIZE = len; \ + status = hcf_rcv_msg(&(lp->hcfCtx), desc, 0) #define BLOCK_INPUT_DMA(buf, len) memcpy( buf, desc_next->buf_addr, pktlen ) @@ -163,14 +163,14 @@ int wl_init( struct net_device *dev ) // unsigned long flags; // struct wl_private *lp = wl_priv(dev); - DBG_PARAM( DbgInfo, "dev", "%s (0x%p)", dev->name, dev ); + DBG_PARAM( DbgInfo, "dev", "%s (0x%p)", dev->name, dev ); - /* Nothing to do, but grab the spinlock anyway just in case we ever need - this routine */ + /* Nothing to do, but grab the spinlock anyway just in case we ever need + this routine */ // wl_lock( lp, &flags ); // wl_unlock( lp, &flags ); - return 0; + return 0; } // wl_init /*============================================================================*/ @@ -195,14 +195,14 @@ int wl_init( struct net_device *dev ) ******************************************************************************/ int wl_config( struct net_device *dev, struct ifmap *map ) { - DBG_PARAM( DbgInfo, "dev", "%s (0x%p)", dev->name, dev ); - DBG_PARAM( DbgInfo, "map", "0x%p", map ); + DBG_PARAM( DbgInfo, "dev", "%s (0x%p)", dev->name, dev ); + DBG_PARAM( DbgInfo, "map", "0x%p", map ); - /* The only thing we care about here is a port change. Since this not needed, - ignore the request. */ - DBG_TRACE(DbgInfo, "%s: %s called.\n", dev->name, __func__); + /* The only thing we care about here is a port change. Since this not needed, + ignore the request. */ + DBG_TRACE(DbgInfo, "%s: %s called.\n", dev->name, __func__); - return 0; + return 0; } // wl_config /*============================================================================*/ @@ -227,44 +227,44 @@ int wl_config( struct net_device *dev, struct ifmap *map ) struct net_device_stats *wl_stats( struct net_device *dev ) { #ifdef USE_WDS - int count; + int count; #endif /* USE_WDS */ - unsigned long flags; - struct net_device_stats *pStats; - struct wl_private *lp = wl_priv(dev); + unsigned long flags; + struct net_device_stats *pStats; + struct wl_private *lp = wl_priv(dev); - //DBG_PARAM( DbgInfo, "dev", "%s (0x%p)", dev->name, dev ); + //DBG_PARAM( DbgInfo, "dev", "%s (0x%p)", dev->name, dev ); - pStats = NULL; + pStats = NULL; - wl_lock( lp, &flags ); + wl_lock( lp, &flags ); #ifdef USE_RTS - if( lp->useRTS == 1 ) { - wl_unlock( lp, &flags ); - return NULL; - } + if( lp->useRTS == 1 ) { + wl_unlock( lp, &flags ); + return NULL; + } #endif /* USE_RTS */ /* Return the statistics for the appropriate device */ #ifdef USE_WDS - for( count = 0; count < NUM_WDS_PORTS; count++ ) { - if( dev == lp->wds_port[count].dev ) { - pStats = &( lp->wds_port[count].stats ); + for( count = 0; count < NUM_WDS_PORTS; count++ ) { + if( dev == lp->wds_port[count].dev ) { + pStats = &( lp->wds_port[count].stats ); + } } - } #endif /* USE_WDS */ - /* If pStats is still NULL, then the device is not a WDS port */ - if( pStats == NULL ) { - pStats = &( lp->stats ); - } + /* If pStats is still NULL, then the device is not a WDS port */ + if( pStats == NULL ) { + pStats = &( lp->stats ); + } - wl_unlock( lp, &flags ); + wl_unlock( lp, &flags ); - return pStats; + return pStats; } // wl_stats /*============================================================================*/ @@ -288,74 +288,74 @@ struct net_device_stats *wl_stats( struct net_device *dev ) ******************************************************************************/ int wl_open(struct net_device *dev) { - int status = HCF_SUCCESS; - struct wl_private *lp = wl_priv(dev); - unsigned long flags; + int status = HCF_SUCCESS; + struct wl_private *lp = wl_priv(dev); + unsigned long flags; - wl_lock( lp, &flags ); + wl_lock( lp, &flags ); #ifdef USE_RTS - if( lp->useRTS == 1 ) { - DBG_TRACE( DbgInfo, "Skipping device open, in RTS mode\n" ); - wl_unlock( lp, &flags ); - return -EIO; - } + if( lp->useRTS == 1 ) { + DBG_TRACE( DbgInfo, "Skipping device open, in RTS mode\n" ); + wl_unlock( lp, &flags ); + return -EIO; + } #endif /* USE_RTS */ #ifdef USE_PROFILE - parse_config( dev ); + parse_config( dev ); #endif - if( lp->portState == WVLAN_PORT_STATE_DISABLED ) { - DBG_TRACE( DbgInfo, "Enabling Port 0\n" ); - status = wl_enable( lp ); + if( lp->portState == WVLAN_PORT_STATE_DISABLED ) { + DBG_TRACE( DbgInfo, "Enabling Port 0\n" ); + status = wl_enable( lp ); - if( status != HCF_SUCCESS ) { - DBG_TRACE( DbgInfo, "Enable port 0 failed: 0x%x\n", status ); - } - } + if( status != HCF_SUCCESS ) { + DBG_TRACE( DbgInfo, "Enable port 0 failed: 0x%x\n", status ); + } + } - // Holding the lock too long, make a gap to allow other processes - wl_unlock(lp, &flags); - wl_lock( lp, &flags ); + // Holding the lock too long, make a gap to allow other processes + wl_unlock(lp, &flags); + wl_lock( lp, &flags ); - if ( strlen( lp->fw_image_filename ) ) { - DBG_TRACE( DbgInfo, ";???? Kludgy way to force a download\n" ); - status = wl_go( lp ); - } else { - status = wl_apply( lp ); - } + if ( strlen( lp->fw_image_filename ) ) { + DBG_TRACE( DbgInfo, ";???? Kludgy way to force a download\n" ); + status = wl_go( lp ); + } else { + status = wl_apply( lp ); + } - // Holding the lock too long, make a gap to allow other processes - wl_unlock(lp, &flags); - wl_lock( lp, &flags ); + // Holding the lock too long, make a gap to allow other processes + wl_unlock(lp, &flags); + wl_lock( lp, &flags ); - if( status != HCF_SUCCESS ) { + if( status != HCF_SUCCESS ) { // Unsuccessful, try reset of the card to recover status = wl_reset( dev ); - } + } - // Holding the lock too long, make a gap to allow other processes - wl_unlock(lp, &flags); - wl_lock( lp, &flags ); + // Holding the lock too long, make a gap to allow other processes + wl_unlock(lp, &flags); + wl_lock( lp, &flags ); - if( status == HCF_SUCCESS ) { - netif_carrier_on( dev ); - WL_WDS_NETIF_CARRIER_ON( lp ); + if( status == HCF_SUCCESS ) { + netif_carrier_on( dev ); + WL_WDS_NETIF_CARRIER_ON( lp ); - lp->is_handling_int = WL_HANDLING_INT; // Start handling interrupts - wl_act_int_on( lp ); + lp->is_handling_int = WL_HANDLING_INT; // Start handling interrupts + wl_act_int_on( lp ); - netif_start_queue( dev ); - WL_WDS_NETIF_START_QUEUE( lp ); - } else { - wl_hcf_error( dev, status ); /* Report the error */ - netif_device_detach( dev ); /* Stop the device and queue */ - } + netif_start_queue( dev ); + WL_WDS_NETIF_START_QUEUE( lp ); + } else { + wl_hcf_error( dev, status ); /* Report the error */ + netif_device_detach( dev ); /* Stop the device and queue */ + } - wl_unlock( lp, &flags ); + wl_unlock( lp, &flags ); - return status; + return status; } // wl_open /*============================================================================*/ @@ -379,68 +379,68 @@ int wl_open(struct net_device *dev) ******************************************************************************/ int wl_close( struct net_device *dev ) { - struct wl_private *lp = wl_priv(dev); - unsigned long flags; + struct wl_private *lp = wl_priv(dev); + unsigned long flags; - DBG_PARAM(DbgInfo, "dev", "%s (0x%p)", dev->name, dev); + DBG_PARAM(DbgInfo, "dev", "%s (0x%p)", dev->name, dev); - /* Mark the adapter as busy */ - netif_stop_queue( dev ); - WL_WDS_NETIF_STOP_QUEUE( lp ); + /* Mark the adapter as busy */ + netif_stop_queue( dev ); + WL_WDS_NETIF_STOP_QUEUE( lp ); - netif_carrier_off( dev ); - WL_WDS_NETIF_CARRIER_OFF( lp ); + netif_carrier_off( dev ); + WL_WDS_NETIF_CARRIER_OFF( lp ); - /* Shutdown the adapter: - Disable adapter interrupts - Stop Tx/Rx - Update statistics - Set low power mode - */ + /* Shutdown the adapter: + Disable adapter interrupts + Stop Tx/Rx + Update statistics + Set low power mode + */ - wl_lock( lp, &flags ); + wl_lock( lp, &flags ); - wl_act_int_off( lp ); - lp->is_handling_int = WL_NOT_HANDLING_INT; // Stop handling interrupts + wl_act_int_off( lp ); + lp->is_handling_int = WL_NOT_HANDLING_INT; // Stop handling interrupts #ifdef USE_RTS - if( lp->useRTS == 1 ) { - DBG_TRACE( DbgInfo, "Skipping device close, in RTS mode\n" ); - wl_unlock( lp, &flags ); - return -EIO; - } + if( lp->useRTS == 1 ) { + DBG_TRACE( DbgInfo, "Skipping device close, in RTS mode\n" ); + wl_unlock( lp, &flags ); + return -EIO; + } #endif /* USE_RTS */ - /* Disable the ports */ - wl_disable( lp ); + /* Disable the ports */ + wl_disable( lp ); - wl_unlock( lp, &flags ); + wl_unlock( lp, &flags ); - return 0; + return 0; } // wl_close /*============================================================================*/ static void wl_get_drvinfo(struct net_device *dev, struct ethtool_drvinfo *info) { - strlcpy(info->driver, DRIVER_NAME, sizeof(info->driver)); - strlcpy(info->version, DRV_VERSION_STR, sizeof(info->version)); + strlcpy(info->driver, DRIVER_NAME, sizeof(info->driver)); + strlcpy(info->version, DRV_VERSION_STR, sizeof(info->version)); // strlcpy(info.fw_version, priv->fw_name, // sizeof(info.fw_version)); - if (dev->dev.parent) { - dev_set_name(dev->dev.parent, "%s", info->bus_info); + if (dev->dev.parent) { + dev_set_name(dev->dev.parent, "%s", info->bus_info); //strlcpy(info->bus_info, dev->dev.parent->bus_id, // sizeof(info->bus_info)); - } else { - snprintf(info->bus_info, sizeof(info->bus_info), + } else { + snprintf(info->bus_info, sizeof(info->bus_info), "PCMCIA FIXME"); -// "PCMCIA 0x%lx", priv->hw.iobase); - } +// "PCMCIA 0x%lx", priv->hw.iobase); + } } // wl_get_drvinfo static struct ethtool_ops wl_ethtool_ops = { - .get_drvinfo = wl_get_drvinfo, - .get_link = ethtool_op_get_link, + .get_drvinfo = wl_get_drvinfo, + .get_link = ethtool_op_get_link, }; @@ -466,79 +466,79 @@ static struct ethtool_ops wl_ethtool_ops = { ******************************************************************************/ int wl_ioctl( struct net_device *dev, struct ifreq *rq, int cmd ) { - struct wl_private *lp = wl_priv(dev); - unsigned long flags; - int ret = 0; + struct wl_private *lp = wl_priv(dev); + unsigned long flags; + int ret = 0; - DBG_PARAM(DbgInfo, "dev", "%s (0x%p)", dev->name, dev); - DBG_PARAM(DbgInfo, "rq", "0x%p", rq); - DBG_PARAM(DbgInfo, "cmd", "0x%04x", cmd); + DBG_PARAM(DbgInfo, "dev", "%s (0x%p)", dev->name, dev); + DBG_PARAM(DbgInfo, "rq", "0x%p", rq); + DBG_PARAM(DbgInfo, "cmd", "0x%04x", cmd); - wl_lock( lp, &flags ); + wl_lock( lp, &flags ); - wl_act_int_off( lp ); + wl_act_int_off( lp ); #ifdef USE_RTS - if( lp->useRTS == 1 ) { + if( lp->useRTS == 1 ) { /* Handle any RTS IOCTL here */ - if( cmd == WL_IOCTL_RTS ) { - DBG_TRACE( DbgInfo, "IOCTL: WL_IOCTL_RTS\n" ); - ret = wvlan_rts( (struct rtsreq *)rq, dev->base_addr ); - } else { - DBG_TRACE( DbgInfo, "IOCTL not supported in RTS mode: 0x%X\n", cmd ); - ret = -EOPNOTSUPP; - } + if( cmd == WL_IOCTL_RTS ) { + DBG_TRACE( DbgInfo, "IOCTL: WL_IOCTL_RTS\n" ); + ret = wvlan_rts( (struct rtsreq *)rq, dev->base_addr ); + } else { + DBG_TRACE( DbgInfo, "IOCTL not supported in RTS mode: 0x%X\n", cmd ); + ret = -EOPNOTSUPP; + } - goto out_act_int_on_unlock; - } + goto out_act_int_on_unlock; + } #endif /* USE_RTS */ - /* Only handle UIL IOCTL requests when the UIL has the system blocked. */ - if( !(( lp->flags & WVLAN2_UIL_BUSY ) && ( cmd != WVLAN2_IOCTL_UIL ))) { + /* Only handle UIL IOCTL requests when the UIL has the system blocked. */ + if( !(( lp->flags & WVLAN2_UIL_BUSY ) && ( cmd != WVLAN2_IOCTL_UIL ))) { #ifdef USE_UIL - struct uilreq *urq = (struct uilreq *)rq; + struct uilreq *urq = (struct uilreq *)rq; #endif /* USE_UIL */ - switch( cmd ) { - // ================== Private IOCTLs (up to 16) ================== + switch( cmd ) { + // ================== Private IOCTLs (up to 16) ================== #ifdef USE_UIL - case WVLAN2_IOCTL_UIL: - DBG_TRACE( DbgInfo, "IOCTL: WVLAN2_IOCTL_UIL\n" ); - ret = wvlan_uil( urq, lp ); - break; + case WVLAN2_IOCTL_UIL: + DBG_TRACE( DbgInfo, "IOCTL: WVLAN2_IOCTL_UIL\n" ); + ret = wvlan_uil( urq, lp ); + break; #endif /* USE_UIL */ - default: - DBG_TRACE(DbgInfo, "IOCTL CODE NOT SUPPORTED: 0x%X\n", cmd ); - ret = -EOPNOTSUPP; - break; + default: + DBG_TRACE(DbgInfo, "IOCTL CODE NOT SUPPORTED: 0x%X\n", cmd ); + ret = -EOPNOTSUPP; + break; + } + } else { + DBG_WARNING( DbgInfo, "DEVICE IS BUSY, CANNOT PROCESS REQUEST\n" ); + ret = -EBUSY; } - } else { - DBG_WARNING( DbgInfo, "DEVICE IS BUSY, CANNOT PROCESS REQUEST\n" ); - ret = -EBUSY; - } #ifdef USE_RTS out_act_int_on_unlock: #endif /* USE_RTS */ - wl_act_int_on( lp ); + wl_act_int_on( lp ); - wl_unlock( lp, &flags ); + wl_unlock( lp, &flags ); - return ret; + return ret; } // wl_ioctl /*============================================================================*/ #ifdef CONFIG_NET_POLL_CONTROLLER void wl_poll(struct net_device *dev) { - struct wl_private *lp = wl_priv(dev); - unsigned long flags; - struct pt_regs regs; + struct wl_private *lp = wl_priv(dev); + unsigned long flags; + struct pt_regs regs; - wl_lock( lp, &flags ); - wl_isr(dev->irq, dev, ®s); - wl_unlock( lp, &flags ); + wl_lock( lp, &flags ); + wl_isr(dev->irq, dev, ®s); + wl_unlock( lp, &flags ); } #endif @@ -562,49 +562,49 @@ void wl_poll(struct net_device *dev) void wl_tx_timeout( struct net_device *dev ) { #ifdef USE_WDS - int count; + int count; #endif /* USE_WDS */ - unsigned long flags; - struct wl_private *lp = wl_priv(dev); - struct net_device_stats *pStats = NULL; + unsigned long flags; + struct wl_private *lp = wl_priv(dev); + struct net_device_stats *pStats = NULL; - DBG_WARNING( DbgInfo, "%s: Transmit timeout.\n", dev->name ); + DBG_WARNING( DbgInfo, "%s: Transmit timeout.\n", dev->name ); - wl_lock( lp, &flags ); + wl_lock( lp, &flags ); #ifdef USE_RTS - if( lp->useRTS == 1 ) { - DBG_TRACE( DbgInfo, "Skipping tx_timeout handler, in RTS mode\n" ); - wl_unlock( lp, &flags ); - return; - } + if( lp->useRTS == 1 ) { + DBG_TRACE( DbgInfo, "Skipping tx_timeout handler, in RTS mode\n" ); + wl_unlock( lp, &flags ); + return; + } #endif /* USE_RTS */ /* Figure out which device (the "root" device or WDS port) this timeout is for */ #ifdef USE_WDS - for( count = 0; count < NUM_WDS_PORTS; count++ ) { - if( dev == lp->wds_port[count].dev ) { - pStats = &( lp->wds_port[count].stats ); + for( count = 0; count < NUM_WDS_PORTS; count++ ) { + if( dev == lp->wds_port[count].dev ) { + pStats = &( lp->wds_port[count].stats ); - /* Break the loop so that we can use the counter to access WDS - information in the private structure */ - break; + /* Break the loop so that we can use the counter to access WDS + information in the private structure */ + break; + } } - } #endif /* USE_WDS */ - /* If pStats is still NULL, then the device is not a WDS port */ - if( pStats == NULL ) { - pStats = &( lp->stats ); - } + /* If pStats is still NULL, then the device is not a WDS port */ + if( pStats == NULL ) { + pStats = &( lp->stats ); + } - /* Accumulate the timeout error */ - pStats->tx_errors++; + /* Accumulate the timeout error */ + pStats->tx_errors++; - wl_unlock( lp, &flags ); + wl_unlock( lp, &flags ); } // wl_tx_timeout /*============================================================================*/ @@ -629,99 +629,99 @@ void wl_tx_timeout( struct net_device *dev ) int wl_send( struct wl_private *lp ) { - int status; - DESC_STRCT *desc; - WVLAN_LFRAME *txF = NULL; - struct list_head *element; - int len; - /*------------------------------------------------------------------------*/ + int status; + DESC_STRCT *desc; + WVLAN_LFRAME *txF = NULL; + struct list_head *element; + int len; + /*------------------------------------------------------------------------*/ + + if( lp == NULL ) { + DBG_ERROR( DbgInfo, "Private adapter struct is NULL\n" ); + return FALSE; + } + if( lp->dev == NULL ) { + DBG_ERROR( DbgInfo, "net_device struct in wl_private is NULL\n" ); + return FALSE; + } + + /* Check for the availability of FIDs; if none are available, don't take any + frames off the txQ */ + if( lp->hcfCtx.IFB_RscInd == 0 ) { + return FALSE; + } + + /* Reclaim the TxQ Elements and place them back on the free queue */ + if( !list_empty( &( lp->txQ[0] ))) { + element = lp->txQ[0].next; + + txF = (WVLAN_LFRAME * )list_entry( element, WVLAN_LFRAME, node ); + if( txF != NULL ) { + lp->txF.skb = txF->frame.skb; + lp->txF.port = txF->frame.port; + + txF->frame.skb = NULL; + txF->frame.port = 0; + + list_del( &( txF->node )); + list_add( element, &( lp->txFree )); + + lp->txQ_count--; + + if( lp->txQ_count < TX_Q_LOW_WATER_MARK ) { + if( lp->netif_queue_on == FALSE ) { + DBG_TX( DbgInfo, "Kickstarting Q: %d\n", lp->txQ_count ); + netif_wake_queue( lp->dev ); + WL_WDS_NETIF_WAKE_QUEUE( lp ); + lp->netif_queue_on = TRUE; + } + } + } + } + + if( lp->txF.skb == NULL ) { + return FALSE; + } - if( lp == NULL ) { - DBG_ERROR( DbgInfo, "Private adapter struct is NULL\n" ); - return FALSE; - } - if( lp->dev == NULL ) { - DBG_ERROR( DbgInfo, "net_device struct in wl_private is NULL\n" ); - return FALSE; - } - - /* Check for the availability of FIDs; if none are available, don't take any - frames off the txQ */ - if( lp->hcfCtx.IFB_RscInd == 0 ) { - return FALSE; - } - - /* Reclaim the TxQ Elements and place them back on the free queue */ - if( !list_empty( &( lp->txQ[0] ))) { - element = lp->txQ[0].next; - - txF = (WVLAN_LFRAME * )list_entry( element, WVLAN_LFRAME, node ); - if( txF != NULL ) { - lp->txF.skb = txF->frame.skb; - lp->txF.port = txF->frame.port; - - txF->frame.skb = NULL; - txF->frame.port = 0; - - list_del( &( txF->node )); - list_add( element, &( lp->txFree )); - - lp->txQ_count--; - - if( lp->txQ_count < TX_Q_LOW_WATER_MARK ) { - if( lp->netif_queue_on == FALSE ) { - DBG_TX( DbgInfo, "Kickstarting Q: %d\n", lp->txQ_count ); - netif_wake_queue( lp->dev ); - WL_WDS_NETIF_WAKE_QUEUE( lp ); - lp->netif_queue_on = TRUE; - } - } - } - } - - if( lp->txF.skb == NULL ) { - return FALSE; - } - - /* If the device has resources (FIDs) available, then Tx the packet */ - /* Format the TxRequest and send it to the adapter */ - len = lp->txF.skb->len < ETH_ZLEN ? ETH_ZLEN : lp->txF.skb->len; - - desc = &( lp->desc_tx ); - desc->buf_addr = lp->txF.skb->data; - desc->BUF_CNT = len; - desc->next_desc_addr = NULL; - - status = hcf_send_msg( &( lp->hcfCtx ), desc, lp->txF.port ); - - if( status == HCF_SUCCESS ) { - lp->dev->trans_start = jiffies; - - DBG_TX( DbgInfo, "Transmit...\n" ); - - if( lp->txF.port == HCF_PORT_0 ) { - lp->stats.tx_packets++; - lp->stats.tx_bytes += lp->txF.skb->len; - } + /* If the device has resources (FIDs) available, then Tx the packet */ + /* Format the TxRequest and send it to the adapter */ + len = lp->txF.skb->len < ETH_ZLEN ? ETH_ZLEN : lp->txF.skb->len; + + desc = &( lp->desc_tx ); + desc->buf_addr = lp->txF.skb->data; + desc->BUF_CNT = len; + desc->next_desc_addr = NULL; + + status = hcf_send_msg( &( lp->hcfCtx ), desc, lp->txF.port ); + + if( status == HCF_SUCCESS ) { + lp->dev->trans_start = jiffies; + + DBG_TX( DbgInfo, "Transmit...\n" ); + + if( lp->txF.port == HCF_PORT_0 ) { + lp->stats.tx_packets++; + lp->stats.tx_bytes += lp->txF.skb->len; + } #ifdef USE_WDS - else - { - lp->wds_port[(( lp->txF.port >> 8 ) - 1)].stats.tx_packets++; - lp->wds_port[(( lp->txF.port >> 8 ) - 1)].stats.tx_bytes += lp->txF.skb->len; - } + else + { + lp->wds_port[(( lp->txF.port >> 8 ) - 1)].stats.tx_packets++; + lp->wds_port[(( lp->txF.port >> 8 ) - 1)].stats.tx_bytes += lp->txF.skb->len; + } #endif /* USE_WDS */ - /* Free the skb and perform queue cleanup, as the buffer was - transmitted successfully */ - dev_kfree_skb( lp->txF.skb ); + /* Free the skb and perform queue cleanup, as the buffer was + transmitted successfully */ + dev_kfree_skb( lp->txF.skb ); - lp->txF.skb = NULL; - lp->txF.port = 0; - } + lp->txF.skb = NULL; + lp->txF.port = 0; + } - return TRUE; + return TRUE; } // wl_send /*============================================================================*/ @@ -746,72 +746,72 @@ int wl_send( struct wl_private *lp ) ******************************************************************************/ int wl_tx( struct sk_buff *skb, struct net_device *dev, int port ) { - unsigned long flags; - struct wl_private *lp = wl_priv(dev); - WVLAN_LFRAME *txF = NULL; - struct list_head *element; - /*------------------------------------------------------------------------*/ - - /* Grab the spinlock */ - wl_lock( lp, &flags ); - - if( lp->flags & WVLAN2_UIL_BUSY ) { - DBG_WARNING( DbgInfo, "UIL has device blocked\n" ); - /* Start dropping packets here??? */ - wl_unlock( lp, &flags ); - return 1; - } + unsigned long flags; + struct wl_private *lp = wl_priv(dev); + WVLAN_LFRAME *txF = NULL; + struct list_head *element; + /*------------------------------------------------------------------------*/ + + /* Grab the spinlock */ + wl_lock( lp, &flags ); + + if( lp->flags & WVLAN2_UIL_BUSY ) { + DBG_WARNING( DbgInfo, "UIL has device blocked\n" ); + /* Start dropping packets here??? */ + wl_unlock( lp, &flags ); + return 1; + } #ifdef USE_RTS - if( lp->useRTS == 1 ) { - DBG_PRINT( "RTS: we're getting a Tx...\n" ); - wl_unlock( lp, &flags ); - return 1; - } + if( lp->useRTS == 1 ) { + DBG_PRINT( "RTS: we're getting a Tx...\n" ); + wl_unlock( lp, &flags ); + return 1; + } #endif /* USE_RTS */ - if( !lp->use_dma ) { - /* Get an element from the queue */ - element = lp->txFree.next; - txF = (WVLAN_LFRAME *)list_entry( element, WVLAN_LFRAME, node ); - if( txF == NULL ) { - DBG_ERROR( DbgInfo, "Problem with list_entry\n" ); - wl_unlock( lp, &flags ); - return 1; - } - /* Fill out the frame */ - txF->frame.skb = skb; - txF->frame.port = port; - /* Move the frame to the txQ */ - /* NOTE: Here's where we would do priority queueing */ - list_move(&(txF->node), &(lp->txQ[0])); - - lp->txQ_count++; - if( lp->txQ_count >= DEFAULT_NUM_TX_FRAMES ) { - DBG_TX( DbgInfo, "Q Full: %d\n", lp->txQ_count ); - if( lp->netif_queue_on == TRUE ) { - netif_stop_queue( lp->dev ); - WL_WDS_NETIF_STOP_QUEUE( lp ); - lp->netif_queue_on = FALSE; - } - } - } - wl_act_int_off( lp ); /* Disable Interrupts */ - - /* Send the data to the hardware using the appropriate method */ + if( !lp->use_dma ) { + /* Get an element from the queue */ + element = lp->txFree.next; + txF = (WVLAN_LFRAME *)list_entry( element, WVLAN_LFRAME, node ); + if( txF == NULL ) { + DBG_ERROR( DbgInfo, "Problem with list_entry\n" ); + wl_unlock( lp, &flags ); + return 1; + } + /* Fill out the frame */ + txF->frame.skb = skb; + txF->frame.port = port; + /* Move the frame to the txQ */ + /* NOTE: Here's where we would do priority queueing */ + list_move(&(txF->node), &(lp->txQ[0])); + + lp->txQ_count++; + if( lp->txQ_count >= DEFAULT_NUM_TX_FRAMES ) { + DBG_TX( DbgInfo, "Q Full: %d\n", lp->txQ_count ); + if( lp->netif_queue_on == TRUE ) { + netif_stop_queue( lp->dev ); + WL_WDS_NETIF_STOP_QUEUE( lp ); + lp->netif_queue_on = FALSE; + } + } + } + wl_act_int_off( lp ); /* Disable Interrupts */ + + /* Send the data to the hardware using the appropriate method */ #ifdef ENABLE_DMA - if( lp->use_dma ) { - wl_send_dma( lp, skb, port ); - } - else + if( lp->use_dma ) { + wl_send_dma( lp, skb, port ); + } + else #endif - { - wl_send( lp ); - } - /* Re-enable Interrupts, release the spinlock and return */ - wl_act_int_on( lp ); - wl_unlock( lp, &flags ); - return 0; + { + wl_send( lp ); + } + /* Re-enable Interrupts, release the spinlock and return */ + wl_act_int_on( lp ); + wl_unlock( lp, &flags ); + return 0; } // wl_tx /*============================================================================*/ @@ -835,135 +835,135 @@ int wl_tx( struct sk_buff *skb, struct net_device *dev, int port ) ******************************************************************************/ int wl_rx(struct net_device *dev) { - int port; - struct sk_buff *skb; - struct wl_private *lp = wl_priv(dev); - int status; - hcf_16 pktlen; - hcf_16 hfs_stat; - DESC_STRCT *desc; - /*------------------------------------------------------------------------*/ + int port; + struct sk_buff *skb; + struct wl_private *lp = wl_priv(dev); + int status; + hcf_16 pktlen; + hcf_16 hfs_stat; + DESC_STRCT *desc; + /*------------------------------------------------------------------------*/ - DBG_PARAM(DbgInfo, "dev", "%s (0x%p)", dev->name, dev); + DBG_PARAM(DbgInfo, "dev", "%s (0x%p)", dev->name, dev); - if(!( lp->flags & WVLAN2_UIL_BUSY )) { + if(!( lp->flags & WVLAN2_UIL_BUSY )) { #ifdef USE_RTS - if( lp->useRTS == 1 ) { - DBG_PRINT( "RTS: We're getting an Rx...\n" ); - return -EIO; - } + if( lp->useRTS == 1 ) { + DBG_PRINT( "RTS: We're getting an Rx...\n" ); + return -EIO; + } #endif /* USE_RTS */ - /* Read the HFS_STAT register from the lookahead buffer */ - hfs_stat = (hcf_16)(( lp->lookAheadBuf[HFS_STAT] ) | - ( lp->lookAheadBuf[HFS_STAT + 1] << 8 )); - - /* Make sure the frame isn't bad */ - if(( hfs_stat & HFS_STAT_ERR ) != HCF_SUCCESS ) { - DBG_WARNING( DbgInfo, "HFS_STAT_ERROR (0x%x) in Rx Packet\n", - lp->lookAheadBuf[HFS_STAT] ); - return -EIO; - } - - /* Determine what port this packet is for */ - port = ( hfs_stat >> 8 ) & 0x0007; - DBG_RX( DbgInfo, "Rx frame for port %d\n", port ); - - pktlen = lp->hcfCtx.IFB_RxLen; - if (pktlen != 0) { - skb = ALLOC_SKB(pktlen); - if (skb != NULL) { - /* Set the netdev based on the port */ - switch( port ) { + /* Read the HFS_STAT register from the lookahead buffer */ + hfs_stat = (hcf_16)(( lp->lookAheadBuf[HFS_STAT] ) | + ( lp->lookAheadBuf[HFS_STAT + 1] << 8 )); + + /* Make sure the frame isn't bad */ + if(( hfs_stat & HFS_STAT_ERR ) != HCF_SUCCESS ) { + DBG_WARNING( DbgInfo, + "HFS_STAT_ERROR (0x%x) in Rx Packet\n", + lp->lookAheadBuf[HFS_STAT] ); + return -EIO; + } + + /* Determine what port this packet is for */ + port = ( hfs_stat >> 8 ) & 0x0007; + DBG_RX( DbgInfo, "Rx frame for port %d\n", port ); + + pktlen = lp->hcfCtx.IFB_RxLen; + if (pktlen != 0) { + skb = ALLOC_SKB(pktlen); + if (skb != NULL) { + /* Set the netdev based on the port */ + switch( port ) { #ifdef USE_WDS - case 1: - case 2: - case 3: - case 4: - case 5: - case 6: - skb->dev = lp->wds_port[port-1].dev; - break; + case 1: + case 2: + case 3: + case 4: + case 5: + case 6: + skb->dev =lp->wds_port[port-1].dev; + break; #endif /* USE_WDS */ + case 0: + default: + skb->dev = dev; + break; + } - case 0: - default: - skb->dev = dev; - break; - } - - desc = &( lp->desc_rx ); + desc = &( lp->desc_rx ); - desc->next_desc_addr = NULL; + desc->next_desc_addr = NULL; /* #define BLOCK_INPUT(buf, len) \ - desc->buf_addr = buf; \ - desc->BUF_SIZE = len; \ - status = hcf_rcv_msg(&(lp->hcfCtx), desc, 0) + desc->buf_addr = buf; \ + desc->BUF_SIZE = len; \ + status = hcf_rcv_msg(&(lp->hcfCtx), desc, 0) */ - GET_PACKET( skb->dev, skb, pktlen ); + GET_PACKET( skb->dev, skb, pktlen ); - if( status == HCF_SUCCESS ) { - netif_rx( skb ); + if( status == HCF_SUCCESS ) { + netif_rx( skb ); - if( port == 0 ) { - lp->stats.rx_packets++; - lp->stats.rx_bytes += pktlen; - } + if( port == 0 ) { + lp->stats.rx_packets++; + lp->stats.rx_bytes += pktlen; + } #ifdef USE_WDS - else - { - lp->wds_port[port-1].stats.rx_packets++; - lp->wds_port[port-1].stats.rx_bytes += pktlen; - } + else + { + lp->wds_port[port-1].stats.rx_packets++; + lp->wds_port[port-1].stats.rx_bytes += pktlen; + } #endif /* USE_WDS */ - dev->last_rx = jiffies; + dev->last_rx = jiffies; #ifdef WIRELESS_EXT #ifdef WIRELESS_SPY - if( lp->spydata.spy_number > 0 ) { - char *srcaddr = skb->mac.raw + MAC_ADDR_SIZE; + if( lp->spydata.spy_number > 0 ) { + char *srcaddr = skb->mac.raw + MAC_ADDR_SIZE; - wl_spy_gather( dev, srcaddr ); - } + wl_spy_gather( dev, srcaddr ); + } #endif /* WIRELESS_SPY */ #endif /* WIRELESS_EXT */ - } else { - DBG_ERROR( DbgInfo, "Rx request to card FAILED\n" ); + } else { + DBG_ERROR( DbgInfo, "Rx request to card FAILED\n" ); - if( port == 0 ) { - lp->stats.rx_dropped++; - } + if( port == 0 ) { + lp->stats.rx_dropped++; + } #ifdef USE_WDS - else - { - lp->wds_port[port-1].stats.rx_dropped++; - } + else + { + lp->wds_port[port-1].stats.rx_dropped++; + } #endif /* USE_WDS */ - dev_kfree_skb( skb ); - } - } else { - DBG_ERROR( DbgInfo, "Could not alloc skb\n" ); + dev_kfree_skb( skb ); + } + } else { + DBG_ERROR( DbgInfo, "Could not alloc skb\n" ); - if( port == 0 ) { - lp->stats.rx_dropped++; - } + if( port == 0 ) { + lp->stats.rx_dropped++; + } #ifdef USE_WDS - else - { - lp->wds_port[port-1].stats.rx_dropped++; - } + else + { + lp->wds_port[port-1].stats.rx_dropped++; + } #endif /* USE_WDS */ - } - } - } + } + } + } - return 0; + return 0; } // wl_rx /*============================================================================*/ @@ -991,102 +991,102 @@ void wl_multicast( struct net_device *dev ) #if 1 //;? (HCF_TYPE) & HCF_TYPE_STA //;?should we return an error status in AP mode //;?seems reasonable that even an AP-only driver could afford this small additional footprint - int x; - struct netdev_hw_addr *ha; - struct wl_private *lp = wl_priv(dev); - unsigned long flags; + int x; + struct netdev_hw_addr *ha; + struct wl_private *lp = wl_priv(dev); + unsigned long flags; - DBG_PARAM( DbgInfo, "dev", "%s (0x%p)", dev->name, dev ); + DBG_PARAM( DbgInfo, "dev", "%s (0x%p)", dev->name, dev ); - if( !wl_adapter_is_open( dev )) - return; + if( !wl_adapter_is_open( dev )) + return; #if DBG - if( DBG_FLAGS( DbgInfo ) & DBG_PARAM_ON ) { - DBG_PRINT(" flags: %s%s%s\n", - ( dev->flags & IFF_PROMISC ) ? "Promiscuous " : "", - ( dev->flags & IFF_MULTICAST ) ? "Multicast " : "", - ( dev->flags & IFF_ALLMULTI ) ? "All-Multicast" : "" ); + if( DBG_FLAGS( DbgInfo ) & DBG_PARAM_ON ) { + DBG_PRINT(" flags: %s%s%s\n", + ( dev->flags & IFF_PROMISC ) ? "Promiscuous " : "", + ( dev->flags & IFF_MULTICAST ) ? "Multicast " : "", + ( dev->flags & IFF_ALLMULTI ) ? "All-Multicast" : "" ); - DBG_PRINT( " mc_count: %d\n", netdev_mc_count(dev)); + DBG_PRINT( " mc_count: %d\n", netdev_mc_count(dev)); - netdev_for_each_mc_addr(ha, dev) - DBG_PRINT(" %pM (%d)\n", ha->addr, dev->addr_len); - } + netdev_for_each_mc_addr(ha, dev) + DBG_PRINT(" %pM (%d)\n", ha->addr, dev->addr_len); + } #endif /* DBG */ - if(!( lp->flags & WVLAN2_UIL_BUSY )) { + if(!( lp->flags & WVLAN2_UIL_BUSY )) { #ifdef USE_RTS - if( lp->useRTS == 1 ) { - DBG_TRACE( DbgInfo, "Skipping multicast, in RTS mode\n" ); - return; - } + if( lp->useRTS == 1 ) { + DBG_TRACE( DbgInfo, "Skipping multicast, in RTS mode\n" ); + return; + } #endif /* USE_RTS */ - wl_lock( lp, &flags ); - wl_act_int_off( lp ); + wl_lock( lp, &flags ); + wl_act_int_off( lp ); if ( CNV_INT_TO_LITTLE( lp->hcfCtx.IFB_FWIdentity.comp_id ) == COMP_ID_FW_STA ) { - if( dev->flags & IFF_PROMISC ) { - /* Enable promiscuous mode */ - lp->ltvRecord.len = 2; - lp->ltvRecord.typ = CFG_PROMISCUOUS_MODE; - lp->ltvRecord.u.u16[0] = CNV_INT_TO_LITTLE( 1 ); - DBG_PRINT( "Enabling Promiscuous mode (IFF_PROMISC)\n" ); - hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); - } - else if ((netdev_mc_count(dev) > HCF_MAX_MULTICAST) || - ( dev->flags & IFF_ALLMULTI )) { - /* Shutting off this filter will enable all multicast frames to - be sent up from the device; however, this is a static RID, so - a call to wl_apply() is needed */ - lp->ltvRecord.len = 2; - lp->ltvRecord.typ = CFG_CNF_RX_ALL_GROUP_ADDR; - lp->ltvRecord.u.u16[0] = CNV_INT_TO_LITTLE( 0 ); - DBG_PRINT( "Enabling all multicast mode (IFF_ALLMULTI)\n" ); - hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); - wl_apply( lp ); - } - else if (!netdev_mc_empty(dev)) { - /* Set the multicast addresses */ - lp->ltvRecord.len = ( netdev_mc_count(dev) * 3 ) + 1; - lp->ltvRecord.typ = CFG_GROUP_ADDR; - - x = 0; - netdev_for_each_mc_addr(ha, dev) - memcpy(&(lp->ltvRecord.u.u8[x++ * ETH_ALEN]), - ha->addr, ETH_ALEN); - DBG_PRINT( "Setting multicast list\n" ); - hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); - } else { - /* Disable promiscuous mode */ - lp->ltvRecord.len = 2; - lp->ltvRecord.typ = CFG_PROMISCUOUS_MODE; - lp->ltvRecord.u.u16[0] = CNV_INT_TO_LITTLE( 0 ); - DBG_PRINT( "Disabling Promiscuous mode\n" ); - hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); - - /* Disable multicast mode */ - lp->ltvRecord.len = 2; - lp->ltvRecord.typ = CFG_GROUP_ADDR; - DBG_PRINT( "Disabling Multicast mode\n" ); - hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); - - /* Turning on this filter will prevent all multicast frames from - being sent up from the device; however, this is a static RID, - so a call to wl_apply() is needed */ - lp->ltvRecord.len = 2; - lp->ltvRecord.typ = CFG_CNF_RX_ALL_GROUP_ADDR; - lp->ltvRecord.u.u16[0] = CNV_INT_TO_LITTLE( 1 ); - DBG_PRINT( "Disabling all multicast mode (IFF_ALLMULTI)\n" ); - hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); - wl_apply( lp ); - } - } - wl_act_int_on( lp ); - wl_unlock( lp, &flags ); - } + if( dev->flags & IFF_PROMISC ) { + /* Enable promiscuous mode */ + lp->ltvRecord.len = 2; + lp->ltvRecord.typ = CFG_PROMISCUOUS_MODE; + lp->ltvRecord.u.u16[0] = CNV_INT_TO_LITTLE( 1 ); + DBG_PRINT( "Enabling Promiscuous mode (IFF_PROMISC)\n" ); + hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); + } + else if ((netdev_mc_count(dev) > HCF_MAX_MULTICAST) || + ( dev->flags & IFF_ALLMULTI )) { + /* Shutting off this filter will enable all multicast frames to + be sent up from the device; however, this is a static RID, so + a call to wl_apply() is needed */ + lp->ltvRecord.len = 2; + lp->ltvRecord.typ = CFG_CNF_RX_ALL_GROUP_ADDR; + lp->ltvRecord.u.u16[0] = CNV_INT_TO_LITTLE( 0 ); + DBG_PRINT( "Enabling all multicast mode (IFF_ALLMULTI)\n" ); + hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); + wl_apply( lp ); + } + else if (!netdev_mc_empty(dev)) { + /* Set the multicast addresses */ + lp->ltvRecord.len = ( netdev_mc_count(dev) * 3 ) + 1; + lp->ltvRecord.typ = CFG_GROUP_ADDR; + + x = 0; + netdev_for_each_mc_addr(ha, dev) + memcpy(&(lp->ltvRecord.u.u8[x++ * ETH_ALEN]), + ha->addr, ETH_ALEN); + DBG_PRINT( "Setting multicast list\n" ); + hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); + } else { + /* Disable promiscuous mode */ + lp->ltvRecord.len = 2; + lp->ltvRecord.typ = CFG_PROMISCUOUS_MODE; + lp->ltvRecord.u.u16[0] = CNV_INT_TO_LITTLE( 0 ); + DBG_PRINT( "Disabling Promiscuous mode\n" ); + hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); + + /* Disable multicast mode */ + lp->ltvRecord.len = 2; + lp->ltvRecord.typ = CFG_GROUP_ADDR; + DBG_PRINT( "Disabling Multicast mode\n" ); + hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); + + /* Turning on this filter will prevent all multicast frames from + being sent up from the device; however, this is a static RID, + so a call to wl_apply() is needed */ + lp->ltvRecord.len = 2; + lp->ltvRecord.typ = CFG_CNF_RX_ALL_GROUP_ADDR; + lp->ltvRecord.u.u16[0] = CNV_INT_TO_LITTLE( 1 ); + DBG_PRINT( "Disabling all multicast mode (IFF_ALLMULTI)\n" ); + hcf_put_info( &( lp->hcfCtx ), (LTVP)&( lp->ltvRecord )); + wl_apply( lp ); + } + } + wl_act_int_on( lp ); + wl_unlock( lp, &flags ); + } #endif /* HCF_STA */ } // wl_multicast /*============================================================================*/ @@ -1095,9 +1095,9 @@ void wl_multicast( struct net_device *dev ) void wl_multicast( struct net_device *dev, int num_addrs, void *addrs ) { - DBG_PARAM( DbgInfo, "dev", "%s (0x%p)", dev->name, dev ); - DBG_PARAM( DbgInfo, "num_addrs", "%d", num_addrs ); - DBG_PARAM( DbgInfo, "addrs", "0x%p", addrs ); + DBG_PARAM( DbgInfo, "dev", "%s (0x%p)", dev->name, dev ); + DBG_PARAM( DbgInfo, "num_addrs", "%d", num_addrs ); + DBG_PARAM( DbgInfo, "addrs", "0x%p", addrs ); #error Obsolete set multicast interface! } // wl_multicast @@ -1107,21 +1107,21 @@ void wl_multicast( struct net_device *dev, int num_addrs, void *addrs ) static const struct net_device_ops wl_netdev_ops = { - .ndo_start_xmit = &wl_tx_port0, + .ndo_start_xmit = &wl_tx_port0, - .ndo_set_config = &wl_config, - .ndo_get_stats = &wl_stats, - .ndo_set_rx_mode = &wl_multicast, + .ndo_set_config = &wl_config, + .ndo_get_stats = &wl_stats, + .ndo_set_rx_mode = &wl_multicast, - .ndo_init = &wl_insert, - .ndo_open = &wl_adapter_open, - .ndo_stop = &wl_adapter_close, - .ndo_do_ioctl = &wl_ioctl, + .ndo_init = &wl_insert, + .ndo_open = &wl_adapter_open, + .ndo_stop = &wl_adapter_close, + .ndo_do_ioctl = &wl_ioctl, - .ndo_tx_timeout = &wl_tx_timeout, + .ndo_tx_timeout = &wl_tx_timeout, #ifdef CONFIG_NET_POLL_CONTROLLER - .ndo_poll_controller = wl_poll, + .ndo_poll_controller = wl_poll, #endif }; @@ -1146,45 +1146,45 @@ static const struct net_device_ops wl_netdev_ops = ******************************************************************************/ struct net_device * wl_device_alloc( void ) { - struct net_device *dev = NULL; - struct wl_private *lp = NULL; + struct net_device *dev = NULL; + struct wl_private *lp = NULL; - /* Alloc a net_device struct */ - dev = alloc_etherdev(sizeof(struct wl_private)); - if (!dev) - return NULL; + /* Alloc a net_device struct */ + dev = alloc_etherdev(sizeof(struct wl_private)); + if (!dev) + return NULL; - /* Initialize the 'next' pointer in the struct. Currently only used for PCI, - but do it here just in case it's used for other buses in the future */ - lp = wl_priv(dev); + /* Initialize the 'next' pointer in the struct. Currently only used for PCI, + but do it here just in case it's used for other buses in the future */ + lp = wl_priv(dev); - /* Check MTU */ - if( dev->mtu > MTU_MAX ) - { - DBG_WARNING( DbgInfo, "%s: MTU set too high, limiting to %d.\n", - dev->name, MTU_MAX ); - dev->mtu = MTU_MAX; - } + /* Check MTU */ + if( dev->mtu > MTU_MAX ) + { + DBG_WARNING( DbgInfo, "%s: MTU set too high, limiting to %d.\n", + dev->name, MTU_MAX ); + dev->mtu = MTU_MAX; + } - /* Setup the function table in the device structure. */ + /* Setup the function table in the device structure. */ - dev->wireless_handlers = (struct iw_handler_def *)&wl_iw_handler_def; - lp->wireless_data.spy_data = &lp->spy_data; - dev->wireless_data = &lp->wireless_data; + dev->wireless_handlers = (struct iw_handler_def *)&wl_iw_handler_def; + lp->wireless_data.spy_data = &lp->spy_data; + dev->wireless_data = &lp->wireless_data; - dev->netdev_ops = &wl_netdev_ops; + dev->netdev_ops = &wl_netdev_ops; - dev->watchdog_timeo = TX_TIMEOUT; + dev->watchdog_timeo = TX_TIMEOUT; - dev->ethtool_ops = &wl_ethtool_ops; + dev->ethtool_ops = &wl_ethtool_ops; - netif_stop_queue( dev ); + netif_stop_queue( dev ); - /* Allocate virtual devices for WDS support if needed */ - WL_WDS_DEVICE_ALLOC( lp ); + /* Allocate virtual devices for WDS support if needed */ + WL_WDS_DEVICE_ALLOC( lp ); - return dev; + return dev; } // wl_device_alloc /*============================================================================*/ @@ -1208,12 +1208,12 @@ struct net_device * wl_device_alloc( void ) ******************************************************************************/ void wl_device_dealloc( struct net_device *dev ) { -// struct wl_private *lp = wl_priv(dev); +// struct wl_private *lp = wl_priv(dev); - /* Dealloc the WDS ports */ - WL_WDS_DEVICE_DEALLOC( lp ); + /* Dealloc the WDS ports */ + WL_WDS_DEVICE_DEALLOC( lp ); - free_netdev( dev ); + free_netdev( dev ); } // wl_device_dealloc /*============================================================================*/ @@ -1237,11 +1237,11 @@ void wl_device_dealloc( struct net_device *dev ) ******************************************************************************/ int wl_tx_port0( struct sk_buff *skb, struct net_device *dev ) { - DBG_TX( DbgInfo, "Tx on Port 0\n" ); + DBG_TX( DbgInfo, "Tx on Port 0\n" ); - return wl_tx( skb, dev, HCF_PORT_0 ); + return wl_tx( skb, dev, HCF_PORT_0 ); #ifdef ENABLE_DMA - return wl_tx_dma( skb, dev, HCF_PORT_0 ); + return wl_tx_dma( skb, dev, HCF_PORT_0 ); #endif } // wl_tx_port0 /*============================================================================*/ @@ -1268,8 +1268,8 @@ int wl_tx_port0( struct sk_buff *skb, struct net_device *dev ) ******************************************************************************/ int wl_tx_port1( struct sk_buff *skb, struct net_device *dev ) { - DBG_TX( DbgInfo, "Tx on Port 1\n" ); - return wl_tx( skb, dev, HCF_PORT_1 ); + DBG_TX( DbgInfo, "Tx on Port 1\n" ); + return wl_tx( skb, dev, HCF_PORT_1 ); } // wl_tx_port1 /*============================================================================*/ @@ -1293,8 +1293,8 @@ int wl_tx_port1( struct sk_buff *skb, struct net_device *dev ) ******************************************************************************/ int wl_tx_port2( struct sk_buff *skb, struct net_device *dev ) { - DBG_TX( DbgInfo, "Tx on Port 2\n" ); - return wl_tx( skb, dev, HCF_PORT_2 ); + DBG_TX( DbgInfo, "Tx on Port 2\n" ); + return wl_tx( skb, dev, HCF_PORT_2 ); } // wl_tx_port2 /*============================================================================*/ @@ -1318,8 +1318,8 @@ int wl_tx_port2( struct sk_buff *skb, struct net_device *dev ) ******************************************************************************/ int wl_tx_port3( struct sk_buff *skb, struct net_device *dev ) { - DBG_TX( DbgInfo, "Tx on Port 3\n" ); - return wl_tx( skb, dev, HCF_PORT_3 ); + DBG_TX( DbgInfo, "Tx on Port 3\n" ); + return wl_tx( skb, dev, HCF_PORT_3 ); } // wl_tx_port3 /*============================================================================*/ @@ -1343,8 +1343,8 @@ int wl_tx_port3( struct sk_buff *skb, struct net_device *dev ) ******************************************************************************/ int wl_tx_port4( struct sk_buff *skb, struct net_device *dev ) { - DBG_TX( DbgInfo, "Tx on Port 4\n" ); - return wl_tx( skb, dev, HCF_PORT_4 ); + DBG_TX( DbgInfo, "Tx on Port 4\n" ); + return wl_tx( skb, dev, HCF_PORT_4 ); } // wl_tx_port4 /*============================================================================*/ @@ -1368,8 +1368,8 @@ int wl_tx_port4( struct sk_buff *skb, struct net_device *dev ) ******************************************************************************/ int wl_tx_port5( struct sk_buff *skb, struct net_device *dev ) { - DBG_TX( DbgInfo, "Tx on Port 5\n" ); - return wl_tx( skb, dev, HCF_PORT_5 ); + DBG_TX( DbgInfo, "Tx on Port 5\n" ); + return wl_tx( skb, dev, HCF_PORT_5 ); } // wl_tx_port5 /*============================================================================*/ @@ -1393,8 +1393,8 @@ int wl_tx_port5( struct sk_buff *skb, struct net_device *dev ) ******************************************************************************/ int wl_tx_port6( struct sk_buff *skb, struct net_device *dev ) { - DBG_TX( DbgInfo, "Tx on Port 6\n" ); - return wl_tx( skb, dev, HCF_PORT_6 ); + DBG_TX( DbgInfo, "Tx on Port 6\n" ); + return wl_tx( skb, dev, HCF_PORT_6 ); } // wl_tx_port6 /*============================================================================*/ @@ -1419,47 +1419,47 @@ int wl_tx_port6( struct sk_buff *skb, struct net_device *dev ) ******************************************************************************/ void wl_wds_device_alloc( struct wl_private *lp ) { - int count; + int count; /* WDS support requires additional net_device structs to be allocated, so that user space apps can use these virtual devices to specify the port on which to Tx/Rx */ - for( count = 0; count < NUM_WDS_PORTS; count++ ) { - struct net_device *dev_wds = NULL; - - dev_wds = kzalloc(sizeof(struct net_device), GFP_KERNEL); - if (!dev_wds) - return; - - ether_setup( dev_wds ); - - lp->wds_port[count].dev = dev_wds; - - /* Re-use wl_init for all the devices, as it currently does nothing, but - is required. Re-use the stats/tx_timeout handler for all as well; the - WDS port which is requesting these operations can be determined by - the net_device pointer. Set the private member of all devices to point - to the same net_device struct; that way, all information gets - funnelled through the one "real" net_device. Name the WDS ports - "wds<n>" */ - lp->wds_port[count].dev->init = &wl_init; - lp->wds_port[count].dev->get_stats = &wl_stats; - lp->wds_port[count].dev->tx_timeout = &wl_tx_timeout; - lp->wds_port[count].dev->watchdog_timeo = TX_TIMEOUT; - lp->wds_port[count].dev->priv = lp; - - sprintf( lp->wds_port[count].dev->name, "wds%d", count ); - } + for( count = 0; count < NUM_WDS_PORTS; count++ ) { + struct net_device *dev_wds = NULL; + + dev_wds = kzalloc(sizeof(struct net_device), GFP_KERNEL); + if (!dev_wds) + return; + + ether_setup( dev_wds ); + + lp->wds_port[count].dev = dev_wds; + + /* Re-use wl_init for all the devices, as it currently does nothing, but + is required. Re-use the stats/tx_timeout handler for all as well; the + WDS port which is requesting these operations can be determined by + the net_device pointer. Set the private member of all devices to point + to the same net_device struct; that way, all information gets + funnelled through the one "real" net_device. Name the WDS ports + "wds<n>" */ + lp->wds_port[count].dev->init = &wl_init; + lp->wds_port[count].dev->get_stats = &wl_stats; + lp->wds_port[count].dev->tx_timeout = &wl_tx_timeout; + lp->wds_port[count].dev->watchdog_timeo = TX_TIMEOUT; + lp->wds_port[count].dev->priv = lp; + + sprintf( lp->wds_port[count].dev->name, "wds%d", count ); + } /* Register the Tx handlers */ - lp->wds_port[0].dev->hard_start_xmit = &wl_tx_port1; - lp->wds_port[1].dev->hard_start_xmit = &wl_tx_port2; - lp->wds_port[2].dev->hard_start_xmit = &wl_tx_port3; - lp->wds_port[3].dev->hard_start_xmit = &wl_tx_port4; - lp->wds_port[4].dev->hard_start_xmit = &wl_tx_port5; - lp->wds_port[5].dev->hard_start_xmit = &wl_tx_port6; - - WL_WDS_NETIF_STOP_QUEUE( lp ); + lp->wds_port[0].dev->hard_start_xmit = &wl_tx_port1; + lp->wds_port[1].dev->hard_start_xmit = &wl_tx_port2; + lp->wds_port[2].dev->hard_start_xmit = &wl_tx_port3; + lp->wds_port[3].dev->hard_start_xmit = &wl_tx_port4; + lp->wds_port[4].dev->hard_start_xmit = &wl_tx_port5; + lp->wds_port[5].dev->hard_start_xmit = &wl_tx_port6; + + WL_WDS_NETIF_STOP_QUEUE( lp ); } // wl_wds_device_alloc /*============================================================================*/ @@ -1482,23 +1482,23 @@ void wl_wds_device_alloc( struct wl_private *lp ) ******************************************************************************/ void wl_wds_device_dealloc( struct wl_private *lp ) { - int count; + int count; - for( count = 0; count < NUM_WDS_PORTS; count++ ) { - struct net_device *dev_wds = NULL; + for( count = 0; count < NUM_WDS_PORTS; count++ ) { + struct net_device *dev_wds = NULL; - dev_wds = lp->wds_port[count].dev; + dev_wds = lp->wds_port[count].dev; - if( dev_wds != NULL ) { - if( dev_wds->flags & IFF_UP ) { - dev_close( dev_wds ); - dev_wds->flags &= ~( IFF_UP | IFF_RUNNING ); - } + if( dev_wds != NULL ) { + if( dev_wds->flags & IFF_UP ) { + dev_close( dev_wds ); + dev_wds->flags &= ~( IFF_UP | IFF_RUNNING ); + } - free_netdev(dev_wds); - lp->wds_port[count].dev = NULL; - } - } + free_netdev(dev_wds); + lp->wds_port[count].dev = NULL; + } + } } // wl_wds_device_dealloc /*============================================================================*/ @@ -1522,18 +1522,18 @@ void wl_wds_device_dealloc( struct wl_private *lp ) ******************************************************************************/ void wl_wds_netif_start_queue( struct wl_private *lp ) { - int count; + int count; /*------------------------------------------------------------------------*/ - if( lp != NULL ) { - for( count = 0; count < NUM_WDS_PORTS; count++ ) { - if( lp->wds_port[count].is_registered && - lp->wds_port[count].netif_queue_on == FALSE ) { - netif_start_queue( lp->wds_port[count].dev ); - lp->wds_port[count].netif_queue_on = TRUE; - } - } - } + if( lp != NULL ) { + for( count = 0; count < NUM_WDS_PORTS; count++ ) { + if( lp->wds_port[count].is_registered && + lp->wds_port[count].netif_queue_on == FALSE ) { + netif_start_queue( lp->wds_port[count].dev ); + lp->wds_port[count].netif_queue_on = TRUE; + } + } + } } // wl_wds_netif_start_queue /*============================================================================*/ @@ -1557,18 +1557,18 @@ void wl_wds_netif_start_queue( struct wl_private *lp ) ******************************************************************************/ void wl_wds_netif_stop_queue( struct wl_private *lp ) { - int count; + int count; /*------------------------------------------------------------------------*/ - if( lp != NULL ) { - for( count = 0; count < NUM_WDS_PORTS; count++ ) { - if( lp->wds_port[count].is_registered && - lp->wds_port[count].netif_queue_on == TRUE ) { - netif_stop_queue( lp->wds_port[count].dev ); - lp->wds_port[count].netif_queue_on = FALSE; - } - } - } + if( lp != NULL ) { + for( count = 0; count < NUM_WDS_PORTS; count++ ) { + if( lp->wds_port[count].is_registered && + lp->wds_port[count].netif_queue_on == TRUE ) { + netif_stop_queue( lp->wds_port[count].dev ); + lp->wds_port[count].netif_queue_on = FALSE; + } + } + } } // wl_wds_netif_stop_queue /*============================================================================*/ @@ -1592,18 +1592,18 @@ void wl_wds_netif_stop_queue( struct wl_private *lp ) ******************************************************************************/ void wl_wds_netif_wake_queue( struct wl_private *lp ) { - int count; + int count; /*------------------------------------------------------------------------*/ - if( lp != NULL ) { - for( count = 0; count < NUM_WDS_PORTS; count++ ) { - if( lp->wds_port[count].is_registered && - lp->wds_port[count].netif_queue_on == FALSE ) { - netif_wake_queue( lp->wds_port[count].dev ); - lp->wds_port[count].netif_queue_on = TRUE; - } - } - } + if( lp != NULL ) { + for( count = 0; count < NUM_WDS_PORTS; count++ ) { + if( lp->wds_port[count].is_registered && + lp->wds_port[count].netif_queue_on == FALSE ) { + netif_wake_queue( lp->wds_port[count].dev ); + lp->wds_port[count].netif_queue_on = TRUE; + } + } + } } // wl_wds_netif_wake_queue /*============================================================================*/ @@ -1627,16 +1627,16 @@ void wl_wds_netif_wake_queue( struct wl_private *lp ) ******************************************************************************/ void wl_wds_netif_carrier_on( struct wl_private *lp ) { - int count; + int count; /*------------------------------------------------------------------------*/ - if( lp != NULL ) { - for( count = 0; count < NUM_WDS_PORTS; count++ ) { - if( lp->wds_port[count].is_registered ) { - netif_carrier_on( lp->wds_port[count].dev ); - } - } - } + if( lp != NULL ) { + for( count = 0; count < NUM_WDS_PORTS; count++ ) { + if( lp->wds_port[count].is_registered ) { + netif_carrier_on( lp->wds_port[count].dev ); + } + } + } } // wl_wds_netif_carrier_on /*============================================================================*/ @@ -1697,67 +1697,67 @@ void wl_wds_netif_carrier_off( struct wl_private *lp ) ******************************************************************************/ int wl_send_dma( struct wl_private *lp, struct sk_buff *skb, int port ) { - int len; - DESC_STRCT *desc = NULL; - DESC_STRCT *desc_next = NULL; - /*------------------------------------------------------------------------*/ - - if( lp == NULL ) { - DBG_ERROR( DbgInfo, "Private adapter struct is NULL\n" ); - return FALSE; - } + int len; + DESC_STRCT *desc = NULL; + DESC_STRCT *desc_next = NULL; +/*------------------------------------------------------------------------*/ + + if( lp == NULL ) { + DBG_ERROR( DbgInfo, "Private adapter struct is NULL\n" ); + return FALSE; + } - if( lp->dev == NULL ) { - DBG_ERROR( DbgInfo, "net_device struct in wl_private is NULL\n" ); - return FALSE; - } + if( lp->dev == NULL ) { + DBG_ERROR( DbgInfo, "net_device struct in wl_private is NULL\n" ); + return FALSE; + } - /* AGAIN, ALL THE QUEUEING DONE HERE IN I/O MODE IS NOT PERFORMED */ + /* AGAIN, ALL THE QUEUEING DONE HERE IN I/O MODE IS NOT PERFORMED */ - if( skb == NULL ) { - DBG_WARNING (DbgInfo, "Nothing to send.\n"); - return FALSE; - } + if( skb == NULL ) { + DBG_WARNING (DbgInfo, "Nothing to send.\n"); + return FALSE; + } - len = skb->len; + len = skb->len; - /* Get a free descriptor */ - desc = wl_pci_dma_get_tx_packet( lp ); + /* Get a free descriptor */ + desc = wl_pci_dma_get_tx_packet( lp ); - if( desc == NULL ) { - if( lp->netif_queue_on == TRUE ) { - netif_stop_queue( lp->dev ); - WL_WDS_NETIF_STOP_QUEUE( lp ); - lp->netif_queue_on = FALSE; + if( desc == NULL ) { + if( lp->netif_queue_on == TRUE ) { + netif_stop_queue( lp->dev ); + WL_WDS_NETIF_STOP_QUEUE( lp ); + lp->netif_queue_on = FALSE; - dev_kfree_skb( skb ); - return 0; - } - } + dev_kfree_skb( skb ); + return 0; + } + } - SET_BUF_CNT( desc, /*HCF_DMA_FD_CNT*/HFS_ADDR_DEST ); - SET_BUF_SIZE( desc, HCF_DMA_TX_BUF1_SIZE ); + SET_BUF_CNT( desc, /*HCF_DMA_FD_CNT*/HFS_ADDR_DEST ); + SET_BUF_SIZE( desc, HCF_DMA_TX_BUF1_SIZE ); - desc_next = desc->next_desc_addr; + desc_next = desc->next_desc_addr; - if( desc_next->buf_addr == NULL ) { - DBG_ERROR( DbgInfo, "DMA descriptor buf_addr is NULL\n" ); - return FALSE; - } + if( desc_next->buf_addr == NULL ) { + DBG_ERROR( DbgInfo, "DMA descriptor buf_addr is NULL\n" ); + return FALSE; + } - /* Copy the payload into the DMA packet */ - memcpy( desc_next->buf_addr, skb->data, len ); + /* Copy the payload into the DMA packet */ + memcpy( desc_next->buf_addr, skb->data, len ); - SET_BUF_CNT( desc_next, len ); - SET_BUF_SIZE( desc_next, HCF_MAX_PACKET_SIZE ); + SET_BUF_CNT( desc_next, len ); + SET_BUF_SIZE( desc_next, HCF_MAX_PACKET_SIZE ); - hcf_dma_tx_put( &( lp->hcfCtx ), desc, 0 ); + hcf_dma_tx_put( &( lp->hcfCtx ), desc, 0 ); - /* Free the skb and perform queue cleanup, as the buffer was - transmitted successfully */ - dev_kfree_skb( skb ); + /* Free the skb and perform queue cleanup, as the buffer was + transmitted successfully */ + dev_kfree_skb( skb ); - return TRUE; + return TRUE; } // wl_send_dma /*============================================================================*/ @@ -1781,145 +1781,144 @@ int wl_send_dma( struct wl_private *lp, struct sk_buff *skb, int port ) ******************************************************************************/ int wl_rx_dma( struct net_device *dev ) { - int port; - hcf_16 pktlen; - hcf_16 hfs_stat; - struct sk_buff *skb; - struct wl_private *lp = NULL; - DESC_STRCT *desc, *desc_next; - //CFG_MB_INFO_RANGE2_STRCT x; - /*------------------------------------------------------------------------*/ + int port; + hcf_16 pktlen; + hcf_16 hfs_stat; + struct sk_buff *skb; + struct wl_private *lp = NULL; + DESC_STRCT *desc, *desc_next; + //CFG_MB_INFO_RANGE2_STRCT x; +/*------------------------------------------------------------------------*/ - DBG_PARAM(DbgInfo, "dev", "%s (0x%p)", dev->name, dev); + DBG_PARAM(DbgInfo, "dev", "%s (0x%p)", dev->name, dev); - if((( lp = dev->priv ) != NULL ) && - !( lp->flags & WVLAN2_UIL_BUSY )) { + if((( lp = dev->priv ) != NULL ) && + !( lp->flags & WVLAN2_UIL_BUSY )) { #ifdef USE_RTS - if( lp->useRTS == 1 ) { - DBG_PRINT( "RTS: We're getting an Rx...\n" ); - return -EIO; - } -#endif /* USE_RTS */ + if( lp->useRTS == 1 ) { + DBG_PRINT( "RTS: We're getting an Rx...\n" ); + return -EIO; + } +#endif /* USE_RTS */ - //if( lp->dma.status == 0 ) - //{ - desc = hcf_dma_rx_get( &( lp->hcfCtx )); - - if( desc != NULL ) - { - /* Check and see if we rcvd. a WMP frame */ - /* - if((( *(hcf_8 *)&desc->buf_addr[HFS_STAT] ) & - ( HFS_STAT_MSG_TYPE | HFS_STAT_ERR )) == HFS_STAT_WMP_MSG ) - { - DBG_TRACE( DbgInfo, "Got a WMP frame\n" ); - - x.len = sizeof( CFG_MB_INFO_RANGE2_STRCT ) / sizeof( hcf_16 ); - x.typ = CFG_MB_INFO; - x.base_typ = CFG_WMP; - x.frag_cnt = 2; - x.frag_buf[0].frag_len = GET_BUF_CNT( descp ) / sizeof( hcf_16 ); - x.frag_buf[0].frag_addr = (hcf_8 *) descp->buf_addr ; - x.frag_buf[1].frag_len = ( GET_BUF_CNT( descp->next_desc_addr ) + 1 ) / sizeof( hcf_16 ); - x.frag_buf[1].frag_addr = (hcf_8 *) descp->next_desc_addr->buf_addr ; - - hcf_put_info( &( lp->hcfCtx ), (LTVP)&x ); - } - */ - - desc_next = desc->next_desc_addr; - - /* Make sure the buffer isn't empty */ - if( GET_BUF_CNT( desc ) == 0 ) { - DBG_WARNING( DbgInfo, "Buffer is empty!\n" ); - - /* Give the descriptor back to the HCF */ - hcf_dma_rx_put( &( lp->hcfCtx ), desc ); - return -EIO; - } - - /* Read the HFS_STAT register from the lookahead buffer */ - hfs_stat = (hcf_16)( desc->buf_addr[HFS_STAT/2] ); - - /* Make sure the frame isn't bad */ - if(( hfs_stat & HFS_STAT_ERR ) != HCF_SUCCESS ) - { - DBG_WARNING( DbgInfo, "HFS_STAT_ERROR (0x%x) in Rx Packet\n", - desc->buf_addr[HFS_STAT/2] ); - - /* Give the descriptor back to the HCF */ - hcf_dma_rx_put( &( lp->hcfCtx ), desc ); - return -EIO; - } - - /* Determine what port this packet is for */ - port = ( hfs_stat >> 8 ) & 0x0007; - DBG_RX( DbgInfo, "Rx frame for port %d\n", port ); - - pktlen = GET_BUF_CNT(desc_next); - if (pktlen != 0) { - skb = ALLOC_SKB(pktlen); - if (skb != NULL) { - switch( port ) { + //if( lp->dma.status == 0 ) + //{ + desc = hcf_dma_rx_get( &( lp->hcfCtx )); + + if( desc != NULL ) + { +/* Check and see if we rcvd. a WMP frame */ +/* + if((( *(hcf_8 *)&desc->buf_addr[HFS_STAT] ) & + ( HFS_STAT_MSG_TYPE | HFS_STAT_ERR )) == HFS_STAT_WMP_MSG ) + { + DBG_TRACE( DbgInfo, "Got a WMP frame\n" ); + + x.len = sizeof( CFG_MB_INFO_RANGE2_STRCT ) / sizeof( hcf_16 ); + x.typ = CFG_MB_INFO; + x.base_typ = CFG_WMP; + x.frag_cnt = 2; + x.frag_buf[0].frag_len = GET_BUF_CNT( descp ) / sizeof( hcf_16 ); + x.frag_buf[0].frag_addr = (hcf_8 *) descp->buf_addr ; + x.frag_buf[1].frag_len = ( GET_BUF_CNT( descp->next_desc_addr ) + 1 ) / sizeof( hcf_16 ); + x.frag_buf[1].frag_addr = (hcf_8 *) descp->next_desc_addr->buf_addr ; + + hcf_put_info( &( lp->hcfCtx ), (LTVP)&x ); + } +*/ + desc_next = desc->next_desc_addr; + + /* Make sure the buffer isn't empty */ + if( GET_BUF_CNT( desc ) == 0 ) { + DBG_WARNING( DbgInfo, "Buffer is empty!\n" ); + + /* Give the descriptor back to the HCF */ + hcf_dma_rx_put( &( lp->hcfCtx ), desc ); + return -EIO; + } + + /* Read the HFS_STAT register from the lookahead buffer */ + hfs_stat = (hcf_16)( desc->buf_addr[HFS_STAT/2] ); + + /* Make sure the frame isn't bad */ + if(( hfs_stat & HFS_STAT_ERR ) != HCF_SUCCESS ) + { + DBG_WARNING( DbgInfo, "HFS_STAT_ERROR (0x%x) in Rx Packet\n", + desc->buf_addr[HFS_STAT/2] ); + + /* Give the descriptor back to the HCF */ + hcf_dma_rx_put( &( lp->hcfCtx ), desc ); + return -EIO; + } + + /* Determine what port this packet is for */ + port = ( hfs_stat >> 8 ) & 0x0007; + DBG_RX( DbgInfo, "Rx frame for port %d\n", port ); + + pktlen = GET_BUF_CNT(desc_next); + if (pktlen != 0) { + skb = ALLOC_SKB(pktlen); + if (skb != NULL) { + switch( port ) { #ifdef USE_WDS - case 1: - case 2: - case 3: - case 4: - case 5: - case 6: - skb->dev = lp->wds_port[port-1].dev; - break; + case 1: + case 2: + case 3: + case 4: + case 5: + case 6: + skb->dev = lp->wds_port[port-1].dev; + break; #endif /* USE_WDS */ - case 0: - default: - skb->dev = dev; - break; - } + case 0: + default: + skb->dev = dev; + break; + } - GET_PACKET_DMA( skb->dev, skb, pktlen ); + GET_PACKET_DMA( skb->dev, skb, pktlen ); - /* Give the descriptor back to the HCF */ - hcf_dma_rx_put( &( lp->hcfCtx ), desc ); + /* Give the descriptor back to the HCF */ + hcf_dma_rx_put( &( lp->hcfCtx ), desc ); - netif_rx( skb ); + netif_rx( skb ); - if( port == 0 ) { - lp->stats.rx_packets++; - lp->stats.rx_bytes += pktlen; - } + if( port == 0 ) { + lp->stats.rx_packets++; + lp->stats.rx_bytes += pktlen; + } #ifdef USE_WDS - else - { - lp->wds_port[port-1].stats.rx_packets++; - lp->wds_port[port-1].stats.rx_bytes += pktlen; - } + else + { + lp->wds_port[port-1].stats.rx_packets++; + lp->wds_port[port-1].stats.rx_bytes += pktlen; + } #endif /* USE_WDS */ - dev->last_rx = jiffies; + dev->last_rx = jiffies; - } else { - DBG_ERROR( DbgInfo, "Could not alloc skb\n" ); + } else { + DBG_ERROR( DbgInfo, "Could not alloc skb\n" ); - if( port == 0 ) - { - lp->stats.rx_dropped++; - } + if( port == 0 ) + { + lp->stats.rx_dropped++; + } #ifdef USE_WDS - else - { - lp->wds_port[port-1].stats.rx_dropped++; - } + else + { + lp->wds_port[port-1].stats.rx_dropped++; + } #endif /* USE_WDS */ - } - } - } - //} - } + } + } + } + //} + } - return 0; + return 0; } // wl_rx_dma /*============================================================================*/ #endif // ENABLE_DMA -- 1.7.9.5 -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html