1 /* via-rhine.c: A Linux Ethernet device driver for VIA Rhine family chips. */
 
   3         Written 1998-2001 by Donald Becker.
 
   5         Current Maintainer: Roger Luethi <rl@hellgate.ch>
 
   7         This software may be used and distributed according to the terms of
 
   8         the GNU General Public License (GPL), incorporated herein by reference.
 
   9         Drivers based on or derived from this code fall under the GPL and must
 
  10         retain the authorship, copyright and license notice.  This file is not
 
  11         a complete program and may only be used when the entire operating
 
  12         system is licensed under the GPL.
 
  14         This driver is designed for the VIA VT86C100A Rhine-I.
 
  15         It also works with the Rhine-II (6102) and Rhine-III (6105/6105L/6105LOM
 
  16         and management NIC 6105M).
 
  18         The author may be reached as becker@scyld.com, or C/O
 
  19         Scyld Computing Corporation
 
  20         410 Severn Ave., Suite 210
 
  24         This driver contains some changes from the original Donald Becker
 
  25         version. He may or may not be interested in bug reports on this
 
  26         code. You can find his versions at:
 
  27         http://www.scyld.com/network/via-rhine.html
 
  28         [link no longer provides useful info -jgarzik]
 
  32 #define DRV_NAME        "via-rhine"
 
  33 #define DRV_VERSION     "1.4.1"
 
  34 #define DRV_RELDATE     "July-24-2006"
 
  37 /* A few user-configurable values.
 
  38    These may be modified when a driver module is loaded. */
 
  40 static int debug = 1;   /* 1 normal messages, 0 quiet .. 7 verbose. */
 
  41 static int max_interrupt_work = 20;
 
  43 /* Set the copy breakpoint for the copy-only-tiny-frames scheme.
 
  44    Setting to > 1518 effectively disables this feature. */
 
  45 static int rx_copybreak;
 
  47 /* Work-around for broken BIOSes: they are unable to get the chip back out of
 
  48    power state D3 so PXE booting fails. bootparam(7): via-rhine.avoid_D3=1 */
 
  52  * In case you are looking for 'options[]' or 'full_duplex[]', they
 
  53  * are gone. Use ethtool(8) instead.
 
  56 /* Maximum number of multicast addresses to filter (vs. rx-all-multicast).
 
  57    The Rhine has a 64 element 8390-like hash table. */
 
  58 static const int multicast_filter_limit = 32;
 
  61 /* Operational parameters that are set at compile time. */
 
  63 /* Keep the ring sizes a power of two for compile efficiency.
 
  64    The compiler will convert <unsigned>'%'<2^N> into a bit mask.
 
  65    Making the Tx ring too large decreases the effectiveness of channel
 
  66    bonding and packet priority.
 
  67    There are no ill effects from too-large receive rings. */
 
  68 #define TX_RING_SIZE    16
 
  69 #define TX_QUEUE_LEN    10      /* Limit ring entries actually used. */
 
  70 #ifdef CONFIG_VIA_RHINE_NAPI
 
  71 #define RX_RING_SIZE    64
 
  73 #define RX_RING_SIZE    16
 
  77 /* Operational parameters that usually are not changed. */
 
  79 /* Time in jiffies before concluding the transmitter is hung. */
 
  80 #define TX_TIMEOUT      (2*HZ)
 
  82 #define PKT_BUF_SZ      1536    /* Size of each temporary Rx buffer.*/
 
  84 #include <linux/module.h>
 
  85 #include <linux/moduleparam.h>
 
  86 #include <linux/kernel.h>
 
  87 #include <linux/string.h>
 
  88 #include <linux/timer.h>
 
  89 #include <linux/errno.h>
 
  90 #include <linux/ioport.h>
 
  91 #include <linux/slab.h>
 
  92 #include <linux/interrupt.h>
 
  93 #include <linux/pci.h>
 
  94 #include <linux/dma-mapping.h>
 
  95 #include <linux/netdevice.h>
 
  96 #include <linux/etherdevice.h>
 
  97 #include <linux/skbuff.h>
 
  98 #include <linux/init.h>
 
  99 #include <linux/delay.h>
 
 100 #include <linux/mii.h>
 
 101 #include <linux/ethtool.h>
 
 102 #include <linux/crc32.h>
 
 103 #include <linux/bitops.h>
 
 104 #include <asm/processor.h>      /* Processor type for cache alignment. */
 
 107 #include <asm/uaccess.h>
 
 109 /* These identify the driver base version and may not be removed. */
 
 110 static char version[] __devinitdata =
 
 111 KERN_INFO DRV_NAME ".c:v1.10-LK" DRV_VERSION " " DRV_RELDATE " Written by Donald Becker\n";
 
 113 /* This driver was written to use PCI memory space. Some early versions
 
 114    of the Rhine may only work correctly with I/O space accesses. */
 
 115 #ifdef CONFIG_VIA_RHINE_MMIO
 
 120 MODULE_AUTHOR("Donald Becker <becker@scyld.com>");
 
 121 MODULE_DESCRIPTION("VIA Rhine PCI Fast Ethernet driver");
 
 122 MODULE_LICENSE("GPL");
 
 124 module_param(max_interrupt_work, int, 0);
 
 125 module_param(debug, int, 0);
 
 126 module_param(rx_copybreak, int, 0);
 
 127 module_param(avoid_D3, bool, 0);
 
 128 MODULE_PARM_DESC(max_interrupt_work, "VIA Rhine maximum events handled per interrupt");
 
 129 MODULE_PARM_DESC(debug, "VIA Rhine debug level (0-7)");
 
 130 MODULE_PARM_DESC(rx_copybreak, "VIA Rhine copy breakpoint for copy-only-tiny-frames");
 
 131 MODULE_PARM_DESC(avoid_D3, "Avoid power state D3 (work-around for broken BIOSes)");
 
 136 I. Board Compatibility
 
 138 This driver is designed for the VIA 86c100A Rhine-II PCI Fast Ethernet
 
 141 II. Board-specific settings
 
 143 Boards with this chip are functional only in a bus-master PCI slot.
 
 145 Many operational settings are loaded from the EEPROM to the Config word at
 
 146 offset 0x78. For most of these settings, this driver assumes that they are
 
 148 If this driver is compiled to use PCI memory space operations the EEPROM
 
 149 must be configured to enable memory ops.
 
 151 III. Driver operation
 
 155 This driver uses two statically allocated fixed-size descriptor lists
 
 156 formed into rings by a branch from the final descriptor to the beginning of
 
 157 the list. The ring sizes are set at compile time by RX/TX_RING_SIZE.
 
 159 IIIb/c. Transmit/Receive Structure
 
 161 This driver attempts to use a zero-copy receive and transmit scheme.
 
 163 Alas, all data buffers are required to start on a 32 bit boundary, so
 
 164 the driver must often copy transmit packets into bounce buffers.
 
 166 The driver allocates full frame size skbuffs for the Rx ring buffers at
 
 167 open() time and passes the skb->data field to the chip as receive data
 
 168 buffers. When an incoming frame is less than RX_COPYBREAK bytes long,
 
 169 a fresh skbuff is allocated and the frame is copied to the new skbuff.
 
 170 When the incoming frame is larger, the skbuff is passed directly up the
 
 171 protocol stack. Buffers consumed this way are replaced by newly allocated
 
 172 skbuffs in the last phase of rhine_rx().
 
 174 The RX_COPYBREAK value is chosen to trade-off the memory wasted by
 
 175 using a full-sized skbuff for small frames vs. the copying costs of larger
 
 176 frames. New boards are typically used in generously configured machines
 
 177 and the underfilled buffers have negligible impact compared to the benefit of
 
 178 a single allocation size, so the default value of zero results in never
 
 179 copying packets. When copying is done, the cost is usually mitigated by using
 
 180 a combined copy/checksum routine. Copying also preloads the cache, which is
 
 181 most useful with small frames.
 
 183 Since the VIA chips are only able to transfer data to buffers on 32 bit
 
 184 boundaries, the IP header at offset 14 in an ethernet frame isn't
 
 185 longword aligned for further processing. Copying these unaligned buffers
 
 186 has the beneficial effect of 16-byte aligning the IP header.
 
 188 IIId. Synchronization
 
 190 The driver runs as two independent, single-threaded flows of control. One
 
 191 is the send-packet routine, which enforces single-threaded use by the
 
 192 dev->priv->lock spinlock. The other thread is the interrupt handler, which
 
 193 is single threaded by the hardware and interrupt handling software.
 
 195 The send packet thread has partial control over the Tx ring. It locks the
 
 196 dev->priv->lock whenever it's queuing a Tx packet. If the next slot in the ring
 
 197 is not available it stops the transmit queue by calling netif_stop_queue.
 
 199 The interrupt handler has exclusive control over the Rx ring and records stats
 
 200 from the Tx ring. After reaping the stats, it marks the Tx queue entry as
 
 201 empty by incrementing the dirty_tx mark. If at least half of the entries in
 
 202 the Rx ring are available the transmit queue is woken up if it was stopped.
 
 208 Preliminary VT86C100A manual from http://www.via.com.tw/
 
 209 http://www.scyld.com/expert/100mbps.html
 
 210 http://www.scyld.com/expert/NWay.html
 
 211 ftp://ftp.via.com.tw/public/lan/Products/NIC/VT86C100A/Datasheet/VT86C100A03.pdf
 
 212 ftp://ftp.via.com.tw/public/lan/Products/NIC/VT6102/Datasheet/VT6102_021.PDF
 
 217 The VT86C100A manual is not reliable information.
 
 218 The 3043 chip does not handle unaligned transmit or receive buffers, resulting
 
 219 in significant performance degradation for bounce buffer copies on transmit
 
 220 and unaligned IP headers on receive.
 
 221 The chip does not pad to minimum transmit length.
 
 226 /* This table drives the PCI probe routines. It's mostly boilerplate in all
 
 227    of the drivers, and will likely be provided by some future kernel.
 
 228    Note the matching code -- the first table entry matchs all 56** cards but
 
 229    second only the 1234 card.
 
 236         VT8231          = 0x50, /* Integrated MAC */
 
 237         VT8233          = 0x60, /* Integrated MAC */
 
 238         VT8235          = 0x74, /* Integrated MAC */
 
 239         VT8237          = 0x78, /* Integrated MAC */
 
 246         VT6105M         = 0x90, /* Management adapter */
 
 250         rqWOL           = 0x0001,       /* Wake-On-LAN support */
 
 251         rqForceReset    = 0x0002,
 
 252         rq6patterns     = 0x0040,       /* 6 instead of 4 patterns for WOL */
 
 253         rqStatusWBRace  = 0x0080,       /* Tx Status Writeback Error possible */
 
 254         rqRhineI        = 0x0100,       /* See comment below */
 
 257  * rqRhineI: VT86C100A (aka Rhine-I) uses different bits to enable
 
 258  * MMIO as well as for the collision counter and the Tx FIFO underflow
 
 259  * indicator. In addition, Tx and Rx buffers need to 4 byte aligned.
 
 262 /* Beware of PCI posted writes */
 
 263 #define IOSYNC  do { ioread8(ioaddr + StationAddr); } while (0)
 
 265 static const struct pci_device_id rhine_pci_tbl[] = {
 
 266         { 0x1106, 0x3043, PCI_ANY_ID, PCI_ANY_ID, },    /* VT86C100A */
 
 267         { 0x1106, 0x3065, PCI_ANY_ID, PCI_ANY_ID, },    /* VT6102 */
 
 268         { 0x1106, 0x3106, PCI_ANY_ID, PCI_ANY_ID, },    /* 6105{,L,LOM} */
 
 269         { 0x1106, 0x3053, PCI_ANY_ID, PCI_ANY_ID, },    /* VT6105M */
 
 270         { }     /* terminate list */
 
 272 MODULE_DEVICE_TABLE(pci, rhine_pci_tbl);
 
 275 /* Offsets to the device registers. */
 
 276 enum register_offsets {
 
 277         StationAddr=0x00, RxConfig=0x06, TxConfig=0x07, ChipCmd=0x08,
 
 279         IntrStatus=0x0C, IntrEnable=0x0E,
 
 280         MulticastFilter0=0x10, MulticastFilter1=0x14,
 
 281         RxRingPtr=0x18, TxRingPtr=0x1C, GFIFOTest=0x54,
 
 282         MIIPhyAddr=0x6C, MIIStatus=0x6D, PCIBusConfig=0x6E,
 
 283         MIICmd=0x70, MIIRegAddr=0x71, MIIData=0x72, MACRegEEcsr=0x74,
 
 284         ConfigA=0x78, ConfigB=0x79, ConfigC=0x7A, ConfigD=0x7B,
 
 285         RxMissed=0x7C, RxCRCErrs=0x7E, MiscCmd=0x81,
 
 286         StickyHW=0x83, IntrStatus2=0x84,
 
 287         WOLcrSet=0xA0, PwcfgSet=0xA1, WOLcgSet=0xA3, WOLcrClr=0xA4,
 
 288         WOLcrClr1=0xA6, WOLcgClr=0xA7,
 
 289         PwrcsrSet=0xA8, PwrcsrSet1=0xA9, PwrcsrClr=0xAC, PwrcsrClr1=0xAD,
 
 292 /* Bits in ConfigD */
 
 294         BackOptional=0x01, BackModify=0x02,
 
 295         BackCaptureEffect=0x04, BackRandom=0x08
 
 299 /* Registers we check that mmio and reg are the same. */
 
 300 static const int mmio_verify_registers[] = {
 
 301         RxConfig, TxConfig, IntrEnable, ConfigA, ConfigB, ConfigC, ConfigD,
 
 306 /* Bits in the interrupt status/mask registers. */
 
 307 enum intr_status_bits {
 
 308         IntrRxDone=0x0001, IntrRxErr=0x0004, IntrRxEmpty=0x0020,
 
 309         IntrTxDone=0x0002, IntrTxError=0x0008, IntrTxUnderrun=0x0210,
 
 311         IntrStatsMax=0x0080, IntrRxEarly=0x0100,
 
 312         IntrRxOverflow=0x0400, IntrRxDropped=0x0800, IntrRxNoBuf=0x1000,
 
 313         IntrTxAborted=0x2000, IntrLinkChange=0x4000,
 
 315         IntrNormalSummary=0x0003, IntrAbnormalSummary=0xC260,
 
 316         IntrTxDescRace=0x080000,        /* mapped from IntrStatus2 */
 
 317         IntrTxErrSummary=0x082218,
 
 320 /* Bits in WOLcrSet/WOLcrClr and PwrcsrSet/PwrcsrClr */
 
 329 /* The Rx and Tx buffer descriptors. */
 
 332         u32 desc_length; /* Chain flag, Buffer/frame length */
 
 338         u32 desc_length; /* Chain flag, Tx Config, Frame length */
 
 343 /* Initial value for tx_desc.desc_length, Buffer size goes to bits 0-10 */
 
 344 #define TXDESC          0x00e08000
 
 346 enum rx_status_bits {
 
 347         RxOK=0x8000, RxWholePkt=0x0300, RxErr=0x008F
 
 350 /* Bits in *_desc.*_status */
 
 351 enum desc_status_bits {
 
 355 /* Bits in ChipCmd. */
 
 357         CmdInit=0x01, CmdStart=0x02, CmdStop=0x04, CmdRxOn=0x08,
 
 358         CmdTxOn=0x10, Cmd1TxDemand=0x20, CmdRxDemand=0x40,
 
 359         Cmd1EarlyRx=0x01, Cmd1EarlyTx=0x02, Cmd1FDuplex=0x04,
 
 360         Cmd1NoTxPoll=0x08, Cmd1Reset=0x80,
 
 363 struct rhine_private {
 
 364         /* Descriptor rings */
 
 365         struct rx_desc *rx_ring;
 
 366         struct tx_desc *tx_ring;
 
 367         dma_addr_t rx_ring_dma;
 
 368         dma_addr_t tx_ring_dma;
 
 370         /* The addresses of receive-in-place skbuffs. */
 
 371         struct sk_buff *rx_skbuff[RX_RING_SIZE];
 
 372         dma_addr_t rx_skbuff_dma[RX_RING_SIZE];
 
 374         /* The saved address of a sent-in-place packet/buffer, for later free(). */
 
 375         struct sk_buff *tx_skbuff[TX_RING_SIZE];
 
 376         dma_addr_t tx_skbuff_dma[TX_RING_SIZE];
 
 378         /* Tx bounce buffers (Rhine-I only) */
 
 379         unsigned char *tx_buf[TX_RING_SIZE];
 
 380         unsigned char *tx_bufs;
 
 381         dma_addr_t tx_bufs_dma;
 
 383         struct pci_dev *pdev;
 
 385         struct net_device_stats stats;
 
 388         /* Frequently used values: keep some adjacent for cache effect. */
 
 390         struct rx_desc *rx_head_desc;
 
 391         unsigned int cur_rx, dirty_rx;  /* Producer/consumer ring indices */
 
 392         unsigned int cur_tx, dirty_tx;
 
 393         unsigned int rx_buf_sz;         /* Based on MTU+slack. */
 
 396         u8 tx_thresh, rx_thresh;
 
 398         struct mii_if_info mii_if;
 
 402 static int  mdio_read(struct net_device *dev, int phy_id, int location);
 
 403 static void mdio_write(struct net_device *dev, int phy_id, int location, int value);
 
 404 static int  rhine_open(struct net_device *dev);
 
 405 static void rhine_tx_timeout(struct net_device *dev);
 
 406 static int  rhine_start_tx(struct sk_buff *skb, struct net_device *dev);
 
 407 static irqreturn_t rhine_interrupt(int irq, void *dev_instance, struct pt_regs *regs);
 
 408 static void rhine_tx(struct net_device *dev);
 
 409 static int rhine_rx(struct net_device *dev, int limit);
 
 410 static void rhine_error(struct net_device *dev, int intr_status);
 
 411 static void rhine_set_rx_mode(struct net_device *dev);
 
 412 static struct net_device_stats *rhine_get_stats(struct net_device *dev);
 
 413 static int netdev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
 
 414 static struct ethtool_ops netdev_ethtool_ops;
 
 415 static int  rhine_close(struct net_device *dev);
 
 416 static void rhine_shutdown (struct pci_dev *pdev);
 
 418 #define RHINE_WAIT_FOR(condition) do {                                  \
 
 420         while (!(condition) && --i)                                     \
 
 422         if (debug > 1 && i < 512)                                       \
 
 423                 printk(KERN_INFO "%s: %4d cycles used @ %s:%d\n",       \
 
 424                                 DRV_NAME, 1024-i, __func__, __LINE__);  \
 
 427 static inline u32 get_intr_status(struct net_device *dev)
 
 429         struct rhine_private *rp = netdev_priv(dev);
 
 430         void __iomem *ioaddr = rp->base;
 
 433         intr_status = ioread16(ioaddr + IntrStatus);
 
 434         /* On Rhine-II, Bit 3 indicates Tx descriptor write-back race. */
 
 435         if (rp->quirks & rqStatusWBRace)
 
 436                 intr_status |= ioread8(ioaddr + IntrStatus2) << 16;
 
 441  * Get power related registers into sane state.
 
 442  * Notify user about past WOL event.
 
 444 static void rhine_power_init(struct net_device *dev)
 
 446         struct rhine_private *rp = netdev_priv(dev);
 
 447         void __iomem *ioaddr = rp->base;
 
 450         if (rp->quirks & rqWOL) {
 
 451                 /* Make sure chip is in power state D0 */
 
 452                 iowrite8(ioread8(ioaddr + StickyHW) & 0xFC, ioaddr + StickyHW);
 
 454                 /* Disable "force PME-enable" */
 
 455                 iowrite8(0x80, ioaddr + WOLcgClr);
 
 457                 /* Clear power-event config bits (WOL) */
 
 458                 iowrite8(0xFF, ioaddr + WOLcrClr);
 
 459                 /* More recent cards can manage two additional patterns */
 
 460                 if (rp->quirks & rq6patterns)
 
 461                         iowrite8(0x03, ioaddr + WOLcrClr1);
 
 463                 /* Save power-event status bits */
 
 464                 wolstat = ioread8(ioaddr + PwrcsrSet);
 
 465                 if (rp->quirks & rq6patterns)
 
 466                         wolstat |= (ioread8(ioaddr + PwrcsrSet1) & 0x03) << 8;
 
 468                 /* Clear power-event status bits */
 
 469                 iowrite8(0xFF, ioaddr + PwrcsrClr);
 
 470                 if (rp->quirks & rq6patterns)
 
 471                         iowrite8(0x03, ioaddr + PwrcsrClr1);
 
 477                                 reason = "Magic packet";
 
 480                                 reason = "Link went up";
 
 483                                 reason = "Link went down";
 
 486                                 reason = "Unicast packet";
 
 489                                 reason = "Multicast/broadcast packet";
 
 494                         printk(KERN_INFO "%s: Woke system up. Reason: %s.\n",
 
 500 static void rhine_chip_reset(struct net_device *dev)
 
 502         struct rhine_private *rp = netdev_priv(dev);
 
 503         void __iomem *ioaddr = rp->base;
 
 505         iowrite8(Cmd1Reset, ioaddr + ChipCmd1);
 
 508         if (ioread8(ioaddr + ChipCmd1) & Cmd1Reset) {
 
 509                 printk(KERN_INFO "%s: Reset not complete yet. "
 
 510                         "Trying harder.\n", DRV_NAME);
 
 513                 if (rp->quirks & rqForceReset)
 
 514                         iowrite8(0x40, ioaddr + MiscCmd);
 
 516                 /* Reset can take somewhat longer (rare) */
 
 517                 RHINE_WAIT_FOR(!(ioread8(ioaddr + ChipCmd1) & Cmd1Reset));
 
 521                 printk(KERN_INFO "%s: Reset %s.\n", dev->name,
 
 522                         (ioread8(ioaddr + ChipCmd1) & Cmd1Reset) ?
 
 523                         "failed" : "succeeded");
 
 527 static void enable_mmio(long pioaddr, u32 quirks)
 
 530         if (quirks & rqRhineI) {
 
 531                 /* More recent docs say that this bit is reserved ... */
 
 532                 n = inb(pioaddr + ConfigA) | 0x20;
 
 533                 outb(n, pioaddr + ConfigA);
 
 535                 n = inb(pioaddr + ConfigD) | 0x80;
 
 536                 outb(n, pioaddr + ConfigD);
 
 542  * Loads bytes 0x00-0x05, 0x6E-0x6F, 0x78-0x7B from EEPROM
 
 543  * (plus 0x6C for Rhine-I/II)
 
 545 static void __devinit rhine_reload_eeprom(long pioaddr, struct net_device *dev)
 
 547         struct rhine_private *rp = netdev_priv(dev);
 
 548         void __iomem *ioaddr = rp->base;
 
 550         outb(0x20, pioaddr + MACRegEEcsr);
 
 551         RHINE_WAIT_FOR(!(inb(pioaddr + MACRegEEcsr) & 0x20));
 
 555          * Reloading from EEPROM overwrites ConfigA-D, so we must re-enable
 
 556          * MMIO. If reloading EEPROM was done first this could be avoided, but
 
 557          * it is not known if that still works with the "win98-reboot" problem.
 
 559         enable_mmio(pioaddr, rp->quirks);
 
 562         /* Turn off EEPROM-controlled wake-up (magic packet) */
 
 563         if (rp->quirks & rqWOL)
 
 564                 iowrite8(ioread8(ioaddr + ConfigA) & 0xFC, ioaddr + ConfigA);
 
 568 #ifdef CONFIG_NET_POLL_CONTROLLER
 
 569 static void rhine_poll(struct net_device *dev)
 
 571         disable_irq(dev->irq);
 
 572         rhine_interrupt(dev->irq, (void *)dev, NULL);
 
 573         enable_irq(dev->irq);
 
 577 #ifdef CONFIG_VIA_RHINE_NAPI
 
 578 static int rhine_napipoll(struct net_device *dev, int *budget)
 
 580         struct rhine_private *rp = netdev_priv(dev);
 
 581         void __iomem *ioaddr = rp->base;
 
 582         int done, limit = min(dev->quota, *budget);
 
 584         done = rhine_rx(dev, limit);
 
 589                 netif_rx_complete(dev);
 
 591                 iowrite16(IntrRxDone | IntrRxErr | IntrRxEmpty| IntrRxOverflow |
 
 592                           IntrRxDropped | IntrRxNoBuf | IntrTxAborted |
 
 593                           IntrTxDone | IntrTxError | IntrTxUnderrun |
 
 594                           IntrPCIErr | IntrStatsMax | IntrLinkChange,
 
 595                           ioaddr + IntrEnable);
 
 603 static void rhine_hw_init(struct net_device *dev, long pioaddr)
 
 605         struct rhine_private *rp = netdev_priv(dev);
 
 607         /* Reset the chip to erase previous misconfiguration. */
 
 608         rhine_chip_reset(dev);
 
 610         /* Rhine-I needs extra time to recuperate before EEPROM reload */
 
 611         if (rp->quirks & rqRhineI)
 
 614         /* Reload EEPROM controlled bytes cleared by soft reset */
 
 615         rhine_reload_eeprom(pioaddr, dev);
 
 618 static int __devinit rhine_init_one(struct pci_dev *pdev,
 
 619                                     const struct pci_device_id *ent)
 
 621         struct net_device *dev;
 
 622         struct rhine_private *rp;
 
 628         void __iomem *ioaddr;
 
 637 /* when built into the kernel, we only print version if device is found */
 
 639         static int printed_version;
 
 640         if (!printed_version++)
 
 644         pci_read_config_byte(pdev, PCI_REVISION_ID, &pci_rev);
 
 650         if (pci_rev < VTunknown0) {
 
 654         else if (pci_rev >= VT6102) {
 
 655                 quirks = rqWOL | rqForceReset;
 
 656                 if (pci_rev < VT6105) {
 
 658                         quirks |= rqStatusWBRace;       /* Rhine-II exclusive */
 
 661                         phy_id = 1;     /* Integrated PHY, phy_id fixed to 1 */
 
 662                         if (pci_rev >= VT6105_B0)
 
 663                                 quirks |= rq6patterns;
 
 664                         if (pci_rev < VT6105M)
 
 667                                 name = "Rhine III (Management Adapter)";
 
 671         rc = pci_enable_device(pdev);
 
 675         /* this should always be supported */
 
 676         rc = pci_set_dma_mask(pdev, DMA_32BIT_MASK);
 
 678                 printk(KERN_ERR "32-bit PCI DMA addresses not supported by "
 
 684         if ((pci_resource_len(pdev, 0) < io_size) ||
 
 685             (pci_resource_len(pdev, 1) < io_size)) {
 
 687                 printk(KERN_ERR "Insufficient PCI resources, aborting\n");
 
 691         pioaddr = pci_resource_start(pdev, 0);
 
 692         memaddr = pci_resource_start(pdev, 1);
 
 694         pci_set_master(pdev);
 
 696         dev = alloc_etherdev(sizeof(struct rhine_private));
 
 699                 printk(KERN_ERR "alloc_etherdev failed\n");
 
 702         SET_MODULE_OWNER(dev);
 
 703         SET_NETDEV_DEV(dev, &pdev->dev);
 
 705         rp = netdev_priv(dev);
 
 707         rp->pioaddr = pioaddr;
 
 710         rc = pci_request_regions(pdev, DRV_NAME);
 
 712                 goto err_out_free_netdev;
 
 714         ioaddr = pci_iomap(pdev, bar, io_size);
 
 717                 printk(KERN_ERR "ioremap failed for device %s, region 0x%X "
 
 718                        "@ 0x%lX\n", pci_name(pdev), io_size, memaddr);
 
 719                 goto err_out_free_res;
 
 723         enable_mmio(pioaddr, quirks);
 
 725         /* Check that selected MMIO registers match the PIO ones */
 
 727         while (mmio_verify_registers[i]) {
 
 728                 int reg = mmio_verify_registers[i++];
 
 729                 unsigned char a = inb(pioaddr+reg);
 
 730                 unsigned char b = readb(ioaddr+reg);
 
 733                         printk(KERN_ERR "MMIO do not match PIO [%02x] "
 
 734                                "(%02x != %02x)\n", reg, a, b);
 
 738 #endif /* USE_MMIO */
 
 740         dev->base_addr = (unsigned long)ioaddr;
 
 743         /* Get chip registers into a sane state */
 
 744         rhine_power_init(dev);
 
 745         rhine_hw_init(dev, pioaddr);
 
 747         for (i = 0; i < 6; i++)
 
 748                 dev->dev_addr[i] = ioread8(ioaddr + StationAddr + i);
 
 749         memcpy(dev->perm_addr, dev->dev_addr, dev->addr_len);
 
 751         if (!is_valid_ether_addr(dev->perm_addr)) {
 
 753                 printk(KERN_ERR "Invalid MAC address\n");
 
 757         /* For Rhine-I/II, phy_id is loaded from EEPROM */
 
 759                 phy_id = ioread8(ioaddr + 0x6C);
 
 761         dev->irq = pdev->irq;
 
 763         spin_lock_init(&rp->lock);
 
 764         rp->mii_if.dev = dev;
 
 765         rp->mii_if.mdio_read = mdio_read;
 
 766         rp->mii_if.mdio_write = mdio_write;
 
 767         rp->mii_if.phy_id_mask = 0x1f;
 
 768         rp->mii_if.reg_num_mask = 0x1f;
 
 770         /* The chip-specific entries in the device structure. */
 
 771         dev->open = rhine_open;
 
 772         dev->hard_start_xmit = rhine_start_tx;
 
 773         dev->stop = rhine_close;
 
 774         dev->get_stats = rhine_get_stats;
 
 775         dev->set_multicast_list = rhine_set_rx_mode;
 
 776         dev->do_ioctl = netdev_ioctl;
 
 777         dev->ethtool_ops = &netdev_ethtool_ops;
 
 778         dev->tx_timeout = rhine_tx_timeout;
 
 779         dev->watchdog_timeo = TX_TIMEOUT;
 
 780 #ifdef CONFIG_NET_POLL_CONTROLLER
 
 781         dev->poll_controller = rhine_poll;
 
 783 #ifdef CONFIG_VIA_RHINE_NAPI
 
 784         dev->poll = rhine_napipoll;
 
 787         if (rp->quirks & rqRhineI)
 
 788                 dev->features |= NETIF_F_SG|NETIF_F_HW_CSUM;
 
 790         /* dev->name not defined before register_netdev()! */
 
 791         rc = register_netdev(dev);
 
 795         printk(KERN_INFO "%s: VIA %s at 0x%lx, ",
 
 804         for (i = 0; i < 5; i++)
 
 805                 printk("%2.2x:", dev->dev_addr[i]);
 
 806         printk("%2.2x, IRQ %d.\n", dev->dev_addr[i], pdev->irq);
 
 808         pci_set_drvdata(pdev, dev);
 
 812                 int mii_status = mdio_read(dev, phy_id, 1);
 
 813                 mii_cmd = mdio_read(dev, phy_id, MII_BMCR) & ~BMCR_ISOLATE;
 
 814                 mdio_write(dev, phy_id, MII_BMCR, mii_cmd);
 
 815                 if (mii_status != 0xffff && mii_status != 0x0000) {
 
 816                         rp->mii_if.advertising = mdio_read(dev, phy_id, 4);
 
 817                         printk(KERN_INFO "%s: MII PHY found at address "
 
 818                                "%d, status 0x%4.4x advertising %4.4x "
 
 819                                "Link %4.4x.\n", dev->name, phy_id,
 
 820                                mii_status, rp->mii_if.advertising,
 
 821                                mdio_read(dev, phy_id, 5));
 
 823                         /* set IFF_RUNNING */
 
 824                         if (mii_status & BMSR_LSTATUS)
 
 825                                 netif_carrier_on(dev);
 
 827                                 netif_carrier_off(dev);
 
 831         rp->mii_if.phy_id = phy_id;
 
 832         if (debug > 1 && avoid_D3)
 
 833                 printk(KERN_INFO "%s: No D3 power state at shutdown.\n",
 
 839         pci_iounmap(pdev, ioaddr);
 
 841         pci_release_regions(pdev);
 
 848 static int alloc_ring(struct net_device* dev)
 
 850         struct rhine_private *rp = netdev_priv(dev);
 
 854         ring = pci_alloc_consistent(rp->pdev,
 
 855                                     RX_RING_SIZE * sizeof(struct rx_desc) +
 
 856                                     TX_RING_SIZE * sizeof(struct tx_desc),
 
 859                 printk(KERN_ERR "Could not allocate DMA memory.\n");
 
 862         if (rp->quirks & rqRhineI) {
 
 863                 rp->tx_bufs = pci_alloc_consistent(rp->pdev,
 
 864                                                    PKT_BUF_SZ * TX_RING_SIZE,
 
 866                 if (rp->tx_bufs == NULL) {
 
 867                         pci_free_consistent(rp->pdev,
 
 868                                     RX_RING_SIZE * sizeof(struct rx_desc) +
 
 869                                     TX_RING_SIZE * sizeof(struct tx_desc),
 
 876         rp->tx_ring = ring + RX_RING_SIZE * sizeof(struct rx_desc);
 
 877         rp->rx_ring_dma = ring_dma;
 
 878         rp->tx_ring_dma = ring_dma + RX_RING_SIZE * sizeof(struct rx_desc);
 
 883 static void free_ring(struct net_device* dev)
 
 885         struct rhine_private *rp = netdev_priv(dev);
 
 887         pci_free_consistent(rp->pdev,
 
 888                             RX_RING_SIZE * sizeof(struct rx_desc) +
 
 889                             TX_RING_SIZE * sizeof(struct tx_desc),
 
 890                             rp->rx_ring, rp->rx_ring_dma);
 
 894                 pci_free_consistent(rp->pdev, PKT_BUF_SZ * TX_RING_SIZE,
 
 895                                     rp->tx_bufs, rp->tx_bufs_dma);
 
 901 static void alloc_rbufs(struct net_device *dev)
 
 903         struct rhine_private *rp = netdev_priv(dev);
 
 907         rp->dirty_rx = rp->cur_rx = 0;
 
 909         rp->rx_buf_sz = (dev->mtu <= 1500 ? PKT_BUF_SZ : dev->mtu + 32);
 
 910         rp->rx_head_desc = &rp->rx_ring[0];
 
 911         next = rp->rx_ring_dma;
 
 913         /* Init the ring entries */
 
 914         for (i = 0; i < RX_RING_SIZE; i++) {
 
 915                 rp->rx_ring[i].rx_status = 0;
 
 916                 rp->rx_ring[i].desc_length = cpu_to_le32(rp->rx_buf_sz);
 
 917                 next += sizeof(struct rx_desc);
 
 918                 rp->rx_ring[i].next_desc = cpu_to_le32(next);
 
 919                 rp->rx_skbuff[i] = NULL;
 
 921         /* Mark the last entry as wrapping the ring. */
 
 922         rp->rx_ring[i-1].next_desc = cpu_to_le32(rp->rx_ring_dma);
 
 924         /* Fill in the Rx buffers.  Handle allocation failure gracefully. */
 
 925         for (i = 0; i < RX_RING_SIZE; i++) {
 
 926                 struct sk_buff *skb = dev_alloc_skb(rp->rx_buf_sz);
 
 927                 rp->rx_skbuff[i] = skb;
 
 930                 skb->dev = dev;                 /* Mark as being used by this device. */
 
 932                 rp->rx_skbuff_dma[i] =
 
 933                         pci_map_single(rp->pdev, skb->data, rp->rx_buf_sz,
 
 936                 rp->rx_ring[i].addr = cpu_to_le32(rp->rx_skbuff_dma[i]);
 
 937                 rp->rx_ring[i].rx_status = cpu_to_le32(DescOwn);
 
 939         rp->dirty_rx = (unsigned int)(i - RX_RING_SIZE);
 
 942 static void free_rbufs(struct net_device* dev)
 
 944         struct rhine_private *rp = netdev_priv(dev);
 
 947         /* Free all the skbuffs in the Rx queue. */
 
 948         for (i = 0; i < RX_RING_SIZE; i++) {
 
 949                 rp->rx_ring[i].rx_status = 0;
 
 950                 rp->rx_ring[i].addr = cpu_to_le32(0xBADF00D0); /* An invalid address. */
 
 951                 if (rp->rx_skbuff[i]) {
 
 952                         pci_unmap_single(rp->pdev,
 
 953                                          rp->rx_skbuff_dma[i],
 
 954                                          rp->rx_buf_sz, PCI_DMA_FROMDEVICE);
 
 955                         dev_kfree_skb(rp->rx_skbuff[i]);
 
 957                 rp->rx_skbuff[i] = NULL;
 
 961 static void alloc_tbufs(struct net_device* dev)
 
 963         struct rhine_private *rp = netdev_priv(dev);
 
 967         rp->dirty_tx = rp->cur_tx = 0;
 
 968         next = rp->tx_ring_dma;
 
 969         for (i = 0; i < TX_RING_SIZE; i++) {
 
 970                 rp->tx_skbuff[i] = NULL;
 
 971                 rp->tx_ring[i].tx_status = 0;
 
 972                 rp->tx_ring[i].desc_length = cpu_to_le32(TXDESC);
 
 973                 next += sizeof(struct tx_desc);
 
 974                 rp->tx_ring[i].next_desc = cpu_to_le32(next);
 
 975                 if (rp->quirks & rqRhineI)
 
 976                         rp->tx_buf[i] = &rp->tx_bufs[i * PKT_BUF_SZ];
 
 978         rp->tx_ring[i-1].next_desc = cpu_to_le32(rp->tx_ring_dma);
 
 982 static void free_tbufs(struct net_device* dev)
 
 984         struct rhine_private *rp = netdev_priv(dev);
 
 987         for (i = 0; i < TX_RING_SIZE; i++) {
 
 988                 rp->tx_ring[i].tx_status = 0;
 
 989                 rp->tx_ring[i].desc_length = cpu_to_le32(TXDESC);
 
 990                 rp->tx_ring[i].addr = cpu_to_le32(0xBADF00D0); /* An invalid address. */
 
 991                 if (rp->tx_skbuff[i]) {
 
 992                         if (rp->tx_skbuff_dma[i]) {
 
 993                                 pci_unmap_single(rp->pdev,
 
 994                                                  rp->tx_skbuff_dma[i],
 
 995                                                  rp->tx_skbuff[i]->len,
 
 998                         dev_kfree_skb(rp->tx_skbuff[i]);
 
1000                 rp->tx_skbuff[i] = NULL;
 
1001                 rp->tx_buf[i] = NULL;
 
1005 static void rhine_check_media(struct net_device *dev, unsigned int init_media)
 
1007         struct rhine_private *rp = netdev_priv(dev);
 
1008         void __iomem *ioaddr = rp->base;
 
1010         mii_check_media(&rp->mii_if, debug, init_media);
 
1012         if (rp->mii_if.full_duplex)
 
1013             iowrite8(ioread8(ioaddr + ChipCmd1) | Cmd1FDuplex,
 
1016             iowrite8(ioread8(ioaddr + ChipCmd1) & ~Cmd1FDuplex,
 
1019                 printk(KERN_INFO "%s: force_media %d, carrier %d\n", dev->name,
 
1020                         rp->mii_if.force_media, netif_carrier_ok(dev));
 
1023 /* Called after status of force_media possibly changed */
 
1024 static void rhine_set_carrier(struct mii_if_info *mii)
 
1026         if (mii->force_media) {
 
1027                 /* autoneg is off: Link is always assumed to be up */
 
1028                 if (!netif_carrier_ok(mii->dev))
 
1029                         netif_carrier_on(mii->dev);
 
1031         else    /* Let MMI library update carrier status */
 
1032                 rhine_check_media(mii->dev, 0);
 
1034                 printk(KERN_INFO "%s: force_media %d, carrier %d\n",
 
1035                        mii->dev->name, mii->force_media,
 
1036                        netif_carrier_ok(mii->dev));
 
1039 static void init_registers(struct net_device *dev)
 
1041         struct rhine_private *rp = netdev_priv(dev);
 
1042         void __iomem *ioaddr = rp->base;
 
1045         for (i = 0; i < 6; i++)
 
1046                 iowrite8(dev->dev_addr[i], ioaddr + StationAddr + i);
 
1048         /* Initialize other registers. */
 
1049         iowrite16(0x0006, ioaddr + PCIBusConfig);       /* Tune configuration??? */
 
1050         /* Configure initial FIFO thresholds. */
 
1051         iowrite8(0x20, ioaddr + TxConfig);
 
1052         rp->tx_thresh = 0x20;
 
1053         rp->rx_thresh = 0x60;           /* Written in rhine_set_rx_mode(). */
 
1055         iowrite32(rp->rx_ring_dma, ioaddr + RxRingPtr);
 
1056         iowrite32(rp->tx_ring_dma, ioaddr + TxRingPtr);
 
1058         rhine_set_rx_mode(dev);
 
1060         netif_poll_enable(dev);
 
1062         /* Enable interrupts by setting the interrupt mask. */
 
1063         iowrite16(IntrRxDone | IntrRxErr | IntrRxEmpty| IntrRxOverflow |
 
1064                IntrRxDropped | IntrRxNoBuf | IntrTxAborted |
 
1065                IntrTxDone | IntrTxError | IntrTxUnderrun |
 
1066                IntrPCIErr | IntrStatsMax | IntrLinkChange,
 
1067                ioaddr + IntrEnable);
 
1069         iowrite16(CmdStart | CmdTxOn | CmdRxOn | (Cmd1NoTxPoll << 8),
 
1071         rhine_check_media(dev, 1);
 
1074 /* Enable MII link status auto-polling (required for IntrLinkChange) */
 
1075 static void rhine_enable_linkmon(void __iomem *ioaddr)
 
1077         iowrite8(0, ioaddr + MIICmd);
 
1078         iowrite8(MII_BMSR, ioaddr + MIIRegAddr);
 
1079         iowrite8(0x80, ioaddr + MIICmd);
 
1081         RHINE_WAIT_FOR((ioread8(ioaddr + MIIRegAddr) & 0x20));
 
1083         iowrite8(MII_BMSR | 0x40, ioaddr + MIIRegAddr);
 
1086 /* Disable MII link status auto-polling (required for MDIO access) */
 
1087 static void rhine_disable_linkmon(void __iomem *ioaddr, u32 quirks)
 
1089         iowrite8(0, ioaddr + MIICmd);
 
1091         if (quirks & rqRhineI) {
 
1092                 iowrite8(0x01, ioaddr + MIIRegAddr);    // MII_BMSR
 
1094                 /* Can be called from ISR. Evil. */
 
1097                 /* 0x80 must be set immediately before turning it off */
 
1098                 iowrite8(0x80, ioaddr + MIICmd);
 
1100                 RHINE_WAIT_FOR(ioread8(ioaddr + MIIRegAddr) & 0x20);
 
1102                 /* Heh. Now clear 0x80 again. */
 
1103                 iowrite8(0, ioaddr + MIICmd);
 
1106                 RHINE_WAIT_FOR(ioread8(ioaddr + MIIRegAddr) & 0x80);
 
1109 /* Read and write over the MII Management Data I/O (MDIO) interface. */
 
1111 static int mdio_read(struct net_device *dev, int phy_id, int regnum)
 
1113         struct rhine_private *rp = netdev_priv(dev);
 
1114         void __iomem *ioaddr = rp->base;
 
1117         rhine_disable_linkmon(ioaddr, rp->quirks);
 
1119         /* rhine_disable_linkmon already cleared MIICmd */
 
1120         iowrite8(phy_id, ioaddr + MIIPhyAddr);
 
1121         iowrite8(regnum, ioaddr + MIIRegAddr);
 
1122         iowrite8(0x40, ioaddr + MIICmd);                /* Trigger read */
 
1123         RHINE_WAIT_FOR(!(ioread8(ioaddr + MIICmd) & 0x40));
 
1124         result = ioread16(ioaddr + MIIData);
 
1126         rhine_enable_linkmon(ioaddr);
 
1130 static void mdio_write(struct net_device *dev, int phy_id, int regnum, int value)
 
1132         struct rhine_private *rp = netdev_priv(dev);
 
1133         void __iomem *ioaddr = rp->base;
 
1135         rhine_disable_linkmon(ioaddr, rp->quirks);
 
1137         /* rhine_disable_linkmon already cleared MIICmd */
 
1138         iowrite8(phy_id, ioaddr + MIIPhyAddr);
 
1139         iowrite8(regnum, ioaddr + MIIRegAddr);
 
1140         iowrite16(value, ioaddr + MIIData);
 
1141         iowrite8(0x20, ioaddr + MIICmd);                /* Trigger write */
 
1142         RHINE_WAIT_FOR(!(ioread8(ioaddr + MIICmd) & 0x20));
 
1144         rhine_enable_linkmon(ioaddr);
 
1147 static int rhine_open(struct net_device *dev)
 
1149         struct rhine_private *rp = netdev_priv(dev);
 
1150         void __iomem *ioaddr = rp->base;
 
1153         rc = request_irq(rp->pdev->irq, &rhine_interrupt, IRQF_SHARED, dev->name,
 
1159                 printk(KERN_DEBUG "%s: rhine_open() irq %d.\n",
 
1160                        dev->name, rp->pdev->irq);
 
1162         rc = alloc_ring(dev);
 
1164                 free_irq(rp->pdev->irq, dev);
 
1169         rhine_chip_reset(dev);
 
1170         init_registers(dev);
 
1172                 printk(KERN_DEBUG "%s: Done rhine_open(), status %4.4x "
 
1173                        "MII status: %4.4x.\n",
 
1174                        dev->name, ioread16(ioaddr + ChipCmd),
 
1175                        mdio_read(dev, rp->mii_if.phy_id, MII_BMSR));
 
1177         netif_start_queue(dev);
 
1182 static void rhine_tx_timeout(struct net_device *dev)
 
1184         struct rhine_private *rp = netdev_priv(dev);
 
1185         void __iomem *ioaddr = rp->base;
 
1187         printk(KERN_WARNING "%s: Transmit timed out, status %4.4x, PHY status "
 
1188                "%4.4x, resetting...\n",
 
1189                dev->name, ioread16(ioaddr + IntrStatus),
 
1190                mdio_read(dev, rp->mii_if.phy_id, MII_BMSR));
 
1192         /* protect against concurrent rx interrupts */
 
1193         disable_irq(rp->pdev->irq);
 
1195         spin_lock(&rp->lock);
 
1197         /* clear all descriptors */
 
1203         /* Reinitialize the hardware. */
 
1204         rhine_chip_reset(dev);
 
1205         init_registers(dev);
 
1207         spin_unlock(&rp->lock);
 
1208         enable_irq(rp->pdev->irq);
 
1210         dev->trans_start = jiffies;
 
1211         rp->stats.tx_errors++;
 
1212         netif_wake_queue(dev);
 
1215 static int rhine_start_tx(struct sk_buff *skb, struct net_device *dev)
 
1217         struct rhine_private *rp = netdev_priv(dev);
 
1218         void __iomem *ioaddr = rp->base;
 
1221         /* Caution: the write order is important here, set the field
 
1222            with the "ownership" bits last. */
 
1224         /* Calculate the next Tx descriptor entry. */
 
1225         entry = rp->cur_tx % TX_RING_SIZE;
 
1227         if (skb_padto(skb, ETH_ZLEN))
 
1230         rp->tx_skbuff[entry] = skb;
 
1232         if ((rp->quirks & rqRhineI) &&
 
1233             (((unsigned long)skb->data & 3) || skb_shinfo(skb)->nr_frags != 0 || skb->ip_summed == CHECKSUM_HW)) {
 
1234                 /* Must use alignment buffer. */
 
1235                 if (skb->len > PKT_BUF_SZ) {
 
1236                         /* packet too long, drop it */
 
1238                         rp->tx_skbuff[entry] = NULL;
 
1239                         rp->stats.tx_dropped++;
 
1243                 /* Padding is not copied and so must be redone. */
 
1244                 skb_copy_and_csum_dev(skb, rp->tx_buf[entry]);
 
1245                 if (skb->len < ETH_ZLEN)
 
1246                         memset(rp->tx_buf[entry] + skb->len, 0,
 
1247                                ETH_ZLEN - skb->len);
 
1248                 rp->tx_skbuff_dma[entry] = 0;
 
1249                 rp->tx_ring[entry].addr = cpu_to_le32(rp->tx_bufs_dma +
 
1250                                                       (rp->tx_buf[entry] -
 
1253                 rp->tx_skbuff_dma[entry] =
 
1254                         pci_map_single(rp->pdev, skb->data, skb->len,
 
1256                 rp->tx_ring[entry].addr = cpu_to_le32(rp->tx_skbuff_dma[entry]);
 
1259         rp->tx_ring[entry].desc_length =
 
1260                 cpu_to_le32(TXDESC | (skb->len >= ETH_ZLEN ? skb->len : ETH_ZLEN));
 
1263         spin_lock_irq(&rp->lock);
 
1265         rp->tx_ring[entry].tx_status = cpu_to_le32(DescOwn);
 
1270         /* Non-x86 Todo: explicitly flush cache lines here. */
 
1272         /* Wake the potentially-idle transmit channel */
 
1273         iowrite8(ioread8(ioaddr + ChipCmd1) | Cmd1TxDemand,
 
1277         if (rp->cur_tx == rp->dirty_tx + TX_QUEUE_LEN)
 
1278                 netif_stop_queue(dev);
 
1280         dev->trans_start = jiffies;
 
1282         spin_unlock_irq(&rp->lock);
 
1285                 printk(KERN_DEBUG "%s: Transmit frame #%d queued in slot %d.\n",
 
1286                        dev->name, rp->cur_tx-1, entry);
 
1291 /* The interrupt handler does all of the Rx thread work and cleans up
 
1292    after the Tx thread. */
 
1293 static irqreturn_t rhine_interrupt(int irq, void *dev_instance, struct pt_regs *rgs)
 
1295         struct net_device *dev = dev_instance;
 
1296         struct rhine_private *rp = netdev_priv(dev);
 
1297         void __iomem *ioaddr = rp->base;
 
1299         int boguscnt = max_interrupt_work;
 
1302         while ((intr_status = get_intr_status(dev))) {
 
1305                 /* Acknowledge all of the current interrupt sources ASAP. */
 
1306                 if (intr_status & IntrTxDescRace)
 
1307                         iowrite8(0x08, ioaddr + IntrStatus2);
 
1308                 iowrite16(intr_status & 0xffff, ioaddr + IntrStatus);
 
1312                         printk(KERN_DEBUG "%s: Interrupt, status %8.8x.\n",
 
1313                                dev->name, intr_status);
 
1315                 if (intr_status & (IntrRxDone | IntrRxErr | IntrRxDropped |
 
1316                                    IntrRxWakeUp | IntrRxEmpty | IntrRxNoBuf)) {
 
1317 #ifdef CONFIG_VIA_RHINE_NAPI
 
1318                         iowrite16(IntrTxAborted |
 
1319                                   IntrTxDone | IntrTxError | IntrTxUnderrun |
 
1320                                   IntrPCIErr | IntrStatsMax | IntrLinkChange,
 
1321                                   ioaddr + IntrEnable);
 
1323                         netif_rx_schedule(dev);
 
1325                         rhine_rx(dev, RX_RING_SIZE);
 
1329                 if (intr_status & (IntrTxErrSummary | IntrTxDone)) {
 
1330                         if (intr_status & IntrTxErrSummary) {
 
1331                                 /* Avoid scavenging before Tx engine turned off */
 
1332                                 RHINE_WAIT_FOR(!(ioread8(ioaddr+ChipCmd) & CmdTxOn));
 
1334                                     ioread8(ioaddr+ChipCmd) & CmdTxOn)
 
1335                                         printk(KERN_WARNING "%s: "
 
1336                                                "rhine_interrupt() Tx engine"
 
1337                                                "still on.\n", dev->name);
 
1342                 /* Abnormal error summary/uncommon events handlers. */
 
1343                 if (intr_status & (IntrPCIErr | IntrLinkChange |
 
1344                                    IntrStatsMax | IntrTxError | IntrTxAborted |
 
1345                                    IntrTxUnderrun | IntrTxDescRace))
 
1346                         rhine_error(dev, intr_status);
 
1348                 if (--boguscnt < 0) {
 
1349                         printk(KERN_WARNING "%s: Too much work at interrupt, "
 
1351                                dev->name, intr_status);
 
1357                 printk(KERN_DEBUG "%s: exiting interrupt, status=%8.8x.\n",
 
1358                        dev->name, ioread16(ioaddr + IntrStatus));
 
1359         return IRQ_RETVAL(handled);
 
1362 /* This routine is logically part of the interrupt handler, but isolated
 
1364 static void rhine_tx(struct net_device *dev)
 
1366         struct rhine_private *rp = netdev_priv(dev);
 
1367         int txstatus = 0, entry = rp->dirty_tx % TX_RING_SIZE;
 
1369         spin_lock(&rp->lock);
 
1371         /* find and cleanup dirty tx descriptors */
 
1372         while (rp->dirty_tx != rp->cur_tx) {
 
1373                 txstatus = le32_to_cpu(rp->tx_ring[entry].tx_status);
 
1375                         printk(KERN_DEBUG "Tx scavenge %d status %8.8x.\n",
 
1377                 if (txstatus & DescOwn)
 
1379                 if (txstatus & 0x8000) {
 
1381                                 printk(KERN_DEBUG "%s: Transmit error, "
 
1382                                        "Tx status %8.8x.\n",
 
1383                                        dev->name, txstatus);
 
1384                         rp->stats.tx_errors++;
 
1385                         if (txstatus & 0x0400) rp->stats.tx_carrier_errors++;
 
1386                         if (txstatus & 0x0200) rp->stats.tx_window_errors++;
 
1387                         if (txstatus & 0x0100) rp->stats.tx_aborted_errors++;
 
1388                         if (txstatus & 0x0080) rp->stats.tx_heartbeat_errors++;
 
1389                         if (((rp->quirks & rqRhineI) && txstatus & 0x0002) ||
 
1390                             (txstatus & 0x0800) || (txstatus & 0x1000)) {
 
1391                                 rp->stats.tx_fifo_errors++;
 
1392                                 rp->tx_ring[entry].tx_status = cpu_to_le32(DescOwn);
 
1393                                 break; /* Keep the skb - we try again */
 
1395                         /* Transmitter restarted in 'abnormal' handler. */
 
1397                         if (rp->quirks & rqRhineI)
 
1398                                 rp->stats.collisions += (txstatus >> 3) & 0x0F;
 
1400                                 rp->stats.collisions += txstatus & 0x0F;
 
1402                                 printk(KERN_DEBUG "collisions: %1.1x:%1.1x\n",
 
1403                                        (txstatus >> 3) & 0xF,
 
1405                         rp->stats.tx_bytes += rp->tx_skbuff[entry]->len;
 
1406                         rp->stats.tx_packets++;
 
1408                 /* Free the original skb. */
 
1409                 if (rp->tx_skbuff_dma[entry]) {
 
1410                         pci_unmap_single(rp->pdev,
 
1411                                          rp->tx_skbuff_dma[entry],
 
1412                                          rp->tx_skbuff[entry]->len,
 
1415                 dev_kfree_skb_irq(rp->tx_skbuff[entry]);
 
1416                 rp->tx_skbuff[entry] = NULL;
 
1417                 entry = (++rp->dirty_tx) % TX_RING_SIZE;
 
1419         if ((rp->cur_tx - rp->dirty_tx) < TX_QUEUE_LEN - 4)
 
1420                 netif_wake_queue(dev);
 
1422         spin_unlock(&rp->lock);
 
1425 /* Process up to limit frames from receive ring */
 
1426 static int rhine_rx(struct net_device *dev, int limit)
 
1428         struct rhine_private *rp = netdev_priv(dev);
 
1430         int entry = rp->cur_rx % RX_RING_SIZE;
 
1433                 printk(KERN_DEBUG "%s: rhine_rx(), entry %d status %8.8x.\n",
 
1435                        le32_to_cpu(rp->rx_head_desc->rx_status));
 
1438         /* If EOP is set on the next entry, it's a new packet. Send it up. */
 
1439         for (count = 0; count < limit; ++count) {
 
1440                 struct rx_desc *desc = rp->rx_head_desc;
 
1441                 u32 desc_status = le32_to_cpu(desc->rx_status);
 
1442                 int data_size = desc_status >> 16;
 
1444                 if (desc_status & DescOwn)
 
1448                         printk(KERN_DEBUG "rhine_rx() status is %8.8x.\n",
 
1451                 if ((desc_status & (RxWholePkt | RxErr)) != RxWholePkt) {
 
1452                         if ((desc_status & RxWholePkt) != RxWholePkt) {
 
1453                                 printk(KERN_WARNING "%s: Oversized Ethernet "
 
1454                                        "frame spanned multiple buffers, entry "
 
1455                                        "%#x length %d status %8.8x!\n",
 
1456                                        dev->name, entry, data_size,
 
1458                                 printk(KERN_WARNING "%s: Oversized Ethernet "
 
1459                                        "frame %p vs %p.\n", dev->name,
 
1460                                        rp->rx_head_desc, &rp->rx_ring[entry]);
 
1461                                 rp->stats.rx_length_errors++;
 
1462                         } else if (desc_status & RxErr) {
 
1463                                 /* There was a error. */
 
1465                                         printk(KERN_DEBUG "rhine_rx() Rx "
 
1466                                                "error was %8.8x.\n",
 
1468                                 rp->stats.rx_errors++;
 
1469                                 if (desc_status & 0x0030) rp->stats.rx_length_errors++;
 
1470                                 if (desc_status & 0x0048) rp->stats.rx_fifo_errors++;
 
1471                                 if (desc_status & 0x0004) rp->stats.rx_frame_errors++;
 
1472                                 if (desc_status & 0x0002) {
 
1473                                         /* this can also be updated outside the interrupt handler */
 
1474                                         spin_lock(&rp->lock);
 
1475                                         rp->stats.rx_crc_errors++;
 
1476                                         spin_unlock(&rp->lock);
 
1480                         struct sk_buff *skb;
 
1481                         /* Length should omit the CRC */
 
1482                         int pkt_len = data_size - 4;
 
1484                         /* Check if the packet is long enough to accept without
 
1485                            copying to a minimally-sized skbuff. */
 
1486                         if (pkt_len < rx_copybreak &&
 
1487                                 (skb = dev_alloc_skb(pkt_len + 2)) != NULL) {
 
1489                                 skb_reserve(skb, 2);    /* 16 byte align the IP header */
 
1490                                 pci_dma_sync_single_for_cpu(rp->pdev,
 
1491                                                             rp->rx_skbuff_dma[entry],
 
1493                                                             PCI_DMA_FROMDEVICE);
 
1495                                 eth_copy_and_sum(skb,
 
1496                                                  rp->rx_skbuff[entry]->data,
 
1498                                 skb_put(skb, pkt_len);
 
1499                                 pci_dma_sync_single_for_device(rp->pdev,
 
1500                                                                rp->rx_skbuff_dma[entry],
 
1502                                                                PCI_DMA_FROMDEVICE);
 
1504                                 skb = rp->rx_skbuff[entry];
 
1506                                         printk(KERN_ERR "%s: Inconsistent Rx "
 
1507                                                "descriptor chain.\n",
 
1511                                 rp->rx_skbuff[entry] = NULL;
 
1512                                 skb_put(skb, pkt_len);
 
1513                                 pci_unmap_single(rp->pdev,
 
1514                                                  rp->rx_skbuff_dma[entry],
 
1516                                                  PCI_DMA_FROMDEVICE);
 
1518                         skb->protocol = eth_type_trans(skb, dev);
 
1519 #ifdef CONFIG_VIA_RHINE_NAPI
 
1520                         netif_receive_skb(skb);
 
1524                         dev->last_rx = jiffies;
 
1525                         rp->stats.rx_bytes += pkt_len;
 
1526                         rp->stats.rx_packets++;
 
1528                 entry = (++rp->cur_rx) % RX_RING_SIZE;
 
1529                 rp->rx_head_desc = &rp->rx_ring[entry];
 
1532         /* Refill the Rx ring buffers. */
 
1533         for (; rp->cur_rx - rp->dirty_rx > 0; rp->dirty_rx++) {
 
1534                 struct sk_buff *skb;
 
1535                 entry = rp->dirty_rx % RX_RING_SIZE;
 
1536                 if (rp->rx_skbuff[entry] == NULL) {
 
1537                         skb = dev_alloc_skb(rp->rx_buf_sz);
 
1538                         rp->rx_skbuff[entry] = skb;
 
1540                                 break;  /* Better luck next round. */
 
1541                         skb->dev = dev; /* Mark as being used by this device. */
 
1542                         rp->rx_skbuff_dma[entry] =
 
1543                                 pci_map_single(rp->pdev, skb->data,
 
1545                                                PCI_DMA_FROMDEVICE);
 
1546                         rp->rx_ring[entry].addr = cpu_to_le32(rp->rx_skbuff_dma[entry]);
 
1548                 rp->rx_ring[entry].rx_status = cpu_to_le32(DescOwn);
 
1555  * Clears the "tally counters" for CRC errors and missed frames(?).
 
1556  * It has been reported that some chips need a write of 0 to clear
 
1557  * these, for others the counters are set to 1 when written to and
 
1558  * instead cleared when read. So we clear them both ways ...
 
1560 static inline void clear_tally_counters(void __iomem *ioaddr)
 
1562         iowrite32(0, ioaddr + RxMissed);
 
1563         ioread16(ioaddr + RxCRCErrs);
 
1564         ioread16(ioaddr + RxMissed);
 
1567 static void rhine_restart_tx(struct net_device *dev) {
 
1568         struct rhine_private *rp = netdev_priv(dev);
 
1569         void __iomem *ioaddr = rp->base;
 
1570         int entry = rp->dirty_tx % TX_RING_SIZE;
 
1574          * If new errors occured, we need to sort them out before doing Tx.
 
1575          * In that case the ISR will be back here RSN anyway.
 
1577         intr_status = get_intr_status(dev);
 
1579         if ((intr_status & IntrTxErrSummary) == 0) {
 
1581                 /* We know better than the chip where it should continue. */
 
1582                 iowrite32(rp->tx_ring_dma + entry * sizeof(struct tx_desc),
 
1583                        ioaddr + TxRingPtr);
 
1585                 iowrite8(ioread8(ioaddr + ChipCmd) | CmdTxOn,
 
1587                 iowrite8(ioread8(ioaddr + ChipCmd1) | Cmd1TxDemand,
 
1592                 /* This should never happen */
 
1594                         printk(KERN_WARNING "%s: rhine_restart_tx() "
 
1595                                "Another error occured %8.8x.\n",
 
1596                                dev->name, intr_status);
 
1601 static void rhine_error(struct net_device *dev, int intr_status)
 
1603         struct rhine_private *rp = netdev_priv(dev);
 
1604         void __iomem *ioaddr = rp->base;
 
1606         spin_lock(&rp->lock);
 
1608         if (intr_status & IntrLinkChange)
 
1609                 rhine_check_media(dev, 0);
 
1610         if (intr_status & IntrStatsMax) {
 
1611                 rp->stats.rx_crc_errors += ioread16(ioaddr + RxCRCErrs);
 
1612                 rp->stats.rx_missed_errors += ioread16(ioaddr + RxMissed);
 
1613                 clear_tally_counters(ioaddr);
 
1615         if (intr_status & IntrTxAborted) {
 
1617                         printk(KERN_INFO "%s: Abort %8.8x, frame dropped.\n",
 
1618                                dev->name, intr_status);
 
1620         if (intr_status & IntrTxUnderrun) {
 
1621                 if (rp->tx_thresh < 0xE0)
 
1622                         iowrite8(rp->tx_thresh += 0x20, ioaddr + TxConfig);
 
1624                         printk(KERN_INFO "%s: Transmitter underrun, Tx "
 
1625                                "threshold now %2.2x.\n",
 
1626                                dev->name, rp->tx_thresh);
 
1628         if (intr_status & IntrTxDescRace) {
 
1630                         printk(KERN_INFO "%s: Tx descriptor write-back race.\n",
 
1633         if ((intr_status & IntrTxError) &&
 
1634             (intr_status & (IntrTxAborted |
 
1635              IntrTxUnderrun | IntrTxDescRace)) == 0) {
 
1636                 if (rp->tx_thresh < 0xE0) {
 
1637                         iowrite8(rp->tx_thresh += 0x20, ioaddr + TxConfig);
 
1640                         printk(KERN_INFO "%s: Unspecified error. Tx "
 
1641                                "threshold now %2.2x.\n",
 
1642                                dev->name, rp->tx_thresh);
 
1644         if (intr_status & (IntrTxAborted | IntrTxUnderrun | IntrTxDescRace |
 
1646                 rhine_restart_tx(dev);
 
1648         if (intr_status & ~(IntrLinkChange | IntrStatsMax | IntrTxUnderrun |
 
1649                             IntrTxError | IntrTxAborted | IntrNormalSummary |
 
1652                         printk(KERN_ERR "%s: Something Wicked happened! "
 
1653                                "%8.8x.\n", dev->name, intr_status);
 
1656         spin_unlock(&rp->lock);
 
1659 static struct net_device_stats *rhine_get_stats(struct net_device *dev)
 
1661         struct rhine_private *rp = netdev_priv(dev);
 
1662         void __iomem *ioaddr = rp->base;
 
1663         unsigned long flags;
 
1665         spin_lock_irqsave(&rp->lock, flags);
 
1666         rp->stats.rx_crc_errors += ioread16(ioaddr + RxCRCErrs);
 
1667         rp->stats.rx_missed_errors += ioread16(ioaddr + RxMissed);
 
1668         clear_tally_counters(ioaddr);
 
1669         spin_unlock_irqrestore(&rp->lock, flags);
 
1674 static void rhine_set_rx_mode(struct net_device *dev)
 
1676         struct rhine_private *rp = netdev_priv(dev);
 
1677         void __iomem *ioaddr = rp->base;
 
1678         u32 mc_filter[2];       /* Multicast hash filter */
 
1679         u8 rx_mode;             /* Note: 0x02=accept runt, 0x01=accept errs */
 
1681         if (dev->flags & IFF_PROMISC) {         /* Set promiscuous. */
 
1682                 /* Unconditionally log net taps. */
 
1683                 printk(KERN_NOTICE "%s: Promiscuous mode enabled.\n",
 
1686                 iowrite32(0xffffffff, ioaddr + MulticastFilter0);
 
1687                 iowrite32(0xffffffff, ioaddr + MulticastFilter1);
 
1688         } else if ((dev->mc_count > multicast_filter_limit)
 
1689                    || (dev->flags & IFF_ALLMULTI)) {
 
1690                 /* Too many to match, or accept all multicasts. */
 
1691                 iowrite32(0xffffffff, ioaddr + MulticastFilter0);
 
1692                 iowrite32(0xffffffff, ioaddr + MulticastFilter1);
 
1695                 struct dev_mc_list *mclist;
 
1697                 memset(mc_filter, 0, sizeof(mc_filter));
 
1698                 for (i = 0, mclist = dev->mc_list; mclist && i < dev->mc_count;
 
1699                      i++, mclist = mclist->next) {
 
1700                         int bit_nr = ether_crc(ETH_ALEN, mclist->dmi_addr) >> 26;
 
1702                         mc_filter[bit_nr >> 5] |= 1 << (bit_nr & 31);
 
1704                 iowrite32(mc_filter[0], ioaddr + MulticastFilter0);
 
1705                 iowrite32(mc_filter[1], ioaddr + MulticastFilter1);
 
1708         iowrite8(rp->rx_thresh | rx_mode, ioaddr + RxConfig);
 
1711 static void netdev_get_drvinfo(struct net_device *dev, struct ethtool_drvinfo *info)
 
1713         struct rhine_private *rp = netdev_priv(dev);
 
1715         strcpy(info->driver, DRV_NAME);
 
1716         strcpy(info->version, DRV_VERSION);
 
1717         strcpy(info->bus_info, pci_name(rp->pdev));
 
1720 static int netdev_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
 
1722         struct rhine_private *rp = netdev_priv(dev);
 
1725         spin_lock_irq(&rp->lock);
 
1726         rc = mii_ethtool_gset(&rp->mii_if, cmd);
 
1727         spin_unlock_irq(&rp->lock);
 
1732 static int netdev_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
 
1734         struct rhine_private *rp = netdev_priv(dev);
 
1737         spin_lock_irq(&rp->lock);
 
1738         rc = mii_ethtool_sset(&rp->mii_if, cmd);
 
1739         spin_unlock_irq(&rp->lock);
 
1740         rhine_set_carrier(&rp->mii_if);
 
1745 static int netdev_nway_reset(struct net_device *dev)
 
1747         struct rhine_private *rp = netdev_priv(dev);
 
1749         return mii_nway_restart(&rp->mii_if);
 
1752 static u32 netdev_get_link(struct net_device *dev)
 
1754         struct rhine_private *rp = netdev_priv(dev);
 
1756         return mii_link_ok(&rp->mii_if);
 
1759 static u32 netdev_get_msglevel(struct net_device *dev)
 
1764 static void netdev_set_msglevel(struct net_device *dev, u32 value)
 
1769 static void rhine_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol)
 
1771         struct rhine_private *rp = netdev_priv(dev);
 
1773         if (!(rp->quirks & rqWOL))
 
1776         spin_lock_irq(&rp->lock);
 
1777         wol->supported = WAKE_PHY | WAKE_MAGIC |
 
1778                          WAKE_UCAST | WAKE_MCAST | WAKE_BCAST;  /* Untested */
 
1779         wol->wolopts = rp->wolopts;
 
1780         spin_unlock_irq(&rp->lock);
 
1783 static int rhine_set_wol(struct net_device *dev, struct ethtool_wolinfo *wol)
 
1785         struct rhine_private *rp = netdev_priv(dev);
 
1786         u32 support = WAKE_PHY | WAKE_MAGIC |
 
1787                       WAKE_UCAST | WAKE_MCAST | WAKE_BCAST;     /* Untested */
 
1789         if (!(rp->quirks & rqWOL))
 
1792         if (wol->wolopts & ~support)
 
1795         spin_lock_irq(&rp->lock);
 
1796         rp->wolopts = wol->wolopts;
 
1797         spin_unlock_irq(&rp->lock);
 
1802 static struct ethtool_ops netdev_ethtool_ops = {
 
1803         .get_drvinfo            = netdev_get_drvinfo,
 
1804         .get_settings           = netdev_get_settings,
 
1805         .set_settings           = netdev_set_settings,
 
1806         .nway_reset             = netdev_nway_reset,
 
1807         .get_link               = netdev_get_link,
 
1808         .get_msglevel           = netdev_get_msglevel,
 
1809         .set_msglevel           = netdev_set_msglevel,
 
1810         .get_wol                = rhine_get_wol,
 
1811         .set_wol                = rhine_set_wol,
 
1812         .get_sg                 = ethtool_op_get_sg,
 
1813         .get_tx_csum            = ethtool_op_get_tx_csum,
 
1814         .get_perm_addr          = ethtool_op_get_perm_addr,
 
1817 static int netdev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
 
1819         struct rhine_private *rp = netdev_priv(dev);
 
1822         if (!netif_running(dev))
 
1825         spin_lock_irq(&rp->lock);
 
1826         rc = generic_mii_ioctl(&rp->mii_if, if_mii(rq), cmd, NULL);
 
1827         spin_unlock_irq(&rp->lock);
 
1828         rhine_set_carrier(&rp->mii_if);
 
1833 static int rhine_close(struct net_device *dev)
 
1835         struct rhine_private *rp = netdev_priv(dev);
 
1836         void __iomem *ioaddr = rp->base;
 
1838         spin_lock_irq(&rp->lock);
 
1840         netif_stop_queue(dev);
 
1841         netif_poll_disable(dev);
 
1844                 printk(KERN_DEBUG "%s: Shutting down ethercard, "
 
1845                        "status was %4.4x.\n",
 
1846                        dev->name, ioread16(ioaddr + ChipCmd));
 
1848         /* Switch to loopback mode to avoid hardware races. */
 
1849         iowrite8(rp->tx_thresh | 0x02, ioaddr + TxConfig);
 
1851         /* Disable interrupts by clearing the interrupt mask. */
 
1852         iowrite16(0x0000, ioaddr + IntrEnable);
 
1854         /* Stop the chip's Tx and Rx processes. */
 
1855         iowrite16(CmdStop, ioaddr + ChipCmd);
 
1857         spin_unlock_irq(&rp->lock);
 
1859         free_irq(rp->pdev->irq, dev);
 
1868 static void __devexit rhine_remove_one(struct pci_dev *pdev)
 
1870         struct net_device *dev = pci_get_drvdata(pdev);
 
1871         struct rhine_private *rp = netdev_priv(dev);
 
1873         unregister_netdev(dev);
 
1875         pci_iounmap(pdev, rp->base);
 
1876         pci_release_regions(pdev);
 
1879         pci_disable_device(pdev);
 
1880         pci_set_drvdata(pdev, NULL);
 
1883 static void rhine_shutdown (struct pci_dev *pdev)
 
1885         struct net_device *dev = pci_get_drvdata(pdev);
 
1886         struct rhine_private *rp = netdev_priv(dev);
 
1887         void __iomem *ioaddr = rp->base;
 
1889         if (!(rp->quirks & rqWOL))
 
1890                 return; /* Nothing to do for non-WOL adapters */
 
1892         rhine_power_init(dev);
 
1894         /* Make sure we use pattern 0, 1 and not 4, 5 */
 
1895         if (rp->quirks & rq6patterns)
 
1896                 iowrite8(0x04, ioaddr + 0xA7);
 
1898         if (rp->wolopts & WAKE_MAGIC) {
 
1899                 iowrite8(WOLmagic, ioaddr + WOLcrSet);
 
1901                  * Turn EEPROM-controlled wake-up back on -- some hardware may
 
1902                  * not cooperate otherwise.
 
1904                 iowrite8(ioread8(ioaddr + ConfigA) | 0x03, ioaddr + ConfigA);
 
1907         if (rp->wolopts & (WAKE_BCAST|WAKE_MCAST))
 
1908                 iowrite8(WOLbmcast, ioaddr + WOLcgSet);
 
1910         if (rp->wolopts & WAKE_PHY)
 
1911                 iowrite8(WOLlnkon | WOLlnkoff, ioaddr + WOLcrSet);
 
1913         if (rp->wolopts & WAKE_UCAST)
 
1914                 iowrite8(WOLucast, ioaddr + WOLcrSet);
 
1917                 /* Enable legacy WOL (for old motherboards) */
 
1918                 iowrite8(0x01, ioaddr + PwcfgSet);
 
1919                 iowrite8(ioread8(ioaddr + StickyHW) | 0x04, ioaddr + StickyHW);
 
1922         /* Hit power state D3 (sleep) */
 
1924                 iowrite8(ioread8(ioaddr + StickyHW) | 0x03, ioaddr + StickyHW);
 
1926         /* TODO: Check use of pci_enable_wake() */
 
1931 static int rhine_suspend(struct pci_dev *pdev, pm_message_t state)
 
1933         struct net_device *dev = pci_get_drvdata(pdev);
 
1934         struct rhine_private *rp = netdev_priv(dev);
 
1935         unsigned long flags;
 
1937         if (!netif_running(dev))
 
1940         netif_device_detach(dev);
 
1941         pci_save_state(pdev);
 
1943         spin_lock_irqsave(&rp->lock, flags);
 
1944         rhine_shutdown(pdev);
 
1945         spin_unlock_irqrestore(&rp->lock, flags);
 
1947         free_irq(dev->irq, dev);
 
1951 static int rhine_resume(struct pci_dev *pdev)
 
1953         struct net_device *dev = pci_get_drvdata(pdev);
 
1954         struct rhine_private *rp = netdev_priv(dev);
 
1955         unsigned long flags;
 
1958         if (!netif_running(dev))
 
1961         if (request_irq(dev->irq, rhine_interrupt, IRQF_SHARED, dev->name, dev))
 
1962                 printk(KERN_ERR "via-rhine %s: request_irq failed\n", dev->name);
 
1964         ret = pci_set_power_state(pdev, PCI_D0);
 
1966                 printk(KERN_INFO "%s: Entering power state D0 %s (%d).\n",
 
1967                         dev->name, ret ? "failed" : "succeeded", ret);
 
1969         pci_restore_state(pdev);
 
1971         spin_lock_irqsave(&rp->lock, flags);
 
1973         enable_mmio(rp->pioaddr, rp->quirks);
 
1975         rhine_power_init(dev);
 
1980         init_registers(dev);
 
1981         spin_unlock_irqrestore(&rp->lock, flags);
 
1983         netif_device_attach(dev);
 
1987 #endif /* CONFIG_PM */
 
1989 static struct pci_driver rhine_driver = {
 
1991         .id_table       = rhine_pci_tbl,
 
1992         .probe          = rhine_init_one,
 
1993         .remove         = __devexit_p(rhine_remove_one),
 
1995         .suspend        = rhine_suspend,
 
1996         .resume         = rhine_resume,
 
1997 #endif /* CONFIG_PM */
 
1998         .shutdown =     rhine_shutdown,
 
2002 static int __init rhine_init(void)
 
2004 /* when a module, this is printed whether or not devices are found in probe */
 
2008         return pci_module_init(&rhine_driver);
 
2012 static void __exit rhine_cleanup(void)
 
2014         pci_unregister_driver(&rhine_driver);
 
2018 module_init(rhine_init);
 
2019 module_exit(rhine_cleanup);