aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/fealnx.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/fealnx.c')
-rw-r--r--drivers/net/fealnx.c68
1 files changed, 36 insertions, 32 deletions
diff --git a/drivers/net/fealnx.c b/drivers/net/fealnx.c
index 15f4f8d3d46d..d7e8f6b8f4cf 100644
--- a/drivers/net/fealnx.c
+++ b/drivers/net/fealnx.c
@@ -382,8 +382,6 @@ struct netdev_private {
382 382
383 spinlock_t lock; 383 spinlock_t lock;
384 384
385 struct net_device_stats stats;
386
387 /* Media monitoring timer. */ 385 /* Media monitoring timer. */
388 struct timer_list timer; 386 struct timer_list timer;
389 387
@@ -1234,7 +1232,7 @@ static void fealnx_tx_timeout(struct net_device *dev)
1234 spin_unlock_irqrestore(&np->lock, flags); 1232 spin_unlock_irqrestore(&np->lock, flags);
1235 1233
1236 dev->trans_start = jiffies; /* prevent tx timeout */ 1234 dev->trans_start = jiffies; /* prevent tx timeout */
1237 np->stats.tx_errors++; 1235 dev->stats.tx_errors++;
1238 netif_wake_queue(dev); /* or .._start_.. ?? */ 1236 netif_wake_queue(dev); /* or .._start_.. ?? */
1239} 1237}
1240 1238
@@ -1479,10 +1477,11 @@ static irqreturn_t intr_handler(int irq, void *dev_instance)
1479 1477
1480 if (intr_status & CNTOVF) { 1478 if (intr_status & CNTOVF) {
1481 /* missed pkts */ 1479 /* missed pkts */
1482 np->stats.rx_missed_errors += ioread32(ioaddr + TALLY) & 0x7fff; 1480 dev->stats.rx_missed_errors +=
1481 ioread32(ioaddr + TALLY) & 0x7fff;
1483 1482
1484 /* crc error */ 1483 /* crc error */
1485 np->stats.rx_crc_errors += 1484 dev->stats.rx_crc_errors +=
1486 (ioread32(ioaddr + TALLY) & 0x7fff0000) >> 16; 1485 (ioread32(ioaddr + TALLY) & 0x7fff0000) >> 16;
1487 } 1486 }
1488 1487
@@ -1513,30 +1512,30 @@ static irqreturn_t intr_handler(int irq, void *dev_instance)
1513 1512
1514 if (!(np->crvalue & CR_W_ENH)) { 1513 if (!(np->crvalue & CR_W_ENH)) {
1515 if (tx_status & (CSL | LC | EC | UDF | HF)) { 1514 if (tx_status & (CSL | LC | EC | UDF | HF)) {
1516 np->stats.tx_errors++; 1515 dev->stats.tx_errors++;
1517 if (tx_status & EC) 1516 if (tx_status & EC)
1518 np->stats.tx_aborted_errors++; 1517 dev->stats.tx_aborted_errors++;
1519 if (tx_status & CSL) 1518 if (tx_status & CSL)
1520 np->stats.tx_carrier_errors++; 1519 dev->stats.tx_carrier_errors++;
1521 if (tx_status & LC) 1520 if (tx_status & LC)
1522 np->stats.tx_window_errors++; 1521 dev->stats.tx_window_errors++;
1523 if (tx_status & UDF) 1522 if (tx_status & UDF)
1524 np->stats.tx_fifo_errors++; 1523 dev->stats.tx_fifo_errors++;
1525 if ((tx_status & HF) && np->mii.full_duplex == 0) 1524 if ((tx_status & HF) && np->mii.full_duplex == 0)
1526 np->stats.tx_heartbeat_errors++; 1525 dev->stats.tx_heartbeat_errors++;
1527 1526
1528 } else { 1527 } else {
1529 np->stats.tx_bytes += 1528 dev->stats.tx_bytes +=
1530 ((tx_control & PKTSMask) >> PKTSShift); 1529 ((tx_control & PKTSMask) >> PKTSShift);
1531 1530
1532 np->stats.collisions += 1531 dev->stats.collisions +=
1533 ((tx_status & NCRMask) >> NCRShift); 1532 ((tx_status & NCRMask) >> NCRShift);
1534 np->stats.tx_packets++; 1533 dev->stats.tx_packets++;
1535 } 1534 }
1536 } else { 1535 } else {
1537 np->stats.tx_bytes += 1536 dev->stats.tx_bytes +=
1538 ((tx_control & PKTSMask) >> PKTSShift); 1537 ((tx_control & PKTSMask) >> PKTSShift);
1539 np->stats.tx_packets++; 1538 dev->stats.tx_packets++;
1540 } 1539 }
1541 1540
1542 /* Free the original skb. */ 1541 /* Free the original skb. */
@@ -1564,10 +1563,12 @@ static irqreturn_t intr_handler(int irq, void *dev_instance)
1564 long data; 1563 long data;
1565 1564
1566 data = ioread32(ioaddr + TSR); 1565 data = ioread32(ioaddr + TSR);
1567 np->stats.tx_errors += (data & 0xff000000) >> 24; 1566 dev->stats.tx_errors += (data & 0xff000000) >> 24;
1568 np->stats.tx_aborted_errors += (data & 0xff000000) >> 24; 1567 dev->stats.tx_aborted_errors +=
1569 np->stats.tx_window_errors += (data & 0x00ff0000) >> 16; 1568 (data & 0xff000000) >> 24;
1570 np->stats.collisions += (data & 0x0000ffff); 1569 dev->stats.tx_window_errors +=
1570 (data & 0x00ff0000) >> 16;
1571 dev->stats.collisions += (data & 0x0000ffff);
1571 } 1572 }
1572 1573
1573 if (--boguscnt < 0) { 1574 if (--boguscnt < 0) {
@@ -1593,10 +1594,11 @@ static irqreturn_t intr_handler(int irq, void *dev_instance)
1593 1594
1594 /* read the tally counters */ 1595 /* read the tally counters */
1595 /* missed pkts */ 1596 /* missed pkts */
1596 np->stats.rx_missed_errors += ioread32(ioaddr + TALLY) & 0x7fff; 1597 dev->stats.rx_missed_errors += ioread32(ioaddr + TALLY) & 0x7fff;
1597 1598
1598 /* crc error */ 1599 /* crc error */
1599 np->stats.rx_crc_errors += (ioread32(ioaddr + TALLY) & 0x7fff0000) >> 16; 1600 dev->stats.rx_crc_errors +=
1601 (ioread32(ioaddr + TALLY) & 0x7fff0000) >> 16;
1600 1602
1601 if (debug) 1603 if (debug)
1602 printk(KERN_DEBUG "%s: exiting interrupt, status=%#4.4x.\n", 1604 printk(KERN_DEBUG "%s: exiting interrupt, status=%#4.4x.\n",
@@ -1635,13 +1637,13 @@ static int netdev_rx(struct net_device *dev)
1635 "%s: Receive error, Rx status %8.8x.\n", 1637 "%s: Receive error, Rx status %8.8x.\n",
1636 dev->name, rx_status); 1638 dev->name, rx_status);
1637 1639
1638 np->stats.rx_errors++; /* end of a packet. */ 1640 dev->stats.rx_errors++; /* end of a packet. */
1639 if (rx_status & (LONG | RUNT)) 1641 if (rx_status & (LONG | RUNT))
1640 np->stats.rx_length_errors++; 1642 dev->stats.rx_length_errors++;
1641 if (rx_status & RXER) 1643 if (rx_status & RXER)
1642 np->stats.rx_frame_errors++; 1644 dev->stats.rx_frame_errors++;
1643 if (rx_status & CRC) 1645 if (rx_status & CRC)
1644 np->stats.rx_crc_errors++; 1646 dev->stats.rx_crc_errors++;
1645 } else { 1647 } else {
1646 int need_to_reset = 0; 1648 int need_to_reset = 0;
1647 int desno = 0; 1649 int desno = 0;
@@ -1667,7 +1669,7 @@ static int netdev_rx(struct net_device *dev)
1667 if (need_to_reset == 0) { 1669 if (need_to_reset == 0) {
1668 int i; 1670 int i;
1669 1671
1670 np->stats.rx_length_errors++; 1672 dev->stats.rx_length_errors++;
1671 1673
1672 /* free all rx descriptors related this long pkt */ 1674 /* free all rx descriptors related this long pkt */
1673 for (i = 0; i < desno; ++i) { 1675 for (i = 0; i < desno; ++i) {
@@ -1733,8 +1735,8 @@ static int netdev_rx(struct net_device *dev)
1733 } 1735 }
1734 skb->protocol = eth_type_trans(skb, dev); 1736 skb->protocol = eth_type_trans(skb, dev);
1735 netif_rx(skb); 1737 netif_rx(skb);
1736 np->stats.rx_packets++; 1738 dev->stats.rx_packets++;
1737 np->stats.rx_bytes += pkt_len; 1739 dev->stats.rx_bytes += pkt_len;
1738 } 1740 }
1739 1741
1740 np->cur_rx = np->cur_rx->next_desc_logical; 1742 np->cur_rx = np->cur_rx->next_desc_logical;
@@ -1754,11 +1756,13 @@ static struct net_device_stats *get_stats(struct net_device *dev)
1754 1756
1755 /* The chip only need report frame silently dropped. */ 1757 /* The chip only need report frame silently dropped. */
1756 if (netif_running(dev)) { 1758 if (netif_running(dev)) {
1757 np->stats.rx_missed_errors += ioread32(ioaddr + TALLY) & 0x7fff; 1759 dev->stats.rx_missed_errors +=
1758 np->stats.rx_crc_errors += (ioread32(ioaddr + TALLY) & 0x7fff0000) >> 16; 1760 ioread32(ioaddr + TALLY) & 0x7fff;
1761 dev->stats.rx_crc_errors +=
1762 (ioread32(ioaddr + TALLY) & 0x7fff0000) >> 16;
1759 } 1763 }
1760 1764
1761 return &np->stats; 1765 return &dev->stats;
1762} 1766}
1763 1767
1764 1768