1 /* sis900.c: A SiS 900/7016 PCI Fast Ethernet driver for Linux.
 
   2    Copyright 1999 Silicon Integrated System Corporation 
 
   3    Revision:    1.08.09 Sep. 19 2005
 
   5    Modified from the driver which is originally written by Donald Becker.
 
   7    This software may be used and distributed according to the terms
 
   8    of the GNU General Public License (GPL), incorporated herein by reference.
 
   9    Drivers based on this skeleton fall under the GPL and must retain
 
  10    the authorship (implicit copyright) notice.
 
  13    SiS 7016 Fast Ethernet PCI Bus 10/100 Mbps LAN Controller with OnNow Support,
 
  14    preliminary Rev. 1.0 Jan. 14, 1998
 
  15    SiS 900 Fast Ethernet PCI Bus 10/100 Mbps LAN Single Chip with OnNow Support,
 
  16    preliminary Rev. 1.0 Nov. 10, 1998
 
  17    SiS 7014 Single Chip 100BASE-TX/10BASE-T Physical Layer Solution,
 
  18    preliminary Rev. 1.0 Jan. 18, 1998
 
  20    Rev 1.08.09 Sep. 19 2005 Daniele Venzano add Wake on LAN support
 
  21    Rev 1.08.08 Jan. 22 2005 Daniele Venzano use netif_msg for debugging messages
 
  22    Rev 1.08.07 Nov.  2 2003 Daniele Venzano <webvenza@libero.it> add suspend/resume support
 
  23    Rev 1.08.06 Sep. 24 2002 Mufasa Yang bug fix for Tx timeout & add SiS963 support
 
  24    Rev 1.08.05 Jun.  6 2002 Mufasa Yang bug fix for read_eeprom & Tx descriptor over-boundary
 
  25    Rev 1.08.04 Apr. 25 2002 Mufasa Yang <mufasa@sis.com.tw> added SiS962 support
 
  26    Rev 1.08.03 Feb.  1 2002 Matt Domsch <Matt_Domsch@dell.com> update to use library crc32 function
 
  27    Rev 1.08.02 Nov. 30 2001 Hui-Fen Hsu workaround for EDB & bug fix for dhcp problem
 
  28    Rev 1.08.01 Aug. 25 2001 Hui-Fen Hsu update for 630ET & workaround for ICS1893 PHY
 
  29    Rev 1.08.00 Jun. 11 2001 Hui-Fen Hsu workaround for RTL8201 PHY and some bug fix
 
  30    Rev 1.07.11 Apr.  2 2001 Hui-Fen Hsu updates PCI drivers to use the new pci_set_dma_mask for kernel 2.4.3
 
  31    Rev 1.07.10 Mar.  1 2001 Hui-Fen Hsu <hfhsu@sis.com.tw> some bug fix & 635M/B support 
 
  32    Rev 1.07.09 Feb.  9 2001 Dave Jones <davej@suse.de> PCI enable cleanup
 
  33    Rev 1.07.08 Jan.  8 2001 Lei-Chun Chang added RTL8201 PHY support
 
  34    Rev 1.07.07 Nov. 29 2000 Lei-Chun Chang added kernel-doc extractable documentation and 630 workaround fix
 
  35    Rev 1.07.06 Nov.  7 2000 Jeff Garzik <jgarzik@pobox.com> some bug fix and cleaning
 
  36    Rev 1.07.05 Nov.  6 2000 metapirat<metapirat@gmx.de> contribute media type select by ifconfig
 
  37    Rev 1.07.04 Sep.  6 2000 Lei-Chun Chang added ICS1893 PHY support
 
  38    Rev 1.07.03 Aug. 24 2000 Lei-Chun Chang (lcchang@sis.com.tw) modified 630E eqaulizer workaround rule
 
  39    Rev 1.07.01 Aug. 08 2000 Ollie Lho minor update for SiS 630E and SiS 630E A1
 
  40    Rev 1.07    Mar. 07 2000 Ollie Lho bug fix in Rx buffer ring
 
  41    Rev 1.06.04 Feb. 11 2000 Jeff Garzik <jgarzik@pobox.com> softnet and init for kernel 2.4
 
  42    Rev 1.06.03 Dec. 23 1999 Ollie Lho Third release
 
  43    Rev 1.06.02 Nov. 23 1999 Ollie Lho bug in mac probing fixed
 
  44    Rev 1.06.01 Nov. 16 1999 Ollie Lho CRC calculation provide by Joseph Zbiciak (im14u2c@primenet.com)
 
  45    Rev 1.06 Nov. 4 1999 Ollie Lho (ollie@sis.com.tw) Second release
 
  46    Rev 1.05.05 Oct. 29 1999 Ollie Lho (ollie@sis.com.tw) Single buffer Tx/Rx
 
  47    Chin-Shan Li (lcs@sis.com.tw) Added AMD Am79c901 HomePNA PHY support
 
  48    Rev 1.05 Aug. 7 1999 Jim Huang (cmhuang@sis.com.tw) Initial release
 
  51 #include <linux/module.h>
 
  52 #include <linux/moduleparam.h>
 
  53 #include <linux/kernel.h>
 
  54 #include <linux/string.h>
 
  55 #include <linux/timer.h>
 
  56 #include <linux/errno.h>
 
  57 #include <linux/ioport.h>
 
  58 #include <linux/slab.h>
 
  59 #include <linux/interrupt.h>
 
  60 #include <linux/pci.h>
 
  61 #include <linux/netdevice.h>
 
  62 #include <linux/init.h>
 
  63 #include <linux/mii.h>
 
  64 #include <linux/etherdevice.h>
 
  65 #include <linux/skbuff.h>
 
  66 #include <linux/delay.h>
 
  67 #include <linux/ethtool.h>
 
  68 #include <linux/crc32.h>
 
  69 #include <linux/bitops.h>
 
  70 #include <linux/dma-mapping.h>
 
  72 #include <asm/processor.h>      /* Processor type for cache alignment. */
 
  75 #include <asm/uaccess.h>        /* User space memory access functions */
 
  79 #define SIS900_MODULE_NAME "sis900"
 
  80 #define SIS900_DRV_VERSION "v1.08.09 Sep. 19 2005"
 
  82 static char version[] __devinitdata =
 
  83 KERN_INFO "sis900.c: " SIS900_DRV_VERSION "\n";
 
  85 static int max_interrupt_work = 40;
 
  86 static int multicast_filter_limit = 128;
 
  88 static int sis900_debug = -1; /* Use SIS900_DEF_MSG as value */
 
  90 #define SIS900_DEF_MSG \
 
  96 /* Time in jiffies before concluding the transmitter is hung. */
 
  97 #define TX_TIMEOUT  (4*HZ)
 
 103 static const char * card_names[] = {
 
 104         "SiS 900 PCI Fast Ethernet",
 
 105         "SiS 7016 PCI Fast Ethernet"
 
 107 static struct pci_device_id sis900_pci_tbl [] = {
 
 108         {PCI_VENDOR_ID_SI, PCI_DEVICE_ID_SI_900,
 
 109          PCI_ANY_ID, PCI_ANY_ID, 0, 0, SIS_900},
 
 110         {PCI_VENDOR_ID_SI, PCI_DEVICE_ID_SI_7016,
 
 111          PCI_ANY_ID, PCI_ANY_ID, 0, 0, SIS_7016},
 
 114 MODULE_DEVICE_TABLE (pci, sis900_pci_tbl);
 
 116 static void sis900_read_mode(struct net_device *net_dev, int *speed, int *duplex);
 
 118 static const struct mii_chip_info {
 
 127 } mii_chip_table[] = {
 
 128         { "SiS 900 Internal MII PHY",           0x001d, 0x8000, LAN },
 
 129         { "SiS 7014 Physical Layer Solution",   0x0016, 0xf830, LAN },
 
 130         { "Altimata AC101LF PHY",               0x0022, 0x5520, LAN },
 
 131         { "ADM 7001 LAN PHY",                   0x002e, 0xcc60, LAN },
 
 132         { "AMD 79C901 10BASE-T PHY",            0x0000, 0x6B70, LAN },
 
 133         { "AMD 79C901 HomePNA PHY",             0x0000, 0x6B90, HOME},
 
 134         { "ICS LAN PHY",                        0x0015, 0xF440, LAN },
 
 135         { "NS 83851 PHY",                       0x2000, 0x5C20, MIX },
 
 136         { "NS 83847 PHY",                       0x2000, 0x5C30, MIX },
 
 137         { "Realtek RTL8201 PHY",                0x0000, 0x8200, LAN },
 
 138         { "VIA 6103 PHY",                       0x0101, 0x8f20, LAN },
 
 143         struct mii_phy * next;
 
 151 typedef struct _BufferDesc {
 
 157 struct sis900_private {
 
 158         struct net_device_stats stats;
 
 159         struct pci_dev * pci_dev;
 
 163         struct mii_phy * mii;
 
 164         struct mii_phy * first_mii; /* record the first mii structure */
 
 165         unsigned int cur_phy;
 
 166         struct mii_if_info mii_info;
 
 168         struct timer_list timer; /* Link status detection timer. */
 
 169         u8 autong_complete; /* 1: auto-negotiate complete  */
 
 173         unsigned int cur_rx, dirty_rx; /* producer/comsumer pointers for Tx/Rx ring */
 
 174         unsigned int cur_tx, dirty_tx;
 
 176         /* The saved address of a sent/receive-in-place packet buffer */
 
 177         struct sk_buff *tx_skbuff[NUM_TX_DESC];
 
 178         struct sk_buff *rx_skbuff[NUM_RX_DESC];
 
 182         dma_addr_t tx_ring_dma;
 
 183         dma_addr_t rx_ring_dma;
 
 185         unsigned int tx_full; /* The Tx queue is full. */
 
 190 MODULE_AUTHOR("Jim Huang <cmhuang@sis.com.tw>, Ollie Lho <ollie@sis.com.tw>");
 
 191 MODULE_DESCRIPTION("SiS 900 PCI Fast Ethernet driver");
 
 192 MODULE_LICENSE("GPL");
 
 194 module_param(multicast_filter_limit, int, 0444);
 
 195 module_param(max_interrupt_work, int, 0444);
 
 196 module_param(sis900_debug, int, 0444);
 
 197 MODULE_PARM_DESC(multicast_filter_limit, "SiS 900/7016 maximum number of filtered multicast addresses");
 
 198 MODULE_PARM_DESC(max_interrupt_work, "SiS 900/7016 maximum events handled per interrupt");
 
 199 MODULE_PARM_DESC(sis900_debug, "SiS 900/7016 bitmapped debugging message level");
 
 201 #ifdef CONFIG_NET_POLL_CONTROLLER
 
 202 static void sis900_poll(struct net_device *dev);
 
 204 static int sis900_open(struct net_device *net_dev);
 
 205 static int sis900_mii_probe (struct net_device * net_dev);
 
 206 static void sis900_init_rxfilter (struct net_device * net_dev);
 
 207 static u16 read_eeprom(long ioaddr, int location);
 
 208 static int mdio_read(struct net_device *net_dev, int phy_id, int location);
 
 209 static void mdio_write(struct net_device *net_dev, int phy_id, int location, int val);
 
 210 static void sis900_timer(unsigned long data);
 
 211 static void sis900_check_mode (struct net_device *net_dev, struct mii_phy *mii_phy);
 
 212 static void sis900_tx_timeout(struct net_device *net_dev);
 
 213 static void sis900_init_tx_ring(struct net_device *net_dev);
 
 214 static void sis900_init_rx_ring(struct net_device *net_dev);
 
 215 static int sis900_start_xmit(struct sk_buff *skb, struct net_device *net_dev);
 
 216 static int sis900_rx(struct net_device *net_dev);
 
 217 static void sis900_finish_xmit (struct net_device *net_dev);
 
 218 static irqreturn_t sis900_interrupt(int irq, void *dev_instance, struct pt_regs *regs);
 
 219 static int sis900_close(struct net_device *net_dev);
 
 220 static int mii_ioctl(struct net_device *net_dev, struct ifreq *rq, int cmd);
 
 221 static struct net_device_stats *sis900_get_stats(struct net_device *net_dev);
 
 222 static u16 sis900_mcast_bitnr(u8 *addr, u8 revision);
 
 223 static void set_rx_mode(struct net_device *net_dev);
 
 224 static void sis900_reset(struct net_device *net_dev);
 
 225 static void sis630_set_eq(struct net_device *net_dev, u8 revision);
 
 226 static int sis900_set_config(struct net_device *dev, struct ifmap *map);
 
 227 static u16 sis900_default_phy(struct net_device * net_dev);
 
 228 static void sis900_set_capability( struct net_device *net_dev ,struct mii_phy *phy);
 
 229 static u16 sis900_reset_phy(struct net_device *net_dev, int phy_addr);
 
 230 static void sis900_auto_negotiate(struct net_device *net_dev, int phy_addr);
 
 231 static void sis900_set_mode (long ioaddr, int speed, int duplex);
 
 232 static struct ethtool_ops sis900_ethtool_ops;
 
 235  *      sis900_get_mac_addr - Get MAC address for stand alone SiS900 model
 
 236  *      @pci_dev: the sis900 pci device
 
 237  *      @net_dev: the net device to get address for 
 
 239  *      Older SiS900 and friends, use EEPROM to store MAC address.
 
 240  *      MAC address is read from read_eeprom() into @net_dev->dev_addr.
 
 243 static int __devinit sis900_get_mac_addr(struct pci_dev * pci_dev, struct net_device *net_dev)
 
 245         long ioaddr = pci_resource_start(pci_dev, 0);
 
 249         /* check to see if we have sane EEPROM */
 
 250         signature = (u16) read_eeprom(ioaddr, EEPROMSignature);    
 
 251         if (signature == 0xffff || signature == 0x0000) {
 
 252                 printk (KERN_WARNING "%s: Error EERPOM read %x\n", 
 
 253                         pci_name(pci_dev), signature);
 
 257         /* get MAC address from EEPROM */
 
 258         for (i = 0; i < 3; i++)
 
 259                 ((u16 *)(net_dev->dev_addr))[i] = read_eeprom(ioaddr, i+EEPROMMACAddr);
 
 265  *      sis630e_get_mac_addr - Get MAC address for SiS630E model
 
 266  *      @pci_dev: the sis900 pci device
 
 267  *      @net_dev: the net device to get address for 
 
 269  *      SiS630E model, use APC CMOS RAM to store MAC address.
 
 270  *      APC CMOS RAM is accessed through ISA bridge.
 
 271  *      MAC address is read into @net_dev->dev_addr.
 
 274 static int __devinit sis630e_get_mac_addr(struct pci_dev * pci_dev,
 
 275                                         struct net_device *net_dev)
 
 277         struct pci_dev *isa_bridge = NULL;
 
 281         isa_bridge = pci_get_device(PCI_VENDOR_ID_SI, 0x0008, isa_bridge);
 
 283                 isa_bridge = pci_get_device(PCI_VENDOR_ID_SI, 0x0018, isa_bridge);
 
 285                 printk(KERN_WARNING "%s: Can not find ISA bridge\n",
 
 289         pci_read_config_byte(isa_bridge, 0x48, ®);
 
 290         pci_write_config_byte(isa_bridge, 0x48, reg | 0x40);
 
 292         for (i = 0; i < 6; i++) {
 
 293                 outb(0x09 + i, 0x70);
 
 294                 ((u8 *)(net_dev->dev_addr))[i] = inb(0x71); 
 
 296         pci_write_config_byte(isa_bridge, 0x48, reg & ~0x40);
 
 297         pci_dev_put(isa_bridge);
 
 304  *      sis635_get_mac_addr - Get MAC address for SIS635 model
 
 305  *      @pci_dev: the sis900 pci device
 
 306  *      @net_dev: the net device to get address for 
 
 308  *      SiS635 model, set MAC Reload Bit to load Mac address from APC
 
 309  *      to rfdr. rfdr is accessed through rfcr. MAC address is read into 
 
 310  *      @net_dev->dev_addr.
 
 313 static int __devinit sis635_get_mac_addr(struct pci_dev * pci_dev,
 
 314                                         struct net_device *net_dev)
 
 316         long ioaddr = net_dev->base_addr;
 
 320         rfcrSave = inl(rfcr + ioaddr);
 
 322         outl(rfcrSave | RELOAD, ioaddr + cr);
 
 323         outl(0, ioaddr + cr);
 
 325         /* disable packet filtering before setting filter */
 
 326         outl(rfcrSave & ~RFEN, rfcr + ioaddr);
 
 328         /* load MAC addr to filter data register */
 
 329         for (i = 0 ; i < 3 ; i++) {
 
 330                 outl((i << RFADDR_shift), ioaddr + rfcr);
 
 331                 *( ((u16 *)net_dev->dev_addr) + i) = inw(ioaddr + rfdr);
 
 334         /* enable packet filtering */
 
 335         outl(rfcrSave | RFEN, rfcr + ioaddr);
 
 341  *      sis96x_get_mac_addr - Get MAC address for SiS962 or SiS963 model
 
 342  *      @pci_dev: the sis900 pci device
 
 343  *      @net_dev: the net device to get address for 
 
 345  *      SiS962 or SiS963 model, use EEPROM to store MAC address. And EEPROM 
 
 347  *      LAN and 1394. When access EEPROM, send EEREQ signal to hardware first 
 
 348  *      and wait for EEGNT. If EEGNT is ON, EEPROM is permitted to be access 
 
 349  *      by LAN, otherwise is not. After MAC address is read from EEPROM, send
 
 350  *      EEDONE signal to refuse EEPROM access by LAN. 
 
 351  *      The EEPROM map of SiS962 or SiS963 is different to SiS900. 
 
 352  *      The signature field in SiS962 or SiS963 spec is meaningless. 
 
 353  *      MAC address is read into @net_dev->dev_addr.
 
 356 static int __devinit sis96x_get_mac_addr(struct pci_dev * pci_dev,
 
 357                                         struct net_device *net_dev)
 
 359         long ioaddr = net_dev->base_addr;
 
 360         long ee_addr = ioaddr + mear;
 
 364         outl(EEREQ, ee_addr);
 
 365         while(waittime < 2000) {
 
 366                 if(inl(ee_addr) & EEGNT) {
 
 368                         /* get MAC address from EEPROM */
 
 369                         for (i = 0; i < 3; i++)
 
 370                                 ((u16 *)(net_dev->dev_addr))[i] = read_eeprom(ioaddr, i+EEPROMMACAddr);
 
 372                         outl(EEDONE, ee_addr);
 
 379         outl(EEDONE, ee_addr);
 
 384  *      sis900_probe - Probe for sis900 device
 
 385  *      @pci_dev: the sis900 pci device
 
 386  *      @pci_id: the pci device ID
 
 388  *      Check and probe sis900 net device for @pci_dev.
 
 389  *      Get mac address according to the chip revision, 
 
 390  *      and assign SiS900-specific entries in the device structure.
 
 391  *      ie: sis900_open(), sis900_start_xmit(), sis900_close(), etc.
 
 394 static int __devinit sis900_probe(struct pci_dev *pci_dev,
 
 395                                 const struct pci_device_id *pci_id)
 
 397         struct sis900_private *sis_priv;
 
 398         struct net_device *net_dev;
 
 404         const char *card_name = card_names[pci_id->driver_data];
 
 405         const char *dev_name = pci_name(pci_dev);
 
 407 /* when built into the kernel, we only print version if device is found */
 
 409         static int printed_version;
 
 410         if (!printed_version++)
 
 414         /* setup various bits in PCI command register */
 
 415         ret = pci_enable_device(pci_dev);
 
 418         i = pci_set_dma_mask(pci_dev, DMA_32BIT_MASK);
 
 420                 printk(KERN_ERR "sis900.c: architecture does not support"
 
 421                         "32bit PCI busmaster DMA\n");
 
 425         pci_set_master(pci_dev);
 
 427         net_dev = alloc_etherdev(sizeof(struct sis900_private));
 
 430         SET_MODULE_OWNER(net_dev);
 
 431         SET_NETDEV_DEV(net_dev, &pci_dev->dev);
 
 433         /* We do a request_region() to register /proc/ioports info. */
 
 434         ioaddr = pci_resource_start(pci_dev, 0);        
 
 435         ret = pci_request_regions(pci_dev, "sis900");
 
 439         sis_priv = net_dev->priv;
 
 440         net_dev->base_addr = ioaddr;
 
 441         net_dev->irq = pci_dev->irq;
 
 442         sis_priv->pci_dev = pci_dev;
 
 443         spin_lock_init(&sis_priv->lock);
 
 445         pci_set_drvdata(pci_dev, net_dev);
 
 447         ring_space = pci_alloc_consistent(pci_dev, TX_TOTAL_SIZE, &ring_dma);
 
 450                 goto err_out_cleardev;
 
 452         sis_priv->tx_ring = (BufferDesc *)ring_space;
 
 453         sis_priv->tx_ring_dma = ring_dma;
 
 455         ring_space = pci_alloc_consistent(pci_dev, RX_TOTAL_SIZE, &ring_dma);
 
 460         sis_priv->rx_ring = (BufferDesc *)ring_space;
 
 461         sis_priv->rx_ring_dma = ring_dma;
 
 463         /* The SiS900-specific entries in the device structure. */
 
 464         net_dev->open = &sis900_open;
 
 465         net_dev->hard_start_xmit = &sis900_start_xmit;
 
 466         net_dev->stop = &sis900_close;
 
 467         net_dev->get_stats = &sis900_get_stats;
 
 468         net_dev->set_config = &sis900_set_config;
 
 469         net_dev->set_multicast_list = &set_rx_mode;
 
 470         net_dev->do_ioctl = &mii_ioctl;
 
 471         net_dev->tx_timeout = sis900_tx_timeout;
 
 472         net_dev->watchdog_timeo = TX_TIMEOUT;
 
 473         net_dev->ethtool_ops = &sis900_ethtool_ops;
 
 475 #ifdef CONFIG_NET_POLL_CONTROLLER
 
 476         net_dev->poll_controller = &sis900_poll;
 
 479         if (sis900_debug > 0)
 
 480                 sis_priv->msg_enable = sis900_debug;
 
 482                 sis_priv->msg_enable = SIS900_DEF_MSG;
 
 484         sis_priv->mii_info.dev = net_dev;
 
 485         sis_priv->mii_info.mdio_read = mdio_read;
 
 486         sis_priv->mii_info.mdio_write = mdio_write;
 
 487         sis_priv->mii_info.phy_id_mask = 0x1f;
 
 488         sis_priv->mii_info.reg_num_mask = 0x1f;
 
 490         /* Get Mac address according to the chip revision */
 
 491         pci_read_config_byte(pci_dev, PCI_CLASS_REVISION, &(sis_priv->chipset_rev));
 
 492         if(netif_msg_probe(sis_priv))
 
 493                 printk(KERN_DEBUG "%s: detected revision %2.2x, "
 
 494                                 "trying to get MAC address...\n",
 
 495                                 dev_name, sis_priv->chipset_rev);
 
 498         if (sis_priv->chipset_rev == SIS630E_900_REV)
 
 499                 ret = sis630e_get_mac_addr(pci_dev, net_dev);
 
 500         else if ((sis_priv->chipset_rev > 0x81) && (sis_priv->chipset_rev <= 0x90) )
 
 501                 ret = sis635_get_mac_addr(pci_dev, net_dev);
 
 502         else if (sis_priv->chipset_rev == SIS96x_900_REV)
 
 503                 ret = sis96x_get_mac_addr(pci_dev, net_dev);
 
 505                 ret = sis900_get_mac_addr(pci_dev, net_dev);
 
 508                 printk(KERN_WARNING "%s: Cannot read MAC address.\n", dev_name);
 
 513         /* 630ET : set the mii access mode as software-mode */
 
 514         if (sis_priv->chipset_rev == SIS630ET_900_REV)
 
 515                 outl(ACCESSMODE | inl(ioaddr + cr), ioaddr + cr);
 
 517         /* probe for mii transceiver */
 
 518         if (sis900_mii_probe(net_dev) == 0) {
 
 519                 printk(KERN_WARNING "%s: Error probing MII device.\n",
 
 525         /* save our host bridge revision */
 
 526         dev = pci_get_device(PCI_VENDOR_ID_SI, PCI_DEVICE_ID_SI_630, NULL);
 
 528                 pci_read_config_byte(dev, PCI_CLASS_REVISION, &sis_priv->host_bridge_rev);
 
 532         ret = register_netdev(net_dev);
 
 536         /* print some information about our NIC */
 
 537         printk(KERN_INFO "%s: %s at %#lx, IRQ %d, ", net_dev->name,
 
 538                card_name, ioaddr, net_dev->irq);
 
 539         for (i = 0; i < 5; i++)
 
 540                 printk("%2.2x:", (u8)net_dev->dev_addr[i]);
 
 541         printk("%2.2x.\n", net_dev->dev_addr[i]);
 
 543         /* Detect Wake on Lan support */
 
 544         ret = (inl(net_dev->base_addr + CFGPMC) & PMESP) >> 27;
 
 545         if (netif_msg_probe(sis_priv) && (ret & PME_D3C) == 0)
 
 546                 printk(KERN_INFO "%s: Wake on LAN only available from suspend to RAM.", net_dev->name);
 
 551         pci_free_consistent(pci_dev, RX_TOTAL_SIZE, sis_priv->rx_ring,
 
 552                 sis_priv->rx_ring_dma);
 
 554         pci_free_consistent(pci_dev, TX_TOTAL_SIZE, sis_priv->tx_ring,
 
 555                 sis_priv->tx_ring_dma);
 
 557         pci_set_drvdata(pci_dev, NULL);
 
 558         pci_release_regions(pci_dev);
 
 560         free_netdev(net_dev);
 
 565  *      sis900_mii_probe - Probe MII PHY for sis900
 
 566  *      @net_dev: the net device to probe for
 
 568  *      Search for total of 32 possible mii phy addresses.
 
 569  *      Identify and set current phy if found one,
 
 570  *      return error if it failed to found.
 
 573 static int __init sis900_mii_probe(struct net_device * net_dev)
 
 575         struct sis900_private * sis_priv = net_dev->priv;
 
 576         const char *dev_name = pci_name(sis_priv->pci_dev);
 
 577         u16 poll_bit = MII_STAT_LINK, status = 0;
 
 578         unsigned long timeout = jiffies + 5 * HZ;
 
 581         sis_priv->mii = NULL;
 
 583         /* search for total of 32 possible mii phy addresses */
 
 584         for (phy_addr = 0; phy_addr < 32; phy_addr++) { 
 
 585                 struct mii_phy * mii_phy = NULL;
 
 590                 for(i = 0; i < 2; i++)
 
 591                         mii_status = mdio_read(net_dev, phy_addr, MII_STATUS);
 
 593                 if (mii_status == 0xffff || mii_status == 0x0000) {
 
 594                         if (netif_msg_probe(sis_priv))
 
 595                                 printk(KERN_DEBUG "%s: MII at address %d"
 
 601                 if ((mii_phy = kmalloc(sizeof(struct mii_phy), GFP_KERNEL)) == NULL) {
 
 602                         printk(KERN_WARNING "Cannot allocate mem for struct mii_phy\n");
 
 603                         mii_phy = sis_priv->first_mii;
 
 607                                 mii_phy = mii_phy->next;
 
 613                 mii_phy->phy_id0 = mdio_read(net_dev, phy_addr, MII_PHY_ID0);
 
 614                 mii_phy->phy_id1 = mdio_read(net_dev, phy_addr, MII_PHY_ID1);           
 
 615                 mii_phy->phy_addr = phy_addr;
 
 616                 mii_phy->status = mii_status;
 
 617                 mii_phy->next = sis_priv->mii;
 
 618                 sis_priv->mii = mii_phy;
 
 619                 sis_priv->first_mii = mii_phy;
 
 621                 for (i = 0; mii_chip_table[i].phy_id1; i++)
 
 622                         if ((mii_phy->phy_id0 == mii_chip_table[i].phy_id0 ) &&
 
 623                             ((mii_phy->phy_id1 & 0xFFF0) == mii_chip_table[i].phy_id1)){
 
 624                                 mii_phy->phy_types = mii_chip_table[i].phy_types;
 
 625                                 if (mii_chip_table[i].phy_types == MIX)
 
 627                                             (mii_status & (MII_STAT_CAN_TX_FDX | MII_STAT_CAN_TX)) ? LAN : HOME;
 
 628                                 printk(KERN_INFO "%s: %s transceiver found "
 
 631                                                         mii_chip_table[i].name,
 
 636                 if( !mii_chip_table[i].phy_id1 ) {
 
 637                         printk(KERN_INFO "%s: Unknown PHY transceiver found at address %d.\n",
 
 639                         mii_phy->phy_types = UNKNOWN;
 
 643         if (sis_priv->mii == NULL) {
 
 644                 printk(KERN_INFO "%s: No MII transceivers found!\n", dev_name);
 
 648         /* select default PHY for mac */
 
 649         sis_priv->mii = NULL;
 
 650         sis900_default_phy( net_dev );
 
 652         /* Reset phy if default phy is internal sis900 */
 
 653         if ((sis_priv->mii->phy_id0 == 0x001D) &&
 
 654             ((sis_priv->mii->phy_id1&0xFFF0) == 0x8000))
 
 655                 status = sis900_reset_phy(net_dev, sis_priv->cur_phy);
 
 657         /* workaround for ICS1893 PHY */
 
 658         if ((sis_priv->mii->phy_id0 == 0x0015) &&
 
 659             ((sis_priv->mii->phy_id1&0xFFF0) == 0xF440))
 
 660                 mdio_write(net_dev, sis_priv->cur_phy, 0x0018, 0xD200);
 
 662         if(status & MII_STAT_LINK){
 
 666                         poll_bit ^= (mdio_read(net_dev, sis_priv->cur_phy, MII_STATUS) & poll_bit);
 
 667                         if (time_after_eq(jiffies, timeout)) {
 
 668                                 printk(KERN_WARNING "%s: reset phy and link down now\n",
 
 675         if (sis_priv->chipset_rev == SIS630E_900_REV) {
 
 676                 /* SiS 630E has some bugs on default value of PHY registers */
 
 677                 mdio_write(net_dev, sis_priv->cur_phy, MII_ANADV, 0x05e1);
 
 678                 mdio_write(net_dev, sis_priv->cur_phy, MII_CONFIG1, 0x22);
 
 679                 mdio_write(net_dev, sis_priv->cur_phy, MII_CONFIG2, 0xff00);
 
 680                 mdio_write(net_dev, sis_priv->cur_phy, MII_MASK, 0xffc0);
 
 681                 //mdio_write(net_dev, sis_priv->cur_phy, MII_CONTROL, 0x1000);  
 
 684         if (sis_priv->mii->status & MII_STAT_LINK)
 
 685                 netif_carrier_on(net_dev);
 
 687                 netif_carrier_off(net_dev);
 
 693  *      sis900_default_phy - Select default PHY for sis900 mac.
 
 694  *      @net_dev: the net device to probe for
 
 696  *      Select first detected PHY with link as default.
 
 697  *      If no one is link on, select PHY whose types is HOME as default.
 
 698  *      If HOME doesn't exist, select LAN.
 
 701 static u16 sis900_default_phy(struct net_device * net_dev)
 
 703         struct sis900_private * sis_priv = net_dev->priv;
 
 704         struct mii_phy *phy = NULL, *phy_home = NULL, 
 
 705                 *default_phy = NULL, *phy_lan = NULL;
 
 708         for (phy=sis_priv->first_mii; phy; phy=phy->next) {
 
 709                 status = mdio_read(net_dev, phy->phy_addr, MII_STATUS);
 
 710                 status = mdio_read(net_dev, phy->phy_addr, MII_STATUS);
 
 712                 /* Link ON & Not select default PHY & not ghost PHY */
 
 713                  if ((status & MII_STAT_LINK) && !default_phy &&
 
 714                                         (phy->phy_types != UNKNOWN))
 
 717                         status = mdio_read(net_dev, phy->phy_addr, MII_CONTROL);
 
 718                         mdio_write(net_dev, phy->phy_addr, MII_CONTROL,
 
 719                                 status | MII_CNTL_AUTO | MII_CNTL_ISOLATE);
 
 720                         if (phy->phy_types == HOME)
 
 722                         else if(phy->phy_types == LAN)
 
 727         if (!default_phy && phy_home)
 
 728                 default_phy = phy_home;
 
 729         else if (!default_phy && phy_lan)
 
 730                 default_phy = phy_lan;
 
 731         else if (!default_phy)
 
 732                 default_phy = sis_priv->first_mii;
 
 734         if (sis_priv->mii != default_phy) {
 
 735                 sis_priv->mii = default_phy;
 
 736                 sis_priv->cur_phy = default_phy->phy_addr;
 
 737                 printk(KERN_INFO "%s: Using transceiver found at address %d as default\n",
 
 738                        pci_name(sis_priv->pci_dev), sis_priv->cur_phy);
 
 741         sis_priv->mii_info.phy_id = sis_priv->cur_phy;
 
 743         status = mdio_read(net_dev, sis_priv->cur_phy, MII_CONTROL);
 
 744         status &= (~MII_CNTL_ISOLATE);
 
 746         mdio_write(net_dev, sis_priv->cur_phy, MII_CONTROL, status);    
 
 747         status = mdio_read(net_dev, sis_priv->cur_phy, MII_STATUS);
 
 748         status = mdio_read(net_dev, sis_priv->cur_phy, MII_STATUS);
 
 755  *      sis900_set_capability - set the media capability of network adapter.
 
 756  *      @net_dev : the net device to probe for
 
 759  *      Set the media capability of network adapter according to
 
 760  *      mii status register. It's necessary before auto-negotiate.
 
 763 static void sis900_set_capability(struct net_device *net_dev, struct mii_phy *phy)
 
 768         status = mdio_read(net_dev, phy->phy_addr, MII_STATUS);
 
 769         status = mdio_read(net_dev, phy->phy_addr, MII_STATUS);
 
 771         cap = MII_NWAY_CSMA_CD |
 
 772                 ((phy->status & MII_STAT_CAN_TX_FDX)? MII_NWAY_TX_FDX:0) |
 
 773                 ((phy->status & MII_STAT_CAN_TX)    ? MII_NWAY_TX:0) |
 
 774                 ((phy->status & MII_STAT_CAN_T_FDX) ? MII_NWAY_T_FDX:0)|
 
 775                 ((phy->status & MII_STAT_CAN_T)     ? MII_NWAY_T:0);
 
 777         mdio_write(net_dev, phy->phy_addr, MII_ANADV, cap);
 
 781 /* Delay between EEPROM clock transitions. */
 
 782 #define eeprom_delay()  inl(ee_addr)
 
 785  *      read_eeprom - Read Serial EEPROM
 
 786  *      @ioaddr: base i/o address
 
 787  *      @location: the EEPROM location to read
 
 789  *      Read Serial EEPROM through EEPROM Access Register.
 
 790  *      Note that location is in word (16 bits) unit
 
 793 static u16 __devinit read_eeprom(long ioaddr, int location)
 
 797         long ee_addr = ioaddr + mear;
 
 798         u32 read_cmd = location | EEread;
 
 805         /* Shift the read command (9) bits out. */
 
 806         for (i = 8; i >= 0; i--) {
 
 807                 u32 dataval = (read_cmd & (1 << i)) ? EEDI | EECS : EECS;
 
 808                 outl(dataval, ee_addr);
 
 810                 outl(dataval | EECLK, ee_addr);
 
 816         /* read the 16-bits data in */
 
 817         for (i = 16; i > 0; i--) {
 
 820                 outl(EECS | EECLK, ee_addr);
 
 822                 retval = (retval << 1) | ((inl(ee_addr) & EEDO) ? 1 : 0);
 
 826         /* Terminate the EEPROM access. */
 
 833 /* Read and write the MII management registers using software-generated
 
 834    serial MDIO protocol. Note that the command bits and data bits are
 
 835    send out separately */
 
 836 #define mdio_delay()    inl(mdio_addr)
 
 838 static void mdio_idle(long mdio_addr)
 
 840         outl(MDIO | MDDIR, mdio_addr);
 
 842         outl(MDIO | MDDIR | MDC, mdio_addr);
 
 845 /* Syncronize the MII management interface by shifting 32 one bits out. */
 
 846 static void mdio_reset(long mdio_addr)
 
 850         for (i = 31; i >= 0; i--) {
 
 851                 outl(MDDIR | MDIO, mdio_addr);
 
 853                 outl(MDDIR | MDIO | MDC, mdio_addr);
 
 860  *      mdio_read - read MII PHY register
 
 861  *      @net_dev: the net device to read
 
 862  *      @phy_id: the phy address to read
 
 863  *      @location: the phy regiester id to read
 
 865  *      Read MII registers through MDIO and MDC
 
 866  *      using MDIO management frame structure and protocol(defined by ISO/IEC).
 
 867  *      Please see SiS7014 or ICS spec
 
 870 static int mdio_read(struct net_device *net_dev, int phy_id, int location)
 
 872         long mdio_addr = net_dev->base_addr + mear;
 
 873         int mii_cmd = MIIread|(phy_id<<MIIpmdShift)|(location<<MIIregShift);
 
 877         mdio_reset(mdio_addr);
 
 878         mdio_idle(mdio_addr);
 
 880         for (i = 15; i >= 0; i--) {
 
 881                 int dataval = (mii_cmd & (1 << i)) ? MDDIR | MDIO : MDDIR;
 
 882                 outl(dataval, mdio_addr);
 
 884                 outl(dataval | MDC, mdio_addr);
 
 888         /* Read the 16 data bits. */
 
 889         for (i = 16; i > 0; i--) {
 
 892                 retval = (retval << 1) | ((inl(mdio_addr) & MDIO) ? 1 : 0);
 
 893                 outl(MDC, mdio_addr);
 
 896         outl(0x00, mdio_addr);
 
 902  *      mdio_write - write MII PHY register
 
 903  *      @net_dev: the net device to write
 
 904  *      @phy_id: the phy address to write
 
 905  *      @location: the phy regiester id to write
 
 906  *      @value: the register value to write with
 
 908  *      Write MII registers with @value through MDIO and MDC
 
 909  *      using MDIO management frame structure and protocol(defined by ISO/IEC)
 
 910  *      please see SiS7014 or ICS spec
 
 913 static void mdio_write(struct net_device *net_dev, int phy_id, int location,
 
 916         long mdio_addr = net_dev->base_addr + mear;
 
 917         int mii_cmd = MIIwrite|(phy_id<<MIIpmdShift)|(location<<MIIregShift);
 
 920         mdio_reset(mdio_addr);
 
 921         mdio_idle(mdio_addr);
 
 923         /* Shift the command bits out. */
 
 924         for (i = 15; i >= 0; i--) {
 
 925                 int dataval = (mii_cmd & (1 << i)) ? MDDIR | MDIO : MDDIR;
 
 926                 outb(dataval, mdio_addr);
 
 928                 outb(dataval | MDC, mdio_addr);
 
 933         /* Shift the value bits out. */
 
 934         for (i = 15; i >= 0; i--) {
 
 935                 int dataval = (value & (1 << i)) ? MDDIR | MDIO : MDDIR;
 
 936                 outl(dataval, mdio_addr);
 
 938                 outl(dataval | MDC, mdio_addr);
 
 943         /* Clear out extra bits. */
 
 944         for (i = 2; i > 0; i--) {
 
 947                 outb(MDC, mdio_addr);
 
 950         outl(0x00, mdio_addr);
 
 957  *      sis900_reset_phy - reset sis900 mii phy.
 
 958  *      @net_dev: the net device to write
 
 959  *      @phy_addr: default phy address
 
 961  *      Some specific phy can't work properly without reset.
 
 962  *      This function will be called during initialization and
 
 963  *      link status change from ON to DOWN.
 
 966 static u16 sis900_reset_phy(struct net_device *net_dev, int phy_addr)
 
 972                 status = mdio_read(net_dev, phy_addr, MII_STATUS);
 
 974         mdio_write( net_dev, phy_addr, MII_CONTROL, MII_CNTL_RESET );
 
 979 #ifdef CONFIG_NET_POLL_CONTROLLER
 
 981  * Polling 'interrupt' - used by things like netconsole to send skbs
 
 982  * without having to re-enable interrupts. It's not called while
 
 983  * the interrupt routine is executing.
 
 985 static void sis900_poll(struct net_device *dev)
 
 987         disable_irq(dev->irq);
 
 988         sis900_interrupt(dev->irq, dev, NULL);
 
 989         enable_irq(dev->irq);
 
 994  *      sis900_open - open sis900 device
 
 995  *      @net_dev: the net device to open
 
 997  *      Do some initialization and start net interface.
 
 998  *      enable interrupts and set sis900 timer.
 
1002 sis900_open(struct net_device *net_dev)
 
1004         struct sis900_private *sis_priv = net_dev->priv;
 
1005         long ioaddr = net_dev->base_addr;
 
1008         /* Soft reset the chip. */
 
1009         sis900_reset(net_dev);
 
1011         /* Equalizer workaround Rule */
 
1012         sis630_set_eq(net_dev, sis_priv->chipset_rev);
 
1014         ret = request_irq(net_dev->irq, &sis900_interrupt, SA_SHIRQ,
 
1015                                                 net_dev->name, net_dev);
 
1019         sis900_init_rxfilter(net_dev);
 
1021         sis900_init_tx_ring(net_dev);
 
1022         sis900_init_rx_ring(net_dev);
 
1024         set_rx_mode(net_dev);
 
1026         netif_start_queue(net_dev);
 
1028         /* Workaround for EDB */
 
1029         sis900_set_mode(ioaddr, HW_SPEED_10_MBPS, FDX_CAPABLE_HALF_SELECTED);
 
1031         /* Enable all known interrupts by setting the interrupt mask. */
 
1032         outl((RxSOVR|RxORN|RxERR|RxOK|TxURN|TxERR|TxIDLE), ioaddr + imr);
 
1033         outl(RxENA | inl(ioaddr + cr), ioaddr + cr);
 
1034         outl(IE, ioaddr + ier);
 
1036         sis900_check_mode(net_dev, sis_priv->mii);
 
1038         /* Set the timer to switch to check for link beat and perhaps switch
 
1039            to an alternate media type. */
 
1040         init_timer(&sis_priv->timer);
 
1041         sis_priv->timer.expires = jiffies + HZ;
 
1042         sis_priv->timer.data = (unsigned long)net_dev;
 
1043         sis_priv->timer.function = &sis900_timer;
 
1044         add_timer(&sis_priv->timer);
 
1050  *      sis900_init_rxfilter - Initialize the Rx filter
 
1051  *      @net_dev: the net device to initialize for
 
1053  *      Set receive filter address to our MAC address
 
1054  *      and enable packet filtering.
 
1058 sis900_init_rxfilter (struct net_device * net_dev)
 
1060         struct sis900_private *sis_priv = net_dev->priv;
 
1061         long ioaddr = net_dev->base_addr;
 
1065         rfcrSave = inl(rfcr + ioaddr);
 
1067         /* disable packet filtering before setting filter */
 
1068         outl(rfcrSave & ~RFEN, rfcr + ioaddr);
 
1070         /* load MAC addr to filter data register */
 
1071         for (i = 0 ; i < 3 ; i++) {
 
1074                 w = (u32) *((u16 *)(net_dev->dev_addr)+i);
 
1075                 outl((i << RFADDR_shift), ioaddr + rfcr);
 
1076                 outl(w, ioaddr + rfdr);
 
1078                 if (netif_msg_hw(sis_priv)) {
 
1079                         printk(KERN_DEBUG "%s: Receive Filter Addrss[%d]=%x\n",
 
1080                                net_dev->name, i, inl(ioaddr + rfdr));
 
1084         /* enable packet filtering */
 
1085         outl(rfcrSave | RFEN, rfcr + ioaddr);
 
1089  *      sis900_init_tx_ring - Initialize the Tx descriptor ring
 
1090  *      @net_dev: the net device to initialize for
 
1092  *      Initialize the Tx descriptor ring, 
 
1096 sis900_init_tx_ring(struct net_device *net_dev)
 
1098         struct sis900_private *sis_priv = net_dev->priv;
 
1099         long ioaddr = net_dev->base_addr;
 
1102         sis_priv->tx_full = 0;
 
1103         sis_priv->dirty_tx = sis_priv->cur_tx = 0;
 
1105         for (i = 0; i < NUM_TX_DESC; i++) {
 
1106                 sis_priv->tx_skbuff[i] = NULL;
 
1108                 sis_priv->tx_ring[i].link = sis_priv->tx_ring_dma +
 
1109                         ((i+1)%NUM_TX_DESC)*sizeof(BufferDesc);
 
1110                 sis_priv->tx_ring[i].cmdsts = 0;
 
1111                 sis_priv->tx_ring[i].bufptr = 0;
 
1114         /* load Transmit Descriptor Register */
 
1115         outl(sis_priv->tx_ring_dma, ioaddr + txdp);
 
1116         if (netif_msg_hw(sis_priv))
 
1117                 printk(KERN_DEBUG "%s: TX descriptor register loaded with: %8.8x\n",
 
1118                        net_dev->name, inl(ioaddr + txdp));
 
1122  *      sis900_init_rx_ring - Initialize the Rx descriptor ring
 
1123  *      @net_dev: the net device to initialize for
 
1125  *      Initialize the Rx descriptor ring, 
 
1126  *      and pre-allocate recevie buffers (socket buffer)
 
1130 sis900_init_rx_ring(struct net_device *net_dev)
 
1132         struct sis900_private *sis_priv = net_dev->priv;
 
1133         long ioaddr = net_dev->base_addr;
 
1136         sis_priv->cur_rx = 0;
 
1137         sis_priv->dirty_rx = 0;
 
1139         /* init RX descriptor */
 
1140         for (i = 0; i < NUM_RX_DESC; i++) {
 
1141                 sis_priv->rx_skbuff[i] = NULL;
 
1143                 sis_priv->rx_ring[i].link = sis_priv->rx_ring_dma +
 
1144                         ((i+1)%NUM_RX_DESC)*sizeof(BufferDesc);
 
1145                 sis_priv->rx_ring[i].cmdsts = 0;
 
1146                 sis_priv->rx_ring[i].bufptr = 0;
 
1149         /* allocate sock buffers */
 
1150         for (i = 0; i < NUM_RX_DESC; i++) {
 
1151                 struct sk_buff *skb;
 
1153                 if ((skb = dev_alloc_skb(RX_BUF_SIZE)) == NULL) {
 
1154                         /* not enough memory for skbuff, this makes a "hole"
 
1155                            on the buffer ring, it is not clear how the
 
1156                            hardware will react to this kind of degenerated
 
1161                 sis_priv->rx_skbuff[i] = skb;
 
1162                 sis_priv->rx_ring[i].cmdsts = RX_BUF_SIZE;
 
1163                 sis_priv->rx_ring[i].bufptr = pci_map_single(sis_priv->pci_dev,
 
1164                         skb->data, RX_BUF_SIZE, PCI_DMA_FROMDEVICE);
 
1166         sis_priv->dirty_rx = (unsigned int) (i - NUM_RX_DESC);
 
1168         /* load Receive Descriptor Register */
 
1169         outl(sis_priv->rx_ring_dma, ioaddr + rxdp);
 
1170         if (netif_msg_hw(sis_priv))
 
1171                 printk(KERN_DEBUG "%s: RX descriptor register loaded with: %8.8x\n",
 
1172                        net_dev->name, inl(ioaddr + rxdp));
 
1176  *      sis630_set_eq - set phy equalizer value for 630 LAN
 
1177  *      @net_dev: the net device to set equalizer value
 
1178  *      @revision: 630 LAN revision number
 
1180  *      630E equalizer workaround rule(Cyrus Huang 08/15)
 
1181  *      PHY register 14h(Test)
 
1182  *      Bit 14: 0 -- Automatically dectect (default)
 
1183  *              1 -- Manually set Equalizer filter
 
1184  *      Bit 13: 0 -- (Default)
 
1185  *              1 -- Speed up convergence of equalizer setting
 
1186  *      Bit 9 : 0 -- (Default)
 
1187  *              1 -- Disable Baseline Wander
 
1188  *      Bit 3~7   -- Equalizer filter setting
 
1189  *      Link ON: Set Bit 9, 13 to 1, Bit 14 to 0
 
1190  *      Then calculate equalizer value
 
1191  *      Then set equalizer value, and set Bit 14 to 1, Bit 9 to 0
 
1192  *      Link Off:Set Bit 13 to 1, Bit 14 to 0
 
1193  *      Calculate Equalizer value:
 
1194  *      When Link is ON and Bit 14 is 0, SIS900PHY will auto-dectect proper equalizer value.
 
1195  *      When the equalizer is stable, this value is not a fixed value. It will be within
 
1196  *      a small range(eg. 7~9). Then we get a minimum and a maximum value(eg. min=7, max=9)
 
1197  *      0 <= max <= 4  --> set equalizer to max
 
1198  *      5 <= max <= 14 --> set equalizer to max+1 or set equalizer to max+2 if max == min
 
1199  *      max >= 15      --> set equalizer to max+5 or set equalizer to max+6 if max == min
 
1202 static void sis630_set_eq(struct net_device *net_dev, u8 revision)
 
1204         struct sis900_private *sis_priv = net_dev->priv;
 
1205         u16 reg14h, eq_value=0, max_value=0, min_value=0;
 
1208         if ( !(revision == SIS630E_900_REV || revision == SIS630EA1_900_REV ||
 
1209                revision == SIS630A_900_REV || revision ==  SIS630ET_900_REV) )
 
1212         if (netif_carrier_ok(net_dev)) {
 
1213                 reg14h = mdio_read(net_dev, sis_priv->cur_phy, MII_RESV);
 
1214                 mdio_write(net_dev, sis_priv->cur_phy, MII_RESV,
 
1215                                         (0x2200 | reg14h) & 0xBFFF);
 
1216                 for (i=0; i < maxcount; i++) {
 
1217                         eq_value = (0x00F8 & mdio_read(net_dev,
 
1218                                         sis_priv->cur_phy, MII_RESV)) >> 3;
 
1220                                 max_value=min_value=eq_value;
 
1221                         max_value = (eq_value > max_value) ?
 
1222                                                 eq_value : max_value;
 
1223                         min_value = (eq_value < min_value) ?
 
1224                                                 eq_value : min_value;
 
1226                 /* 630E rule to determine the equalizer value */
 
1227                 if (revision == SIS630E_900_REV || revision == SIS630EA1_900_REV ||
 
1228                     revision == SIS630ET_900_REV) {
 
1230                                 eq_value = max_value;
 
1231                         else if (max_value >= 5 && max_value < 15)
 
1232                                 eq_value = (max_value == min_value) ?
 
1233                                                 max_value+2 : max_value+1;
 
1234                         else if (max_value >= 15)
 
1235                                 eq_value=(max_value == min_value) ?
 
1236                                                 max_value+6 : max_value+5;
 
1238                 /* 630B0&B1 rule to determine the equalizer value */
 
1239                 if (revision == SIS630A_900_REV && 
 
1240                     (sis_priv->host_bridge_rev == SIS630B0 || 
 
1241                      sis_priv->host_bridge_rev == SIS630B1)) {
 
1245                                 eq_value = (max_value + min_value + 1)/2;
 
1247                 /* write equalizer value and setting */
 
1248                 reg14h = mdio_read(net_dev, sis_priv->cur_phy, MII_RESV);
 
1249                 reg14h = (reg14h & 0xFF07) | ((eq_value << 3) & 0x00F8);
 
1250                 reg14h = (reg14h | 0x6000) & 0xFDFF;
 
1251                 mdio_write(net_dev, sis_priv->cur_phy, MII_RESV, reg14h);
 
1253                 reg14h = mdio_read(net_dev, sis_priv->cur_phy, MII_RESV);
 
1254                 if (revision == SIS630A_900_REV && 
 
1255                     (sis_priv->host_bridge_rev == SIS630B0 || 
 
1256                      sis_priv->host_bridge_rev == SIS630B1)) 
 
1257                         mdio_write(net_dev, sis_priv->cur_phy, MII_RESV,
 
1258                                                 (reg14h | 0x2200) & 0xBFFF);
 
1260                         mdio_write(net_dev, sis_priv->cur_phy, MII_RESV,
 
1261                                                 (reg14h | 0x2000) & 0xBFFF);
 
1267  *      sis900_timer - sis900 timer routine
 
1268  *      @data: pointer to sis900 net device
 
1270  *      On each timer ticks we check two things, 
 
1271  *      link status (ON/OFF) and link mode (10/100/Full/Half)
 
1274 static void sis900_timer(unsigned long data)
 
1276         struct net_device *net_dev = (struct net_device *)data;
 
1277         struct sis900_private *sis_priv = net_dev->priv;
 
1278         struct mii_phy *mii_phy = sis_priv->mii;
 
1279         static const int next_tick = 5*HZ;
 
1282         if (!sis_priv->autong_complete){
 
1283                 int speed, duplex = 0;
 
1285                 sis900_read_mode(net_dev, &speed, &duplex);
 
1287                         sis900_set_mode(net_dev->base_addr, speed, duplex);
 
1288                         sis630_set_eq(net_dev, sis_priv->chipset_rev);
 
1289                         netif_start_queue(net_dev);
 
1292                 sis_priv->timer.expires = jiffies + HZ;
 
1293                 add_timer(&sis_priv->timer);
 
1297         status = mdio_read(net_dev, sis_priv->cur_phy, MII_STATUS);
 
1298         status = mdio_read(net_dev, sis_priv->cur_phy, MII_STATUS);
 
1300         /* Link OFF -> ON */
 
1301         if (!netif_carrier_ok(net_dev)) {
 
1303                 /* Search for new PHY */
 
1304                 status = sis900_default_phy(net_dev);
 
1305                 mii_phy = sis_priv->mii;
 
1307                 if (status & MII_STAT_LINK){
 
1308                         sis900_check_mode(net_dev, mii_phy);
 
1309                         netif_carrier_on(net_dev);
 
1312         /* Link ON -> OFF */
 
1313                 if (!(status & MII_STAT_LINK)){
 
1314                         netif_carrier_off(net_dev);
 
1315                         if(netif_msg_link(sis_priv))
 
1316                                 printk(KERN_INFO "%s: Media Link Off\n", net_dev->name);
 
1318                         /* Change mode issue */
 
1319                         if ((mii_phy->phy_id0 == 0x001D) && 
 
1320                             ((mii_phy->phy_id1 & 0xFFF0) == 0x8000))
 
1321                                 sis900_reset_phy(net_dev,  sis_priv->cur_phy);
 
1323                         sis630_set_eq(net_dev, sis_priv->chipset_rev);
 
1329         sis_priv->timer.expires = jiffies + next_tick;
 
1330         add_timer(&sis_priv->timer);
 
1334  *      sis900_check_mode - check the media mode for sis900
 
1335  *      @net_dev: the net device to be checked
 
1336  *      @mii_phy: the mii phy
 
1338  *      Older driver gets the media mode from mii status output
 
1339  *      register. Now we set our media capability and auto-negotiate
 
1340  *      to get the upper bound of speed and duplex between two ends.
 
1341  *      If the types of mii phy is HOME, it doesn't need to auto-negotiate
 
1342  *      and autong_complete should be set to 1.
 
1345 static void sis900_check_mode(struct net_device *net_dev, struct mii_phy *mii_phy)
 
1347         struct sis900_private *sis_priv = net_dev->priv;
 
1348         long ioaddr = net_dev->base_addr;
 
1351         if (mii_phy->phy_types == LAN) {
 
1352                 outl(~EXD & inl(ioaddr + cfg), ioaddr + cfg);
 
1353                 sis900_set_capability(net_dev , mii_phy);
 
1354                 sis900_auto_negotiate(net_dev, sis_priv->cur_phy);
 
1356                 outl(EXD | inl(ioaddr + cfg), ioaddr + cfg);
 
1357                 speed = HW_SPEED_HOME;
 
1358                 duplex = FDX_CAPABLE_HALF_SELECTED;
 
1359                 sis900_set_mode(ioaddr, speed, duplex);
 
1360                 sis_priv->autong_complete = 1;
 
1365  *      sis900_set_mode - Set the media mode of mac register.
 
1366  *      @ioaddr: the address of the device
 
1367  *      @speed : the transmit speed to be determined
 
1368  *      @duplex: the duplex mode to be determined
 
1370  *      Set the media mode of mac register txcfg/rxcfg according to
 
1371  *      speed and duplex of phy. Bit EDB_MASTER_EN indicates the EDB
 
1372  *      bus is used instead of PCI bus. When this bit is set 1, the
 
1373  *      Max DMA Burst Size for TX/RX DMA should be no larger than 16
 
1377 static void sis900_set_mode (long ioaddr, int speed, int duplex)
 
1379         u32 tx_flags = 0, rx_flags = 0;
 
1381         if (inl(ioaddr + cfg) & EDB_MASTER_EN) {
 
1382                 tx_flags = TxATP | (DMA_BURST_64 << TxMXDMA_shift) |
 
1383                                         (TX_FILL_THRESH << TxFILLT_shift);
 
1384                 rx_flags = DMA_BURST_64 << RxMXDMA_shift;
 
1386                 tx_flags = TxATP | (DMA_BURST_512 << TxMXDMA_shift) |
 
1387                                         (TX_FILL_THRESH << TxFILLT_shift);
 
1388                 rx_flags = DMA_BURST_512 << RxMXDMA_shift;
 
1391         if (speed == HW_SPEED_HOME || speed == HW_SPEED_10_MBPS) {
 
1392                 rx_flags |= (RxDRNT_10 << RxDRNT_shift);
 
1393                 tx_flags |= (TxDRNT_10 << TxDRNT_shift);
 
1395                 rx_flags |= (RxDRNT_100 << RxDRNT_shift);
 
1396                 tx_flags |= (TxDRNT_100 << TxDRNT_shift);
 
1399         if (duplex == FDX_CAPABLE_FULL_SELECTED) {
 
1400                 tx_flags |= (TxCSI | TxHBI);
 
1404         outl (tx_flags, ioaddr + txcfg);
 
1405         outl (rx_flags, ioaddr + rxcfg);
 
1409  *      sis900_auto_negotiate - Set the Auto-Negotiation Enable/Reset bit.
 
1410  *      @net_dev: the net device to read mode for
 
1411  *      @phy_addr: mii phy address
 
1413  *      If the adapter is link-on, set the auto-negotiate enable/reset bit.
 
1414  *      autong_complete should be set to 0 when starting auto-negotiation.
 
1415  *      autong_complete should be set to 1 if we didn't start auto-negotiation.
 
1416  *      sis900_timer will wait for link on again if autong_complete = 0.
 
1419 static void sis900_auto_negotiate(struct net_device *net_dev, int phy_addr)
 
1421         struct sis900_private *sis_priv = net_dev->priv;
 
1426                 status = mdio_read(net_dev, phy_addr, MII_STATUS);
 
1428         if (!(status & MII_STAT_LINK)){
 
1429                 if(netif_msg_link(sis_priv))
 
1430                         printk(KERN_INFO "%s: Media Link Off\n", net_dev->name);
 
1431                 sis_priv->autong_complete = 1;
 
1432                 netif_carrier_off(net_dev);
 
1436         /* (Re)start AutoNegotiate */
 
1437         mdio_write(net_dev, phy_addr, MII_CONTROL,
 
1438                    MII_CNTL_AUTO | MII_CNTL_RST_AUTO);
 
1439         sis_priv->autong_complete = 0;
 
1444  *      sis900_read_mode - read media mode for sis900 internal phy
 
1445  *      @net_dev: the net device to read mode for
 
1446  *      @speed  : the transmit speed to be determined
 
1447  *      @duplex : the duplex mode to be determined
 
1449  *      The capability of remote end will be put in mii register autorec
 
1450  *      after auto-negotiation. Use AND operation to get the upper bound
 
1451  *      of speed and duplex between two ends.
 
1454 static void sis900_read_mode(struct net_device *net_dev, int *speed, int *duplex)
 
1456         struct sis900_private *sis_priv = net_dev->priv;
 
1457         struct mii_phy *phy = sis_priv->mii;
 
1458         int phy_addr = sis_priv->cur_phy;
 
1460         u16 autoadv, autorec;
 
1464                 status = mdio_read(net_dev, phy_addr, MII_STATUS);
 
1466         if (!(status & MII_STAT_LINK))
 
1469         /* AutoNegotiate completed */
 
1470         autoadv = mdio_read(net_dev, phy_addr, MII_ANADV);
 
1471         autorec = mdio_read(net_dev, phy_addr, MII_ANLPAR);
 
1472         status = autoadv & autorec;
 
1474         *speed = HW_SPEED_10_MBPS;
 
1475         *duplex = FDX_CAPABLE_HALF_SELECTED;
 
1477         if (status & (MII_NWAY_TX | MII_NWAY_TX_FDX))
 
1478                 *speed = HW_SPEED_100_MBPS;
 
1479         if (status & ( MII_NWAY_TX_FDX | MII_NWAY_T_FDX))
 
1480                 *duplex = FDX_CAPABLE_FULL_SELECTED;
 
1482         sis_priv->autong_complete = 1;
 
1484         /* Workaround for Realtek RTL8201 PHY issue */
 
1485         if ((phy->phy_id0 == 0x0000) && ((phy->phy_id1 & 0xFFF0) == 0x8200)) {
 
1486                 if (mdio_read(net_dev, phy_addr, MII_CONTROL) & MII_CNTL_FDX)
 
1487                         *duplex = FDX_CAPABLE_FULL_SELECTED;
 
1488                 if (mdio_read(net_dev, phy_addr, 0x0019) & 0x01)
 
1489                         *speed = HW_SPEED_100_MBPS;
 
1492         if(netif_msg_link(sis_priv))
 
1493                 printk(KERN_INFO "%s: Media Link On %s %s-duplex \n",
 
1495                                         *speed == HW_SPEED_100_MBPS ?
 
1496                                                 "100mbps" : "10mbps",
 
1497                                         *duplex == FDX_CAPABLE_FULL_SELECTED ?
 
1502  *      sis900_tx_timeout - sis900 transmit timeout routine
 
1503  *      @net_dev: the net device to transmit
 
1505  *      print transmit timeout status
 
1506  *      disable interrupts and do some tasks
 
1509 static void sis900_tx_timeout(struct net_device *net_dev)
 
1511         struct sis900_private *sis_priv = net_dev->priv;
 
1512         long ioaddr = net_dev->base_addr;
 
1513         unsigned long flags;
 
1516         if(netif_msg_tx_err(sis_priv))
 
1517                 printk(KERN_INFO "%s: Transmit timeout, status %8.8x %8.8x \n",
 
1518                         net_dev->name, inl(ioaddr + cr), inl(ioaddr + isr));
 
1520         /* Disable interrupts by clearing the interrupt mask. */
 
1521         outl(0x0000, ioaddr + imr);
 
1523         /* use spinlock to prevent interrupt handler accessing buffer ring */
 
1524         spin_lock_irqsave(&sis_priv->lock, flags);
 
1526         /* discard unsent packets */
 
1527         sis_priv->dirty_tx = sis_priv->cur_tx = 0;
 
1528         for (i = 0; i < NUM_TX_DESC; i++) {
 
1529                 struct sk_buff *skb = sis_priv->tx_skbuff[i];
 
1532                         pci_unmap_single(sis_priv->pci_dev, 
 
1533                                 sis_priv->tx_ring[i].bufptr, skb->len,
 
1535                         dev_kfree_skb_irq(skb);
 
1536                         sis_priv->tx_skbuff[i] = NULL;
 
1537                         sis_priv->tx_ring[i].cmdsts = 0;
 
1538                         sis_priv->tx_ring[i].bufptr = 0;
 
1539                         sis_priv->stats.tx_dropped++;
 
1542         sis_priv->tx_full = 0;
 
1543         netif_wake_queue(net_dev);
 
1545         spin_unlock_irqrestore(&sis_priv->lock, flags);
 
1547         net_dev->trans_start = jiffies;
 
1549         /* load Transmit Descriptor Register */
 
1550         outl(sis_priv->tx_ring_dma, ioaddr + txdp);
 
1552         /* Enable all known interrupts by setting the interrupt mask. */
 
1553         outl((RxSOVR|RxORN|RxERR|RxOK|TxURN|TxERR|TxIDLE), ioaddr + imr);
 
1558  *      sis900_start_xmit - sis900 start transmit routine
 
1559  *      @skb: socket buffer pointer to put the data being transmitted
 
1560  *      @net_dev: the net device to transmit with
 
1562  *      Set the transmit buffer descriptor, 
 
1563  *      and write TxENA to enable transmit state machine.
 
1564  *      tell upper layer if the buffer is full
 
1568 sis900_start_xmit(struct sk_buff *skb, struct net_device *net_dev)
 
1570         struct sis900_private *sis_priv = net_dev->priv;
 
1571         long ioaddr = net_dev->base_addr;
 
1573         unsigned long flags;
 
1574         unsigned int  index_cur_tx, index_dirty_tx;
 
1575         unsigned int  count_dirty_tx;
 
1577         /* Don't transmit data before the complete of auto-negotiation */
 
1578         if(!sis_priv->autong_complete){
 
1579                 netif_stop_queue(net_dev);
 
1583         spin_lock_irqsave(&sis_priv->lock, flags);
 
1585         /* Calculate the next Tx descriptor entry. */
 
1586         entry = sis_priv->cur_tx % NUM_TX_DESC;
 
1587         sis_priv->tx_skbuff[entry] = skb;
 
1589         /* set the transmit buffer descriptor and enable Transmit State Machine */
 
1590         sis_priv->tx_ring[entry].bufptr = pci_map_single(sis_priv->pci_dev,
 
1591                 skb->data, skb->len, PCI_DMA_TODEVICE);
 
1592         sis_priv->tx_ring[entry].cmdsts = (OWN | skb->len);
 
1593         outl(TxENA | inl(ioaddr + cr), ioaddr + cr);
 
1595         sis_priv->cur_tx ++;
 
1596         index_cur_tx = sis_priv->cur_tx;
 
1597         index_dirty_tx = sis_priv->dirty_tx;
 
1599         for (count_dirty_tx = 0; index_cur_tx != index_dirty_tx; index_dirty_tx++)
 
1602         if (index_cur_tx == index_dirty_tx) {
 
1603                 /* dirty_tx is met in the cycle of cur_tx, buffer full */
 
1604                 sis_priv->tx_full = 1;
 
1605                 netif_stop_queue(net_dev);
 
1606         } else if (count_dirty_tx < NUM_TX_DESC) { 
 
1607                 /* Typical path, tell upper layer that more transmission is possible */
 
1608                 netif_start_queue(net_dev);
 
1610                 /* buffer full, tell upper layer no more transmission */
 
1611                 sis_priv->tx_full = 1;
 
1612                 netif_stop_queue(net_dev);
 
1615         spin_unlock_irqrestore(&sis_priv->lock, flags);
 
1617         net_dev->trans_start = jiffies;
 
1619         if (netif_msg_tx_queued(sis_priv))
 
1620                 printk(KERN_DEBUG "%s: Queued Tx packet at %p size %d "
 
1622                        net_dev->name, skb->data, (int)skb->len, entry);
 
1628  *      sis900_interrupt - sis900 interrupt handler
 
1629  *      @irq: the irq number
 
1630  *      @dev_instance: the client data object
 
1631  *      @regs: snapshot of processor context
 
1633  *      The interrupt handler does all of the Rx thread work, 
 
1634  *      and cleans up after the Tx thread
 
1637 static irqreturn_t sis900_interrupt(int irq, void *dev_instance, struct pt_regs *regs)
 
1639         struct net_device *net_dev = dev_instance;
 
1640         struct sis900_private *sis_priv = net_dev->priv;
 
1641         int boguscnt = max_interrupt_work;
 
1642         long ioaddr = net_dev->base_addr;
 
1644         unsigned int handled = 0;
 
1646         spin_lock (&sis_priv->lock);
 
1649                 status = inl(ioaddr + isr);
 
1651                 if ((status & (HIBERR|TxURN|TxERR|TxIDLE|RxORN|RxERR|RxOK)) == 0)
 
1652                         /* nothing intresting happened */
 
1656                 /* why dow't we break after Tx/Rx case ?? keyword: full-duplex */
 
1657                 if (status & (RxORN | RxERR | RxOK))
 
1661                 if (status & (TxURN | TxERR | TxIDLE))
 
1663                         sis900_finish_xmit(net_dev);
 
1665                 /* something strange happened !!! */
 
1666                 if (status & HIBERR) {
 
1667                         if(netif_msg_intr(sis_priv))
 
1668                                 printk(KERN_INFO "%s: Abnormal interrupt,"
 
1669                                         "status %#8.8x.\n", net_dev->name, status);
 
1672                 if (--boguscnt < 0) {
 
1673                         if(netif_msg_intr(sis_priv))
 
1674                                 printk(KERN_INFO "%s: Too much work at interrupt, "
 
1675                                         "interrupt status = %#8.8x.\n",
 
1676                                         net_dev->name, status);
 
1681         if(netif_msg_intr(sis_priv))
 
1682                 printk(KERN_DEBUG "%s: exiting interrupt, "
 
1683                        "interrupt status = 0x%#8.8x.\n",
 
1684                        net_dev->name, inl(ioaddr + isr));
 
1686         spin_unlock (&sis_priv->lock);
 
1687         return IRQ_RETVAL(handled);
 
1691  *      sis900_rx - sis900 receive routine
 
1692  *      @net_dev: the net device which receives data
 
1694  *      Process receive interrupt events, 
 
1695  *      put buffer to higher layer and refill buffer pool
 
1696  *      Note: This function is called by interrupt handler,
 
1697  *      don't do "too much" work here
 
1700 static int sis900_rx(struct net_device *net_dev)
 
1702         struct sis900_private *sis_priv = net_dev->priv;
 
1703         long ioaddr = net_dev->base_addr;
 
1704         unsigned int entry = sis_priv->cur_rx % NUM_RX_DESC;
 
1705         u32 rx_status = sis_priv->rx_ring[entry].cmdsts;
 
1708         if (netif_msg_rx_status(sis_priv))
 
1709                 printk(KERN_DEBUG "sis900_rx, cur_rx:%4.4d, dirty_rx:%4.4d "
 
1711                        sis_priv->cur_rx, sis_priv->dirty_rx, rx_status);
 
1712         rx_work_limit = sis_priv->dirty_rx + NUM_RX_DESC - sis_priv->cur_rx;
 
1714         while (rx_status & OWN) {
 
1715                 unsigned int rx_size;
 
1717                 if (--rx_work_limit < 0)
 
1720                 rx_size = (rx_status & DSIZE) - CRC_SIZE;
 
1722                 if (rx_status & (ABORT|OVERRUN|TOOLONG|RUNT|RXISERR|CRCERR|FAERR)) {
 
1723                         /* corrupted packet received */
 
1724                         if (netif_msg_rx_err(sis_priv))
 
1725                                 printk(KERN_DEBUG "%s: Corrupted packet "
 
1726                                        "received, buffer status = 0x%8.8x.\n",
 
1727                                        net_dev->name, rx_status);
 
1728                         sis_priv->stats.rx_errors++;
 
1729                         if (rx_status & OVERRUN)
 
1730                                 sis_priv->stats.rx_over_errors++;
 
1731                         if (rx_status & (TOOLONG|RUNT))
 
1732                                 sis_priv->stats.rx_length_errors++;
 
1733                         if (rx_status & (RXISERR | FAERR))
 
1734                                 sis_priv->stats.rx_frame_errors++;
 
1735                         if (rx_status & CRCERR) 
 
1736                                 sis_priv->stats.rx_crc_errors++;
 
1737                         /* reset buffer descriptor state */
 
1738                         sis_priv->rx_ring[entry].cmdsts = RX_BUF_SIZE;
 
1740                         struct sk_buff * skb;
 
1742                         /* This situation should never happen, but due to
 
1743                            some unknow bugs, it is possible that
 
1744                            we are working on NULL sk_buff :-( */
 
1745                         if (sis_priv->rx_skbuff[entry] == NULL) {
 
1746                                 if (netif_msg_rx_err(sis_priv))
 
1747                                         printk(KERN_WARNING "%s: NULL pointer " 
 
1748                                               "encountered in Rx ring\n"
 
1749                                               "cur_rx:%4.4d, dirty_rx:%4.4d\n",
 
1750                                               net_dev->name, sis_priv->cur_rx,
 
1751                                               sis_priv->dirty_rx);
 
1755                         pci_unmap_single(sis_priv->pci_dev, 
 
1756                                 sis_priv->rx_ring[entry].bufptr, RX_BUF_SIZE, 
 
1757                                 PCI_DMA_FROMDEVICE);
 
1758                         /* give the socket buffer to upper layers */
 
1759                         skb = sis_priv->rx_skbuff[entry];
 
1760                         skb_put(skb, rx_size);
 
1761                         skb->protocol = eth_type_trans(skb, net_dev);
 
1764                         /* some network statistics */
 
1765                         if ((rx_status & BCAST) == MCAST)
 
1766                                 sis_priv->stats.multicast++;
 
1767                         net_dev->last_rx = jiffies;
 
1768                         sis_priv->stats.rx_bytes += rx_size;
 
1769                         sis_priv->stats.rx_packets++;
 
1771                         /* refill the Rx buffer, what if there is not enought
 
1772                          * memory for new socket buffer ?? */
 
1773                         if ((skb = dev_alloc_skb(RX_BUF_SIZE)) == NULL) {
 
1774                                 /* not enough memory for skbuff, this makes a
 
1775                                  * "hole" on the buffer ring, it is not clear
 
1776                                  * how the hardware will react to this kind
 
1777                                  * of degenerated buffer */
 
1778                                 if (netif_msg_rx_status(sis_priv))
 
1779                                         printk(KERN_INFO "%s: Memory squeeze,"
 
1780                                                 "deferring packet.\n",
 
1782                                 sis_priv->rx_skbuff[entry] = NULL;
 
1783                                 /* reset buffer descriptor state */
 
1784                                 sis_priv->rx_ring[entry].cmdsts = 0;
 
1785                                 sis_priv->rx_ring[entry].bufptr = 0;
 
1786                                 sis_priv->stats.rx_dropped++;
 
1791                         sis_priv->rx_skbuff[entry] = skb;
 
1792                         sis_priv->rx_ring[entry].cmdsts = RX_BUF_SIZE;
 
1793                         sis_priv->rx_ring[entry].bufptr = 
 
1794                                 pci_map_single(sis_priv->pci_dev, skb->data, 
 
1795                                         RX_BUF_SIZE, PCI_DMA_FROMDEVICE);
 
1796                         sis_priv->dirty_rx++;
 
1799                 entry = sis_priv->cur_rx % NUM_RX_DESC;
 
1800                 rx_status = sis_priv->rx_ring[entry].cmdsts;
 
1803         /* refill the Rx buffer, what if the rate of refilling is slower
 
1804          * than consuming ?? */
 
1805         for (; sis_priv->cur_rx != sis_priv->dirty_rx; sis_priv->dirty_rx++) {
 
1806                 struct sk_buff *skb;
 
1808                 entry = sis_priv->dirty_rx % NUM_RX_DESC;
 
1810                 if (sis_priv->rx_skbuff[entry] == NULL) {
 
1811                         if ((skb = dev_alloc_skb(RX_BUF_SIZE)) == NULL) {
 
1812                                 /* not enough memory for skbuff, this makes a
 
1813                                  * "hole" on the buffer ring, it is not clear
 
1814                                  * how the hardware will react to this kind
 
1815                                  * of degenerated buffer */
 
1816                                 if (netif_msg_rx_err(sis_priv))
 
1817                                         printk(KERN_INFO "%s: Memory squeeze,"
 
1818                                                 "deferring packet.\n",
 
1820                                 sis_priv->stats.rx_dropped++;
 
1824                         sis_priv->rx_skbuff[entry] = skb;
 
1825                         sis_priv->rx_ring[entry].cmdsts = RX_BUF_SIZE;
 
1826                         sis_priv->rx_ring[entry].bufptr =
 
1827                                 pci_map_single(sis_priv->pci_dev, skb->data,
 
1828                                         RX_BUF_SIZE, PCI_DMA_FROMDEVICE);
 
1831         /* re-enable the potentially idle receive state matchine */
 
1832         outl(RxENA | inl(ioaddr + cr), ioaddr + cr );
 
1838  *      sis900_finish_xmit - finish up transmission of packets
 
1839  *      @net_dev: the net device to be transmitted on
 
1841  *      Check for error condition and free socket buffer etc 
 
1842  *      schedule for more transmission as needed
 
1843  *      Note: This function is called by interrupt handler,
 
1844  *      don't do "too much" work here
 
1847 static void sis900_finish_xmit (struct net_device *net_dev)
 
1849         struct sis900_private *sis_priv = net_dev->priv;
 
1851         for (; sis_priv->dirty_tx != sis_priv->cur_tx; sis_priv->dirty_tx++) {
 
1852                 struct sk_buff *skb;
 
1856                 entry = sis_priv->dirty_tx % NUM_TX_DESC;
 
1857                 tx_status = sis_priv->tx_ring[entry].cmdsts;
 
1859                 if (tx_status & OWN) {
 
1860                         /* The packet is not transmitted yet (owned by hardware) !
 
1861                          * Note: the interrupt is generated only when Tx Machine
 
1862                          * is idle, so this is an almost impossible case */
 
1866                 if (tx_status & (ABORT | UNDERRUN | OWCOLL)) {
 
1867                         /* packet unsuccessfully transmitted */
 
1868                         if (netif_msg_tx_err(sis_priv))
 
1869                                 printk(KERN_DEBUG "%s: Transmit "
 
1870                                        "error, Tx status %8.8x.\n",
 
1871                                        net_dev->name, tx_status);
 
1872                         sis_priv->stats.tx_errors++;
 
1873                         if (tx_status & UNDERRUN)
 
1874                                 sis_priv->stats.tx_fifo_errors++;
 
1875                         if (tx_status & ABORT)
 
1876                                 sis_priv->stats.tx_aborted_errors++;
 
1877                         if (tx_status & NOCARRIER)
 
1878                                 sis_priv->stats.tx_carrier_errors++;
 
1879                         if (tx_status & OWCOLL)
 
1880                                 sis_priv->stats.tx_window_errors++;
 
1882                         /* packet successfully transmitted */
 
1883                         sis_priv->stats.collisions += (tx_status & COLCNT) >> 16;
 
1884                         sis_priv->stats.tx_bytes += tx_status & DSIZE;
 
1885                         sis_priv->stats.tx_packets++;
 
1887                 /* Free the original skb. */
 
1888                 skb = sis_priv->tx_skbuff[entry];
 
1889                 pci_unmap_single(sis_priv->pci_dev, 
 
1890                         sis_priv->tx_ring[entry].bufptr, skb->len,
 
1892                 dev_kfree_skb_irq(skb);
 
1893                 sis_priv->tx_skbuff[entry] = NULL;
 
1894                 sis_priv->tx_ring[entry].bufptr = 0;
 
1895                 sis_priv->tx_ring[entry].cmdsts = 0;
 
1898         if (sis_priv->tx_full && netif_queue_stopped(net_dev) &&
 
1899             sis_priv->cur_tx - sis_priv->dirty_tx < NUM_TX_DESC - 4) {
 
1900                 /* The ring is no longer full, clear tx_full and schedule
 
1901                  * more transmission by netif_wake_queue(net_dev) */
 
1902                 sis_priv->tx_full = 0;
 
1903                 netif_wake_queue (net_dev);
 
1908  *      sis900_close - close sis900 device 
 
1909  *      @net_dev: the net device to be closed
 
1911  *      Disable interrupts, stop the Tx and Rx Status Machine 
 
1912  *      free Tx and RX socket buffer
 
1915 static int sis900_close(struct net_device *net_dev)
 
1917         long ioaddr = net_dev->base_addr;
 
1918         struct sis900_private *sis_priv = net_dev->priv;
 
1919         struct sk_buff *skb;
 
1922         netif_stop_queue(net_dev);
 
1924         /* Disable interrupts by clearing the interrupt mask. */
 
1925         outl(0x0000, ioaddr + imr);
 
1926         outl(0x0000, ioaddr + ier);
 
1928         /* Stop the chip's Tx and Rx Status Machine */
 
1929         outl(RxDIS | TxDIS | inl(ioaddr + cr), ioaddr + cr);
 
1931         del_timer(&sis_priv->timer);
 
1933         free_irq(net_dev->irq, net_dev);
 
1935         /* Free Tx and RX skbuff */
 
1936         for (i = 0; i < NUM_RX_DESC; i++) {
 
1937                 skb = sis_priv->rx_skbuff[i];
 
1939                         pci_unmap_single(sis_priv->pci_dev, 
 
1940                                 sis_priv->rx_ring[i].bufptr,
 
1941                                 RX_BUF_SIZE, PCI_DMA_FROMDEVICE);
 
1943                         sis_priv->rx_skbuff[i] = NULL;
 
1946         for (i = 0; i < NUM_TX_DESC; i++) {
 
1947                 skb = sis_priv->tx_skbuff[i];
 
1949                         pci_unmap_single(sis_priv->pci_dev, 
 
1950                                 sis_priv->tx_ring[i].bufptr, skb->len,
 
1953                         sis_priv->tx_skbuff[i] = NULL;
 
1957         /* Green! Put the chip in low-power mode. */
 
1963  *      sis900_get_drvinfo - Return information about driver
 
1964  *      @net_dev: the net device to probe
 
1965  *      @info: container for info returned
 
1967  *      Process ethtool command such as "ehtool -i" to show information
 
1970 static void sis900_get_drvinfo(struct net_device *net_dev,
 
1971                                struct ethtool_drvinfo *info)
 
1973         struct sis900_private *sis_priv = net_dev->priv;
 
1975         strcpy (info->driver, SIS900_MODULE_NAME);
 
1976         strcpy (info->version, SIS900_DRV_VERSION);
 
1977         strcpy (info->bus_info, pci_name(sis_priv->pci_dev));
 
1980 static u32 sis900_get_msglevel(struct net_device *net_dev)
 
1982         struct sis900_private *sis_priv = net_dev->priv;
 
1983         return sis_priv->msg_enable;
 
1986 static void sis900_set_msglevel(struct net_device *net_dev, u32 value)
 
1988         struct sis900_private *sis_priv = net_dev->priv;
 
1989         sis_priv->msg_enable = value;
 
1992 static u32 sis900_get_link(struct net_device *net_dev)
 
1994         struct sis900_private *sis_priv = net_dev->priv;
 
1995         return mii_link_ok(&sis_priv->mii_info);
 
1998 static int sis900_get_settings(struct net_device *net_dev,
 
1999                                 struct ethtool_cmd *cmd)
 
2001         struct sis900_private *sis_priv = net_dev->priv;
 
2002         spin_lock_irq(&sis_priv->lock);
 
2003         mii_ethtool_gset(&sis_priv->mii_info, cmd);
 
2004         spin_unlock_irq(&sis_priv->lock);
 
2008 static int sis900_set_settings(struct net_device *net_dev,
 
2009                                 struct ethtool_cmd *cmd)
 
2011         struct sis900_private *sis_priv = net_dev->priv;
 
2013         spin_lock_irq(&sis_priv->lock);
 
2014         rt = mii_ethtool_sset(&sis_priv->mii_info, cmd);
 
2015         spin_unlock_irq(&sis_priv->lock);
 
2019 static int sis900_nway_reset(struct net_device *net_dev)
 
2021         struct sis900_private *sis_priv = net_dev->priv;
 
2022         return mii_nway_restart(&sis_priv->mii_info);
 
2026  *      sis900_set_wol - Set up Wake on Lan registers
 
2027  *      @net_dev: the net device to probe
 
2028  *      @wol: container for info passed to the driver
 
2030  *      Process ethtool command "wol" to setup wake on lan features.
 
2031  *      SiS900 supports sending WoL events if a correct packet is received,
 
2032  *      but there is no simple way to filter them to only a subset (broadcast,
 
2033  *      multicast, unicast or arp).
 
2036 static int sis900_set_wol(struct net_device *net_dev, struct ethtool_wolinfo *wol)
 
2038         struct sis900_private *sis_priv = net_dev->priv;
 
2039         long pmctrl_addr = net_dev->base_addr + pmctrl;
 
2040         u32 cfgpmcsr = 0, pmctrl_bits = 0;
 
2042         if (wol->wolopts == 0) {
 
2043                 pci_read_config_dword(sis_priv->pci_dev, CFGPMCSR, &cfgpmcsr);
 
2044                 cfgpmcsr &= ~PME_EN;
 
2045                 pci_write_config_dword(sis_priv->pci_dev, CFGPMCSR, cfgpmcsr);
 
2046                 outl(pmctrl_bits, pmctrl_addr);
 
2047                 if (netif_msg_wol(sis_priv))
 
2048                         printk(KERN_DEBUG "%s: Wake on LAN disabled\n", net_dev->name);
 
2052         if (wol->wolopts & (WAKE_MAGICSECURE | WAKE_UCAST | WAKE_MCAST
 
2053                                 | WAKE_BCAST | WAKE_ARP))
 
2056         if (wol->wolopts & WAKE_MAGIC)
 
2057                 pmctrl_bits |= MAGICPKT;
 
2058         if (wol->wolopts & WAKE_PHY)
 
2059                 pmctrl_bits |= LINKON;
 
2061         outl(pmctrl_bits, pmctrl_addr);
 
2063         pci_read_config_dword(sis_priv->pci_dev, CFGPMCSR, &cfgpmcsr);
 
2065         pci_write_config_dword(sis_priv->pci_dev, CFGPMCSR, cfgpmcsr);
 
2066         if (netif_msg_wol(sis_priv))
 
2067                 printk(KERN_DEBUG "%s: Wake on LAN enabled\n", net_dev->name);
 
2072 static void sis900_get_wol(struct net_device *net_dev, struct ethtool_wolinfo *wol)
 
2074         long pmctrl_addr = net_dev->base_addr + pmctrl;
 
2077         pmctrl_bits = inl(pmctrl_addr);
 
2078         if (pmctrl_bits & MAGICPKT)
 
2079                 wol->wolopts |= WAKE_MAGIC;
 
2080         if (pmctrl_bits & LINKON)
 
2081                 wol->wolopts |= WAKE_PHY;
 
2083         wol->supported = (WAKE_PHY | WAKE_MAGIC);
 
2086 static struct ethtool_ops sis900_ethtool_ops = {
 
2087         .get_drvinfo    = sis900_get_drvinfo,
 
2088         .get_msglevel   = sis900_get_msglevel,
 
2089         .set_msglevel   = sis900_set_msglevel,
 
2090         .get_link       = sis900_get_link,
 
2091         .get_settings   = sis900_get_settings,
 
2092         .set_settings   = sis900_set_settings,
 
2093         .nway_reset     = sis900_nway_reset,
 
2094         .get_wol        = sis900_get_wol,
 
2095         .set_wol        = sis900_set_wol
 
2099  *      mii_ioctl - process MII i/o control command 
 
2100  *      @net_dev: the net device to command for
 
2101  *      @rq: parameter for command
 
2102  *      @cmd: the i/o command
 
2104  *      Process MII command like read/write MII register
 
2107 static int mii_ioctl(struct net_device *net_dev, struct ifreq *rq, int cmd)
 
2109         struct sis900_private *sis_priv = net_dev->priv;
 
2110         struct mii_ioctl_data *data = if_mii(rq);
 
2113         case SIOCGMIIPHY:               /* Get address of MII PHY in use. */
 
2114                 data->phy_id = sis_priv->mii->phy_addr;
 
2117         case SIOCGMIIREG:               /* Read MII PHY register. */
 
2118                 data->val_out = mdio_read(net_dev, data->phy_id & 0x1f, data->reg_num & 0x1f);
 
2121         case SIOCSMIIREG:               /* Write MII PHY register. */
 
2122                 if (!capable(CAP_NET_ADMIN))
 
2124                 mdio_write(net_dev, data->phy_id & 0x1f, data->reg_num & 0x1f, data->val_in);
 
2132  *      sis900_get_stats - Get sis900 read/write statistics 
 
2133  *      @net_dev: the net device to get statistics for
 
2135  *      get tx/rx statistics for sis900
 
2138 static struct net_device_stats *
 
2139 sis900_get_stats(struct net_device *net_dev)
 
2141         struct sis900_private *sis_priv = net_dev->priv;
 
2143         return &sis_priv->stats;
 
2147  *      sis900_set_config - Set media type by net_device.set_config 
 
2148  *      @dev: the net device for media type change
 
2149  *      @map: ifmap passed by ifconfig
 
2151  *      Set media type to 10baseT, 100baseT or 0(for auto) by ifconfig
 
2152  *      we support only port changes. All other runtime configuration
 
2153  *      changes will be ignored
 
2156 static int sis900_set_config(struct net_device *dev, struct ifmap *map)
 
2158         struct sis900_private *sis_priv = dev->priv;
 
2159         struct mii_phy *mii_phy = sis_priv->mii;
 
2163         if ((map->port != (u_char)(-1)) && (map->port != dev->if_port)) {
 
2164                 /* we switch on the ifmap->port field. I couldn't find anything
 
2165                  * like a definition or standard for the values of that field.
 
2166                  * I think the meaning of those values is device specific. But
 
2167                  * since I would like to change the media type via the ifconfig
 
2168                  * command I use the definition from linux/netdevice.h 
 
2169                  * (which seems to be different from the ifport(pcmcia) definition) */
 
2171                 case IF_PORT_UNKNOWN: /* use auto here */   
 
2172                         dev->if_port = map->port;
 
2173                         /* we are going to change the media type, so the Link
 
2174                          * will be temporary down and we need to reflect that
 
2175                          * here. When the Link comes up again, it will be
 
2176                          * sensed by the sis_timer procedure, which also does
 
2177                          * all the rest for us */
 
2178                         netif_carrier_off(dev);
 
2180                         /* read current state */
 
2181                         status = mdio_read(dev, mii_phy->phy_addr, MII_CONTROL);
 
2183                         /* enable auto negotiation and reset the negotioation
 
2184                          * (I don't really know what the auto negatiotiation
 
2185                          * reset really means, but it sounds for me right to
 
2187                         mdio_write(dev, mii_phy->phy_addr,
 
2188                                    MII_CONTROL, status | MII_CNTL_AUTO | MII_CNTL_RST_AUTO);
 
2192                 case IF_PORT_10BASET: /* 10BaseT */         
 
2193                         dev->if_port = map->port;
 
2195                         /* we are going to change the media type, so the Link
 
2196                          * will be temporary down and we need to reflect that
 
2197                          * here. When the Link comes up again, it will be
 
2198                          * sensed by the sis_timer procedure, which also does
 
2199                          * all the rest for us */
 
2200                         netif_carrier_off(dev);
 
2202                         /* set Speed to 10Mbps */
 
2203                         /* read current state */
 
2204                         status = mdio_read(dev, mii_phy->phy_addr, MII_CONTROL);
 
2206                         /* disable auto negotiation and force 10MBit mode*/
 
2207                         mdio_write(dev, mii_phy->phy_addr,
 
2208                                    MII_CONTROL, status & ~(MII_CNTL_SPEED |
 
2212                 case IF_PORT_100BASET: /* 100BaseT */
 
2213                 case IF_PORT_100BASETX: /* 100BaseTx */ 
 
2214                         dev->if_port = map->port;
 
2216                         /* we are going to change the media type, so the Link
 
2217                          * will be temporary down and we need to reflect that
 
2218                          * here. When the Link comes up again, it will be
 
2219                          * sensed by the sis_timer procedure, which also does
 
2220                          * all the rest for us */
 
2221                         netif_carrier_off(dev);
 
2223                         /* set Speed to 100Mbps */
 
2224                         /* disable auto negotiation and enable 100MBit Mode */
 
2225                         status = mdio_read(dev, mii_phy->phy_addr, MII_CONTROL);
 
2226                         mdio_write(dev, mii_phy->phy_addr,
 
2227                                    MII_CONTROL, (status & ~MII_CNTL_SPEED) |
 
2232                 case IF_PORT_10BASE2: /* 10Base2 */
 
2233                 case IF_PORT_AUI: /* AUI */
 
2234                 case IF_PORT_100BASEFX: /* 100BaseFx */
 
2235                         /* These Modes are not supported (are they?)*/
 
2247  *      sis900_mcast_bitnr - compute hashtable index 
 
2248  *      @addr: multicast address
 
2249  *      @revision: revision id of chip
 
2251  *      SiS 900 uses the most sigificant 7 bits to index a 128 bits multicast
 
2252  *      hash table, which makes this function a little bit different from other drivers
 
2253  *      SiS 900 B0 & 635 M/B uses the most significat 8 bits to index 256 bits
 
2254  *      multicast hash table. 
 
2257 static inline u16 sis900_mcast_bitnr(u8 *addr, u8 revision)
 
2260         u32 crc = ether_crc(6, addr);
 
2262         /* leave 8 or 7 most siginifant bits */
 
2263         if ((revision >= SIS635A_900_REV) || (revision == SIS900B_900_REV))
 
2264                 return ((int)(crc >> 24));
 
2266                 return ((int)(crc >> 25));
 
2270  *      set_rx_mode - Set SiS900 receive mode 
 
2271  *      @net_dev: the net device to be set
 
2273  *      Set SiS900 receive mode for promiscuous, multicast, or broadcast mode.
 
2274  *      And set the appropriate multicast filter.
 
2275  *      Multicast hash table changes from 128 to 256 bits for 635M/B & 900B0.
 
2278 static void set_rx_mode(struct net_device *net_dev)
 
2280         long ioaddr = net_dev->base_addr;
 
2281         struct sis900_private * sis_priv = net_dev->priv;
 
2282         u16 mc_filter[16] = {0};        /* 256/128 bits multicast hash table */
 
2283         int i, table_entries;
 
2286         /* 635 Hash Table entries = 256(2^16) */
 
2287         if((sis_priv->chipset_rev >= SIS635A_900_REV) ||
 
2288                         (sis_priv->chipset_rev == SIS900B_900_REV))
 
2293         if (net_dev->flags & IFF_PROMISC) {
 
2294                 /* Accept any kinds of packets */
 
2295                 rx_mode = RFPromiscuous;
 
2296                 for (i = 0; i < table_entries; i++)
 
2297                         mc_filter[i] = 0xffff;
 
2298         } else if ((net_dev->mc_count > multicast_filter_limit) ||
 
2299                    (net_dev->flags & IFF_ALLMULTI)) {
 
2300                 /* too many multicast addresses or accept all multicast packet */
 
2301                 rx_mode = RFAAB | RFAAM;
 
2302                 for (i = 0; i < table_entries; i++)
 
2303                         mc_filter[i] = 0xffff;
 
2305                 /* Accept Broadcast packet, destination address matchs our
 
2306                  * MAC address, use Receive Filter to reject unwanted MCAST
 
2308                 struct dev_mc_list *mclist;
 
2310                 for (i = 0, mclist = net_dev->mc_list;
 
2311                         mclist && i < net_dev->mc_count;
 
2312                         i++, mclist = mclist->next) {
 
2313                         unsigned int bit_nr =
 
2314                                 sis900_mcast_bitnr(mclist->dmi_addr, sis_priv->chipset_rev);
 
2315                         mc_filter[bit_nr >> 4] |= (1 << (bit_nr & 0xf));
 
2319         /* update Multicast Hash Table in Receive Filter */
 
2320         for (i = 0; i < table_entries; i++) {
 
2321                 /* why plus 0x04 ??, That makes the correct value for hash table. */
 
2322                 outl((u32)(0x00000004+i) << RFADDR_shift, ioaddr + rfcr);
 
2323                 outl(mc_filter[i], ioaddr + rfdr);
 
2326         outl(RFEN | rx_mode, ioaddr + rfcr);
 
2328         /* sis900 is capable of looping back packets at MAC level for
 
2329          * debugging purpose */
 
2330         if (net_dev->flags & IFF_LOOPBACK) {
 
2332                 /* We must disable Tx/Rx before setting loopback mode */
 
2333                 cr_saved = inl(ioaddr + cr);
 
2334                 outl(cr_saved | TxDIS | RxDIS, ioaddr + cr);
 
2335                 /* enable loopback */
 
2336                 outl(inl(ioaddr + txcfg) | TxMLB, ioaddr + txcfg);
 
2337                 outl(inl(ioaddr + rxcfg) | RxATX, ioaddr + rxcfg);
 
2339                 outl(cr_saved, ioaddr + cr);
 
2346  *      sis900_reset - Reset sis900 MAC 
 
2347  *      @net_dev: the net device to reset
 
2349  *      reset sis900 MAC and wait until finished
 
2350  *      reset through command register
 
2351  *      change backoff algorithm for 900B0 & 635 M/B
 
2354 static void sis900_reset(struct net_device *net_dev)
 
2356         struct sis900_private * sis_priv = net_dev->priv;
 
2357         long ioaddr = net_dev->base_addr;
 
2359         u32 status = TxRCMP | RxRCMP;
 
2361         outl(0, ioaddr + ier);
 
2362         outl(0, ioaddr + imr);
 
2363         outl(0, ioaddr + rfcr);
 
2365         outl(RxRESET | TxRESET | RESET | inl(ioaddr + cr), ioaddr + cr);
 
2367         /* Check that the chip has finished the reset. */
 
2368         while (status && (i++ < 1000)) {
 
2369                 status ^= (inl(isr + ioaddr) & status);
 
2372         if( (sis_priv->chipset_rev >= SIS635A_900_REV) ||
 
2373                         (sis_priv->chipset_rev == SIS900B_900_REV) )
 
2374                 outl(PESEL | RND_CNT, ioaddr + cfg);
 
2376                 outl(PESEL, ioaddr + cfg);
 
2380  *      sis900_remove - Remove sis900 device 
 
2381  *      @pci_dev: the pci device to be removed
 
2383  *      remove and release SiS900 net device
 
2386 static void __devexit sis900_remove(struct pci_dev *pci_dev)
 
2388         struct net_device *net_dev = pci_get_drvdata(pci_dev);
 
2389         struct sis900_private * sis_priv = net_dev->priv;
 
2390         struct mii_phy *phy = NULL;
 
2392         while (sis_priv->first_mii) {
 
2393                 phy = sis_priv->first_mii;
 
2394                 sis_priv->first_mii = phy->next;
 
2398         pci_free_consistent(pci_dev, RX_TOTAL_SIZE, sis_priv->rx_ring,
 
2399                 sis_priv->rx_ring_dma);
 
2400         pci_free_consistent(pci_dev, TX_TOTAL_SIZE, sis_priv->tx_ring,
 
2401                 sis_priv->tx_ring_dma);
 
2402         unregister_netdev(net_dev);
 
2403         free_netdev(net_dev);
 
2404         pci_release_regions(pci_dev);
 
2405         pci_set_drvdata(pci_dev, NULL);
 
2410 static int sis900_suspend(struct pci_dev *pci_dev, pm_message_t state)
 
2412         struct net_device *net_dev = pci_get_drvdata(pci_dev);
 
2413         long ioaddr = net_dev->base_addr;
 
2415         if(!netif_running(net_dev))
 
2418         netif_stop_queue(net_dev);
 
2419         netif_device_detach(net_dev);
 
2421         /* Stop the chip's Tx and Rx Status Machine */
 
2422         outl(RxDIS | TxDIS | inl(ioaddr + cr), ioaddr + cr);
 
2424         pci_set_power_state(pci_dev, PCI_D3hot);
 
2425         pci_save_state(pci_dev);
 
2430 static int sis900_resume(struct pci_dev *pci_dev)
 
2432         struct net_device *net_dev = pci_get_drvdata(pci_dev);
 
2433         struct sis900_private *sis_priv = net_dev->priv;
 
2434         long ioaddr = net_dev->base_addr;
 
2436         if(!netif_running(net_dev))
 
2438         pci_restore_state(pci_dev);
 
2439         pci_set_power_state(pci_dev, PCI_D0);
 
2441         sis900_init_rxfilter(net_dev);
 
2443         sis900_init_tx_ring(net_dev);
 
2444         sis900_init_rx_ring(net_dev);
 
2446         set_rx_mode(net_dev);
 
2448         netif_device_attach(net_dev);
 
2449         netif_start_queue(net_dev);
 
2451         /* Workaround for EDB */
 
2452         sis900_set_mode(ioaddr, HW_SPEED_10_MBPS, FDX_CAPABLE_HALF_SELECTED);
 
2454         /* Enable all known interrupts by setting the interrupt mask. */
 
2455         outl((RxSOVR|RxORN|RxERR|RxOK|TxURN|TxERR|TxIDLE), ioaddr + imr);
 
2456         outl(RxENA | inl(ioaddr + cr), ioaddr + cr);
 
2457         outl(IE, ioaddr + ier);
 
2459         sis900_check_mode(net_dev, sis_priv->mii);
 
2463 #endif /* CONFIG_PM */
 
2465 static struct pci_driver sis900_pci_driver = {
 
2466         .name           = SIS900_MODULE_NAME,
 
2467         .id_table       = sis900_pci_tbl,
 
2468         .probe          = sis900_probe,
 
2469         .remove         = __devexit_p(sis900_remove),
 
2471         .suspend        = sis900_suspend,
 
2472         .resume         = sis900_resume,
 
2473 #endif /* CONFIG_PM */
 
2476 static int __init sis900_init_module(void)
 
2478 /* when a module, this is printed whether or not devices are found in probe */
 
2483         return pci_module_init(&sis900_pci_driver);
 
2486 static void __exit sis900_cleanup_module(void)
 
2488         pci_unregister_driver(&sis900_pci_driver);
 
2491 module_init(sis900_init_module);
 
2492 module_exit(sis900_cleanup_module);