aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/ksz884x.c46
1 files changed, 22 insertions, 24 deletions
diff --git a/drivers/net/ksz884x.c b/drivers/net/ksz884x.c
index 62362b4a8c56..b3c010b85658 100644
--- a/drivers/net/ksz884x.c
+++ b/drivers/net/ksz884x.c
@@ -1457,7 +1457,6 @@ struct dev_info {
1457 * @adapter: Adapter device information. 1457 * @adapter: Adapter device information.
1458 * @port: Port information. 1458 * @port: Port information.
1459 * @monitor_time_info: Timer to monitor ports. 1459 * @monitor_time_info: Timer to monitor ports.
1460 * @stats: Network statistics.
1461 * @proc_sem: Semaphore for proc accessing. 1460 * @proc_sem: Semaphore for proc accessing.
1462 * @id: Device ID. 1461 * @id: Device ID.
1463 * @mii_if: MII interface information. 1462 * @mii_if: MII interface information.
@@ -1471,7 +1470,6 @@ struct dev_priv {
1471 struct dev_info *adapter; 1470 struct dev_info *adapter;
1472 struct ksz_port port; 1471 struct ksz_port port;
1473 struct ksz_timer_info monitor_timer_info; 1472 struct ksz_timer_info monitor_timer_info;
1474 struct net_device_stats stats;
1475 1473
1476 struct semaphore proc_sem; 1474 struct semaphore proc_sem;
1477 int id; 1475 int id;
@@ -4751,8 +4749,8 @@ static void send_packet(struct sk_buff *skb, struct net_device *dev)
4751 hw_send_pkt(hw); 4749 hw_send_pkt(hw);
4752 4750
4753 /* Update transmit statistics. */ 4751 /* Update transmit statistics. */
4754 priv->stats.tx_packets++; 4752 dev->stats.tx_packets++;
4755 priv->stats.tx_bytes += len; 4753 dev->stats.tx_bytes += len;
4756} 4754}
4757 4755
4758/** 4756/**
@@ -5030,7 +5028,7 @@ static inline int rx_proc(struct net_device *dev, struct ksz_hw* hw,
5030 /* skb->data != skb->head */ 5028 /* skb->data != skb->head */
5031 skb = dev_alloc_skb(packet_len + 2); 5029 skb = dev_alloc_skb(packet_len + 2);
5032 if (!skb) { 5030 if (!skb) {
5033 priv->stats.rx_dropped++; 5031 dev->stats.rx_dropped++;
5034 return -ENOMEM; 5032 return -ENOMEM;
5035 } 5033 }
5036 5034
@@ -5050,8 +5048,8 @@ static inline int rx_proc(struct net_device *dev, struct ksz_hw* hw,
5050 csum_verified(skb); 5048 csum_verified(skb);
5051 5049
5052 /* Update receive statistics. */ 5050 /* Update receive statistics. */
5053 priv->stats.rx_packets++; 5051 dev->stats.rx_packets++;
5054 priv->stats.rx_bytes += packet_len; 5052 dev->stats.rx_bytes += packet_len;
5055 5053
5056 /* Notify upper layer for received packet. */ 5054 /* Notify upper layer for received packet. */
5057 rx_status = netif_rx(skb); 5055 rx_status = netif_rx(skb);
@@ -5291,7 +5289,7 @@ static irqreturn_t netdev_intr(int irq, void *dev_id)
5291 } 5289 }
5292 5290
5293 if (unlikely(int_enable & KS884X_INT_RX_OVERRUN)) { 5291 if (unlikely(int_enable & KS884X_INT_RX_OVERRUN)) {
5294 priv->stats.rx_fifo_errors++; 5292 dev->stats.rx_fifo_errors++;
5295 hw_resume_rx(hw); 5293 hw_resume_rx(hw);
5296 } 5294 }
5297 5295
@@ -5522,7 +5520,7 @@ static int netdev_open(struct net_device *dev)
5522 priv->promiscuous = 0; 5520 priv->promiscuous = 0;
5523 5521
5524 /* Reset device statistics. */ 5522 /* Reset device statistics. */
5525 memset(&priv->stats, 0, sizeof(struct net_device_stats)); 5523 memset(&dev->stats, 0, sizeof(struct net_device_stats));
5526 memset((void *) port->counter, 0, 5524 memset((void *) port->counter, 0,
5527 (sizeof(u64) * OID_COUNTER_LAST)); 5525 (sizeof(u64) * OID_COUNTER_LAST));
5528 5526
@@ -5622,42 +5620,42 @@ static struct net_device_stats *netdev_query_statistics(struct net_device *dev)
5622 int i; 5620 int i;
5623 int p; 5621 int p;
5624 5622
5625 priv->stats.rx_errors = port->counter[OID_COUNTER_RCV_ERROR]; 5623 dev->stats.rx_errors = port->counter[OID_COUNTER_RCV_ERROR];
5626 priv->stats.tx_errors = port->counter[OID_COUNTER_XMIT_ERROR]; 5624 dev->stats.tx_errors = port->counter[OID_COUNTER_XMIT_ERROR];
5627 5625
5628 /* Reset to zero to add count later. */ 5626 /* Reset to zero to add count later. */
5629 priv->stats.multicast = 0; 5627 dev->stats.multicast = 0;
5630 priv->stats.collisions = 0; 5628 dev->stats.collisions = 0;
5631 priv->stats.rx_length_errors = 0; 5629 dev->stats.rx_length_errors = 0;
5632 priv->stats.rx_crc_errors = 0; 5630 dev->stats.rx_crc_errors = 0;
5633 priv->stats.rx_frame_errors = 0; 5631 dev->stats.rx_frame_errors = 0;
5634 priv->stats.tx_window_errors = 0; 5632 dev->stats.tx_window_errors = 0;
5635 5633
5636 for (i = 0, p = port->first_port; i < port->mib_port_cnt; i++, p++) { 5634 for (i = 0, p = port->first_port; i < port->mib_port_cnt; i++, p++) {
5637 mib = &hw->port_mib[p]; 5635 mib = &hw->port_mib[p];
5638 5636
5639 priv->stats.multicast += (unsigned long) 5637 dev->stats.multicast += (unsigned long)
5640 mib->counter[MIB_COUNTER_RX_MULTICAST]; 5638 mib->counter[MIB_COUNTER_RX_MULTICAST];
5641 5639
5642 priv->stats.collisions += (unsigned long) 5640 dev->stats.collisions += (unsigned long)
5643 mib->counter[MIB_COUNTER_TX_TOTAL_COLLISION]; 5641 mib->counter[MIB_COUNTER_TX_TOTAL_COLLISION];
5644 5642
5645 priv->stats.rx_length_errors += (unsigned long)( 5643 dev->stats.rx_length_errors += (unsigned long)(
5646 mib->counter[MIB_COUNTER_RX_UNDERSIZE] + 5644 mib->counter[MIB_COUNTER_RX_UNDERSIZE] +
5647 mib->counter[MIB_COUNTER_RX_FRAGMENT] + 5645 mib->counter[MIB_COUNTER_RX_FRAGMENT] +
5648 mib->counter[MIB_COUNTER_RX_OVERSIZE] + 5646 mib->counter[MIB_COUNTER_RX_OVERSIZE] +
5649 mib->counter[MIB_COUNTER_RX_JABBER]); 5647 mib->counter[MIB_COUNTER_RX_JABBER]);
5650 priv->stats.rx_crc_errors += (unsigned long) 5648 dev->stats.rx_crc_errors += (unsigned long)
5651 mib->counter[MIB_COUNTER_RX_CRC_ERR]; 5649 mib->counter[MIB_COUNTER_RX_CRC_ERR];
5652 priv->stats.rx_frame_errors += (unsigned long)( 5650 dev->stats.rx_frame_errors += (unsigned long)(
5653 mib->counter[MIB_COUNTER_RX_ALIGNMENT_ERR] + 5651 mib->counter[MIB_COUNTER_RX_ALIGNMENT_ERR] +
5654 mib->counter[MIB_COUNTER_RX_SYMBOL_ERR]); 5652 mib->counter[MIB_COUNTER_RX_SYMBOL_ERR]);
5655 5653
5656 priv->stats.tx_window_errors += (unsigned long) 5654 dev->stats.tx_window_errors += (unsigned long)
5657 mib->counter[MIB_COUNTER_TX_LATE_COLLISION]; 5655 mib->counter[MIB_COUNTER_TX_LATE_COLLISION];
5658 } 5656 }
5659 5657
5660 return &priv->stats; 5658 return &dev->stats;
5661} 5659}
5662 5660
5663/** 5661/**