diff options
-rw-r--r-- | drivers/net/ni52.c | 37 |
1 files changed, 18 insertions, 19 deletions
diff --git a/drivers/net/ni52.c b/drivers/net/ni52.c index 9bddb5fa7a96..33618edc61f9 100644 --- a/drivers/net/ni52.c +++ b/drivers/net/ni52.c | |||
@@ -185,7 +185,6 @@ static void ni52_xmt_int(struct net_device *dev); | |||
185 | static void ni52_rnr_int(struct net_device *dev); | 185 | static void ni52_rnr_int(struct net_device *dev); |
186 | 186 | ||
187 | struct priv { | 187 | struct priv { |
188 | struct net_device_stats stats; | ||
189 | char __iomem *base; | 188 | char __iomem *base; |
190 | char __iomem *mapped; | 189 | char __iomem *mapped; |
191 | char __iomem *memtop; | 190 | char __iomem *memtop; |
@@ -972,10 +971,10 @@ static void ni52_rcv_int(struct net_device *dev) | |||
972 | memcpy_fromio(skb->data, p->base + readl(&rbd->buffer), totlen); | 971 | memcpy_fromio(skb->data, p->base + readl(&rbd->buffer), totlen); |
973 | skb->protocol = eth_type_trans(skb, dev); | 972 | skb->protocol = eth_type_trans(skb, dev); |
974 | netif_rx(skb); | 973 | netif_rx(skb); |
975 | p->stats.rx_packets++; | 974 | dev->stats.rx_packets++; |
976 | p->stats.rx_bytes += totlen; | 975 | dev->stats.rx_bytes += totlen; |
977 | } else | 976 | } else |
978 | p->stats.rx_dropped++; | 977 | dev->stats.rx_dropped++; |
979 | } else { | 978 | } else { |
980 | int rstat; | 979 | int rstat; |
981 | /* free all RBD's until RBD_LAST is set */ | 980 | /* free all RBD's until RBD_LAST is set */ |
@@ -993,12 +992,12 @@ static void ni52_rcv_int(struct net_device *dev) | |||
993 | writew(0, &rbd->status); | 992 | writew(0, &rbd->status); |
994 | printk(KERN_ERR "%s: received oversized frame! length: %d\n", | 993 | printk(KERN_ERR "%s: received oversized frame! length: %d\n", |
995 | dev->name, totlen); | 994 | dev->name, totlen); |
996 | p->stats.rx_dropped++; | 995 | dev->stats.rx_dropped++; |
997 | } | 996 | } |
998 | } else {/* frame !(ok), only with 'save-bad-frames' */ | 997 | } else {/* frame !(ok), only with 'save-bad-frames' */ |
999 | printk(KERN_ERR "%s: oops! rfd-error-status: %04x\n", | 998 | printk(KERN_ERR "%s: oops! rfd-error-status: %04x\n", |
1000 | dev->name, status); | 999 | dev->name, status); |
1001 | p->stats.rx_errors++; | 1000 | dev->stats.rx_errors++; |
1002 | } | 1001 | } |
1003 | writeb(0, &p->rfd_top->stat_high); | 1002 | writeb(0, &p->rfd_top->stat_high); |
1004 | writeb(RFD_SUSP, &p->rfd_top->last); /* maybe exchange by RFD_LAST */ | 1003 | writeb(RFD_SUSP, &p->rfd_top->last); /* maybe exchange by RFD_LAST */ |
@@ -1043,7 +1042,7 @@ static void ni52_rnr_int(struct net_device *dev) | |||
1043 | { | 1042 | { |
1044 | struct priv *p = netdev_priv(dev); | 1043 | struct priv *p = netdev_priv(dev); |
1045 | 1044 | ||
1046 | p->stats.rx_errors++; | 1045 | dev->stats.rx_errors++; |
1047 | 1046 | ||
1048 | wait_for_scb_cmd(dev); /* wait for the last cmd, WAIT_4_FULLSTAT?? */ | 1047 | wait_for_scb_cmd(dev); /* wait for the last cmd, WAIT_4_FULLSTAT?? */ |
1049 | writeb(RUC_ABORT, &p->scb->cmd_ruc); /* usually the RU is in the 'no resource'-state .. abort it now. */ | 1048 | writeb(RUC_ABORT, &p->scb->cmd_ruc); /* usually the RU is in the 'no resource'-state .. abort it now. */ |
@@ -1076,29 +1075,29 @@ static void ni52_xmt_int(struct net_device *dev) | |||
1076 | printk(KERN_ERR "%s: strange .. xmit-int without a 'COMPLETE'\n", dev->name); | 1075 | printk(KERN_ERR "%s: strange .. xmit-int without a 'COMPLETE'\n", dev->name); |
1077 | 1076 | ||
1078 | if (status & STAT_OK) { | 1077 | if (status & STAT_OK) { |
1079 | p->stats.tx_packets++; | 1078 | dev->stats.tx_packets++; |
1080 | p->stats.collisions += (status & TCMD_MAXCOLLMASK); | 1079 | dev->stats.collisions += (status & TCMD_MAXCOLLMASK); |
1081 | } else { | 1080 | } else { |
1082 | p->stats.tx_errors++; | 1081 | dev->stats.tx_errors++; |
1083 | if (status & TCMD_LATECOLL) { | 1082 | if (status & TCMD_LATECOLL) { |
1084 | printk(KERN_ERR "%s: late collision detected.\n", | 1083 | printk(KERN_ERR "%s: late collision detected.\n", |
1085 | dev->name); | 1084 | dev->name); |
1086 | p->stats.collisions++; | 1085 | dev->stats.collisions++; |
1087 | } else if (status & TCMD_NOCARRIER) { | 1086 | } else if (status & TCMD_NOCARRIER) { |
1088 | p->stats.tx_carrier_errors++; | 1087 | dev->stats.tx_carrier_errors++; |
1089 | printk(KERN_ERR "%s: no carrier detected.\n", | 1088 | printk(KERN_ERR "%s: no carrier detected.\n", |
1090 | dev->name); | 1089 | dev->name); |
1091 | } else if (status & TCMD_LOSTCTS) | 1090 | } else if (status & TCMD_LOSTCTS) |
1092 | printk(KERN_ERR "%s: loss of CTS detected.\n", | 1091 | printk(KERN_ERR "%s: loss of CTS detected.\n", |
1093 | dev->name); | 1092 | dev->name); |
1094 | else if (status & TCMD_UNDERRUN) { | 1093 | else if (status & TCMD_UNDERRUN) { |
1095 | p->stats.tx_fifo_errors++; | 1094 | dev->stats.tx_fifo_errors++; |
1096 | printk(KERN_ERR "%s: DMA underrun detected.\n", | 1095 | printk(KERN_ERR "%s: DMA underrun detected.\n", |
1097 | dev->name); | 1096 | dev->name); |
1098 | } else if (status & TCMD_MAXCOLL) { | 1097 | } else if (status & TCMD_MAXCOLL) { |
1099 | printk(KERN_ERR "%s: Max. collisions exceeded.\n", | 1098 | printk(KERN_ERR "%s: Max. collisions exceeded.\n", |
1100 | dev->name); | 1099 | dev->name); |
1101 | p->stats.collisions += 16; | 1100 | dev->stats.collisions += 16; |
1102 | } | 1101 | } |
1103 | } | 1102 | } |
1104 | #if (NUM_XMIT_BUFFS > 1) | 1103 | #if (NUM_XMIT_BUFFS > 1) |
@@ -1286,12 +1285,12 @@ static struct net_device_stats *ni52_get_stats(struct net_device *dev) | |||
1286 | ovrn = readw(&p->scb->ovrn_errs); | 1285 | ovrn = readw(&p->scb->ovrn_errs); |
1287 | writew(0, &p->scb->ovrn_errs); | 1286 | writew(0, &p->scb->ovrn_errs); |
1288 | 1287 | ||
1289 | p->stats.rx_crc_errors += crc; | 1288 | dev->stats.rx_crc_errors += crc; |
1290 | p->stats.rx_fifo_errors += ovrn; | 1289 | dev->stats.rx_fifo_errors += ovrn; |
1291 | p->stats.rx_frame_errors += aln; | 1290 | dev->stats.rx_frame_errors += aln; |
1292 | p->stats.rx_dropped += rsc; | 1291 | dev->stats.rx_dropped += rsc; |
1293 | 1292 | ||
1294 | return &p->stats; | 1293 | return &dev->stats; |
1295 | } | 1294 | } |
1296 | 1295 | ||
1297 | /******************************************************** | 1296 | /******************************************************** |