From 582e59c042641b4b68a26fa8a5da8467b099c3ac Mon Sep 17 00:00:00 2001 From: H Hartley Sweeten Date: Thu, 4 Sep 2014 12:14:25 -0700 Subject: [PATCH] staging: comedi: adl_pci9118: introduce pci9118_ai_reset_fifo() Introduce a helper function to reset the analog input FIFO. For aesthetics, rename the register used to reset the FIFO. Signed-off-by: H Hartley Sweeten Reviewed-by: Ian Abbott Signed-off-by: Greg Kroah-Hartman --- drivers/staging/comedi/drivers/adl_pci9118.c | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/drivers/staging/comedi/drivers/adl_pci9118.c b/drivers/staging/comedi/drivers/adl_pci9118.c index dfac7975a53e..266eb3f3a4ed 100644 --- a/drivers/staging/comedi/drivers/adl_pci9118.c +++ b/drivers/staging/comedi/drivers/adl_pci9118.c @@ -143,8 +143,8 @@ #define PCI9118_AI_CFG_PM (1 << 2) /* 1=post trigger */ #define PCI9118_AI_CFG_AM (1 << 1) /* 1=about trigger */ #define PCI9118_AI_CFG_START (1 << 0) /* 1=trigger start */ +#define PCI9118_FIFO_RESET_REG 0x34 -#define PCI9118_DELFIFO 0x34 /* W: A/D data FIFO reset */ #define PCI9118_INTSRC 0x38 /* R: interrupt reason register */ #define PCI9118_INTCTRL 0x38 /* W: interrupt control register */ @@ -318,6 +318,12 @@ static void pci9118_timer_set_mode(struct comedi_device *dev, outl(val, dev->iobase + PCI9118_TIMER_CTRL_REG); } +static void pci9118_ai_reset_fifo(struct comedi_device *dev) +{ + /* writing any value resets the A/D FIFO */ + outl(0, dev->iobase + PCI9118_FIFO_RESET_REG); +} + static int check_channel_list(struct comedi_device *dev, struct comedi_subdevice *s, int n_chan, unsigned int *chanlist, int frontadd, int backadd) @@ -497,14 +503,14 @@ static int pci9118_insn_read_ai(struct comedi_device *dev, if (!setup_channel_list(dev, s, 1, &insn->chanspec, 0, 0, 0, 0)) return -EINVAL; - outl(0, dev->iobase + PCI9118_DELFIFO); /* flush FIFO */ + pci9118_ai_reset_fifo(dev); for (n = 0; n < insn->n; n++) { pci9118_ai_start_conv(dev); ret = comedi_timeout(dev, s, insn, pci9118_ai_eoc, 0); if (ret) { - outl(0, dev->iobase + PCI9118_DELFIFO); /* flush FIFO */ + pci9118_ai_reset_fifo(dev); return ret; } @@ -515,7 +521,7 @@ static int pci9118_insn_read_ai(struct comedi_device *dev, data[n] = (val >> 4) & 0xfff; } - outl(0, dev->iobase + PCI9118_DELFIFO); /* flush FIFO */ + pci9118_ai_reset_fifo(dev); return n; } @@ -768,7 +774,7 @@ static int pci9118_ai_cancel(struct comedi_device *dev, /* reset scan queue */ outl(1, dev->iobase + PCI9118_AI_AUTOSCAN_MODE_REG); outl(2, dev->iobase + PCI9118_AI_AUTOSCAN_MODE_REG); - outl(0, dev->iobase + PCI9118_DELFIFO); /* flush FIFO */ + pci9118_ai_reset_fifo(dev); devpriv->ai_do = 0; devpriv->usedma = 0; @@ -1643,7 +1649,7 @@ static int pci9118_ai_cmd(struct comedi_device *dev, struct comedi_subdevice *s) */ outl(devpriv->AdFunctionReg, dev->iobase + PCI9118_AI_CFG_REG); udelay(1); - outl(0, dev->iobase + PCI9118_DELFIFO); /* flush FIFO */ + pci9118_ai_reset_fifo(dev); /* clear A/D and INT status registers */ inl(dev->iobase + PCI9118_AI_STATUS_REG); @@ -1703,7 +1709,7 @@ static int pci9118_reset(struct comedi_device *dev) outl(0, dev->iobase + PCI9118_DIO_REG); /* reset digi outs to L */ udelay(10); inl(dev->iobase + PCI9118_AI_FIFO_REG); - outl(0, dev->iobase + PCI9118_DELFIFO); /* flush FIFO */ + pci9118_ai_reset_fifo(dev); outl(0, dev->iobase + PCI9118_INTSRC); /* remove INT requests */ /* clear A/D and INT status registers */ inl(dev->iobase + PCI9118_AI_STATUS_REG); -- 2.20.1