Commit 5417f5ea authored by Marc Zyngier's avatar Marc Zyngier Committed by Linus Torvalds

EISA sysfs updates to 3c509 and 3c59x drivers

parent 1416b996
...@@ -53,11 +53,13 @@ ...@@ -53,11 +53,13 @@
- Additional ethtool features - Additional ethtool features
v1.19a 28Oct2002 Davud Ruggiero <jdr@farfalle.com> v1.19a 28Oct2002 Davud Ruggiero <jdr@farfalle.com>
- Increase *read_eeprom udelay to workaround oops with 2 cards. - Increase *read_eeprom udelay to workaround oops with 2 cards.
v1.19b 08Nov2002 Marc Zyngier <maz@wild-wind.fr.eu.org>
- Introduce driver model for EISA cards.
*/ */
#define DRV_NAME "3c509" #define DRV_NAME "3c509"
#define DRV_VERSION "1.19a" #define DRV_VERSION "1.19b"
#define DRV_RELDATE "28Oct2002" #define DRV_RELDATE "08Nov2002"
/* A few values that may be tweaked. */ /* A few values that may be tweaked. */
...@@ -84,6 +86,8 @@ static int max_interrupt_work = 10; ...@@ -84,6 +86,8 @@ static int max_interrupt_work = 10;
#include <linux/delay.h> /* for udelay() */ #include <linux/delay.h> /* for udelay() */
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/ethtool.h> #include <linux/ethtool.h>
#include <linux/device.h>
#include <linux/eisa.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#include <asm/bitops.h> #include <asm/bitops.h>
...@@ -170,6 +174,9 @@ struct el3_private { ...@@ -170,6 +174,9 @@ struct el3_private {
#ifdef __ISAPNP__ #ifdef __ISAPNP__
struct pnp_dev *pnpdev; struct pnp_dev *pnpdev;
#endif #endif
#ifdef CONFIG_EISA
struct eisa_device *edev;
#endif
}; };
static int id_port __initdata = 0x110; /* Start with 0x110 to avoid new sound cards.*/ static int id_port __initdata = 0x110; /* Start with 0x110 to avoid new sound cards.*/
static struct net_device *el3_root_dev; static struct net_device *el3_root_dev;
...@@ -194,6 +201,26 @@ static int el3_resume(struct pm_dev *pdev); ...@@ -194,6 +201,26 @@ static int el3_resume(struct pm_dev *pdev);
static int el3_pm_callback(struct pm_dev *pdev, pm_request_t rqst, void *data); static int el3_pm_callback(struct pm_dev *pdev, pm_request_t rqst, void *data);
#endif #endif
#ifdef CONFIG_EISA
struct eisa_device_id el3_eisa_ids[] = {
{ "TCM5092" },
{ "TCM5093" },
{ "" }
};
static int el3_eisa_probe (struct device *device);
static int el3_eisa_remove (struct device *device);
struct eisa_driver el3_eisa_driver = {
.id_table = el3_eisa_ids,
.driver = {
.name = "3c509",
.probe = el3_eisa_probe,
.remove = __devexit_p (el3_eisa_remove)
}
};
#endif
#ifdef CONFIG_MCA #ifdef CONFIG_MCA
struct el3_mca_adapters_struct { struct el3_mca_adapters_struct {
char* name; char* name;
...@@ -240,8 +267,97 @@ static u16 el3_isapnp_phys_addr[8][3]; ...@@ -240,8 +267,97 @@ static u16 el3_isapnp_phys_addr[8][3];
#endif /* __ISAPNP__ */ #endif /* __ISAPNP__ */
static int nopnp; static int nopnp;
int __init el3_probe(struct net_device *dev, int card_idx) /* With the driver model introduction for EISA devices, both init
* and cleanup have been split :
* - EISA devices probe/remove starts in el3_eisa_probe/el3_eisa_remove
* - MCA/ISA still use el3_probe
*
* Both call el3_common_init/el3_common_remove. */
static int __init el3_common_init (struct net_device *dev)
{
struct el3_private *lp = dev->priv;
short i;
#ifdef CONFIG_EISA
if (!lp->edev) /* EISA devices are not chained */
#endif
{
lp->next_dev = el3_root_dev;
el3_root_dev = dev;
}
spin_lock_init(&lp->lock);
if (dev->mem_start & 0x05) { /* xcvr codes 1/3/4/12 */
dev->if_port = (dev->mem_start & 0x0f);
} else { /* xcvr codes 0/8 */
/* use eeprom value, but save user's full-duplex selection */
dev->if_port |= (dev->mem_start & 0x08);
}
{
const char *if_names[] = {"10baseT", "AUI", "undefined", "BNC"};
printk("%s: 3c5x9 at %#3.3lx, %s port, address ",
dev->name, dev->base_addr, if_names[(dev->if_port & 0x03)]);
}
/* Read in the station address. */
for (i = 0; i < 6; i++)
printk(" %2.2x", dev->dev_addr[i]);
printk(", IRQ %d.\n", dev->irq);
if (el3_debug > 0)
printk(KERN_INFO "%s" KERN_INFO "%s", versionA, versionB);
/* The EL3-specific entries in the device structure. */
dev->open = &el3_open;
dev->hard_start_xmit = &el3_start_xmit;
dev->stop = &el3_close;
dev->get_stats = &el3_get_stats;
dev->set_multicast_list = &set_multicast_list;
dev->tx_timeout = el3_tx_timeout;
dev->watchdog_timeo = TX_TIMEOUT;
dev->do_ioctl = netdev_ioctl;
#ifdef CONFIG_PM
/* register power management */
lp->pmdev = pm_register(PM_ISA_DEV, card_idx, el3_pm_callback);
if (lp->pmdev) {
struct pm_dev *p;
p = lp->pmdev;
p->data = (struct net_device *)dev;
}
#endif
return 0;
}
static void el3_common_remove (struct net_device *dev)
{
struct el3_private *lp = dev->priv;
(void) lp; /* Keep gcc quiet... */
#ifdef CONFIG_MCA
if(lp->mca_slot!=-1)
mca_mark_as_unused(lp->mca_slot);
#endif
#ifdef CONFIG_PM
if (lp->pmdev)
pm_unregister(lp->pmdev);
#endif
#ifdef __ISAPNP__
if (lp->pnpdev)
pnp_device_detach(lp->pnpdev);
#endif
unregister_netdev (dev);
release_region(dev->base_addr, EL3_IO_EXTENT);
kfree (dev);
}
static int __init el3_probe(int card_idx)
{ {
struct net_device *dev;
struct el3_private *lp; struct el3_private *lp;
short lrs_state = 0xff, i; short lrs_state = 0xff, i;
int ioaddr, irq, if_port; int ioaddr, irq, if_port;
...@@ -253,44 +369,6 @@ int __init el3_probe(struct net_device *dev, int card_idx) ...@@ -253,44 +369,6 @@ int __init el3_probe(struct net_device *dev, int card_idx)
struct pnp_dev *idev = NULL; struct pnp_dev *idev = NULL;
#endif /* __ISAPNP__ */ #endif /* __ISAPNP__ */
if (dev) SET_MODULE_OWNER(dev);
/* First check all slots of the EISA bus. The next slot address to
probe is kept in 'eisa_addr' to support multiple probe() calls. */
if (EISA_bus) {
static int eisa_addr = 0x1000;
while (eisa_addr < 0x9000) {
int device_id;
ioaddr = eisa_addr;
eisa_addr += 0x1000;
/* Check the standard EISA ID register for an encoded '3Com'. */
if (inw(ioaddr + 0xC80) != 0x6d50)
continue;
/* Avoid conflict with 3c590, 3c592, 3c597, etc */
device_id = (inb(ioaddr + 0xC82)<<8) + inb(ioaddr + 0xC83);
if ((device_id & 0xFF00) == 0x5900) {
continue;
}
/* Change the register set to the configuration window 0. */
outw(SelectWindow | 0, ioaddr + 0xC80 + EL3_CMD);
irq = inw(ioaddr + WN0_IRQ) >> 12;
if_port = inw(ioaddr + 6)>>14;
for (i = 0; i < 3; i++)
phys_addr[i] = htons(read_eeprom(ioaddr, i));
/* Restore the "Product ID" to the EEPROM read register. */
read_eeprom(ioaddr, 3);
/* Was the EISA code an add-on hack? Nahhhhh... */
goto found;
}
}
#ifdef CONFIG_MCA #ifdef CONFIG_MCA
/* Based on Erik Nygren's (nygren@mit.edu) 3c529 patch, heavily /* Based on Erik Nygren's (nygren@mit.edu) 3c529 patch, heavily
* modified by Chris Beauregard (cpbeaure@csclub.uwaterloo.ca) * modified by Chris Beauregard (cpbeaure@csclub.uwaterloo.ca)
...@@ -469,6 +547,8 @@ int __init el3_probe(struct net_device *dev, int card_idx) ...@@ -469,6 +547,8 @@ int __init el3_probe(struct net_device *dev, int card_idx)
} }
irq = id_read_eeprom(9) >> 12; irq = id_read_eeprom(9) >> 12;
#if 0 /* Huh ?
Can someone explain what is this for ? */
if (dev) { /* Set passed-in IRQ or I/O Addr. */ if (dev) { /* Set passed-in IRQ or I/O Addr. */
if (dev->irq > 1 && dev->irq < 16) if (dev->irq > 1 && dev->irq < 16)
irq = dev->irq; irq = dev->irq;
...@@ -481,6 +561,7 @@ int __init el3_probe(struct net_device *dev, int card_idx) ...@@ -481,6 +561,7 @@ int __init el3_probe(struct net_device *dev, int card_idx)
return -ENODEV; return -ENODEV;
} }
} }
#endif
if (!request_region(ioaddr, EL3_IO_EXTENT, "3c509")) if (!request_region(ioaddr, EL3_IO_EXTENT, "3c509"))
return -EBUSY; return -EBUSY;
...@@ -500,79 +581,86 @@ int __init el3_probe(struct net_device *dev, int card_idx) ...@@ -500,79 +581,86 @@ int __init el3_probe(struct net_device *dev, int card_idx)
/* Free the interrupt so that some other card can use it. */ /* Free the interrupt so that some other card can use it. */
outw(0x0f00, ioaddr + WN0_IRQ); outw(0x0f00, ioaddr + WN0_IRQ);
found: found:
dev = init_etherdev(NULL, sizeof(struct el3_private));
if (dev == NULL) { if (dev == NULL) {
dev = init_etherdev(dev, sizeof(struct el3_private)); release_region(ioaddr, EL3_IO_EXTENT);
if (dev == NULL) { return -ENOMEM;
release_region(ioaddr, EL3_IO_EXTENT);
return -ENOMEM;
}
SET_MODULE_OWNER(dev);
} }
SET_MODULE_OWNER(dev);
memcpy(dev->dev_addr, phys_addr, sizeof(phys_addr)); memcpy(dev->dev_addr, phys_addr, sizeof(phys_addr));
dev->base_addr = ioaddr; dev->base_addr = ioaddr;
dev->irq = irq; dev->irq = irq;
dev->if_port = if_port;
if (dev->mem_start & 0x05) { /* xcvr codes 1/3/4/12 */
dev->if_port = (dev->mem_start & 0x0f);
} else { /* xcvr codes 0/8 */
/* use eeprom value, but save user's full-duplex selection */
dev->if_port = (if_port | (dev->mem_start & 0x08) );
}
{
const char *if_names[] = {"10baseT", "AUI", "undefined", "BNC"};
printk("%s: 3c5x9 at %#3.3lx, %s port, address ",
dev->name, dev->base_addr, if_names[(dev->if_port & 0x03)]);
}
/* Read in the station address. */
for (i = 0; i < 6; i++)
printk(" %2.2x", dev->dev_addr[i]);
printk(", IRQ %d.\n", dev->irq);
/* Make up a EL3-specific-data structure. */
if (dev->priv == NULL)
dev->priv = kmalloc(sizeof(struct el3_private), GFP_KERNEL);
if (dev->priv == NULL)
return -ENOMEM;
memset(dev->priv, 0, sizeof(struct el3_private));
lp = dev->priv; lp = dev->priv;
#ifdef __ISAPNP__ #ifdef __ISAPNP__
lp->pnpdev = idev; lp->pnpdev = idev;
#endif #endif
lp->mca_slot = mca_slot; lp->mca_slot = mca_slot;
lp->next_dev = el3_root_dev;
spin_lock_init(&lp->lock);
el3_root_dev = dev;
if (el3_debug > 0) return el3_common_init (dev);
printk(KERN_INFO "%s" KERN_INFO "%s", versionA, versionB); }
/* The EL3-specific entries in the device structure. */ #ifdef CONFIG_EISA
dev->open = &el3_open; static int __init el3_eisa_probe (struct device *device)
dev->hard_start_xmit = &el3_start_xmit; {
dev->stop = &el3_close; struct el3_private *lp;
dev->get_stats = &el3_get_stats; short i;
dev->set_multicast_list = &set_multicast_list; int ioaddr, irq, if_port;
dev->tx_timeout = el3_tx_timeout; u16 phys_addr[3];
dev->watchdog_timeo = TX_TIMEOUT; struct net_device *dev = NULL;
dev->do_ioctl = netdev_ioctl; struct eisa_device *edev;
#ifdef CONFIG_PM /* Yeepee, The driver framework is calling us ! */
/* register power management */ edev = to_eisa_device (device);
lp->pmdev = pm_register(PM_ISA_DEV, card_idx, el3_pm_callback); ioaddr = edev->base_addr;
if (lp->pmdev) {
struct pm_dev *p; if (!request_region(ioaddr, EL3_IO_EXTENT, "3c509"))
p = lp->pmdev; return -EBUSY;
p->data = (struct net_device *)dev;
/* Change the register set to the configuration window 0. */
outw(SelectWindow | 0, ioaddr + 0xC80 + EL3_CMD);
irq = inw(ioaddr + WN0_IRQ) >> 12;
if_port = inw(ioaddr + 6)>>14;
for (i = 0; i < 3; i++)
phys_addr[i] = htons(read_eeprom(ioaddr, i));
/* Restore the "Product ID" to the EEPROM read register. */
read_eeprom(ioaddr, 3);
dev = init_etherdev(NULL, sizeof(struct el3_private));
if (dev == NULL) {
release_region(ioaddr, EL3_IO_EXTENT);
return -ENOMEM;
} }
#endif
/* Fill in the generic fields of the device structure. */ SET_MODULE_OWNER(dev);
ether_setup(dev);
return 0; memcpy(dev->dev_addr, phys_addr, sizeof(phys_addr));
dev->base_addr = ioaddr;
dev->irq = irq;
dev->if_port = if_port;
lp = dev->priv;
lp->mca_slot = -1;
lp->edev = edev;
eisa_set_drvdata (edev, dev);
return el3_common_init (dev);
}
static int __devexit el3_eisa_remove (struct device *device)
{
struct eisa_device *edev;
struct net_device *dev;
edev = to_eisa_device (device);
dev = eisa_get_drvdata (edev);
el3_common_remove (dev);
return 0;
} }
#endif
/* Read a word from the EEPROM using the regular EEPROM access register. /* Read a word from the EEPROM using the regular EEPROM access register.
Assume that we are in register window zero. Assume that we are in register window zero.
...@@ -982,7 +1070,8 @@ static int ...@@ -982,7 +1070,8 @@ static int
el3_close(struct net_device *dev) el3_close(struct net_device *dev)
{ {
int ioaddr = dev->base_addr; int ioaddr = dev->base_addr;
struct el3_private *lp = (struct el3_private *)dev->priv;
if (el3_debug > 2) if (el3_debug > 2)
printk("%s: Shutting down ethercard.\n", dev->name); printk("%s: Shutting down ethercard.\n", dev->name);
...@@ -991,8 +1080,12 @@ el3_close(struct net_device *dev) ...@@ -991,8 +1080,12 @@ el3_close(struct net_device *dev)
free_irq(dev->irq, dev); free_irq(dev->irq, dev);
/* Switching back to window 0 disables the IRQ. */ /* Switching back to window 0 disables the IRQ. */
EL3WINDOW(0); EL3WINDOW(0);
/* But we explicitly zero the IRQ line select anyway. */ if (!lp->edev) {
outw(0x0f00, ioaddr + WN0_IRQ); /* But we explicitly zero the IRQ line select anyway. Don't do
* it on EISA cards, it prevents the module from getting an
* IRQ after unload+reload... */
outw(0x0f00, ioaddr + WN0_IRQ);
}
return 0; return 0;
} }
...@@ -1414,7 +1507,6 @@ el3_pm_callback(struct pm_dev *pdev, pm_request_t rqst, void *data) ...@@ -1414,7 +1507,6 @@ el3_pm_callback(struct pm_dev *pdev, pm_request_t rqst, void *data)
#endif /* CONFIG_PM */ #endif /* CONFIG_PM */
#ifdef MODULE
/* Parameters that may be passed into the module. */ /* Parameters that may be passed into the module. */
static int debug = -1; static int debug = -1;
static int irq[] = {-1, -1, -1, -1, -1, -1, -1, -1}; static int irq[] = {-1, -1, -1, -1, -1, -1, -1, -1};
...@@ -1436,8 +1528,7 @@ MODULE_DEVICE_TABLE(isapnp, el3_isapnp_adapters); ...@@ -1436,8 +1528,7 @@ MODULE_DEVICE_TABLE(isapnp, el3_isapnp_adapters);
MODULE_DESCRIPTION("3Com Etherlink III (3c509, 3c509B) ISA/PnP ethernet driver"); MODULE_DESCRIPTION("3Com Etherlink III (3c509, 3c509B) ISA/PnP ethernet driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
int static int __init el3_init_module(void)
init_module(void)
{ {
int el3_cards = 0; int el3_cards = 0;
...@@ -1445,7 +1536,7 @@ init_module(void) ...@@ -1445,7 +1536,7 @@ init_module(void)
el3_debug = debug; el3_debug = debug;
el3_root_dev = NULL; el3_root_dev = NULL;
while (el3_probe(0, el3_cards) == 0) { while (el3_probe(el3_cards) == 0) {
if (irq[el3_cards] > 1) if (irq[el3_cards] > 1)
el3_root_dev->irq = irq[el3_cards]; el3_root_dev->irq = irq[el3_cards];
if (xcvr[el3_cards] >= 0) if (xcvr[el3_cards] >= 0)
...@@ -1453,38 +1544,36 @@ init_module(void) ...@@ -1453,38 +1544,36 @@ init_module(void)
el3_cards++; el3_cards++;
} }
#ifdef CONFIG_EISA
if (eisa_driver_register (&el3_eisa_driver) < 0) {
eisa_driver_unregister (&el3_eisa_driver);
}
else
el3_cards++; /* Found an eisa card */
#endif
return el3_cards ? 0 : -ENODEV; return el3_cards ? 0 : -ENODEV;
} }
void static void __exit el3_cleanup_module(void)
cleanup_module(void)
{ {
struct net_device *next_dev; struct net_device *next_dev;
/* No need to check MOD_IN_USE, as sys_delete_module() checks. */ /* No need to check MOD_IN_USE, as sys_delete_module() checks. */
while (el3_root_dev) { while (el3_root_dev) {
struct el3_private *lp = (struct el3_private *)el3_root_dev->priv; struct el3_private *lp = (struct el3_private *)el3_root_dev->priv;
#ifdef CONFIG_MCA
if(lp->mca_slot!=-1)
mca_mark_as_unused(lp->mca_slot);
#endif
#ifdef CONFIG_PM
if (lp->pmdev)
pm_unregister(lp->pmdev);
#endif
next_dev = lp->next_dev; next_dev = lp->next_dev;
unregister_netdev(el3_root_dev); el3_common_remove (el3_root_dev);
release_region(el3_root_dev->base_addr, EL3_IO_EXTENT);
#ifdef __ISAPNP__
if (lp->pnpdev)
pnp_device_detach(lp->pnpdev);
#endif
kfree(el3_root_dev);
el3_root_dev = next_dev; el3_root_dev = next_dev;
} }
#ifdef CONFIG_EISA
eisa_driver_unregister (&el3_eisa_driver);
#endif
} }
#endif /* MODULE */
module_init (el3_init_module);
module_exit (el3_cleanup_module);
/* /*
* Local variables: * Local variables:
......
...@@ -180,6 +180,9 @@ ...@@ -180,6 +180,9 @@
- See http://www.zip.com.au/~akpm/linux/#3c59x-2.3 for more details. - See http://www.zip.com.au/~akpm/linux/#3c59x-2.3 for more details.
- Also see Documentation/networking/vortex.txt - Also see Documentation/networking/vortex.txt
LK1.1.19 10Nov09 Marc Zyngier <maz@wild-wind.fr.eu.org>
- EISA sysfs integration.
*/ */
/* /*
...@@ -193,8 +196,8 @@ ...@@ -193,8 +196,8 @@
#define DRV_NAME "3c59x" #define DRV_NAME "3c59x"
#define DRV_VERSION "LK1.1.18" #define DRV_VERSION "LK1.1.19"
#define DRV_RELDATE "1 Jul 2002" #define DRV_RELDATE "10 Nov 2002"
...@@ -259,7 +262,7 @@ static int vortex_debug = 1; ...@@ -259,7 +262,7 @@ static int vortex_debug = 1;
#include <linux/skbuff.h> #include <linux/skbuff.h>
#include <linux/ethtool.h> #include <linux/ethtool.h>
#include <linux/highmem.h> #include <linux/highmem.h>
#include <linux/eisa.h>
#include <asm/irq.h> /* For NR_IRQS only. */ #include <asm/irq.h> /* For NR_IRQS only. */
#include <asm/bitops.h> #include <asm/bitops.h>
#include <asm/io.h> #include <asm/io.h>
...@@ -768,7 +771,6 @@ struct vortex_private { ...@@ -768,7 +771,6 @@ struct vortex_private {
/* The addresses of transmit- and receive-in-place skbuffs. */ /* The addresses of transmit- and receive-in-place skbuffs. */
struct sk_buff* rx_skbuff[RX_RING_SIZE]; struct sk_buff* rx_skbuff[RX_RING_SIZE];
struct sk_buff* tx_skbuff[TX_RING_SIZE]; struct sk_buff* tx_skbuff[TX_RING_SIZE];
struct net_device *next_module; /* NULL if PCI device */
unsigned int cur_rx, cur_tx; /* The next free ring entry */ unsigned int cur_rx, cur_tx; /* The next free ring entry */
unsigned int dirty_rx, dirty_tx; /* The ring entries to be free()ed. */ unsigned int dirty_rx, dirty_tx; /* The ring entries to be free()ed. */
struct net_device_stats stats; struct net_device_stats stats;
...@@ -776,7 +778,7 @@ struct vortex_private { ...@@ -776,7 +778,7 @@ struct vortex_private {
dma_addr_t tx_skb_dma; /* Allocated DMA address for bus master ctrl DMA. */ dma_addr_t tx_skb_dma; /* Allocated DMA address for bus master ctrl DMA. */
/* PCI configuration space information. */ /* PCI configuration space information. */
struct pci_dev *pdev; struct device *gendev;
char *cb_fn_base; /* CardBus function status addr space. */ char *cb_fn_base; /* CardBus function status addr space. */
/* Some values here only for performance evaluation and path-coverage */ /* Some values here only for performance evaluation and path-coverage */
...@@ -815,6 +817,18 @@ struct vortex_private { ...@@ -815,6 +817,18 @@ struct vortex_private {
u32 power_state[16]; u32 power_state[16];
}; };
#define DEVICE_PCI(dev) (((dev)->bus == &pci_bus_type) ? to_pci_dev((dev)) : NULL)
#define VORTEX_PCI(vp) (((vp)->gendev) ? DEVICE_PCI((vp)->gendev) : NULL)
#ifdef CONFIG_EISA
#define DEVICE_EISA(dev) (((dev)->bus == &eisa_bus_type) ? to_eisa_device((dev)) : NULL)
#else
#define DEVICE_EISA(dev) NULL
#endif
#define VORTEX_EISA(vp) (((vp)->gendev) ? DEVICE_EISA((vp)->gendev) : NULL)
/* The action to take with a media selection timer tick. /* The action to take with a media selection timer tick.
Note that we deviate from the 3Com order by checking 10base2 before AUI. Note that we deviate from the 3Com order by checking 10base2 before AUI.
*/ */
...@@ -843,7 +857,7 @@ static struct media_table { ...@@ -843,7 +857,7 @@ static struct media_table {
{ "Default", 0, 0xFF, XCVR_10baseT, 10000}, { "Default", 0, 0xFF, XCVR_10baseT, 10000},
}; };
static int vortex_probe1(struct pci_dev *pdev, long ioaddr, int irq, static int vortex_probe1(struct device *gendev, long ioaddr, int irq,
int chip_idx, int card_idx); int chip_idx, int card_idx);
static void vortex_up(struct net_device *dev); static void vortex_up(struct net_device *dev);
static void vortex_down(struct net_device *dev); static void vortex_down(struct net_device *dev);
...@@ -882,11 +896,9 @@ static int global_enable_wol = -1; ...@@ -882,11 +896,9 @@ static int global_enable_wol = -1;
/* #define dev_alloc_skb dev_alloc_skb_debug */ /* #define dev_alloc_skb dev_alloc_skb_debug */
/* A list of all installed Vortex EISA devices, for removing the driver module. */
static struct net_device *root_vortex_eisa_dev;
/* Variables to work-around the Compaq PCI BIOS32 problem. */ /* Variables to work-around the Compaq PCI BIOS32 problem. */
static int compaq_ioaddr, compaq_irq, compaq_device_id = 0x5900; static int compaq_ioaddr, compaq_irq, compaq_device_id = 0x5900;
static struct net_device *compaq_net_device;
static int vortex_cards_found; static int vortex_cards_found;
...@@ -920,44 +932,89 @@ static int vortex_resume (struct pci_dev *pdev) ...@@ -920,44 +932,89 @@ static int vortex_resume (struct pci_dev *pdev)
#endif /* CONFIG_PM */ #endif /* CONFIG_PM */
/* returns count found (>= 0), or negative on error */ #ifdef CONFIG_EISA
static int __init vortex_eisa_init (void) static struct eisa_device_id vortex_eisa_ids[] = {
{ "TCM5920" },
{ "TCM5970" },
{ "" }
};
static int vortex_eisa_probe (struct device *device);
static int vortex_eisa_remove (struct device *device);
static struct eisa_driver vortex_eisa_driver = {
.id_table = vortex_eisa_ids,
.driver = {
.name = "3c59x",
.probe = vortex_eisa_probe,
.remove = vortex_eisa_remove
}
};
static int vortex_eisa_probe (struct device *device)
{ {
long ioaddr; long ioaddr;
int rc; struct eisa_device *edev;
int orig_cards_found = vortex_cards_found;
/* Now check all slots of the EISA bus. */ edev = to_eisa_device (device);
if (!EISA_bus) ioaddr = edev->base_addr;
return 0;
for (ioaddr = 0x1000; ioaddr < 0x9000; ioaddr += 0x1000) { if (!request_region(ioaddr, VORTEX_TOTAL_SIZE, DRV_NAME))
int device_id; return -EBUSY;
if (request_region(ioaddr, VORTEX_TOTAL_SIZE, DRV_NAME) == NULL) if (vortex_probe1(device, ioaddr, inw(ioaddr + 0xC88) >> 12,
continue; EISA_TBL_OFFSET, vortex_cards_found)) {
release_region (ioaddr, VORTEX_TOTAL_SIZE);
return -ENODEV;
}
/* Check the standard EISA ID register for an encoded '3Com'. */ vortex_cards_found++;
if (inw(ioaddr + 0xC80) != 0x6d50) {
release_region (ioaddr, VORTEX_TOTAL_SIZE);
continue;
}
/* Check for a product that we support, 3c59{2,7} any rev. */ return 0;
device_id = (inb(ioaddr + 0xC82)<<8) + inb(ioaddr + 0xC83); }
if ((device_id & 0xFF00) != 0x5900) {
release_region (ioaddr, VORTEX_TOTAL_SIZE);
continue;
}
rc = vortex_probe1(NULL, ioaddr, inw(ioaddr + 0xC88) >> 12, static int vortex_eisa_remove (struct device *device)
EISA_TBL_OFFSET, vortex_cards_found); {
if (rc == 0) struct eisa_device *edev;
vortex_cards_found++; struct net_device *dev;
else struct vortex_private *vp;
release_region (ioaddr, VORTEX_TOTAL_SIZE); long ioaddr;
edev = to_eisa_device (device);
dev = eisa_get_drvdata (edev);
if (!dev) {
printk("vortex_eisa_remove called for Compaq device!\n");
BUG();
} }
vp = dev->priv;
ioaddr = dev->base_addr;
unregister_netdev (dev);
outw (TotalReset|0x14, ioaddr + EL3_CMD);
release_region (ioaddr, VORTEX_TOTAL_SIZE);
kfree (dev);
return 0;
}
#endif
/* returns count found (>= 0), or negative on error */
static int __init vortex_eisa_init (void)
{
int orig_cards_found = vortex_cards_found;
/* Now check all slots of the EISA bus. */
if (!EISA_bus)
return 0;
#ifdef CONFIG_EISA
if (eisa_driver_register (&vortex_eisa_driver) < 0) {
eisa_driver_unregister (&vortex_eisa_driver);
}
#endif
/* Special code to work-around the Compaq PCI BIOS32 problem. */ /* Special code to work-around the Compaq PCI BIOS32 problem. */
if (compaq_ioaddr) { if (compaq_ioaddr) {
vortex_probe1(NULL, compaq_ioaddr, compaq_irq, vortex_probe1(NULL, compaq_ioaddr, compaq_irq,
...@@ -977,8 +1034,8 @@ static int __devinit vortex_init_one (struct pci_dev *pdev, ...@@ -977,8 +1034,8 @@ static int __devinit vortex_init_one (struct pci_dev *pdev,
if (pci_enable_device (pdev)) { if (pci_enable_device (pdev)) {
rc = -EIO; rc = -EIO;
} else { } else {
rc = vortex_probe1 (pdev, pci_resource_start (pdev, 0), pdev->irq, rc = vortex_probe1 (&pdev->dev, pci_resource_start (pdev, 0),
ent->driver_data, vortex_cards_found); pdev->irq, ent->driver_data, vortex_cards_found);
if (rc == 0) if (rc == 0)
vortex_cards_found++; vortex_cards_found++;
} }
...@@ -986,12 +1043,12 @@ static int __devinit vortex_init_one (struct pci_dev *pdev, ...@@ -986,12 +1043,12 @@ static int __devinit vortex_init_one (struct pci_dev *pdev,
} }
/* /*
* Start up the PCI device which is described by *pdev. * Start up the PCI/EISA device which is described by *gendev.
* Return 0 on success. * Return 0 on success.
* *
* NOTE: pdev can be NULL, for the case of an EISA driver * NOTE: pdev can be NULL, for the case of a Compaq device
*/ */
static int __devinit vortex_probe1(struct pci_dev *pdev, static int __devinit vortex_probe1(struct device *gendev,
long ioaddr, int irq, long ioaddr, int irq,
int chip_idx, int card_idx) int chip_idx, int card_idx)
{ {
...@@ -1003,14 +1060,24 @@ static int __devinit vortex_probe1(struct pci_dev *pdev, ...@@ -1003,14 +1060,24 @@ static int __devinit vortex_probe1(struct pci_dev *pdev,
static int printed_version; static int printed_version;
int retval, print_info; int retval, print_info;
struct vortex_chip_info * const vci = &vortex_info_tbl[chip_idx]; struct vortex_chip_info * const vci = &vortex_info_tbl[chip_idx];
char *print_name; char *print_name = "3c59x";
struct pci_dev *pdev = NULL;
struct eisa_device *edev = NULL;
if (!printed_version) { if (!printed_version) {
printk (version); printk (version);
printed_version = 1; printed_version = 1;
} }
print_name = pdev ? pdev->slot_name : "3c59x"; if (gendev) {
if ((pdev = DEVICE_PCI(gendev))) {
print_name = pdev->slot_name;
}
if ((edev = DEVICE_EISA(gendev))) {
print_name = edev->dev.bus_id;
}
}
dev = alloc_etherdev(sizeof(*vp)); dev = alloc_etherdev(sizeof(*vp));
retval = -ENOMEM; retval = -ENOMEM;
...@@ -1063,10 +1130,9 @@ static int __devinit vortex_probe1(struct pci_dev *pdev, ...@@ -1063,10 +1130,9 @@ static int __devinit vortex_probe1(struct pci_dev *pdev,
vp->io_size = vci->io_size; vp->io_size = vci->io_size;
vp->card_idx = card_idx; vp->card_idx = card_idx;
/* module list only for EISA devices */ /* module list only for Compaq device */
if (pdev == NULL) { if (gendev == NULL) {
vp->next_module = root_vortex_eisa_dev; compaq_net_device = dev;
root_vortex_eisa_dev = dev;
} }
/* PCI-only startup logic */ /* PCI-only startup logic */
...@@ -1100,7 +1166,7 @@ static int __devinit vortex_probe1(struct pci_dev *pdev, ...@@ -1100,7 +1166,7 @@ static int __devinit vortex_probe1(struct pci_dev *pdev,
spin_lock_init(&vp->lock); spin_lock_init(&vp->lock);
spin_lock_init(&vp->mdio_lock); spin_lock_init(&vp->mdio_lock);
vp->pdev = pdev; vp->gendev = gendev;
/* Makes sure rings are at least 16 byte aligned. */ /* Makes sure rings are at least 16 byte aligned. */
vp->rx_ring = pci_alloc_consistent(pdev, sizeof(struct boom_rx_desc) * RX_RING_SIZE vp->rx_ring = pci_alloc_consistent(pdev, sizeof(struct boom_rx_desc) * RX_RING_SIZE
...@@ -1117,6 +1183,8 @@ static int __devinit vortex_probe1(struct pci_dev *pdev, ...@@ -1117,6 +1183,8 @@ static int __devinit vortex_probe1(struct pci_dev *pdev,
* instead of a module list */ * instead of a module list */
if (pdev) if (pdev)
pci_set_drvdata(pdev, dev); pci_set_drvdata(pdev, dev);
if (edev)
eisa_set_drvdata (edev, dev);
vp->media_override = 7; vp->media_override = 7;
if (option >= 0) { if (option >= 0) {
...@@ -1367,7 +1435,7 @@ static int __devinit vortex_probe1(struct pci_dev *pdev, ...@@ -1367,7 +1435,7 @@ static int __devinit vortex_probe1(struct pci_dev *pdev,
dev->watchdog_timeo = (watchdog * HZ) / 1000; dev->watchdog_timeo = (watchdog * HZ) / 1000;
if (pdev && vp->enable_wol) { if (pdev && vp->enable_wol) {
vp->pm_state_valid = 1; vp->pm_state_valid = 1;
pci_save_state(vp->pdev, vp->power_state); pci_save_state(VORTEX_PCI(vp), vp->power_state);
acpi_set_WOL(dev); acpi_set_WOL(dev);
} }
retval = register_netdev(dev); retval = register_netdev(dev);
...@@ -1422,9 +1490,9 @@ vortex_up(struct net_device *dev) ...@@ -1422,9 +1490,9 @@ vortex_up(struct net_device *dev)
unsigned int config; unsigned int config;
int i; int i;
if (vp->pdev && vp->enable_wol) { if (VORTEX_PCI(vp) && vp->enable_wol) {
pci_set_power_state(vp->pdev, 0); /* Go active */ pci_set_power_state(VORTEX_PCI(vp), 0); /* Go active */
pci_restore_state(vp->pdev, vp->power_state); pci_restore_state(VORTEX_PCI(vp), vp->power_state);
} }
/* Before initializing select the active media port. */ /* Before initializing select the active media port. */
...@@ -1641,7 +1709,7 @@ vortex_open(struct net_device *dev) ...@@ -1641,7 +1709,7 @@ vortex_open(struct net_device *dev)
break; /* Bad news! */ break; /* Bad news! */
skb->dev = dev; /* Mark as being used by this device. */ skb->dev = dev; /* Mark as being used by this device. */
skb_reserve(skb, 2); /* Align IP on 16 byte boundaries */ skb_reserve(skb, 2); /* Align IP on 16 byte boundaries */
vp->rx_ring[i].addr = cpu_to_le32(pci_map_single(vp->pdev, skb->tail, PKT_BUF_SZ, PCI_DMA_FROMDEVICE)); vp->rx_ring[i].addr = cpu_to_le32(pci_map_single(VORTEX_PCI(vp), skb->tail, PKT_BUF_SZ, PCI_DMA_FROMDEVICE));
} }
if (i != RX_RING_SIZE) { if (i != RX_RING_SIZE) {
int j; int j;
...@@ -1978,7 +2046,7 @@ vortex_start_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -1978,7 +2046,7 @@ vortex_start_xmit(struct sk_buff *skb, struct net_device *dev)
if (vp->bus_master) { if (vp->bus_master) {
/* Set the bus-master controller to transfer the packet. */ /* Set the bus-master controller to transfer the packet. */
int len = (skb->len + 3) & ~3; int len = (skb->len + 3) & ~3;
outl( vp->tx_skb_dma = pci_map_single(vp->pdev, skb->data, len, PCI_DMA_TODEVICE), outl( vp->tx_skb_dma = pci_map_single(VORTEX_PCI(vp), skb->data, len, PCI_DMA_TODEVICE),
ioaddr + Wn7_MasterAddr); ioaddr + Wn7_MasterAddr);
outw(len, ioaddr + Wn7_MasterLen); outw(len, ioaddr + Wn7_MasterLen);
vp->tx_skb = skb; vp->tx_skb = skb;
...@@ -2057,13 +2125,13 @@ boomerang_start_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -2057,13 +2125,13 @@ boomerang_start_xmit(struct sk_buff *skb, struct net_device *dev)
vp->tx_ring[entry].status = cpu_to_le32(skb->len | TxIntrUploaded | AddTCPChksum | AddUDPChksum); vp->tx_ring[entry].status = cpu_to_le32(skb->len | TxIntrUploaded | AddTCPChksum | AddUDPChksum);
if (!skb_shinfo(skb)->nr_frags) { if (!skb_shinfo(skb)->nr_frags) {
vp->tx_ring[entry].frag[0].addr = cpu_to_le32(pci_map_single(vp->pdev, skb->data, vp->tx_ring[entry].frag[0].addr = cpu_to_le32(pci_map_single(VORTEX_PCI(vp), skb->data,
skb->len, PCI_DMA_TODEVICE)); skb->len, PCI_DMA_TODEVICE));
vp->tx_ring[entry].frag[0].length = cpu_to_le32(skb->len | LAST_FRAG); vp->tx_ring[entry].frag[0].length = cpu_to_le32(skb->len | LAST_FRAG);
} else { } else {
int i; int i;
vp->tx_ring[entry].frag[0].addr = cpu_to_le32(pci_map_single(vp->pdev, skb->data, vp->tx_ring[entry].frag[0].addr = cpu_to_le32(pci_map_single(VORTEX_PCI(vp), skb->data,
skb->len-skb->data_len, PCI_DMA_TODEVICE)); skb->len-skb->data_len, PCI_DMA_TODEVICE));
vp->tx_ring[entry].frag[0].length = cpu_to_le32(skb->len-skb->data_len); vp->tx_ring[entry].frag[0].length = cpu_to_le32(skb->len-skb->data_len);
...@@ -2071,7 +2139,7 @@ boomerang_start_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -2071,7 +2139,7 @@ boomerang_start_xmit(struct sk_buff *skb, struct net_device *dev)
skb_frag_t *frag = &skb_shinfo(skb)->frags[i]; skb_frag_t *frag = &skb_shinfo(skb)->frags[i];
vp->tx_ring[entry].frag[i+1].addr = vp->tx_ring[entry].frag[i+1].addr =
cpu_to_le32(pci_map_single(vp->pdev, cpu_to_le32(pci_map_single(VORTEX_PCI(vp),
(void*)page_address(frag->page) + frag->page_offset, (void*)page_address(frag->page) + frag->page_offset,
frag->size, PCI_DMA_TODEVICE)); frag->size, PCI_DMA_TODEVICE));
...@@ -2082,7 +2150,7 @@ boomerang_start_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -2082,7 +2150,7 @@ boomerang_start_xmit(struct sk_buff *skb, struct net_device *dev)
} }
} }
#else #else
vp->tx_ring[entry].addr = cpu_to_le32(pci_map_single(vp->pdev, skb->data, skb->len, PCI_DMA_TODEVICE)); vp->tx_ring[entry].addr = cpu_to_le32(pci_map_single(VORTEX_PCI(vp), skb->data, skb->len, PCI_DMA_TODEVICE));
vp->tx_ring[entry].length = cpu_to_le32(skb->len | LAST_FRAG); vp->tx_ring[entry].length = cpu_to_le32(skb->len | LAST_FRAG);
vp->tx_ring[entry].status = cpu_to_le32(skb->len | TxIntrUploaded); vp->tx_ring[entry].status = cpu_to_le32(skb->len | TxIntrUploaded);
#endif #endif
...@@ -2170,7 +2238,7 @@ static void vortex_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -2170,7 +2238,7 @@ static void vortex_interrupt(int irq, void *dev_id, struct pt_regs *regs)
if (status & DMADone) { if (status & DMADone) {
if (inw(ioaddr + Wn7_MasterStatus) & 0x1000) { if (inw(ioaddr + Wn7_MasterStatus) & 0x1000) {
outw(0x1000, ioaddr + Wn7_MasterStatus); /* Ack the event. */ outw(0x1000, ioaddr + Wn7_MasterStatus); /* Ack the event. */
pci_unmap_single(vp->pdev, vp->tx_skb_dma, (vp->tx_skb->len + 3) & ~3, PCI_DMA_TODEVICE); pci_unmap_single(VORTEX_PCI(vp), vp->tx_skb_dma, (vp->tx_skb->len + 3) & ~3, PCI_DMA_TODEVICE);
dev_kfree_skb_irq(vp->tx_skb); /* Release the transferred buffer */ dev_kfree_skb_irq(vp->tx_skb); /* Release the transferred buffer */
if (inw(ioaddr + TxFree) > 1536) { if (inw(ioaddr + TxFree) > 1536) {
/* /*
...@@ -2291,12 +2359,12 @@ static void boomerang_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -2291,12 +2359,12 @@ static void boomerang_interrupt(int irq, void *dev_id, struct pt_regs *regs)
#if DO_ZEROCOPY #if DO_ZEROCOPY
int i; int i;
for (i=0; i<=skb_shinfo(skb)->nr_frags; i++) for (i=0; i<=skb_shinfo(skb)->nr_frags; i++)
pci_unmap_single(vp->pdev, pci_unmap_single(VORTEX_PCI(vp),
le32_to_cpu(vp->tx_ring[entry].frag[i].addr), le32_to_cpu(vp->tx_ring[entry].frag[i].addr),
le32_to_cpu(vp->tx_ring[entry].frag[i].length)&0xFFF, le32_to_cpu(vp->tx_ring[entry].frag[i].length)&0xFFF,
PCI_DMA_TODEVICE); PCI_DMA_TODEVICE);
#else #else
pci_unmap_single(vp->pdev, pci_unmap_single(VORTEX_PCI(vp),
le32_to_cpu(vp->tx_ring[entry].addr), skb->len, PCI_DMA_TODEVICE); le32_to_cpu(vp->tx_ring[entry].addr), skb->len, PCI_DMA_TODEVICE);
#endif #endif
dev_kfree_skb_irq(skb); dev_kfree_skb_irq(skb);
...@@ -2383,14 +2451,14 @@ static int vortex_rx(struct net_device *dev) ...@@ -2383,14 +2451,14 @@ static int vortex_rx(struct net_device *dev)
/* 'skb_put()' points to the start of sk_buff data area. */ /* 'skb_put()' points to the start of sk_buff data area. */
if (vp->bus_master && if (vp->bus_master &&
! (inw(ioaddr + Wn7_MasterStatus) & 0x8000)) { ! (inw(ioaddr + Wn7_MasterStatus) & 0x8000)) {
dma_addr_t dma = pci_map_single(vp->pdev, skb_put(skb, pkt_len), dma_addr_t dma = pci_map_single(VORTEX_PCI(vp), skb_put(skb, pkt_len),
pkt_len, PCI_DMA_FROMDEVICE); pkt_len, PCI_DMA_FROMDEVICE);
outl(dma, ioaddr + Wn7_MasterAddr); outl(dma, ioaddr + Wn7_MasterAddr);
outw((skb->len + 3) & ~3, ioaddr + Wn7_MasterLen); outw((skb->len + 3) & ~3, ioaddr + Wn7_MasterLen);
outw(StartDMAUp, ioaddr + EL3_CMD); outw(StartDMAUp, ioaddr + EL3_CMD);
while (inw(ioaddr + Wn7_MasterStatus) & 0x8000) while (inw(ioaddr + Wn7_MasterStatus) & 0x8000)
; ;
pci_unmap_single(vp->pdev, dma, pkt_len, PCI_DMA_FROMDEVICE); pci_unmap_single(VORTEX_PCI(vp), dma, pkt_len, PCI_DMA_FROMDEVICE);
} else { } else {
insl(ioaddr + RX_FIFO, skb_put(skb, pkt_len), insl(ioaddr + RX_FIFO, skb_put(skb, pkt_len),
(pkt_len + 3) >> 2); (pkt_len + 3) >> 2);
...@@ -2456,7 +2524,7 @@ boomerang_rx(struct net_device *dev) ...@@ -2456,7 +2524,7 @@ boomerang_rx(struct net_device *dev)
if (pkt_len < rx_copybreak && (skb = dev_alloc_skb(pkt_len + 2)) != 0) { if (pkt_len < rx_copybreak && (skb = dev_alloc_skb(pkt_len + 2)) != 0) {
skb->dev = dev; skb->dev = dev;
skb_reserve(skb, 2); /* Align IP on 16 byte boundaries */ skb_reserve(skb, 2); /* Align IP on 16 byte boundaries */
pci_dma_sync_single(vp->pdev, dma, PKT_BUF_SZ, PCI_DMA_FROMDEVICE); pci_dma_sync_single(VORTEX_PCI(vp), dma, PKT_BUF_SZ, PCI_DMA_FROMDEVICE);
/* 'skb_put()' points to the start of sk_buff data area. */ /* 'skb_put()' points to the start of sk_buff data area. */
memcpy(skb_put(skb, pkt_len), memcpy(skb_put(skb, pkt_len),
vp->rx_skbuff[entry]->tail, vp->rx_skbuff[entry]->tail,
...@@ -2467,7 +2535,7 @@ boomerang_rx(struct net_device *dev) ...@@ -2467,7 +2535,7 @@ boomerang_rx(struct net_device *dev)
skb = vp->rx_skbuff[entry]; skb = vp->rx_skbuff[entry];
vp->rx_skbuff[entry] = NULL; vp->rx_skbuff[entry] = NULL;
skb_put(skb, pkt_len); skb_put(skb, pkt_len);
pci_unmap_single(vp->pdev, dma, PKT_BUF_SZ, PCI_DMA_FROMDEVICE); pci_unmap_single(VORTEX_PCI(vp), dma, PKT_BUF_SZ, PCI_DMA_FROMDEVICE);
vp->rx_nocopy++; vp->rx_nocopy++;
} }
skb->protocol = eth_type_trans(skb, dev); skb->protocol = eth_type_trans(skb, dev);
...@@ -2504,7 +2572,7 @@ boomerang_rx(struct net_device *dev) ...@@ -2504,7 +2572,7 @@ boomerang_rx(struct net_device *dev)
} }
skb->dev = dev; /* Mark as being used by this device. */ skb->dev = dev; /* Mark as being used by this device. */
skb_reserve(skb, 2); /* Align IP on 16 byte boundaries */ skb_reserve(skb, 2); /* Align IP on 16 byte boundaries */
vp->rx_ring[entry].addr = cpu_to_le32(pci_map_single(vp->pdev, skb->tail, PKT_BUF_SZ, PCI_DMA_FROMDEVICE)); vp->rx_ring[entry].addr = cpu_to_le32(pci_map_single(VORTEX_PCI(vp), skb->tail, PKT_BUF_SZ, PCI_DMA_FROMDEVICE));
vp->rx_skbuff[entry] = skb; vp->rx_skbuff[entry] = skb;
} }
vp->rx_ring[entry].status = 0; /* Clear complete bit. */ vp->rx_ring[entry].status = 0; /* Clear complete bit. */
...@@ -2563,8 +2631,8 @@ vortex_down(struct net_device *dev) ...@@ -2563,8 +2631,8 @@ vortex_down(struct net_device *dev)
if (vp->full_bus_master_tx) if (vp->full_bus_master_tx)
outl(0, ioaddr + DownListPtr); outl(0, ioaddr + DownListPtr);
if (vp->pdev && vp->enable_wol) { if (VORTEX_PCI(vp) && vp->enable_wol) {
pci_save_state(vp->pdev, vp->power_state); pci_save_state(VORTEX_PCI(vp), vp->power_state);
acpi_set_WOL(dev); acpi_set_WOL(dev);
} }
} }
...@@ -2600,7 +2668,7 @@ vortex_close(struct net_device *dev) ...@@ -2600,7 +2668,7 @@ vortex_close(struct net_device *dev)
if (vp->full_bus_master_rx) { /* Free Boomerang bus master Rx buffers. */ if (vp->full_bus_master_rx) { /* Free Boomerang bus master Rx buffers. */
for (i = 0; i < RX_RING_SIZE; i++) for (i = 0; i < RX_RING_SIZE; i++)
if (vp->rx_skbuff[i]) { if (vp->rx_skbuff[i]) {
pci_unmap_single( vp->pdev, le32_to_cpu(vp->rx_ring[i].addr), pci_unmap_single( VORTEX_PCI(vp), le32_to_cpu(vp->rx_ring[i].addr),
PKT_BUF_SZ, PCI_DMA_FROMDEVICE); PKT_BUF_SZ, PCI_DMA_FROMDEVICE);
dev_kfree_skb(vp->rx_skbuff[i]); dev_kfree_skb(vp->rx_skbuff[i]);
vp->rx_skbuff[i] = 0; vp->rx_skbuff[i] = 0;
...@@ -2614,12 +2682,12 @@ vortex_close(struct net_device *dev) ...@@ -2614,12 +2682,12 @@ vortex_close(struct net_device *dev)
int k; int k;
for (k=0; k<=skb_shinfo(skb)->nr_frags; k++) for (k=0; k<=skb_shinfo(skb)->nr_frags; k++)
pci_unmap_single(vp->pdev, pci_unmap_single(VORTEX_PCI(vp),
le32_to_cpu(vp->tx_ring[i].frag[k].addr), le32_to_cpu(vp->tx_ring[i].frag[k].addr),
le32_to_cpu(vp->tx_ring[i].frag[k].length)&0xFFF, le32_to_cpu(vp->tx_ring[i].frag[k].length)&0xFFF,
PCI_DMA_TODEVICE); PCI_DMA_TODEVICE);
#else #else
pci_unmap_single(vp->pdev, le32_to_cpu(vp->tx_ring[i].addr), skb->len, PCI_DMA_TODEVICE); pci_unmap_single(VORTEX_PCI(vp), le32_to_cpu(vp->tx_ring[i].addr), skb->len, PCI_DMA_TODEVICE);
#endif #endif
dev_kfree_skb(skb); dev_kfree_skb(skb);
vp->tx_skbuff[i] = 0; vp->tx_skbuff[i] = 0;
...@@ -2738,11 +2806,15 @@ static int netdev_ethtool_ioctl(struct net_device *dev, void *useraddr) ...@@ -2738,11 +2806,15 @@ static int netdev_ethtool_ioctl(struct net_device *dev, void *useraddr)
struct ethtool_drvinfo info = {ETHTOOL_GDRVINFO}; struct ethtool_drvinfo info = {ETHTOOL_GDRVINFO};
strcpy(info.driver, DRV_NAME); strcpy(info.driver, DRV_NAME);
strcpy(info.version, DRV_VERSION); strcpy(info.version, DRV_VERSION);
if (vp->pdev) if (VORTEX_PCI(vp))
strcpy(info.bus_info, vp->pdev->slot_name); strcpy(info.bus_info, VORTEX_PCI(vp)->slot_name);
else else {
sprintf(info.bus_info, "EISA 0x%lx %d", if (VORTEX_EISA(vp))
dev->base_addr, dev->irq); sprintf (info.bus_info, vp->gendev->bus_id);
else
sprintf(info.bus_info, "EISA 0x%lx %d",
dev->base_addr, dev->irq);
}
if (copy_to_user(useraddr, &info, sizeof(info))) if (copy_to_user(useraddr, &info, sizeof(info)))
return -EFAULT; return -EFAULT;
return 0; return 0;
...@@ -2924,8 +2996,8 @@ static void acpi_set_WOL(struct net_device *dev) ...@@ -2924,8 +2996,8 @@ static void acpi_set_WOL(struct net_device *dev)
outw(RxEnable, ioaddr + EL3_CMD); outw(RxEnable, ioaddr + EL3_CMD);
/* Change the power state to D3; RxEnable doesn't take effect. */ /* Change the power state to D3; RxEnable doesn't take effect. */
pci_enable_wake(vp->pdev, 0, 1); pci_enable_wake(VORTEX_PCI(vp), 0, 1);
pci_set_power_state(vp->pdev, 3); pci_set_power_state(VORTEX_PCI(vp), 3);
} }
...@@ -2935,7 +3007,7 @@ static void __devexit vortex_remove_one (struct pci_dev *pdev) ...@@ -2935,7 +3007,7 @@ static void __devexit vortex_remove_one (struct pci_dev *pdev)
struct vortex_private *vp; struct vortex_private *vp;
if (!dev) { if (!dev) {
printk("vortex_remove_one called for EISA device!\n"); printk("vortex_remove_one called for Compaq device!\n");
BUG(); BUG();
} }
...@@ -2949,10 +3021,10 @@ static void __devexit vortex_remove_one (struct pci_dev *pdev) ...@@ -2949,10 +3021,10 @@ static void __devexit vortex_remove_one (struct pci_dev *pdev)
/* Should really use issue_and_wait() here */ /* Should really use issue_and_wait() here */
outw(TotalReset|0x14, dev->base_addr + EL3_CMD); outw(TotalReset|0x14, dev->base_addr + EL3_CMD);
if (vp->pdev && vp->enable_wol) { if (VORTEX_PCI(vp) && vp->enable_wol) {
pci_set_power_state(vp->pdev, 0); /* Go active */ pci_set_power_state(VORTEX_PCI(vp), 0); /* Go active */
if (vp->pm_state_valid) if (vp->pm_state_valid)
pci_restore_state(vp->pdev, vp->power_state); pci_restore_state(VORTEX_PCI(vp), vp->power_state);
} }
pci_free_consistent(pdev, pci_free_consistent(pdev,
...@@ -3000,24 +3072,23 @@ static int __init vortex_init (void) ...@@ -3000,24 +3072,23 @@ static int __init vortex_init (void)
static void __exit vortex_eisa_cleanup (void) static void __exit vortex_eisa_cleanup (void)
{ {
struct net_device *dev, *tmp;
struct vortex_private *vp; struct vortex_private *vp;
long ioaddr; long ioaddr;
dev = root_vortex_eisa_dev; #ifdef CONFIG_EISA
/* Take care of the EISA devices */
while (dev) { eisa_driver_unregister (&vortex_eisa_driver);
vp = dev->priv; #endif
ioaddr = dev->base_addr;
if (compaq_net_device) {
vp = compaq_net_device->priv;
ioaddr = compaq_net_device->base_addr;
unregister_netdev (dev); unregister_netdev (compaq_net_device);
outw (TotalReset, ioaddr + EL3_CMD); outw (TotalReset, ioaddr + EL3_CMD);
release_region (ioaddr, VORTEX_TOTAL_SIZE); release_region (ioaddr, VORTEX_TOTAL_SIZE);
tmp = dev; kfree (compaq_net_device);
dev = vp->next_module;
kfree (tmp);
} }
} }
......
...@@ -55,7 +55,6 @@ extern int hp_probe(struct net_device *dev); ...@@ -55,7 +55,6 @@ extern int hp_probe(struct net_device *dev);
extern int hp_plus_probe(struct net_device *dev); extern int hp_plus_probe(struct net_device *dev);
extern int express_probe(struct net_device *); extern int express_probe(struct net_device *);
extern int eepro_probe(struct net_device *); extern int eepro_probe(struct net_device *);
extern int el3_probe(struct net_device *);
extern int at1500_probe(struct net_device *); extern int at1500_probe(struct net_device *);
extern int at1700_probe(struct net_device *); extern int at1700_probe(struct net_device *);
extern int fmv18x_probe(struct net_device *); extern int fmv18x_probe(struct net_device *);
...@@ -210,9 +209,6 @@ static struct devprobe mca_probes[] __initdata = { ...@@ -210,9 +209,6 @@ static struct devprobe mca_probes[] __initdata = {
* look for EISA/PCI/MCA cards in addition to ISA cards). * look for EISA/PCI/MCA cards in addition to ISA cards).
*/ */
static struct devprobe isa_probes[] __initdata = { static struct devprobe isa_probes[] __initdata = {
#ifdef CONFIG_EL3 /* ISA, EISA, MCA 3c5x9 */
{el3_probe, 0},
#endif
#ifdef CONFIG_HP100 /* ISA, EISA & PCI */ #ifdef CONFIG_HP100 /* ISA, EISA & PCI */
{hp100_probe, 0}, {hp100_probe, 0},
#endif #endif
......
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