Commit 79218e71 authored by Pavel Roskin's avatar Pavel Roskin Committed by Jeff Garzik

[netdrvr pci-skeleton] refresh

Here it is.  The patch fixes all compile errors and warnings in
pci-skeleton.c.  The "debug" parameter lacks corresponding variable,
so I removed it to avoid a warning on module load.  Obsolete
pci_power_on() and pci_power_off() have been replaced with the new
code using pci_set_power_state(), pci_save_state() and
pci_restore_state().  The driver has been tested by compiling it as
module and as part of the kernel.
parent 33d7e016
...@@ -481,6 +481,7 @@ struct netdrv_private { ...@@ -481,6 +481,7 @@ struct netdrv_private {
unsigned int mediasense:1; /* Media sensing in progress. */ unsigned int mediasense:1; /* Media sensing in progress. */
spinlock_t lock; spinlock_t lock;
chip_t chipset; chip_t chipset;
u32 pci_state[16]; /* Data saved during suspend */
}; };
MODULE_AUTHOR ("Jeff Garzik <jgarzik@pobox.com>"); MODULE_AUTHOR ("Jeff Garzik <jgarzik@pobox.com>");
...@@ -488,12 +489,10 @@ MODULE_DESCRIPTION ("Skeleton for a PCI Fast Ethernet driver"); ...@@ -488,12 +489,10 @@ MODULE_DESCRIPTION ("Skeleton for a PCI Fast Ethernet driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
MODULE_PARM (multicast_filter_limit, "i"); MODULE_PARM (multicast_filter_limit, "i");
MODULE_PARM (max_interrupt_work, "i"); MODULE_PARM (max_interrupt_work, "i");
MODULE_PARM (debug, "i");
MODULE_PARM (media, "1-" __MODULE_STRING(8) "i"); MODULE_PARM (media, "1-" __MODULE_STRING(8) "i");
MODULE_PARM_DESC (multicast_filter_limit, "pci-skeleton maximum number of filtered multicast addresses"); MODULE_PARM_DESC (multicast_filter_limit, "pci-skeleton maximum number of filtered multicast addresses");
MODULE_PARM_DESC (max_interrupt_work, "pci-skeleton maximum events handled per interrupt"); MODULE_PARM_DESC (max_interrupt_work, "pci-skeleton maximum events handled per interrupt");
MODULE_PARM_DESC (media, "pci-skeleton: Bits 0-3: media type, bit 17: full duplex"); MODULE_PARM_DESC (media, "pci-skeleton: Bits 0-3: media type, bit 17: full duplex");
MODULE_PARM_DESC (debug, "(unused)");
static int read_eeprom (void *ioaddr, int location, int addr_len); static int read_eeprom (void *ioaddr, int location, int addr_len);
static int netdrv_open (struct net_device *dev); static int netdrv_open (struct net_device *dev);
...@@ -588,7 +587,6 @@ static int __devinit netdrv_init_board (struct pci_dev *pdev, ...@@ -588,7 +587,6 @@ static int __devinit netdrv_init_board (struct pci_dev *pdev,
void *ioaddr = NULL; void *ioaddr = NULL;
struct net_device *dev; struct net_device *dev;
struct netdrv_private *tp; struct netdrv_private *tp;
u8 tmp8;
int rc, i; int rc, i;
u32 pio_start, pio_end, pio_flags, pio_len; u32 pio_start, pio_end, pio_flags, pio_len;
unsigned long mmio_start, mmio_end, mmio_flags, mmio_len; unsigned long mmio_start, mmio_end, mmio_flags, mmio_len;
...@@ -744,7 +742,6 @@ static int __devinit netdrv_init_one (struct pci_dev *pdev, ...@@ -744,7 +742,6 @@ static int __devinit netdrv_init_one (struct pci_dev *pdev,
int i, addr_len, option; int i, addr_len, option;
void *ioaddr = NULL; void *ioaddr = NULL;
static int board_idx = -1; static int board_idx = -1;
u8 tmp;
/* when built into the kernel, we only print version if device is found */ /* when built into the kernel, we only print version if device is found */
#ifndef MODULE #ifndef MODULE
...@@ -868,7 +865,7 @@ static void __devexit netdrv_remove_one (struct pci_dev *pdev) ...@@ -868,7 +865,7 @@ static void __devexit netdrv_remove_one (struct pci_dev *pdev)
pci_set_drvdata (pdev, NULL); pci_set_drvdata (pdev, NULL);
pci_power_off (pdev, -1); pci_disable_device (pdev);
DPRINTK ("EXIT\n"); DPRINTK ("EXIT\n");
} }
...@@ -1136,7 +1133,6 @@ static void netdrv_hw_start (struct net_device *dev) ...@@ -1136,7 +1133,6 @@ static void netdrv_hw_start (struct net_device *dev)
struct netdrv_private *tp = dev->priv; struct netdrv_private *tp = dev->priv;
void *ioaddr = tp->mmio_addr; void *ioaddr = tp->mmio_addr;
u32 i; u32 i;
u8 tmp;
DPRINTK ("ENTER\n"); DPRINTK ("ENTER\n");
...@@ -1875,9 +1871,11 @@ static void netdrv_set_rx_mode (struct net_device *dev) ...@@ -1875,9 +1871,11 @@ static void netdrv_set_rx_mode (struct net_device *dev)
rx_mode = AcceptBroadcast | AcceptMulticast | AcceptMyPhys; rx_mode = AcceptBroadcast | AcceptMulticast | AcceptMyPhys;
mc_filter[1] = mc_filter[0] = 0; mc_filter[1] = mc_filter[0] = 0;
for (i = 0, mclist = dev->mc_list; mclist && i < dev->mc_count; for (i = 0, mclist = dev->mc_list; mclist && i < dev->mc_count;
i++, mclist = mclist->next) i++, mclist = mclist->next) {
set_bit (ether_crc (ETH_ALEN, mclist->dmi_addr) >> 26, int bit_nr = ether_crc(ETH_ALEN, mclist->dmi_addr) >> 26;
mc_filter);
mc_filter[bit_nr >> 5] |= 1 << (bit_nr & 31);
}
} }
/* if called from irq handler, lock already acquired */ /* if called from irq handler, lock already acquired */
...@@ -1908,7 +1906,7 @@ static int netdrv_suspend (struct pci_dev *pdev, u32 state) ...@@ -1908,7 +1906,7 @@ static int netdrv_suspend (struct pci_dev *pdev, u32 state)
unsigned long flags; unsigned long flags;
if (!netif_running(dev)) if (!netif_running(dev))
return; return 0;
netif_device_detach (dev); netif_device_detach (dev);
spin_lock_irqsave (&tp->lock, flags); spin_lock_irqsave (&tp->lock, flags);
...@@ -1923,7 +1921,8 @@ static int netdrv_suspend (struct pci_dev *pdev, u32 state) ...@@ -1923,7 +1921,8 @@ static int netdrv_suspend (struct pci_dev *pdev, u32 state)
spin_unlock_irqrestore (&tp->lock, flags); spin_unlock_irqrestore (&tp->lock, flags);
pci_power_off (pdev, -1); pci_save_state (pdev, tp->pci_state);
pci_set_power_state (pdev, 3);
return 0; return 0;
} }
...@@ -1932,10 +1931,12 @@ static int netdrv_suspend (struct pci_dev *pdev, u32 state) ...@@ -1932,10 +1931,12 @@ static int netdrv_suspend (struct pci_dev *pdev, u32 state)
static int netdrv_resume (struct pci_dev *pdev) static int netdrv_resume (struct pci_dev *pdev)
{ {
struct net_device *dev = pci_get_drvdata (pdev); struct net_device *dev = pci_get_drvdata (pdev);
struct netdrv_private *tp = dev->priv;
if (!netif_running(dev)) if (!netif_running(dev))
return; return 0;
pci_power_on (pdev); pci_set_power_state (pdev, 0);
pci_restore_state (pdev, tp->pci_state);
netif_device_attach (dev); netif_device_attach (dev);
netdrv_hw_start (dev); netdrv_hw_start (dev);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment