diff options
author | Glenn Elliott <gelliott@cs.unc.edu> | 2012-03-04 19:47:13 -0500 |
---|---|---|
committer | Glenn Elliott <gelliott@cs.unc.edu> | 2012-03-04 19:47:13 -0500 |
commit | c71c03bda1e86c9d5198c5d83f712e695c4f2a1e (patch) | |
tree | ecb166cb3e2b7e2adb3b5e292245fefd23381ac8 /drivers/net/tulip/winbond-840.c | |
parent | ea53c912f8a86a8567697115b6a0d8152beee5c8 (diff) | |
parent | 6a00f206debf8a5c8899055726ad127dbeeed098 (diff) |
Merge branch 'mpi-master' into wip-k-fmlpwip-k-fmlp
Conflicts:
litmus/sched_cedf.c
Diffstat (limited to 'drivers/net/tulip/winbond-840.c')
-rw-r--r-- | drivers/net/tulip/winbond-840.c | 83 |
1 files changed, 40 insertions, 43 deletions
diff --git a/drivers/net/tulip/winbond-840.c b/drivers/net/tulip/winbond-840.c index 66d41cf8da29..862eadf07191 100644 --- a/drivers/net/tulip/winbond-840.c +++ b/drivers/net/tulip/winbond-840.c | |||
@@ -44,6 +44,8 @@ | |||
44 | * Wake-On-LAN | 44 | * Wake-On-LAN |
45 | */ | 45 | */ |
46 | 46 | ||
47 | #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt | ||
48 | |||
47 | #define DRV_NAME "winbond-840" | 49 | #define DRV_NAME "winbond-840" |
48 | #define DRV_VERSION "1.01-e" | 50 | #define DRV_VERSION "1.01-e" |
49 | #define DRV_RELDATE "Sep-11-2006" | 51 | #define DRV_RELDATE "Sep-11-2006" |
@@ -139,7 +141,7 @@ static int full_duplex[MAX_UNITS] = {-1, -1, -1, -1, -1, -1, -1, -1}; | |||
139 | 141 | ||
140 | /* These identify the driver base version and may not be removed. */ | 142 | /* These identify the driver base version and may not be removed. */ |
141 | static const char version[] __initconst = | 143 | static const char version[] __initconst = |
142 | KERN_INFO DRV_NAME ".c:v" DRV_VERSION " (2.4 port) " | 144 | "v" DRV_VERSION " (2.4 port) " |
143 | DRV_RELDATE " Donald Becker <becker@scyld.com>\n" | 145 | DRV_RELDATE " Donald Becker <becker@scyld.com>\n" |
144 | " http://www.scyld.com/network/drivers.html\n"; | 146 | " http://www.scyld.com/network/drivers.html\n"; |
145 | 147 | ||
@@ -375,8 +377,8 @@ static int __devinit w840_probe1 (struct pci_dev *pdev, | |||
375 | irq = pdev->irq; | 377 | irq = pdev->irq; |
376 | 378 | ||
377 | if (pci_set_dma_mask(pdev, DMA_BIT_MASK(32))) { | 379 | if (pci_set_dma_mask(pdev, DMA_BIT_MASK(32))) { |
378 | pr_warning("Winbond-840: Device %s disabled due to DMA limitations\n", | 380 | pr_warn("Device %s disabled due to DMA limitations\n", |
379 | pci_name(pdev)); | 381 | pci_name(pdev)); |
380 | return -EIO; | 382 | return -EIO; |
381 | } | 383 | } |
382 | dev = alloc_etherdev(sizeof(*np)); | 384 | dev = alloc_etherdev(sizeof(*np)); |
@@ -643,8 +645,7 @@ static int netdev_open(struct net_device *dev) | |||
643 | goto out_err; | 645 | goto out_err; |
644 | 646 | ||
645 | if (debug > 1) | 647 | if (debug > 1) |
646 | printk(KERN_DEBUG "%s: w89c840_open() irq %d\n", | 648 | netdev_dbg(dev, "w89c840_open() irq %d\n", dev->irq); |
647 | dev->name, dev->irq); | ||
648 | 649 | ||
649 | if((i=alloc_ringdesc(dev))) | 650 | if((i=alloc_ringdesc(dev))) |
650 | goto out_err; | 651 | goto out_err; |
@@ -656,13 +657,13 @@ static int netdev_open(struct net_device *dev) | |||
656 | 657 | ||
657 | netif_start_queue(dev); | 658 | netif_start_queue(dev); |
658 | if (debug > 2) | 659 | if (debug > 2) |
659 | printk(KERN_DEBUG "%s: Done netdev_open()\n", dev->name); | 660 | netdev_dbg(dev, "Done netdev_open()\n"); |
660 | 661 | ||
661 | /* Set the timer to check for link beat. */ | 662 | /* Set the timer to check for link beat. */ |
662 | init_timer(&np->timer); | 663 | init_timer(&np->timer); |
663 | np->timer.expires = jiffies + 1*HZ; | 664 | np->timer.expires = jiffies + 1*HZ; |
664 | np->timer.data = (unsigned long)dev; | 665 | np->timer.data = (unsigned long)dev; |
665 | np->timer.function = &netdev_timer; /* timer handler */ | 666 | np->timer.function = netdev_timer; /* timer handler */ |
666 | add_timer(&np->timer); | 667 | add_timer(&np->timer); |
667 | return 0; | 668 | return 0; |
668 | out_err: | 669 | out_err: |
@@ -785,9 +786,9 @@ static void netdev_timer(unsigned long data) | |||
785 | void __iomem *ioaddr = np->base_addr; | 786 | void __iomem *ioaddr = np->base_addr; |
786 | 787 | ||
787 | if (debug > 2) | 788 | if (debug > 2) |
788 | printk(KERN_DEBUG "%s: Media selection timer tick, status %08x config %08x\n", | 789 | netdev_dbg(dev, "Media selection timer tick, status %08x config %08x\n", |
789 | dev->name, ioread32(ioaddr + IntrStatus), | 790 | ioread32(ioaddr + IntrStatus), |
790 | ioread32(ioaddr + NetworkConfig)); | 791 | ioread32(ioaddr + NetworkConfig)); |
791 | spin_lock_irq(&np->lock); | 792 | spin_lock_irq(&np->lock); |
792 | update_csr6(dev, update_link(dev)); | 793 | update_csr6(dev, update_link(dev)); |
793 | spin_unlock_irq(&np->lock); | 794 | spin_unlock_irq(&np->lock); |
@@ -1054,8 +1055,8 @@ static netdev_tx_t start_tx(struct sk_buff *skb, struct net_device *dev) | |||
1054 | spin_unlock_irq(&np->lock); | 1055 | spin_unlock_irq(&np->lock); |
1055 | 1056 | ||
1056 | if (debug > 4) { | 1057 | if (debug > 4) { |
1057 | printk(KERN_DEBUG "%s: Transmit frame #%d queued in slot %d\n", | 1058 | netdev_dbg(dev, "Transmit frame #%d queued in slot %d\n", |
1058 | dev->name, np->cur_tx, entry); | 1059 | np->cur_tx, entry); |
1059 | } | 1060 | } |
1060 | return NETDEV_TX_OK; | 1061 | return NETDEV_TX_OK; |
1061 | } | 1062 | } |
@@ -1072,8 +1073,8 @@ static void netdev_tx_done(struct net_device *dev) | |||
1072 | if (tx_status & 0x8000) { /* There was an error, log it. */ | 1073 | if (tx_status & 0x8000) { /* There was an error, log it. */ |
1073 | #ifndef final_version | 1074 | #ifndef final_version |
1074 | if (debug > 1) | 1075 | if (debug > 1) |
1075 | printk(KERN_DEBUG "%s: Transmit error, Tx status %08x\n", | 1076 | netdev_dbg(dev, "Transmit error, Tx status %08x\n", |
1076 | dev->name, tx_status); | 1077 | tx_status); |
1077 | #endif | 1078 | #endif |
1078 | np->stats.tx_errors++; | 1079 | np->stats.tx_errors++; |
1079 | if (tx_status & 0x0104) np->stats.tx_aborted_errors++; | 1080 | if (tx_status & 0x0104) np->stats.tx_aborted_errors++; |
@@ -1085,8 +1086,8 @@ static void netdev_tx_done(struct net_device *dev) | |||
1085 | } else { | 1086 | } else { |
1086 | #ifndef final_version | 1087 | #ifndef final_version |
1087 | if (debug > 3) | 1088 | if (debug > 3) |
1088 | printk(KERN_DEBUG "%s: Transmit slot %d ok, Tx status %08x\n", | 1089 | netdev_dbg(dev, "Transmit slot %d ok, Tx status %08x\n", |
1089 | dev->name, entry, tx_status); | 1090 | entry, tx_status); |
1090 | #endif | 1091 | #endif |
1091 | np->stats.tx_bytes += np->tx_skbuff[entry]->len; | 1092 | np->stats.tx_bytes += np->tx_skbuff[entry]->len; |
1092 | np->stats.collisions += (tx_status >> 3) & 15; | 1093 | np->stats.collisions += (tx_status >> 3) & 15; |
@@ -1129,8 +1130,7 @@ static irqreturn_t intr_handler(int irq, void *dev_instance) | |||
1129 | iowrite32(intr_status & 0x001ffff, ioaddr + IntrStatus); | 1130 | iowrite32(intr_status & 0x001ffff, ioaddr + IntrStatus); |
1130 | 1131 | ||
1131 | if (debug > 4) | 1132 | if (debug > 4) |
1132 | printk(KERN_DEBUG "%s: Interrupt, status %04x\n", | 1133 | netdev_dbg(dev, "Interrupt, status %04x\n", intr_status); |
1133 | dev->name, intr_status); | ||
1134 | 1134 | ||
1135 | if ((intr_status & (NormalIntr|AbnormalIntr)) == 0) | 1135 | if ((intr_status & (NormalIntr|AbnormalIntr)) == 0) |
1136 | break; | 1136 | break; |
@@ -1171,8 +1171,8 @@ static irqreturn_t intr_handler(int irq, void *dev_instance) | |||
1171 | } while (1); | 1171 | } while (1); |
1172 | 1172 | ||
1173 | if (debug > 3) | 1173 | if (debug > 3) |
1174 | printk(KERN_DEBUG "%s: exiting interrupt, status=%#4.4x\n", | 1174 | netdev_dbg(dev, "exiting interrupt, status=%#4.4x\n", |
1175 | dev->name, ioread32(ioaddr + IntrStatus)); | 1175 | ioread32(ioaddr + IntrStatus)); |
1176 | return IRQ_RETVAL(handled); | 1176 | return IRQ_RETVAL(handled); |
1177 | } | 1177 | } |
1178 | 1178 | ||
@@ -1185,8 +1185,8 @@ static int netdev_rx(struct net_device *dev) | |||
1185 | int work_limit = np->dirty_rx + RX_RING_SIZE - np->cur_rx; | 1185 | int work_limit = np->dirty_rx + RX_RING_SIZE - np->cur_rx; |
1186 | 1186 | ||
1187 | if (debug > 4) { | 1187 | if (debug > 4) { |
1188 | printk(KERN_DEBUG " In netdev_rx(), entry %d status %04x\n", | 1188 | netdev_dbg(dev, " In netdev_rx(), entry %d status %04x\n", |
1189 | entry, np->rx_ring[entry].status); | 1189 | entry, np->rx_ring[entry].status); |
1190 | } | 1190 | } |
1191 | 1191 | ||
1192 | /* If EOP is set on the next entry, it's a new packet. Send it up. */ | 1192 | /* If EOP is set on the next entry, it's a new packet. Send it up. */ |
@@ -1195,8 +1195,8 @@ static int netdev_rx(struct net_device *dev) | |||
1195 | s32 status = desc->status; | 1195 | s32 status = desc->status; |
1196 | 1196 | ||
1197 | if (debug > 4) | 1197 | if (debug > 4) |
1198 | printk(KERN_DEBUG " netdev_rx() status was %08x\n", | 1198 | netdev_dbg(dev, " netdev_rx() status was %08x\n", |
1199 | status); | 1199 | status); |
1200 | if (status < 0) | 1200 | if (status < 0) |
1201 | break; | 1201 | break; |
1202 | if ((status & 0x38008300) != 0x0300) { | 1202 | if ((status & 0x38008300) != 0x0300) { |
@@ -1211,8 +1211,8 @@ static int netdev_rx(struct net_device *dev) | |||
1211 | } else if (status & 0x8000) { | 1211 | } else if (status & 0x8000) { |
1212 | /* There was a fatal error. */ | 1212 | /* There was a fatal error. */ |
1213 | if (debug > 2) | 1213 | if (debug > 2) |
1214 | printk(KERN_DEBUG "%s: Receive error, Rx status %08x\n", | 1214 | netdev_dbg(dev, "Receive error, Rx status %08x\n", |
1215 | dev->name, status); | 1215 | status); |
1216 | np->stats.rx_errors++; /* end of a packet.*/ | 1216 | np->stats.rx_errors++; /* end of a packet.*/ |
1217 | if (status & 0x0890) np->stats.rx_length_errors++; | 1217 | if (status & 0x0890) np->stats.rx_length_errors++; |
1218 | if (status & 0x004C) np->stats.rx_frame_errors++; | 1218 | if (status & 0x004C) np->stats.rx_frame_errors++; |
@@ -1225,8 +1225,8 @@ static int netdev_rx(struct net_device *dev) | |||
1225 | 1225 | ||
1226 | #ifndef final_version | 1226 | #ifndef final_version |
1227 | if (debug > 4) | 1227 | if (debug > 4) |
1228 | printk(KERN_DEBUG " netdev_rx() normal Rx pkt length %d status %x\n", | 1228 | netdev_dbg(dev, " netdev_rx() normal Rx pkt length %d status %x\n", |
1229 | pkt_len, status); | 1229 | pkt_len, status); |
1230 | #endif | 1230 | #endif |
1231 | /* Check if the packet is long enough to accept without copying | 1231 | /* Check if the packet is long enough to accept without copying |
1232 | to a minimally-sized skbuff. */ | 1232 | to a minimally-sized skbuff. */ |
@@ -1251,10 +1251,10 @@ static int netdev_rx(struct net_device *dev) | |||
1251 | #ifndef final_version /* Remove after testing. */ | 1251 | #ifndef final_version /* Remove after testing. */ |
1252 | /* You will want this info for the initial debug. */ | 1252 | /* You will want this info for the initial debug. */ |
1253 | if (debug > 5) | 1253 | if (debug > 5) |
1254 | printk(KERN_DEBUG " Rx data %pM %pM %02x%02x %pI4\n", | 1254 | netdev_dbg(dev, " Rx data %pM %pM %02x%02x %pI4\n", |
1255 | &skb->data[0], &skb->data[6], | 1255 | &skb->data[0], &skb->data[6], |
1256 | skb->data[12], skb->data[13], | 1256 | skb->data[12], skb->data[13], |
1257 | &skb->data[14]); | 1257 | &skb->data[14]); |
1258 | #endif | 1258 | #endif |
1259 | skb->protocol = eth_type_trans(skb, dev); | 1259 | skb->protocol = eth_type_trans(skb, dev); |
1260 | netif_rx(skb); | 1260 | netif_rx(skb); |
@@ -1292,8 +1292,7 @@ static void netdev_error(struct net_device *dev, int intr_status) | |||
1292 | void __iomem *ioaddr = np->base_addr; | 1292 | void __iomem *ioaddr = np->base_addr; |
1293 | 1293 | ||
1294 | if (debug > 2) | 1294 | if (debug > 2) |
1295 | printk(KERN_DEBUG "%s: Abnormal event, %08x\n", | 1295 | netdev_dbg(dev, "Abnormal event, %08x\n", intr_status); |
1296 | dev->name, intr_status); | ||
1297 | if (intr_status == 0xffffffff) | 1296 | if (intr_status == 0xffffffff) |
1298 | return; | 1297 | return; |
1299 | spin_lock(&np->lock); | 1298 | spin_lock(&np->lock); |
@@ -1313,8 +1312,7 @@ static void netdev_error(struct net_device *dev, int intr_status) | |||
1313 | new = 127; /* load full packet before starting */ | 1312 | new = 127; /* load full packet before starting */ |
1314 | new = (np->csr6 & ~(0x7F << 14)) | (new<<14); | 1313 | new = (np->csr6 & ~(0x7F << 14)) | (new<<14); |
1315 | #endif | 1314 | #endif |
1316 | printk(KERN_DEBUG "%s: Tx underflow, new csr6 %08x\n", | 1315 | netdev_dbg(dev, "Tx underflow, new csr6 %08x\n", new); |
1317 | dev->name, new); | ||
1318 | update_csr6(dev, new); | 1316 | update_csr6(dev, new); |
1319 | } | 1317 | } |
1320 | if (intr_status & RxDied) { /* Missed a Rx frame. */ | 1318 | if (intr_status & RxDied) { /* Missed a Rx frame. */ |
@@ -1487,13 +1485,12 @@ static int netdev_close(struct net_device *dev) | |||
1487 | netif_stop_queue(dev); | 1485 | netif_stop_queue(dev); |
1488 | 1486 | ||
1489 | if (debug > 1) { | 1487 | if (debug > 1) { |
1490 | printk(KERN_DEBUG "%s: Shutting down ethercard, status was %08x Config %08x\n", | 1488 | netdev_dbg(dev, "Shutting down ethercard, status was %08x Config %08x\n", |
1491 | dev->name, ioread32(ioaddr + IntrStatus), | 1489 | ioread32(ioaddr + IntrStatus), |
1492 | ioread32(ioaddr + NetworkConfig)); | 1490 | ioread32(ioaddr + NetworkConfig)); |
1493 | printk(KERN_DEBUG "%s: Queue pointers were Tx %d / %d, Rx %d / %d\n", | 1491 | netdev_dbg(dev, "Queue pointers were Tx %d / %d, Rx %d / %d\n", |
1494 | dev->name, | 1492 | np->cur_tx, np->dirty_tx, |
1495 | np->cur_tx, np->dirty_tx, | 1493 | np->cur_rx, np->dirty_rx); |
1496 | np->cur_rx, np->dirty_rx); | ||
1497 | } | 1494 | } |
1498 | 1495 | ||
1499 | /* Stop the chip's Tx and Rx processes. */ | 1496 | /* Stop the chip's Tx and Rx processes. */ |