Commit c44253ad authored by Jochen Friedrich's avatar Jochen Friedrich Committed by Jeff Garzik

[PATCH] tms380tr patch 1/3 (bug fix)

Hi Jeff,

this fixes some problems partly introduced in the latest token ring
update:
- mix of alloc_trdev(0) and alloc_trdev(sizeof(struct net_local)) confused
  memory management.
- initialization of proteon and sknet cards was broken.
- proteon_close() and skisa_close() deleted.

--jochen

 abyss.c    |    2 -
 madgemc.c  |    2 -
 proteon.c  |   91 ++++++++++++++++++++++++-------------------------------
 skisa.c    |  100 +++++++++++++++++++++++++------------------------------------
 tms380tr.c |   41 +++++++++----------------
 tmspci.c   |    2 -
 6 files changed, 100 insertions(+), 138 deletions(-)
parent 2d8f0320
...@@ -112,7 +112,7 @@ static int __devinit abyss_attach(struct pci_dev *pdev, const struct pci_device_ ...@@ -112,7 +112,7 @@ static int __devinit abyss_attach(struct pci_dev *pdev, const struct pci_device_
/* At this point we have found a valid card. */ /* At this point we have found a valid card. */
dev = alloc_trdev(0); dev = alloc_trdev(sizeof(struct net_local));
if (!dev) if (!dev)
return -ENOMEM; return -ENOMEM;
......
...@@ -177,7 +177,7 @@ static int __init madgemc_probe(void) ...@@ -177,7 +177,7 @@ static int __init madgemc_probe(void)
if (versionprinted++ == 0) if (versionprinted++ == 0)
printk("%s", version); printk("%s", version);
dev = alloc_trdev(0); dev = alloc_trdev(sizeof(struct net_local));
if (dev == NULL) { if (dev == NULL) {
printk("madgemc: unable to allocate dev space\n"); printk("madgemc: unable to allocate dev space\n");
if (madgemc_card_list) if (madgemc_card_list)
......
...@@ -65,7 +65,6 @@ static char cardname[] = "Proteon 1392\0"; ...@@ -65,7 +65,6 @@ static char cardname[] = "Proteon 1392\0";
struct net_device *proteon_probe(int unit); struct net_device *proteon_probe(int unit);
static int proteon_open(struct net_device *dev); static int proteon_open(struct net_device *dev);
static int proteon_close(struct net_device *dev);
static void proteon_read_eeprom(struct net_device *dev); static void proteon_read_eeprom(struct net_device *dev);
static unsigned short proteon_setnselout_pins(struct net_device *dev); static unsigned short proteon_setnselout_pins(struct net_device *dev);
...@@ -117,21 +116,15 @@ static int __init proteon_probe1(struct net_device *dev, int ioaddr) ...@@ -117,21 +116,15 @@ static int __init proteon_probe1(struct net_device *dev, int ioaddr)
return -ENODEV; return -ENODEV;
} }
struct net_device * __init proteon_probe(int unit) static int __init setup_card(struct net_device *dev)
{ {
struct net_device *dev = alloc_trdev(sizeof(struct net_local));
struct net_local *tp; struct net_local *tp;
static int versionprinted; static int versionprinted;
const unsigned *port; const unsigned *port;
int j,err = 0; int j,err = 0;
if (!dev) if (!dev)
return ERR_PTR(-ENOMEM); return -ENOMEM;
if (unit >= 0) {
sprintf(dev->name, "tr%d", unit);
netdev_boot_setup_check(dev);
}
SET_MODULE_OWNER(dev); SET_MODULE_OWNER(dev);
if (dev->base_addr) /* probe specific location */ if (dev->base_addr) /* probe specific location */
...@@ -178,7 +171,7 @@ struct net_device * __init proteon_probe(int unit) ...@@ -178,7 +171,7 @@ struct net_device * __init proteon_probe(int unit)
tp->tmspriv = NULL; tp->tmspriv = NULL;
dev->open = proteon_open; dev->open = proteon_open;
dev->stop = proteon_close; dev->stop = tms380tr_close;
if (dev->irq == 0) if (dev->irq == 0)
{ {
...@@ -257,7 +250,7 @@ struct net_device * __init proteon_probe(int unit) ...@@ -257,7 +250,7 @@ struct net_device * __init proteon_probe(int unit)
if (err) if (err)
goto out; goto out;
return dev; return 0;
out: out:
free_dma(dev->dma); free_dma(dev->dma);
out2: out2:
...@@ -266,6 +259,29 @@ struct net_device * __init proteon_probe(int unit) ...@@ -266,6 +259,29 @@ struct net_device * __init proteon_probe(int unit)
tmsdev_term(dev); tmsdev_term(dev);
out4: out4:
release_region(dev->base_addr, PROTEON_IO_EXTENT); release_region(dev->base_addr, PROTEON_IO_EXTENT);
return err;
}
struct net_device * __init proteon_probe(int unit)
{
struct net_device *dev = alloc_trdev(sizeof(struct net_local));
int err = 0;
if (!dev)
return ERR_PTR(-ENOMEM);
if (unit >= 0) {
sprintf(dev->name, "tr%d", unit);
netdev_boot_setup_check(dev);
}
err = setup_card(dev);
if (err)
goto out;
return dev;
out:
free_netdev(dev); free_netdev(dev);
return ERR_PTR(err); return ERR_PTR(err);
} }
...@@ -333,14 +349,7 @@ static int proteon_open(struct net_device *dev) ...@@ -333,14 +349,7 @@ static int proteon_open(struct net_device *dev)
val |= i; val |= i;
outb(val, dev->base_addr + 0x13); outb(val, dev->base_addr + 0x13);
tms380tr_open(dev); return tms380tr_open(dev);
return 0;
}
static int proteon_close(struct net_device *dev)
{
tms380tr_close(dev);
return 0;
} }
#ifdef MODULE #ifdef MODULE
...@@ -359,45 +368,25 @@ MODULE_PARM(dma, "1-" __MODULE_STRING(ISATR_MAX_ADAPTERS) "i"); ...@@ -359,45 +368,25 @@ MODULE_PARM(dma, "1-" __MODULE_STRING(ISATR_MAX_ADAPTERS) "i");
static struct net_device *proteon_dev[ISATR_MAX_ADAPTERS]; static struct net_device *proteon_dev[ISATR_MAX_ADAPTERS];
static struct net_device * __init setup_card(unsigned long io, unsigned irq, unsigned char dma)
{
struct net_device *dev = alloc_trdev(sizeof(struct net_local));
int err;
if (!dev)
return ERR_PTR(-ENOMEM);
dev->irq = irq;
dev->dma = dma;
err = proteon_probe1(dev, io);
if (err)
goto out;
err = register_netdev(dev);
if (err)
goto out1;
return dev;
out1:
release_region(dev->base_addr, PROTEON_IO_EXTENT);
free_irq(dev->irq, dev);
free_dma(dev->dma);
tmsdev_term(dev);
out:
free_netdev(dev);
return ERR_PTR(err);
}
int init_module(void) int init_module(void)
{ {
struct net_device *dev; struct net_device *dev;
int i, num = 0; int i, num = 0, err = 0;
for (i = 0; i < ISATR_MAX_ADAPTERS ; i++) { for (i = 0; i < ISATR_MAX_ADAPTERS ; i++) {
dev = io[0] ? setup_card(io[i], irq[i], dma[i]) dev = alloc_trdev(sizeof(struct net_local));
: proteon_probe(-1); if (!dev)
if (!IS_ERR(dev)) { continue;
dev->base_addr = io[i];
dev->irq = irq[i];
dev->dma = dma[i];
err = setup_card(dev);
if (!err) {
proteon_dev[i] = dev; proteon_dev[i] = dev;
++num; ++num;
} else {
free_netdev(dev);
} }
} }
......
...@@ -69,8 +69,8 @@ static int dmalist[] __initdata = { ...@@ -69,8 +69,8 @@ static int dmalist[] __initdata = {
static char isa_cardname[] = "SK NET TR 4/16 ISA\0"; static char isa_cardname[] = "SK NET TR 4/16 ISA\0";
struct net_device *sk_isa_probe(int unit);
static int sk_isa_open(struct net_device *dev); static int sk_isa_open(struct net_device *dev);
static int sk_isa_close(struct net_device *dev);
static void sk_isa_read_eeprom(struct net_device *dev); static void sk_isa_read_eeprom(struct net_device *dev);
static unsigned short sk_isa_setnselout_pins(struct net_device *dev); static unsigned short sk_isa_setnselout_pins(struct net_device *dev);
...@@ -133,21 +133,15 @@ static int __init sk_isa_probe1(struct net_device *dev, int ioaddr) ...@@ -133,21 +133,15 @@ static int __init sk_isa_probe1(struct net_device *dev, int ioaddr)
return 0; return 0;
} }
struct net_device * __init sk_isa_probe(int unit) static int __init setup_card(struct net_device *dev)
{ {
struct net_device *dev = alloc_trdev(sizeof(struct net_local));
struct net_local *tp; struct net_local *tp;
static int versionprinted; static int versionprinted;
const unsigned *port; const unsigned *port;
int j, err = 0; int j, err = 0;
if (!dev) if (!dev)
return ERR_PTR(-ENOMEM); return -ENOMEM;
if (unit >= 0) {
sprintf(dev->name, "tr%d", unit);
netdev_boot_setup_check(dev);
}
SET_MODULE_OWNER(dev); SET_MODULE_OWNER(dev);
if (dev->base_addr) /* probe specific location */ if (dev->base_addr) /* probe specific location */
...@@ -194,7 +188,7 @@ struct net_device * __init sk_isa_probe(int unit) ...@@ -194,7 +188,7 @@ struct net_device * __init sk_isa_probe(int unit)
tp->tmspriv = NULL; tp->tmspriv = NULL;
dev->open = sk_isa_open; dev->open = sk_isa_open;
dev->stop = sk_isa_close; dev->stop = tms380tr_close;
if (dev->irq == 0) if (dev->irq == 0)
{ {
...@@ -273,7 +267,7 @@ struct net_device * __init sk_isa_probe(int unit) ...@@ -273,7 +267,7 @@ struct net_device * __init sk_isa_probe(int unit)
if (err) if (err)
goto out; goto out;
return dev; return 0;
out: out:
free_dma(dev->dma); free_dma(dev->dma);
out2: out2:
...@@ -282,6 +276,28 @@ struct net_device * __init sk_isa_probe(int unit) ...@@ -282,6 +276,28 @@ struct net_device * __init sk_isa_probe(int unit)
tmsdev_term(dev); tmsdev_term(dev);
out4: out4:
release_region(dev->base_addr, SK_ISA_IO_EXTENT); release_region(dev->base_addr, SK_ISA_IO_EXTENT);
return err;
}
struct net_device * __init sk_isa_probe(int unit)
{
struct net_device *dev = alloc_trdev(sizeof(struct net_local));
int err = 0;
if (!dev)
return ERR_PTR(-ENOMEM);
if (unit >= 0) {
sprintf(dev->name, "tr%d", unit);
netdev_boot_setup_check(dev);
}
err = setup_card(dev);
if (err)
goto out;
return dev;
out:
free_netdev(dev); free_netdev(dev);
return ERR_PTR(err); return ERR_PTR(err);
} }
...@@ -342,22 +358,13 @@ static int sk_isa_open(struct net_device *dev) ...@@ -342,22 +358,13 @@ static int sk_isa_open(struct net_device *dev)
val &= oldval; val &= oldval;
sk_isa_sifwriteb(dev, val, POSREG); sk_isa_sifwriteb(dev, val, POSREG);
tms380tr_open(dev); return tms380tr_open(dev);
return 0;
}
static int sk_isa_close(struct net_device *dev)
{
tms380tr_close(dev);
return 0;
} }
#ifdef MODULE #ifdef MODULE
#define ISATR_MAX_ADAPTERS 3 #define ISATR_MAX_ADAPTERS 3
static struct net_device *sk_isa_dev[ISATR_MAX_ADAPTERS];
static int io[ISATR_MAX_ADAPTERS]; static int io[ISATR_MAX_ADAPTERS];
static int irq[ISATR_MAX_ADAPTERS]; static int irq[ISATR_MAX_ADAPTERS];
static int dma[ISATR_MAX_ADAPTERS]; static int dma[ISATR_MAX_ADAPTERS];
...@@ -368,51 +375,28 @@ MODULE_PARM(io, "1-" __MODULE_STRING(ISATR_MAX_ADAPTERS) "i"); ...@@ -368,51 +375,28 @@ MODULE_PARM(io, "1-" __MODULE_STRING(ISATR_MAX_ADAPTERS) "i");
MODULE_PARM(irq, "1-" __MODULE_STRING(ISATR_MAX_ADAPTERS) "i"); MODULE_PARM(irq, "1-" __MODULE_STRING(ISATR_MAX_ADAPTERS) "i");
MODULE_PARM(dma, "1-" __MODULE_STRING(ISATR_MAX_ADAPTERS) "i"); MODULE_PARM(dma, "1-" __MODULE_STRING(ISATR_MAX_ADAPTERS) "i");
static struct net_device * __init setup_card(unsigned long io, unsigned irq, unsigned char dma) static struct net_device *sk_isa_dev[ISATR_MAX_ADAPTERS];
{
struct net_device *dev = alloc_trdev(sizeof(struct net_local));
int err;
if (!dev)
return ERR_PTR(-ENOMEM);
dev->base_addr = io;
dev->irq = irq;
dev->dma = dma;
err = sk_isa_probe1(dev, io);
if (err)
goto out;
err = register_netdev(dev);
if (err)
goto out1;
return dev;
out1:
release_region(dev->base_addr, SK_ISA_IO_EXTENT);
free_irq(dev->irq, dev);
free_dma(dev->dma);
tmsdev_term(dev);
out:
free_netdev(dev);
return ERR_PTR(err);
}
int init_module(void) int init_module(void)
{ {
struct net_device *dev; struct net_device *dev;
int i, num; int i, num = 0, err = 0;
num = 0;
for (i = 0; i < ISATR_MAX_ADAPTERS ; i++) { for (i = 0; i < ISATR_MAX_ADAPTERS ; i++) {
if (io[0]) /* Only probe addresses from command line */ dev = alloc_trdev(sizeof(struct net_local));
dev = setup_card(io[i], irq[i], dma[i]); if (!dev)
else continue;
dev = sk_isa_probe(-1);
if (!IS_ERR(dev)) { dev->base_addr = io[i];
dev->irq = irq[i];
dev->dma = dma[i];
err = setup_card(dev);
if (!err) {
sk_isa_dev[i] = dev; sk_isa_dev[i] = dev;
++num; ++num;
} else {
free_netdev(dev);
} }
} }
......
...@@ -246,6 +246,7 @@ int tms380tr_open(struct net_device *dev) ...@@ -246,6 +246,7 @@ int tms380tr_open(struct net_device *dev)
/* init the spinlock */ /* init the spinlock */
spin_lock_init(&tp->lock); spin_lock_init(&tp->lock);
init_timer(&tp->timer);
/* Reset the hardware here. Don't forget to set the station address. */ /* Reset the hardware here. Don't forget to set the station address. */
...@@ -266,7 +267,6 @@ int tms380tr_open(struct net_device *dev) ...@@ -266,7 +267,6 @@ int tms380tr_open(struct net_device *dev)
return (-1); return (-1);
} }
init_timer(&tp->timer);
tp->timer.expires = jiffies + 30*HZ; tp->timer.expires = jiffies + 30*HZ;
tp->timer.function = tms380tr_timer_end_wait; tp->timer.function = tms380tr_timer_end_wait;
tp->timer.data = (unsigned long)dev; tp->timer.data = (unsigned long)dev;
...@@ -2342,23 +2342,13 @@ void tmsdev_term(struct net_device *dev) ...@@ -2342,23 +2342,13 @@ void tmsdev_term(struct net_device *dev)
tp = (struct net_local *) dev->priv; tp = (struct net_local *) dev->priv;
pci_unmap_single(tp->pdev, tp->dmabuffer, sizeof(struct net_local), pci_unmap_single(tp->pdev, tp->dmabuffer, sizeof(struct net_local),
PCI_DMA_BIDIRECTIONAL); PCI_DMA_BIDIRECTIONAL);
kfree(dev->priv);
} }
int tmsdev_init(struct net_device *dev, unsigned long dmalimit, int tmsdev_init(struct net_device *dev, unsigned long dmalimit,
struct pci_dev *pdev) struct pci_dev *pdev)
{ {
if (dev->priv == NULL)
{
struct net_local *tms_local; struct net_local *tms_local;
dev->priv = kmalloc(sizeof(struct net_local), GFP_KERNEL | GFP_DMA);
if (dev->priv == NULL)
{
printk(KERN_INFO "%s: Out of memory for DMA\n",
dev->name);
return -ENOMEM;
}
memset(dev->priv, 0, sizeof(struct net_local)); memset(dev->priv, 0, sizeof(struct net_local));
tms_local = (struct net_local *)dev->priv; tms_local = (struct net_local *)dev->priv;
init_waitqueue_head(&tms_local->wait_for_tok_int); init_waitqueue_head(&tms_local->wait_for_tok_int);
...@@ -2373,7 +2363,6 @@ int tmsdev_init(struct net_device *dev, unsigned long dmalimit, ...@@ -2373,7 +2363,6 @@ int tmsdev_init(struct net_device *dev, unsigned long dmalimit,
tmsdev_term(dev); tmsdev_term(dev);
return -ENOMEM; return -ENOMEM;
} }
}
/* These can be overridden by the card driver if needed */ /* These can be overridden by the card driver if needed */
dev->open = tms380tr_open; dev->open = tms380tr_open;
......
...@@ -112,7 +112,7 @@ static int __devinit tms_pci_attach(struct pci_dev *pdev, const struct pci_devic ...@@ -112,7 +112,7 @@ static int __devinit tms_pci_attach(struct pci_dev *pdev, const struct pci_devic
pci_ioaddr = pci_resource_start (pdev, 0); pci_ioaddr = pci_resource_start (pdev, 0);
/* At this point we have found a valid card. */ /* At this point we have found a valid card. */
dev = alloc_trdev(0); dev = alloc_trdev(sizeof(struct net_local));
if (!dev) if (!dev)
return -ENOMEM; return -ENOMEM;
SET_MODULE_OWNER(dev); SET_MODULE_OWNER(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