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

staging: comedi: pcl812: use comedi_timeout()

Use comedi_timeout() to wait for the analog input end-of-conversion.

Combine the logic for the pcl812 and acl812 end-of-conversion in the
helper function to simplify the driver.
Signed-off-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
Cc: Ian Abbott <abbotti@mev.co.uk>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 304d2e4c
...@@ -394,16 +394,35 @@ static void setup_range_channel(struct comedi_device *dev, ...@@ -394,16 +394,35 @@ static void setup_range_channel(struct comedi_device *dev,
unsigned int rangechan, char wait); unsigned int rangechan, char wait);
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 int pcl812_ai_eoc(struct comedi_device *dev,
*/ struct comedi_subdevice *s,
struct comedi_insn *insn,
unsigned long context)
{
struct pcl812_private *devpriv = dev->private;
unsigned int status;
if (devpriv->ai_is16b) {
status = inb(dev->iobase + ACL8216_STATUS);
if ((status & ACL8216_DRDY) == 0)
return 0;
} else {
status = inb(dev->iobase + PCL812_AD_HI);
if ((status & PCL812_DRDY) == 0)
return 0;
}
return -EBUSY;
}
static int pcl812_ai_insn_read(struct comedi_device *dev, static int pcl812_ai_insn_read(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)
{ {
struct pcl812_private *devpriv = dev->private; struct pcl812_private *devpriv = dev->private;
int ret = 0;
int n; int n;
int timeout, hi; 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);
...@@ -413,33 +432,27 @@ static int pcl812_ai_insn_read(struct comedi_device *dev, ...@@ -413,33 +432,27 @@ static int pcl812_ai_insn_read(struct comedi_device *dev,
/* start conversion */ /* start conversion */
outb(255, dev->iobase + PCL812_SOFTTRIG); outb(255, dev->iobase + PCL812_SOFTTRIG);
udelay(5); udelay(5);
timeout = 50; /* wait max 50us, it must finish under 33us */
while (timeout--) { ret = comedi_timeout(dev, s, insn, pcl812_ai_eoc, 0);
hi = inb(dev->iobase + PCL812_AD_HI); if (ret) {
if (!(hi & PCL812_DRDY)) dev_dbg(dev->class_dev, "A/D insn read timeout\n");
goto conv_finish; break;
udelay(1);
} }
dev_dbg(dev->class_dev, "A/D insn read timeout\n");
outb(devpriv->mode_reg_int | 0, dev->iobase + PCL812_MODE);
return -ETIME;
conv_finish: hi = inb(dev->iobase + PCL812_AD_HI);
data[n] = ((hi & 0xf) << 8) | inb(dev->iobase + PCL812_AD_LO); 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);
return n;
return ret ? ret : n;
} }
/*
==============================================================================
*/
static int acl8216_ai_insn_read(struct comedi_device *dev, static int acl8216_ai_insn_read(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)
{ {
int ret = 0;
int n; int n;
int timeout;
/* select software trigger */ /* select software trigger */
outb(1, dev->iobase + PCL812_MODE); outb(1, dev->iobase + PCL812_MODE);
...@@ -449,23 +462,20 @@ static int acl8216_ai_insn_read(struct comedi_device *dev, ...@@ -449,23 +462,20 @@ static int acl8216_ai_insn_read(struct comedi_device *dev,
/* start conversion */ /* start conversion */
outb(255, dev->iobase + PCL812_SOFTTRIG); outb(255, dev->iobase + PCL812_SOFTTRIG);
udelay(5); udelay(5);
timeout = 50; /* wait max 50us, it must finish under 33us */
while (timeout--) { ret = comedi_timeout(dev, s, insn, pcl812_ai_eoc, 0);
if (!(inb(dev->iobase + ACL8216_STATUS) & ACL8216_DRDY)) if (ret) {
goto conv_finish; dev_dbg(dev->class_dev, "A/D insn read timeout\n");
udelay(1); break;
} }
dev_dbg(dev->class_dev, "A/D insn read timeout\n");
outb(0, dev->iobase + PCL812_MODE);
return -ETIME;
conv_finish:
data[n] = data[n] =
(inb(dev->iobase + (inb(dev->iobase +
PCL812_AD_HI) << 8) | inb(dev->iobase + PCL812_AD_LO); PCL812_AD_HI) << 8) | inb(dev->iobase + PCL812_AD_LO);
} }
outb(0, dev->iobase + PCL812_MODE); outb(0, dev->iobase + PCL812_MODE);
return n;
return ret ? ret : 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