diff options
Diffstat (limited to 'drivers/net/tulip')
-rw-r--r-- | drivers/net/tulip/21142.c | 14 | ||||
-rw-r--r-- | drivers/net/tulip/Kconfig | 6 | ||||
-rw-r--r-- | drivers/net/tulip/Makefile | 2 | ||||
-rw-r--r-- | drivers/net/tulip/de2104x.c | 201 | ||||
-rw-r--r-- | drivers/net/tulip/de4x5.c | 63 | ||||
-rw-r--r-- | drivers/net/tulip/dmfe.c | 23 | ||||
-rw-r--r-- | drivers/net/tulip/eeprom.c | 6 | ||||
-rw-r--r-- | drivers/net/tulip/interrupt.c | 125 | ||||
-rw-r--r-- | drivers/net/tulip/media.c | 49 | ||||
-rw-r--r-- | drivers/net/tulip/pnic.c | 22 | ||||
-rw-r--r-- | drivers/net/tulip/pnic2.c | 18 | ||||
-rw-r--r-- | drivers/net/tulip/timer.c | 47 | ||||
-rw-r--r-- | drivers/net/tulip/tulip.h | 11 | ||||
-rw-r--r-- | drivers/net/tulip/tulip_core.c | 75 | ||||
-rw-r--r-- | drivers/net/tulip/uli526x.c | 75 | ||||
-rw-r--r-- | drivers/net/tulip/winbond-840.c | 83 | ||||
-rw-r--r-- | drivers/net/tulip/xircom_cb.c | 283 |
17 files changed, 476 insertions, 627 deletions
diff --git a/drivers/net/tulip/21142.c b/drivers/net/tulip/21142.c index 007d8e75666d..092c3faa882a 100644 --- a/drivers/net/tulip/21142.c +++ b/drivers/net/tulip/21142.c | |||
@@ -122,8 +122,8 @@ void t21142_start_nway(struct net_device *dev) | |||
122 | tp->nway = tp->mediasense = 1; | 122 | tp->nway = tp->mediasense = 1; |
123 | tp->nwayset = tp->lpar = 0; | 123 | tp->nwayset = tp->lpar = 0; |
124 | if (tulip_debug > 1) | 124 | if (tulip_debug > 1) |
125 | printk(KERN_DEBUG "%s: Restarting 21143 autonegotiation, csr14=%08x\n", | 125 | netdev_dbg(dev, "Restarting 21143 autonegotiation, csr14=%08x\n", |
126 | dev->name, csr14); | 126 | csr14); |
127 | iowrite32(0x0001, ioaddr + CSR13); | 127 | iowrite32(0x0001, ioaddr + CSR13); |
128 | udelay(100); | 128 | udelay(100); |
129 | iowrite32(csr14, ioaddr + CSR14); | 129 | iowrite32(csr14, ioaddr + CSR14); |
@@ -206,14 +206,14 @@ void t21142_lnk_change(struct net_device *dev, int csr5) | |||
206 | #if 0 /* Restart shouldn't be needed. */ | 206 | #if 0 /* Restart shouldn't be needed. */ |
207 | iowrite32(tp->csr6 | RxOn, ioaddr + CSR6); | 207 | iowrite32(tp->csr6 | RxOn, ioaddr + CSR6); |
208 | if (tulip_debug > 2) | 208 | if (tulip_debug > 2) |
209 | printk(KERN_DEBUG "%s: Restarting Tx and Rx, CSR5 is %08x\n", | 209 | netdev_dbg(dev, " Restarting Tx and Rx, CSR5 is %08x\n", |
210 | dev->name, ioread32(ioaddr + CSR5)); | 210 | ioread32(ioaddr + CSR5)); |
211 | #endif | 211 | #endif |
212 | tulip_start_rxtx(tp); | 212 | tulip_start_rxtx(tp); |
213 | if (tulip_debug > 2) | 213 | if (tulip_debug > 2) |
214 | printk(KERN_DEBUG "%s: Setting CSR6 %08x/%x CSR12 %08x\n", | 214 | netdev_dbg(dev, " Setting CSR6 %08x/%x CSR12 %08x\n", |
215 | dev->name, tp->csr6, ioread32(ioaddr + CSR6), | 215 | tp->csr6, ioread32(ioaddr + CSR6), |
216 | ioread32(ioaddr + CSR12)); | 216 | ioread32(ioaddr + CSR12)); |
217 | } else if ((tp->nwayset && (csr5 & 0x08000000) && | 217 | } else if ((tp->nwayset && (csr5 & 0x08000000) && |
218 | (dev->if_port == 3 || dev->if_port == 5) && | 218 | (dev->if_port == 3 || dev->if_port == 5) && |
219 | (csr12 & 2) == 2) || | 219 | (csr12 & 2) == 2) || |
diff --git a/drivers/net/tulip/Kconfig b/drivers/net/tulip/Kconfig index 516713fa0a05..1f8d4a8d8ea4 100644 --- a/drivers/net/tulip/Kconfig +++ b/drivers/net/tulip/Kconfig | |||
@@ -11,8 +11,8 @@ menuconfig NET_TULIP | |||
11 | if NET_TULIP | 11 | if NET_TULIP |
12 | 12 | ||
13 | config DE2104X | 13 | config DE2104X |
14 | tristate "Early DECchip Tulip (dc2104x) PCI support (EXPERIMENTAL)" | 14 | tristate "Early DECchip Tulip (dc2104x) PCI support" |
15 | depends on PCI && EXPERIMENTAL | 15 | depends on PCI |
16 | select CRC32 | 16 | select CRC32 |
17 | ---help--- | 17 | ---help--- |
18 | This driver is developed for the SMC EtherPower series Ethernet | 18 | This driver is developed for the SMC EtherPower series Ethernet |
@@ -151,7 +151,7 @@ config ULI526X | |||
151 | select CRC32 | 151 | select CRC32 |
152 | ---help--- | 152 | ---help--- |
153 | This driver is for ULi M5261/M5263 10/100M Ethernet Controller | 153 | This driver is for ULi M5261/M5263 10/100M Ethernet Controller |
154 | (<http://www.uli.com.tw/>). | 154 | (<http://www.nvidia.com/page/uli_drivers.html>). |
155 | 155 | ||
156 | To compile this driver as a module, choose M here. The module will | 156 | To compile this driver as a module, choose M here. The module will |
157 | be called uli526x. | 157 | be called uli526x. |
diff --git a/drivers/net/tulip/Makefile b/drivers/net/tulip/Makefile index 200cbf7c815c..5e8be38b45bb 100644 --- a/drivers/net/tulip/Makefile +++ b/drivers/net/tulip/Makefile | |||
@@ -2,6 +2,8 @@ | |||
2 | # Makefile for the Linux "Tulip" family network device drivers. | 2 | # Makefile for the Linux "Tulip" family network device drivers. |
3 | # | 3 | # |
4 | 4 | ||
5 | ccflags-$(CONFIG_NET_TULIP) := -DDEBUG | ||
6 | |||
5 | obj-$(CONFIG_PCMCIA_XIRCOM) += xircom_cb.o | 7 | obj-$(CONFIG_PCMCIA_XIRCOM) += xircom_cb.o |
6 | obj-$(CONFIG_DM9102) += dmfe.o | 8 | obj-$(CONFIG_DM9102) += dmfe.o |
7 | obj-$(CONFIG_WINBOND_840) += winbond-840.o | 9 | obj-$(CONFIG_WINBOND_840) += winbond-840.o |
diff --git a/drivers/net/tulip/de2104x.c b/drivers/net/tulip/de2104x.c index 6888e3d41462..e2f692351180 100644 --- a/drivers/net/tulip/de2104x.c +++ b/drivers/net/tulip/de2104x.c | |||
@@ -27,6 +27,8 @@ | |||
27 | 27 | ||
28 | */ | 28 | */ |
29 | 29 | ||
30 | #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt | ||
31 | |||
30 | #define DRV_NAME "de2104x" | 32 | #define DRV_NAME "de2104x" |
31 | #define DRV_VERSION "0.7" | 33 | #define DRV_VERSION "0.7" |
32 | #define DRV_RELDATE "Mar 17, 2004" | 34 | #define DRV_RELDATE "Mar 17, 2004" |
@@ -51,7 +53,7 @@ | |||
51 | 53 | ||
52 | /* These identify the driver base version and may not be removed. */ | 54 | /* These identify the driver base version and may not be removed. */ |
53 | static char version[] = | 55 | static char version[] = |
54 | KERN_INFO DRV_NAME " PCI Ethernet driver v" DRV_VERSION " (" DRV_RELDATE ")\n"; | 56 | "PCI Ethernet driver v" DRV_VERSION " (" DRV_RELDATE ")"; |
55 | 57 | ||
56 | MODULE_AUTHOR("Jeff Garzik <jgarzik@pobox.com>"); | 58 | MODULE_AUTHOR("Jeff Garzik <jgarzik@pobox.com>"); |
57 | MODULE_DESCRIPTION("Intel/Digital 21040/1 series PCI Ethernet driver"); | 59 | MODULE_DESCRIPTION("Intel/Digital 21040/1 series PCI Ethernet driver"); |
@@ -73,8 +75,6 @@ static int rx_copybreak = 100; | |||
73 | module_param (rx_copybreak, int, 0); | 75 | module_param (rx_copybreak, int, 0); |
74 | MODULE_PARM_DESC (rx_copybreak, "de2104x Breakpoint at which Rx packets are copied"); | 76 | MODULE_PARM_DESC (rx_copybreak, "de2104x Breakpoint at which Rx packets are copied"); |
75 | 77 | ||
76 | #define PFX DRV_NAME ": " | ||
77 | |||
78 | #define DE_DEF_MSG_ENABLE (NETIF_MSG_DRV | \ | 78 | #define DE_DEF_MSG_ENABLE (NETIF_MSG_DRV | \ |
79 | NETIF_MSG_PROBE | \ | 79 | NETIF_MSG_PROBE | \ |
80 | NETIF_MSG_LINK | \ | 80 | NETIF_MSG_LINK | \ |
@@ -377,18 +377,16 @@ static u16 t21041_csr15[] = { 0x0008, 0x0006, 0x000E, 0x0008, 0x0008, }; | |||
377 | static void de_rx_err_acct (struct de_private *de, unsigned rx_tail, | 377 | static void de_rx_err_acct (struct de_private *de, unsigned rx_tail, |
378 | u32 status, u32 len) | 378 | u32 status, u32 len) |
379 | { | 379 | { |
380 | if (netif_msg_rx_err (de)) | 380 | netif_dbg(de, rx_err, de->dev, |
381 | printk (KERN_DEBUG | 381 | "rx err, slot %d status 0x%x len %d\n", |
382 | "%s: rx err, slot %d status 0x%x len %d\n", | 382 | rx_tail, status, len); |
383 | de->dev->name, rx_tail, status, len); | ||
384 | 383 | ||
385 | if ((status & 0x38000300) != 0x0300) { | 384 | if ((status & 0x38000300) != 0x0300) { |
386 | /* Ingore earlier buffers. */ | 385 | /* Ingore earlier buffers. */ |
387 | if ((status & 0xffff) != 0x7fff) { | 386 | if ((status & 0xffff) != 0x7fff) { |
388 | if (netif_msg_rx_err(de)) | 387 | netif_warn(de, rx_err, de->dev, |
389 | dev_warn(&de->dev->dev, | 388 | "Oversized Ethernet frame spanned multiple buffers, status %08x!\n", |
390 | "Oversized Ethernet frame spanned multiple buffers, status %08x!\n", | 389 | status); |
391 | status); | ||
392 | de->net_stats.rx_length_errors++; | 390 | de->net_stats.rx_length_errors++; |
393 | } | 391 | } |
394 | } else if (status & RxError) { | 392 | } else if (status & RxError) { |
@@ -435,10 +433,9 @@ static void de_rx (struct de_private *de) | |||
435 | 433 | ||
436 | copying_skb = (len <= rx_copybreak); | 434 | copying_skb = (len <= rx_copybreak); |
437 | 435 | ||
438 | if (unlikely(netif_msg_rx_status(de))) | 436 | netif_dbg(de, rx_status, de->dev, |
439 | printk(KERN_DEBUG "%s: rx slot %d status 0x%x len %d copying? %d\n", | 437 | "rx slot %d status 0x%x len %d copying? %d\n", |
440 | de->dev->name, rx_tail, status, len, | 438 | rx_tail, status, len, copying_skb); |
441 | copying_skb); | ||
442 | 439 | ||
443 | buflen = copying_skb ? (len + RX_OFFSET) : de->rx_buf_sz; | 440 | buflen = copying_skb ? (len + RX_OFFSET) : de->rx_buf_sz; |
444 | copy_skb = dev_alloc_skb (buflen); | 441 | copy_skb = dev_alloc_skb (buflen); |
@@ -491,7 +488,7 @@ rx_next: | |||
491 | } | 488 | } |
492 | 489 | ||
493 | if (!rx_work) | 490 | if (!rx_work) |
494 | dev_warn(&de->dev->dev, "rx work limit reached\n"); | 491 | netdev_warn(de->dev, "rx work limit reached\n"); |
495 | 492 | ||
496 | de->rx_tail = rx_tail; | 493 | de->rx_tail = rx_tail; |
497 | } | 494 | } |
@@ -506,10 +503,9 @@ static irqreturn_t de_interrupt (int irq, void *dev_instance) | |||
506 | if ((!(status & (IntrOK|IntrErr))) || (status == 0xFFFF)) | 503 | if ((!(status & (IntrOK|IntrErr))) || (status == 0xFFFF)) |
507 | return IRQ_NONE; | 504 | return IRQ_NONE; |
508 | 505 | ||
509 | if (netif_msg_intr(de)) | 506 | netif_dbg(de, intr, dev, "intr, status %08x mode %08x desc %u/%u/%u\n", |
510 | printk(KERN_DEBUG "%s: intr, status %08x mode %08x desc %u/%u/%u\n", | 507 | status, dr32(MacMode), |
511 | dev->name, status, dr32(MacMode), | 508 | de->rx_tail, de->tx_head, de->tx_tail); |
512 | de->rx_tail, de->tx_head, de->tx_tail); | ||
513 | 509 | ||
514 | dw32(MacStatus, status); | 510 | dw32(MacStatus, status); |
515 | 511 | ||
@@ -534,9 +530,9 @@ static irqreturn_t de_interrupt (int irq, void *dev_instance) | |||
534 | 530 | ||
535 | pci_read_config_word(de->pdev, PCI_STATUS, &pci_status); | 531 | pci_read_config_word(de->pdev, PCI_STATUS, &pci_status); |
536 | pci_write_config_word(de->pdev, PCI_STATUS, pci_status); | 532 | pci_write_config_word(de->pdev, PCI_STATUS, pci_status); |
537 | dev_err(&de->dev->dev, | 533 | netdev_err(de->dev, |
538 | "PCI bus error, status=%08x, PCI status=%04x\n", | 534 | "PCI bus error, status=%08x, PCI status=%04x\n", |
539 | status, pci_status); | 535 | status, pci_status); |
540 | } | 536 | } |
541 | 537 | ||
542 | return IRQ_HANDLED; | 538 | return IRQ_HANDLED; |
@@ -572,9 +568,9 @@ static void de_tx (struct de_private *de) | |||
572 | 568 | ||
573 | if (status & LastFrag) { | 569 | if (status & LastFrag) { |
574 | if (status & TxError) { | 570 | if (status & TxError) { |
575 | if (netif_msg_tx_err(de)) | 571 | netif_dbg(de, tx_err, de->dev, |
576 | printk(KERN_DEBUG "%s: tx err, status 0x%x\n", | 572 | "tx err, status 0x%x\n", |
577 | de->dev->name, status); | 573 | status); |
578 | de->net_stats.tx_errors++; | 574 | de->net_stats.tx_errors++; |
579 | if (status & TxOWC) | 575 | if (status & TxOWC) |
580 | de->net_stats.tx_window_errors++; | 576 | de->net_stats.tx_window_errors++; |
@@ -587,9 +583,8 @@ static void de_tx (struct de_private *de) | |||
587 | } else { | 583 | } else { |
588 | de->net_stats.tx_packets++; | 584 | de->net_stats.tx_packets++; |
589 | de->net_stats.tx_bytes += skb->len; | 585 | de->net_stats.tx_bytes += skb->len; |
590 | if (netif_msg_tx_done(de)) | 586 | netif_dbg(de, tx_done, de->dev, |
591 | printk(KERN_DEBUG "%s: tx done, slot %d\n", | 587 | "tx done, slot %d\n", tx_tail); |
592 | de->dev->name, tx_tail); | ||
593 | } | 588 | } |
594 | dev_kfree_skb_irq(skb); | 589 | dev_kfree_skb_irq(skb); |
595 | } | 590 | } |
@@ -646,9 +641,8 @@ static netdev_tx_t de_start_xmit (struct sk_buff *skb, | |||
646 | wmb(); | 641 | wmb(); |
647 | 642 | ||
648 | de->tx_head = NEXT_TX(entry); | 643 | de->tx_head = NEXT_TX(entry); |
649 | if (netif_msg_tx_queued(de)) | 644 | netif_dbg(de, tx_queued, dev, "tx queued, slot %d, skblen %d\n", |
650 | printk(KERN_DEBUG "%s: tx queued, slot %d, skblen %d\n", | 645 | entry, skb->len); |
651 | dev->name, entry, skb->len); | ||
652 | 646 | ||
653 | if (tx_free == 0) | 647 | if (tx_free == 0) |
654 | netif_stop_queue(dev); | 648 | netif_stop_queue(dev); |
@@ -873,7 +867,7 @@ static void de_stop_rxtx (struct de_private *de) | |||
873 | udelay(100); | 867 | udelay(100); |
874 | } | 868 | } |
875 | 869 | ||
876 | dev_warn(&de->dev->dev, "timeout expired stopping DMA\n"); | 870 | netdev_warn(de->dev, "timeout expired, stopping DMA\n"); |
877 | } | 871 | } |
878 | 872 | ||
879 | static inline void de_start_rxtx (struct de_private *de) | 873 | static inline void de_start_rxtx (struct de_private *de) |
@@ -907,9 +901,8 @@ static void de_link_up(struct de_private *de) | |||
907 | { | 901 | { |
908 | if (!netif_carrier_ok(de->dev)) { | 902 | if (!netif_carrier_ok(de->dev)) { |
909 | netif_carrier_on(de->dev); | 903 | netif_carrier_on(de->dev); |
910 | if (netif_msg_link(de)) | 904 | netif_info(de, link, de->dev, "link up, media %s\n", |
911 | dev_info(&de->dev->dev, "link up, media %s\n", | 905 | media_name[de->media_type]); |
912 | media_name[de->media_type]); | ||
913 | } | 906 | } |
914 | } | 907 | } |
915 | 908 | ||
@@ -917,8 +910,7 @@ static void de_link_down(struct de_private *de) | |||
917 | { | 910 | { |
918 | if (netif_carrier_ok(de->dev)) { | 911 | if (netif_carrier_ok(de->dev)) { |
919 | netif_carrier_off(de->dev); | 912 | netif_carrier_off(de->dev); |
920 | if (netif_msg_link(de)) | 913 | netif_info(de, link, de->dev, "link down\n"); |
921 | dev_info(&de->dev->dev, "link down\n"); | ||
922 | } | 914 | } |
923 | } | 915 | } |
924 | 916 | ||
@@ -928,8 +920,7 @@ static void de_set_media (struct de_private *de) | |||
928 | u32 macmode = dr32(MacMode); | 920 | u32 macmode = dr32(MacMode); |
929 | 921 | ||
930 | if (de_is_running(de)) | 922 | if (de_is_running(de)) |
931 | dev_warn(&de->dev->dev, | 923 | netdev_warn(de->dev, "chip is running while changing media!\n"); |
932 | "chip is running while changing media!\n"); | ||
933 | 924 | ||
934 | if (de->de21040) | 925 | if (de->de21040) |
935 | dw32(CSR11, FULL_DUPLEX_MAGIC); | 926 | dw32(CSR11, FULL_DUPLEX_MAGIC); |
@@ -948,22 +939,18 @@ static void de_set_media (struct de_private *de) | |||
948 | else | 939 | else |
949 | macmode &= ~FullDuplex; | 940 | macmode &= ~FullDuplex; |
950 | 941 | ||
951 | if (netif_msg_link(de)) { | 942 | netif_info(de, link, de->dev, "set link %s\n", media_name[media]); |
952 | dev_info(&de->dev->dev, "set link %s\n", media_name[media]); | 943 | netif_info(de, hw, de->dev, "mode 0x%x, sia 0x%x,0x%x,0x%x,0x%x\n", |
953 | dev_info(&de->dev->dev, "mode 0x%x, sia 0x%x,0x%x,0x%x,0x%x\n", | 944 | dr32(MacMode), dr32(SIAStatus), |
954 | dr32(MacMode), dr32(SIAStatus), | 945 | dr32(CSR13), dr32(CSR14), dr32(CSR15)); |
955 | dr32(CSR13), dr32(CSR14), dr32(CSR15)); | 946 | netif_info(de, hw, de->dev, "set mode 0x%x, set sia 0x%x,0x%x,0x%x\n", |
956 | 947 | macmode, de->media[media].csr13, | |
957 | dev_info(&de->dev->dev, | 948 | de->media[media].csr14, de->media[media].csr15); |
958 | "set mode 0x%x, set sia 0x%x,0x%x,0x%x\n", | ||
959 | macmode, de->media[media].csr13, | ||
960 | de->media[media].csr14, de->media[media].csr15); | ||
961 | } | ||
962 | if (macmode != dr32(MacMode)) | 949 | if (macmode != dr32(MacMode)) |
963 | dw32(MacMode, macmode); | 950 | dw32(MacMode, macmode); |
964 | } | 951 | } |
965 | 952 | ||
966 | static void de_next_media (struct de_private *de, u32 *media, | 953 | static void de_next_media (struct de_private *de, const u32 *media, |
967 | unsigned int n_media) | 954 | unsigned int n_media) |
968 | { | 955 | { |
969 | unsigned int i; | 956 | unsigned int i; |
@@ -995,9 +982,8 @@ static void de21040_media_timer (unsigned long data) | |||
995 | if (!netif_carrier_ok(dev)) | 982 | if (!netif_carrier_ok(dev)) |
996 | de_link_up(de); | 983 | de_link_up(de); |
997 | else | 984 | else |
998 | if (netif_msg_timer(de)) | 985 | netif_info(de, timer, dev, "%s link ok, status %x\n", |
999 | dev_info(&dev->dev, "%s link ok, status %x\n", | 986 | media_name[de->media_type], status); |
1000 | media_name[de->media_type], status); | ||
1001 | return; | 987 | return; |
1002 | } | 988 | } |
1003 | 989 | ||
@@ -1007,10 +993,10 @@ static void de21040_media_timer (unsigned long data) | |||
1007 | return; | 993 | return; |
1008 | 994 | ||
1009 | if (de->media_type == DE_MEDIA_AUI) { | 995 | if (de->media_type == DE_MEDIA_AUI) { |
1010 | u32 next_state = DE_MEDIA_TP; | 996 | static const u32 next_state = DE_MEDIA_TP; |
1011 | de_next_media(de, &next_state, 1); | 997 | de_next_media(de, &next_state, 1); |
1012 | } else { | 998 | } else { |
1013 | u32 next_state = DE_MEDIA_AUI; | 999 | static const u32 next_state = DE_MEDIA_AUI; |
1014 | de_next_media(de, &next_state, 1); | 1000 | de_next_media(de, &next_state, 1); |
1015 | } | 1001 | } |
1016 | 1002 | ||
@@ -1024,9 +1010,8 @@ no_link_yet: | |||
1024 | de->media_timer.expires = jiffies + DE_TIMER_NO_LINK; | 1010 | de->media_timer.expires = jiffies + DE_TIMER_NO_LINK; |
1025 | add_timer(&de->media_timer); | 1011 | add_timer(&de->media_timer); |
1026 | 1012 | ||
1027 | if (netif_msg_timer(de)) | 1013 | netif_info(de, timer, dev, "no link, trying media %s, status %x\n", |
1028 | dev_info(&dev->dev, "no link, trying media %s, status %x\n", | 1014 | media_name[de->media_type], status); |
1029 | media_name[de->media_type], status); | ||
1030 | } | 1015 | } |
1031 | 1016 | ||
1032 | static unsigned int de_ok_to_advertise (struct de_private *de, u32 new_media) | 1017 | static unsigned int de_ok_to_advertise (struct de_private *de, u32 new_media) |
@@ -1084,11 +1069,10 @@ static void de21041_media_timer (unsigned long data) | |||
1084 | if (!netif_carrier_ok(dev)) | 1069 | if (!netif_carrier_ok(dev)) |
1085 | de_link_up(de); | 1070 | de_link_up(de); |
1086 | else | 1071 | else |
1087 | if (netif_msg_timer(de)) | 1072 | netif_info(de, timer, dev, |
1088 | dev_info(&dev->dev, | 1073 | "%s link ok, mode %x status %x\n", |
1089 | "%s link ok, mode %x status %x\n", | 1074 | media_name[de->media_type], |
1090 | media_name[de->media_type], | 1075 | dr32(MacMode), status); |
1091 | dr32(MacMode), status); | ||
1092 | return; | 1076 | return; |
1093 | } | 1077 | } |
1094 | 1078 | ||
@@ -1135,13 +1119,19 @@ static void de21041_media_timer (unsigned long data) | |||
1135 | * simply resets the PHY and reloads the current media settings. | 1119 | * simply resets the PHY and reloads the current media settings. |
1136 | */ | 1120 | */ |
1137 | if (de->media_type == DE_MEDIA_AUI) { | 1121 | if (de->media_type == DE_MEDIA_AUI) { |
1138 | u32 next_states[] = { DE_MEDIA_BNC, DE_MEDIA_TP_AUTO }; | 1122 | static const u32 next_states[] = { |
1123 | DE_MEDIA_BNC, DE_MEDIA_TP_AUTO | ||
1124 | }; | ||
1139 | de_next_media(de, next_states, ARRAY_SIZE(next_states)); | 1125 | de_next_media(de, next_states, ARRAY_SIZE(next_states)); |
1140 | } else if (de->media_type == DE_MEDIA_BNC) { | 1126 | } else if (de->media_type == DE_MEDIA_BNC) { |
1141 | u32 next_states[] = { DE_MEDIA_TP_AUTO, DE_MEDIA_AUI }; | 1127 | static const u32 next_states[] = { |
1128 | DE_MEDIA_TP_AUTO, DE_MEDIA_AUI | ||
1129 | }; | ||
1142 | de_next_media(de, next_states, ARRAY_SIZE(next_states)); | 1130 | de_next_media(de, next_states, ARRAY_SIZE(next_states)); |
1143 | } else { | 1131 | } else { |
1144 | u32 next_states[] = { DE_MEDIA_AUI, DE_MEDIA_BNC, DE_MEDIA_TP_AUTO }; | 1132 | static const u32 next_states[] = { |
1133 | DE_MEDIA_AUI, DE_MEDIA_BNC, DE_MEDIA_TP_AUTO | ||
1134 | }; | ||
1145 | de_next_media(de, next_states, ARRAY_SIZE(next_states)); | 1135 | de_next_media(de, next_states, ARRAY_SIZE(next_states)); |
1146 | } | 1136 | } |
1147 | 1137 | ||
@@ -1156,9 +1146,8 @@ no_link_yet: | |||
1156 | de->media_timer.expires = jiffies + DE_TIMER_NO_LINK; | 1146 | de->media_timer.expires = jiffies + DE_TIMER_NO_LINK; |
1157 | add_timer(&de->media_timer); | 1147 | add_timer(&de->media_timer); |
1158 | 1148 | ||
1159 | if (netif_msg_timer(de)) | 1149 | netif_info(de, timer, dev, "no link, trying media %s, status %x\n", |
1160 | dev_info(&dev->dev, "no link, trying media %s, status %x\n", | 1150 | media_name[de->media_type], status); |
1161 | media_name[de->media_type], status); | ||
1162 | } | 1151 | } |
1163 | 1152 | ||
1164 | static void de_media_interrupt (struct de_private *de, u32 status) | 1153 | static void de_media_interrupt (struct de_private *de, u32 status) |
@@ -1394,14 +1383,13 @@ static int de_open (struct net_device *dev) | |||
1394 | struct de_private *de = netdev_priv(dev); | 1383 | struct de_private *de = netdev_priv(dev); |
1395 | int rc; | 1384 | int rc; |
1396 | 1385 | ||
1397 | if (netif_msg_ifup(de)) | 1386 | netif_dbg(de, ifup, dev, "enabling interface\n"); |
1398 | printk(KERN_DEBUG "%s: enabling interface\n", dev->name); | ||
1399 | 1387 | ||
1400 | de->rx_buf_sz = (dev->mtu <= 1500 ? PKT_BUF_SZ : dev->mtu + 32); | 1388 | de->rx_buf_sz = (dev->mtu <= 1500 ? PKT_BUF_SZ : dev->mtu + 32); |
1401 | 1389 | ||
1402 | rc = de_alloc_rings(de); | 1390 | rc = de_alloc_rings(de); |
1403 | if (rc) { | 1391 | if (rc) { |
1404 | dev_err(&dev->dev, "ring allocation failure, err=%d\n", rc); | 1392 | netdev_err(dev, "ring allocation failure, err=%d\n", rc); |
1405 | return rc; | 1393 | return rc; |
1406 | } | 1394 | } |
1407 | 1395 | ||
@@ -1409,14 +1397,14 @@ static int de_open (struct net_device *dev) | |||
1409 | 1397 | ||
1410 | rc = request_irq(dev->irq, de_interrupt, IRQF_SHARED, dev->name, dev); | 1398 | rc = request_irq(dev->irq, de_interrupt, IRQF_SHARED, dev->name, dev); |
1411 | if (rc) { | 1399 | if (rc) { |
1412 | dev_err(&dev->dev, "IRQ %d request failure, err=%d\n", | 1400 | netdev_err(dev, "IRQ %d request failure, err=%d\n", |
1413 | dev->irq, rc); | 1401 | dev->irq, rc); |
1414 | goto err_out_free; | 1402 | goto err_out_free; |
1415 | } | 1403 | } |
1416 | 1404 | ||
1417 | rc = de_init_hw(de); | 1405 | rc = de_init_hw(de); |
1418 | if (rc) { | 1406 | if (rc) { |
1419 | dev_err(&dev->dev, "h/w init failure, err=%d\n", rc); | 1407 | netdev_err(dev, "h/w init failure, err=%d\n", rc); |
1420 | goto err_out_free_irq; | 1408 | goto err_out_free_irq; |
1421 | } | 1409 | } |
1422 | 1410 | ||
@@ -1437,8 +1425,7 @@ static int de_close (struct net_device *dev) | |||
1437 | struct de_private *de = netdev_priv(dev); | 1425 | struct de_private *de = netdev_priv(dev); |
1438 | unsigned long flags; | 1426 | unsigned long flags; |
1439 | 1427 | ||
1440 | if (netif_msg_ifdown(de)) | 1428 | netif_dbg(de, ifdown, dev, "disabling interface\n"); |
1441 | printk(KERN_DEBUG "%s: disabling interface\n", dev->name); | ||
1442 | 1429 | ||
1443 | del_timer_sync(&de->media_timer); | 1430 | del_timer_sync(&de->media_timer); |
1444 | 1431 | ||
@@ -1459,9 +1446,9 @@ static void de_tx_timeout (struct net_device *dev) | |||
1459 | { | 1446 | { |
1460 | struct de_private *de = netdev_priv(dev); | 1447 | struct de_private *de = netdev_priv(dev); |
1461 | 1448 | ||
1462 | printk(KERN_DEBUG "%s: NIC status %08x mode %08x sia %08x desc %u/%u/%u\n", | 1449 | netdev_dbg(dev, "NIC status %08x mode %08x sia %08x desc %u/%u/%u\n", |
1463 | dev->name, dr32(MacStatus), dr32(MacMode), dr32(SIAStatus), | 1450 | dr32(MacStatus), dr32(MacMode), dr32(SIAStatus), |
1464 | de->rx_tail, de->tx_head, de->tx_tail); | 1451 | de->rx_tail, de->tx_head, de->tx_tail); |
1465 | 1452 | ||
1466 | del_timer_sync(&de->media_timer); | 1453 | del_timer_sync(&de->media_timer); |
1467 | 1454 | ||
@@ -1511,18 +1498,17 @@ static int __de_get_settings(struct de_private *de, struct ethtool_cmd *ecmd) | |||
1511 | switch (de->media_type) { | 1498 | switch (de->media_type) { |
1512 | case DE_MEDIA_AUI: | 1499 | case DE_MEDIA_AUI: |
1513 | ecmd->port = PORT_AUI; | 1500 | ecmd->port = PORT_AUI; |
1514 | ecmd->speed = 5; | ||
1515 | break; | 1501 | break; |
1516 | case DE_MEDIA_BNC: | 1502 | case DE_MEDIA_BNC: |
1517 | ecmd->port = PORT_BNC; | 1503 | ecmd->port = PORT_BNC; |
1518 | ecmd->speed = 2; | ||
1519 | break; | 1504 | break; |
1520 | default: | 1505 | default: |
1521 | ecmd->port = PORT_TP; | 1506 | ecmd->port = PORT_TP; |
1522 | ecmd->speed = SPEED_10; | ||
1523 | break; | 1507 | break; |
1524 | } | 1508 | } |
1525 | 1509 | ||
1510 | ethtool_cmd_speed_set(ecmd, 10); | ||
1511 | |||
1526 | if (dr32(MacMode) & FullDuplex) | 1512 | if (dr32(MacMode) & FullDuplex) |
1527 | ecmd->duplex = DUPLEX_FULL; | 1513 | ecmd->duplex = DUPLEX_FULL; |
1528 | else | 1514 | else |
@@ -1543,9 +1529,7 @@ static int __de_set_settings(struct de_private *de, struct ethtool_cmd *ecmd) | |||
1543 | u32 new_media; | 1529 | u32 new_media; |
1544 | unsigned int media_lock; | 1530 | unsigned int media_lock; |
1545 | 1531 | ||
1546 | if (ecmd->speed != SPEED_10 && ecmd->speed != 5 && ecmd->speed != 2) | 1532 | if (ethtool_cmd_speed(ecmd) != 10) |
1547 | return -EINVAL; | ||
1548 | if (de->de21040 && ecmd->speed == 2) | ||
1549 | return -EINVAL; | 1533 | return -EINVAL; |
1550 | if (ecmd->duplex != DUPLEX_HALF && ecmd->duplex != DUPLEX_FULL) | 1534 | if (ecmd->duplex != DUPLEX_HALF && ecmd->duplex != DUPLEX_FULL) |
1551 | return -EINVAL; | 1535 | return -EINVAL; |
@@ -1689,9 +1673,8 @@ static int de_nway_reset(struct net_device *dev) | |||
1689 | 1673 | ||
1690 | status = dr32(SIAStatus); | 1674 | status = dr32(SIAStatus); |
1691 | dw32(SIAStatus, (status & ~NWayState) | NWayRestart); | 1675 | dw32(SIAStatus, (status & ~NWayState) | NWayRestart); |
1692 | if (netif_msg_link(de)) | 1676 | netif_info(de, link, dev, "link nway restart, status %x,%x\n", |
1693 | dev_info(&de->dev->dev, "link nway restart, status %x,%x\n", | 1677 | status, dr32(SIAStatus)); |
1694 | status, dr32(SIAStatus)); | ||
1695 | return 0; | 1678 | return 0; |
1696 | } | 1679 | } |
1697 | 1680 | ||
@@ -1736,7 +1719,8 @@ static void __devinit de21040_get_mac_address (struct de_private *de) | |||
1736 | de->dev->dev_addr[i] = value; | 1719 | de->dev->dev_addr[i] = value; |
1737 | udelay(1); | 1720 | udelay(1); |
1738 | if (boguscnt <= 0) | 1721 | if (boguscnt <= 0) |
1739 | pr_warning(PFX "timeout reading 21040 MAC address byte %u\n", i); | 1722 | pr_warn("timeout reading 21040 MAC address byte %u\n", |
1723 | i); | ||
1740 | } | 1724 | } |
1741 | } | 1725 | } |
1742 | 1726 | ||
@@ -1922,8 +1906,10 @@ static void __devinit de21041_get_srom_info (struct de_private *de) | |||
1922 | de->media[idx].csr14, | 1906 | de->media[idx].csr14, |
1923 | de->media[idx].csr15); | 1907 | de->media[idx].csr15); |
1924 | 1908 | ||
1925 | } else if (netif_msg_probe(de)) | 1909 | } else { |
1926 | pr_cont("\n"); | 1910 | if (netif_msg_probe(de)) |
1911 | pr_cont("\n"); | ||
1912 | } | ||
1927 | 1913 | ||
1928 | if (bufp > ((void *)&ee_data[DE_EEPROM_SIZE - 3])) | 1914 | if (bufp > ((void *)&ee_data[DE_EEPROM_SIZE - 3])) |
1929 | break; | 1915 | break; |
@@ -1992,7 +1978,7 @@ static int __devinit de_init_one (struct pci_dev *pdev, | |||
1992 | 1978 | ||
1993 | #ifndef MODULE | 1979 | #ifndef MODULE |
1994 | if (board_idx == 0) | 1980 | if (board_idx == 0) |
1995 | printk("%s", version); | 1981 | pr_info("%s\n", version); |
1996 | #endif | 1982 | #endif |
1997 | 1983 | ||
1998 | /* allocate a new ethernet device structure, and fill in defaults */ | 1984 | /* allocate a new ethernet device structure, and fill in defaults */ |
@@ -2020,7 +2006,6 @@ static int __devinit de_init_one (struct pci_dev *pdev, | |||
2020 | de->media_timer.data = (unsigned long) de; | 2006 | de->media_timer.data = (unsigned long) de; |
2021 | 2007 | ||
2022 | netif_carrier_off(dev); | 2008 | netif_carrier_off(dev); |
2023 | netif_stop_queue(dev); | ||
2024 | 2009 | ||
2025 | /* wake up device, assign resources */ | 2010 | /* wake up device, assign resources */ |
2026 | rc = pci_enable_device(pdev); | 2011 | rc = pci_enable_device(pdev); |
@@ -2035,7 +2020,7 @@ static int __devinit de_init_one (struct pci_dev *pdev, | |||
2035 | /* check for invalid IRQ value */ | 2020 | /* check for invalid IRQ value */ |
2036 | if (pdev->irq < 2) { | 2021 | if (pdev->irq < 2) { |
2037 | rc = -EIO; | 2022 | rc = -EIO; |
2038 | pr_err(PFX "invalid irq (%d) for pci dev %s\n", | 2023 | pr_err("invalid irq (%d) for pci dev %s\n", |
2039 | pdev->irq, pci_name(pdev)); | 2024 | pdev->irq, pci_name(pdev)); |
2040 | goto err_out_res; | 2025 | goto err_out_res; |
2041 | } | 2026 | } |
@@ -2046,12 +2031,12 @@ static int __devinit de_init_one (struct pci_dev *pdev, | |||
2046 | pciaddr = pci_resource_start(pdev, 1); | 2031 | pciaddr = pci_resource_start(pdev, 1); |
2047 | if (!pciaddr) { | 2032 | if (!pciaddr) { |
2048 | rc = -EIO; | 2033 | rc = -EIO; |
2049 | pr_err(PFX "no MMIO resource for pci dev %s\n", pci_name(pdev)); | 2034 | pr_err("no MMIO resource for pci dev %s\n", pci_name(pdev)); |
2050 | goto err_out_res; | 2035 | goto err_out_res; |
2051 | } | 2036 | } |
2052 | if (pci_resource_len(pdev, 1) < DE_REGS_SIZE) { | 2037 | if (pci_resource_len(pdev, 1) < DE_REGS_SIZE) { |
2053 | rc = -EIO; | 2038 | rc = -EIO; |
2054 | pr_err(PFX "MMIO resource (%llx) too small on pci dev %s\n", | 2039 | pr_err("MMIO resource (%llx) too small on pci dev %s\n", |
2055 | (unsigned long long)pci_resource_len(pdev, 1), | 2040 | (unsigned long long)pci_resource_len(pdev, 1), |
2056 | pci_name(pdev)); | 2041 | pci_name(pdev)); |
2057 | goto err_out_res; | 2042 | goto err_out_res; |
@@ -2061,7 +2046,7 @@ static int __devinit de_init_one (struct pci_dev *pdev, | |||
2061 | regs = ioremap_nocache(pciaddr, DE_REGS_SIZE); | 2046 | regs = ioremap_nocache(pciaddr, DE_REGS_SIZE); |
2062 | if (!regs) { | 2047 | if (!regs) { |
2063 | rc = -EIO; | 2048 | rc = -EIO; |
2064 | pr_err(PFX "Cannot map PCI MMIO (%llx@%lx) on pci dev %s\n", | 2049 | pr_err("Cannot map PCI MMIO (%llx@%lx) on pci dev %s\n", |
2065 | (unsigned long long)pci_resource_len(pdev, 1), | 2050 | (unsigned long long)pci_resource_len(pdev, 1), |
2066 | pciaddr, pci_name(pdev)); | 2051 | pciaddr, pci_name(pdev)); |
2067 | goto err_out_res; | 2052 | goto err_out_res; |
@@ -2074,7 +2059,7 @@ static int __devinit de_init_one (struct pci_dev *pdev, | |||
2074 | /* make sure hardware is not running */ | 2059 | /* make sure hardware is not running */ |
2075 | rc = de_reset_mac(de); | 2060 | rc = de_reset_mac(de); |
2076 | if (rc) { | 2061 | if (rc) { |
2077 | pr_err(PFX "Cannot reset MAC, pci dev %s\n", pci_name(pdev)); | 2062 | pr_err("Cannot reset MAC, pci dev %s\n", pci_name(pdev)); |
2078 | goto err_out_iomap; | 2063 | goto err_out_iomap; |
2079 | } | 2064 | } |
2080 | 2065 | ||
@@ -2094,11 +2079,11 @@ static int __devinit de_init_one (struct pci_dev *pdev, | |||
2094 | goto err_out_iomap; | 2079 | goto err_out_iomap; |
2095 | 2080 | ||
2096 | /* print info about board and interface just registered */ | 2081 | /* print info about board and interface just registered */ |
2097 | dev_info(&dev->dev, "%s at 0x%lx, %pM, IRQ %d\n", | 2082 | netdev_info(dev, "%s at 0x%lx, %pM, IRQ %d\n", |
2098 | de->de21040 ? "21040" : "21041", | 2083 | de->de21040 ? "21040" : "21041", |
2099 | dev->base_addr, | 2084 | dev->base_addr, |
2100 | dev->dev_addr, | 2085 | dev->dev_addr, |
2101 | dev->irq); | 2086 | dev->irq); |
2102 | 2087 | ||
2103 | pci_set_drvdata(pdev, dev); | 2088 | pci_set_drvdata(pdev, dev); |
2104 | 2089 | ||
@@ -2186,7 +2171,7 @@ static int de_resume (struct pci_dev *pdev) | |||
2186 | if (!netif_running(dev)) | 2171 | if (!netif_running(dev)) |
2187 | goto out_attach; | 2172 | goto out_attach; |
2188 | if ((retval = pci_enable_device(pdev))) { | 2173 | if ((retval = pci_enable_device(pdev))) { |
2189 | dev_err(&dev->dev, "pci_enable_device failed in resume\n"); | 2174 | netdev_err(dev, "pci_enable_device failed in resume\n"); |
2190 | goto out; | 2175 | goto out; |
2191 | } | 2176 | } |
2192 | pci_set_master(pdev); | 2177 | pci_set_master(pdev); |
@@ -2215,7 +2200,7 @@ static struct pci_driver de_driver = { | |||
2215 | static int __init de_init (void) | 2200 | static int __init de_init (void) |
2216 | { | 2201 | { |
2217 | #ifdef MODULE | 2202 | #ifdef MODULE |
2218 | printk("%s", version); | 2203 | pr_info("%s\n", version); |
2219 | #endif | 2204 | #endif |
2220 | return pci_register_driver(&de_driver); | 2205 | return pci_register_driver(&de_driver); |
2221 | } | 2206 | } |
diff --git a/drivers/net/tulip/de4x5.c b/drivers/net/tulip/de4x5.c index 75a64c88cf7a..efaa1d69b720 100644 --- a/drivers/net/tulip/de4x5.c +++ b/drivers/net/tulip/de4x5.c | |||
@@ -79,7 +79,7 @@ | |||
79 | every usable DECchip board, I pinched Donald's 'next_module' field to | 79 | every usable DECchip board, I pinched Donald's 'next_module' field to |
80 | link my modules together. | 80 | link my modules together. |
81 | 81 | ||
82 | Upto 15 EISA cards can be supported under this driver, limited primarily | 82 | Up to 15 EISA cards can be supported under this driver, limited primarily |
83 | by the available IRQ lines. I have checked different configurations of | 83 | by the available IRQ lines. I have checked different configurations of |
84 | multiple depca, EtherWORKS 3 cards and de4x5 cards and have not found a | 84 | multiple depca, EtherWORKS 3 cards and de4x5 cards and have not found a |
85 | problem yet (provided you have at least depca.c v0.38) ... | 85 | problem yet (provided you have at least depca.c v0.38) ... |
@@ -517,7 +517,7 @@ struct mii_phy { | |||
517 | u_int mci; /* 21142 MII Connector Interrupt info */ | 517 | u_int mci; /* 21142 MII Connector Interrupt info */ |
518 | }; | 518 | }; |
519 | 519 | ||
520 | #define DE4X5_MAX_PHY 8 /* Allow upto 8 attached PHY devices per board */ | 520 | #define DE4X5_MAX_PHY 8 /* Allow up to 8 attached PHY devices per board */ |
521 | 521 | ||
522 | struct sia_phy { | 522 | struct sia_phy { |
523 | u_char mc; /* Media Code */ | 523 | u_char mc; /* Media Code */ |
@@ -1436,7 +1436,7 @@ de4x5_sw_reset(struct net_device *dev) | |||
1436 | 1436 | ||
1437 | /* Poll for setup frame completion (adapter interrupts are disabled now) */ | 1437 | /* Poll for setup frame completion (adapter interrupts are disabled now) */ |
1438 | 1438 | ||
1439 | for (j=0, i=0;(i<500) && (j==0);i++) { /* Upto 500ms delay */ | 1439 | for (j=0, i=0;(i<500) && (j==0);i++) { /* Up to 500ms delay */ |
1440 | mdelay(1); | 1440 | mdelay(1); |
1441 | if ((s32)le32_to_cpu(lp->tx_ring[lp->tx_new].status) >= 0) j=1; | 1441 | if ((s32)le32_to_cpu(lp->tx_ring[lp->tx_new].status) >= 0) j=1; |
1442 | } | 1442 | } |
@@ -1448,7 +1448,7 @@ de4x5_sw_reset(struct net_device *dev) | |||
1448 | status = -EIO; | 1448 | status = -EIO; |
1449 | } | 1449 | } |
1450 | 1450 | ||
1451 | lp->tx_new = (++lp->tx_new) % lp->txRingSize; | 1451 | lp->tx_new = (lp->tx_new + 1) % lp->txRingSize; |
1452 | lp->tx_old = lp->tx_new; | 1452 | lp->tx_old = lp->tx_new; |
1453 | 1453 | ||
1454 | return status; | 1454 | return status; |
@@ -1506,7 +1506,7 @@ de4x5_queue_pkt(struct sk_buff *skb, struct net_device *dev) | |||
1506 | lp->stats.tx_bytes += skb->len; | 1506 | lp->stats.tx_bytes += skb->len; |
1507 | outl(POLL_DEMAND, DE4X5_TPD);/* Start the TX */ | 1507 | outl(POLL_DEMAND, DE4X5_TPD);/* Start the TX */ |
1508 | 1508 | ||
1509 | lp->tx_new = (++lp->tx_new) % lp->txRingSize; | 1509 | lp->tx_new = (lp->tx_new + 1) % lp->txRingSize; |
1510 | 1510 | ||
1511 | if (TX_BUFFS_AVAIL) { | 1511 | if (TX_BUFFS_AVAIL) { |
1512 | netif_start_queue(dev); /* Another pkt may be queued */ | 1512 | netif_start_queue(dev); /* Another pkt may be queued */ |
@@ -1657,7 +1657,7 @@ de4x5_rx(struct net_device *dev) | |||
1657 | } | 1657 | } |
1658 | 1658 | ||
1659 | /* Change buffer ownership for this frame, back to the adapter */ | 1659 | /* Change buffer ownership for this frame, back to the adapter */ |
1660 | for (;lp->rx_old!=entry;lp->rx_old=(++lp->rx_old)%lp->rxRingSize) { | 1660 | for (;lp->rx_old!=entry;lp->rx_old=(lp->rx_old + 1)%lp->rxRingSize) { |
1661 | lp->rx_ring[lp->rx_old].status = cpu_to_le32(R_OWN); | 1661 | lp->rx_ring[lp->rx_old].status = cpu_to_le32(R_OWN); |
1662 | barrier(); | 1662 | barrier(); |
1663 | } | 1663 | } |
@@ -1668,7 +1668,7 @@ de4x5_rx(struct net_device *dev) | |||
1668 | /* | 1668 | /* |
1669 | ** Update entry information | 1669 | ** Update entry information |
1670 | */ | 1670 | */ |
1671 | lp->rx_new = (++lp->rx_new) % lp->rxRingSize; | 1671 | lp->rx_new = (lp->rx_new + 1) % lp->rxRingSize; |
1672 | } | 1672 | } |
1673 | 1673 | ||
1674 | return 0; | 1674 | return 0; |
@@ -1726,7 +1726,7 @@ de4x5_tx(struct net_device *dev) | |||
1726 | } | 1726 | } |
1727 | 1727 | ||
1728 | /* Update all the pointers */ | 1728 | /* Update all the pointers */ |
1729 | lp->tx_old = (++lp->tx_old) % lp->txRingSize; | 1729 | lp->tx_old = (lp->tx_old + 1) % lp->txRingSize; |
1730 | } | 1730 | } |
1731 | 1731 | ||
1732 | /* Any resources available? */ | 1732 | /* Any resources available? */ |
@@ -1801,7 +1801,7 @@ de4x5_rx_ovfc(struct net_device *dev) | |||
1801 | 1801 | ||
1802 | for (; (s32)le32_to_cpu(lp->rx_ring[lp->rx_new].status)>=0;) { | 1802 | for (; (s32)le32_to_cpu(lp->rx_ring[lp->rx_new].status)>=0;) { |
1803 | lp->rx_ring[lp->rx_new].status = cpu_to_le32(R_OWN); | 1803 | lp->rx_ring[lp->rx_new].status = cpu_to_le32(R_OWN); |
1804 | lp->rx_new = (++lp->rx_new % lp->rxRingSize); | 1804 | lp->rx_new = (lp->rx_new + 1) % lp->rxRingSize; |
1805 | } | 1805 | } |
1806 | 1806 | ||
1807 | outl(omr, DE4X5_OMR); | 1807 | outl(omr, DE4X5_OMR); |
@@ -1932,7 +1932,7 @@ set_multicast_list(struct net_device *dev) | |||
1932 | load_packet(dev, lp->setup_frame, TD_IC | PERFECT_F | TD_SET | | 1932 | load_packet(dev, lp->setup_frame, TD_IC | PERFECT_F | TD_SET | |
1933 | SETUP_FRAME_LEN, (struct sk_buff *)1); | 1933 | SETUP_FRAME_LEN, (struct sk_buff *)1); |
1934 | 1934 | ||
1935 | lp->tx_new = (++lp->tx_new) % lp->txRingSize; | 1935 | lp->tx_new = (lp->tx_new + 1) % lp->txRingSize; |
1936 | outl(POLL_DEMAND, DE4X5_TPD); /* Start the TX */ | 1936 | outl(POLL_DEMAND, DE4X5_TPD); /* Start the TX */ |
1937 | dev->trans_start = jiffies; /* prevent tx timeout */ | 1937 | dev->trans_start = jiffies; /* prevent tx timeout */ |
1938 | } | 1938 | } |
@@ -3119,7 +3119,7 @@ dc2114x_autoconf(struct net_device *dev) | |||
3119 | if (lp->media == _100Mb) { | 3119 | if (lp->media == _100Mb) { |
3120 | if ((slnk = test_for_100Mb(dev, 6500)) < 0) { | 3120 | if ((slnk = test_for_100Mb(dev, 6500)) < 0) { |
3121 | lp->media = SPD_DET; | 3121 | lp->media = SPD_DET; |
3122 | return (slnk & ~TIMER_CB); | 3122 | return slnk & ~TIMER_CB; |
3123 | } | 3123 | } |
3124 | } else { | 3124 | } else { |
3125 | if (wait_for_link(dev) < 0) { | 3125 | if (wait_for_link(dev) < 0) { |
@@ -3484,7 +3484,7 @@ is_spd_100(struct net_device *dev) | |||
3484 | spd = ((~gep_rd(dev)) & GEP_SLNK); | 3484 | spd = ((~gep_rd(dev)) & GEP_SLNK); |
3485 | } else { | 3485 | } else { |
3486 | if ((lp->ibn == 2) || !lp->asBitValid) | 3486 | if ((lp->ibn == 2) || !lp->asBitValid) |
3487 | return ((lp->chipset == DC21143)?(~inl(DE4X5_SISR)&SISR_LS100):0); | 3487 | return (lp->chipset == DC21143) ? (~inl(DE4X5_SISR)&SISR_LS100) : 0; |
3488 | 3488 | ||
3489 | spd = (lp->asBitValid & (lp->asPolarity ^ (gep_rd(dev) & lp->asBit))) | | 3489 | spd = (lp->asBitValid & (lp->asPolarity ^ (gep_rd(dev) & lp->asBit))) | |
3490 | (lp->linkOK & ~lp->asBitValid); | 3490 | (lp->linkOK & ~lp->asBitValid); |
@@ -3502,15 +3502,15 @@ is_100_up(struct net_device *dev) | |||
3502 | if (lp->useMII) { | 3502 | if (lp->useMII) { |
3503 | /* Double read for sticky bits & temporary drops */ | 3503 | /* Double read for sticky bits & temporary drops */ |
3504 | mii_rd(MII_SR, lp->phy[lp->active].addr, DE4X5_MII); | 3504 | mii_rd(MII_SR, lp->phy[lp->active].addr, DE4X5_MII); |
3505 | return (mii_rd(MII_SR, lp->phy[lp->active].addr, DE4X5_MII) & MII_SR_LKS); | 3505 | return mii_rd(MII_SR, lp->phy[lp->active].addr, DE4X5_MII) & MII_SR_LKS; |
3506 | } else if (!lp->useSROM) { /* de500-xa */ | 3506 | } else if (!lp->useSROM) { /* de500-xa */ |
3507 | return ((~gep_rd(dev)) & GEP_SLNK); | 3507 | return (~gep_rd(dev)) & GEP_SLNK; |
3508 | } else { | 3508 | } else { |
3509 | if ((lp->ibn == 2) || !lp->asBitValid) | 3509 | if ((lp->ibn == 2) || !lp->asBitValid) |
3510 | return ((lp->chipset == DC21143)?(~inl(DE4X5_SISR)&SISR_LS100):0); | 3510 | return (lp->chipset == DC21143) ? (~inl(DE4X5_SISR)&SISR_LS100) : 0; |
3511 | 3511 | ||
3512 | return ((lp->asBitValid&(lp->asPolarity^(gep_rd(dev)&lp->asBit))) | | 3512 | return (lp->asBitValid&(lp->asPolarity^(gep_rd(dev)&lp->asBit))) | |
3513 | (lp->linkOK & ~lp->asBitValid)); | 3513 | (lp->linkOK & ~lp->asBitValid); |
3514 | } | 3514 | } |
3515 | } | 3515 | } |
3516 | 3516 | ||
@@ -3523,17 +3523,17 @@ is_10_up(struct net_device *dev) | |||
3523 | if (lp->useMII) { | 3523 | if (lp->useMII) { |
3524 | /* Double read for sticky bits & temporary drops */ | 3524 | /* Double read for sticky bits & temporary drops */ |
3525 | mii_rd(MII_SR, lp->phy[lp->active].addr, DE4X5_MII); | 3525 | mii_rd(MII_SR, lp->phy[lp->active].addr, DE4X5_MII); |
3526 | return (mii_rd(MII_SR, lp->phy[lp->active].addr, DE4X5_MII) & MII_SR_LKS); | 3526 | return mii_rd(MII_SR, lp->phy[lp->active].addr, DE4X5_MII) & MII_SR_LKS; |
3527 | } else if (!lp->useSROM) { /* de500-xa */ | 3527 | } else if (!lp->useSROM) { /* de500-xa */ |
3528 | return ((~gep_rd(dev)) & GEP_LNP); | 3528 | return (~gep_rd(dev)) & GEP_LNP; |
3529 | } else { | 3529 | } else { |
3530 | if ((lp->ibn == 2) || !lp->asBitValid) | 3530 | if ((lp->ibn == 2) || !lp->asBitValid) |
3531 | return (((lp->chipset & ~0x00ff) == DC2114x) ? | 3531 | return ((lp->chipset & ~0x00ff) == DC2114x) ? |
3532 | (~inl(DE4X5_SISR)&SISR_LS10): | 3532 | (~inl(DE4X5_SISR)&SISR_LS10): |
3533 | 0); | 3533 | 0; |
3534 | 3534 | ||
3535 | return ((lp->asBitValid&(lp->asPolarity^(gep_rd(dev)&lp->asBit))) | | 3535 | return (lp->asBitValid&(lp->asPolarity^(gep_rd(dev)&lp->asBit))) | |
3536 | (lp->linkOK & ~lp->asBitValid)); | 3536 | (lp->linkOK & ~lp->asBitValid); |
3537 | } | 3537 | } |
3538 | } | 3538 | } |
3539 | 3539 | ||
@@ -3544,7 +3544,7 @@ is_anc_capable(struct net_device *dev) | |||
3544 | u_long iobase = dev->base_addr; | 3544 | u_long iobase = dev->base_addr; |
3545 | 3545 | ||
3546 | if (lp->phy[lp->active].id && (!lp->useSROM || lp->useMII)) { | 3546 | if (lp->phy[lp->active].id && (!lp->useSROM || lp->useMII)) { |
3547 | return (mii_rd(MII_SR, lp->phy[lp->active].addr, DE4X5_MII)); | 3547 | return mii_rd(MII_SR, lp->phy[lp->active].addr, DE4X5_MII); |
3548 | } else if ((lp->chipset & ~0x00ff) == DC2114x) { | 3548 | } else if ((lp->chipset & ~0x00ff) == DC2114x) { |
3549 | return (inl(DE4X5_SISR) & SISR_LPN) >> 12; | 3549 | return (inl(DE4X5_SISR) & SISR_LPN) >> 12; |
3550 | } else { | 3550 | } else { |
@@ -3568,7 +3568,7 @@ ping_media(struct net_device *dev, int msec) | |||
3568 | 3568 | ||
3569 | lp->tmp = lp->tx_new; /* Remember the ring position */ | 3569 | lp->tmp = lp->tx_new; /* Remember the ring position */ |
3570 | load_packet(dev, lp->frame, TD_LS | TD_FS | sizeof(lp->frame), (struct sk_buff *)1); | 3570 | load_packet(dev, lp->frame, TD_LS | TD_FS | sizeof(lp->frame), (struct sk_buff *)1); |
3571 | lp->tx_new = (++lp->tx_new) % lp->txRingSize; | 3571 | lp->tx_new = (lp->tx_new + 1) % lp->txRingSize; |
3572 | outl(POLL_DEMAND, DE4X5_TPD); | 3572 | outl(POLL_DEMAND, DE4X5_TPD); |
3573 | } | 3573 | } |
3574 | 3574 | ||
@@ -4930,7 +4930,7 @@ getfrom_mii(u32 command, u_long ioaddr) | |||
4930 | outl(command | MII_MDC, ioaddr); | 4930 | outl(command | MII_MDC, ioaddr); |
4931 | udelay(1); | 4931 | udelay(1); |
4932 | 4932 | ||
4933 | return ((inl(ioaddr) >> 19) & 1); | 4933 | return (inl(ioaddr) >> 19) & 1; |
4934 | } | 4934 | } |
4935 | 4935 | ||
4936 | /* | 4936 | /* |
@@ -4975,8 +4975,8 @@ mii_get_oui(u_char phyaddr, u_long ioaddr) | |||
4975 | a.breg[0]=a.breg[1]; | 4975 | a.breg[0]=a.breg[1]; |
4976 | a.breg[1]=i; | 4976 | a.breg[1]=i; |
4977 | 4977 | ||
4978 | return ((a.reg<<8)|ret); */ /* SEEQ and Cypress way */ | 4978 | return (a.reg<<8)|ret; */ /* SEEQ and Cypress way */ |
4979 | /* return ((r2<<6)|(u_int)(r3>>10)); */ /* NATIONAL and BROADCOM way */ | 4979 | /* return (r2<<6)|(u_int)(r3>>10); */ /* NATIONAL and BROADCOM way */ |
4980 | return r2; /* (I did it) My way */ | 4980 | return r2; /* (I did it) My way */ |
4981 | } | 4981 | } |
4982 | 4982 | ||
@@ -5144,7 +5144,7 @@ gep_rd(struct net_device *dev) | |||
5144 | if (lp->chipset == DC21140) { | 5144 | if (lp->chipset == DC21140) { |
5145 | return inl(DE4X5_GEP); | 5145 | return inl(DE4X5_GEP); |
5146 | } else if ((lp->chipset & ~0x00ff) == DC2114x) { | 5146 | } else if ((lp->chipset & ~0x00ff) == DC2114x) { |
5147 | return (inl(DE4X5_SIGR) & 0x000fffff); | 5147 | return inl(DE4X5_SIGR) & 0x000fffff; |
5148 | } | 5148 | } |
5149 | 5149 | ||
5150 | return 0; | 5150 | return 0; |
@@ -5417,7 +5417,7 @@ de4x5_ioctl(struct net_device *dev, struct ifreq *rq, int cmd) | |||
5417 | /* Set up the descriptor and give ownership to the card */ | 5417 | /* Set up the descriptor and give ownership to the card */ |
5418 | load_packet(dev, lp->setup_frame, TD_IC | PERFECT_F | TD_SET | | 5418 | load_packet(dev, lp->setup_frame, TD_IC | PERFECT_F | TD_SET | |
5419 | SETUP_FRAME_LEN, (struct sk_buff *)1); | 5419 | SETUP_FRAME_LEN, (struct sk_buff *)1); |
5420 | lp->tx_new = (++lp->tx_new) % lp->txRingSize; | 5420 | lp->tx_new = (lp->tx_new + 1) % lp->txRingSize; |
5421 | outl(POLL_DEMAND, DE4X5_TPD); /* Start the TX */ | 5421 | outl(POLL_DEMAND, DE4X5_TPD); /* Start the TX */ |
5422 | netif_wake_queue(dev); /* Unlock the TX ring */ | 5422 | netif_wake_queue(dev); /* Unlock the TX ring */ |
5423 | break; | 5423 | break; |
@@ -5474,7 +5474,8 @@ de4x5_ioctl(struct net_device *dev, struct ifreq *rq, int cmd) | |||
5474 | tmp.lval[6] = inl(DE4X5_STRR); j+=4; | 5474 | tmp.lval[6] = inl(DE4X5_STRR); j+=4; |
5475 | tmp.lval[7] = inl(DE4X5_SIGR); j+=4; | 5475 | tmp.lval[7] = inl(DE4X5_SIGR); j+=4; |
5476 | ioc->len = j; | 5476 | ioc->len = j; |
5477 | if (copy_to_user(ioc->data, tmp.addr, ioc->len)) return -EFAULT; | 5477 | if (copy_to_user(ioc->data, tmp.lval, ioc->len)) |
5478 | return -EFAULT; | ||
5478 | break; | 5479 | break; |
5479 | 5480 | ||
5480 | #define DE4X5_DUMP 0x0f /* Dump the DE4X5 Status */ | 5481 | #define DE4X5_DUMP 0x0f /* Dump the DE4X5 Status */ |
diff --git a/drivers/net/tulip/dmfe.c b/drivers/net/tulip/dmfe.c index 0bc4f3030a80..9a21ca3873fc 100644 --- a/drivers/net/tulip/dmfe.c +++ b/drivers/net/tulip/dmfe.c | |||
@@ -295,8 +295,7 @@ enum dmfe_CR6_bits { | |||
295 | /* Global variable declaration ----------------------------- */ | 295 | /* Global variable declaration ----------------------------- */ |
296 | static int __devinitdata printed_version; | 296 | static int __devinitdata printed_version; |
297 | static const char version[] __devinitconst = | 297 | static const char version[] __devinitconst = |
298 | KERN_INFO DRV_NAME ": Davicom DM9xxx net driver, version " | 298 | "Davicom DM9xxx net driver, version " DRV_VERSION " (" DRV_RELDATE ")"; |
299 | DRV_VERSION " (" DRV_RELDATE ")\n"; | ||
300 | 299 | ||
301 | static int dmfe_debug; | 300 | static int dmfe_debug; |
302 | static unsigned char dmfe_media_mode = DMFE_AUTO; | 301 | static unsigned char dmfe_media_mode = DMFE_AUTO; |
@@ -381,7 +380,7 @@ static int __devinit dmfe_init_one (struct pci_dev *pdev, | |||
381 | DMFE_DBUG(0, "dmfe_init_one()", 0); | 380 | DMFE_DBUG(0, "dmfe_init_one()", 0); |
382 | 381 | ||
383 | if (!printed_version++) | 382 | if (!printed_version++) |
384 | printk(version); | 383 | pr_info("%s\n", version); |
385 | 384 | ||
386 | /* | 385 | /* |
387 | * SPARC on-board DM910x chips should be handled by the main | 386 | * SPARC on-board DM910x chips should be handled by the main |
@@ -406,7 +405,7 @@ static int __devinit dmfe_init_one (struct pci_dev *pdev, | |||
406 | SET_NETDEV_DEV(dev, &pdev->dev); | 405 | SET_NETDEV_DEV(dev, &pdev->dev); |
407 | 406 | ||
408 | if (pci_set_dma_mask(pdev, DMA_BIT_MASK(32))) { | 407 | if (pci_set_dma_mask(pdev, DMA_BIT_MASK(32))) { |
409 | pr_warning("32-bit PCI DMA not available\n"); | 408 | pr_warn("32-bit PCI DMA not available\n"); |
410 | err = -ENODEV; | 409 | err = -ENODEV; |
411 | goto err_out_free; | 410 | goto err_out_free; |
412 | } | 411 | } |
@@ -599,7 +598,7 @@ static int dmfe_open(struct DEVICE *dev) | |||
599 | init_timer(&db->timer); | 598 | init_timer(&db->timer); |
600 | db->timer.expires = DMFE_TIMER_WUT + HZ * 2; | 599 | db->timer.expires = DMFE_TIMER_WUT + HZ * 2; |
601 | db->timer.data = (unsigned long)dev; | 600 | db->timer.data = (unsigned long)dev; |
602 | db->timer.function = &dmfe_timer; | 601 | db->timer.function = dmfe_timer; |
603 | add_timer(&db->timer); | 602 | add_timer(&db->timer); |
604 | 603 | ||
605 | return 0; | 604 | return 0; |
@@ -688,9 +687,6 @@ static netdev_tx_t dmfe_start_xmit(struct sk_buff *skb, | |||
688 | 687 | ||
689 | DMFE_DBUG(0, "dmfe_start_xmit", 0); | 688 | DMFE_DBUG(0, "dmfe_start_xmit", 0); |
690 | 689 | ||
691 | /* Resource flag check */ | ||
692 | netif_stop_queue(dev); | ||
693 | |||
694 | /* Too large packet check */ | 690 | /* Too large packet check */ |
695 | if (skb->len > MAX_PACKET_SIZE) { | 691 | if (skb->len > MAX_PACKET_SIZE) { |
696 | pr_err("big packet = %d\n", (u16)skb->len); | 692 | pr_err("big packet = %d\n", (u16)skb->len); |
@@ -698,6 +694,9 @@ static netdev_tx_t dmfe_start_xmit(struct sk_buff *skb, | |||
698 | return NETDEV_TX_OK; | 694 | return NETDEV_TX_OK; |
699 | } | 695 | } |
700 | 696 | ||
697 | /* Resource flag check */ | ||
698 | netif_stop_queue(dev); | ||
699 | |||
701 | spin_lock_irqsave(&db->lock, flags); | 700 | spin_lock_irqsave(&db->lock, flags); |
702 | 701 | ||
703 | /* No Tx resource check, it never happen nromally */ | 702 | /* No Tx resource check, it never happen nromally */ |
@@ -880,7 +879,6 @@ static void dmfe_free_tx_pkt(struct DEVICE *dev, struct dmfe_board_info * db) | |||
880 | txptr = db->tx_remove_ptr; | 879 | txptr = db->tx_remove_ptr; |
881 | while(db->tx_packet_cnt) { | 880 | while(db->tx_packet_cnt) { |
882 | tdes0 = le32_to_cpu(txptr->tdes0); | 881 | tdes0 = le32_to_cpu(txptr->tdes0); |
883 | pr_debug("tdes0=%x\n", tdes0); | ||
884 | if (tdes0 & 0x80000000) | 882 | if (tdes0 & 0x80000000) |
885 | break; | 883 | break; |
886 | 884 | ||
@@ -890,7 +888,6 @@ static void dmfe_free_tx_pkt(struct DEVICE *dev, struct dmfe_board_info * db) | |||
890 | 888 | ||
891 | /* Transmit statistic counter */ | 889 | /* Transmit statistic counter */ |
892 | if ( tdes0 != 0x7fffffff ) { | 890 | if ( tdes0 != 0x7fffffff ) { |
893 | pr_debug("tdes0=%x\n", tdes0); | ||
894 | dev->stats.collisions += (tdes0 >> 3) & 0xf; | 891 | dev->stats.collisions += (tdes0 >> 3) & 0xf; |
895 | dev->stats.tx_bytes += le32_to_cpu(txptr->tdes1) & 0x7ff; | 892 | dev->stats.tx_bytes += le32_to_cpu(txptr->tdes1) & 0x7ff; |
896 | if (tdes0 & TDES0_ERR_MASK) { | 893 | if (tdes0 & TDES0_ERR_MASK) { |
@@ -987,7 +984,6 @@ static void dmfe_rx_packet(struct DEVICE *dev, struct dmfe_board_info * db) | |||
987 | /* error summary bit check */ | 984 | /* error summary bit check */ |
988 | if (rdes0 & 0x8000) { | 985 | if (rdes0 & 0x8000) { |
989 | /* This is a error packet */ | 986 | /* This is a error packet */ |
990 | pr_debug("rdes0: %x\n", rdes0); | ||
991 | dev->stats.rx_errors++; | 987 | dev->stats.rx_errors++; |
992 | if (rdes0 & 1) | 988 | if (rdes0 & 1) |
993 | dev->stats.rx_fifo_errors++; | 989 | dev->stats.rx_fifo_errors++; |
@@ -1224,7 +1220,7 @@ static void dmfe_timer(unsigned long data) | |||
1224 | 1220 | ||
1225 | 1221 | ||
1226 | /* If chip reports that link is failed it could be because external | 1222 | /* If chip reports that link is failed it could be because external |
1227 | PHY link status pin is not conected correctly to chip | 1223 | PHY link status pin is not connected correctly to chip |
1228 | To be sure ask PHY too. | 1224 | To be sure ask PHY too. |
1229 | */ | 1225 | */ |
1230 | 1226 | ||
@@ -1639,7 +1635,6 @@ static u8 dmfe_sense_speed(struct dmfe_board_info * db) | |||
1639 | else /* DM9102/DM9102A */ | 1635 | else /* DM9102/DM9102A */ |
1640 | phy_mode = phy_read(db->ioaddr, | 1636 | phy_mode = phy_read(db->ioaddr, |
1641 | db->phy_addr, 17, db->chip_id) & 0xf000; | 1637 | db->phy_addr, 17, db->chip_id) & 0xf000; |
1642 | pr_debug("Phy_mode %x\n", phy_mode); | ||
1643 | switch (phy_mode) { | 1638 | switch (phy_mode) { |
1644 | case 0x1000: db->op_mode = DMFE_10MHF; break; | 1639 | case 0x1000: db->op_mode = DMFE_10MHF; break; |
1645 | case 0x2000: db->op_mode = DMFE_10MFD; break; | 1640 | case 0x2000: db->op_mode = DMFE_10MFD; break; |
@@ -2203,7 +2198,7 @@ static int __init dmfe_init_module(void) | |||
2203 | { | 2198 | { |
2204 | int rc; | 2199 | int rc; |
2205 | 2200 | ||
2206 | printk(version); | 2201 | pr_info("%s\n", version); |
2207 | printed_version = 1; | 2202 | printed_version = 1; |
2208 | 2203 | ||
2209 | DMFE_DBUG(0, "init_module() ", debug); | 2204 | DMFE_DBUG(0, "init_module() ", debug); |
diff --git a/drivers/net/tulip/eeprom.c b/drivers/net/tulip/eeprom.c index 3031ed9c4a1a..fa5eee925f25 100644 --- a/drivers/net/tulip/eeprom.c +++ b/drivers/net/tulip/eeprom.c | |||
@@ -115,7 +115,7 @@ static void __devinit tulip_build_fake_mediatable(struct tulip_private *tp) | |||
115 | 0x02, /* phy reset sequence length */ | 115 | 0x02, /* phy reset sequence length */ |
116 | 0x01, 0x00, /* phy reset sequence */ | 116 | 0x01, 0x00, /* phy reset sequence */ |
117 | 0x00, 0x78, /* media capabilities */ | 117 | 0x00, 0x78, /* media capabilities */ |
118 | 0x00, 0xe0, /* nway advertisment */ | 118 | 0x00, 0xe0, /* nway advertisement */ |
119 | 0x00, 0x05, /* fdx bit map */ | 119 | 0x00, 0x05, /* fdx bit map */ |
120 | 0x00, 0x06 /* ttm bit map */ | 120 | 0x00, 0x06 /* ttm bit map */ |
121 | }; | 121 | }; |
@@ -222,8 +222,8 @@ subsequent_board: | |||
222 | /* there is no phy information, don't even try to build mtable */ | 222 | /* there is no phy information, don't even try to build mtable */ |
223 | if (count == 0) { | 223 | if (count == 0) { |
224 | if (tulip_debug > 0) | 224 | if (tulip_debug > 0) |
225 | pr_warning("%s: no phy info, aborting mtable build\n", | 225 | pr_warn("%s: no phy info, aborting mtable build\n", |
226 | dev->name); | 226 | dev->name); |
227 | return; | 227 | return; |
228 | } | 228 | } |
229 | 229 | ||
diff --git a/drivers/net/tulip/interrupt.c b/drivers/net/tulip/interrupt.c index 1faf7a4d7202..5350d753e0ff 100644 --- a/drivers/net/tulip/interrupt.c +++ b/drivers/net/tulip/interrupt.c | |||
@@ -125,12 +125,12 @@ int tulip_poll(struct napi_struct *napi, int budget) | |||
125 | #endif | 125 | #endif |
126 | 126 | ||
127 | if (tulip_debug > 4) | 127 | if (tulip_debug > 4) |
128 | printk(KERN_DEBUG " In tulip_rx(), entry %d %08x\n", | 128 | netdev_dbg(dev, " In tulip_rx(), entry %d %08x\n", |
129 | entry, tp->rx_ring[entry].status); | 129 | entry, tp->rx_ring[entry].status); |
130 | 130 | ||
131 | do { | 131 | do { |
132 | if (ioread32(tp->base_addr + CSR5) == 0xffffffff) { | 132 | if (ioread32(tp->base_addr + CSR5) == 0xffffffff) { |
133 | printk(KERN_DEBUG " In tulip_poll(), hardware disappeared\n"); | 133 | netdev_dbg(dev, " In tulip_poll(), hardware disappeared\n"); |
134 | break; | 134 | break; |
135 | } | 135 | } |
136 | /* Acknowledge current RX interrupt sources. */ | 136 | /* Acknowledge current RX interrupt sources. */ |
@@ -145,9 +145,9 @@ int tulip_poll(struct napi_struct *napi, int budget) | |||
145 | if (tp->dirty_rx + RX_RING_SIZE == tp->cur_rx) | 145 | if (tp->dirty_rx + RX_RING_SIZE == tp->cur_rx) |
146 | break; | 146 | break; |
147 | 147 | ||
148 | if (tulip_debug > 5) | 148 | if (tulip_debug > 5) |
149 | printk(KERN_DEBUG "%s: In tulip_rx(), entry %d %08x\n", | 149 | netdev_dbg(dev, "In tulip_rx(), entry %d %08x\n", |
150 | dev->name, entry, status); | 150 | entry, status); |
151 | 151 | ||
152 | if (++work_done >= budget) | 152 | if (++work_done >= budget) |
153 | goto not_done; | 153 | goto not_done; |
@@ -180,21 +180,24 @@ int tulip_poll(struct napi_struct *napi, int budget) | |||
180 | dev_warn(&dev->dev, | 180 | dev_warn(&dev->dev, |
181 | "Oversized Ethernet frame spanned multiple buffers, status %08x!\n", | 181 | "Oversized Ethernet frame spanned multiple buffers, status %08x!\n", |
182 | status); | 182 | status); |
183 | tp->stats.rx_length_errors++; | 183 | dev->stats.rx_length_errors++; |
184 | } | 184 | } |
185 | } else { | 185 | } else { |
186 | /* There was a fatal error. */ | 186 | /* There was a fatal error. */ |
187 | if (tulip_debug > 2) | 187 | if (tulip_debug > 2) |
188 | printk(KERN_DEBUG "%s: Receive error, Rx status %08x\n", | 188 | netdev_dbg(dev, "Receive error, Rx status %08x\n", |
189 | dev->name, status); | 189 | status); |
190 | tp->stats.rx_errors++; /* end of a packet.*/ | 190 | dev->stats.rx_errors++; /* end of a packet.*/ |
191 | if (pkt_len > 1518 || | 191 | if (pkt_len > 1518 || |
192 | (status & RxDescRunt)) | 192 | (status & RxDescRunt)) |
193 | tp->stats.rx_length_errors++; | 193 | dev->stats.rx_length_errors++; |
194 | 194 | ||
195 | if (status & 0x0004) tp->stats.rx_frame_errors++; | 195 | if (status & 0x0004) |
196 | if (status & 0x0002) tp->stats.rx_crc_errors++; | 196 | dev->stats.rx_frame_errors++; |
197 | if (status & 0x0001) tp->stats.rx_fifo_errors++; | 197 | if (status & 0x0002) |
198 | dev->stats.rx_crc_errors++; | ||
199 | if (status & 0x0001) | ||
200 | dev->stats.rx_fifo_errors++; | ||
198 | } | 201 | } |
199 | } else { | 202 | } else { |
200 | struct sk_buff *skb; | 203 | struct sk_buff *skb; |
@@ -244,8 +247,8 @@ int tulip_poll(struct napi_struct *napi, int budget) | |||
244 | 247 | ||
245 | netif_receive_skb(skb); | 248 | netif_receive_skb(skb); |
246 | 249 | ||
247 | tp->stats.rx_packets++; | 250 | dev->stats.rx_packets++; |
248 | tp->stats.rx_bytes += pkt_len; | 251 | dev->stats.rx_bytes += pkt_len; |
249 | } | 252 | } |
250 | #ifdef CONFIG_TULIP_NAPI_HW_MITIGATION | 253 | #ifdef CONFIG_TULIP_NAPI_HW_MITIGATION |
251 | received++; | 254 | received++; |
@@ -364,16 +367,16 @@ static int tulip_rx(struct net_device *dev) | |||
364 | int received = 0; | 367 | int received = 0; |
365 | 368 | ||
366 | if (tulip_debug > 4) | 369 | if (tulip_debug > 4) |
367 | printk(KERN_DEBUG " In tulip_rx(), entry %d %08x\n", | 370 | netdev_dbg(dev, "In tulip_rx(), entry %d %08x\n", |
368 | entry, tp->rx_ring[entry].status); | 371 | entry, tp->rx_ring[entry].status); |
369 | /* If we own the next entry, it is a new packet. Send it up. */ | 372 | /* If we own the next entry, it is a new packet. Send it up. */ |
370 | while ( ! (tp->rx_ring[entry].status & cpu_to_le32(DescOwned))) { | 373 | while ( ! (tp->rx_ring[entry].status & cpu_to_le32(DescOwned))) { |
371 | s32 status = le32_to_cpu(tp->rx_ring[entry].status); | 374 | s32 status = le32_to_cpu(tp->rx_ring[entry].status); |
372 | short pkt_len; | 375 | short pkt_len; |
373 | 376 | ||
374 | if (tulip_debug > 5) | 377 | if (tulip_debug > 5) |
375 | printk(KERN_DEBUG "%s: In tulip_rx(), entry %d %08x\n", | 378 | netdev_dbg(dev, "In tulip_rx(), entry %d %08x\n", |
376 | dev->name, entry, status); | 379 | entry, status); |
377 | if (--rx_work_limit < 0) | 380 | if (--rx_work_limit < 0) |
378 | break; | 381 | break; |
379 | 382 | ||
@@ -401,23 +404,26 @@ static int tulip_rx(struct net_device *dev) | |||
401 | /* Ingore earlier buffers. */ | 404 | /* Ingore earlier buffers. */ |
402 | if ((status & 0xffff) != 0x7fff) { | 405 | if ((status & 0xffff) != 0x7fff) { |
403 | if (tulip_debug > 1) | 406 | if (tulip_debug > 1) |
404 | dev_warn(&dev->dev, | 407 | netdev_warn(dev, |
405 | "Oversized Ethernet frame spanned multiple buffers, status %08x!\n", | 408 | "Oversized Ethernet frame spanned multiple buffers, status %08x!\n", |
406 | status); | 409 | status); |
407 | tp->stats.rx_length_errors++; | 410 | dev->stats.rx_length_errors++; |
408 | } | 411 | } |
409 | } else { | 412 | } else { |
410 | /* There was a fatal error. */ | 413 | /* There was a fatal error. */ |
411 | if (tulip_debug > 2) | 414 | if (tulip_debug > 2) |
412 | printk(KERN_DEBUG "%s: Receive error, Rx status %08x\n", | 415 | netdev_dbg(dev, "Receive error, Rx status %08x\n", |
413 | dev->name, status); | 416 | status); |
414 | tp->stats.rx_errors++; /* end of a packet.*/ | 417 | dev->stats.rx_errors++; /* end of a packet.*/ |
415 | if (pkt_len > 1518 || | 418 | if (pkt_len > 1518 || |
416 | (status & RxDescRunt)) | 419 | (status & RxDescRunt)) |
417 | tp->stats.rx_length_errors++; | 420 | dev->stats.rx_length_errors++; |
418 | if (status & 0x0004) tp->stats.rx_frame_errors++; | 421 | if (status & 0x0004) |
419 | if (status & 0x0002) tp->stats.rx_crc_errors++; | 422 | dev->stats.rx_frame_errors++; |
420 | if (status & 0x0001) tp->stats.rx_fifo_errors++; | 423 | if (status & 0x0002) |
424 | dev->stats.rx_crc_errors++; | ||
425 | if (status & 0x0001) | ||
426 | dev->stats.rx_fifo_errors++; | ||
421 | } | 427 | } |
422 | } else { | 428 | } else { |
423 | struct sk_buff *skb; | 429 | struct sk_buff *skb; |
@@ -467,8 +473,8 @@ static int tulip_rx(struct net_device *dev) | |||
467 | 473 | ||
468 | netif_rx(skb); | 474 | netif_rx(skb); |
469 | 475 | ||
470 | tp->stats.rx_packets++; | 476 | dev->stats.rx_packets++; |
471 | tp->stats.rx_bytes += pkt_len; | 477 | dev->stats.rx_bytes += pkt_len; |
472 | } | 478 | } |
473 | received++; | 479 | received++; |
474 | entry = (++tp->cur_rx) % RX_RING_SIZE; | 480 | entry = (++tp->cur_rx) % RX_RING_SIZE; |
@@ -567,8 +573,8 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance) | |||
567 | #endif /* CONFIG_TULIP_NAPI */ | 573 | #endif /* CONFIG_TULIP_NAPI */ |
568 | 574 | ||
569 | if (tulip_debug > 4) | 575 | if (tulip_debug > 4) |
570 | printk(KERN_DEBUG "%s: interrupt csr5=%#8.8x new csr5=%#8.8x\n", | 576 | netdev_dbg(dev, "interrupt csr5=%#8.8x new csr5=%#8.8x\n", |
571 | dev->name, csr5, ioread32(ioaddr + CSR5)); | 577 | csr5, ioread32(ioaddr + CSR5)); |
572 | 578 | ||
573 | 579 | ||
574 | if (csr5 & (TxNoBuf | TxDied | TxIntr | TimerInt)) { | 580 | if (csr5 & (TxNoBuf | TxDied | TxIntr | TimerInt)) { |
@@ -599,21 +605,25 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance) | |||
599 | /* There was an major error, log it. */ | 605 | /* There was an major error, log it. */ |
600 | #ifndef final_version | 606 | #ifndef final_version |
601 | if (tulip_debug > 1) | 607 | if (tulip_debug > 1) |
602 | printk(KERN_DEBUG "%s: Transmit error, Tx status %08x\n", | 608 | netdev_dbg(dev, "Transmit error, Tx status %08x\n", |
603 | dev->name, status); | 609 | status); |
604 | #endif | 610 | #endif |
605 | tp->stats.tx_errors++; | 611 | dev->stats.tx_errors++; |
606 | if (status & 0x4104) tp->stats.tx_aborted_errors++; | 612 | if (status & 0x4104) |
607 | if (status & 0x0C00) tp->stats.tx_carrier_errors++; | 613 | dev->stats.tx_aborted_errors++; |
608 | if (status & 0x0200) tp->stats.tx_window_errors++; | 614 | if (status & 0x0C00) |
609 | if (status & 0x0002) tp->stats.tx_fifo_errors++; | 615 | dev->stats.tx_carrier_errors++; |
616 | if (status & 0x0200) | ||
617 | dev->stats.tx_window_errors++; | ||
618 | if (status & 0x0002) | ||
619 | dev->stats.tx_fifo_errors++; | ||
610 | if ((status & 0x0080) && tp->full_duplex == 0) | 620 | if ((status & 0x0080) && tp->full_duplex == 0) |
611 | tp->stats.tx_heartbeat_errors++; | 621 | dev->stats.tx_heartbeat_errors++; |
612 | } else { | 622 | } else { |
613 | tp->stats.tx_bytes += | 623 | dev->stats.tx_bytes += |
614 | tp->tx_buffers[entry].skb->len; | 624 | tp->tx_buffers[entry].skb->len; |
615 | tp->stats.collisions += (status >> 3) & 15; | 625 | dev->stats.collisions += (status >> 3) & 15; |
616 | tp->stats.tx_packets++; | 626 | dev->stats.tx_packets++; |
617 | } | 627 | } |
618 | 628 | ||
619 | pci_unmap_single(tp->pdev, tp->tx_buffers[entry].mapping, | 629 | pci_unmap_single(tp->pdev, tp->tx_buffers[entry].mapping, |
@@ -655,7 +665,8 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance) | |||
655 | if (csr5 & AbnormalIntr) { /* Abnormal error summary bit. */ | 665 | if (csr5 & AbnormalIntr) { /* Abnormal error summary bit. */ |
656 | if (csr5 == 0xffffffff) | 666 | if (csr5 == 0xffffffff) |
657 | break; | 667 | break; |
658 | if (csr5 & TxJabber) tp->stats.tx_errors++; | 668 | if (csr5 & TxJabber) |
669 | dev->stats.tx_errors++; | ||
659 | if (csr5 & TxFIFOUnderflow) { | 670 | if (csr5 & TxFIFOUnderflow) { |
660 | if ((tp->csr6 & 0xC000) != 0xC000) | 671 | if ((tp->csr6 & 0xC000) != 0xC000) |
661 | tp->csr6 += 0x4000; /* Bump up the Tx threshold */ | 672 | tp->csr6 += 0x4000; /* Bump up the Tx threshold */ |
@@ -672,8 +683,8 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance) | |||
672 | } | 683 | } |
673 | } | 684 | } |
674 | if (csr5 & RxDied) { /* Missed a Rx frame. */ | 685 | if (csr5 & RxDied) { /* Missed a Rx frame. */ |
675 | tp->stats.rx_missed_errors += ioread32(ioaddr + CSR8) & 0xffff; | 686 | dev->stats.rx_missed_errors += ioread32(ioaddr + CSR8) & 0xffff; |
676 | tp->stats.rx_errors++; | 687 | dev->stats.rx_errors++; |
677 | tulip_start_rxtx(tp); | 688 | tulip_start_rxtx(tp); |
678 | } | 689 | } |
679 | /* | 690 | /* |
@@ -789,12 +800,12 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance) | |||
789 | #endif /* CONFIG_TULIP_NAPI */ | 800 | #endif /* CONFIG_TULIP_NAPI */ |
790 | 801 | ||
791 | if ((missed = ioread32(ioaddr + CSR8) & 0x1ffff)) { | 802 | if ((missed = ioread32(ioaddr + CSR8) & 0x1ffff)) { |
792 | tp->stats.rx_dropped += missed & 0x10000 ? 0x10000 : missed; | 803 | dev->stats.rx_dropped += missed & 0x10000 ? 0x10000 : missed; |
793 | } | 804 | } |
794 | 805 | ||
795 | if (tulip_debug > 4) | 806 | if (tulip_debug > 4) |
796 | printk(KERN_DEBUG "%s: exiting interrupt, csr5=%#04x\n", | 807 | netdev_dbg(dev, "exiting interrupt, csr5=%#04x\n", |
797 | dev->name, ioread32(ioaddr + CSR5)); | 808 | ioread32(ioaddr + CSR5)); |
798 | 809 | ||
799 | return IRQ_HANDLED; | 810 | return IRQ_HANDLED; |
800 | } | 811 | } |
diff --git a/drivers/net/tulip/media.c b/drivers/net/tulip/media.c index a0c770ee4b64..4bd13922875d 100644 --- a/drivers/net/tulip/media.c +++ b/drivers/net/tulip/media.c | |||
@@ -182,8 +182,8 @@ void tulip_select_media(struct net_device *dev, int startup) | |||
182 | switch (mleaf->type) { | 182 | switch (mleaf->type) { |
183 | case 0: /* 21140 non-MII xcvr. */ | 183 | case 0: /* 21140 non-MII xcvr. */ |
184 | if (tulip_debug > 1) | 184 | if (tulip_debug > 1) |
185 | printk(KERN_DEBUG "%s: Using a 21140 non-MII transceiver with control setting %02x\n", | 185 | netdev_dbg(dev, "Using a 21140 non-MII transceiver with control setting %02x\n", |
186 | dev->name, p[1]); | 186 | p[1]); |
187 | dev->if_port = p[0]; | 187 | dev->if_port = p[0]; |
188 | if (startup) | 188 | if (startup) |
189 | iowrite32(mtable->csr12dir | 0x100, ioaddr + CSR12); | 189 | iowrite32(mtable->csr12dir | 0x100, ioaddr + CSR12); |
@@ -204,15 +204,14 @@ void tulip_select_media(struct net_device *dev, int startup) | |||
204 | struct medialeaf *rleaf = &mtable->mleaf[mtable->has_reset]; | 204 | struct medialeaf *rleaf = &mtable->mleaf[mtable->has_reset]; |
205 | unsigned char *rst = rleaf->leafdata; | 205 | unsigned char *rst = rleaf->leafdata; |
206 | if (tulip_debug > 1) | 206 | if (tulip_debug > 1) |
207 | printk(KERN_DEBUG "%s: Resetting the transceiver\n", | 207 | netdev_dbg(dev, "Resetting the transceiver\n"); |
208 | dev->name); | ||
209 | for (i = 0; i < rst[0]; i++) | 208 | for (i = 0; i < rst[0]; i++) |
210 | iowrite32(get_u16(rst + 1 + (i<<1)) << 16, ioaddr + CSR15); | 209 | iowrite32(get_u16(rst + 1 + (i<<1)) << 16, ioaddr + CSR15); |
211 | } | 210 | } |
212 | if (tulip_debug > 1) | 211 | if (tulip_debug > 1) |
213 | printk(KERN_DEBUG "%s: 21143 non-MII %s transceiver control %04x/%04x\n", | 212 | netdev_dbg(dev, "21143 non-MII %s transceiver control %04x/%04x\n", |
214 | dev->name, medianame[dev->if_port], | 213 | medianame[dev->if_port], |
215 | setup[0], setup[1]); | 214 | setup[0], setup[1]); |
216 | if (p[0] & 0x40) { /* SIA (CSR13-15) setup values are provided. */ | 215 | if (p[0] & 0x40) { /* SIA (CSR13-15) setup values are provided. */ |
217 | csr13val = setup[0]; | 216 | csr13val = setup[0]; |
218 | csr14val = setup[1]; | 217 | csr14val = setup[1]; |
@@ -239,8 +238,8 @@ void tulip_select_media(struct net_device *dev, int startup) | |||
239 | if (startup) iowrite32(csr13val, ioaddr + CSR13); | 238 | if (startup) iowrite32(csr13val, ioaddr + CSR13); |
240 | } | 239 | } |
241 | if (tulip_debug > 1) | 240 | if (tulip_debug > 1) |
242 | printk(KERN_DEBUG "%s: Setting CSR15 to %08x/%08x\n", | 241 | netdev_dbg(dev, "Setting CSR15 to %08x/%08x\n", |
243 | dev->name, csr15dir, csr15val); | 242 | csr15dir, csr15val); |
244 | if (mleaf->type == 4) | 243 | if (mleaf->type == 4) |
245 | new_csr6 = 0x82020000 | ((setup[2] & 0x71) << 18); | 244 | new_csr6 = 0x82020000 | ((setup[2] & 0x71) << 18); |
246 | else | 245 | else |
@@ -316,9 +315,9 @@ void tulip_select_media(struct net_device *dev, int startup) | |||
316 | if (tp->mii_advertise == 0) | 315 | if (tp->mii_advertise == 0) |
317 | tp->mii_advertise = tp->advertising[phy_num]; | 316 | tp->mii_advertise = tp->advertising[phy_num]; |
318 | if (tulip_debug > 1) | 317 | if (tulip_debug > 1) |
319 | printk(KERN_DEBUG "%s: Advertising %04x on MII %d\n", | 318 | netdev_dbg(dev, " Advertising %04x on MII %d\n", |
320 | dev->name, tp->mii_advertise, | 319 | tp->mii_advertise, |
321 | tp->phys[phy_num]); | 320 | tp->phys[phy_num]); |
322 | tulip_mdio_write(dev, tp->phys[phy_num], 4, tp->mii_advertise); | 321 | tulip_mdio_write(dev, tp->phys[phy_num], 4, tp->mii_advertise); |
323 | } | 322 | } |
324 | break; | 323 | break; |
@@ -335,8 +334,7 @@ void tulip_select_media(struct net_device *dev, int startup) | |||
335 | struct medialeaf *rleaf = &mtable->mleaf[mtable->has_reset]; | 334 | struct medialeaf *rleaf = &mtable->mleaf[mtable->has_reset]; |
336 | unsigned char *rst = rleaf->leafdata; | 335 | unsigned char *rst = rleaf->leafdata; |
337 | if (tulip_debug > 1) | 336 | if (tulip_debug > 1) |
338 | printk(KERN_DEBUG "%s: Resetting the transceiver\n", | 337 | netdev_dbg(dev, "Resetting the transceiver\n"); |
339 | dev->name); | ||
340 | for (i = 0; i < rst[0]; i++) | 338 | for (i = 0; i < rst[0]; i++) |
341 | iowrite32(get_u16(rst + 1 + (i<<1)) << 16, ioaddr + CSR15); | 339 | iowrite32(get_u16(rst + 1 + (i<<1)) << 16, ioaddr + CSR15); |
342 | } | 340 | } |
@@ -344,20 +342,21 @@ void tulip_select_media(struct net_device *dev, int startup) | |||
344 | break; | 342 | break; |
345 | } | 343 | } |
346 | default: | 344 | default: |
347 | printk(KERN_DEBUG "%s: Invalid media table selection %d\n", | 345 | netdev_dbg(dev, " Invalid media table selection %d\n", |
348 | dev->name, mleaf->type); | 346 | mleaf->type); |
349 | new_csr6 = 0x020E0000; | 347 | new_csr6 = 0x020E0000; |
350 | } | 348 | } |
351 | if (tulip_debug > 1) | 349 | if (tulip_debug > 1) |
352 | printk(KERN_DEBUG "%s: Using media type %s, CSR12 is %02x\n", | 350 | netdev_dbg(dev, "Using media type %s, CSR12 is %02x\n", |
353 | dev->name, medianame[dev->if_port], | 351 | medianame[dev->if_port], |
354 | ioread32(ioaddr + CSR12) & 0xff); | 352 | ioread32(ioaddr + CSR12) & 0xff); |
355 | } else if (tp->chip_id == LC82C168) { | 353 | } else if (tp->chip_id == LC82C168) { |
356 | if (startup && ! tp->medialock) | 354 | if (startup && ! tp->medialock) |
357 | dev->if_port = tp->mii_cnt ? 11 : 0; | 355 | dev->if_port = tp->mii_cnt ? 11 : 0; |
358 | if (tulip_debug > 1) | 356 | if (tulip_debug > 1) |
359 | printk(KERN_DEBUG "%s: PNIC PHY status is %3.3x, media %s\n", | 357 | netdev_dbg(dev, "PNIC PHY status is %3.3x, media %s\n", |
360 | dev->name, ioread32(ioaddr + 0xB8), medianame[dev->if_port]); | 358 | ioread32(ioaddr + 0xB8), |
359 | medianame[dev->if_port]); | ||
361 | if (tp->mii_cnt) { | 360 | if (tp->mii_cnt) { |
362 | new_csr6 = 0x810C0000; | 361 | new_csr6 = 0x810C0000; |
363 | iowrite32(0x0001, ioaddr + CSR15); | 362 | iowrite32(0x0001, ioaddr + CSR15); |
@@ -388,9 +387,9 @@ void tulip_select_media(struct net_device *dev, int startup) | |||
388 | } else | 387 | } else |
389 | new_csr6 = 0x03860000; | 388 | new_csr6 = 0x03860000; |
390 | if (tulip_debug > 1) | 389 | if (tulip_debug > 1) |
391 | printk(KERN_DEBUG "%s: No media description table, assuming %s transceiver, CSR12 %02x\n", | 390 | netdev_dbg(dev, "No media description table, assuming %s transceiver, CSR12 %02x\n", |
392 | dev->name, medianame[dev->if_port], | 391 | medianame[dev->if_port], |
393 | ioread32(ioaddr + CSR12)); | 392 | ioread32(ioaddr + CSR12)); |
394 | } | 393 | } |
395 | 394 | ||
396 | tp->csr6 = new_csr6 | (tp->csr6 & 0xfdff) | (tp->full_duplex ? 0x0200 : 0); | 395 | tp->csr6 = new_csr6 | (tp->csr6 & 0xfdff) | (tp->full_duplex ? 0x0200 : 0); |
@@ -504,8 +503,8 @@ void __devinit tulip_find_mii (struct net_device *dev, int board_idx) | |||
504 | 503 | ||
505 | /* Fixup for DLink with miswired PHY. */ | 504 | /* Fixup for DLink with miswired PHY. */ |
506 | if (mii_advert != to_advert) { | 505 | if (mii_advert != to_advert) { |
507 | printk(KERN_DEBUG "tulip%d: Advertising %04x on PHY %d, previously advertising %04x\n", | 506 | pr_debug("tulip%d: Advertising %04x on PHY %d, previously advertising %04x\n", |
508 | board_idx, to_advert, phy, mii_advert); | 507 | board_idx, to_advert, phy, mii_advert); |
509 | tulip_mdio_write (dev, phy, 4, to_advert); | 508 | tulip_mdio_write (dev, phy, 4, to_advert); |
510 | } | 509 | } |
511 | 510 | ||
diff --git a/drivers/net/tulip/pnic.c b/drivers/net/tulip/pnic.c index a63e64b6863d..aa4d9dad0395 100644 --- a/drivers/net/tulip/pnic.c +++ b/drivers/net/tulip/pnic.c | |||
@@ -40,8 +40,8 @@ void pnic_do_nway(struct net_device *dev) | |||
40 | new_csr6 |= 0x00000200; | 40 | new_csr6 |= 0x00000200; |
41 | } | 41 | } |
42 | if (tulip_debug > 1) | 42 | if (tulip_debug > 1) |
43 | printk(KERN_DEBUG "%s: PNIC autonegotiated status %08x, %s\n", | 43 | netdev_dbg(dev, "PNIC autonegotiated status %08x, %s\n", |
44 | dev->name, phy_reg, medianame[dev->if_port]); | 44 | phy_reg, medianame[dev->if_port]); |
45 | if (tp->csr6 != new_csr6) { | 45 | if (tp->csr6 != new_csr6) { |
46 | tp->csr6 = new_csr6; | 46 | tp->csr6 = new_csr6; |
47 | /* Restart Tx */ | 47 | /* Restart Tx */ |
@@ -58,8 +58,8 @@ void pnic_lnk_change(struct net_device *dev, int csr5) | |||
58 | int phy_reg = ioread32(ioaddr + 0xB8); | 58 | int phy_reg = ioread32(ioaddr + 0xB8); |
59 | 59 | ||
60 | if (tulip_debug > 1) | 60 | if (tulip_debug > 1) |
61 | printk(KERN_DEBUG "%s: PNIC link changed state %08x, CSR5 %08x\n", | 61 | netdev_dbg(dev, "PNIC link changed state %08x, CSR5 %08x\n", |
62 | dev->name, phy_reg, csr5); | 62 | phy_reg, csr5); |
63 | if (ioread32(ioaddr + CSR5) & TPLnkFail) { | 63 | if (ioread32(ioaddr + CSR5) & TPLnkFail) { |
64 | iowrite32((ioread32(ioaddr + CSR7) & ~TPLnkFail) | TPLnkPass, ioaddr + CSR7); | 64 | iowrite32((ioread32(ioaddr + CSR7) & ~TPLnkFail) | TPLnkPass, ioaddr + CSR7); |
65 | /* If we use an external MII, then we mustn't use the | 65 | /* If we use an external MII, then we mustn't use the |
@@ -114,8 +114,8 @@ void pnic_timer(unsigned long data) | |||
114 | int csr5 = ioread32(ioaddr + CSR5); | 114 | int csr5 = ioread32(ioaddr + CSR5); |
115 | 115 | ||
116 | if (tulip_debug > 1) | 116 | if (tulip_debug > 1) |
117 | printk(KERN_DEBUG "%s: PNIC timer PHY status %08x, %s CSR5 %08x\n", | 117 | netdev_dbg(dev, "PNIC timer PHY status %08x, %s CSR5 %08x\n", |
118 | dev->name, phy_reg, medianame[dev->if_port], csr5); | 118 | phy_reg, medianame[dev->if_port], csr5); |
119 | if (phy_reg & 0x04000000) { /* Remote link fault */ | 119 | if (phy_reg & 0x04000000) { /* Remote link fault */ |
120 | iowrite32(0x0201F078, ioaddr + 0xB8); | 120 | iowrite32(0x0201F078, ioaddr + 0xB8); |
121 | next_tick = 1*HZ; | 121 | next_tick = 1*HZ; |
@@ -125,11 +125,11 @@ void pnic_timer(unsigned long data) | |||
125 | next_tick = 60*HZ; | 125 | next_tick = 60*HZ; |
126 | } else if (csr5 & TPLnkFail) { /* 100baseTx link beat */ | 126 | } else if (csr5 & TPLnkFail) { /* 100baseTx link beat */ |
127 | if (tulip_debug > 1) | 127 | if (tulip_debug > 1) |
128 | printk(KERN_DEBUG "%s: %s link beat failed, CSR12 %04x, CSR5 %08x, PHY %03x\n", | 128 | netdev_dbg(dev, "%s link beat failed, CSR12 %04x, CSR5 %08x, PHY %03x\n", |
129 | dev->name, medianame[dev->if_port], | 129 | medianame[dev->if_port], |
130 | csr12, | 130 | csr12, |
131 | ioread32(ioaddr + CSR5), | 131 | ioread32(ioaddr + CSR5), |
132 | ioread32(ioaddr + 0xB8)); | 132 | ioread32(ioaddr + 0xB8)); |
133 | next_tick = 3*HZ; | 133 | next_tick = 3*HZ; |
134 | if (tp->medialock) { | 134 | if (tp->medialock) { |
135 | } else if (tp->nwayset && (dev->if_port & 1)) { | 135 | } else if (tp->nwayset && (dev->if_port & 1)) { |
diff --git a/drivers/net/tulip/pnic2.c b/drivers/net/tulip/pnic2.c index b8197666021e..93358ee4d830 100644 --- a/drivers/net/tulip/pnic2.c +++ b/drivers/net/tulip/pnic2.c | |||
@@ -59,7 +59,7 @@ | |||
59 | * Bit 14:12 - autonegotiation state (write 001 to start autonegotiate) | 59 | * Bit 14:12 - autonegotiation state (write 001 to start autonegotiate) |
60 | * Bit 3 - Autopolarity state | 60 | * Bit 3 - Autopolarity state |
61 | * Bit 2 - LS10B - link state of 10baseT 0 - good, 1 - failed | 61 | * Bit 2 - LS10B - link state of 10baseT 0 - good, 1 - failed |
62 | * Bit 1 - LS100B - link state of 100baseT 0 - good, 1- faild | 62 | * Bit 1 - LS100B - link state of 100baseT 0 - good, 1 - failed |
63 | * | 63 | * |
64 | * | 64 | * |
65 | * Data Port Selection Info | 65 | * Data Port Selection Info |
@@ -125,8 +125,8 @@ void pnic2_start_nway(struct net_device *dev) | |||
125 | csr14 |= 0x00001184; | 125 | csr14 |= 0x00001184; |
126 | 126 | ||
127 | if (tulip_debug > 1) | 127 | if (tulip_debug > 1) |
128 | printk(KERN_DEBUG "%s: Restarting PNIC2 autonegotiation, csr14=%08x\n", | 128 | netdev_dbg(dev, "Restarting PNIC2 autonegotiation, csr14=%08x\n", |
129 | dev->name, csr14); | 129 | csr14); |
130 | 130 | ||
131 | /* tell pnic2_lnk_change we are doing an nway negotiation */ | 131 | /* tell pnic2_lnk_change we are doing an nway negotiation */ |
132 | dev->if_port = 0; | 132 | dev->if_port = 0; |
@@ -137,8 +137,7 @@ void pnic2_start_nway(struct net_device *dev) | |||
137 | 137 | ||
138 | tp->csr6 = ioread32(ioaddr + CSR6); | 138 | tp->csr6 = ioread32(ioaddr + CSR6); |
139 | if (tulip_debug > 1) | 139 | if (tulip_debug > 1) |
140 | printk(KERN_DEBUG "%s: On Entry to Nway, csr6=%08x\n", | 140 | netdev_dbg(dev, "On Entry to Nway, csr6=%08x\n", tp->csr6); |
141 | dev->name, tp->csr6); | ||
142 | 141 | ||
143 | /* mask off any bits not to touch | 142 | /* mask off any bits not to touch |
144 | * comment at top of file explains mask value | 143 | * comment at top of file explains mask value |
@@ -271,9 +270,10 @@ void pnic2_lnk_change(struct net_device *dev, int csr5) | |||
271 | iowrite32(1, ioaddr + CSR13); | 270 | iowrite32(1, ioaddr + CSR13); |
272 | 271 | ||
273 | if (tulip_debug > 2) | 272 | if (tulip_debug > 2) |
274 | printk(KERN_DEBUG "%s: Setting CSR6 %08x/%x CSR12 %08x\n", | 273 | netdev_dbg(dev, "Setting CSR6 %08x/%x CSR12 %08x\n", |
275 | dev->name, tp->csr6, | 274 | tp->csr6, |
276 | ioread32(ioaddr + CSR6), ioread32(ioaddr + CSR12)); | 275 | ioread32(ioaddr + CSR6), |
276 | ioread32(ioaddr + CSR12)); | ||
277 | 277 | ||
278 | /* now the following actually writes out the | 278 | /* now the following actually writes out the |
279 | * new csr6 values | 279 | * new csr6 values |
@@ -324,7 +324,7 @@ void pnic2_lnk_change(struct net_device *dev, int csr5) | |||
324 | /* Link blew? Maybe restart NWay. */ | 324 | /* Link blew? Maybe restart NWay. */ |
325 | 325 | ||
326 | if (tulip_debug > 2) | 326 | if (tulip_debug > 2) |
327 | printk(KERN_DEBUG "%s: Ugh! Link blew?\n", dev->name); | 327 | netdev_dbg(dev, "Ugh! Link blew?\n"); |
328 | 328 | ||
329 | del_timer_sync(&tp->timer); | 329 | del_timer_sync(&tp->timer); |
330 | pnic2_start_nway(dev); | 330 | pnic2_start_nway(dev); |
diff --git a/drivers/net/tulip/timer.c b/drivers/net/tulip/timer.c index 36c2725ec886..2017faf2d0e6 100644 --- a/drivers/net/tulip/timer.c +++ b/drivers/net/tulip/timer.c | |||
@@ -28,11 +28,11 @@ void tulip_media_task(struct work_struct *work) | |||
28 | unsigned long flags; | 28 | unsigned long flags; |
29 | 29 | ||
30 | if (tulip_debug > 2) { | 30 | if (tulip_debug > 2) { |
31 | printk(KERN_DEBUG "%s: Media selection tick, %s, status %08x mode %08x SIA %08x %08x %08x %08x\n", | 31 | netdev_dbg(dev, "Media selection tick, %s, status %08x mode %08x SIA %08x %08x %08x %08x\n", |
32 | dev->name, medianame[dev->if_port], | 32 | medianame[dev->if_port], |
33 | ioread32(ioaddr + CSR5), ioread32(ioaddr + CSR6), | 33 | ioread32(ioaddr + CSR5), ioread32(ioaddr + CSR6), |
34 | csr12, ioread32(ioaddr + CSR13), | 34 | csr12, ioread32(ioaddr + CSR13), |
35 | ioread32(ioaddr + CSR14), ioread32(ioaddr + CSR15)); | 35 | ioread32(ioaddr + CSR14), ioread32(ioaddr + CSR15)); |
36 | } | 36 | } |
37 | switch (tp->chip_id) { | 37 | switch (tp->chip_id) { |
38 | case DC21140: | 38 | case DC21140: |
@@ -48,9 +48,9 @@ void tulip_media_task(struct work_struct *work) | |||
48 | Assume this a generic MII or SYM transceiver. */ | 48 | Assume this a generic MII or SYM transceiver. */ |
49 | next_tick = 60*HZ; | 49 | next_tick = 60*HZ; |
50 | if (tulip_debug > 2) | 50 | if (tulip_debug > 2) |
51 | printk(KERN_DEBUG "%s: network media monitor CSR6 %08x CSR12 0x%02x\n", | 51 | netdev_dbg(dev, "network media monitor CSR6 %08x CSR12 0x%02x\n", |
52 | dev->name, | 52 | ioread32(ioaddr + CSR6), |
53 | ioread32(ioaddr + CSR6), csr12 & 0xff); | 53 | csr12 & 0xff); |
54 | break; | 54 | break; |
55 | } | 55 | } |
56 | mleaf = &tp->mtable->mleaf[tp->cur_index]; | 56 | mleaf = &tp->mtable->mleaf[tp->cur_index]; |
@@ -62,8 +62,8 @@ void tulip_media_task(struct work_struct *work) | |||
62 | s8 bitnum = p[offset]; | 62 | s8 bitnum = p[offset]; |
63 | if (p[offset+1] & 0x80) { | 63 | if (p[offset+1] & 0x80) { |
64 | if (tulip_debug > 1) | 64 | if (tulip_debug > 1) |
65 | printk(KERN_DEBUG "%s: Transceiver monitor tick CSR12=%#02x, no media sense\n", | 65 | netdev_dbg(dev, "Transceiver monitor tick CSR12=%#02x, no media sense\n", |
66 | dev->name, csr12); | 66 | csr12); |
67 | if (mleaf->type == 4) { | 67 | if (mleaf->type == 4) { |
68 | if (mleaf->media == 3 && (csr12 & 0x02)) | 68 | if (mleaf->media == 3 && (csr12 & 0x02)) |
69 | goto select_next_media; | 69 | goto select_next_media; |
@@ -71,17 +71,16 @@ void tulip_media_task(struct work_struct *work) | |||
71 | break; | 71 | break; |
72 | } | 72 | } |
73 | if (tulip_debug > 2) | 73 | if (tulip_debug > 2) |
74 | printk(KERN_DEBUG "%s: Transceiver monitor tick: CSR12=%#02x bit %d is %d, expecting %d\n", | 74 | netdev_dbg(dev, "Transceiver monitor tick: CSR12=%#02x bit %d is %d, expecting %d\n", |
75 | dev->name, csr12, (bitnum >> 1) & 7, | 75 | csr12, (bitnum >> 1) & 7, |
76 | (csr12 & (1 << ((bitnum >> 1) & 7))) != 0, | 76 | (csr12 & (1 << ((bitnum >> 1) & 7))) != 0, |
77 | (bitnum >= 0)); | 77 | (bitnum >= 0)); |
78 | /* Check that the specified bit has the proper value. */ | 78 | /* Check that the specified bit has the proper value. */ |
79 | if ((bitnum < 0) != | 79 | if ((bitnum < 0) != |
80 | ((csr12 & (1 << ((bitnum >> 1) & 7))) != 0)) { | 80 | ((csr12 & (1 << ((bitnum >> 1) & 7))) != 0)) { |
81 | if (tulip_debug > 2) | 81 | if (tulip_debug > 2) |
82 | printk(KERN_DEBUG "%s: Link beat detected for %s\n", | 82 | netdev_dbg(dev, "Link beat detected for %s\n", |
83 | dev->name, | 83 | medianame[mleaf->media & MEDIA_MASK]); |
84 | medianame[mleaf->media & MEDIA_MASK]); | ||
85 | if ((p[2] & 0x61) == 0x01) /* Bogus Znyx board. */ | 84 | if ((p[2] & 0x61) == 0x01) /* Bogus Znyx board. */ |
86 | goto actually_mii; | 85 | goto actually_mii; |
87 | netif_carrier_on(dev); | 86 | netif_carrier_on(dev); |
@@ -99,10 +98,9 @@ void tulip_media_task(struct work_struct *work) | |||
99 | if (tulip_media_cap[dev->if_port] & MediaIsFD) | 98 | if (tulip_media_cap[dev->if_port] & MediaIsFD) |
100 | goto select_next_media; /* Skip FD entries. */ | 99 | goto select_next_media; /* Skip FD entries. */ |
101 | if (tulip_debug > 1) | 100 | if (tulip_debug > 1) |
102 | printk(KERN_DEBUG "%s: No link beat on media %s, trying transceiver type %s\n", | 101 | netdev_dbg(dev, "No link beat on media %s, trying transceiver type %s\n", |
103 | dev->name, | 102 | medianame[mleaf->media & MEDIA_MASK], |
104 | medianame[mleaf->media & MEDIA_MASK], | 103 | medianame[tp->mtable->mleaf[tp->cur_index].media]); |
105 | medianame[tp->mtable->mleaf[tp->cur_index].media]); | ||
106 | tulip_select_media(dev, 0); | 104 | tulip_select_media(dev, 0); |
107 | /* Restart the transmit process. */ | 105 | /* Restart the transmit process. */ |
108 | tulip_restart_rxtx(tp); | 106 | tulip_restart_rxtx(tp); |
@@ -166,10 +164,9 @@ void comet_timer(unsigned long data) | |||
166 | int next_tick = 60*HZ; | 164 | int next_tick = 60*HZ; |
167 | 165 | ||
168 | if (tulip_debug > 1) | 166 | if (tulip_debug > 1) |
169 | printk(KERN_DEBUG "%s: Comet link status %04x partner capability %04x\n", | 167 | netdev_dbg(dev, "Comet link status %04x partner capability %04x\n", |
170 | dev->name, | 168 | tulip_mdio_read(dev, tp->phys[0], 1), |
171 | tulip_mdio_read(dev, tp->phys[0], 1), | 169 | tulip_mdio_read(dev, tp->phys[0], 5)); |
172 | tulip_mdio_read(dev, tp->phys[0], 5)); | ||
173 | /* mod_timer synchronizes us with potential add_timer calls | 170 | /* mod_timer synchronizes us with potential add_timer calls |
174 | * from interrupts. | 171 | * from interrupts. |
175 | */ | 172 | */ |
diff --git a/drivers/net/tulip/tulip.h b/drivers/net/tulip/tulip.h index e525875ed67d..9db528967da9 100644 --- a/drivers/net/tulip/tulip.h +++ b/drivers/net/tulip/tulip.h | |||
@@ -417,7 +417,6 @@ struct tulip_private { | |||
417 | int revision; | 417 | int revision; |
418 | int flags; | 418 | int flags; |
419 | struct napi_struct napi; | 419 | struct napi_struct napi; |
420 | struct net_device_stats stats; | ||
421 | struct timer_list timer; /* Media selection timer. */ | 420 | struct timer_list timer; /* Media selection timer. */ |
422 | struct timer_list oom_timer; /* Out of memory timer. */ | 421 | struct timer_list oom_timer; /* Out of memory timer. */ |
423 | u32 mc_filter[2]; | 422 | u32 mc_filter[2]; |
@@ -548,11 +547,9 @@ static inline void tulip_stop_rxtx(struct tulip_private *tp) | |||
548 | udelay(10); | 547 | udelay(10); |
549 | 548 | ||
550 | if (!i) | 549 | if (!i) |
551 | printk(KERN_DEBUG "%s: tulip_stop_rxtx() failed" | 550 | netdev_dbg(tp->dev, "tulip_stop_rxtx() failed (CSR5 0x%x CSR6 0x%x)\n", |
552 | " (CSR5 0x%x CSR6 0x%x)\n", | 551 | ioread32(ioaddr + CSR5), |
553 | pci_name(tp->pdev), | 552 | ioread32(ioaddr + CSR6)); |
554 | ioread32(ioaddr + CSR5), | ||
555 | ioread32(ioaddr + CSR6)); | ||
556 | } | 553 | } |
557 | } | 554 | } |
558 | 555 | ||
@@ -570,7 +567,7 @@ static inline void tulip_tx_timeout_complete(struct tulip_private *tp, void __io | |||
570 | /* Trigger an immediate transmit demand. */ | 567 | /* Trigger an immediate transmit demand. */ |
571 | iowrite32(0, ioaddr + CSR1); | 568 | iowrite32(0, ioaddr + CSR1); |
572 | 569 | ||
573 | tp->stats.tx_errors++; | 570 | tp->dev->stats.tx_errors++; |
574 | } | 571 | } |
575 | 572 | ||
576 | #endif /* __NET_TULIP_H__ */ | 573 | #endif /* __NET_TULIP_H__ */ |
diff --git a/drivers/net/tulip/tulip_core.c b/drivers/net/tulip/tulip_core.c index 3a8d7efa2acf..82f87647207e 100644 --- a/drivers/net/tulip/tulip_core.c +++ b/drivers/net/tulip/tulip_core.c | |||
@@ -12,6 +12,7 @@ | |||
12 | Please submit bugs to http://bugzilla.kernel.org/ . | 12 | Please submit bugs to http://bugzilla.kernel.org/ . |
13 | */ | 13 | */ |
14 | 14 | ||
15 | #define pr_fmt(fmt) "tulip: " fmt | ||
15 | 16 | ||
16 | #define DRV_NAME "tulip" | 17 | #define DRV_NAME "tulip" |
17 | #ifdef CONFIG_TULIP_NAPI | 18 | #ifdef CONFIG_TULIP_NAPI |
@@ -119,8 +120,6 @@ module_param(csr0, int, 0); | |||
119 | module_param_array(options, int, NULL, 0); | 120 | module_param_array(options, int, NULL, 0); |
120 | module_param_array(full_duplex, int, NULL, 0); | 121 | module_param_array(full_duplex, int, NULL, 0); |
121 | 122 | ||
122 | #define PFX DRV_NAME ": " | ||
123 | |||
124 | #ifdef TULIP_DEBUG | 123 | #ifdef TULIP_DEBUG |
125 | int tulip_debug = TULIP_DEBUG; | 124 | int tulip_debug = TULIP_DEBUG; |
126 | #else | 125 | #else |
@@ -331,8 +330,7 @@ static void tulip_up(struct net_device *dev) | |||
331 | udelay(100); | 330 | udelay(100); |
332 | 331 | ||
333 | if (tulip_debug > 1) | 332 | if (tulip_debug > 1) |
334 | printk(KERN_DEBUG "%s: tulip_up(), irq==%d\n", | 333 | netdev_dbg(dev, "tulip_up(), irq==%d\n", dev->irq); |
335 | dev->name, dev->irq); | ||
336 | 334 | ||
337 | iowrite32(tp->rx_ring_dma, ioaddr + CSR3); | 335 | iowrite32(tp->rx_ring_dma, ioaddr + CSR3); |
338 | iowrite32(tp->tx_ring_dma, ioaddr + CSR4); | 336 | iowrite32(tp->tx_ring_dma, ioaddr + CSR4); |
@@ -499,10 +497,10 @@ media_picked: | |||
499 | iowrite32(0, ioaddr + CSR2); /* Rx poll demand */ | 497 | iowrite32(0, ioaddr + CSR2); /* Rx poll demand */ |
500 | 498 | ||
501 | if (tulip_debug > 2) { | 499 | if (tulip_debug > 2) { |
502 | printk(KERN_DEBUG "%s: Done tulip_up(), CSR0 %08x, CSR5 %08x CSR6 %08x\n", | 500 | netdev_dbg(dev, "Done tulip_up(), CSR0 %08x, CSR5 %08x CSR6 %08x\n", |
503 | dev->name, ioread32(ioaddr + CSR0), | 501 | ioread32(ioaddr + CSR0), |
504 | ioread32(ioaddr + CSR5), | 502 | ioread32(ioaddr + CSR5), |
505 | ioread32(ioaddr + CSR6)); | 503 | ioread32(ioaddr + CSR6)); |
506 | } | 504 | } |
507 | 505 | ||
508 | /* Set the timer to switch to check for link beat and perhaps switch | 506 | /* Set the timer to switch to check for link beat and perhaps switch |
@@ -725,7 +723,7 @@ static void tulip_clean_tx_ring(struct tulip_private *tp) | |||
725 | int status = le32_to_cpu(tp->tx_ring[entry].status); | 723 | int status = le32_to_cpu(tp->tx_ring[entry].status); |
726 | 724 | ||
727 | if (status < 0) { | 725 | if (status < 0) { |
728 | tp->stats.tx_errors++; /* It wasn't Txed */ | 726 | tp->dev->stats.tx_errors++; /* It wasn't Txed */ |
729 | tp->tx_ring[entry].status = 0; | 727 | tp->tx_ring[entry].status = 0; |
730 | } | 728 | } |
731 | 729 | ||
@@ -781,8 +779,8 @@ static void tulip_down (struct net_device *dev) | |||
781 | /* release any unconsumed transmit buffers */ | 779 | /* release any unconsumed transmit buffers */ |
782 | tulip_clean_tx_ring(tp); | 780 | tulip_clean_tx_ring(tp); |
783 | 781 | ||
784 | if (ioread32 (ioaddr + CSR6) != 0xffffffff) | 782 | if (ioread32(ioaddr + CSR6) != 0xffffffff) |
785 | tp->stats.rx_missed_errors += ioread32 (ioaddr + CSR8) & 0xffff; | 783 | dev->stats.rx_missed_errors += ioread32(ioaddr + CSR8) & 0xffff; |
786 | 784 | ||
787 | spin_unlock_irqrestore (&tp->lock, flags); | 785 | spin_unlock_irqrestore (&tp->lock, flags); |
788 | 786 | ||
@@ -843,8 +841,7 @@ static int tulip_close (struct net_device *dev) | |||
843 | tulip_down (dev); | 841 | tulip_down (dev); |
844 | 842 | ||
845 | if (tulip_debug > 1) | 843 | if (tulip_debug > 1) |
846 | dev_printk(KERN_DEBUG, &dev->dev, | 844 | netdev_dbg(dev, "Shutting down ethercard, status was %02x\n", |
847 | "Shutting down ethercard, status was %02x\n", | ||
848 | ioread32 (ioaddr + CSR5)); | 845 | ioread32 (ioaddr + CSR5)); |
849 | 846 | ||
850 | free_irq (dev->irq, dev); | 847 | free_irq (dev->irq, dev); |
@@ -864,12 +861,12 @@ static struct net_device_stats *tulip_get_stats(struct net_device *dev) | |||
864 | 861 | ||
865 | spin_lock_irqsave (&tp->lock, flags); | 862 | spin_lock_irqsave (&tp->lock, flags); |
866 | 863 | ||
867 | tp->stats.rx_missed_errors += ioread32(ioaddr + CSR8) & 0xffff; | 864 | dev->stats.rx_missed_errors += ioread32(ioaddr + CSR8) & 0xffff; |
868 | 865 | ||
869 | spin_unlock_irqrestore(&tp->lock, flags); | 866 | spin_unlock_irqrestore(&tp->lock, flags); |
870 | } | 867 | } |
871 | 868 | ||
872 | return &tp->stats; | 869 | return &dev->stats; |
873 | } | 870 | } |
874 | 871 | ||
875 | 872 | ||
@@ -1207,7 +1204,7 @@ static void __devinit tulip_mwi_config (struct pci_dev *pdev, | |||
1207 | u32 csr0; | 1204 | u32 csr0; |
1208 | 1205 | ||
1209 | if (tulip_debug > 3) | 1206 | if (tulip_debug > 3) |
1210 | printk(KERN_DEBUG "%s: tulip_mwi_config()\n", pci_name(pdev)); | 1207 | netdev_dbg(dev, "tulip_mwi_config()\n"); |
1211 | 1208 | ||
1212 | tp->csr0 = csr0 = 0; | 1209 | tp->csr0 = csr0 = 0; |
1213 | 1210 | ||
@@ -1269,8 +1266,8 @@ static void __devinit tulip_mwi_config (struct pci_dev *pdev, | |||
1269 | out: | 1266 | out: |
1270 | tp->csr0 = csr0; | 1267 | tp->csr0 = csr0; |
1271 | if (tulip_debug > 2) | 1268 | if (tulip_debug > 2) |
1272 | printk(KERN_DEBUG "%s: MWI config cacheline=%d, csr0=%08x\n", | 1269 | netdev_dbg(dev, "MWI config cacheline=%d, csr0=%08x\n", |
1273 | pci_name(pdev), cache, csr0); | 1270 | cache, csr0); |
1274 | } | 1271 | } |
1275 | #endif | 1272 | #endif |
1276 | 1273 | ||
@@ -1302,17 +1299,18 @@ static const struct net_device_ops tulip_netdev_ops = { | |||
1302 | #endif | 1299 | #endif |
1303 | }; | 1300 | }; |
1304 | 1301 | ||
1302 | DEFINE_PCI_DEVICE_TABLE(early_486_chipsets) = { | ||
1303 | { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82424) }, | ||
1304 | { PCI_DEVICE(PCI_VENDOR_ID_SI, PCI_DEVICE_ID_SI_496) }, | ||
1305 | { }, | ||
1306 | }; | ||
1307 | |||
1305 | static int __devinit tulip_init_one (struct pci_dev *pdev, | 1308 | static int __devinit tulip_init_one (struct pci_dev *pdev, |
1306 | const struct pci_device_id *ent) | 1309 | const struct pci_device_id *ent) |
1307 | { | 1310 | { |
1308 | struct tulip_private *tp; | 1311 | struct tulip_private *tp; |
1309 | /* See note below on the multiport cards. */ | 1312 | /* See note below on the multiport cards. */ |
1310 | static unsigned char last_phys_addr[6] = {0x00, 'L', 'i', 'n', 'u', 'x'}; | 1313 | static unsigned char last_phys_addr[6] = {0x00, 'L', 'i', 'n', 'u', 'x'}; |
1311 | static struct pci_device_id early_486_chipsets[] = { | ||
1312 | { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82424) }, | ||
1313 | { PCI_DEVICE(PCI_VENDOR_ID_SI, PCI_DEVICE_ID_SI_496) }, | ||
1314 | { }, | ||
1315 | }; | ||
1316 | static int last_irq; | 1314 | static int last_irq; |
1317 | static int multiport_cnt; /* For four-port boards w/one EEPROM */ | 1315 | static int multiport_cnt; /* For four-port boards w/one EEPROM */ |
1318 | int i, irq; | 1316 | int i, irq; |
@@ -1339,13 +1337,13 @@ static int __devinit tulip_init_one (struct pci_dev *pdev, | |||
1339 | */ | 1337 | */ |
1340 | 1338 | ||
1341 | if (pdev->subsystem_vendor == PCI_VENDOR_ID_LMC) { | 1339 | if (pdev->subsystem_vendor == PCI_VENDOR_ID_LMC) { |
1342 | pr_err(PFX "skipping LMC card\n"); | 1340 | pr_err("skipping LMC card\n"); |
1343 | return -ENODEV; | 1341 | return -ENODEV; |
1344 | } else if (pdev->subsystem_vendor == PCI_VENDOR_ID_SBE && | 1342 | } else if (pdev->subsystem_vendor == PCI_VENDOR_ID_SBE && |
1345 | (pdev->subsystem_device == PCI_SUBDEVICE_ID_SBE_T3E3 || | 1343 | (pdev->subsystem_device == PCI_SUBDEVICE_ID_SBE_T3E3 || |
1346 | pdev->subsystem_device == PCI_SUBDEVICE_ID_SBE_2T3E3_P0 || | 1344 | pdev->subsystem_device == PCI_SUBDEVICE_ID_SBE_2T3E3_P0 || |
1347 | pdev->subsystem_device == PCI_SUBDEVICE_ID_SBE_2T3E3_P1)) { | 1345 | pdev->subsystem_device == PCI_SUBDEVICE_ID_SBE_2T3E3_P1)) { |
1348 | pr_err(PFX "skipping SBE T3E3 port\n"); | 1346 | pr_err("skipping SBE T3E3 port\n"); |
1349 | return -ENODEV; | 1347 | return -ENODEV; |
1350 | } | 1348 | } |
1351 | 1349 | ||
@@ -1361,13 +1359,13 @@ static int __devinit tulip_init_one (struct pci_dev *pdev, | |||
1361 | 1359 | ||
1362 | if (pdev->vendor == 0x1282 && pdev->device == 0x9100 && | 1360 | if (pdev->vendor == 0x1282 && pdev->device == 0x9100 && |
1363 | pdev->revision < 0x30) { | 1361 | pdev->revision < 0x30) { |
1364 | pr_info(PFX "skipping early DM9100 with Crc bug (use dmfe)\n"); | 1362 | pr_info("skipping early DM9100 with Crc bug (use dmfe)\n"); |
1365 | return -ENODEV; | 1363 | return -ENODEV; |
1366 | } | 1364 | } |
1367 | 1365 | ||
1368 | dp = pci_device_to_OF_node(pdev); | 1366 | dp = pci_device_to_OF_node(pdev); |
1369 | if (!(dp && of_get_property(dp, "local-mac-address", NULL))) { | 1367 | if (!(dp && of_get_property(dp, "local-mac-address", NULL))) { |
1370 | pr_info(PFX "skipping DM910x expansion card (use dmfe)\n"); | 1368 | pr_info("skipping DM910x expansion card (use dmfe)\n"); |
1371 | return -ENODEV; | 1369 | return -ENODEV; |
1372 | } | 1370 | } |
1373 | } | 1371 | } |
@@ -1414,16 +1412,14 @@ static int __devinit tulip_init_one (struct pci_dev *pdev, | |||
1414 | 1412 | ||
1415 | i = pci_enable_device(pdev); | 1413 | i = pci_enable_device(pdev); |
1416 | if (i) { | 1414 | if (i) { |
1417 | pr_err(PFX "Cannot enable tulip board #%d, aborting\n", | 1415 | pr_err("Cannot enable tulip board #%d, aborting\n", board_idx); |
1418 | board_idx); | ||
1419 | return i; | 1416 | return i; |
1420 | } | 1417 | } |
1421 | 1418 | ||
1422 | /* The chip will fail to enter a low-power state later unless | 1419 | /* The chip will fail to enter a low-power state later unless |
1423 | * first explicitly commanded into D0 */ | 1420 | * first explicitly commanded into D0 */ |
1424 | if (pci_set_power_state(pdev, PCI_D0)) { | 1421 | if (pci_set_power_state(pdev, PCI_D0)) { |
1425 | printk (KERN_NOTICE PFX | 1422 | pr_notice("Failed to set power state to D0\n"); |
1426 | "Failed to set power state to D0\n"); | ||
1427 | } | 1423 | } |
1428 | 1424 | ||
1429 | irq = pdev->irq; | 1425 | irq = pdev->irq; |
@@ -1431,13 +1427,13 @@ static int __devinit tulip_init_one (struct pci_dev *pdev, | |||
1431 | /* alloc_etherdev ensures aligned and zeroed private structures */ | 1427 | /* alloc_etherdev ensures aligned and zeroed private structures */ |
1432 | dev = alloc_etherdev (sizeof (*tp)); | 1428 | dev = alloc_etherdev (sizeof (*tp)); |
1433 | if (!dev) { | 1429 | if (!dev) { |
1434 | pr_err(PFX "ether device alloc failed, aborting\n"); | 1430 | pr_err("ether device alloc failed, aborting\n"); |
1435 | return -ENOMEM; | 1431 | return -ENOMEM; |
1436 | } | 1432 | } |
1437 | 1433 | ||
1438 | SET_NETDEV_DEV(dev, &pdev->dev); | 1434 | SET_NETDEV_DEV(dev, &pdev->dev); |
1439 | if (pci_resource_len (pdev, 0) < tulip_tbl[chip_idx].io_size) { | 1435 | if (pci_resource_len (pdev, 0) < tulip_tbl[chip_idx].io_size) { |
1440 | pr_err(PFX "%s: I/O region (0x%llx@0x%llx) too small, aborting\n", | 1436 | pr_err("%s: I/O region (0x%llx@0x%llx) too small, aborting\n", |
1441 | pci_name(pdev), | 1437 | pci_name(pdev), |
1442 | (unsigned long long)pci_resource_len (pdev, 0), | 1438 | (unsigned long long)pci_resource_len (pdev, 0), |
1443 | (unsigned long long)pci_resource_start (pdev, 0)); | 1439 | (unsigned long long)pci_resource_start (pdev, 0)); |
@@ -1482,7 +1478,8 @@ static int __devinit tulip_init_one (struct pci_dev *pdev, | |||
1482 | if (sig == 0x09811317) { | 1478 | if (sig == 0x09811317) { |
1483 | tp->flags |= COMET_PM; | 1479 | tp->flags |= COMET_PM; |
1484 | tp->wolinfo.supported = WAKE_PHY | WAKE_MAGIC; | 1480 | tp->wolinfo.supported = WAKE_PHY | WAKE_MAGIC; |
1485 | printk(KERN_INFO "tulip_init_one: Enabled WOL support for AN983B\n"); | 1481 | pr_info("%s: Enabled WOL support for AN983B\n", |
1482 | __func__); | ||
1486 | } | 1483 | } |
1487 | } | 1484 | } |
1488 | tp->pdev = pdev; | 1485 | tp->pdev = pdev; |
@@ -1682,7 +1679,9 @@ static int __devinit tulip_init_one (struct pci_dev *pdev, | |||
1682 | tp->full_duplex_lock = 1; | 1679 | tp->full_duplex_lock = 1; |
1683 | 1680 | ||
1684 | if (tulip_media_cap[tp->default_port] & MediaIsMII) { | 1681 | if (tulip_media_cap[tp->default_port] & MediaIsMII) { |
1685 | u16 media2advert[] = { 0x20, 0x40, 0x03e0, 0x60, 0x80, 0x100, 0x200 }; | 1682 | static const u16 media2advert[] = { |
1683 | 0x20, 0x40, 0x03e0, 0x60, 0x80, 0x100, 0x200 | ||
1684 | }; | ||
1686 | tp->mii_advertise = media2advert[tp->default_port - 9]; | 1685 | tp->mii_advertise = media2advert[tp->default_port - 9]; |
1687 | tp->mii_advertise |= (tp->flags & HAS_8023X); /* Matching bits! */ | 1686 | tp->mii_advertise |= (tp->flags & HAS_8023X); /* Matching bits! */ |
1688 | } | 1687 | } |
@@ -1876,7 +1875,7 @@ save_state: | |||
1876 | tulip_set_wolopts(pdev, tp->wolinfo.wolopts); | 1875 | tulip_set_wolopts(pdev, tp->wolinfo.wolopts); |
1877 | rc = pci_enable_wake(pdev, pstate, tp->wolinfo.wolopts); | 1876 | rc = pci_enable_wake(pdev, pstate, tp->wolinfo.wolopts); |
1878 | if (rc) | 1877 | if (rc) |
1879 | printk("tulip: pci_enable_wake failed (%d)\n", rc); | 1878 | pr_err("pci_enable_wake failed (%d)\n", rc); |
1880 | } | 1879 | } |
1881 | pci_set_power_state(pdev, pstate); | 1880 | pci_set_power_state(pdev, pstate); |
1882 | 1881 | ||
@@ -1902,12 +1901,12 @@ static int tulip_resume(struct pci_dev *pdev) | |||
1902 | return 0; | 1901 | return 0; |
1903 | 1902 | ||
1904 | if ((retval = pci_enable_device(pdev))) { | 1903 | if ((retval = pci_enable_device(pdev))) { |
1905 | pr_err(PFX "pci_enable_device failed in resume\n"); | 1904 | pr_err("pci_enable_device failed in resume\n"); |
1906 | return retval; | 1905 | return retval; |
1907 | } | 1906 | } |
1908 | 1907 | ||
1909 | if ((retval = request_irq(dev->irq, tulip_interrupt, IRQF_SHARED, dev->name, dev))) { | 1908 | if ((retval = request_irq(dev->irq, tulip_interrupt, IRQF_SHARED, dev->name, dev))) { |
1910 | pr_err(PFX "request_irq failed in resume\n"); | 1909 | pr_err("request_irq failed in resume\n"); |
1911 | return retval; | 1910 | return retval; |
1912 | } | 1911 | } |
1913 | 1912 | ||
diff --git a/drivers/net/tulip/uli526x.c b/drivers/net/tulip/uli526x.c index 96de5829b940..9e63f406f72d 100644 --- a/drivers/net/tulip/uli526x.c +++ b/drivers/net/tulip/uli526x.c | |||
@@ -209,8 +209,7 @@ enum uli526x_CR6_bits { | |||
209 | /* Global variable declaration ----------------------------- */ | 209 | /* Global variable declaration ----------------------------- */ |
210 | static int __devinitdata printed_version; | 210 | static int __devinitdata printed_version; |
211 | static const char version[] __devinitconst = | 211 | static const char version[] __devinitconst = |
212 | KERN_INFO DRV_NAME ": ULi M5261/M5263 net driver, version " | 212 | "ULi M5261/M5263 net driver, version " DRV_VERSION " (" DRV_RELDATE ")"; |
213 | DRV_VERSION " (" DRV_RELDATE ")\n"; | ||
214 | 213 | ||
215 | static int uli526x_debug; | 214 | static int uli526x_debug; |
216 | static unsigned char uli526x_media_mode = ULI526X_AUTO; | 215 | static unsigned char uli526x_media_mode = ULI526X_AUTO; |
@@ -283,7 +282,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev, | |||
283 | ULI526X_DBUG(0, "uli526x_init_one()", 0); | 282 | ULI526X_DBUG(0, "uli526x_init_one()", 0); |
284 | 283 | ||
285 | if (!printed_version++) | 284 | if (!printed_version++) |
286 | printk(version); | 285 | pr_info("%s\n", version); |
287 | 286 | ||
288 | /* Init network device */ | 287 | /* Init network device */ |
289 | dev = alloc_etherdev(sizeof(*db)); | 288 | dev = alloc_etherdev(sizeof(*db)); |
@@ -292,7 +291,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev, | |||
292 | SET_NETDEV_DEV(dev, &pdev->dev); | 291 | SET_NETDEV_DEV(dev, &pdev->dev); |
293 | 292 | ||
294 | if (pci_set_dma_mask(pdev, DMA_BIT_MASK(32))) { | 293 | if (pci_set_dma_mask(pdev, DMA_BIT_MASK(32))) { |
295 | pr_warning("32-bit PCI DMA not available\n"); | 294 | pr_warn("32-bit PCI DMA not available\n"); |
296 | err = -ENODEV; | 295 | err = -ENODEV; |
297 | goto err_out_free; | 296 | goto err_out_free; |
298 | } | 297 | } |
@@ -390,9 +389,9 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev, | |||
390 | if (err) | 389 | if (err) |
391 | goto err_out_res; | 390 | goto err_out_res; |
392 | 391 | ||
393 | dev_info(&dev->dev, "ULi M%04lx at pci%s, %pM, irq %d\n", | 392 | netdev_info(dev, "ULi M%04lx at pci%s, %pM, irq %d\n", |
394 | ent->driver_data >> 16, pci_name(pdev), | 393 | ent->driver_data >> 16, pci_name(pdev), |
395 | dev->dev_addr, dev->irq); | 394 | dev->dev_addr, dev->irq); |
396 | 395 | ||
397 | pci_set_master(pdev); | 396 | pci_set_master(pdev); |
398 | 397 | ||
@@ -480,7 +479,7 @@ static int uli526x_open(struct net_device *dev) | |||
480 | init_timer(&db->timer); | 479 | init_timer(&db->timer); |
481 | db->timer.expires = ULI526X_TIMER_WUT + HZ * 2; | 480 | db->timer.expires = ULI526X_TIMER_WUT + HZ * 2; |
482 | db->timer.data = (unsigned long)dev; | 481 | db->timer.data = (unsigned long)dev; |
483 | db->timer.function = &uli526x_timer; | 482 | db->timer.function = uli526x_timer; |
484 | add_timer(&db->timer); | 483 | add_timer(&db->timer); |
485 | 484 | ||
486 | return 0; | 485 | return 0; |
@@ -524,7 +523,7 @@ static void uli526x_init(struct net_device *dev) | |||
524 | } | 523 | } |
525 | } | 524 | } |
526 | if(phy_tmp == 32) | 525 | if(phy_tmp == 32) |
527 | pr_warning("Can not find the phy address!!!"); | 526 | pr_warn("Can not find the phy address!!!\n"); |
528 | /* Parser SROM and media mode */ | 527 | /* Parser SROM and media mode */ |
529 | db->media_mode = uli526x_media_mode; | 528 | db->media_mode = uli526x_media_mode; |
530 | 529 | ||
@@ -590,7 +589,7 @@ static netdev_tx_t uli526x_start_xmit(struct sk_buff *skb, | |||
590 | 589 | ||
591 | /* Too large packet check */ | 590 | /* Too large packet check */ |
592 | if (skb->len > MAX_PACKET_SIZE) { | 591 | if (skb->len > MAX_PACKET_SIZE) { |
593 | pr_err("big packet = %d\n", (u16)skb->len); | 592 | netdev_err(dev, "big packet = %d\n", (u16)skb->len); |
594 | dev_kfree_skb(skb); | 593 | dev_kfree_skb(skb); |
595 | return NETDEV_TX_OK; | 594 | return NETDEV_TX_OK; |
596 | } | 595 | } |
@@ -600,7 +599,7 @@ static netdev_tx_t uli526x_start_xmit(struct sk_buff *skb, | |||
600 | /* No Tx resource check, it never happen nromally */ | 599 | /* No Tx resource check, it never happen nromally */ |
601 | if (db->tx_packet_cnt >= TX_FREE_DESC_CNT) { | 600 | if (db->tx_packet_cnt >= TX_FREE_DESC_CNT) { |
602 | spin_unlock_irqrestore(&db->lock, flags); | 601 | spin_unlock_irqrestore(&db->lock, flags); |
603 | pr_err("No Tx resource %ld\n", db->tx_packet_cnt); | 602 | netdev_err(dev, "No Tx resource %ld\n", db->tx_packet_cnt); |
604 | return NETDEV_TX_BUSY; | 603 | return NETDEV_TX_BUSY; |
605 | } | 604 | } |
606 | 605 | ||
@@ -667,15 +666,6 @@ static int uli526x_stop(struct net_device *dev) | |||
667 | /* free allocated rx buffer */ | 666 | /* free allocated rx buffer */ |
668 | uli526x_free_rxbuffer(db); | 667 | uli526x_free_rxbuffer(db); |
669 | 668 | ||
670 | #if 0 | ||
671 | /* show statistic counter */ | ||
672 | printk(DRV_NAME ": FU:%lx EC:%lx LC:%lx NC:%lx LOC:%lx TXJT:%lx RESET:%lx RCR8:%lx FAL:%lx TT:%lx\n", | ||
673 | db->tx_fifo_underrun, db->tx_excessive_collision, | ||
674 | db->tx_late_collision, db->tx_no_carrier, db->tx_loss_carrier, | ||
675 | db->tx_jabber_timeout, db->reset_count, db->reset_cr8, | ||
676 | db->reset_fatal, db->reset_TXtimeout); | ||
677 | #endif | ||
678 | |||
679 | return 0; | 669 | return 0; |
680 | } | 670 | } |
681 | 671 | ||
@@ -755,7 +745,6 @@ static void uli526x_free_tx_pkt(struct net_device *dev, | |||
755 | txptr = db->tx_remove_ptr; | 745 | txptr = db->tx_remove_ptr; |
756 | while(db->tx_packet_cnt) { | 746 | while(db->tx_packet_cnt) { |
757 | tdes0 = le32_to_cpu(txptr->tdes0); | 747 | tdes0 = le32_to_cpu(txptr->tdes0); |
758 | /* printk(DRV_NAME ": tdes0=%x\n", tdes0); */ | ||
759 | if (tdes0 & 0x80000000) | 748 | if (tdes0 & 0x80000000) |
760 | break; | 749 | break; |
761 | 750 | ||
@@ -765,7 +754,6 @@ static void uli526x_free_tx_pkt(struct net_device *dev, | |||
765 | 754 | ||
766 | /* Transmit statistic counter */ | 755 | /* Transmit statistic counter */ |
767 | if ( tdes0 != 0x7fffffff ) { | 756 | if ( tdes0 != 0x7fffffff ) { |
768 | /* printk(DRV_NAME ": tdes0=%x\n", tdes0); */ | ||
769 | dev->stats.collisions += (tdes0 >> 3) & 0xf; | 757 | dev->stats.collisions += (tdes0 >> 3) & 0xf; |
770 | dev->stats.tx_bytes += le32_to_cpu(txptr->tdes1) & 0x7ff; | 758 | dev->stats.tx_bytes += le32_to_cpu(txptr->tdes1) & 0x7ff; |
771 | if (tdes0 & TDES0_ERR_MASK) { | 759 | if (tdes0 & TDES0_ERR_MASK) { |
@@ -838,7 +826,6 @@ static void uli526x_rx_packet(struct net_device *dev, struct uli526x_board_info | |||
838 | /* error summary bit check */ | 826 | /* error summary bit check */ |
839 | if (rdes0 & 0x8000) { | 827 | if (rdes0 & 0x8000) { |
840 | /* This is a error packet */ | 828 | /* This is a error packet */ |
841 | //printk(DRV_NAME ": rdes0: %lx\n", rdes0); | ||
842 | dev->stats.rx_errors++; | 829 | dev->stats.rx_errors++; |
843 | if (rdes0 & 1) | 830 | if (rdes0 & 1) |
844 | dev->stats.rx_fifo_errors++; | 831 | dev->stats.rx_fifo_errors++; |
@@ -945,12 +932,12 @@ ULi_ethtool_gset(struct uli526x_board_info *db, struct ethtool_cmd *ecmd) | |||
945 | 932 | ||
946 | ecmd->transceiver = XCVR_EXTERNAL; | 933 | ecmd->transceiver = XCVR_EXTERNAL; |
947 | 934 | ||
948 | ecmd->speed = 10; | 935 | ethtool_cmd_speed_set(ecmd, SPEED_10); |
949 | ecmd->duplex = DUPLEX_HALF; | 936 | ecmd->duplex = DUPLEX_HALF; |
950 | 937 | ||
951 | if(db->op_mode==ULI526X_100MHF || db->op_mode==ULI526X_100MFD) | 938 | if(db->op_mode==ULI526X_100MHF || db->op_mode==ULI526X_100MFD) |
952 | { | 939 | { |
953 | ecmd->speed = 100; | 940 | ethtool_cmd_speed_set(ecmd, SPEED_100); |
954 | } | 941 | } |
955 | if(db->op_mode==ULI526X_10MFD || db->op_mode==ULI526X_100MFD) | 942 | if(db->op_mode==ULI526X_10MFD || db->op_mode==ULI526X_100MFD) |
956 | { | 943 | { |
@@ -958,7 +945,7 @@ ULi_ethtool_gset(struct uli526x_board_info *db, struct ethtool_cmd *ecmd) | |||
958 | } | 945 | } |
959 | if(db->link_failed) | 946 | if(db->link_failed) |
960 | { | 947 | { |
961 | ecmd->speed = -1; | 948 | ethtool_cmd_speed_set(ecmd, -1); |
962 | ecmd->duplex = -1; | 949 | ecmd->duplex = -1; |
963 | } | 950 | } |
964 | 951 | ||
@@ -1024,7 +1011,6 @@ static void uli526x_timer(unsigned long data) | |||
1024 | struct net_device *dev = (struct net_device *) data; | 1011 | struct net_device *dev = (struct net_device *) data; |
1025 | struct uli526x_board_info *db = netdev_priv(dev); | 1012 | struct uli526x_board_info *db = netdev_priv(dev); |
1026 | unsigned long flags; | 1013 | unsigned long flags; |
1027 | u8 TmpSpeed=10; | ||
1028 | 1014 | ||
1029 | //ULI526X_DBUG(0, "uli526x_timer()", 0); | 1015 | //ULI526X_DBUG(0, "uli526x_timer()", 0); |
1030 | spin_lock_irqsave(&db->lock, flags); | 1016 | spin_lock_irqsave(&db->lock, flags); |
@@ -1047,8 +1033,7 @@ static void uli526x_timer(unsigned long data) | |||
1047 | if ( time_after(jiffies, dev_trans_start(dev) + ULI526X_TX_TIMEOUT) ) { | 1033 | if ( time_after(jiffies, dev_trans_start(dev) + ULI526X_TX_TIMEOUT) ) { |
1048 | db->reset_TXtimeout++; | 1034 | db->reset_TXtimeout++; |
1049 | db->wait_reset = 1; | 1035 | db->wait_reset = 1; |
1050 | printk( "%s: Tx timeout - resetting\n", | 1036 | netdev_err(dev, " Tx timeout - resetting\n"); |
1051 | dev->name); | ||
1052 | } | 1037 | } |
1053 | } | 1038 | } |
1054 | 1039 | ||
@@ -1070,7 +1055,7 @@ static void uli526x_timer(unsigned long data) | |||
1070 | /* Link Failed */ | 1055 | /* Link Failed */ |
1071 | ULI526X_DBUG(0, "Link Failed", tmp_cr12); | 1056 | ULI526X_DBUG(0, "Link Failed", tmp_cr12); |
1072 | netif_carrier_off(dev); | 1057 | netif_carrier_off(dev); |
1073 | pr_info("%s NIC Link is Down\n",dev->name); | 1058 | netdev_info(dev, "NIC Link is Down\n"); |
1074 | db->link_failed = 1; | 1059 | db->link_failed = 1; |
1075 | 1060 | ||
1076 | /* For Force 10/100M Half/Full mode: Enable Auto-Nego mode */ | 1061 | /* For Force 10/100M Half/Full mode: Enable Auto-Nego mode */ |
@@ -1096,18 +1081,13 @@ static void uli526x_timer(unsigned long data) | |||
1096 | 1081 | ||
1097 | if(db->link_failed==0) | 1082 | if(db->link_failed==0) |
1098 | { | 1083 | { |
1099 | if(db->op_mode==ULI526X_100MHF || db->op_mode==ULI526X_100MFD) | 1084 | netdev_info(dev, "NIC Link is Up %d Mbps %s duplex\n", |
1100 | { | 1085 | (db->op_mode == ULI526X_100MHF || |
1101 | TmpSpeed = 100; | 1086 | db->op_mode == ULI526X_100MFD) |
1102 | } | 1087 | ? 100 : 10, |
1103 | if(db->op_mode==ULI526X_10MFD || db->op_mode==ULI526X_100MFD) | 1088 | (db->op_mode == ULI526X_10MFD || |
1104 | { | 1089 | db->op_mode == ULI526X_100MFD) |
1105 | pr_info("%s NIC Link is Up %d Mbps Full duplex\n",dev->name,TmpSpeed); | 1090 | ? "Full" : "Half"); |
1106 | } | ||
1107 | else | ||
1108 | { | ||
1109 | pr_info("%s NIC Link is Up %d Mbps Half duplex\n",dev->name,TmpSpeed); | ||
1110 | } | ||
1111 | netif_carrier_on(dev); | 1091 | netif_carrier_on(dev); |
1112 | } | 1092 | } |
1113 | /* SHOW_MEDIA_TYPE(db->op_mode); */ | 1093 | /* SHOW_MEDIA_TYPE(db->op_mode); */ |
@@ -1116,7 +1096,7 @@ static void uli526x_timer(unsigned long data) | |||
1116 | { | 1096 | { |
1117 | if(db->init==1) | 1097 | if(db->init==1) |
1118 | { | 1098 | { |
1119 | pr_info("%s NIC Link is Down\n",dev->name); | 1099 | netdev_info(dev, "NIC Link is Down\n"); |
1120 | netif_carrier_off(dev); | 1100 | netif_carrier_off(dev); |
1121 | } | 1101 | } |
1122 | } | 1102 | } |
@@ -1242,7 +1222,7 @@ static int uli526x_resume(struct pci_dev *pdev) | |||
1242 | 1222 | ||
1243 | err = pci_set_power_state(pdev, PCI_D0); | 1223 | err = pci_set_power_state(pdev, PCI_D0); |
1244 | if (err) { | 1224 | if (err) { |
1245 | dev_warn(&dev->dev, "Could not put device into D0\n"); | 1225 | netdev_warn(dev, "Could not put device into D0\n"); |
1246 | return err; | 1226 | return err; |
1247 | } | 1227 | } |
1248 | 1228 | ||
@@ -1443,7 +1423,7 @@ static void send_filter_frame(struct net_device *dev, int mc_cnt) | |||
1443 | update_cr6(db->cr6_data, dev->base_addr); | 1423 | update_cr6(db->cr6_data, dev->base_addr); |
1444 | dev->trans_start = jiffies; | 1424 | dev->trans_start = jiffies; |
1445 | } else | 1425 | } else |
1446 | pr_err("No Tx resource - Send_filter_frame!\n"); | 1426 | netdev_err(dev, "No Tx resource - Send_filter_frame!\n"); |
1447 | } | 1427 | } |
1448 | 1428 | ||
1449 | 1429 | ||
@@ -1540,7 +1520,6 @@ static u8 uli526x_sense_speed(struct uli526x_board_info * db) | |||
1540 | else | 1520 | else |
1541 | phy_mode = 0x1000; | 1521 | phy_mode = 0x1000; |
1542 | 1522 | ||
1543 | /* printk(DRV_NAME ": Phy_mode %x ",phy_mode); */ | ||
1544 | switch (phy_mode) { | 1523 | switch (phy_mode) { |
1545 | case 0x1000: db->op_mode = ULI526X_10MHF; break; | 1524 | case 0x1000: db->op_mode = ULI526X_10MHF; break; |
1546 | case 0x2000: db->op_mode = ULI526X_10MFD; break; | 1525 | case 0x2000: db->op_mode = ULI526X_10MFD; break; |
@@ -1747,7 +1726,7 @@ static u16 phy_readby_cr10(unsigned long iobase, u8 phy_addr, u8 offset) | |||
1747 | if(cr10_value&0x10000000) | 1726 | if(cr10_value&0x10000000) |
1748 | break; | 1727 | break; |
1749 | } | 1728 | } |
1750 | return (cr10_value&0x0ffff); | 1729 | return cr10_value & 0x0ffff; |
1751 | } | 1730 | } |
1752 | 1731 | ||
1753 | static void phy_writeby_cr10(unsigned long iobase, u8 phy_addr, u8 offset, u16 phy_data) | 1732 | static void phy_writeby_cr10(unsigned long iobase, u8 phy_addr, u8 offset, u16 phy_data) |
@@ -1829,7 +1808,7 @@ MODULE_PARM_DESC(mode, "ULi M5261/M5263: Bit 0: 10/100Mbps, bit 2: duplex, bit 8 | |||
1829 | static int __init uli526x_init_module(void) | 1808 | static int __init uli526x_init_module(void) |
1830 | { | 1809 | { |
1831 | 1810 | ||
1832 | printk(version); | 1811 | pr_info("%s\n", version); |
1833 | printed_version = 1; | 1812 | printed_version = 1; |
1834 | 1813 | ||
1835 | ULI526X_DBUG(0, "init_module() ", debug); | 1814 | ULI526X_DBUG(0, "init_module() ", debug); |
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. */ |
diff --git a/drivers/net/tulip/xircom_cb.c b/drivers/net/tulip/xircom_cb.c index a439e93be22d..988b8eb24d37 100644 --- a/drivers/net/tulip/xircom_cb.c +++ b/drivers/net/tulip/xircom_cb.c | |||
@@ -29,7 +29,6 @@ | |||
29 | #include <linux/skbuff.h> | 29 | #include <linux/skbuff.h> |
30 | #include <linux/delay.h> | 30 | #include <linux/delay.h> |
31 | #include <linux/init.h> | 31 | #include <linux/init.h> |
32 | #include <linux/ethtool.h> | ||
33 | #include <linux/bitops.h> | 32 | #include <linux/bitops.h> |
34 | 33 | ||
35 | #include <asm/uaccess.h> | 34 | #include <asm/uaccess.h> |
@@ -38,15 +37,6 @@ | |||
38 | #include <asm/irq.h> | 37 | #include <asm/irq.h> |
39 | #endif | 38 | #endif |
40 | 39 | ||
41 | #ifdef DEBUG | ||
42 | #define enter(x) printk("Enter: %s, %s line %i\n",x,__FILE__,__LINE__) | ||
43 | #define leave(x) printk("Leave: %s, %s line %i\n",x,__FILE__,__LINE__) | ||
44 | #else | ||
45 | #define enter(x) do {} while (0) | ||
46 | #define leave(x) do {} while (0) | ||
47 | #endif | ||
48 | |||
49 | |||
50 | MODULE_DESCRIPTION("Xircom Cardbus ethernet driver"); | 40 | MODULE_DESCRIPTION("Xircom Cardbus ethernet driver"); |
51 | MODULE_AUTHOR("Arjan van de Ven <arjanv@redhat.com>"); | 41 | MODULE_AUTHOR("Arjan van de Ven <arjanv@redhat.com>"); |
52 | MODULE_LICENSE("GPL"); | 42 | MODULE_LICENSE("GPL"); |
@@ -162,7 +152,7 @@ static struct pci_driver xircom_ops = { | |||
162 | }; | 152 | }; |
163 | 153 | ||
164 | 154 | ||
165 | #ifdef DEBUG | 155 | #if defined DEBUG && DEBUG > 1 |
166 | static void print_binary(unsigned int number) | 156 | static void print_binary(unsigned int number) |
167 | { | 157 | { |
168 | int i,i2; | 158 | int i,i2; |
@@ -177,23 +167,10 @@ static void print_binary(unsigned int number) | |||
177 | if ((i&3)==0) | 167 | if ((i&3)==0) |
178 | buffer[i2++]=' '; | 168 | buffer[i2++]=' '; |
179 | } | 169 | } |
180 | printk("%s\n",buffer); | 170 | pr_debug("%s\n",buffer); |
181 | } | 171 | } |
182 | #endif | 172 | #endif |
183 | 173 | ||
184 | static void netdev_get_drvinfo(struct net_device *dev, | ||
185 | struct ethtool_drvinfo *info) | ||
186 | { | ||
187 | struct xircom_private *private = netdev_priv(dev); | ||
188 | |||
189 | strcpy(info->driver, "xircom_cb"); | ||
190 | strcpy(info->bus_info, pci_name(private->pdev)); | ||
191 | } | ||
192 | |||
193 | static const struct ethtool_ops netdev_ethtool_ops = { | ||
194 | .get_drvinfo = netdev_get_drvinfo, | ||
195 | }; | ||
196 | |||
197 | static const struct net_device_ops netdev_ops = { | 174 | static const struct net_device_ops netdev_ops = { |
198 | .ndo_open = xircom_open, | 175 | .ndo_open = xircom_open, |
199 | .ndo_stop = xircom_close, | 176 | .ndo_stop = xircom_close, |
@@ -219,7 +196,6 @@ static int __devinit xircom_probe(struct pci_dev *pdev, const struct pci_device_ | |||
219 | struct xircom_private *private; | 196 | struct xircom_private *private; |
220 | unsigned long flags; | 197 | unsigned long flags; |
221 | unsigned short tmp16; | 198 | unsigned short tmp16; |
222 | enter("xircom_probe"); | ||
223 | 199 | ||
224 | /* First do the PCI initialisation */ | 200 | /* First do the PCI initialisation */ |
225 | 201 | ||
@@ -279,7 +255,6 @@ static int __devinit xircom_probe(struct pci_dev *pdev, const struct pci_device_ | |||
279 | setup_descriptors(private); | 255 | setup_descriptors(private); |
280 | 256 | ||
281 | dev->netdev_ops = &netdev_ops; | 257 | dev->netdev_ops = &netdev_ops; |
282 | SET_ETHTOOL_OPS(dev, &netdev_ethtool_ops); | ||
283 | pci_set_drvdata(pdev, dev); | 258 | pci_set_drvdata(pdev, dev); |
284 | 259 | ||
285 | if (register_netdev(dev)) { | 260 | if (register_netdev(dev)) { |
@@ -287,8 +262,8 @@ static int __devinit xircom_probe(struct pci_dev *pdev, const struct pci_device_ | |||
287 | goto reg_fail; | 262 | goto reg_fail; |
288 | } | 263 | } |
289 | 264 | ||
290 | dev_info(&dev->dev, "Xircom cardbus revision %i at irq %i\n", | 265 | netdev_info(dev, "Xircom cardbus revision %i at irq %i\n", |
291 | pdev->revision, pdev->irq); | 266 | pdev->revision, pdev->irq); |
292 | /* start the transmitter to get a heartbeat */ | 267 | /* start the transmitter to get a heartbeat */ |
293 | /* TODO: send 2 dummy packets here */ | 268 | /* TODO: send 2 dummy packets here */ |
294 | transceiver_voodoo(private); | 269 | transceiver_voodoo(private); |
@@ -300,7 +275,6 @@ static int __devinit xircom_probe(struct pci_dev *pdev, const struct pci_device_ | |||
300 | 275 | ||
301 | trigger_receive(private); | 276 | trigger_receive(private); |
302 | 277 | ||
303 | leave("xircom_probe"); | ||
304 | return 0; | 278 | return 0; |
305 | 279 | ||
306 | reg_fail: | 280 | reg_fail: |
@@ -325,7 +299,6 @@ static void __devexit xircom_remove(struct pci_dev *pdev) | |||
325 | struct net_device *dev = pci_get_drvdata(pdev); | 299 | struct net_device *dev = pci_get_drvdata(pdev); |
326 | struct xircom_private *card = netdev_priv(dev); | 300 | struct xircom_private *card = netdev_priv(dev); |
327 | 301 | ||
328 | enter("xircom_remove"); | ||
329 | pci_free_consistent(pdev,8192,card->rx_buffer,card->rx_dma_handle); | 302 | pci_free_consistent(pdev,8192,card->rx_buffer,card->rx_dma_handle); |
330 | pci_free_consistent(pdev,8192,card->tx_buffer,card->tx_dma_handle); | 303 | pci_free_consistent(pdev,8192,card->tx_buffer,card->tx_dma_handle); |
331 | 304 | ||
@@ -333,7 +306,6 @@ static void __devexit xircom_remove(struct pci_dev *pdev) | |||
333 | unregister_netdev(dev); | 306 | unregister_netdev(dev); |
334 | free_netdev(dev); | 307 | free_netdev(dev); |
335 | pci_set_drvdata(pdev, NULL); | 308 | pci_set_drvdata(pdev, NULL); |
336 | leave("xircom_remove"); | ||
337 | } | 309 | } |
338 | 310 | ||
339 | static irqreturn_t xircom_interrupt(int irq, void *dev_instance) | 311 | static irqreturn_t xircom_interrupt(int irq, void *dev_instance) |
@@ -343,17 +315,15 @@ static irqreturn_t xircom_interrupt(int irq, void *dev_instance) | |||
343 | unsigned int status; | 315 | unsigned int status; |
344 | int i; | 316 | int i; |
345 | 317 | ||
346 | enter("xircom_interrupt\n"); | ||
347 | |||
348 | spin_lock(&card->lock); | 318 | spin_lock(&card->lock); |
349 | status = inl(card->io_port+CSR5); | 319 | status = inl(card->io_port+CSR5); |
350 | 320 | ||
351 | #ifdef DEBUG | 321 | #if defined DEBUG && DEBUG > 1 |
352 | print_binary(status); | 322 | print_binary(status); |
353 | printk("tx status 0x%08x 0x%08x\n", | 323 | pr_debug("tx status 0x%08x 0x%08x\n", |
354 | card->tx_buffer[0], card->tx_buffer[4]); | 324 | card->tx_buffer[0], card->tx_buffer[4]); |
355 | printk("rx status 0x%08x 0x%08x\n", | 325 | pr_debug("rx status 0x%08x 0x%08x\n", |
356 | card->rx_buffer[0], card->rx_buffer[4]); | 326 | card->rx_buffer[0], card->rx_buffer[4]); |
357 | #endif | 327 | #endif |
358 | /* Handle shared irq and hotplug */ | 328 | /* Handle shared irq and hotplug */ |
359 | if (status == 0 || status == 0xffffffff) { | 329 | if (status == 0 || status == 0xffffffff) { |
@@ -363,9 +333,9 @@ static irqreturn_t xircom_interrupt(int irq, void *dev_instance) | |||
363 | 333 | ||
364 | if (link_status_changed(card)) { | 334 | if (link_status_changed(card)) { |
365 | int newlink; | 335 | int newlink; |
366 | printk(KERN_DEBUG "xircom_cb: Link status has changed\n"); | 336 | netdev_dbg(dev, "Link status has changed\n"); |
367 | newlink = link_status(card); | 337 | newlink = link_status(card); |
368 | dev_info(&dev->dev, "Link is %i mbit\n", newlink); | 338 | netdev_info(dev, "Link is %d mbit\n", newlink); |
369 | if (newlink) | 339 | if (newlink) |
370 | netif_carrier_on(dev); | 340 | netif_carrier_on(dev); |
371 | else | 341 | else |
@@ -384,9 +354,7 @@ static irqreturn_t xircom_interrupt(int irq, void *dev_instance) | |||
384 | for (i=0;i<NUMDESCRIPTORS;i++) | 354 | for (i=0;i<NUMDESCRIPTORS;i++) |
385 | investigate_read_descriptor(dev,card,i,bufferoffsets[i]); | 355 | investigate_read_descriptor(dev,card,i,bufferoffsets[i]); |
386 | 356 | ||
387 | |||
388 | spin_unlock(&card->lock); | 357 | spin_unlock(&card->lock); |
389 | leave("xircom_interrupt"); | ||
390 | return IRQ_HANDLED; | 358 | return IRQ_HANDLED; |
391 | } | 359 | } |
392 | 360 | ||
@@ -397,7 +365,6 @@ static netdev_tx_t xircom_start_xmit(struct sk_buff *skb, | |||
397 | unsigned long flags; | 365 | unsigned long flags; |
398 | int nextdescriptor; | 366 | int nextdescriptor; |
399 | int desc; | 367 | int desc; |
400 | enter("xircom_start_xmit"); | ||
401 | 368 | ||
402 | card = netdev_priv(dev); | 369 | card = netdev_priv(dev); |
403 | spin_lock_irqsave(&card->lock,flags); | 370 | spin_lock_irqsave(&card->lock,flags); |
@@ -439,13 +406,10 @@ static netdev_tx_t xircom_start_xmit(struct sk_buff *skb, | |||
439 | netif_stop_queue(dev); | 406 | netif_stop_queue(dev); |
440 | } | 407 | } |
441 | card->transmit_used = nextdescriptor; | 408 | card->transmit_used = nextdescriptor; |
442 | leave("xircom-start_xmit - sent"); | ||
443 | spin_unlock_irqrestore(&card->lock,flags); | 409 | spin_unlock_irqrestore(&card->lock,flags); |
444 | return NETDEV_TX_OK; | 410 | return NETDEV_TX_OK; |
445 | } | 411 | } |
446 | 412 | ||
447 | |||
448 | |||
449 | /* Uh oh... no free descriptor... drop the packet */ | 413 | /* Uh oh... no free descriptor... drop the packet */ |
450 | netif_stop_queue(dev); | 414 | netif_stop_queue(dev); |
451 | spin_unlock_irqrestore(&card->lock,flags); | 415 | spin_unlock_irqrestore(&card->lock,flags); |
@@ -461,18 +425,16 @@ static int xircom_open(struct net_device *dev) | |||
461 | { | 425 | { |
462 | struct xircom_private *xp = netdev_priv(dev); | 426 | struct xircom_private *xp = netdev_priv(dev); |
463 | int retval; | 427 | int retval; |
464 | enter("xircom_open"); | 428 | |
465 | pr_info("xircom cardbus adaptor found, registering as %s, using irq %i\n", | 429 | netdev_info(dev, "xircom cardbus adaptor found, using irq %i\n", |
466 | dev->name, dev->irq); | 430 | dev->irq); |
467 | retval = request_irq(dev->irq, xircom_interrupt, IRQF_SHARED, dev->name, dev); | 431 | retval = request_irq(dev->irq, xircom_interrupt, IRQF_SHARED, dev->name, dev); |
468 | if (retval) { | 432 | if (retval) |
469 | leave("xircom_open - No IRQ"); | ||
470 | return retval; | 433 | return retval; |
471 | } | ||
472 | 434 | ||
473 | xircom_up(xp); | 435 | xircom_up(xp); |
474 | xp->open = 1; | 436 | xp->open = 1; |
475 | leave("xircom_open"); | 437 | |
476 | return 0; | 438 | return 0; |
477 | } | 439 | } |
478 | 440 | ||
@@ -481,7 +443,6 @@ static int xircom_close(struct net_device *dev) | |||
481 | struct xircom_private *card; | 443 | struct xircom_private *card; |
482 | unsigned long flags; | 444 | unsigned long flags; |
483 | 445 | ||
484 | enter("xircom_close"); | ||
485 | card = netdev_priv(dev); | 446 | card = netdev_priv(dev); |
486 | netif_stop_queue(dev); /* we don't want new packets */ | 447 | netif_stop_queue(dev); /* we don't want new packets */ |
487 | 448 | ||
@@ -501,8 +462,6 @@ static int xircom_close(struct net_device *dev) | |||
501 | card->open = 0; | 462 | card->open = 0; |
502 | free_irq(dev->irq,dev); | 463 | free_irq(dev->irq,dev); |
503 | 464 | ||
504 | leave("xircom_close"); | ||
505 | |||
506 | return 0; | 465 | return 0; |
507 | 466 | ||
508 | } | 467 | } |
@@ -522,8 +481,6 @@ static void initialize_card(struct xircom_private *card) | |||
522 | { | 481 | { |
523 | unsigned int val; | 482 | unsigned int val; |
524 | unsigned long flags; | 483 | unsigned long flags; |
525 | enter("initialize_card"); | ||
526 | |||
527 | 484 | ||
528 | spin_lock_irqsave(&card->lock, flags); | 485 | spin_lock_irqsave(&card->lock, flags); |
529 | 486 | ||
@@ -549,8 +506,6 @@ static void initialize_card(struct xircom_private *card) | |||
549 | deactivate_transmitter(card); | 506 | deactivate_transmitter(card); |
550 | 507 | ||
551 | spin_unlock_irqrestore(&card->lock, flags); | 508 | spin_unlock_irqrestore(&card->lock, flags); |
552 | |||
553 | leave("initialize_card"); | ||
554 | } | 509 | } |
555 | 510 | ||
556 | /* | 511 | /* |
@@ -562,12 +517,9 @@ ignored; I chose zero. | |||
562 | static void trigger_transmit(struct xircom_private *card) | 517 | static void trigger_transmit(struct xircom_private *card) |
563 | { | 518 | { |
564 | unsigned int val; | 519 | unsigned int val; |
565 | enter("trigger_transmit"); | ||
566 | 520 | ||
567 | val = 0; | 521 | val = 0; |
568 | outl(val, card->io_port + CSR1); | 522 | outl(val, card->io_port + CSR1); |
569 | |||
570 | leave("trigger_transmit"); | ||
571 | } | 523 | } |
572 | 524 | ||
573 | /* | 525 | /* |
@@ -580,12 +532,9 @@ ignored; I chose zero. | |||
580 | static void trigger_receive(struct xircom_private *card) | 532 | static void trigger_receive(struct xircom_private *card) |
581 | { | 533 | { |
582 | unsigned int val; | 534 | unsigned int val; |
583 | enter("trigger_receive"); | ||
584 | 535 | ||
585 | val = 0; | 536 | val = 0; |
586 | outl(val, card->io_port + CSR2); | 537 | outl(val, card->io_port + CSR2); |
587 | |||
588 | leave("trigger_receive"); | ||
589 | } | 538 | } |
590 | 539 | ||
591 | /* | 540 | /* |
@@ -596,8 +545,6 @@ static void setup_descriptors(struct xircom_private *card) | |||
596 | { | 545 | { |
597 | u32 address; | 546 | u32 address; |
598 | int i; | 547 | int i; |
599 | enter("setup_descriptors"); | ||
600 | |||
601 | 548 | ||
602 | BUG_ON(card->rx_buffer == NULL); | 549 | BUG_ON(card->rx_buffer == NULL); |
603 | BUG_ON(card->tx_buffer == NULL); | 550 | BUG_ON(card->tx_buffer == NULL); |
@@ -651,8 +598,6 @@ static void setup_descriptors(struct xircom_private *card) | |||
651 | /* wite the transmit descriptor ring to the card */ | 598 | /* wite the transmit descriptor ring to the card */ |
652 | address = card->tx_dma_handle; | 599 | address = card->tx_dma_handle; |
653 | outl(address, card->io_port + CSR4); /* xmit descr list address */ | 600 | outl(address, card->io_port + CSR4); /* xmit descr list address */ |
654 | |||
655 | leave("setup_descriptors"); | ||
656 | } | 601 | } |
657 | 602 | ||
658 | /* | 603 | /* |
@@ -662,13 +607,10 @@ valid by setting the address in the card to 0x00. | |||
662 | static void remove_descriptors(struct xircom_private *card) | 607 | static void remove_descriptors(struct xircom_private *card) |
663 | { | 608 | { |
664 | unsigned int val; | 609 | unsigned int val; |
665 | enter("remove_descriptors"); | ||
666 | 610 | ||
667 | val = 0; | 611 | val = 0; |
668 | outl(val, card->io_port + CSR3); /* Receive descriptor address */ | 612 | outl(val, card->io_port + CSR3); /* Receive descriptor address */ |
669 | outl(val, card->io_port + CSR4); /* Send descriptor address */ | 613 | outl(val, card->io_port + CSR4); /* Send descriptor address */ |
670 | |||
671 | leave("remove_descriptors"); | ||
672 | } | 614 | } |
673 | 615 | ||
674 | /* | 616 | /* |
@@ -680,21 +622,17 @@ This function also clears the status-bit. | |||
680 | static int link_status_changed(struct xircom_private *card) | 622 | static int link_status_changed(struct xircom_private *card) |
681 | { | 623 | { |
682 | unsigned int val; | 624 | unsigned int val; |
683 | enter("link_status_changed"); | ||
684 | 625 | ||
685 | val = inl(card->io_port + CSR5); /* Status register */ | 626 | val = inl(card->io_port + CSR5); /* Status register */ |
686 | 627 | ||
687 | if ((val & (1 << 27)) == 0) { /* no change */ | 628 | if ((val & (1 << 27)) == 0) /* no change */ |
688 | leave("link_status_changed - nochange"); | ||
689 | return 0; | 629 | return 0; |
690 | } | ||
691 | 630 | ||
692 | /* clear the event by writing a 1 to the bit in the | 631 | /* clear the event by writing a 1 to the bit in the |
693 | status register. */ | 632 | status register. */ |
694 | val = (1 << 27); | 633 | val = (1 << 27); |
695 | outl(val, card->io_port + CSR5); | 634 | outl(val, card->io_port + CSR5); |
696 | 635 | ||
697 | leave("link_status_changed - changed"); | ||
698 | return 1; | 636 | return 1; |
699 | } | 637 | } |
700 | 638 | ||
@@ -706,16 +644,12 @@ in a non-stopped state. | |||
706 | static int transmit_active(struct xircom_private *card) | 644 | static int transmit_active(struct xircom_private *card) |
707 | { | 645 | { |
708 | unsigned int val; | 646 | unsigned int val; |
709 | enter("transmit_active"); | ||
710 | 647 | ||
711 | val = inl(card->io_port + CSR5); /* Status register */ | 648 | val = inl(card->io_port + CSR5); /* Status register */ |
712 | 649 | ||
713 | if ((val & (7 << 20)) == 0) { /* transmitter disabled */ | 650 | if ((val & (7 << 20)) == 0) /* transmitter disabled */ |
714 | leave("transmit_active - inactive"); | ||
715 | return 0; | 651 | return 0; |
716 | } | ||
717 | 652 | ||
718 | leave("transmit_active - active"); | ||
719 | return 1; | 653 | return 1; |
720 | } | 654 | } |
721 | 655 | ||
@@ -726,17 +660,12 @@ in a non-stopped state. | |||
726 | static int receive_active(struct xircom_private *card) | 660 | static int receive_active(struct xircom_private *card) |
727 | { | 661 | { |
728 | unsigned int val; | 662 | unsigned int val; |
729 | enter("receive_active"); | ||
730 | |||
731 | 663 | ||
732 | val = inl(card->io_port + CSR5); /* Status register */ | 664 | val = inl(card->io_port + CSR5); /* Status register */ |
733 | 665 | ||
734 | if ((val & (7 << 17)) == 0) { /* receiver disabled */ | 666 | if ((val & (7 << 17)) == 0) /* receiver disabled */ |
735 | leave("receive_active - inactive"); | ||
736 | return 0; | 667 | return 0; |
737 | } | ||
738 | 668 | ||
739 | leave("receive_active - active"); | ||
740 | return 1; | 669 | return 1; |
741 | } | 670 | } |
742 | 671 | ||
@@ -754,8 +683,6 @@ static void activate_receiver(struct xircom_private *card) | |||
754 | { | 683 | { |
755 | unsigned int val; | 684 | unsigned int val; |
756 | int counter; | 685 | int counter; |
757 | enter("activate_receiver"); | ||
758 | |||
759 | 686 | ||
760 | val = inl(card->io_port + CSR6); /* Operation mode */ | 687 | val = inl(card->io_port + CSR6); /* Operation mode */ |
761 | 688 | ||
@@ -776,7 +703,7 @@ static void activate_receiver(struct xircom_private *card) | |||
776 | udelay(50); | 703 | udelay(50); |
777 | counter--; | 704 | counter--; |
778 | if (counter <= 0) | 705 | if (counter <= 0) |
779 | pr_err("Receiver failed to deactivate\n"); | 706 | netdev_err(card->dev, "Receiver failed to deactivate\n"); |
780 | } | 707 | } |
781 | 708 | ||
782 | /* enable the receiver */ | 709 | /* enable the receiver */ |
@@ -793,10 +720,9 @@ static void activate_receiver(struct xircom_private *card) | |||
793 | udelay(50); | 720 | udelay(50); |
794 | counter--; | 721 | counter--; |
795 | if (counter <= 0) | 722 | if (counter <= 0) |
796 | pr_err("Receiver failed to re-activate\n"); | 723 | netdev_err(card->dev, |
724 | "Receiver failed to re-activate\n"); | ||
797 | } | 725 | } |
798 | |||
799 | leave("activate_receiver"); | ||
800 | } | 726 | } |
801 | 727 | ||
802 | /* | 728 | /* |
@@ -810,7 +736,6 @@ static void deactivate_receiver(struct xircom_private *card) | |||
810 | { | 736 | { |
811 | unsigned int val; | 737 | unsigned int val; |
812 | int counter; | 738 | int counter; |
813 | enter("deactivate_receiver"); | ||
814 | 739 | ||
815 | val = inl(card->io_port + CSR6); /* Operation mode */ | 740 | val = inl(card->io_port + CSR6); /* Operation mode */ |
816 | val = val & ~2; /* disable the receiver */ | 741 | val = val & ~2; /* disable the receiver */ |
@@ -824,11 +749,8 @@ static void deactivate_receiver(struct xircom_private *card) | |||
824 | udelay(50); | 749 | udelay(50); |
825 | counter--; | 750 | counter--; |
826 | if (counter <= 0) | 751 | if (counter <= 0) |
827 | pr_err("Receiver failed to deactivate\n"); | 752 | netdev_err(card->dev, "Receiver failed to deactivate\n"); |
828 | } | 753 | } |
829 | |||
830 | |||
831 | leave("deactivate_receiver"); | ||
832 | } | 754 | } |
833 | 755 | ||
834 | 756 | ||
@@ -846,8 +768,6 @@ static void activate_transmitter(struct xircom_private *card) | |||
846 | { | 768 | { |
847 | unsigned int val; | 769 | unsigned int val; |
848 | int counter; | 770 | int counter; |
849 | enter("activate_transmitter"); | ||
850 | |||
851 | 771 | ||
852 | val = inl(card->io_port + CSR6); /* Operation mode */ | 772 | val = inl(card->io_port + CSR6); /* Operation mode */ |
853 | 773 | ||
@@ -867,7 +787,8 @@ static void activate_transmitter(struct xircom_private *card) | |||
867 | udelay(50); | 787 | udelay(50); |
868 | counter--; | 788 | counter--; |
869 | if (counter <= 0) | 789 | if (counter <= 0) |
870 | pr_err("Transmitter failed to deactivate\n"); | 790 | netdev_err(card->dev, |
791 | "Transmitter failed to deactivate\n"); | ||
871 | } | 792 | } |
872 | 793 | ||
873 | /* enable the transmitter */ | 794 | /* enable the transmitter */ |
@@ -884,10 +805,9 @@ static void activate_transmitter(struct xircom_private *card) | |||
884 | udelay(50); | 805 | udelay(50); |
885 | counter--; | 806 | counter--; |
886 | if (counter <= 0) | 807 | if (counter <= 0) |
887 | pr_err("Transmitter failed to re-activate\n"); | 808 | netdev_err(card->dev, |
809 | "Transmitter failed to re-activate\n"); | ||
888 | } | 810 | } |
889 | |||
890 | leave("activate_transmitter"); | ||
891 | } | 811 | } |
892 | 812 | ||
893 | /* | 813 | /* |
@@ -901,7 +821,6 @@ static void deactivate_transmitter(struct xircom_private *card) | |||
901 | { | 821 | { |
902 | unsigned int val; | 822 | unsigned int val; |
903 | int counter; | 823 | int counter; |
904 | enter("deactivate_transmitter"); | ||
905 | 824 | ||
906 | val = inl(card->io_port + CSR6); /* Operation mode */ | 825 | val = inl(card->io_port + CSR6); /* Operation mode */ |
907 | val = val & ~2; /* disable the transmitter */ | 826 | val = val & ~2; /* disable the transmitter */ |
@@ -915,11 +834,9 @@ static void deactivate_transmitter(struct xircom_private *card) | |||
915 | udelay(50); | 834 | udelay(50); |
916 | counter--; | 835 | counter--; |
917 | if (counter <= 0) | 836 | if (counter <= 0) |
918 | pr_err("Transmitter failed to deactivate\n"); | 837 | netdev_err(card->dev, |
838 | "Transmitter failed to deactivate\n"); | ||
919 | } | 839 | } |
920 | |||
921 | |||
922 | leave("deactivate_transmitter"); | ||
923 | } | 840 | } |
924 | 841 | ||
925 | 842 | ||
@@ -931,13 +848,10 @@ must be called with the lock held and interrupts disabled. | |||
931 | static void enable_transmit_interrupt(struct xircom_private *card) | 848 | static void enable_transmit_interrupt(struct xircom_private *card) |
932 | { | 849 | { |
933 | unsigned int val; | 850 | unsigned int val; |
934 | enter("enable_transmit_interrupt"); | ||
935 | 851 | ||
936 | val = inl(card->io_port + CSR7); /* Interrupt enable register */ | 852 | val = inl(card->io_port + CSR7); /* Interrupt enable register */ |
937 | val |= 1; /* enable the transmit interrupt */ | 853 | val |= 1; /* enable the transmit interrupt */ |
938 | outl(val, card->io_port + CSR7); | 854 | outl(val, card->io_port + CSR7); |
939 | |||
940 | leave("enable_transmit_interrupt"); | ||
941 | } | 855 | } |
942 | 856 | ||
943 | 857 | ||
@@ -949,13 +863,10 @@ must be called with the lock held and interrupts disabled. | |||
949 | static void enable_receive_interrupt(struct xircom_private *card) | 863 | static void enable_receive_interrupt(struct xircom_private *card) |
950 | { | 864 | { |
951 | unsigned int val; | 865 | unsigned int val; |
952 | enter("enable_receive_interrupt"); | ||
953 | 866 | ||
954 | val = inl(card->io_port + CSR7); /* Interrupt enable register */ | 867 | val = inl(card->io_port + CSR7); /* Interrupt enable register */ |
955 | val = val | (1 << 6); /* enable the receive interrupt */ | 868 | val = val | (1 << 6); /* enable the receive interrupt */ |
956 | outl(val, card->io_port + CSR7); | 869 | outl(val, card->io_port + CSR7); |
957 | |||
958 | leave("enable_receive_interrupt"); | ||
959 | } | 870 | } |
960 | 871 | ||
961 | /* | 872 | /* |
@@ -966,13 +877,10 @@ must be called with the lock held and interrupts disabled. | |||
966 | static void enable_link_interrupt(struct xircom_private *card) | 877 | static void enable_link_interrupt(struct xircom_private *card) |
967 | { | 878 | { |
968 | unsigned int val; | 879 | unsigned int val; |
969 | enter("enable_link_interrupt"); | ||
970 | 880 | ||
971 | val = inl(card->io_port + CSR7); /* Interrupt enable register */ | 881 | val = inl(card->io_port + CSR7); /* Interrupt enable register */ |
972 | val = val | (1 << 27); /* enable the link status chage interrupt */ | 882 | val = val | (1 << 27); /* enable the link status chage interrupt */ |
973 | outl(val, card->io_port + CSR7); | 883 | outl(val, card->io_port + CSR7); |
974 | |||
975 | leave("enable_link_interrupt"); | ||
976 | } | 884 | } |
977 | 885 | ||
978 | 886 | ||
@@ -985,12 +893,9 @@ must be called with the lock held and interrupts disabled. | |||
985 | static void disable_all_interrupts(struct xircom_private *card) | 893 | static void disable_all_interrupts(struct xircom_private *card) |
986 | { | 894 | { |
987 | unsigned int val; | 895 | unsigned int val; |
988 | enter("enable_all_interrupts"); | ||
989 | 896 | ||
990 | val = 0; /* disable all interrupts */ | 897 | val = 0; /* disable all interrupts */ |
991 | outl(val, card->io_port + CSR7); | 898 | outl(val, card->io_port + CSR7); |
992 | |||
993 | leave("disable_all_interrupts"); | ||
994 | } | 899 | } |
995 | 900 | ||
996 | /* | 901 | /* |
@@ -1001,7 +906,6 @@ must be called with the lock held and interrupts disabled. | |||
1001 | static void enable_common_interrupts(struct xircom_private *card) | 906 | static void enable_common_interrupts(struct xircom_private *card) |
1002 | { | 907 | { |
1003 | unsigned int val; | 908 | unsigned int val; |
1004 | enter("enable_link_interrupt"); | ||
1005 | 909 | ||
1006 | val = inl(card->io_port + CSR7); /* Interrupt enable register */ | 910 | val = inl(card->io_port + CSR7); /* Interrupt enable register */ |
1007 | val |= (1<<16); /* Normal Interrupt Summary */ | 911 | val |= (1<<16); /* Normal Interrupt Summary */ |
@@ -1013,8 +917,6 @@ static void enable_common_interrupts(struct xircom_private *card) | |||
1013 | val |= (1<<2); /* Transmit Buffer Unavailable */ | 917 | val |= (1<<2); /* Transmit Buffer Unavailable */ |
1014 | val |= (1<<1); /* Transmit Process Stopped */ | 918 | val |= (1<<1); /* Transmit Process Stopped */ |
1015 | outl(val, card->io_port + CSR7); | 919 | outl(val, card->io_port + CSR7); |
1016 | |||
1017 | leave("enable_link_interrupt"); | ||
1018 | } | 920 | } |
1019 | 921 | ||
1020 | /* | 922 | /* |
@@ -1025,13 +927,11 @@ must be called with the lock held and interrupts disabled. | |||
1025 | static int enable_promisc(struct xircom_private *card) | 927 | static int enable_promisc(struct xircom_private *card) |
1026 | { | 928 | { |
1027 | unsigned int val; | 929 | unsigned int val; |
1028 | enter("enable_promisc"); | ||
1029 | 930 | ||
1030 | val = inl(card->io_port + CSR6); | 931 | val = inl(card->io_port + CSR6); |
1031 | val = val | (1 << 6); | 932 | val = val | (1 << 6); |
1032 | outl(val, card->io_port + CSR6); | 933 | outl(val, card->io_port + CSR6); |
1033 | 934 | ||
1034 | leave("enable_promisc"); | ||
1035 | return 1; | 935 | return 1; |
1036 | } | 936 | } |
1037 | 937 | ||
@@ -1046,7 +946,6 @@ Must be called in locked state with interrupts disabled | |||
1046 | static int link_status(struct xircom_private *card) | 946 | static int link_status(struct xircom_private *card) |
1047 | { | 947 | { |
1048 | unsigned int val; | 948 | unsigned int val; |
1049 | enter("link_status"); | ||
1050 | 949 | ||
1051 | val = inb(card->io_port + CSR12); | 950 | val = inb(card->io_port + CSR12); |
1052 | 951 | ||
@@ -1057,7 +956,6 @@ static int link_status(struct xircom_private *card) | |||
1057 | 956 | ||
1058 | /* If we get here -> no link at all */ | 957 | /* If we get here -> no link at all */ |
1059 | 958 | ||
1060 | leave("link_status"); | ||
1061 | return 0; | 959 | return 0; |
1062 | } | 960 | } |
1063 | 961 | ||
@@ -1076,8 +974,6 @@ static void read_mac_address(struct xircom_private *card) | |||
1076 | unsigned long flags; | 974 | unsigned long flags; |
1077 | int i; | 975 | int i; |
1078 | 976 | ||
1079 | enter("read_mac_address"); | ||
1080 | |||
1081 | spin_lock_irqsave(&card->lock, flags); | 977 | spin_lock_irqsave(&card->lock, flags); |
1082 | 978 | ||
1083 | outl(1 << 12, card->io_port + CSR9); /* enable boot rom access */ | 979 | outl(1 << 12, card->io_port + CSR9); /* enable boot rom access */ |
@@ -1105,7 +1001,6 @@ static void read_mac_address(struct xircom_private *card) | |||
1105 | } | 1001 | } |
1106 | spin_unlock_irqrestore(&card->lock, flags); | 1002 | spin_unlock_irqrestore(&card->lock, flags); |
1107 | pr_debug(" %pM\n", card->dev->dev_addr); | 1003 | pr_debug(" %pM\n", card->dev->dev_addr); |
1108 | leave("read_mac_address"); | ||
1109 | } | 1004 | } |
1110 | 1005 | ||
1111 | 1006 | ||
@@ -1118,8 +1013,6 @@ static void transceiver_voodoo(struct xircom_private *card) | |||
1118 | { | 1013 | { |
1119 | unsigned long flags; | 1014 | unsigned long flags; |
1120 | 1015 | ||
1121 | enter("transceiver_voodoo"); | ||
1122 | |||
1123 | /* disable all powermanagement */ | 1016 | /* disable all powermanagement */ |
1124 | pci_write_config_dword(card->pdev, PCI_POWERMGMT, 0x0000); | 1017 | pci_write_config_dword(card->pdev, PCI_POWERMGMT, 0x0000); |
1125 | 1018 | ||
@@ -1137,7 +1030,6 @@ static void transceiver_voodoo(struct xircom_private *card) | |||
1137 | spin_unlock_irqrestore(&card->lock, flags); | 1030 | spin_unlock_irqrestore(&card->lock, flags); |
1138 | 1031 | ||
1139 | netif_start_queue(card->dev); | 1032 | netif_start_queue(card->dev); |
1140 | leave("transceiver_voodoo"); | ||
1141 | } | 1033 | } |
1142 | 1034 | ||
1143 | 1035 | ||
@@ -1146,8 +1038,6 @@ static void xircom_up(struct xircom_private *card) | |||
1146 | unsigned long flags; | 1038 | unsigned long flags; |
1147 | int i; | 1039 | int i; |
1148 | 1040 | ||
1149 | enter("xircom_up"); | ||
1150 | |||
1151 | /* disable all powermanagement */ | 1041 | /* disable all powermanagement */ |
1152 | pci_write_config_dword(card->pdev, PCI_POWERMGMT, 0x0000); | 1042 | pci_write_config_dword(card->pdev, PCI_POWERMGMT, 0x0000); |
1153 | 1043 | ||
@@ -1171,87 +1061,84 @@ static void xircom_up(struct xircom_private *card) | |||
1171 | trigger_receive(card); | 1061 | trigger_receive(card); |
1172 | trigger_transmit(card); | 1062 | trigger_transmit(card); |
1173 | netif_start_queue(card->dev); | 1063 | netif_start_queue(card->dev); |
1174 | leave("xircom_up"); | ||
1175 | } | 1064 | } |
1176 | 1065 | ||
1177 | /* Bufferoffset is in BYTES */ | 1066 | /* Bufferoffset is in BYTES */ |
1178 | static void investigate_read_descriptor(struct net_device *dev,struct xircom_private *card, int descnr, unsigned int bufferoffset) | 1067 | static void |
1068 | investigate_read_descriptor(struct net_device *dev, struct xircom_private *card, | ||
1069 | int descnr, unsigned int bufferoffset) | ||
1179 | { | 1070 | { |
1180 | int status; | 1071 | int status; |
1181 | 1072 | ||
1182 | enter("investigate_read_descriptor"); | 1073 | status = le32_to_cpu(card->rx_buffer[4*descnr]); |
1183 | status = le32_to_cpu(card->rx_buffer[4*descnr]); | ||
1184 | 1074 | ||
1185 | if ((status > 0)) { /* packet received */ | 1075 | if (status > 0) { /* packet received */ |
1186 | 1076 | ||
1187 | /* TODO: discard error packets */ | 1077 | /* TODO: discard error packets */ |
1188 | 1078 | ||
1189 | short pkt_len = ((status >> 16) & 0x7ff) - 4; /* minus 4, we don't want the CRC */ | 1079 | short pkt_len = ((status >> 16) & 0x7ff) - 4; |
1190 | struct sk_buff *skb; | 1080 | /* minus 4, we don't want the CRC */ |
1081 | struct sk_buff *skb; | ||
1191 | 1082 | ||
1192 | if (pkt_len > 1518) { | 1083 | if (pkt_len > 1518) { |
1193 | pr_err("Packet length %i is bogus\n", pkt_len); | 1084 | netdev_err(dev, "Packet length %i is bogus\n", pkt_len); |
1194 | pkt_len = 1518; | 1085 | pkt_len = 1518; |
1195 | } | ||
1196 | |||
1197 | skb = dev_alloc_skb(pkt_len + 2); | ||
1198 | if (skb == NULL) { | ||
1199 | dev->stats.rx_dropped++; | ||
1200 | goto out; | ||
1201 | } | ||
1202 | skb_reserve(skb, 2); | ||
1203 | skb_copy_to_linear_data(skb, (unsigned char*)&card->rx_buffer[bufferoffset / 4], pkt_len); | ||
1204 | skb_put(skb, pkt_len); | ||
1205 | skb->protocol = eth_type_trans(skb, dev); | ||
1206 | netif_rx(skb); | ||
1207 | dev->stats.rx_packets++; | ||
1208 | dev->stats.rx_bytes += pkt_len; | ||
1209 | |||
1210 | out: | ||
1211 | /* give the buffer back to the card */ | ||
1212 | card->rx_buffer[4*descnr] = cpu_to_le32(0x80000000); | ||
1213 | trigger_receive(card); | ||
1214 | } | 1086 | } |
1215 | 1087 | ||
1216 | leave("investigate_read_descriptor"); | 1088 | skb = dev_alloc_skb(pkt_len + 2); |
1217 | 1089 | if (skb == NULL) { | |
1090 | dev->stats.rx_dropped++; | ||
1091 | goto out; | ||
1092 | } | ||
1093 | skb_reserve(skb, 2); | ||
1094 | skb_copy_to_linear_data(skb, | ||
1095 | &card->rx_buffer[bufferoffset / 4], | ||
1096 | pkt_len); | ||
1097 | skb_put(skb, pkt_len); | ||
1098 | skb->protocol = eth_type_trans(skb, dev); | ||
1099 | netif_rx(skb); | ||
1100 | dev->stats.rx_packets++; | ||
1101 | dev->stats.rx_bytes += pkt_len; | ||
1102 | |||
1103 | out: | ||
1104 | /* give the buffer back to the card */ | ||
1105 | card->rx_buffer[4*descnr] = cpu_to_le32(0x80000000); | ||
1106 | trigger_receive(card); | ||
1107 | } | ||
1218 | } | 1108 | } |
1219 | 1109 | ||
1220 | 1110 | ||
1221 | /* Bufferoffset is in BYTES */ | 1111 | /* Bufferoffset is in BYTES */ |
1222 | static void investigate_write_descriptor(struct net_device *dev, struct xircom_private *card, int descnr, unsigned int bufferoffset) | 1112 | static void |
1113 | investigate_write_descriptor(struct net_device *dev, | ||
1114 | struct xircom_private *card, | ||
1115 | int descnr, unsigned int bufferoffset) | ||
1223 | { | 1116 | { |
1224 | int status; | 1117 | int status; |
1225 | |||
1226 | enter("investigate_write_descriptor"); | ||
1227 | 1118 | ||
1228 | status = le32_to_cpu(card->tx_buffer[4*descnr]); | 1119 | status = le32_to_cpu(card->tx_buffer[4*descnr]); |
1229 | #if 0 | 1120 | #if 0 |
1230 | if (status & 0x8000) { /* Major error */ | 1121 | if (status & 0x8000) { /* Major error */ |
1231 | pr_err("Major transmit error status %x\n", status); | 1122 | pr_err("Major transmit error status %x\n", status); |
1232 | card->tx_buffer[4*descnr] = 0; | 1123 | card->tx_buffer[4*descnr] = 0; |
1233 | netif_wake_queue (dev); | 1124 | netif_wake_queue (dev); |
1234 | } | 1125 | } |
1235 | #endif | 1126 | #endif |
1236 | if (status > 0) { /* bit 31 is 0 when done */ | 1127 | if (status > 0) { /* bit 31 is 0 when done */ |
1237 | if (card->tx_skb[descnr]!=NULL) { | 1128 | if (card->tx_skb[descnr]!=NULL) { |
1238 | dev->stats.tx_bytes += card->tx_skb[descnr]->len; | 1129 | dev->stats.tx_bytes += card->tx_skb[descnr]->len; |
1239 | dev_kfree_skb_irq(card->tx_skb[descnr]); | 1130 | dev_kfree_skb_irq(card->tx_skb[descnr]); |
1240 | } | ||
1241 | card->tx_skb[descnr] = NULL; | ||
1242 | /* Bit 8 in the status field is 1 if there was a collision */ | ||
1243 | if (status&(1<<8)) | ||
1244 | dev->stats.collisions++; | ||
1245 | card->tx_buffer[4*descnr] = 0; /* descriptor is free again */ | ||
1246 | netif_wake_queue (dev); | ||
1247 | dev->stats.tx_packets++; | ||
1248 | } | 1131 | } |
1249 | 1132 | card->tx_skb[descnr] = NULL; | |
1250 | leave("investigate_write_descriptor"); | 1133 | /* Bit 8 in the status field is 1 if there was a collision */ |
1251 | 1134 | if (status & (1 << 8)) | |
1135 | dev->stats.collisions++; | ||
1136 | card->tx_buffer[4*descnr] = 0; /* descriptor is free again */ | ||
1137 | netif_wake_queue (dev); | ||
1138 | dev->stats.tx_packets++; | ||
1139 | } | ||
1252 | } | 1140 | } |
1253 | 1141 | ||
1254 | |||
1255 | static int __init xircom_init(void) | 1142 | static int __init xircom_init(void) |
1256 | { | 1143 | { |
1257 | return pci_register_driver(&xircom_ops); | 1144 | return pci_register_driver(&xircom_ops); |