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

staging: comedi: pcl812: introduce pcl812_ai_get_sample()

Introduce a helper function to read the 12/16-bit analog input data
sample.
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 f8bf22a8
...@@ -551,6 +551,17 @@ static void setup_range_channel(struct comedi_device *dev, ...@@ -551,6 +551,17 @@ static void setup_range_channel(struct comedi_device *dev,
static int pcl812_ai_cancel(struct comedi_device *dev, static int pcl812_ai_cancel(struct comedi_device *dev,
struct comedi_subdevice *s); struct comedi_subdevice *s);
static unsigned int pcl812_ai_get_sample(struct comedi_device *dev,
struct comedi_subdevice *s)
{
unsigned int val;
val = inb(dev->iobase + PCL812_AD_HI) << 8;
val |= inb(dev->iobase + PCL812_AD_LO);
return val & s->maxdata;
}
static int pcl812_ai_eoc(struct comedi_device *dev, static int pcl812_ai_eoc(struct comedi_device *dev,
struct comedi_subdevice *s, struct comedi_subdevice *s,
struct comedi_insn *insn, struct comedi_insn *insn,
...@@ -578,7 +589,6 @@ static int pcl812_ai_insn_read(struct comedi_device *dev, ...@@ -578,7 +589,6 @@ static int pcl812_ai_insn_read(struct comedi_device *dev,
struct pcl812_private *devpriv = dev->private; struct pcl812_private *devpriv = dev->private;
int ret = 0; int ret = 0;
int n; int n;
int hi;
/* select software trigger */ /* select software trigger */
outb(devpriv->mode_reg_int | 1, dev->iobase + PCL812_MODE); outb(devpriv->mode_reg_int | 1, dev->iobase + PCL812_MODE);
...@@ -593,8 +603,7 @@ static int pcl812_ai_insn_read(struct comedi_device *dev, ...@@ -593,8 +603,7 @@ static int pcl812_ai_insn_read(struct comedi_device *dev,
if (ret) if (ret)
break; break;
hi = inb(dev->iobase + PCL812_AD_HI); data[n] = pcl812_ai_get_sample(dev, s);
data[n] = ((hi & 0xf) << 8) | inb(dev->iobase + PCL812_AD_LO);
} }
outb(devpriv->mode_reg_int | 0, dev->iobase + PCL812_MODE); outb(devpriv->mode_reg_int | 0, dev->iobase + PCL812_MODE);
...@@ -621,9 +630,7 @@ static int acl8216_ai_insn_read(struct comedi_device *dev, ...@@ -621,9 +630,7 @@ static int acl8216_ai_insn_read(struct comedi_device *dev,
if (ret) if (ret)
break; break;
data[n] = data[n] = pcl812_ai_get_sample(dev, s);
(inb(dev->iobase +
PCL812_AD_HI) << 8) | inb(dev->iobase + PCL812_AD_LO);
} }
outb(0, dev->iobase + PCL812_MODE); outb(0, dev->iobase + PCL812_MODE);
...@@ -912,7 +919,7 @@ static int pcl812_ai_cmd(struct comedi_device *dev, struct comedi_subdevice *s) ...@@ -912,7 +919,7 @@ static int pcl812_ai_cmd(struct comedi_device *dev, struct comedi_subdevice *s)
static irqreturn_t interrupt_pcl812_ai_int(int irq, void *d) static irqreturn_t interrupt_pcl812_ai_int(int irq, void *d)
{ {
char err = 1; char err = 1;
unsigned int mask, timeout; unsigned int timeout;
struct comedi_device *dev = d; struct comedi_device *dev = d;
struct pcl812_private *devpriv = dev->private; struct pcl812_private *devpriv = dev->private;
struct comedi_subdevice *s = dev->read_subdev; struct comedi_subdevice *s = dev->read_subdev;
...@@ -922,7 +929,6 @@ static irqreturn_t interrupt_pcl812_ai_int(int irq, void *d) ...@@ -922,7 +929,6 @@ static irqreturn_t interrupt_pcl812_ai_int(int irq, void *d)
timeout = 50; /* wait max 50us, it must finish under 33us */ timeout = 50; /* wait max 50us, it must finish under 33us */
if (devpriv->ai_is16b) { if (devpriv->ai_is16b) {
mask = 0xffff;
while (timeout--) { while (timeout--) {
if (!(inb(dev->iobase + ACL8216_STATUS) & ACL8216_DRDY)) { if (!(inb(dev->iobase + ACL8216_STATUS) & ACL8216_DRDY)) {
err = 0; err = 0;
...@@ -931,7 +937,6 @@ static irqreturn_t interrupt_pcl812_ai_int(int irq, void *d) ...@@ -931,7 +937,6 @@ static irqreturn_t interrupt_pcl812_ai_int(int irq, void *d)
udelay(1); udelay(1);
} }
} else { } else {
mask = 0x0fff;
while (timeout--) { while (timeout--) {
if (!(inb(dev->iobase + PCL812_AD_HI) & PCL812_DRDY)) { if (!(inb(dev->iobase + PCL812_AD_HI) & PCL812_DRDY)) {
err = 0; err = 0;
...@@ -949,9 +954,7 @@ static irqreturn_t interrupt_pcl812_ai_int(int irq, void *d) ...@@ -949,9 +954,7 @@ static irqreturn_t interrupt_pcl812_ai_int(int irq, void *d)
return IRQ_HANDLED; return IRQ_HANDLED;
} }
comedi_buf_put(s->async, comedi_buf_put(s->async, pcl812_ai_get_sample(dev, s));
((inb(dev->iobase + PCL812_AD_HI) << 8) |
inb(dev->iobase + PCL812_AD_LO)) & mask);
/* Set up next channel. Added by abbotti 2010-01-20, but untested. */ /* Set up next channel. Added by abbotti 2010-01-20, but untested. */
next_chan = s->async->cur_chan + 1; next_chan = s->async->cur_chan + 1;
......
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