staging: comedi: comedi_pcmcia: allow drivers to use a custom conf_check()
authorH Hartley Sweeten <hsweeten@visionengravers.com>
Wed, 6 Feb 2013 01:16:07 +0000 (18:16 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 6 Feb 2013 02:16:19 +0000 (18:16 -0800)
Allow comedi pcmcia drivers to use a custom conf_check() when calling
comedi_pcmcia_enable() to enable the pcmcia device. If a conf_check()
is not passed the internal comedi_pcmcia_conf_check() will be used.

Signed-off-by: H Hartley Sweeten <hsweeten@visionengravers.com>
Cc: Ian Abbott <abbotti@mev.co.uk>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/comedi/comedi_pcmcia.c
drivers/staging/comedi/comedidev.h
drivers/staging/comedi/drivers/cb_das16_cs.c
drivers/staging/comedi/drivers/das08_cs.c
drivers/staging/comedi/drivers/ni_daq_700.c
drivers/staging/comedi/drivers/ni_daq_dio24.c
drivers/staging/comedi/drivers/ni_labpc_cs.c

index 925f12825c1b052c5c94c3e51aadd9194790c0c1..453ff3b28617ad2c5270124065e24249ada791ba 100644 (file)
@@ -49,12 +49,14 @@ static int comedi_pcmcia_conf_check(struct pcmcia_device *link,
 /**
  * comedi_pcmcia_enable() - Request the regions and enable the PCMCIA device.
  * @dev: comedi_device struct
+ * @conf_check: optional callback to check the pcmcia_device configuration
  *
  * The comedi PCMCIA driver needs to set the link->config_flags, as
  * appropriate for that driver, before calling this function in order
  * to allow pcmcia_loop_config() to do its internal autoconfiguration.
  */
-int comedi_pcmcia_enable(struct comedi_device *dev)
+int comedi_pcmcia_enable(struct comedi_device *dev,
+                        int (*conf_check)(struct pcmcia_device *, void *))
 {
        struct pcmcia_device *link = comedi_to_pcmcia_dev(dev);
        int ret;
@@ -62,7 +64,10 @@ int comedi_pcmcia_enable(struct comedi_device *dev)
        if (!link)
                return -ENODEV;
 
-       ret = pcmcia_loop_config(link, comedi_pcmcia_conf_check, NULL);
+       if (!conf_check)
+               conf_check = comedi_pcmcia_conf_check;
+
+       ret = pcmcia_loop_config(link, conf_check, NULL);
        if (ret)
                return ret;
 
index d921cd784b0086582e7dfb1ef93de26a26085ca8..f3a990b45df5f9dce3f564c4f475016af87f44d1 100644 (file)
@@ -440,7 +440,8 @@ struct pcmcia_device;
 
 struct pcmcia_device *comedi_to_pcmcia_dev(struct comedi_device *);
 
-int comedi_pcmcia_enable(struct comedi_device *);
+int comedi_pcmcia_enable(struct comedi_device *,
+                        int (*conf_check)(struct pcmcia_device *, void *));
 void comedi_pcmcia_disable(struct comedi_device *);
 
 int comedi_pcmcia_auto_config(struct pcmcia_device *, struct comedi_driver *);
index 5bbffd9f8af939ad215369399672556dafc808d2..f874fff445236bc627615dd82af30f059ae881b0 100644 (file)
@@ -413,7 +413,7 @@ static int das16cs_auto_attach(struct comedi_device *dev,
        dev->board_name = board->name;
 
        link->config_flags |= CONF_AUTO_SET_IO | CONF_ENABLE_IRQ;
-       ret = comedi_pcmcia_enable(dev);
+       ret = comedi_pcmcia_enable(dev, NULL);
        if (ret)
                return ret;
        dev->iobase = link->resource[0]->start;
index 818a609b0dbaf03af7de3fcc7acde8f234870759..cfeebe4d1ddda851136250231f5f398d89037e99 100644 (file)
@@ -81,7 +81,7 @@ static int das08_cs_auto_attach(struct comedi_device *dev,
        dev->board_ptr = &das08_cs_boards[0];
 
        link->config_flags |= CONF_AUTO_SET_IO;
-       ret = comedi_pcmcia_enable(dev);
+       ret = comedi_pcmcia_enable(dev, NULL);
        if (ret)
                return ret;
        iobase = link->resource[0]->start;
index c8f4c7d2a832c3966078ca317674cd9e01cd9ddd..9cc6092eacdd87df8d2fc4141e397d1ef085675a 100644 (file)
@@ -205,7 +205,7 @@ static int daq700_auto_attach(struct comedi_device *dev,
        dev->board_name = dev->driver->driver_name;
 
        link->config_flags |= CONF_AUTO_SET_IO;
-       ret = comedi_pcmcia_enable(dev);
+       ret = comedi_pcmcia_enable(dev, NULL);
        if (ret)
                return ret;
        dev->iobase = link->resource[0]->start;
index edfbfb315122f3377e37d1675aaad5808819edbc..32ee22dbb8588f1d12fb44e965c04c25cfebbcc3 100644 (file)
@@ -55,7 +55,7 @@ static int dio24_auto_attach(struct comedi_device *dev,
        dev->board_name = dev->driver->driver_name;
 
        link->config_flags |= CONF_AUTO_SET_IO;
-       ret = comedi_pcmcia_enable(dev);
+       ret = comedi_pcmcia_enable(dev, NULL);
                return ret;
        dev->iobase = link->resource[0]->start;
 
index 1c55de35e874a5d41e38da9841da1e3da790b9ed..be7d1413b2e513a5b4bf4f8af553eae9de117be2 100644 (file)
@@ -99,7 +99,7 @@ static int labpc_auto_attach(struct comedi_device *dev,
 
        link->config_flags |= CONF_AUTO_SET_IO |
                              CONF_ENABLE_IRQ | CONF_ENABLE_PULSE_IRQ;
-       ret = comedi_pcmcia_enable(dev);
+       ret = comedi_pcmcia_enable(dev, NULL);
        if (ret)
                return ret;
        dev->iobase = link->resource[0]->start;