From d7b6c574d17fed09a0d9fa4bc7674c13fa156805 Mon Sep 17 00:00:00 2001 From: H Hartley Sweeten Date: Fri, 20 Jun 2014 13:13:02 -0700 Subject: [PATCH] staging: comedi: dt282x: automatically handle D/A data format The DT2821 series board have jumpers that set the output range for the two Analog Output channels. The range_table for the Analog Output subdevice provides all possible ranges to the user. When a unipolar range is selected the board expects the data to be in a straight binary format. When a bipolar range is select the data should be in two's complement format. Currently, the user passes some configuration options when attaching to the driver to select the data format for each channel. If the user does not pass the config options, the data format is assumed to be straight binary. The Analog Output subdevice now has a range_table that provides the user will all possible ranges. Use the range information to determine if the data values need to be munged into two's complememnt values and deprecate the config options. Signed-off-by: H Hartley Sweeten Reviewed-by: Ian Abbott Signed-off-by: Greg Kroah-Hartman --- drivers/staging/comedi/drivers/dt282x.c | 23 +++++++---------------- 1 file changed, 7 insertions(+), 16 deletions(-) diff --git a/drivers/staging/comedi/drivers/dt282x.c b/drivers/staging/comedi/drivers/dt282x.c index e30a0646f4f1..27a8bb18bcd5 100644 --- a/drivers/staging/comedi/drivers/dt282x.c +++ b/drivers/staging/comedi/drivers/dt282x.c @@ -46,8 +46,8 @@ * [3] - DMA 2 (optional, required for async command support) * [4] - AI jumpered for 0=single ended, 1=differential * [5] - AI jumpered for 0=straight binary, 1=2's complement - * [6] - AO 0 jumpered for 0=straight binary, 1=2's complement - * [7] - AO 1 jumpered for 0=straight binary, 1=2's complement + * [6] - AO 0 data format (deprecated, see below) + * [7] - AO 1 data format (deprecated, see below) * [8] - AI jumpered for 0=[-10,10]V, 1=[0,10], 2=[-5,5], 3=[0,5] * [9] - AO channel 0 range (deprecated, see below) * [10]- AO channel 1 range (deprecated, see below) @@ -60,7 +60,9 @@ * - AO range is not programmable. The AO subdevice has a range_table * containing all the possible analog output ranges. Use the range * that matches your board configuration to convert between data - * values and physical units. + * values and physical units. The format of the data written to the + * board is handled automatically based on the unipolar/bipolar + * range that is selected. */ #include @@ -310,8 +312,6 @@ static const struct dt282x_board boardtypes[] = { struct dt282x_private { unsigned int ad_2scomp:1; - unsigned int da0_2scomp:1; - unsigned int da1_2scomp:1; unsigned int divisor; @@ -847,24 +847,17 @@ static int dt282x_ao_insn_write(struct comedi_device *dev, { struct dt282x_private *devpriv = dev->private; unsigned int chan = CR_CHAN(insn->chanspec); - bool munge = false; + unsigned int range = CR_RANGE(insn->chanspec); unsigned int val; int i; devpriv->dacsr |= DT2821_DACSR_SSEL | DT2821_DACSR_YSEL(chan); - if (chan) { - if (devpriv->da1_2scomp) - munge = true; - } else { - if (devpriv->da0_2scomp) - munge = true; - } for (i = 0; i < insn->n; i++) { val = data[i]; devpriv->ao_readback[chan] = val; - if (munge) + if (comedi_range_is_bipolar(s, range)) val = comedi_offset_munge(s, val); outw(devpriv->dacsr, dev->iobase + DT2821_DACSR_REG); @@ -1261,8 +1254,6 @@ static int dt282x_attach(struct comedi_device *dev, struct comedi_devconfig *it) /* ranges are per-channel, set by jumpers on the board */ s->range_table = &dt282x_ao_range; - devpriv->da0_2scomp = it->options[6] ? 1 : 0; - devpriv->da1_2scomp = it->options[7] ? 1 : 0; s->insn_read = dt282x_ao_insn_read; s->insn_write = dt282x_ao_insn_write; -- 2.20.1