Commit abc45592 authored by Ben Hutchings's avatar Ben Hutchings Committed by David S. Miller

via-ircc: Use pci_{get, set}_drvdata() instead of static pointer variable

via-ircc still maintains its own array of device pointers in Linux 2.4
style.  Worse, it always uses index 0, so it will crash if there are
multiple suitable devices in the system.
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 93ca3bb5
...@@ -75,15 +75,9 @@ static int dongle_id = 0; /* default: probe */ ...@@ -75,15 +75,9 @@ static int dongle_id = 0; /* default: probe */
/* We can't guess the type of connected dongle, user *must* supply it. */ /* We can't guess the type of connected dongle, user *must* supply it. */
module_param(dongle_id, int, 0); module_param(dongle_id, int, 0);
/* FIXME : we should not need this, because instances should be automatically
* managed by the PCI layer. Especially that we seem to only be using the
* first entry. Jean II */
/* Max 4 instances for now */
static struct via_ircc_cb *dev_self[] = { NULL, NULL, NULL, NULL };
/* Some prototypes */ /* Some prototypes */
static int via_ircc_open(int i, chipio_t * info, unsigned int id); static int via_ircc_open(struct pci_dev *pdev, chipio_t * info,
static int via_ircc_close(struct via_ircc_cb *self); unsigned int id);
static int via_ircc_dma_receive(struct via_ircc_cb *self); static int via_ircc_dma_receive(struct via_ircc_cb *self);
static int via_ircc_dma_receive_complete(struct via_ircc_cb *self, static int via_ircc_dma_receive_complete(struct via_ircc_cb *self,
int iobase); int iobase);
...@@ -215,7 +209,7 @@ static int __devinit via_init_one (struct pci_dev *pcidev, const struct pci_devi ...@@ -215,7 +209,7 @@ static int __devinit via_init_one (struct pci_dev *pcidev, const struct pci_devi
pci_write_config_byte(pcidev,0x42,(bTmp | 0xf0)); pci_write_config_byte(pcidev,0x42,(bTmp | 0xf0));
pci_write_config_byte(pcidev,0x5a,0xc0); pci_write_config_byte(pcidev,0x5a,0xc0);
WriteLPCReg(0x28, 0x70 ); WriteLPCReg(0x28, 0x70 );
if (via_ircc_open(0, &info,0x3076) == 0) if (via_ircc_open(pcidev, &info, 0x3076) == 0)
rc=0; rc=0;
} else } else
rc = -ENODEV; //IR not turn on rc = -ENODEV; //IR not turn on
...@@ -254,7 +248,7 @@ static int __devinit via_init_one (struct pci_dev *pcidev, const struct pci_devi ...@@ -254,7 +248,7 @@ static int __devinit via_init_one (struct pci_dev *pcidev, const struct pci_devi
info.irq=FirIRQ; info.irq=FirIRQ;
info.dma=FirDRQ1; info.dma=FirDRQ1;
info.dma2=FirDRQ0; info.dma2=FirDRQ0;
if (via_ircc_open(0, &info,0x3096) == 0) if (via_ircc_open(pcidev, &info, 0x3096) == 0)
rc=0; rc=0;
} else } else
rc = -ENODEV; //IR not turn on !!!!! rc = -ENODEV; //IR not turn on !!!!!
...@@ -264,48 +258,10 @@ static int __devinit via_init_one (struct pci_dev *pcidev, const struct pci_devi ...@@ -264,48 +258,10 @@ static int __devinit via_init_one (struct pci_dev *pcidev, const struct pci_devi
return rc; return rc;
} }
/*
* Function via_ircc_clean ()
*
* Close all configured chips
*
*/
static void via_ircc_clean(void)
{
int i;
IRDA_DEBUG(3, "%s()\n", __func__);
for (i=0; i < ARRAY_SIZE(dev_self); i++) {
if (dev_self[i])
via_ircc_close(dev_self[i]);
}
}
static void __devexit via_remove_one (struct pci_dev *pdev)
{
IRDA_DEBUG(3, "%s()\n", __func__);
/* FIXME : This is ugly. We should use pci_get_drvdata(pdev);
* to get our driver instance and call directly via_ircc_close().
* See vlsi_ir for details...
* Jean II */
via_ircc_clean();
/* FIXME : This should be in via_ircc_close(), because here we may
* theoritically disable still configured devices :-( - Jean II */
pci_disable_device(pdev);
}
static void __exit via_ircc_cleanup(void) static void __exit via_ircc_cleanup(void)
{ {
IRDA_DEBUG(3, "%s()\n", __func__); IRDA_DEBUG(3, "%s()\n", __func__);
/* FIXME : This should be redundant, as pci_unregister_driver()
* should call via_remove_one() on each device.
* Jean II */
via_ircc_clean();
/* Cleanup all instances of the driver */ /* Cleanup all instances of the driver */
pci_unregister_driver (&via_driver); pci_unregister_driver (&via_driver);
} }
...@@ -324,12 +280,13 @@ static const struct net_device_ops via_ircc_fir_ops = { ...@@ -324,12 +280,13 @@ static const struct net_device_ops via_ircc_fir_ops = {
}; };
/* /*
* Function via_ircc_open (iobase, irq) * Function via_ircc_open(pdev, iobase, irq)
* *
* Open driver instance * Open driver instance
* *
*/ */
static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id) static __devinit int via_ircc_open(struct pci_dev *pdev, chipio_t * info,
unsigned int id)
{ {
struct net_device *dev; struct net_device *dev;
struct via_ircc_cb *self; struct via_ircc_cb *self;
...@@ -337,9 +294,6 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id) ...@@ -337,9 +294,6 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id)
IRDA_DEBUG(3, "%s()\n", __func__); IRDA_DEBUG(3, "%s()\n", __func__);
if (i >= ARRAY_SIZE(dev_self))
return -ENOMEM;
/* Allocate new instance of the driver */ /* Allocate new instance of the driver */
dev = alloc_irdadev(sizeof(struct via_ircc_cb)); dev = alloc_irdadev(sizeof(struct via_ircc_cb));
if (dev == NULL) if (dev == NULL)
...@@ -349,13 +303,8 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id) ...@@ -349,13 +303,8 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id)
self->netdev = dev; self->netdev = dev;
spin_lock_init(&self->lock); spin_lock_init(&self->lock);
/* FIXME : We should store our driver instance in the PCI layer, pci_set_drvdata(pdev, self);
* using pci_set_drvdata(), not in this array.
* See vlsi_ir for details... - Jean II */
/* FIXME : 'i' is always 0 (see via_init_one()) :-( - Jean II */
/* Need to store self somewhere */
dev_self[i] = self;
self->index = i;
/* Initialize Resource */ /* Initialize Resource */
self->io.cfg_base = info->cfg_base; self->io.cfg_base = info->cfg_base;
self->io.fir_base = info->fir_base; self->io.fir_base = info->fir_base;
...@@ -463,25 +412,24 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id) ...@@ -463,25 +412,24 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id)
err_out2: err_out2:
release_region(self->io.fir_base, self->io.fir_ext); release_region(self->io.fir_base, self->io.fir_ext);
err_out1: err_out1:
pci_set_drvdata(pdev, NULL);
free_netdev(dev); free_netdev(dev);
dev_self[i] = NULL;
return err; return err;
} }
/* /*
* Function via_ircc_close (self) * Function via_remove_one(pdev)
* *
* Close driver instance * Close driver instance
* *
*/ */
static int via_ircc_close(struct via_ircc_cb *self) static void __devexit via_remove_one(struct pci_dev *pdev)
{ {
struct via_ircc_cb *self = pci_get_drvdata(pdev);
int iobase; int iobase;
IRDA_DEBUG(3, "%s()\n", __func__); IRDA_DEBUG(3, "%s()\n", __func__);
IRDA_ASSERT(self != NULL, return -1;);
iobase = self->io.fir_base; iobase = self->io.fir_base;
ResetChip(iobase, 5); //hardware reset. ResetChip(iobase, 5); //hardware reset.
...@@ -498,11 +446,11 @@ static int via_ircc_close(struct via_ircc_cb *self) ...@@ -498,11 +446,11 @@ static int via_ircc_close(struct via_ircc_cb *self)
if (self->rx_buff.head) if (self->rx_buff.head)
dma_free_coherent(NULL, self->rx_buff.truesize, dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma); self->rx_buff.head, self->rx_buff_dma);
dev_self[self->index] = NULL; pci_set_drvdata(pdev, NULL);
free_netdev(self->netdev); free_netdev(self->netdev);
return 0; pci_disable_device(pdev);
} }
/* /*
......
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