From 349c268a0177dbd3e92bb988d06f85e4c7b0ae2a Mon Sep 17 00:00:00 2001 From: Ian Abbott Date: Fri, 31 Aug 2012 20:41:44 +0100 Subject: [PATCH] --- yaml --- r: 324666 b: refs/heads/master c: f0ba1d6e19c5e7f91005eaa4d9c14851e217feea h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/staging/comedi/drivers/das08.c | 20 +++++++++++++++++++- trunk/drivers/staging/comedi/drivers/das08.h | 1 + 3 files changed, 21 insertions(+), 2 deletions(-) diff --git a/[refs] b/[refs] index 08cc5bf3d3b3..90130df3c94e 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 8432eb35a924440e21bccd965009b101a37a3aad +refs/heads/master: f0ba1d6e19c5e7f91005eaa4d9c14851e217feea diff --git a/trunk/drivers/staging/comedi/drivers/das08.c b/trunk/drivers/staging/comedi/drivers/das08.c index 0457b9b7ef2d..623e77ef2d28 100644 --- a/trunk/drivers/staging/comedi/drivers/das08.c +++ b/trunk/drivers/staging/comedi/drivers/das08.c @@ -373,6 +373,7 @@ static void das08_ao_set_data(struct comedi_device *dev, unsigned int chan, unsigned int data) { const struct das08_board_struct *thisboard = comedi_board(dev); + struct das08_private_struct *devpriv = dev->private; unsigned char lsb; unsigned char msb; @@ -389,6 +390,7 @@ static void das08_ao_set_data(struct comedi_device *dev, /* load DACs */ inb(dev->iobase + DAS08AO_AO_UPDATE); } + devpriv->ao_readback[chan] = data; } static void das08_ao_initialize(struct comedi_device *dev, @@ -417,6 +419,22 @@ static int das08_ao_winsn(struct comedi_device *dev, return n; } +static int das08_ao_rinsn(struct comedi_device *dev, + struct comedi_subdevice *s, + struct comedi_insn *insn, unsigned int *data) +{ + struct das08_private_struct *devpriv = dev->private; + unsigned int n; + unsigned int chan; + + chan = CR_CHAN(insn->chanspec); + + for (n = 0; n < insn->n; n++) + data[n] = devpriv->ao_readback[chan]; + + return n; +} + static void i8254_initialize(struct comedi_device *dev) { const struct das08_board_struct *thisboard = comedi_board(dev); @@ -670,12 +688,12 @@ int das08_common_attach(struct comedi_device *dev, unsigned long iobase) /* ao */ if (thisboard->ao_nbits) { s->type = COMEDI_SUBD_AO; -/* XXX lacks read-back insn */ s->subdev_flags = SDF_WRITABLE; s->n_chan = 2; s->maxdata = (1 << thisboard->ao_nbits) - 1; s->range_table = &range_bipolar5; s->insn_write = das08_ao_winsn; + s->insn_read = das08_ao_rinsn; das08_ao_initialize(dev, s); } else { s->type = COMEDI_SUBD_UNUSED; diff --git a/trunk/drivers/staging/comedi/drivers/das08.h b/trunk/drivers/staging/comedi/drivers/das08.h index 5a339934f1ba..4231be553c0d 100644 --- a/trunk/drivers/staging/comedi/drivers/das08.h +++ b/trunk/drivers/staging/comedi/drivers/das08.h @@ -52,6 +52,7 @@ struct das08_private_struct { unsigned int do_bits; /* bits for do register on boards with register dedicated to digital out only */ const unsigned int *pg_gainlist; struct pci_dev *pdev; /* struct for pci-das08 */ + unsigned int ao_readback[2]; /* assume 2 AO channels */ }; int das08_common_attach(struct comedi_device *dev, unsigned long iobase);