aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorH Hartley Sweeten <hsweeten@visionengravers.com>2013-08-26 18:29:33 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2013-08-27 19:59:08 -0400
commitf9f34d57bab010e6f11ec3ebd674b4ff4fc909ee (patch)
tree11cce298282c5076f774350428f4c631ee3e9f9f
parent49b71ebab2b40ffec19007e8b4dba6b8f8622f46 (diff)
staging: comedi: ni_atmio16d: fix atmio16d_dio_insn_config()
This is the (*insn_config) function for a DIO subdevice. It should be using the data[0] value as the "instruction" to perform on the subdevice. Use the comedi_dio_insn_config() helper to properly handle instructions. 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>
-rw-r--r--drivers/staging/comedi/drivers/ni_atmio16d.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/drivers/staging/comedi/drivers/ni_atmio16d.c b/drivers/staging/comedi/drivers/ni_atmio16d.c
index 8520d83d940f..bb3491f5ad21 100644
--- a/drivers/staging/comedi/drivers/ni_atmio16d.c
+++ b/drivers/staging/comedi/drivers/ni_atmio16d.c
@@ -576,15 +576,19 @@ static int atmio16d_dio_insn_config(struct comedi_device *dev,
576 unsigned int *data) 576 unsigned int *data)
577{ 577{
578 struct atmio16d_private *devpriv = dev->private; 578 struct atmio16d_private *devpriv = dev->private;
579 int i; 579 unsigned int chan = CR_CHAN(insn->chanspec);
580 int mask; 580 unsigned int mask;
581 int ret;
582
583 if (chan < 4)
584 mask = 0x0f;
585 else
586 mask = 0xf0;
587
588 ret = comedi_dio_insn_config(dev, s, insn, data, mask);
589 if (ret)
590 return ret;
581 591
582 for (i = 0; i < insn->n; i++) {
583 mask = (CR_CHAN(insn->chanspec) < 4) ? 0x0f : 0xf0;
584 s->io_bits &= ~mask;
585 if (data[i])
586 s->io_bits |= mask;
587 }
588 devpriv->com_reg_2_state &= ~(COMREG2_DOUTEN0 | COMREG2_DOUTEN1); 592 devpriv->com_reg_2_state &= ~(COMREG2_DOUTEN0 | COMREG2_DOUTEN1);
589 if (s->io_bits & 0x0f) 593 if (s->io_bits & 0x0f)
590 devpriv->com_reg_2_state |= COMREG2_DOUTEN0; 594 devpriv->com_reg_2_state |= COMREG2_DOUTEN0;
@@ -592,7 +596,7 @@ static int atmio16d_dio_insn_config(struct comedi_device *dev,
592 devpriv->com_reg_2_state |= COMREG2_DOUTEN1; 596 devpriv->com_reg_2_state |= COMREG2_DOUTEN1;
593 outw(devpriv->com_reg_2_state, dev->iobase + COM_REG_2); 597 outw(devpriv->com_reg_2_state, dev->iobase + COM_REG_2);
594 598
595 return i; 599 return insn->n;
596} 600}
597 601
598/* 602/*