]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
staging: comedi: icp_multi: remove board reset during (*detach)
authorH Hartley Sweeten <hsweeten@visionengravers.com>
Wed, 7 Oct 2015 21:52:48 +0000 (14:52 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 13 Oct 2015 05:56:42 +0000 (22:56 -0700)
The icp_multi_reset() function currnelt does the following during the
(*auto_attach) and (*detach) of this driver:

  1) disables all interrupts and clears any pending requests
  2) resets the analog output channels to 0V (0..5V range)
  3) sets all digital output channels to 0

Interrupts are not used by this driver so the disable/clear when
detaching is not necessary.

Depending on the use, reseting the analog and digital outputs when the
driver is detached might not be desireable.

Remove the board reset during the (*detach) and use comedi_pci_detach()
directly.

Signed-off-by: H Hartley Sweeten <hsweeten@visionengravers.com>
Reviewed-by: Ian Abbott <abbotti@mev.co.uk>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/comedi/drivers/icp_multi.c

index 17cf514f8bc037d6301795ece3918e35a8982613..b76b594ad0388938596590f269559b44d16413b9 100644 (file)
@@ -313,18 +313,11 @@ static int icp_multi_auto_attach(struct comedi_device *dev,
        return 0;
 }
 
-static void icp_multi_detach(struct comedi_device *dev)
-{
-       if (dev->mmio)
-               icp_multi_reset(dev);
-       comedi_pci_detach(dev);
-}
-
 static struct comedi_driver icp_multi_driver = {
        .driver_name    = "icp_multi",
        .module         = THIS_MODULE,
        .auto_attach    = icp_multi_auto_attach,
-       .detach         = icp_multi_detach,
+       .detach         = comedi_pci_detach,
 };
 
 static int icp_multi_pci_probe(struct pci_dev *dev,