Commit 198191c4 authored by Krzysztof Halasa's avatar Krzysztof Halasa Committed by Jeff Garzik

WAN: convert drivers to use built-in netdev_stats

There is no point in using separate net_device_stats structs when
the one in struct net_device is present. Compiles.
Signed-off-by: default avatarKrzysztof Hałasa <khc@pm.waw.pl>
Signed-off-by: default avatarJeff Garzik <jgarzik@redhat.com>
parent 844290e5
...@@ -3886,9 +3886,8 @@ static bool rx_get_frame(MGSLPC_INFO *info) ...@@ -3886,9 +3886,8 @@ static bool rx_get_frame(MGSLPC_INFO *info)
framesize = 0; framesize = 0;
#if SYNCLINK_GENERIC_HDLC #if SYNCLINK_GENERIC_HDLC
{ {
struct net_device_stats *stats = hdlc_stats(info->netdev); info->netdev->stats.rx_errors++;
stats->rx_errors++; info->netdev->stats.rx_frame_errors++;
stats->rx_frame_errors++;
} }
#endif #endif
} else } else
...@@ -4144,7 +4143,6 @@ static int hdlcdev_attach(struct net_device *dev, unsigned short encoding, ...@@ -4144,7 +4143,6 @@ static int hdlcdev_attach(struct net_device *dev, unsigned short encoding,
static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev) static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev)
{ {
MGSLPC_INFO *info = dev_to_port(dev); MGSLPC_INFO *info = dev_to_port(dev);
struct net_device_stats *stats = hdlc_stats(dev);
unsigned long flags; unsigned long flags;
if (debug_level >= DEBUG_LEVEL_INFO) if (debug_level >= DEBUG_LEVEL_INFO)
...@@ -4159,8 +4157,8 @@ static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -4159,8 +4157,8 @@ static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev)
info->tx_put = info->tx_count = skb->len; info->tx_put = info->tx_count = skb->len;
/* update network statistics */ /* update network statistics */
stats->tx_packets++; dev->stats.tx_packets++;
stats->tx_bytes += skb->len; dev->stats.tx_bytes += skb->len;
/* done with socket buffer, so free it */ /* done with socket buffer, so free it */
dev_kfree_skb(skb); dev_kfree_skb(skb);
...@@ -4376,14 +4374,13 @@ static int hdlcdev_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) ...@@ -4376,14 +4374,13 @@ static int hdlcdev_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
static void hdlcdev_tx_timeout(struct net_device *dev) static void hdlcdev_tx_timeout(struct net_device *dev)
{ {
MGSLPC_INFO *info = dev_to_port(dev); MGSLPC_INFO *info = dev_to_port(dev);
struct net_device_stats *stats = hdlc_stats(dev);
unsigned long flags; unsigned long flags;
if (debug_level >= DEBUG_LEVEL_INFO) if (debug_level >= DEBUG_LEVEL_INFO)
printk("hdlcdev_tx_timeout(%s)\n",dev->name); printk("hdlcdev_tx_timeout(%s)\n",dev->name);
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_aborted_errors++; dev->stats.tx_aborted_errors++;
spin_lock_irqsave(&info->lock,flags); spin_lock_irqsave(&info->lock,flags);
tx_stop(info); tx_stop(info);
...@@ -4416,27 +4413,26 @@ static void hdlcdev_rx(MGSLPC_INFO *info, char *buf, int size) ...@@ -4416,27 +4413,26 @@ static void hdlcdev_rx(MGSLPC_INFO *info, char *buf, int size)
{ {
struct sk_buff *skb = dev_alloc_skb(size); struct sk_buff *skb = dev_alloc_skb(size);
struct net_device *dev = info->netdev; struct net_device *dev = info->netdev;
struct net_device_stats *stats = hdlc_stats(dev);
if (debug_level >= DEBUG_LEVEL_INFO) if (debug_level >= DEBUG_LEVEL_INFO)
printk("hdlcdev_rx(%s)\n",dev->name); printk("hdlcdev_rx(%s)\n",dev->name);
if (skb == NULL) { if (skb == NULL) {
printk(KERN_NOTICE "%s: can't alloc skb, dropping packet\n", dev->name); printk(KERN_NOTICE "%s: can't alloc skb, dropping packet\n", dev->name);
stats->rx_dropped++; dev->stats.rx_dropped++;
return; return;
} }
memcpy(skb_put(skb, size),buf,size); memcpy(skb_put(skb, size), buf, size);
skb->protocol = hdlc_type_trans(skb, info->netdev); skb->protocol = hdlc_type_trans(skb, dev);
stats->rx_packets++; dev->stats.rx_packets++;
stats->rx_bytes += size; dev->stats.rx_bytes += size;
netif_rx(skb); netif_rx(skb);
info->netdev->last_rx = jiffies; dev->last_rx = jiffies;
} }
/** /**
......
...@@ -6640,9 +6640,8 @@ static bool mgsl_get_rx_frame(struct mgsl_struct *info) ...@@ -6640,9 +6640,8 @@ static bool mgsl_get_rx_frame(struct mgsl_struct *info)
framesize = 0; framesize = 0;
#if SYNCLINK_GENERIC_HDLC #if SYNCLINK_GENERIC_HDLC
{ {
struct net_device_stats *stats = hdlc_stats(info->netdev); info->netdev->stats.rx_errors++;
stats->rx_errors++; info->netdev->stats.rx_frame_errors++;
stats->rx_frame_errors++;
} }
#endif #endif
} else } else
...@@ -7753,7 +7752,6 @@ static int hdlcdev_attach(struct net_device *dev, unsigned short encoding, ...@@ -7753,7 +7752,6 @@ static int hdlcdev_attach(struct net_device *dev, unsigned short encoding,
static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev) static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev)
{ {
struct mgsl_struct *info = dev_to_port(dev); struct mgsl_struct *info = dev_to_port(dev);
struct net_device_stats *stats = hdlc_stats(dev);
unsigned long flags; unsigned long flags;
if (debug_level >= DEBUG_LEVEL_INFO) if (debug_level >= DEBUG_LEVEL_INFO)
...@@ -7767,8 +7765,8 @@ static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -7767,8 +7765,8 @@ static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev)
mgsl_load_tx_dma_buffer(info, skb->data, skb->len); mgsl_load_tx_dma_buffer(info, skb->data, skb->len);
/* update network statistics */ /* update network statistics */
stats->tx_packets++; dev->stats.tx_packets++;
stats->tx_bytes += skb->len; dev->stats.tx_bytes += skb->len;
/* done with socket buffer, so free it */ /* done with socket buffer, so free it */
dev_kfree_skb(skb); dev_kfree_skb(skb);
...@@ -7984,14 +7982,13 @@ static int hdlcdev_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) ...@@ -7984,14 +7982,13 @@ static int hdlcdev_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
static void hdlcdev_tx_timeout(struct net_device *dev) static void hdlcdev_tx_timeout(struct net_device *dev)
{ {
struct mgsl_struct *info = dev_to_port(dev); struct mgsl_struct *info = dev_to_port(dev);
struct net_device_stats *stats = hdlc_stats(dev);
unsigned long flags; unsigned long flags;
if (debug_level >= DEBUG_LEVEL_INFO) if (debug_level >= DEBUG_LEVEL_INFO)
printk("hdlcdev_tx_timeout(%s)\n",dev->name); printk("hdlcdev_tx_timeout(%s)\n",dev->name);
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_aborted_errors++; dev->stats.tx_aborted_errors++;
spin_lock_irqsave(&info->irq_spinlock,flags); spin_lock_irqsave(&info->irq_spinlock,flags);
usc_stop_transmitter(info); usc_stop_transmitter(info);
...@@ -8024,27 +8021,27 @@ static void hdlcdev_rx(struct mgsl_struct *info, char *buf, int size) ...@@ -8024,27 +8021,27 @@ static void hdlcdev_rx(struct mgsl_struct *info, char *buf, int size)
{ {
struct sk_buff *skb = dev_alloc_skb(size); struct sk_buff *skb = dev_alloc_skb(size);
struct net_device *dev = info->netdev; struct net_device *dev = info->netdev;
struct net_device_stats *stats = hdlc_stats(dev);
if (debug_level >= DEBUG_LEVEL_INFO) if (debug_level >= DEBUG_LEVEL_INFO)
printk("hdlcdev_rx(%s)\n",dev->name); printk("hdlcdev_rx(%s)\n", dev->name);
if (skb == NULL) { if (skb == NULL) {
printk(KERN_NOTICE "%s: can't alloc skb, dropping packet\n", dev->name); printk(KERN_NOTICE "%s: can't alloc skb, dropping packet\n",
stats->rx_dropped++; dev->name);
dev->stats.rx_dropped++;
return; return;
} }
memcpy(skb_put(skb, size),buf,size); memcpy(skb_put(skb, size), buf, size);
skb->protocol = hdlc_type_trans(skb, info->netdev); skb->protocol = hdlc_type_trans(skb, dev);
stats->rx_packets++; dev->stats.rx_packets++;
stats->rx_bytes += size; dev->stats.rx_bytes += size;
netif_rx(skb); netif_rx(skb);
info->netdev->last_rx = jiffies; dev->last_rx = jiffies;
} }
/** /**
......
...@@ -1544,7 +1544,6 @@ static int hdlcdev_attach(struct net_device *dev, unsigned short encoding, ...@@ -1544,7 +1544,6 @@ static int hdlcdev_attach(struct net_device *dev, unsigned short encoding,
static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev) static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev)
{ {
struct slgt_info *info = dev_to_port(dev); struct slgt_info *info = dev_to_port(dev);
struct net_device_stats *stats = hdlc_stats(dev);
unsigned long flags; unsigned long flags;
DBGINFO(("%s hdlc_xmit\n", dev->name)); DBGINFO(("%s hdlc_xmit\n", dev->name));
...@@ -1557,8 +1556,8 @@ static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -1557,8 +1556,8 @@ static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev)
tx_load(info, skb->data, skb->len); tx_load(info, skb->data, skb->len);
/* update network statistics */ /* update network statistics */
stats->tx_packets++; dev->stats.tx_packets++;
stats->tx_bytes += skb->len; dev->stats.tx_bytes += skb->len;
/* done with socket buffer, so free it */ /* done with socket buffer, so free it */
dev_kfree_skb(skb); dev_kfree_skb(skb);
...@@ -1775,13 +1774,12 @@ static int hdlcdev_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) ...@@ -1775,13 +1774,12 @@ static int hdlcdev_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
static void hdlcdev_tx_timeout(struct net_device *dev) static void hdlcdev_tx_timeout(struct net_device *dev)
{ {
struct slgt_info *info = dev_to_port(dev); struct slgt_info *info = dev_to_port(dev);
struct net_device_stats *stats = hdlc_stats(dev);
unsigned long flags; unsigned long flags;
DBGINFO(("%s hdlcdev_tx_timeout\n", dev->name)); DBGINFO(("%s hdlcdev_tx_timeout\n", dev->name));
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_aborted_errors++; dev->stats.tx_aborted_errors++;
spin_lock_irqsave(&info->lock,flags); spin_lock_irqsave(&info->lock,flags);
tx_stop(info); tx_stop(info);
...@@ -1814,26 +1812,25 @@ static void hdlcdev_rx(struct slgt_info *info, char *buf, int size) ...@@ -1814,26 +1812,25 @@ static void hdlcdev_rx(struct slgt_info *info, char *buf, int size)
{ {
struct sk_buff *skb = dev_alloc_skb(size); struct sk_buff *skb = dev_alloc_skb(size);
struct net_device *dev = info->netdev; struct net_device *dev = info->netdev;
struct net_device_stats *stats = hdlc_stats(dev);
DBGINFO(("%s hdlcdev_rx\n", dev->name)); DBGINFO(("%s hdlcdev_rx\n", dev->name));
if (skb == NULL) { if (skb == NULL) {
DBGERR(("%s: can't alloc skb, drop packet\n", dev->name)); DBGERR(("%s: can't alloc skb, drop packet\n", dev->name));
stats->rx_dropped++; dev->stats.rx_dropped++;
return; return;
} }
memcpy(skb_put(skb, size),buf,size); memcpy(skb_put(skb, size), buf, size);
skb->protocol = hdlc_type_trans(skb, info->netdev); skb->protocol = hdlc_type_trans(skb, dev);
stats->rx_packets++; dev->stats.rx_packets++;
stats->rx_bytes += size; dev->stats.rx_bytes += size;
netif_rx(skb); netif_rx(skb);
info->netdev->last_rx = jiffies; dev->last_rx = jiffies;
} }
/** /**
...@@ -4577,9 +4574,8 @@ static bool rx_get_frame(struct slgt_info *info) ...@@ -4577,9 +4574,8 @@ static bool rx_get_frame(struct slgt_info *info)
#if SYNCLINK_GENERIC_HDLC #if SYNCLINK_GENERIC_HDLC
if (framesize == 0) { if (framesize == 0) {
struct net_device_stats *stats = hdlc_stats(info->netdev); info->netdev->stats.rx_errors++;
stats->rx_errors++; info->netdev->stats.rx_frame_errors++;
stats->rx_frame_errors++;
} }
#endif #endif
......
...@@ -1678,7 +1678,6 @@ static int hdlcdev_attach(struct net_device *dev, unsigned short encoding, ...@@ -1678,7 +1678,6 @@ static int hdlcdev_attach(struct net_device *dev, unsigned short encoding,
static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev) static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev)
{ {
SLMP_INFO *info = dev_to_port(dev); SLMP_INFO *info = dev_to_port(dev);
struct net_device_stats *stats = hdlc_stats(dev);
unsigned long flags; unsigned long flags;
if (debug_level >= DEBUG_LEVEL_INFO) if (debug_level >= DEBUG_LEVEL_INFO)
...@@ -1692,8 +1691,8 @@ static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -1692,8 +1691,8 @@ static int hdlcdev_xmit(struct sk_buff *skb, struct net_device *dev)
tx_load_dma_buffer(info, skb->data, skb->len); tx_load_dma_buffer(info, skb->data, skb->len);
/* update network statistics */ /* update network statistics */
stats->tx_packets++; dev->stats.tx_packets++;
stats->tx_bytes += skb->len; dev->stats.tx_bytes += skb->len;
/* done with socket buffer, so free it */ /* done with socket buffer, so free it */
dev_kfree_skb(skb); dev_kfree_skb(skb);
...@@ -1909,14 +1908,13 @@ static int hdlcdev_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) ...@@ -1909,14 +1908,13 @@ static int hdlcdev_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
static void hdlcdev_tx_timeout(struct net_device *dev) static void hdlcdev_tx_timeout(struct net_device *dev)
{ {
SLMP_INFO *info = dev_to_port(dev); SLMP_INFO *info = dev_to_port(dev);
struct net_device_stats *stats = hdlc_stats(dev);
unsigned long flags; unsigned long flags;
if (debug_level >= DEBUG_LEVEL_INFO) if (debug_level >= DEBUG_LEVEL_INFO)
printk("hdlcdev_tx_timeout(%s)\n",dev->name); printk("hdlcdev_tx_timeout(%s)\n",dev->name);
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_aborted_errors++; dev->stats.tx_aborted_errors++;
spin_lock_irqsave(&info->lock,flags); spin_lock_irqsave(&info->lock,flags);
tx_stop(info); tx_stop(info);
...@@ -1949,27 +1947,27 @@ static void hdlcdev_rx(SLMP_INFO *info, char *buf, int size) ...@@ -1949,27 +1947,27 @@ static void hdlcdev_rx(SLMP_INFO *info, char *buf, int size)
{ {
struct sk_buff *skb = dev_alloc_skb(size); struct sk_buff *skb = dev_alloc_skb(size);
struct net_device *dev = info->netdev; struct net_device *dev = info->netdev;
struct net_device_stats *stats = hdlc_stats(dev);
if (debug_level >= DEBUG_LEVEL_INFO) if (debug_level >= DEBUG_LEVEL_INFO)
printk("hdlcdev_rx(%s)\n",dev->name); printk("hdlcdev_rx(%s)\n",dev->name);
if (skb == NULL) { if (skb == NULL) {
printk(KERN_NOTICE "%s: can't alloc skb, dropping packet\n", dev->name); printk(KERN_NOTICE "%s: can't alloc skb, dropping packet\n",
stats->rx_dropped++; dev->name);
dev->stats.rx_dropped++;
return; return;
} }
memcpy(skb_put(skb, size),buf,size); memcpy(skb_put(skb, size), buf, size);
skb->protocol = hdlc_type_trans(skb, info->netdev); skb->protocol = hdlc_type_trans(skb, dev);
stats->rx_packets++; dev->stats.rx_packets++;
stats->rx_bytes += size; dev->stats.rx_bytes += size;
netif_rx(skb); netif_rx(skb);
info->netdev->last_rx = jiffies; dev->last_rx = jiffies;
} }
/** /**
...@@ -4983,9 +4981,8 @@ static bool rx_get_frame(SLMP_INFO *info) ...@@ -4983,9 +4981,8 @@ static bool rx_get_frame(SLMP_INFO *info)
framesize = 0; framesize = 0;
#if SYNCLINK_GENERIC_HDLC #if SYNCLINK_GENERIC_HDLC
{ {
struct net_device_stats *stats = hdlc_stats(info->netdev); info->netdev->stats.rx_errors++;
stats->rx_errors++; info->netdev->stats.rx_frame_errors++;
stats->rx_frame_errors++;
} }
#endif #endif
} }
......
...@@ -133,9 +133,9 @@ static void sca_msci_intr(port_t *port) ...@@ -133,9 +133,9 @@ static void sca_msci_intr(port_t *port)
sca_out(stat & (ST1_UDRN | ST1_CDCD), MSCI0_OFFSET + ST1, port); sca_out(stat & (ST1_UDRN | ST1_CDCD), MSCI0_OFFSET + ST1, port);
if (stat & ST1_UDRN) { if (stat & ST1_UDRN) {
struct net_device_stats *stats = hdlc_stats(port_to_dev(port)); /* TX Underrun error detected */
stats->tx_errors++; /* TX Underrun error detected */ port_to_dev(port)->stats.tx_errors++;
stats->tx_fifo_errors++; port_to_dev(port)->stats.tx_fifo_errors++;
} }
stat = sca_in(MSCI1_OFFSET + ST1, port); /* read MSCI1 ST1 status */ stat = sca_in(MSCI1_OFFSET + ST1, port); /* read MSCI1 ST1 status */
......
...@@ -642,7 +642,6 @@ static inline void dscc4_rx_skb(struct dscc4_dev_priv *dpriv, ...@@ -642,7 +642,6 @@ static inline void dscc4_rx_skb(struct dscc4_dev_priv *dpriv,
struct net_device *dev) struct net_device *dev)
{ {
struct RxFD *rx_fd = dpriv->rx_fd + dpriv->rx_current%RX_RING_SIZE; struct RxFD *rx_fd = dpriv->rx_fd + dpriv->rx_current%RX_RING_SIZE;
struct net_device_stats *stats = hdlc_stats(dev);
struct pci_dev *pdev = dpriv->pci_priv->pdev; struct pci_dev *pdev = dpriv->pci_priv->pdev;
struct sk_buff *skb; struct sk_buff *skb;
int pkt_len; int pkt_len;
...@@ -656,8 +655,8 @@ static inline void dscc4_rx_skb(struct dscc4_dev_priv *dpriv, ...@@ -656,8 +655,8 @@ static inline void dscc4_rx_skb(struct dscc4_dev_priv *dpriv,
pci_unmap_single(pdev, le32_to_cpu(rx_fd->data), pci_unmap_single(pdev, le32_to_cpu(rx_fd->data),
RX_MAX(HDLC_MAX_MRU), PCI_DMA_FROMDEVICE); RX_MAX(HDLC_MAX_MRU), PCI_DMA_FROMDEVICE);
if ((skb->data[--pkt_len] & FrameOk) == FrameOk) { if ((skb->data[--pkt_len] & FrameOk) == FrameOk) {
stats->rx_packets++; dev->stats.rx_packets++;
stats->rx_bytes += pkt_len; dev->stats.rx_bytes += pkt_len;
skb_put(skb, pkt_len); skb_put(skb, pkt_len);
if (netif_running(dev)) if (netif_running(dev))
skb->protocol = hdlc_type_trans(skb, dev); skb->protocol = hdlc_type_trans(skb, dev);
...@@ -665,13 +664,13 @@ static inline void dscc4_rx_skb(struct dscc4_dev_priv *dpriv, ...@@ -665,13 +664,13 @@ static inline void dscc4_rx_skb(struct dscc4_dev_priv *dpriv,
netif_rx(skb); netif_rx(skb);
} else { } else {
if (skb->data[pkt_len] & FrameRdo) if (skb->data[pkt_len] & FrameRdo)
stats->rx_fifo_errors++; dev->stats.rx_fifo_errors++;
else if (!(skb->data[pkt_len] | ~FrameCrc)) else if (!(skb->data[pkt_len] | ~FrameCrc))
stats->rx_crc_errors++; dev->stats.rx_crc_errors++;
else if (!(skb->data[pkt_len] | ~(FrameVfr | FrameRab))) else if (!(skb->data[pkt_len] | ~(FrameVfr | FrameRab)))
stats->rx_length_errors++; dev->stats.rx_length_errors++;
else else
stats->rx_errors++; dev->stats.rx_errors++;
dev_kfree_skb_irq(skb); dev_kfree_skb_irq(skb);
} }
refill: refill:
...@@ -1569,7 +1568,6 @@ static void dscc4_tx_irq(struct dscc4_pci_priv *ppriv, ...@@ -1569,7 +1568,6 @@ static void dscc4_tx_irq(struct dscc4_pci_priv *ppriv,
if (state & SccEvt) { if (state & SccEvt) {
if (state & Alls) { if (state & Alls) {
struct net_device_stats *stats = hdlc_stats(dev);
struct sk_buff *skb; struct sk_buff *skb;
struct TxFD *tx_fd; struct TxFD *tx_fd;
...@@ -1586,8 +1584,8 @@ static void dscc4_tx_irq(struct dscc4_pci_priv *ppriv, ...@@ -1586,8 +1584,8 @@ static void dscc4_tx_irq(struct dscc4_pci_priv *ppriv,
pci_unmap_single(ppriv->pdev, le32_to_cpu(tx_fd->data), pci_unmap_single(ppriv->pdev, le32_to_cpu(tx_fd->data),
skb->len, PCI_DMA_TODEVICE); skb->len, PCI_DMA_TODEVICE);
if (tx_fd->state & FrameEnd) { if (tx_fd->state & FrameEnd) {
stats->tx_packets++; dev->stats.tx_packets++;
stats->tx_bytes += skb->len; dev->stats.tx_bytes += skb->len;
} }
dev_kfree_skb_irq(skb); dev_kfree_skb_irq(skb);
dpriv->tx_skbuff[cur] = NULL; dpriv->tx_skbuff[cur] = NULL;
...@@ -1698,7 +1696,7 @@ static void dscc4_tx_irq(struct dscc4_pci_priv *ppriv, ...@@ -1698,7 +1696,7 @@ static void dscc4_tx_irq(struct dscc4_pci_priv *ppriv,
} }
if (state & Err) { if (state & Err) {
printk(KERN_INFO "%s: Tx ERR\n", dev->name); printk(KERN_INFO "%s: Tx ERR\n", dev->name);
hdlc_stats(dev)->tx_errors++; dev->stats.tx_errors++;
state &= ~Err; state &= ~Err;
} }
} }
...@@ -1834,7 +1832,7 @@ static void dscc4_rx_irq(struct dscc4_pci_priv *priv, ...@@ -1834,7 +1832,7 @@ static void dscc4_rx_irq(struct dscc4_pci_priv *priv,
if (!(rx_fd->state2 & DataComplete)) if (!(rx_fd->state2 & DataComplete))
break; break;
if (rx_fd->state2 & FrameAborted) { if (rx_fd->state2 & FrameAborted) {
hdlc_stats(dev)->rx_over_errors++; dev->stats.rx_over_errors++;
rx_fd->state1 |= Hold; rx_fd->state1 |= Hold;
rx_fd->state2 = 0x00000000; rx_fd->state2 = 0x00000000;
rx_fd->end = cpu_to_le32(0xbabeface); rx_fd->end = cpu_to_le32(0xbabeface);
......
...@@ -845,7 +845,6 @@ fst_tx_dma_complete(struct fst_card_info *card, struct fst_port_info *port, ...@@ -845,7 +845,6 @@ fst_tx_dma_complete(struct fst_card_info *card, struct fst_port_info *port,
int len, int txpos) int len, int txpos)
{ {
struct net_device *dev = port_to_dev(port); struct net_device *dev = port_to_dev(port);
struct net_device_stats *stats = hdlc_stats(dev);
/* /*
* Everything is now set, just tell the card to go * Everything is now set, just tell the card to go
...@@ -853,8 +852,8 @@ fst_tx_dma_complete(struct fst_card_info *card, struct fst_port_info *port, ...@@ -853,8 +852,8 @@ fst_tx_dma_complete(struct fst_card_info *card, struct fst_port_info *port,
dbg(DBG_TX, "fst_tx_dma_complete\n"); dbg(DBG_TX, "fst_tx_dma_complete\n");
FST_WRB(card, txDescrRing[port->index][txpos].bits, FST_WRB(card, txDescrRing[port->index][txpos].bits,
DMA_OWN | TX_STP | TX_ENP); DMA_OWN | TX_STP | TX_ENP);
stats->tx_packets++; dev->stats.tx_packets++;
stats->tx_bytes += len; dev->stats.tx_bytes += len;
dev->trans_start = jiffies; dev->trans_start = jiffies;
} }
...@@ -876,7 +875,6 @@ fst_rx_dma_complete(struct fst_card_info *card, struct fst_port_info *port, ...@@ -876,7 +875,6 @@ fst_rx_dma_complete(struct fst_card_info *card, struct fst_port_info *port,
int len, struct sk_buff *skb, int rxp) int len, struct sk_buff *skb, int rxp)
{ {
struct net_device *dev = port_to_dev(port); struct net_device *dev = port_to_dev(port);
struct net_device_stats *stats = hdlc_stats(dev);
int pi; int pi;
int rx_status; int rx_status;
...@@ -888,8 +886,8 @@ fst_rx_dma_complete(struct fst_card_info *card, struct fst_port_info *port, ...@@ -888,8 +886,8 @@ fst_rx_dma_complete(struct fst_card_info *card, struct fst_port_info *port,
FST_WRB(card, rxDescrRing[pi][rxp].bits, DMA_OWN); FST_WRB(card, rxDescrRing[pi][rxp].bits, DMA_OWN);
/* Update stats */ /* Update stats */
stats->rx_packets++; dev->stats.rx_packets++;
stats->rx_bytes += len; dev->stats.rx_bytes += len;
/* Push upstream */ /* Push upstream */
dbg(DBG_RX, "Pushing the frame up the stack\n"); dbg(DBG_RX, "Pushing the frame up the stack\n");
...@@ -900,7 +898,7 @@ fst_rx_dma_complete(struct fst_card_info *card, struct fst_port_info *port, ...@@ -900,7 +898,7 @@ fst_rx_dma_complete(struct fst_card_info *card, struct fst_port_info *port,
rx_status = netif_rx(skb); rx_status = netif_rx(skb);
fst_process_rx_status(rx_status, port_to_dev(port)->name); fst_process_rx_status(rx_status, port_to_dev(port)->name);
if (rx_status == NET_RX_DROP) if (rx_status == NET_RX_DROP)
stats->rx_dropped++; dev->stats.rx_dropped++;
dev->last_rx = jiffies; dev->last_rx = jiffies;
} }
...@@ -1163,29 +1161,28 @@ fst_log_rx_error(struct fst_card_info *card, struct fst_port_info *port, ...@@ -1163,29 +1161,28 @@ fst_log_rx_error(struct fst_card_info *card, struct fst_port_info *port,
unsigned char dmabits, int rxp, unsigned short len) unsigned char dmabits, int rxp, unsigned short len)
{ {
struct net_device *dev = port_to_dev(port); struct net_device *dev = port_to_dev(port);
struct net_device_stats *stats = hdlc_stats(dev);
/* /*
* Increment the appropriate error counter * Increment the appropriate error counter
*/ */
stats->rx_errors++; dev->stats.rx_errors++;
if (dmabits & RX_OFLO) { if (dmabits & RX_OFLO) {
stats->rx_fifo_errors++; dev->stats.rx_fifo_errors++;
dbg(DBG_ASS, "Rx fifo error on card %d port %d buffer %d\n", dbg(DBG_ASS, "Rx fifo error on card %d port %d buffer %d\n",
card->card_no, port->index, rxp); card->card_no, port->index, rxp);
} }
if (dmabits & RX_CRC) { if (dmabits & RX_CRC) {
stats->rx_crc_errors++; dev->stats.rx_crc_errors++;
dbg(DBG_ASS, "Rx crc error on card %d port %d\n", dbg(DBG_ASS, "Rx crc error on card %d port %d\n",
card->card_no, port->index); card->card_no, port->index);
} }
if (dmabits & RX_FRAM) { if (dmabits & RX_FRAM) {
stats->rx_frame_errors++; dev->stats.rx_frame_errors++;
dbg(DBG_ASS, "Rx frame error on card %d port %d\n", dbg(DBG_ASS, "Rx frame error on card %d port %d\n",
card->card_no, port->index); card->card_no, port->index);
} }
if (dmabits == (RX_STP | RX_ENP)) { if (dmabits == (RX_STP | RX_ENP)) {
stats->rx_length_errors++; dev->stats.rx_length_errors++;
dbg(DBG_ASS, "Rx length error (%d) on card %d port %d\n", dbg(DBG_ASS, "Rx length error (%d) on card %d port %d\n",
len, card->card_no, port->index); len, card->card_no, port->index);
} }
...@@ -1242,7 +1239,6 @@ fst_intr_rx(struct fst_card_info *card, struct fst_port_info *port) ...@@ -1242,7 +1239,6 @@ fst_intr_rx(struct fst_card_info *card, struct fst_port_info *port)
unsigned short len; unsigned short len;
struct sk_buff *skb; struct sk_buff *skb;
struct net_device *dev = port_to_dev(port); struct net_device *dev = port_to_dev(port);
struct net_device_stats *stats = hdlc_stats(dev);
/* Check we have a buffer to process */ /* Check we have a buffer to process */
pi = port->index; pi = port->index;
...@@ -1291,7 +1287,7 @@ fst_intr_rx(struct fst_card_info *card, struct fst_port_info *port) ...@@ -1291,7 +1287,7 @@ fst_intr_rx(struct fst_card_info *card, struct fst_port_info *port)
if ((skb = dev_alloc_skb(len)) == NULL) { if ((skb = dev_alloc_skb(len)) == NULL) {
dbg(DBG_RX, "intr_rx: can't allocate buffer\n"); dbg(DBG_RX, "intr_rx: can't allocate buffer\n");
stats->rx_dropped++; dev->stats.rx_dropped++;
/* Return descriptor to card */ /* Return descriptor to card */
FST_WRB(card, rxDescrRing[pi][rxp].bits, DMA_OWN); FST_WRB(card, rxDescrRing[pi][rxp].bits, DMA_OWN);
...@@ -1316,8 +1312,8 @@ fst_intr_rx(struct fst_card_info *card, struct fst_port_info *port) ...@@ -1316,8 +1312,8 @@ fst_intr_rx(struct fst_card_info *card, struct fst_port_info *port)
FST_WRB(card, rxDescrRing[pi][rxp].bits, DMA_OWN); FST_WRB(card, rxDescrRing[pi][rxp].bits, DMA_OWN);
/* Update stats */ /* Update stats */
stats->rx_packets++; dev->stats.rx_packets++;
stats->rx_bytes += len; dev->stats.rx_bytes += len;
/* Push upstream */ /* Push upstream */
dbg(DBG_RX, "Pushing frame up the stack\n"); dbg(DBG_RX, "Pushing frame up the stack\n");
...@@ -1327,9 +1323,8 @@ fst_intr_rx(struct fst_card_info *card, struct fst_port_info *port) ...@@ -1327,9 +1323,8 @@ fst_intr_rx(struct fst_card_info *card, struct fst_port_info *port)
skb->protocol = hdlc_type_trans(skb, dev); skb->protocol = hdlc_type_trans(skb, dev);
rx_status = netif_rx(skb); rx_status = netif_rx(skb);
fst_process_rx_status(rx_status, port_to_dev(port)->name); fst_process_rx_status(rx_status, port_to_dev(port)->name);
if (rx_status == NET_RX_DROP) { if (rx_status == NET_RX_DROP)
stats->rx_dropped++; dev->stats.rx_dropped++;
}
dev->last_rx = jiffies; dev->last_rx = jiffies;
} else { } else {
card->dma_skb_rx = skb; card->dma_skb_rx = skb;
...@@ -1361,7 +1356,6 @@ do_bottom_half_tx(struct fst_card_info *card) ...@@ -1361,7 +1356,6 @@ do_bottom_half_tx(struct fst_card_info *card)
struct sk_buff *skb; struct sk_buff *skb;
unsigned long flags; unsigned long flags;
struct net_device *dev; struct net_device *dev;
struct net_device_stats *stats;
/* /*
* Find a free buffer for the transmit * Find a free buffer for the transmit
...@@ -1373,12 +1367,10 @@ do_bottom_half_tx(struct fst_card_info *card) ...@@ -1373,12 +1367,10 @@ do_bottom_half_tx(struct fst_card_info *card)
if (!port->run) if (!port->run)
continue; continue;
dev = port_to_dev(port); dev = port_to_dev(port);
stats = hdlc_stats(dev); while (!(FST_RDB(card, txDescrRing[pi][port->txpos].bits) &
while (! DMA_OWN)
(FST_RDB(card, txDescrRing[pi][port->txpos].bits) & && !(card->dmatx_in_progress)) {
DMA_OWN)
&& !(card->dmatx_in_progress)) {
/* /*
* There doesn't seem to be a txdone event per-se * There doesn't seem to be a txdone event per-se
* We seem to have to deduce it, by checking the DMA_OWN * We seem to have to deduce it, by checking the DMA_OWN
...@@ -1422,8 +1414,8 @@ do_bottom_half_tx(struct fst_card_info *card) ...@@ -1422,8 +1414,8 @@ do_bottom_half_tx(struct fst_card_info *card)
txDescrRing[pi][port->txpos]. txDescrRing[pi][port->txpos].
bits, bits,
DMA_OWN | TX_STP | TX_ENP); DMA_OWN | TX_STP | TX_ENP);
stats->tx_packets++; dev->stats.tx_packets++;
stats->tx_bytes += skb->len; dev->stats.tx_bytes += skb->len;
dev->trans_start = jiffies; dev->trans_start = jiffies;
} else { } else {
/* Or do it through dma */ /* Or do it through dma */
...@@ -1628,8 +1620,8 @@ fst_intr(int dummy, void *dev_id) ...@@ -1628,8 +1620,8 @@ fst_intr(int dummy, void *dev_id)
* always load up the entire packet for DMA. * always load up the entire packet for DMA.
*/ */
dbg(DBG_TX, "Tx underflow port %d\n", port->index); dbg(DBG_TX, "Tx underflow port %d\n", port->index);
hdlc_stats(port_to_dev(port))->tx_errors++; port_to_dev(port)->stats.tx_errors++;
hdlc_stats(port_to_dev(port))->tx_fifo_errors++; port_to_dev(port)->stats.tx_fifo_errors++;
dbg(DBG_ASS, "Tx underflow on card %d port %d\n", dbg(DBG_ASS, "Tx underflow on card %d port %d\n",
card->card_no, port->index); card->card_no, port->index);
break; break;
...@@ -2292,12 +2284,11 @@ fst_tx_timeout(struct net_device *dev) ...@@ -2292,12 +2284,11 @@ fst_tx_timeout(struct net_device *dev)
{ {
struct fst_port_info *port; struct fst_port_info *port;
struct fst_card_info *card; struct fst_card_info *card;
struct net_device_stats *stats = hdlc_stats(dev);
port = dev_to_port(dev); port = dev_to_port(dev);
card = port->card; card = port->card;
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_aborted_errors++; dev->stats.tx_aborted_errors++;
dbg(DBG_ASS, "Tx timeout card %d port %d\n", dbg(DBG_ASS, "Tx timeout card %d port %d\n",
card->card_no, port->index); card->card_no, port->index);
fst_issue_cmd(port, ABORTTX); fst_issue_cmd(port, ABORTTX);
...@@ -2312,7 +2303,6 @@ fst_start_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -2312,7 +2303,6 @@ fst_start_xmit(struct sk_buff *skb, struct net_device *dev)
{ {
struct fst_card_info *card; struct fst_card_info *card;
struct fst_port_info *port; struct fst_port_info *port;
struct net_device_stats *stats = hdlc_stats(dev);
unsigned long flags; unsigned long flags;
int txq_length; int txq_length;
...@@ -2323,8 +2313,8 @@ fst_start_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -2323,8 +2313,8 @@ fst_start_xmit(struct sk_buff *skb, struct net_device *dev)
/* Drop packet with error if we don't have carrier */ /* Drop packet with error if we don't have carrier */
if (!netif_carrier_ok(dev)) { if (!netif_carrier_ok(dev)) {
dev_kfree_skb(skb); dev_kfree_skb(skb);
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_carrier_errors++; dev->stats.tx_carrier_errors++;
dbg(DBG_ASS, dbg(DBG_ASS,
"Tried to transmit but no carrier on card %d port %d\n", "Tried to transmit but no carrier on card %d port %d\n",
card->card_no, port->index); card->card_no, port->index);
...@@ -2336,7 +2326,7 @@ fst_start_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -2336,7 +2326,7 @@ fst_start_xmit(struct sk_buff *skb, struct net_device *dev)
dbg(DBG_ASS, "Packet too large %d vs %d\n", skb->len, dbg(DBG_ASS, "Packet too large %d vs %d\n", skb->len,
LEN_TX_BUFFER); LEN_TX_BUFFER);
dev_kfree_skb(skb); dev_kfree_skb(skb);
stats->tx_errors++; dev->stats.tx_errors++;
return 0; return 0;
} }
...@@ -2368,7 +2358,7 @@ fst_start_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -2368,7 +2358,7 @@ fst_start_xmit(struct sk_buff *skb, struct net_device *dev)
* This shouldn't have happened but such is life * This shouldn't have happened but such is life
*/ */
dev_kfree_skb(skb); dev_kfree_skb(skb);
stats->tx_errors++; dev->stats.tx_errors++;
dbg(DBG_ASS, "Tx queue overflow card %d port %d\n", dbg(DBG_ASS, "Tx queue overflow card %d port %d\n",
card->card_no, port->index); card->card_no, port->index);
return 0; return 0;
......
...@@ -271,9 +271,9 @@ static inline void sca_msci_intr(port_t *port) ...@@ -271,9 +271,9 @@ static inline void sca_msci_intr(port_t *port)
sca_out(stat & (ST1_UDRN | ST1_CDCD), msci + ST1, card); sca_out(stat & (ST1_UDRN | ST1_CDCD), msci + ST1, card);
if (stat & ST1_UDRN) { if (stat & ST1_UDRN) {
struct net_device_stats *stats = hdlc_stats(port_to_dev(port)); /* TX Underrun error detected */
stats->tx_errors++; /* TX Underrun error detected */ port_to_dev(port)->stats.tx_errors++;
stats->tx_fifo_errors++; port_to_dev(port)->stats.tx_fifo_errors++;
} }
if (stat & ST1_CDCD) if (stat & ST1_CDCD)
...@@ -286,7 +286,6 @@ static inline void sca_msci_intr(port_t *port) ...@@ -286,7 +286,6 @@ static inline void sca_msci_intr(port_t *port)
static inline void sca_rx(card_t *card, port_t *port, pkt_desc __iomem *desc, u16 rxin) static inline void sca_rx(card_t *card, port_t *port, pkt_desc __iomem *desc, u16 rxin)
{ {
struct net_device *dev = port_to_dev(port); struct net_device *dev = port_to_dev(port);
struct net_device_stats *stats = hdlc_stats(dev);
struct sk_buff *skb; struct sk_buff *skb;
u16 len; u16 len;
u32 buff; u32 buff;
...@@ -298,7 +297,7 @@ static inline void sca_rx(card_t *card, port_t *port, pkt_desc __iomem *desc, u1 ...@@ -298,7 +297,7 @@ static inline void sca_rx(card_t *card, port_t *port, pkt_desc __iomem *desc, u1
len = readw(&desc->len); len = readw(&desc->len);
skb = dev_alloc_skb(len); skb = dev_alloc_skb(len);
if (!skb) { if (!skb) {
stats->rx_dropped++; dev->stats.rx_dropped++;
return; return;
} }
...@@ -327,8 +326,8 @@ static inline void sca_rx(card_t *card, port_t *port, pkt_desc __iomem *desc, u1 ...@@ -327,8 +326,8 @@ static inline void sca_rx(card_t *card, port_t *port, pkt_desc __iomem *desc, u1
printk(KERN_DEBUG "%s RX(%i):", dev->name, skb->len); printk(KERN_DEBUG "%s RX(%i):", dev->name, skb->len);
debug_frame(skb); debug_frame(skb);
#endif #endif
stats->rx_packets++; dev->stats.rx_packets++;
stats->rx_bytes += skb->len; dev->stats.rx_bytes += skb->len;
dev->last_rx = jiffies; dev->last_rx = jiffies;
skb->protocol = hdlc_type_trans(skb, dev); skb->protocol = hdlc_type_trans(skb, dev);
netif_rx(skb); netif_rx(skb);
...@@ -339,17 +338,18 @@ static inline void sca_rx(card_t *card, port_t *port, pkt_desc __iomem *desc, u1 ...@@ -339,17 +338,18 @@ static inline void sca_rx(card_t *card, port_t *port, pkt_desc __iomem *desc, u1
/* Receive DMA interrupt service */ /* Receive DMA interrupt service */
static inline void sca_rx_intr(port_t *port) static inline void sca_rx_intr(port_t *port)
{ {
struct net_device *dev = port_to_dev(port);
u16 dmac = get_dmac_rx(port); u16 dmac = get_dmac_rx(port);
card_t *card = port_to_card(port); card_t *card = port_to_card(port);
u8 stat = sca_in(DSR_RX(phy_node(port)), card); /* read DMA Status */ u8 stat = sca_in(DSR_RX(phy_node(port)), card); /* read DMA Status */
struct net_device_stats *stats = hdlc_stats(port_to_dev(port));
/* Reset DSR status bits */ /* Reset DSR status bits */
sca_out((stat & (DSR_EOT | DSR_EOM | DSR_BOF | DSR_COF)) | DSR_DWE, sca_out((stat & (DSR_EOT | DSR_EOM | DSR_BOF | DSR_COF)) | DSR_DWE,
DSR_RX(phy_node(port)), card); DSR_RX(phy_node(port)), card);
if (stat & DSR_BOF) if (stat & DSR_BOF)
stats->rx_over_errors++; /* Dropped one or more frames */ /* Dropped one or more frames */
dev->stats.rx_over_errors++;
while (1) { while (1) {
u32 desc_off = desc_offset(port, port->rxin, 0); u32 desc_off = desc_offset(port, port->rxin, 0);
...@@ -364,12 +364,14 @@ static inline void sca_rx_intr(port_t *port) ...@@ -364,12 +364,14 @@ static inline void sca_rx_intr(port_t *port)
if (!(stat & ST_RX_EOM)) if (!(stat & ST_RX_EOM))
port->rxpart = 1; /* partial frame received */ port->rxpart = 1; /* partial frame received */
else if ((stat & ST_ERROR_MASK) || port->rxpart) { else if ((stat & ST_ERROR_MASK) || port->rxpart) {
stats->rx_errors++; dev->stats.rx_errors++;
if (stat & ST_RX_OVERRUN) stats->rx_fifo_errors++; if (stat & ST_RX_OVERRUN)
dev->stats.rx_fifo_errors++;
else if ((stat & (ST_RX_SHORT | ST_RX_ABORT | else if ((stat & (ST_RX_SHORT | ST_RX_ABORT |
ST_RX_RESBIT)) || port->rxpart) ST_RX_RESBIT)) || port->rxpart)
stats->rx_frame_errors++; dev->stats.rx_frame_errors++;
else if (stat & ST_RX_CRC) stats->rx_crc_errors++; else if (stat & ST_RX_CRC)
dev->stats.rx_crc_errors++;
if (stat & ST_RX_EOM) if (stat & ST_RX_EOM)
port->rxpart = 0; /* received last fragment */ port->rxpart = 0; /* received last fragment */
} else } else
...@@ -390,7 +392,6 @@ static inline void sca_rx_intr(port_t *port) ...@@ -390,7 +392,6 @@ static inline void sca_rx_intr(port_t *port)
static inline void sca_tx_intr(port_t *port) static inline void sca_tx_intr(port_t *port)
{ {
struct net_device *dev = port_to_dev(port); struct net_device *dev = port_to_dev(port);
struct net_device_stats *stats = hdlc_stats(dev);
u16 dmac = get_dmac_tx(port); u16 dmac = get_dmac_tx(port);
card_t* card = port_to_card(port); card_t* card = port_to_card(port);
u8 stat; u8 stat;
...@@ -412,8 +413,8 @@ static inline void sca_tx_intr(port_t *port) ...@@ -412,8 +413,8 @@ static inline void sca_tx_intr(port_t *port)
break; /* Transmitter is/will_be sending this frame */ break; /* Transmitter is/will_be sending this frame */
desc = desc_address(port, port->txlast, 1); desc = desc_address(port, port->txlast, 1);
stats->tx_packets++; dev->stats.tx_packets++;
stats->tx_bytes += readw(&desc->len); dev->stats.tx_bytes += readw(&desc->len);
writeb(0, &desc->stat); /* Free descriptor */ writeb(0, &desc->stat); /* Free descriptor */
port->txlast = next_desc(port, port->txlast, 1); port->txlast = next_desc(port, port->txlast, 1);
} }
......
...@@ -57,7 +57,7 @@ static int hdlc_change_mtu(struct net_device *dev, int new_mtu) ...@@ -57,7 +57,7 @@ static int hdlc_change_mtu(struct net_device *dev, int new_mtu)
static struct net_device_stats *hdlc_get_stats(struct net_device *dev) static struct net_device_stats *hdlc_get_stats(struct net_device *dev)
{ {
return hdlc_stats(dev); return &dev->stats;
} }
......
...@@ -252,8 +252,8 @@ static int cisco_rx(struct sk_buff *skb) ...@@ -252,8 +252,8 @@ static int cisco_rx(struct sk_buff *skb)
dev_kfree_skb_any(skb); dev_kfree_skb_any(skb);
return NET_RX_DROP; return NET_RX_DROP;
rx_error: rx_error:
dev_to_hdlc(dev)->stats.rx_errors++; /* Mark error */ dev->stats.rx_errors++; /* Mark error */
dev_kfree_skb_any(skb); dev_kfree_skb_any(skb);
return NET_RX_DROP; return NET_RX_DROP;
} }
......
...@@ -136,7 +136,6 @@ typedef struct pvc_device_struct { ...@@ -136,7 +136,6 @@ typedef struct pvc_device_struct {
}pvc_device; }pvc_device;
struct pvc_desc { struct pvc_desc {
struct net_device_stats stats;
pvc_device *pvc; pvc_device *pvc;
}; };
...@@ -184,11 +183,6 @@ static inline struct pvc_desc* pvcdev_to_desc(struct net_device *dev) ...@@ -184,11 +183,6 @@ static inline struct pvc_desc* pvcdev_to_desc(struct net_device *dev)
return dev->priv; return dev->priv;
} }
static inline struct net_device_stats* pvc_get_stats(struct net_device *dev)
{
return &pvcdev_to_desc(dev)->stats;
}
static inline pvc_device* find_pvc(hdlc_device *hdlc, u16 dlci) static inline pvc_device* find_pvc(hdlc_device *hdlc, u16 dlci)
{ {
pvc_device *pvc = state(hdlc)->first_pvc; pvc_device *pvc = state(hdlc)->first_pvc;
...@@ -425,7 +419,6 @@ static int pvc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) ...@@ -425,7 +419,6 @@ static int pvc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
static int pvc_xmit(struct sk_buff *skb, struct net_device *dev) static int pvc_xmit(struct sk_buff *skb, struct net_device *dev)
{ {
pvc_device *pvc = pvcdev_to_desc(dev)->pvc; pvc_device *pvc = pvcdev_to_desc(dev)->pvc;
struct net_device_stats *stats = pvc_get_stats(dev);
if (pvc->state.active) { if (pvc->state.active) {
if (dev->type == ARPHRD_ETHER) { if (dev->type == ARPHRD_ETHER) {
...@@ -435,7 +428,7 @@ static int pvc_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -435,7 +428,7 @@ static int pvc_xmit(struct sk_buff *skb, struct net_device *dev)
if (skb_tailroom(skb) < pad) if (skb_tailroom(skb) < pad)
if (pskb_expand_head(skb, 0, pad, if (pskb_expand_head(skb, 0, pad,
GFP_ATOMIC)) { GFP_ATOMIC)) {
stats->tx_dropped++; dev->stats.tx_dropped++;
dev_kfree_skb(skb); dev_kfree_skb(skb);
return 0; return 0;
} }
...@@ -445,17 +438,17 @@ static int pvc_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -445,17 +438,17 @@ static int pvc_xmit(struct sk_buff *skb, struct net_device *dev)
skb->protocol = __constant_htons(ETH_P_802_3); skb->protocol = __constant_htons(ETH_P_802_3);
} }
if (!fr_hard_header(&skb, pvc->dlci)) { if (!fr_hard_header(&skb, pvc->dlci)) {
stats->tx_bytes += skb->len; dev->stats.tx_bytes += skb->len;
stats->tx_packets++; dev->stats.tx_packets++;
if (pvc->state.fecn) /* TX Congestion counter */ if (pvc->state.fecn) /* TX Congestion counter */
stats->tx_compressed++; dev->stats.tx_compressed++;
skb->dev = pvc->frad; skb->dev = pvc->frad;
dev_queue_xmit(skb); dev_queue_xmit(skb);
return 0; return 0;
} }
} }
stats->tx_dropped++; dev->stats.tx_dropped++;
dev_kfree_skb(skb); dev_kfree_skb(skb);
return 0; return 0;
} }
...@@ -955,7 +948,7 @@ static int fr_rx(struct sk_buff *skb) ...@@ -955,7 +948,7 @@ static int fr_rx(struct sk_buff *skb)
if ((skb = skb_share_check(skb, GFP_ATOMIC)) == NULL) { if ((skb = skb_share_check(skb, GFP_ATOMIC)) == NULL) {
dev_to_hdlc(frad)->stats.rx_dropped++; frad->stats.rx_dropped++;
return NET_RX_DROP; return NET_RX_DROP;
} }
...@@ -1003,11 +996,10 @@ static int fr_rx(struct sk_buff *skb) ...@@ -1003,11 +996,10 @@ static int fr_rx(struct sk_buff *skb)
} }
if (dev) { if (dev) {
struct net_device_stats *stats = pvc_get_stats(dev); dev->stats.rx_packets++; /* PVC traffic */
stats->rx_packets++; /* PVC traffic */ dev->stats.rx_bytes += skb->len;
stats->rx_bytes += skb->len;
if (pvc->state.becn) if (pvc->state.becn)
stats->rx_compressed++; dev->stats.rx_compressed++;
netif_rx(skb); netif_rx(skb);
return NET_RX_SUCCESS; return NET_RX_SUCCESS;
} else { } else {
...@@ -1016,7 +1008,7 @@ static int fr_rx(struct sk_buff *skb) ...@@ -1016,7 +1008,7 @@ static int fr_rx(struct sk_buff *skb)
} }
rx_error: rx_error:
dev_to_hdlc(frad)->stats.rx_errors++; /* Mark error */ frad->stats.rx_errors++; /* Mark error */
dev_kfree_skb_any(skb); dev_kfree_skb_any(skb);
return NET_RX_DROP; return NET_RX_DROP;
} }
...@@ -1122,7 +1114,6 @@ static int fr_add_pvc(struct net_device *frad, unsigned int dlci, int type) ...@@ -1122,7 +1114,6 @@ static int fr_add_pvc(struct net_device *frad, unsigned int dlci, int type)
dlci_to_q922(dev->broadcast, dlci); dlci_to_q922(dev->broadcast, dlci);
} }
dev->hard_start_xmit = pvc_xmit; dev->hard_start_xmit = pvc_xmit;
dev->get_stats = pvc_get_stats;
dev->open = pvc_open; dev->open = pvc_open;
dev->stop = pvc_close; dev->stop = pvc_close;
dev->do_ioctl = pvc_ioctl; dev->do_ioctl = pvc_ioctl;
......
...@@ -33,7 +33,7 @@ static int eth_tx(struct sk_buff *skb, struct net_device *dev) ...@@ -33,7 +33,7 @@ static int eth_tx(struct sk_buff *skb, struct net_device *dev)
int len = skb->len; int len = skb->len;
if (skb_tailroom(skb) < pad) if (skb_tailroom(skb) < pad)
if (pskb_expand_head(skb, 0, pad, GFP_ATOMIC)) { if (pskb_expand_head(skb, 0, pad, GFP_ATOMIC)) {
hdlc_stats(dev)->tx_dropped++; dev->stats.tx_dropped++;
dev_kfree_skb(skb); dev_kfree_skb(skb);
return 0; return 0;
} }
......
...@@ -164,17 +164,15 @@ static void x25_close(struct net_device *dev) ...@@ -164,17 +164,15 @@ static void x25_close(struct net_device *dev)
static int x25_rx(struct sk_buff *skb) static int x25_rx(struct sk_buff *skb)
{ {
struct hdlc_device *hdlc = dev_to_hdlc(skb->dev);
if ((skb = skb_share_check(skb, GFP_ATOMIC)) == NULL) { if ((skb = skb_share_check(skb, GFP_ATOMIC)) == NULL) {
hdlc->stats.rx_dropped++; skb->dev->stats.rx_dropped++;
return NET_RX_DROP; return NET_RX_DROP;
} }
if (lapb_data_received(skb->dev, skb) == LAPB_OK) if (lapb_data_received(skb->dev, skb) == LAPB_OK)
return NET_RX_SUCCESS; return NET_RX_SUCCESS;
hdlc->stats.rx_errors++; skb->dev->stats.rx_errors++;
dev_kfree_skb_any(skb); dev_kfree_skb_any(skb);
return NET_RX_DROP; return NET_RX_DROP;
} }
......
...@@ -285,7 +285,6 @@ static void rx_dma_buf_init(pc300_t *, int); ...@@ -285,7 +285,6 @@ static void rx_dma_buf_init(pc300_t *, int);
static void tx_dma_buf_check(pc300_t *, int); static void tx_dma_buf_check(pc300_t *, int);
static void rx_dma_buf_check(pc300_t *, int); static void rx_dma_buf_check(pc300_t *, int);
static irqreturn_t cpc_intr(int, void *); static irqreturn_t cpc_intr(int, void *);
static struct net_device_stats *cpc_get_stats(struct net_device *);
static int clock_rate_calc(uclong, uclong, int *); static int clock_rate_calc(uclong, uclong, int *);
static uclong detect_ram(pc300_t *); static uclong detect_ram(pc300_t *);
static void plx_init(pc300_t *); static void plx_init(pc300_t *);
...@@ -1775,13 +1774,12 @@ static void cpc_tx_timeout(struct net_device *dev) ...@@ -1775,13 +1774,12 @@ static void cpc_tx_timeout(struct net_device *dev)
pc300dev_t *d = (pc300dev_t *) dev->priv; pc300dev_t *d = (pc300dev_t *) dev->priv;
pc300ch_t *chan = (pc300ch_t *) d->chan; pc300ch_t *chan = (pc300ch_t *) d->chan;
pc300_t *card = (pc300_t *) chan->card; pc300_t *card = (pc300_t *) chan->card;
struct net_device_stats *stats = hdlc_stats(dev);
int ch = chan->channel; int ch = chan->channel;
unsigned long flags; unsigned long flags;
ucchar ilar; ucchar ilar;
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_aborted_errors++; dev->stats.tx_aborted_errors++;
CPC_LOCK(card, flags); CPC_LOCK(card, flags);
if ((ilar = cpc_readb(card->hw.scabase + ILAR)) != 0) { if ((ilar = cpc_readb(card->hw.scabase + ILAR)) != 0) {
printk("%s: ILAR=0x%x\n", dev->name, ilar); printk("%s: ILAR=0x%x\n", dev->name, ilar);
...@@ -1803,7 +1801,6 @@ static int cpc_queue_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -1803,7 +1801,6 @@ static int cpc_queue_xmit(struct sk_buff *skb, struct net_device *dev)
pc300dev_t *d = (pc300dev_t *) dev->priv; pc300dev_t *d = (pc300dev_t *) dev->priv;
pc300ch_t *chan = (pc300ch_t *) d->chan; pc300ch_t *chan = (pc300ch_t *) d->chan;
pc300_t *card = (pc300_t *) chan->card; pc300_t *card = (pc300_t *) chan->card;
struct net_device_stats *stats = hdlc_stats(dev);
int ch = chan->channel; int ch = chan->channel;
unsigned long flags; unsigned long flags;
#ifdef PC300_DEBUG_TX #ifdef PC300_DEBUG_TX
...@@ -1817,13 +1814,13 @@ static int cpc_queue_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -1817,13 +1814,13 @@ static int cpc_queue_xmit(struct sk_buff *skb, struct net_device *dev)
} else if (!netif_carrier_ok(dev)) { } else if (!netif_carrier_ok(dev)) {
/* DCD must be OFF: drop packet */ /* DCD must be OFF: drop packet */
dev_kfree_skb(skb); dev_kfree_skb(skb);
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_carrier_errors++; dev->stats.tx_carrier_errors++;
return 0; return 0;
} else if (cpc_readb(card->hw.scabase + M_REG(ST3, ch)) & ST3_DCD) { } else if (cpc_readb(card->hw.scabase + M_REG(ST3, ch)) & ST3_DCD) {
printk("%s: DCD is OFF. Going administrative down.\n", dev->name); printk("%s: DCD is OFF. Going administrative down.\n", dev->name);
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_carrier_errors++; dev->stats.tx_carrier_errors++;
dev_kfree_skb(skb); dev_kfree_skb(skb);
netif_carrier_off(dev); netif_carrier_off(dev);
CPC_LOCK(card, flags); CPC_LOCK(card, flags);
...@@ -1843,8 +1840,8 @@ static int cpc_queue_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -1843,8 +1840,8 @@ static int cpc_queue_xmit(struct sk_buff *skb, struct net_device *dev)
// printk("%s: write error. Dropping TX packet.\n", dev->name); // printk("%s: write error. Dropping TX packet.\n", dev->name);
netif_stop_queue(dev); netif_stop_queue(dev);
dev_kfree_skb(skb); dev_kfree_skb(skb);
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_dropped++; dev->stats.tx_dropped++;
return 0; return 0;
} }
#ifdef PC300_DEBUG_TX #ifdef PC300_DEBUG_TX
...@@ -1886,7 +1883,6 @@ static void cpc_net_rx(struct net_device *dev) ...@@ -1886,7 +1883,6 @@ static void cpc_net_rx(struct net_device *dev)
pc300dev_t *d = (pc300dev_t *) dev->priv; pc300dev_t *d = (pc300dev_t *) dev->priv;
pc300ch_t *chan = (pc300ch_t *) d->chan; pc300ch_t *chan = (pc300ch_t *) d->chan;
pc300_t *card = (pc300_t *) chan->card; pc300_t *card = (pc300_t *) chan->card;
struct net_device_stats *stats = hdlc_stats(dev);
int ch = chan->channel; int ch = chan->channel;
#ifdef PC300_DEBUG_RX #ifdef PC300_DEBUG_RX
int i; int i;
...@@ -1922,24 +1918,24 @@ static void cpc_net_rx(struct net_device *dev) ...@@ -1922,24 +1918,24 @@ static void cpc_net_rx(struct net_device *dev)
#endif #endif
if ((skb == NULL) && (rxb > 0)) { if ((skb == NULL) && (rxb > 0)) {
/* rxb > dev->mtu */ /* rxb > dev->mtu */
stats->rx_errors++; dev->stats.rx_errors++;
stats->rx_length_errors++; dev->stats.rx_length_errors++;
continue; continue;
} }
if (rxb < 0) { /* Invalid frame */ if (rxb < 0) { /* Invalid frame */
rxb = -rxb; rxb = -rxb;
if (rxb & DST_OVR) { if (rxb & DST_OVR) {
stats->rx_errors++; dev->stats.rx_errors++;
stats->rx_fifo_errors++; dev->stats.rx_fifo_errors++;
} }
if (rxb & DST_CRC) { if (rxb & DST_CRC) {
stats->rx_errors++; dev->stats.rx_errors++;
stats->rx_crc_errors++; dev->stats.rx_crc_errors++;
} }
if (rxb & (DST_RBIT | DST_SHRT | DST_ABT)) { if (rxb & (DST_RBIT | DST_SHRT | DST_ABT)) {
stats->rx_errors++; dev->stats.rx_errors++;
stats->rx_frame_errors++; dev->stats.rx_frame_errors++;
} }
} }
if (skb) { if (skb) {
...@@ -1948,7 +1944,7 @@ static void cpc_net_rx(struct net_device *dev) ...@@ -1948,7 +1944,7 @@ static void cpc_net_rx(struct net_device *dev)
continue; continue;
} }
stats->rx_bytes += rxb; dev->stats.rx_bytes += rxb;
#ifdef PC300_DEBUG_RX #ifdef PC300_DEBUG_RX
printk("%s R:", dev->name); printk("%s R:", dev->name);
...@@ -1959,7 +1955,7 @@ static void cpc_net_rx(struct net_device *dev) ...@@ -1959,7 +1955,7 @@ static void cpc_net_rx(struct net_device *dev)
if (d->trace_on) { if (d->trace_on) {
cpc_trace(dev, skb, 'R'); cpc_trace(dev, skb, 'R');
} }
stats->rx_packets++; dev->stats.rx_packets++;
skb->protocol = hdlc_type_trans(skb, dev); skb->protocol = hdlc_type_trans(skb, dev);
netif_rx(skb); netif_rx(skb);
} }
...@@ -1974,16 +1970,15 @@ static void sca_tx_intr(pc300dev_t *dev) ...@@ -1974,16 +1970,15 @@ static void sca_tx_intr(pc300dev_t *dev)
pc300_t *card = (pc300_t *)chan->card; pc300_t *card = (pc300_t *)chan->card;
int ch = chan->channel; int ch = chan->channel;
volatile pcsca_bd_t __iomem * ptdescr; volatile pcsca_bd_t __iomem * ptdescr;
struct net_device_stats *stats = hdlc_stats(dev->dev);
/* Clean up descriptors from previous transmission */ /* Clean up descriptors from previous transmission */
ptdescr = (card->hw.rambase + ptdescr = (card->hw.rambase +
TX_BD_ADDR(ch,chan->tx_first_bd)); TX_BD_ADDR(ch,chan->tx_first_bd));
while ((cpc_readl(card->hw.scabase + DTX_REG(CDAL,ch)) != while ((cpc_readl(card->hw.scabase + DTX_REG(CDAL,ch)) !=
TX_BD_ADDR(ch,chan->tx_first_bd)) && TX_BD_ADDR(ch,chan->tx_first_bd)) &&
(cpc_readb(&ptdescr->status) & DST_OSB)) { (cpc_readb(&ptdescr->status) & DST_OSB)) {
stats->tx_packets++; dev->dev->stats.tx_packets++;
stats->tx_bytes += cpc_readw(&ptdescr->len); dev->dev->stats.tx_bytes += cpc_readw(&ptdescr->len);
cpc_writeb(&ptdescr->status, DST_OSB); cpc_writeb(&ptdescr->status, DST_OSB);
cpc_writew(&ptdescr->len, 0); cpc_writew(&ptdescr->len, 0);
chan->nfree_tx_bd++; chan->nfree_tx_bd++;
...@@ -2048,8 +2043,8 @@ static void sca_intr(pc300_t * card) ...@@ -2048,8 +2043,8 @@ static void sca_intr(pc300_t * card)
} }
cpc_net_rx(dev); cpc_net_rx(dev);
/* Discard invalid frames */ /* Discard invalid frames */
hdlc_stats(dev)->rx_errors++; dev->stats.rx_errors++;
hdlc_stats(dev)->rx_over_errors++; dev->stats.rx_over_errors++;
chan->rx_first_bd = 0; chan->rx_first_bd = 0;
chan->rx_last_bd = N_DMA_RX_BUF - 1; chan->rx_last_bd = N_DMA_RX_BUF - 1;
rx_dma_start(card, ch); rx_dma_start(card, ch);
...@@ -2115,8 +2110,8 @@ static void sca_intr(pc300_t * card) ...@@ -2115,8 +2110,8 @@ static void sca_intr(pc300_t * card)
card->hw.cpld_reg2) & card->hw.cpld_reg2) &
~ (CPLD_REG2_FALC_LED1 << (2 * ch))); ~ (CPLD_REG2_FALC_LED1 << (2 * ch)));
} }
hdlc_stats(dev)->tx_errors++; dev->stats.tx_errors++;
hdlc_stats(dev)->tx_fifo_errors++; dev->stats.tx_fifo_errors++;
sca_tx_intr(d); sca_tx_intr(d);
} }
} }
...@@ -2604,7 +2599,7 @@ static int cpc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) ...@@ -2604,7 +2599,7 @@ static int cpc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
case SIOCGPC300UTILSTATS: case SIOCGPC300UTILSTATS:
{ {
if (!arg) { /* clear statistics */ if (!arg) { /* clear statistics */
memset(hdlc_stats(dev), 0, sizeof(struct net_device_stats)); memset(&dev->stats, 0, sizeof(dev->stats));
if (card->hw.type == PC300_TE) { if (card->hw.type == PC300_TE) {
memset(&chan->falc, 0, sizeof(falc_t)); memset(&chan->falc, 0, sizeof(falc_t));
} }
...@@ -2615,8 +2610,8 @@ static int cpc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) ...@@ -2615,8 +2610,8 @@ static int cpc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
pc300stats.hw_type = card->hw.type; pc300stats.hw_type = card->hw.type;
pc300stats.line_on = card->chan[ch].d.line_on; pc300stats.line_on = card->chan[ch].d.line_on;
pc300stats.line_off = card->chan[ch].d.line_off; pc300stats.line_off = card->chan[ch].d.line_off;
memcpy(&pc300stats.gen_stats, hdlc_stats(dev), memcpy(&pc300stats.gen_stats, &dev->stats,
sizeof(struct net_device_stats)); sizeof(dev->stats));
if (card->hw.type == PC300_TE) if (card->hw.type == PC300_TE)
memcpy(&pc300stats.te_stats,&chan->falc,sizeof(falc_t)); memcpy(&pc300stats.te_stats,&chan->falc,sizeof(falc_t));
if (copy_to_user(arg, &pc300stats, sizeof(pc300stats_t))) if (copy_to_user(arg, &pc300stats, sizeof(pc300stats_t)))
...@@ -2823,11 +2818,6 @@ static int cpc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) ...@@ -2823,11 +2818,6 @@ static int cpc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
} }
} }
static struct net_device_stats *cpc_get_stats(struct net_device *dev)
{
return hdlc_stats(dev);
}
static int clock_rate_calc(uclong rate, uclong clock, int *br_io) static int clock_rate_calc(uclong rate, uclong clock, int *br_io)
{ {
int br, tc; int br, tc;
...@@ -3394,7 +3384,6 @@ static void cpc_init_card(pc300_t * card) ...@@ -3394,7 +3384,6 @@ static void cpc_init_card(pc300_t * card)
dev->stop = cpc_close; dev->stop = cpc_close;
dev->tx_timeout = cpc_tx_timeout; dev->tx_timeout = cpc_tx_timeout;
dev->watchdog_timeo = PC300_TX_TIMEOUT; dev->watchdog_timeo = PC300_TX_TIMEOUT;
dev->get_stats = cpc_get_stats;
dev->set_multicast_list = NULL; dev->set_multicast_list = NULL;
dev->set_mac_address = NULL; dev->set_mac_address = NULL;
dev->change_mtu = cpc_change_mtu; dev->change_mtu = cpc_change_mtu;
......
...@@ -458,7 +458,7 @@ static int cpc_tty_write(struct tty_struct *tty, const unsigned char *buf, int c ...@@ -458,7 +458,7 @@ static int cpc_tty_write(struct tty_struct *tty, const unsigned char *buf, int c
CPC_TTY_DBG("%s: cpc_tty_write data len=%i\n",cpc_tty->name,count); CPC_TTY_DBG("%s: cpc_tty_write data len=%i\n",cpc_tty->name,count);
pc300chan = (pc300ch_t *)((pc300dev_t*)cpc_tty->pc300dev)->chan; pc300chan = (pc300ch_t *)((pc300dev_t*)cpc_tty->pc300dev)->chan;
stats = hdlc_stats(((pc300dev_t*)cpc_tty->pc300dev)->dev); stats = &cpc_tty->pc300dev->dev->stats;
card = (pc300_t *) pc300chan->card; card = (pc300_t *) pc300chan->card;
ch = pc300chan->channel; ch = pc300chan->channel;
...@@ -743,7 +743,7 @@ void cpc_tty_receive(pc300dev_t *pc300dev) ...@@ -743,7 +743,7 @@ void cpc_tty_receive(pc300dev_t *pc300dev)
pc300_t *card = (pc300_t *)pc300chan->card; pc300_t *card = (pc300_t *)pc300chan->card;
int ch = pc300chan->channel; int ch = pc300chan->channel;
volatile pcsca_bd_t __iomem * ptdescr; volatile pcsca_bd_t __iomem * ptdescr;
struct net_device_stats *stats = hdlc_stats(pc300dev->dev); struct net_device_stats *stats = &pc300dev->dev->stats;
int rx_len, rx_aux; int rx_len, rx_aux;
volatile unsigned char status; volatile unsigned char status;
unsigned short first_bd = pc300chan->rx_first_bd; unsigned short first_bd = pc300chan->rx_first_bd;
...@@ -917,7 +917,7 @@ static int cpc_tty_send_to_card(pc300dev_t *dev,void* buf, int len) ...@@ -917,7 +917,7 @@ static int cpc_tty_send_to_card(pc300dev_t *dev,void* buf, int len)
pc300ch_t *chan = (pc300ch_t *)dev->chan; pc300ch_t *chan = (pc300ch_t *)dev->chan;
pc300_t *card = (pc300_t *)chan->card; pc300_t *card = (pc300_t *)chan->card;
int ch = chan->channel; int ch = chan->channel;
struct net_device_stats *stats = hdlc_stats(dev->dev); struct net_device_stats *stats = &dev->dev->stats;
unsigned long flags; unsigned long flags;
volatile pcsca_bd_t __iomem *ptdescr; volatile pcsca_bd_t __iomem *ptdescr;
int i, nchar; int i, nchar;
......
...@@ -161,7 +161,6 @@ static inline void wanxl_cable_intr(port_t *port) ...@@ -161,7 +161,6 @@ static inline void wanxl_cable_intr(port_t *port)
static inline void wanxl_tx_intr(port_t *port) static inline void wanxl_tx_intr(port_t *port)
{ {
struct net_device *dev = port->dev; struct net_device *dev = port->dev;
struct net_device_stats *stats = hdlc_stats(dev);
while (1) { while (1) {
desc_t *desc = &get_status(port)->tx_descs[port->tx_in]; desc_t *desc = &get_status(port)->tx_descs[port->tx_in];
struct sk_buff *skb = port->tx_skbs[port->tx_in]; struct sk_buff *skb = port->tx_skbs[port->tx_in];
...@@ -173,13 +172,13 @@ static inline void wanxl_tx_intr(port_t *port) ...@@ -173,13 +172,13 @@ static inline void wanxl_tx_intr(port_t *port)
return; return;
case PACKET_UNDERRUN: case PACKET_UNDERRUN:
stats->tx_errors++; dev->stats.tx_errors++;
stats->tx_fifo_errors++; dev->stats.tx_fifo_errors++;
break; break;
default: default:
stats->tx_packets++; dev->stats.tx_packets++;
stats->tx_bytes += skb->len; dev->stats.tx_bytes += skb->len;
} }
desc->stat = PACKET_EMPTY; /* Free descriptor */ desc->stat = PACKET_EMPTY; /* Free descriptor */
pci_unmap_single(port->card->pdev, desc->address, skb->len, pci_unmap_single(port->card->pdev, desc->address, skb->len,
...@@ -205,10 +204,9 @@ static inline void wanxl_rx_intr(card_t *card) ...@@ -205,10 +204,9 @@ static inline void wanxl_rx_intr(card_t *card)
port_t *port = &card->ports[desc->stat & port_t *port = &card->ports[desc->stat &
PACKET_PORT_MASK]; PACKET_PORT_MASK];
struct net_device *dev = port->dev; struct net_device *dev = port->dev;
struct net_device_stats *stats = hdlc_stats(dev);
if (!skb) if (!skb)
stats->rx_dropped++; dev->stats.rx_dropped++;
else { else {
pci_unmap_single(card->pdev, desc->address, pci_unmap_single(card->pdev, desc->address,
BUFFER_LENGTH, BUFFER_LENGTH,
...@@ -220,8 +218,8 @@ static inline void wanxl_rx_intr(card_t *card) ...@@ -220,8 +218,8 @@ static inline void wanxl_rx_intr(card_t *card)
skb->len); skb->len);
debug_frame(skb); debug_frame(skb);
#endif #endif
stats->rx_packets++; dev->stats.rx_packets++;
stats->rx_bytes += skb->len; dev->stats.rx_bytes += skb->len;
dev->last_rx = jiffies; dev->last_rx = jiffies;
skb->protocol = hdlc_type_trans(skb, dev); skb->protocol = hdlc_type_trans(skb, dev);
netif_rx(skb); netif_rx(skb);
...@@ -468,13 +466,13 @@ static int wanxl_close(struct net_device *dev) ...@@ -468,13 +466,13 @@ static int wanxl_close(struct net_device *dev)
static struct net_device_stats *wanxl_get_stats(struct net_device *dev) static struct net_device_stats *wanxl_get_stats(struct net_device *dev)
{ {
struct net_device_stats *stats = hdlc_stats(dev);
port_t *port = dev_to_port(dev); port_t *port = dev_to_port(dev);
stats->rx_over_errors = get_status(port)->rx_overruns; dev->stats.rx_over_errors = get_status(port)->rx_overruns;
stats->rx_frame_errors = get_status(port)->rx_frame_errors; dev->stats.rx_frame_errors = get_status(port)->rx_frame_errors;
stats->rx_errors = stats->rx_over_errors + stats->rx_frame_errors; dev->stats.rx_errors = dev->stats.rx_over_errors +
return stats; dev->stats.rx_frame_errors;
return &dev->stats;
} }
......
...@@ -45,7 +45,6 @@ struct hdlc_proto { ...@@ -45,7 +45,6 @@ struct hdlc_proto {
/* Pointed to by dev->priv */ /* Pointed to by dev->priv */
typedef struct hdlc_device { typedef struct hdlc_device {
struct net_device_stats stats;
/* used by HDLC layer to take control over HDLC device from hw driver*/ /* used by HDLC layer to take control over HDLC device from hw driver*/
int (*attach)(struct net_device *dev, int (*attach)(struct net_device *dev,
unsigned short encoding, unsigned short parity); unsigned short encoding, unsigned short parity);
...@@ -109,12 +108,6 @@ int attach_hdlc_protocol(struct net_device *dev, struct hdlc_proto *proto, ...@@ -109,12 +108,6 @@ int attach_hdlc_protocol(struct net_device *dev, struct hdlc_proto *proto,
/* May be used by hardware driver to gain control over HDLC device */ /* May be used by hardware driver to gain control over HDLC device */
void detach_hdlc_protocol(struct net_device *dev); void detach_hdlc_protocol(struct net_device *dev);
static __inline__ struct net_device_stats *hdlc_stats(struct net_device *dev)
{
return &dev_to_hdlc(dev)->stats;
}
static __inline__ __be16 hdlc_type_trans(struct sk_buff *skb, static __inline__ __be16 hdlc_type_trans(struct sk_buff *skb,
struct net_device *dev) struct net_device *dev)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment