staging: comedi: addi_apci_3120: fix timer (*insn_read)
authorH Hartley Sweeten <hsweeten@visionengravers.com>
Tue, 4 Nov 2014 17:55:14 +0000 (10:55 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 7 Nov 2014 17:34:04 +0000 (09:34 -0800)
The timer subdevice in this driver does not follow the comedi API.
Fix the (*insn_read) to work correctly.

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/addi-data/hwdrv_apci3120.c
drivers/staging/comedi/drivers/addi_apci_3120.c

index 0c9a6550f6443ab48b4fc4e01c61c2b82223bb9c..7c6dec1aaa45e83cf1fa8ceba7417494dc2d108a 100644 (file)
@@ -608,38 +608,3 @@ static int apci3120_write_insn_timer(struct comedi_device *dev,
 
        return insn->n;
 }
-
-/*
- * Read the Timer value
- *
- * for Timer: data[0]= Timer constant
- *
- * for watchdog: data[0] = 0 (still running)
- *                      = 1 (run down)
- */
-static int apci3120_read_insn_timer(struct comedi_device *dev,
-                                   struct comedi_subdevice *s,
-                                   struct comedi_insn *insn,
-                                   unsigned int *data)
-{
-       struct apci3120_private *devpriv = dev->private;
-       unsigned int status;
-
-       if ((devpriv->b_Timer2Mode != APCI3120_WATCHDOG)
-               && (devpriv->b_Timer2Mode != APCI3120_TIMER)) {
-               dev_err(dev->class_dev, "timer2 not configured\n");
-       }
-       if (devpriv->b_Timer2Mode == APCI3120_TIMER) {
-               data[0] = apci3120_timer_read(dev, 2);
-       } else {
-               /* Read watch dog status */
-               status = inw(dev->iobase + APCI3120_STATUS_REG);
-               if (status & APCI3120_STATUS_TIMER2_INT) {
-                       apci3120_clr_timer2_interrupt(dev);
-                       data[0] = 1;
-               } else {
-                       data[0] = 0;
-               }
-       }
-       return insn->n;
-}
index ec2077cb68f0aac6acf3d4b47b5fc85f3daa6c7b..c67c10fc7d667f9dc53b4463f6d29d3282634afe 100644 (file)
@@ -447,6 +447,19 @@ static int apci3120_do_insn_bits(struct comedi_device *dev,
        return insn->n;
 }
 
+static int apci3120_timer_insn_read(struct comedi_device *dev,
+                                   struct comedi_subdevice *s,
+                                   struct comedi_insn *insn,
+                                   unsigned int *data)
+{
+       int i;
+
+       for (i = 0; i < insn->n; i++)
+               data[i] = apci3120_timer_read(dev, 2);
+
+       return insn->n;
+}
+
 static void apci3120_dma_alloc(struct comedi_device *dev)
 {
        struct apci3120_private *devpriv = dev->private;
@@ -618,8 +631,8 @@ static int apci3120_auto_attach(struct comedi_device *dev,
        s->n_chan       = 1;
        s->maxdata      = 0x00ffffff;
        s->insn_write   = apci3120_write_insn_timer;
-       s->insn_read    = apci3120_read_insn_timer;
        s->insn_config  = apci3120_config_insn_timer;
+       s->insn_read    = apci3120_timer_insn_read;
 
        return 0;
 }