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

staging: comedi: ni_mio_common: tidy up the gpct counter subdevice init

For aesthetics, add some whitespace to the subdevice init and
tidy it up a bit.

Unfortunately we can't get rid of the '#ifdef PCIDMA' here yet due
to other ifdefery in this file. For now just add the correct test
so that the async command support is not hooked up unless we have
an IRQ and DMA.
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 43f2c8b7
...@@ -5490,7 +5490,6 @@ static int ni_E_init(struct comedi_device *dev, ...@@ -5490,7 +5490,6 @@ static int ni_E_init(struct comedi_device *dev,
const struct ni_board_struct *board = comedi_board(dev); const struct ni_board_struct *board = comedi_board(dev);
struct ni_private *devpriv = dev->private; struct ni_private *devpriv = dev->private;
struct comedi_subdevice *s; struct comedi_subdevice *s;
enum ni_gpct_variant counter_variant;
int ret; int ret;
int i; int i;
...@@ -5735,44 +5734,47 @@ static int ni_E_init(struct comedi_device *dev, ...@@ -5735,44 +5734,47 @@ static int ni_E_init(struct comedi_device *dev,
s->insn_config = ni_rtsi_insn_config; s->insn_config = ni_rtsi_insn_config;
ni_rtsi_init(dev); ni_rtsi_init(dev);
if (devpriv->is_m_series) /* allocate and initialize the gpct counter device */
counter_variant = ni_gpct_variant_m_series;
else
counter_variant = ni_gpct_variant_e_series;
devpriv->counter_dev = ni_gpct_device_construct(dev, devpriv->counter_dev = ni_gpct_device_construct(dev,
&ni_gpct_write_register, ni_gpct_write_register,
&ni_gpct_read_register, ni_gpct_read_register,
counter_variant, (devpriv->is_m_series)
NUM_GPCT); ? ni_gpct_variant_m_series
: ni_gpct_variant_e_series,
NUM_GPCT);
if (!devpriv->counter_dev) if (!devpriv->counter_dev)
return -ENOMEM; return -ENOMEM;
/* General purpose counters */ /* Counter (gpct) subdevices */
for (i = 0; i < NUM_GPCT; ++i) { for (i = 0; i < NUM_GPCT; ++i) {
struct ni_gpct *gpct = &devpriv->counter_dev->counters[i];
/* setup and initialize the counter */
gpct->chip_index = 0;
gpct->counter_index = i;
ni_tio_init_counter(gpct);
s = &dev->subdevices[NI_GPCT_SUBDEV(i)]; s = &dev->subdevices[NI_GPCT_SUBDEV(i)];
s->type = COMEDI_SUBD_COUNTER; s->type = COMEDI_SUBD_COUNTER;
s->subdev_flags = SDF_READABLE | SDF_WRITABLE | SDF_LSAMPL; s->subdev_flags = SDF_READABLE | SDF_WRITABLE | SDF_LSAMPL;
s->n_chan = 3; s->n_chan = 3;
if (devpriv->is_m_series) s->maxdata = (devpriv->is_m_series) ? 0xffffffff
s->maxdata = 0xffffffff; : 0x00ffffff;
else s->insn_read = ni_tio_insn_read;
s->maxdata = 0xffffff; s->insn_write = ni_tio_insn_read;
s->insn_read = ni_tio_insn_read; s->insn_config = ni_tio_insn_config;
s->insn_write = ni_tio_insn_read;
s->insn_config = ni_tio_insn_config;
#ifdef PCIDMA #ifdef PCIDMA
s->subdev_flags |= SDF_CMD_READ /* | SDF_CMD_WRITE */; if (dev->irq && devpriv->mite) {
s->do_cmd = &ni_gpct_cmd; s->subdev_flags |= SDF_CMD_READ /* | SDF_CMD_WRITE */;
s->len_chanlist = 1; s->len_chanlist = 1;
s->do_cmdtest = ni_tio_cmdtest; s->do_cmdtest = ni_tio_cmdtest;
s->cancel = &ni_gpct_cancel; s->do_cmd = ni_gpct_cmd;
s->async_dma_dir = DMA_BIDIRECTIONAL; s->cancel = ni_gpct_cancel;
#endif
s->private = &devpriv->counter_dev->counters[i];
devpriv->counter_dev->counters[i].chip_index = 0; s->async_dma_dir = DMA_BIDIRECTIONAL;
devpriv->counter_dev->counters[i].counter_index = i; }
ni_tio_init_counter(&devpriv->counter_dev->counters[i]); #endif
s->private = gpct;
} }
/* Frequency output */ /* Frequency output */
......
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