Commit 826f783a authored by H Hartley Sweeten's avatar H Hartley Sweeten Committed by Greg Kroah-Hartman

staging: comedi: ni_660x: tidy up ni_660x_dio_insn_bits()

Use some local variables to clarify this function.

This (*insn_bits) function is a bit different from most comedi drivers.
Add some comments to clarify why the shifts are used.
Signed-off-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
Reviewed-by: default avatarIan Abbott <abbotti@mev.co.uk>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 7e906186
...@@ -780,21 +780,30 @@ static void init_tio_chip(struct comedi_device *dev, int chipset) ...@@ -780,21 +780,30 @@ static void init_tio_chip(struct comedi_device *dev, int chipset)
static int ni_660x_dio_insn_bits(struct comedi_device *dev, static int ni_660x_dio_insn_bits(struct comedi_device *dev,
struct comedi_subdevice *s, struct comedi_subdevice *s,
struct comedi_insn *insn, unsigned int *data) struct comedi_insn *insn,
unsigned int *data)
{ {
unsigned int base_bitfield_channel = CR_CHAN(insn->chanspec); unsigned int shift = CR_CHAN(insn->chanspec);
unsigned int mask = data[0] << shift;
unsigned int bits = data[1] << shift;
/* Check if we have to write some bits */ /*
if (data[0]) { * There are 40 channels in this subdevice but only 32 are usable
s->state &= ~(data[0] << base_bitfield_channel); * as DIO. The shift adjusts the mask/bits to account for the base
s->state |= (data[0] & data[1]) << base_bitfield_channel; * channel in insn->chanspec. The state update can then be handled
/* Write out the new digital output lines */ * normally for the 32 usable channels.
*/
if (mask) {
s->state &= ~mask;
s->state |= (bits & mask);
ni_660x_write(dev, 0, s->state, NI660X_DIO32_OUTPUT); ni_660x_write(dev, 0, s->state, NI660X_DIO32_OUTPUT);
} }
/* on return, data[1] contains the value of the digital
* input and output lines. */ /*
data[1] = (ni_660x_read(dev, 0, NI660X_DIO32_INPUT) >> * Return the input channels, shifted back to account for the base
base_bitfield_channel); * channel.
*/
data[1] = ni_660x_read(dev, 0, NI660X_DIO32_INPUT) >> shift;
return insn->n; return insn->n;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment