diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/yellowfin.c | 162 |
1 files changed, 78 insertions, 84 deletions
diff --git a/drivers/net/yellowfin.c b/drivers/net/yellowfin.c index 5c880240a642..e4aab4d5b553 100644 --- a/drivers/net/yellowfin.c +++ b/drivers/net/yellowfin.c | |||
@@ -23,12 +23,12 @@ | |||
23 | 23 | ||
24 | */ | 24 | */ |
25 | 25 | ||
26 | #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt | ||
27 | |||
26 | #define DRV_NAME "yellowfin" | 28 | #define DRV_NAME "yellowfin" |
27 | #define DRV_VERSION "2.1" | 29 | #define DRV_VERSION "2.1" |
28 | #define DRV_RELDATE "Sep 11, 2006" | 30 | #define DRV_RELDATE "Sep 11, 2006" |
29 | 31 | ||
30 | #define PFX DRV_NAME ": " | ||
31 | |||
32 | /* The user-configurable values. | 32 | /* The user-configurable values. |
33 | These may be modified when a driver module is loaded.*/ | 33 | These may be modified when a driver module is loaded.*/ |
34 | 34 | ||
@@ -399,7 +399,7 @@ static int __devinit yellowfin_init_one(struct pci_dev *pdev, | |||
399 | 399 | ||
400 | dev = alloc_etherdev(sizeof(*np)); | 400 | dev = alloc_etherdev(sizeof(*np)); |
401 | if (!dev) { | 401 | if (!dev) { |
402 | printk (KERN_ERR PFX "cannot allocate ethernet device\n"); | 402 | pr_err("cannot allocate ethernet device\n"); |
403 | return -ENOMEM; | 403 | return -ENOMEM; |
404 | } | 404 | } |
405 | SET_NETDEV_DEV(dev, &pdev->dev); | 405 | SET_NETDEV_DEV(dev, &pdev->dev); |
@@ -487,10 +487,10 @@ static int __devinit yellowfin_init_one(struct pci_dev *pdev, | |||
487 | if (i) | 487 | if (i) |
488 | goto err_out_unmap_status; | 488 | goto err_out_unmap_status; |
489 | 489 | ||
490 | printk(KERN_INFO "%s: %s type %8x at %p, %pM, IRQ %d.\n", | 490 | netdev_info(dev, "%s type %8x at %p, %pM, IRQ %d\n", |
491 | dev->name, pci_id_tbl[chip_idx].name, | 491 | pci_id_tbl[chip_idx].name, |
492 | ioread32(ioaddr + ChipRev), ioaddr, | 492 | ioread32(ioaddr + ChipRev), ioaddr, |
493 | dev->dev_addr, irq); | 493 | dev->dev_addr, irq); |
494 | 494 | ||
495 | if (np->drv_flags & HasMII) { | 495 | if (np->drv_flags & HasMII) { |
496 | int phy, phy_idx = 0; | 496 | int phy, phy_idx = 0; |
@@ -499,9 +499,8 @@ static int __devinit yellowfin_init_one(struct pci_dev *pdev, | |||
499 | if (mii_status != 0xffff && mii_status != 0x0000) { | 499 | if (mii_status != 0xffff && mii_status != 0x0000) { |
500 | np->phys[phy_idx++] = phy; | 500 | np->phys[phy_idx++] = phy; |
501 | np->advertising = mdio_read(ioaddr, phy, 4); | 501 | np->advertising = mdio_read(ioaddr, phy, 4); |
502 | printk(KERN_INFO "%s: MII PHY found at address %d, status " | 502 | netdev_info(dev, "MII PHY found at address %d, status 0x%04x advertising %04x\n", |
503 | "0x%4.4x advertising %4.4x.\n", | 503 | phy, mii_status, np->advertising); |
504 | dev->name, phy, mii_status, np->advertising); | ||
505 | } | 504 | } |
506 | } | 505 | } |
507 | np->mii_cnt = phy_idx; | 506 | np->mii_cnt = phy_idx; |
@@ -584,8 +583,8 @@ static int yellowfin_open(struct net_device *dev) | |||
584 | return ret; | 583 | return ret; |
585 | 584 | ||
586 | if (yellowfin_debug > 1) | 585 | if (yellowfin_debug > 1) |
587 | printk(KERN_DEBUG "%s: yellowfin_open() irq %d.\n", | 586 | netdev_printk(KERN_DEBUG, dev, "%s() irq %d\n", |
588 | dev->name, dev->irq); | 587 | __func__, dev->irq); |
589 | 588 | ||
590 | ret = yellowfin_init_ring(dev); | 589 | ret = yellowfin_init_ring(dev); |
591 | if (ret) { | 590 | if (ret) { |
@@ -642,8 +641,7 @@ static int yellowfin_open(struct net_device *dev) | |||
642 | iowrite32(0x80008000, ioaddr + TxCtrl); | 641 | iowrite32(0x80008000, ioaddr + TxCtrl); |
643 | 642 | ||
644 | if (yellowfin_debug > 2) { | 643 | if (yellowfin_debug > 2) { |
645 | printk(KERN_DEBUG "%s: Done yellowfin_open().\n", | 644 | netdev_printk(KERN_DEBUG, dev, "Done %s()\n", __func__); |
646 | dev->name); | ||
647 | } | 645 | } |
648 | 646 | ||
649 | /* Set the timer to check for link beat. */ | 647 | /* Set the timer to check for link beat. */ |
@@ -664,8 +662,8 @@ static void yellowfin_timer(unsigned long data) | |||
664 | int next_tick = 60*HZ; | 662 | int next_tick = 60*HZ; |
665 | 663 | ||
666 | if (yellowfin_debug > 3) { | 664 | if (yellowfin_debug > 3) { |
667 | printk(KERN_DEBUG "%s: Yellowfin timer tick, status %8.8x.\n", | 665 | netdev_printk(KERN_DEBUG, dev, "Yellowfin timer tick, status %08x\n", |
668 | dev->name, ioread16(ioaddr + IntrStatus)); | 666 | ioread16(ioaddr + IntrStatus)); |
669 | } | 667 | } |
670 | 668 | ||
671 | if (yp->mii_cnt) { | 669 | if (yp->mii_cnt) { |
@@ -673,9 +671,8 @@ static void yellowfin_timer(unsigned long data) | |||
673 | int lpa = mdio_read(ioaddr, yp->phys[0], MII_LPA); | 671 | int lpa = mdio_read(ioaddr, yp->phys[0], MII_LPA); |
674 | int negotiated = lpa & yp->advertising; | 672 | int negotiated = lpa & yp->advertising; |
675 | if (yellowfin_debug > 1) | 673 | if (yellowfin_debug > 1) |
676 | printk(KERN_DEBUG "%s: MII #%d status register is %4.4x, " | 674 | netdev_printk(KERN_DEBUG, dev, "MII #%d status register is %04x, link partner capability %04x\n", |
677 | "link partner capability %4.4x.\n", | 675 | yp->phys[0], bmsr, lpa); |
678 | dev->name, yp->phys[0], bmsr, lpa); | ||
679 | 676 | ||
680 | yp->full_duplex = mii_duplex(yp->duplex_lock, negotiated); | 677 | yp->full_duplex = mii_duplex(yp->duplex_lock, negotiated); |
681 | 678 | ||
@@ -696,25 +693,24 @@ static void yellowfin_tx_timeout(struct net_device *dev) | |||
696 | struct yellowfin_private *yp = netdev_priv(dev); | 693 | struct yellowfin_private *yp = netdev_priv(dev); |
697 | void __iomem *ioaddr = yp->base; | 694 | void __iomem *ioaddr = yp->base; |
698 | 695 | ||
699 | printk(KERN_WARNING "%s: Yellowfin transmit timed out at %d/%d Tx " | 696 | netdev_warn(dev, "Yellowfin transmit timed out at %d/%d Tx status %04x, Rx status %04x, resetting...\n", |
700 | "status %4.4x, Rx status %4.4x, resetting...\n", | 697 | yp->cur_tx, yp->dirty_tx, |
701 | dev->name, yp->cur_tx, yp->dirty_tx, | 698 | ioread32(ioaddr + TxStatus), |
702 | ioread32(ioaddr + TxStatus), ioread32(ioaddr + RxStatus)); | 699 | ioread32(ioaddr + RxStatus)); |
703 | 700 | ||
704 | /* Note: these should be KERN_DEBUG. */ | 701 | /* Note: these should be KERN_DEBUG. */ |
705 | if (yellowfin_debug) { | 702 | if (yellowfin_debug) { |
706 | int i; | 703 | int i; |
707 | printk(KERN_WARNING " Rx ring %p: ", yp->rx_ring); | 704 | pr_warning(" Rx ring %p: ", yp->rx_ring); |
708 | for (i = 0; i < RX_RING_SIZE; i++) | 705 | for (i = 0; i < RX_RING_SIZE; i++) |
709 | printk(KERN_CONT " %8.8x", | 706 | pr_cont(" %08x", yp->rx_ring[i].result_status); |
710 | yp->rx_ring[i].result_status); | 707 | pr_cont("\n"); |
711 | printk(KERN_CONT "\n"); | 708 | pr_warning(" Tx ring %p: ", yp->tx_ring); |
712 | printk(KERN_WARNING" Tx ring %p: ", yp->tx_ring); | ||
713 | for (i = 0; i < TX_RING_SIZE; i++) | 709 | for (i = 0; i < TX_RING_SIZE; i++) |
714 | printk(KERN_CONT " %4.4x /%8.8x", | 710 | pr_cont(" %04x /%08x", |
715 | yp->tx_status[i].tx_errs, | 711 | yp->tx_status[i].tx_errs, |
716 | yp->tx_ring[i].result_status); | 712 | yp->tx_ring[i].result_status); |
717 | printk(KERN_CONT "\n"); | 713 | pr_cont("\n"); |
718 | } | 714 | } |
719 | 715 | ||
720 | /* If the hardware is found to hang regularly, we will update the code | 716 | /* If the hardware is found to hang regularly, we will update the code |
@@ -891,8 +887,8 @@ static netdev_tx_t yellowfin_start_xmit(struct sk_buff *skb, | |||
891 | yp->tx_full = 1; | 887 | yp->tx_full = 1; |
892 | 888 | ||
893 | if (yellowfin_debug > 4) { | 889 | if (yellowfin_debug > 4) { |
894 | printk(KERN_DEBUG "%s: Yellowfin transmit frame #%d queued in slot %d.\n", | 890 | netdev_printk(KERN_DEBUG, dev, "Yellowfin transmit frame #%d queued in slot %d\n", |
895 | dev->name, yp->cur_tx, entry); | 891 | yp->cur_tx, entry); |
896 | } | 892 | } |
897 | return NETDEV_TX_OK; | 893 | return NETDEV_TX_OK; |
898 | } | 894 | } |
@@ -916,8 +912,8 @@ static irqreturn_t yellowfin_interrupt(int irq, void *dev_instance) | |||
916 | u16 intr_status = ioread16(ioaddr + IntrClear); | 912 | u16 intr_status = ioread16(ioaddr + IntrClear); |
917 | 913 | ||
918 | if (yellowfin_debug > 4) | 914 | if (yellowfin_debug > 4) |
919 | printk(KERN_DEBUG "%s: Yellowfin interrupt, status %4.4x.\n", | 915 | netdev_printk(KERN_DEBUG, dev, "Yellowfin interrupt, status %04x\n", |
920 | dev->name, intr_status); | 916 | intr_status); |
921 | 917 | ||
922 | if (intr_status == 0) | 918 | if (intr_status == 0) |
923 | break; | 919 | break; |
@@ -963,13 +959,12 @@ static irqreturn_t yellowfin_interrupt(int irq, void *dev_instance) | |||
963 | 959 | ||
964 | #ifndef final_version | 960 | #ifndef final_version |
965 | if (yellowfin_debug > 5) | 961 | if (yellowfin_debug > 5) |
966 | printk(KERN_DEBUG "%s: Tx queue %d check, Tx status " | 962 | netdev_printk(KERN_DEBUG, dev, "Tx queue %d check, Tx status %04x %04x %04x %04x\n", |
967 | "%4.4x %4.4x %4.4x %4.4x.\n", | 963 | entry, |
968 | dev->name, entry, | 964 | yp->tx_status[entry].tx_cnt, |
969 | yp->tx_status[entry].tx_cnt, | 965 | yp->tx_status[entry].tx_errs, |
970 | yp->tx_status[entry].tx_errs, | 966 | yp->tx_status[entry].total_tx_cnt, |
971 | yp->tx_status[entry].total_tx_cnt, | 967 | yp->tx_status[entry].paused); |
972 | yp->tx_status[entry].paused); | ||
973 | #endif | 968 | #endif |
974 | if (tx_errs == 0) | 969 | if (tx_errs == 0) |
975 | break; /* It still hasn't been Txed */ | 970 | break; /* It still hasn't been Txed */ |
@@ -978,8 +973,8 @@ static irqreturn_t yellowfin_interrupt(int irq, void *dev_instance) | |||
978 | /* There was an major error, log it. */ | 973 | /* There was an major error, log it. */ |
979 | #ifndef final_version | 974 | #ifndef final_version |
980 | if (yellowfin_debug > 1) | 975 | if (yellowfin_debug > 1) |
981 | printk(KERN_DEBUG "%s: Transmit error, Tx status %4.4x.\n", | 976 | netdev_printk(KERN_DEBUG, dev, "Transmit error, Tx status %04x\n", |
982 | dev->name, tx_errs); | 977 | tx_errs); |
983 | #endif | 978 | #endif |
984 | dev->stats.tx_errors++; | 979 | dev->stats.tx_errors++; |
985 | if (tx_errs & 0xF800) dev->stats.tx_aborted_errors++; | 980 | if (tx_errs & 0xF800) dev->stats.tx_aborted_errors++; |
@@ -989,8 +984,8 @@ static irqreturn_t yellowfin_interrupt(int irq, void *dev_instance) | |||
989 | } else { | 984 | } else { |
990 | #ifndef final_version | 985 | #ifndef final_version |
991 | if (yellowfin_debug > 4) | 986 | if (yellowfin_debug > 4) |
992 | printk(KERN_DEBUG "%s: Normal transmit, Tx status %4.4x.\n", | 987 | netdev_printk(KERN_DEBUG, dev, "Normal transmit, Tx status %04x\n", |
993 | dev->name, tx_errs); | 988 | tx_errs); |
994 | #endif | 989 | #endif |
995 | dev->stats.tx_bytes += skb->len; | 990 | dev->stats.tx_bytes += skb->len; |
996 | dev->stats.collisions += tx_errs & 15; | 991 | dev->stats.collisions += tx_errs & 15; |
@@ -1008,8 +1003,8 @@ static irqreturn_t yellowfin_interrupt(int irq, void *dev_instance) | |||
1008 | 1003 | ||
1009 | #ifndef final_version | 1004 | #ifndef final_version |
1010 | if (yp->cur_tx - dirty_tx > TX_RING_SIZE) { | 1005 | if (yp->cur_tx - dirty_tx > TX_RING_SIZE) { |
1011 | printk(KERN_ERR "%s: Out-of-sync dirty pointer, %d vs. %d, full=%d.\n", | 1006 | netdev_err(dev, "Out-of-sync dirty pointer, %d vs. %d, full=%d\n", |
1012 | dev->name, dirty_tx, yp->cur_tx, yp->tx_full); | 1007 | dirty_tx, yp->cur_tx, yp->tx_full); |
1013 | dirty_tx += TX_RING_SIZE; | 1008 | dirty_tx += TX_RING_SIZE; |
1014 | } | 1009 | } |
1015 | #endif | 1010 | #endif |
@@ -1031,16 +1026,15 @@ static irqreturn_t yellowfin_interrupt(int irq, void *dev_instance) | |||
1031 | yellowfin_error(dev, intr_status); | 1026 | yellowfin_error(dev, intr_status); |
1032 | 1027 | ||
1033 | if (--boguscnt < 0) { | 1028 | if (--boguscnt < 0) { |
1034 | printk(KERN_WARNING "%s: Too much work at interrupt, " | 1029 | netdev_warn(dev, "Too much work at interrupt, status=%#04x\n", |
1035 | "status=0x%4.4x.\n", | 1030 | intr_status); |
1036 | dev->name, intr_status); | ||
1037 | break; | 1031 | break; |
1038 | } | 1032 | } |
1039 | } while (1); | 1033 | } while (1); |
1040 | 1034 | ||
1041 | if (yellowfin_debug > 3) | 1035 | if (yellowfin_debug > 3) |
1042 | printk(KERN_DEBUG "%s: exiting interrupt, status=%#4.4x.\n", | 1036 | netdev_printk(KERN_DEBUG, dev, "exiting interrupt, status=%#04x\n", |
1043 | dev->name, ioread16(ioaddr + IntrStatus)); | 1037 | ioread16(ioaddr + IntrStatus)); |
1044 | 1038 | ||
1045 | spin_unlock (&yp->lock); | 1039 | spin_unlock (&yp->lock); |
1046 | return IRQ_RETVAL(handled); | 1040 | return IRQ_RETVAL(handled); |
@@ -1055,9 +1049,9 @@ static int yellowfin_rx(struct net_device *dev) | |||
1055 | int boguscnt = yp->dirty_rx + RX_RING_SIZE - yp->cur_rx; | 1049 | int boguscnt = yp->dirty_rx + RX_RING_SIZE - yp->cur_rx; |
1056 | 1050 | ||
1057 | if (yellowfin_debug > 4) { | 1051 | if (yellowfin_debug > 4) { |
1058 | printk(KERN_DEBUG " In yellowfin_rx(), entry %d status %8.8x.\n", | 1052 | printk(KERN_DEBUG " In yellowfin_rx(), entry %d status %08x\n", |
1059 | entry, yp->rx_ring[entry].result_status); | 1053 | entry, yp->rx_ring[entry].result_status); |
1060 | printk(KERN_DEBUG " #%d desc. %8.8x %8.8x %8.8x.\n", | 1054 | printk(KERN_DEBUG " #%d desc. %08x %08x %08x\n", |
1061 | entry, yp->rx_ring[entry].dbdma_cmd, yp->rx_ring[entry].addr, | 1055 | entry, yp->rx_ring[entry].dbdma_cmd, yp->rx_ring[entry].addr, |
1062 | yp->rx_ring[entry].result_status); | 1056 | yp->rx_ring[entry].result_status); |
1063 | } | 1057 | } |
@@ -1081,20 +1075,20 @@ static int yellowfin_rx(struct net_device *dev) | |||
1081 | le32_to_cpu(desc->result_status)) & 0xffff; | 1075 | le32_to_cpu(desc->result_status)) & 0xffff; |
1082 | frame_status = get_unaligned_le16(&(buf_addr[data_size - 2])); | 1076 | frame_status = get_unaligned_le16(&(buf_addr[data_size - 2])); |
1083 | if (yellowfin_debug > 4) | 1077 | if (yellowfin_debug > 4) |
1084 | printk(KERN_DEBUG " yellowfin_rx() status was %4.4x.\n", | 1078 | printk(KERN_DEBUG " %s() status was %04x\n", |
1085 | frame_status); | 1079 | __func__, frame_status); |
1086 | if (--boguscnt < 0) | 1080 | if (--boguscnt < 0) |
1087 | break; | 1081 | break; |
1088 | if ( ! (desc_status & RX_EOP)) { | 1082 | if ( ! (desc_status & RX_EOP)) { |
1089 | if (data_size != 0) | 1083 | if (data_size != 0) |
1090 | printk(KERN_WARNING "%s: Oversized Ethernet frame spanned multiple buffers," | 1084 | netdev_warn(dev, "Oversized Ethernet frame spanned multiple buffers, status %04x, data_size %d!\n", |
1091 | " status %4.4x, data_size %d!\n", dev->name, desc_status, data_size); | 1085 | desc_status, data_size); |
1092 | dev->stats.rx_length_errors++; | 1086 | dev->stats.rx_length_errors++; |
1093 | } else if ((yp->drv_flags & IsGigabit) && (frame_status & 0x0038)) { | 1087 | } else if ((yp->drv_flags & IsGigabit) && (frame_status & 0x0038)) { |
1094 | /* There was a error. */ | 1088 | /* There was a error. */ |
1095 | if (yellowfin_debug > 3) | 1089 | if (yellowfin_debug > 3) |
1096 | printk(KERN_DEBUG " yellowfin_rx() Rx error was %4.4x.\n", | 1090 | printk(KERN_DEBUG " %s() Rx error was %04x\n", |
1097 | frame_status); | 1091 | __func__, frame_status); |
1098 | dev->stats.rx_errors++; | 1092 | dev->stats.rx_errors++; |
1099 | if (frame_status & 0x0060) dev->stats.rx_length_errors++; | 1093 | if (frame_status & 0x0060) dev->stats.rx_length_errors++; |
1100 | if (frame_status & 0x0008) dev->stats.rx_frame_errors++; | 1094 | if (frame_status & 0x0008) dev->stats.rx_frame_errors++; |
@@ -1118,8 +1112,8 @@ static int yellowfin_rx(struct net_device *dev) | |||
1118 | entry*sizeof(struct yellowfin_desc)), | 1112 | entry*sizeof(struct yellowfin_desc)), |
1119 | "\377\377\377\377\377\377", 6) != 0) { | 1113 | "\377\377\377\377\377\377", 6) != 0) { |
1120 | if (bogus_rx++ == 0) | 1114 | if (bogus_rx++ == 0) |
1121 | printk(KERN_WARNING "%s: Bad frame to %pM\n", | 1115 | netdev_warn(dev, "Bad frame to %pM\n", |
1122 | dev->name, buf_addr); | 1116 | buf_addr); |
1123 | #endif | 1117 | #endif |
1124 | } else { | 1118 | } else { |
1125 | struct sk_buff *skb; | 1119 | struct sk_buff *skb; |
@@ -1129,9 +1123,8 @@ static int yellowfin_rx(struct net_device *dev) | |||
1129 | 1123 | ||
1130 | #ifndef final_version | 1124 | #ifndef final_version |
1131 | if (yellowfin_debug > 4) | 1125 | if (yellowfin_debug > 4) |
1132 | printk(KERN_DEBUG " yellowfin_rx() normal Rx pkt length %d" | 1126 | printk(KERN_DEBUG " %s() normal Rx pkt length %d of %d, bogus_cnt %d\n", |
1133 | " of %d, bogus_cnt %d.\n", | 1127 | __func__, pkt_len, data_size, boguscnt); |
1134 | pkt_len, data_size, boguscnt); | ||
1135 | #endif | 1128 | #endif |
1136 | /* Check if the packet is long enough to just pass up the skbuff | 1129 | /* Check if the packet is long enough to just pass up the skbuff |
1137 | without copying to a properly sized skbuff. */ | 1130 | without copying to a properly sized skbuff. */ |
@@ -1191,8 +1184,7 @@ static int yellowfin_rx(struct net_device *dev) | |||
1191 | 1184 | ||
1192 | static void yellowfin_error(struct net_device *dev, int intr_status) | 1185 | static void yellowfin_error(struct net_device *dev, int intr_status) |
1193 | { | 1186 | { |
1194 | printk(KERN_ERR "%s: Something Wicked happened! %4.4x.\n", | 1187 | netdev_err(dev, "Something Wicked happened! %04x\n", intr_status); |
1195 | dev->name, intr_status); | ||
1196 | /* Hmmmmm, it's not clear what to do here. */ | 1188 | /* Hmmmmm, it's not clear what to do here. */ |
1197 | if (intr_status & (IntrTxPCIErr | IntrTxPCIFault)) | 1189 | if (intr_status & (IntrTxPCIErr | IntrTxPCIFault)) |
1198 | dev->stats.tx_errors++; | 1190 | dev->stats.tx_errors++; |
@@ -1209,13 +1201,13 @@ static int yellowfin_close(struct net_device *dev) | |||
1209 | netif_stop_queue (dev); | 1201 | netif_stop_queue (dev); |
1210 | 1202 | ||
1211 | if (yellowfin_debug > 1) { | 1203 | if (yellowfin_debug > 1) { |
1212 | printk(KERN_DEBUG "%s: Shutting down ethercard, status was Tx %4.4x " | 1204 | netdev_printk(KERN_DEBUG, dev, "Shutting down ethercard, status was Tx %04x Rx %04x Int %02x\n", |
1213 | "Rx %4.4x Int %2.2x.\n", | 1205 | ioread16(ioaddr + TxStatus), |
1214 | dev->name, ioread16(ioaddr + TxStatus), | 1206 | ioread16(ioaddr + RxStatus), |
1215 | ioread16(ioaddr + RxStatus), | 1207 | ioread16(ioaddr + IntrStatus)); |
1216 | ioread16(ioaddr + IntrStatus)); | 1208 | netdev_printk(KERN_DEBUG, dev, "Queue pointers were Tx %d / %d, Rx %d / %d\n", |
1217 | printk(KERN_DEBUG "%s: Queue pointers were Tx %d / %d, Rx %d / %d.\n", | 1209 | yp->cur_tx, yp->dirty_tx, |
1218 | dev->name, yp->cur_tx, yp->dirty_tx, yp->cur_rx, yp->dirty_rx); | 1210 | yp->cur_rx, yp->dirty_rx); |
1219 | } | 1211 | } |
1220 | 1212 | ||
1221 | /* Disable interrupts by clearing the interrupt mask. */ | 1213 | /* Disable interrupts by clearing the interrupt mask. */ |
@@ -1229,33 +1221,35 @@ static int yellowfin_close(struct net_device *dev) | |||
1229 | 1221 | ||
1230 | #if defined(__i386__) | 1222 | #if defined(__i386__) |
1231 | if (yellowfin_debug > 2) { | 1223 | if (yellowfin_debug > 2) { |
1232 | printk(KERN_DEBUG" Tx ring at %8.8llx:\n", | 1224 | printk(KERN_DEBUG " Tx ring at %08llx:\n", |
1233 | (unsigned long long)yp->tx_ring_dma); | 1225 | (unsigned long long)yp->tx_ring_dma); |
1234 | for (i = 0; i < TX_RING_SIZE*2; i++) | 1226 | for (i = 0; i < TX_RING_SIZE*2; i++) |
1235 | printk(KERN_DEBUG " %c #%d desc. %8.8x %8.8x %8.8x %8.8x.\n", | 1227 | printk(KERN_DEBUG " %c #%d desc. %08x %08x %08x %08x\n", |
1236 | ioread32(ioaddr + TxPtr) == (long)&yp->tx_ring[i] ? '>' : ' ', | 1228 | ioread32(ioaddr + TxPtr) == (long)&yp->tx_ring[i] ? '>' : ' ', |
1237 | i, yp->tx_ring[i].dbdma_cmd, yp->tx_ring[i].addr, | 1229 | i, yp->tx_ring[i].dbdma_cmd, yp->tx_ring[i].addr, |
1238 | yp->tx_ring[i].branch_addr, yp->tx_ring[i].result_status); | 1230 | yp->tx_ring[i].branch_addr, yp->tx_ring[i].result_status); |
1239 | printk(KERN_DEBUG " Tx status %p:\n", yp->tx_status); | 1231 | printk(KERN_DEBUG " Tx status %p:\n", yp->tx_status); |
1240 | for (i = 0; i < TX_RING_SIZE; i++) | 1232 | for (i = 0; i < TX_RING_SIZE; i++) |
1241 | printk(KERN_DEBUG " #%d status %4.4x %4.4x %4.4x %4.4x.\n", | 1233 | printk(KERN_DEBUG " #%d status %04x %04x %04x %04x\n", |
1242 | i, yp->tx_status[i].tx_cnt, yp->tx_status[i].tx_errs, | 1234 | i, yp->tx_status[i].tx_cnt, yp->tx_status[i].tx_errs, |
1243 | yp->tx_status[i].total_tx_cnt, yp->tx_status[i].paused); | 1235 | yp->tx_status[i].total_tx_cnt, yp->tx_status[i].paused); |
1244 | 1236 | ||
1245 | printk(KERN_DEBUG " Rx ring %8.8llx:\n", | 1237 | printk(KERN_DEBUG " Rx ring %08llx:\n", |
1246 | (unsigned long long)yp->rx_ring_dma); | 1238 | (unsigned long long)yp->rx_ring_dma); |
1247 | for (i = 0; i < RX_RING_SIZE; i++) { | 1239 | for (i = 0; i < RX_RING_SIZE; i++) { |
1248 | printk(KERN_DEBUG " %c #%d desc. %8.8x %8.8x %8.8x\n", | 1240 | printk(KERN_DEBUG " %c #%d desc. %08x %08x %08x\n", |
1249 | ioread32(ioaddr + RxPtr) == (long)&yp->rx_ring[i] ? '>' : ' ', | 1241 | ioread32(ioaddr + RxPtr) == (long)&yp->rx_ring[i] ? '>' : ' ', |
1250 | i, yp->rx_ring[i].dbdma_cmd, yp->rx_ring[i].addr, | 1242 | i, yp->rx_ring[i].dbdma_cmd, yp->rx_ring[i].addr, |
1251 | yp->rx_ring[i].result_status); | 1243 | yp->rx_ring[i].result_status); |
1252 | if (yellowfin_debug > 6) { | 1244 | if (yellowfin_debug > 6) { |
1253 | if (get_unaligned((u8*)yp->rx_ring[i].addr) != 0x69) { | 1245 | if (get_unaligned((u8*)yp->rx_ring[i].addr) != 0x69) { |
1254 | int j; | 1246 | int j; |
1247 | |||
1248 | printk(KERN_DEBUG); | ||
1255 | for (j = 0; j < 0x50; j++) | 1249 | for (j = 0; j < 0x50; j++) |
1256 | printk(" %4.4x", | 1250 | pr_cont(" %04x", |
1257 | get_unaligned(((u16*)yp->rx_ring[i].addr) + j)); | 1251 | get_unaligned(((u16*)yp->rx_ring[i].addr) + j)); |
1258 | printk("\n"); | 1252 | pr_cont("\n"); |
1259 | } | 1253 | } |
1260 | } | 1254 | } |
1261 | } | 1255 | } |
@@ -1281,8 +1275,8 @@ static int yellowfin_close(struct net_device *dev) | |||
1281 | 1275 | ||
1282 | #ifdef YF_PROTOTYPE /* Support for prototype hardware errata. */ | 1276 | #ifdef YF_PROTOTYPE /* Support for prototype hardware errata. */ |
1283 | if (yellowfin_debug > 0) { | 1277 | if (yellowfin_debug > 0) { |
1284 | printk(KERN_DEBUG "%s: Received %d frames that we should not have.\n", | 1278 | netdev_printk(KERN_DEBUG, dev, "Received %d frames that we should not have\n", |
1285 | dev->name, bogus_rx); | 1279 | bogus_rx); |
1286 | } | 1280 | } |
1287 | #endif | 1281 | #endif |
1288 | 1282 | ||