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

staging: comedi: das16m1: tidy up analog input data register defines

Convert the inline helper munge_sample() into a macro and rename the
defines for the analog input data register/bits. Use the register define
when accessing this register instead of just dev->iobase.
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 07cbd594
...@@ -63,8 +63,9 @@ ...@@ -63,8 +63,9 @@
/* /*
* Register map (dev->iobase) * Register map (dev->iobase)
*/ */
#define DAS16M1_AI 0 /* 16-bit wide register */ #define DAS16M1_AI_REG 0x00 /* 16-bit register */
#define AI_CHAN(x) ((x) & 0xf) #define DAS16M1_AI_TO_CHAN(x) (((x) >> 0) & 0xf)
#define DAS16M1_AI_TO_SAMPLE(x) (((x) >> 4) & 0xfff)
#define DAS16M1_CS 2 #define DAS16M1_CS 2
#define EXT_TRIG_BIT 0x1 #define EXT_TRIG_BIT 0x1
#define OVRUN 0x20 #define OVRUN 0x20
...@@ -109,17 +110,12 @@ struct das16m1_private_struct { ...@@ -109,17 +110,12 @@ struct das16m1_private_struct {
unsigned long extra_iobase; unsigned long extra_iobase;
}; };
static inline unsigned short munge_sample(unsigned short data)
{
return (data >> 4) & 0xfff;
}
static void munge_sample_array(unsigned short *array, unsigned int num_elements) static void munge_sample_array(unsigned short *array, unsigned int num_elements)
{ {
unsigned int i; unsigned int i;
for (i = 0; i < num_elements; i++) for (i = 0; i < num_elements; i++)
array[i] = munge_sample(array[i]); array[i] = DAS16M1_AI_TO_SAMPLE(array[i]);
} }
static int das16m1_ai_check_chanlist(struct comedi_device *dev, static int das16m1_ai_check_chanlist(struct comedi_device *dev,
...@@ -331,16 +327,19 @@ static int das16m1_ai_rinsn(struct comedi_device *dev, ...@@ -331,16 +327,19 @@ static int das16m1_ai_rinsn(struct comedi_device *dev,
outb(byte, dev->iobase + DAS16M1_QUEUE_DATA); outb(byte, dev->iobase + DAS16M1_QUEUE_DATA);
for (n = 0; n < insn->n; n++) { for (n = 0; n < insn->n; n++) {
unsigned short val;
/* clear IRQDATA bit */ /* clear IRQDATA bit */
outb(0, dev->iobase + DAS16M1_CLEAR_INTR); outb(0, dev->iobase + DAS16M1_CLEAR_INTR);
/* trigger conversion */ /* trigger conversion */
outb(0, dev->iobase); outb(0, dev->iobase + DAS16M1_AI_REG);
ret = comedi_timeout(dev, s, insn, das16m1_ai_eoc, 0); ret = comedi_timeout(dev, s, insn, das16m1_ai_eoc, 0);
if (ret) if (ret)
return ret; return ret;
data[n] = munge_sample(inw(dev->iobase)); val = inw(dev->iobase + DAS16M1_AI_REG);
data[n] = DAS16M1_AI_TO_SAMPLE(val);
} }
return n; return 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