]> git.karo-electronics.de Git - linux-beck.git/commitdiff
staging: comedi: pcl711: fix software trigger for board->is_8112
authorH Hartley Sweeten <hsweeten@visionengravers.com>
Fri, 20 Sep 2013 23:41:39 +0000 (16:41 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 25 Sep 2013 22:59:59 +0000 (15:59 -0700)
The acl-8112 boards also need to write a value to the software
trigger register in order to start an A/D conversion. Remove the
if (!board->is_8112) test so that the write is always done.

Also, the analog input mode does not need to be set each time for
multiple samples. Move the pcl711_ai_set_mode() out of the for loop.

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/pcl711.c

index 945e0bc111fb05d701da0bf047b557599a970b63..f8401b738f1ac9d94bff2963f3b7729bd254896f 100644 (file)
@@ -91,7 +91,8 @@ supported.
 #define PCL711_MODE_PACER      (4 << 0)
 #define PCL711_MODE_PACER_IRQ  (6 << 0)
 #define PCL711_MODE_IRQ(x)     (((x) & 0x7) << 4)
-#define PCL711_SOFTTRIG                0x0c
+#define PCL711_SOFTTRIG_REG    0x0c
+#define PCL711_SOFTTRIG                (0 << 0)  /* any value will work */
 #define PCL711_DO_LO           0x0d
 #define PCL711_DO_HI           0x0e
 
@@ -280,17 +281,15 @@ static int pcl711_ai_wait_for_eoc(struct comedi_device *dev,
 static int pcl711_ai_insn(struct comedi_device *dev, struct comedi_subdevice *s,
                          struct comedi_insn *insn, unsigned int *data)
 {
-       const struct pcl711_board *board = comedi_board(dev);
        int ret;
        int n;
 
        pcl711_set_changain(dev, insn->chanspec);
 
-       for (n = 0; n < insn->n; n++) {
-               pcl711_ai_set_mode(dev, PCL711_MODE_SOFTTRIG);
+       pcl711_ai_set_mode(dev, PCL711_MODE_SOFTTRIG);
 
-               if (!board->is_8112)
-                       outb(0, dev->iobase + PCL711_SOFTTRIG);
+       for (n = 0; n < insn->n; n++) {
+               outb(PCL711_SOFTTRIG, dev->iobase + PCL711_SOFTTRIG_REG);
 
                ret = pcl711_ai_wait_for_eoc(dev, 100);
                if (ret)