aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/mac89x0.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/mac89x0.c')
-rw-r--r--drivers/net/mac89x0.c52
1 files changed, 29 insertions, 23 deletions
diff --git a/drivers/net/mac89x0.c b/drivers/net/mac89x0.c
index 69fa4ef64dd2..669b317974a8 100644
--- a/drivers/net/mac89x0.c
+++ b/drivers/net/mac89x0.c
@@ -110,7 +110,6 @@ static unsigned int net_debug = NET_DEBUG;
110 110
111/* Information that need to be kept for each board. */ 111/* Information that need to be kept for each board. */
112struct net_local { 112struct net_local {
113 struct net_device_stats stats;
114 int chip_type; /* one of: CS8900, CS8920, CS8920M */ 113 int chip_type; /* one of: CS8900, CS8920, CS8920M */
115 char chip_revision; /* revision letter of the chip ('A'...) */ 114 char chip_revision; /* revision letter of the chip ('A'...) */
116 int send_cmd; /* the propercommand used to send a packet. */ 115 int send_cmd; /* the propercommand used to send a packet. */
@@ -444,13 +443,18 @@ static irqreturn_t net_interrupt(int irq, void *dev_id)
444 net_rx(dev); 443 net_rx(dev);
445 break; 444 break;
446 case ISQ_TRANSMITTER_EVENT: 445 case ISQ_TRANSMITTER_EVENT:
447 lp->stats.tx_packets++; 446 dev->stats.tx_packets++;
448 netif_wake_queue(dev); 447 netif_wake_queue(dev);
449 if ((status & TX_OK) == 0) lp->stats.tx_errors++; 448 if ((status & TX_OK) == 0)
450 if (status & TX_LOST_CRS) lp->stats.tx_carrier_errors++; 449 dev->stats.tx_errors++;
451 if (status & TX_SQE_ERROR) lp->stats.tx_heartbeat_errors++; 450 if (status & TX_LOST_CRS)
452 if (status & TX_LATE_COL) lp->stats.tx_window_errors++; 451 dev->stats.tx_carrier_errors++;
453 if (status & TX_16_COL) lp->stats.tx_aborted_errors++; 452 if (status & TX_SQE_ERROR)
453 dev->stats.tx_heartbeat_errors++;
454 if (status & TX_LATE_COL)
455 dev->stats.tx_window_errors++;
456 if (status & TX_16_COL)
457 dev->stats.tx_aborted_errors++;
454 break; 458 break;
455 case ISQ_BUFFER_EVENT: 459 case ISQ_BUFFER_EVENT:
456 if (status & READY_FOR_TX) { 460 if (status & READY_FOR_TX) {
@@ -469,10 +473,10 @@ static irqreturn_t net_interrupt(int irq, void *dev_id)
469 } 473 }
470 break; 474 break;
471 case ISQ_RX_MISS_EVENT: 475 case ISQ_RX_MISS_EVENT:
472 lp->stats.rx_missed_errors += (status >>6); 476 dev->stats.rx_missed_errors += (status >> 6);
473 break; 477 break;
474 case ISQ_TX_COL_EVENT: 478 case ISQ_TX_COL_EVENT:
475 lp->stats.collisions += (status >>6); 479 dev->stats.collisions += (status >> 6);
476 break; 480 break;
477 } 481 }
478 } 482 }
@@ -483,19 +487,22 @@ static irqreturn_t net_interrupt(int irq, void *dev_id)
483static void 487static void
484net_rx(struct net_device *dev) 488net_rx(struct net_device *dev)
485{ 489{
486 struct net_local *lp = netdev_priv(dev);
487 struct sk_buff *skb; 490 struct sk_buff *skb;
488 int status, length; 491 int status, length;
489 492
490 status = readreg(dev, PP_RxStatus); 493 status = readreg(dev, PP_RxStatus);
491 if ((status & RX_OK) == 0) { 494 if ((status & RX_OK) == 0) {
492 lp->stats.rx_errors++; 495 dev->stats.rx_errors++;
493 if (status & RX_RUNT) lp->stats.rx_length_errors++; 496 if (status & RX_RUNT)
494 if (status & RX_EXTRA_DATA) lp->stats.rx_length_errors++; 497 dev->stats.rx_length_errors++;
495 if (status & RX_CRC_ERROR) if (!(status & (RX_EXTRA_DATA|RX_RUNT))) 498 if (status & RX_EXTRA_DATA)
499 dev->stats.rx_length_errors++;
500 if ((status & RX_CRC_ERROR) &&
501 !(status & (RX_EXTRA_DATA|RX_RUNT)))
496 /* per str 172 */ 502 /* per str 172 */
497 lp->stats.rx_crc_errors++; 503 dev->stats.rx_crc_errors++;
498 if (status & RX_DRIBBLE) lp->stats.rx_frame_errors++; 504 if (status & RX_DRIBBLE)
505 dev->stats.rx_frame_errors++;
499 return; 506 return;
500 } 507 }
501 508
@@ -504,7 +511,7 @@ net_rx(struct net_device *dev)
504 skb = alloc_skb(length, GFP_ATOMIC); 511 skb = alloc_skb(length, GFP_ATOMIC);
505 if (skb == NULL) { 512 if (skb == NULL) {
506 printk("%s: Memory squeeze, dropping packet.\n", dev->name); 513 printk("%s: Memory squeeze, dropping packet.\n", dev->name);
507 lp->stats.rx_dropped++; 514 dev->stats.rx_dropped++;
508 return; 515 return;
509 } 516 }
510 skb_put(skb, length); 517 skb_put(skb, length);
@@ -519,8 +526,8 @@ net_rx(struct net_device *dev)
519 526
520 skb->protocol=eth_type_trans(skb,dev); 527 skb->protocol=eth_type_trans(skb,dev);
521 netif_rx(skb); 528 netif_rx(skb);
522 lp->stats.rx_packets++; 529 dev->stats.rx_packets++;
523 lp->stats.rx_bytes += length; 530 dev->stats.rx_bytes += length;
524} 531}
525 532
526/* The inverse routine to net_open(). */ 533/* The inverse routine to net_open(). */
@@ -548,16 +555,15 @@ net_close(struct net_device *dev)
548static struct net_device_stats * 555static struct net_device_stats *
549net_get_stats(struct net_device *dev) 556net_get_stats(struct net_device *dev)
550{ 557{
551 struct net_local *lp = netdev_priv(dev);
552 unsigned long flags; 558 unsigned long flags;
553 559
554 local_irq_save(flags); 560 local_irq_save(flags);
555 /* Update the statistics from the device registers. */ 561 /* Update the statistics from the device registers. */
556 lp->stats.rx_missed_errors += (readreg(dev, PP_RxMiss) >> 6); 562 dev->stats.rx_missed_errors += (readreg(dev, PP_RxMiss) >> 6);
557 lp->stats.collisions += (readreg(dev, PP_TxCol) >> 6); 563 dev->stats.collisions += (readreg(dev, PP_TxCol) >> 6);
558 local_irq_restore(flags); 564 local_irq_restore(flags);
559 565
560 return &lp->stats; 566 return &dev->stats;
561} 567}
562 568
563static void set_multicast_list(struct net_device *dev) 569static void set_multicast_list(struct net_device *dev)