From f8ade68c9037bc0c37ec967348336e8e13bf11f2 Mon Sep 17 00:00:00 2001 From: David Schleef Date: Tue, 9 Jan 2001 19:21:47 +0000 Subject: [PATCH] added poc driver --- comedi/Config.in | 1 + comedi/drivers/Makefile | 2 + comedi/drivers/poc.c | 211 ++++++++++++++++++++++++++++++++++++++++ 3 files changed, 214 insertions(+) create mode 100644 comedi/drivers/poc.c diff --git a/comedi/Config.in b/comedi/Config.in index 5042c67c..dc38b6a6 100644 --- a/comedi/Config.in +++ b/comedi/Config.in @@ -97,6 +97,7 @@ if [ "$CONFIG_PCI" = "y" ];then dep_tristate 'IOtech DaqBoard/2000' CONFIG_COMEDI_DAQBOARD2000 $CONFIG_COMEDI bool ' Compile in DaqBoard/2000 FPGA code' CONFIG_COMEDI_DAQBOARD2000_FPGA fi +dep_tristate 'Generic ISA driver for simple boards' CONFIG_COMEDI_POC $CONFIG_COMEDI dep_tristate 'Skeleton driver' CONFIG_COMEDI_SKEL $CONFIG_COMEDI if [ "$CONFIG_COMEDI_RT" = "y" ];then diff --git a/comedi/drivers/Makefile b/comedi/drivers/Makefile index 94caf12c..9667e353 100644 --- a/comedi/drivers/Makefile +++ b/comedi/drivers/Makefile @@ -52,6 +52,8 @@ obj-$(CONFIG_COMEDI_NI_PCIDIO) += ni_pcidio.o obj-$(CONFIG_COMEDI_MITE) += mite.o obj-$(CONFIG_COMEDI_NI_ATMIO16D) += ni_atmio16d.o +obj-$(CONFIG_COMEDI_POC) += poc.o + obj-$(CONFIG_COMEDI_PCL711) += pcl711.o obj-$(CONFIG_COMEDI_PCL724) += pcl724.o obj-$(CONFIG_COMEDI_PCL725) += pcl725.o diff --git a/comedi/drivers/poc.c b/comedi/drivers/poc.c new file mode 100644 index 00000000..84c9e100 --- /dev/null +++ b/comedi/drivers/poc.c @@ -0,0 +1,211 @@ +/* + comedi/drivers/poc.c + Mini-drivers for POC (Piece of Crap) boards + Copyright (C) 2000 Frank Mori Hess + Copyright (C) 2001 David A. Schleef + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +*/ +/* + * This driver is a kind of miscellaneous driver for very + * simple ISA boards. + */ +/* + dac02 - Keithley DAC-02 analog output board driver + +The card's ranges are set by the wiring you use. The driver only +uses the range specified to decide whether or not to take the +complement of the data before sending it to the card (since the +bipolar outputs of the card are inverted.) + +*/ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +/* DAC-02 registers */ +#define DAC02_LSB(a) (2 * a) +#define DAC02_MSB(a) (2 * a + 1) + +static int poc_attach(comedi_device *dev,comedi_devconfig *it); +static int poc_detach(comedi_device *dev); +static int dac02_ao_winsn(comedi_device *dev,comedi_subdevice *s,comedi_insn *insn,lsampl_t *data); +static int readback_insn(comedi_device *dev,comedi_subdevice *s,comedi_insn *insn,lsampl_t *data); +static int poc_recognize(const char *name); + +struct boarddef_struct{ + char *name; + int iosize; + int (*setup)(comedi_device *); + int type; + int n_chan; + int n_bits; + int (*winsn)(comedi_device *,comedi_subdevice *,comedi_insn *,lsampl_t *); + int (*rinsn)(comedi_device *,comedi_subdevice *,comedi_insn *,lsampl_t *); +}; +static struct boarddef_struct boards[]={ + { + name: "dac02", + size: 8, + setup: dac02_setup, + type: COMEDI_SUBD_AO, + n_chan: 2, + n_bits: 12, + winsn: dac02_ao_winsn, + rinsn: readback_insn, + } +}; +#define n_boards ((sizeof(boards)/sizeof(boards[0])) + +comedi_driver driver_poc= +{ + driver_name: "poc", + module: THIS_MODULE, + attach: poc_attach, + detach: poc_detach, + recognize: poc_recognize, +}; + +// analog output ranges +static comedi_lrange range_dac02 = { + 4, + { + RANGE( -5, 5 ), + RANGE( -10, 10 ), + RANGE( 0, 5 ), + RANGE( 0, 10 ), + } +}; + +static int poc_recognize(const char *name) +{ + int i; + + for(i=0;iminor, + boards[dev->board].name, iobase); + + dev->board_name = boards[dev->board].name; + + if(iobase == 0) + { + printk("io base address required\n"); + return -EINVAL; + } + + iobase = it->options[0]; + iosize = boards[dev->board].name; + /* check if io addresses are available */ + if(check_region(iobase, iosize) < 0) + { + printk("I/O port conflict: failed to allocate ports 0x%x to 0x%x\n", + iobase, iobase + iosize - 1); + return -EIO; + } + request_region(iobase, iosize, "dac02"); + dev->iobase = iobase; + dev->iosize = iosize; + + dev->n_subdevices = 1; + if(alloc_subdevices(dev) < 0) + return -ENOMEM; + if(alloc_private(dev,sizeof(lsampl_t)*boards[dev->board].n_chan) < 0) + return -ENOMEM; + + /* analog output subdevice */ + s=dev->subdevices + 0; + s->type = boards[dev->board].type; + s->n_chan = boards[dev->board].n_chan; + s->maxdata = (1<board].n_bits)-1; + s->range_table = &range_dac02; // XXX + s->insn_write = boards[dev->board].winsn; + s->insn_write = boards[dev->board].rinsn; + if(s->type==COMEDI_SUBD_AO || s->type==COMEDI_SUBD_DO){ + s->subdev_flags = SDF_WRITEABLE; + } + + return 0; +} + +static int poc_detach(comedi_device *dev) +{ + /* only free stuff if it has been allocated by _attach */ + if(dev->iobase) + release_region(dev->iobase, dev->iosize); + + printk("comedi%d: dac02: remove\n", dev->minor); + + return 0; +} + +static int readback_insn(comedi_device *dev,comedi_subdevice *s,comedi_insn *insn,lsampl_t *data) +{ + int temp; + int chan; + int output; + + chan = CR_CHAN(insn->chanspec); + data[0]=((lsampl_t *)dev->private)[chan]; + + return 1; +} + +static int dac02_ao_winsn(comedi_device *dev,comedi_subdevice *s,comedi_insn *insn,lsampl_t *data) +{ + int temp; + int chan; + int output; + + chan = CR_CHAN(insn->chanspec); + ((lsampl_t *)dev->private)[chan] = data[0]; + output = data[0]; +#if wrong + // convert to complementary binary if range is bipolar + if((CR_RANGE(insn->chanspec) & 0x2) == 0) + output = ~output; +#endif + temp = (output << 4) & 0xf0; + outb(temp, dev->iobase + DAC02_LSB(chan)); + temp = (output >> 4) & 0xff; + outb(temp, dev->iobase + DAC02_MSB(chan)); + + return 1; +} + +COMEDI_INITCLEANUP(driver_poc); + -- 2.26.2