diff options
Diffstat (limited to 'drivers/net/lance.c')
-rw-r--r-- | drivers/net/lance.c | 56 |
1 files changed, 32 insertions, 24 deletions
diff --git a/drivers/net/lance.c b/drivers/net/lance.c index 21f8adaa87c1..f06296bfe293 100644 --- a/drivers/net/lance.c +++ b/drivers/net/lance.c | |||
@@ -248,7 +248,6 @@ struct lance_private { | |||
248 | int cur_rx, cur_tx; /* The next free ring entry */ | 248 | int cur_rx, cur_tx; /* The next free ring entry */ |
249 | int dirty_rx, dirty_tx; /* The ring entries to be free()ed. */ | 249 | int dirty_rx, dirty_tx; /* The ring entries to be free()ed. */ |
250 | int dma; | 250 | int dma; |
251 | struct net_device_stats stats; | ||
252 | unsigned char chip_version; /* See lance_chip_type. */ | 251 | unsigned char chip_version; /* See lance_chip_type. */ |
253 | spinlock_t devlock; | 252 | spinlock_t devlock; |
254 | }; | 253 | }; |
@@ -925,7 +924,7 @@ static void lance_tx_timeout (struct net_device *dev) | |||
925 | printk ("%s: transmit timed out, status %4.4x, resetting.\n", | 924 | printk ("%s: transmit timed out, status %4.4x, resetting.\n", |
926 | dev->name, inw (ioaddr + LANCE_DATA)); | 925 | dev->name, inw (ioaddr + LANCE_DATA)); |
927 | outw (0x0004, ioaddr + LANCE_DATA); | 926 | outw (0x0004, ioaddr + LANCE_DATA); |
928 | lp->stats.tx_errors++; | 927 | dev->stats.tx_errors++; |
929 | #ifndef final_version | 928 | #ifndef final_version |
930 | if (lance_debug > 3) { | 929 | if (lance_debug > 3) { |
931 | int i; | 930 | int i; |
@@ -989,7 +988,7 @@ static netdev_tx_t lance_start_xmit(struct sk_buff *skb, | |||
989 | 988 | ||
990 | lp->tx_ring[entry].misc = 0x0000; | 989 | lp->tx_ring[entry].misc = 0x0000; |
991 | 990 | ||
992 | lp->stats.tx_bytes += skb->len; | 991 | dev->stats.tx_bytes += skb->len; |
993 | 992 | ||
994 | /* If any part of this buffer is >16M we must copy it to a low-memory | 993 | /* If any part of this buffer is >16M we must copy it to a low-memory |
995 | buffer. */ | 994 | buffer. */ |
@@ -1062,13 +1061,16 @@ static irqreturn_t lance_interrupt(int irq, void *dev_id) | |||
1062 | if (status & 0x40000000) { | 1061 | if (status & 0x40000000) { |
1063 | /* There was an major error, log it. */ | 1062 | /* There was an major error, log it. */ |
1064 | int err_status = lp->tx_ring[entry].misc; | 1063 | int err_status = lp->tx_ring[entry].misc; |
1065 | lp->stats.tx_errors++; | 1064 | dev->stats.tx_errors++; |
1066 | if (err_status & 0x0400) lp->stats.tx_aborted_errors++; | 1065 | if (err_status & 0x0400) |
1067 | if (err_status & 0x0800) lp->stats.tx_carrier_errors++; | 1066 | dev->stats.tx_aborted_errors++; |
1068 | if (err_status & 0x1000) lp->stats.tx_window_errors++; | 1067 | if (err_status & 0x0800) |
1068 | dev->stats.tx_carrier_errors++; | ||
1069 | if (err_status & 0x1000) | ||
1070 | dev->stats.tx_window_errors++; | ||
1069 | if (err_status & 0x4000) { | 1071 | if (err_status & 0x4000) { |
1070 | /* Ackk! On FIFO errors the Tx unit is turned off! */ | 1072 | /* Ackk! On FIFO errors the Tx unit is turned off! */ |
1071 | lp->stats.tx_fifo_errors++; | 1073 | dev->stats.tx_fifo_errors++; |
1072 | /* Remove this verbosity later! */ | 1074 | /* Remove this verbosity later! */ |
1073 | printk("%s: Tx FIFO error! Status %4.4x.\n", | 1075 | printk("%s: Tx FIFO error! Status %4.4x.\n", |
1074 | dev->name, csr0); | 1076 | dev->name, csr0); |
@@ -1077,8 +1079,8 @@ static irqreturn_t lance_interrupt(int irq, void *dev_id) | |||
1077 | } | 1079 | } |
1078 | } else { | 1080 | } else { |
1079 | if (status & 0x18000000) | 1081 | if (status & 0x18000000) |
1080 | lp->stats.collisions++; | 1082 | dev->stats.collisions++; |
1081 | lp->stats.tx_packets++; | 1083 | dev->stats.tx_packets++; |
1082 | } | 1084 | } |
1083 | 1085 | ||
1084 | /* We must free the original skb if it's not a data-only copy | 1086 | /* We must free the original skb if it's not a data-only copy |
@@ -1108,8 +1110,10 @@ static irqreturn_t lance_interrupt(int irq, void *dev_id) | |||
1108 | } | 1110 | } |
1109 | 1111 | ||
1110 | /* Log misc errors. */ | 1112 | /* Log misc errors. */ |
1111 | if (csr0 & 0x4000) lp->stats.tx_errors++; /* Tx babble. */ | 1113 | if (csr0 & 0x4000) |
1112 | if (csr0 & 0x1000) lp->stats.rx_errors++; /* Missed a Rx frame. */ | 1114 | dev->stats.tx_errors++; /* Tx babble. */ |
1115 | if (csr0 & 0x1000) | ||
1116 | dev->stats.rx_errors++; /* Missed a Rx frame. */ | ||
1113 | if (csr0 & 0x0800) { | 1117 | if (csr0 & 0x0800) { |
1114 | printk("%s: Bus master arbitration failure, status %4.4x.\n", | 1118 | printk("%s: Bus master arbitration failure, status %4.4x.\n", |
1115 | dev->name, csr0); | 1119 | dev->name, csr0); |
@@ -1155,11 +1159,15 @@ lance_rx(struct net_device *dev) | |||
1155 | buffers it's possible for a jabber packet to use two | 1159 | buffers it's possible for a jabber packet to use two |
1156 | buffers, with only the last correctly noting the error. */ | 1160 | buffers, with only the last correctly noting the error. */ |
1157 | if (status & 0x01) /* Only count a general error at the */ | 1161 | if (status & 0x01) /* Only count a general error at the */ |
1158 | lp->stats.rx_errors++; /* end of a packet.*/ | 1162 | dev->stats.rx_errors++; /* end of a packet.*/ |
1159 | if (status & 0x20) lp->stats.rx_frame_errors++; | 1163 | if (status & 0x20) |
1160 | if (status & 0x10) lp->stats.rx_over_errors++; | 1164 | dev->stats.rx_frame_errors++; |
1161 | if (status & 0x08) lp->stats.rx_crc_errors++; | 1165 | if (status & 0x10) |
1162 | if (status & 0x04) lp->stats.rx_fifo_errors++; | 1166 | dev->stats.rx_over_errors++; |
1167 | if (status & 0x08) | ||
1168 | dev->stats.rx_crc_errors++; | ||
1169 | if (status & 0x04) | ||
1170 | dev->stats.rx_fifo_errors++; | ||
1163 | lp->rx_ring[entry].base &= 0x03ffffff; | 1171 | lp->rx_ring[entry].base &= 0x03ffffff; |
1164 | } | 1172 | } |
1165 | else | 1173 | else |
@@ -1171,7 +1179,7 @@ lance_rx(struct net_device *dev) | |||
1171 | if(pkt_len<60) | 1179 | if(pkt_len<60) |
1172 | { | 1180 | { |
1173 | printk("%s: Runt packet!\n",dev->name); | 1181 | printk("%s: Runt packet!\n",dev->name); |
1174 | lp->stats.rx_errors++; | 1182 | dev->stats.rx_errors++; |
1175 | } | 1183 | } |
1176 | else | 1184 | else |
1177 | { | 1185 | { |
@@ -1185,7 +1193,7 @@ lance_rx(struct net_device *dev) | |||
1185 | 1193 | ||
1186 | if (i > RX_RING_SIZE -2) | 1194 | if (i > RX_RING_SIZE -2) |
1187 | { | 1195 | { |
1188 | lp->stats.rx_dropped++; | 1196 | dev->stats.rx_dropped++; |
1189 | lp->rx_ring[entry].base |= 0x80000000; | 1197 | lp->rx_ring[entry].base |= 0x80000000; |
1190 | lp->cur_rx++; | 1198 | lp->cur_rx++; |
1191 | } | 1199 | } |
@@ -1198,8 +1206,8 @@ lance_rx(struct net_device *dev) | |||
1198 | pkt_len); | 1206 | pkt_len); |
1199 | skb->protocol=eth_type_trans(skb,dev); | 1207 | skb->protocol=eth_type_trans(skb,dev); |
1200 | netif_rx(skb); | 1208 | netif_rx(skb); |
1201 | lp->stats.rx_packets++; | 1209 | dev->stats.rx_packets++; |
1202 | lp->stats.rx_bytes+=pkt_len; | 1210 | dev->stats.rx_bytes += pkt_len; |
1203 | } | 1211 | } |
1204 | } | 1212 | } |
1205 | /* The docs say that the buffer length isn't touched, but Andrew Boyd | 1213 | /* The docs say that the buffer length isn't touched, but Andrew Boyd |
@@ -1225,7 +1233,7 @@ lance_close(struct net_device *dev) | |||
1225 | 1233 | ||
1226 | if (chip_table[lp->chip_version].flags & LANCE_HAS_MISSED_FRAME) { | 1234 | if (chip_table[lp->chip_version].flags & LANCE_HAS_MISSED_FRAME) { |
1227 | outw(112, ioaddr+LANCE_ADDR); | 1235 | outw(112, ioaddr+LANCE_ADDR); |
1228 | lp->stats.rx_missed_errors = inw(ioaddr+LANCE_DATA); | 1236 | dev->stats.rx_missed_errors = inw(ioaddr+LANCE_DATA); |
1229 | } | 1237 | } |
1230 | outw(0, ioaddr+LANCE_ADDR); | 1238 | outw(0, ioaddr+LANCE_ADDR); |
1231 | 1239 | ||
@@ -1262,12 +1270,12 @@ static struct net_device_stats *lance_get_stats(struct net_device *dev) | |||
1262 | spin_lock_irqsave(&lp->devlock, flags); | 1270 | spin_lock_irqsave(&lp->devlock, flags); |
1263 | saved_addr = inw(ioaddr+LANCE_ADDR); | 1271 | saved_addr = inw(ioaddr+LANCE_ADDR); |
1264 | outw(112, ioaddr+LANCE_ADDR); | 1272 | outw(112, ioaddr+LANCE_ADDR); |
1265 | lp->stats.rx_missed_errors = inw(ioaddr+LANCE_DATA); | 1273 | dev->stats.rx_missed_errors = inw(ioaddr+LANCE_DATA); |
1266 | outw(saved_addr, ioaddr+LANCE_ADDR); | 1274 | outw(saved_addr, ioaddr+LANCE_ADDR); |
1267 | spin_unlock_irqrestore(&lp->devlock, flags); | 1275 | spin_unlock_irqrestore(&lp->devlock, flags); |
1268 | } | 1276 | } |
1269 | 1277 | ||
1270 | return &lp->stats; | 1278 | return &dev->stats; |
1271 | } | 1279 | } |
1272 | 1280 | ||
1273 | /* Set or clear the multicast filter for this adaptor. | 1281 | /* Set or clear the multicast filter for this adaptor. |