Ian Abbott [Thu, 21 Feb 2008 12:47:49 +0000 (12:47 +0000)]
Added Fred Brooks (ni_daq_700 driver).
Ian Abbott [Thu, 21 Feb 2008 12:36:10 +0000 (12:36 +0000)]
Changed subdev_700_insn to include the state of the output channels
(0 to 7) in the returned data. This may be inaccurate unless the output
channels have been written at least once.
Ian Abbott [Thu, 21 Feb 2008 12:26:24 +0000 (12:26 +0000)]
Changed the name in the second entry of the boards array to "ni_daq_700"
to match the driver name. This is an alias of the first entry which has
the name "daqcard-700".
Ian Abbott [Thu, 21 Feb 2008 12:22:31 +0000 (12:22 +0000)]
Removed spurious '#define _700_H'.
Ian Abbott [Thu, 21 Feb 2008 12:20:53 +0000 (12:20 +0000)]
Updated driver description using information from other comments.
Ian Abbott [Thu, 21 Feb 2008 12:02:27 +0000 (12:02 +0000)]
Ran source through comedi_indent script.
Ian Abbott [Thu, 21 Feb 2008 11:54:51 +0000 (11:54 +0000)]
Added NI DAQCard-700 DIO-only driver by fred brooks.
Ian Abbott [Thu, 21 Feb 2008 11:21:47 +0000 (11:21 +0000)]
Applied update to driver documentation section from jeremy theler:
- corrected 'Devices' line
- updated status
- updated description and changelog.
I corrected the year in jeremy's updated 'Updated' line.
Ian Abbott [Fri, 15 Feb 2008 10:57:25 +0000 (10:57 +0000)]
Add PCI bus/slot options.
Frank Mori Hess [Fri, 8 Feb 2008 19:03:07 +0000 (19:03 +0000)]
Fixed spelling error "sucess"->"success".
Bernd Porr [Tue, 5 Feb 2008 22:47:03 +0000 (22:47 +0000)]
forgotten to uncomment the debug macro. Soooory.
Bernd Porr [Tue, 5 Feb 2008 22:43:48 +0000 (22:43 +0000)]
Silly mistake in the frequency setting. Sent out the wrong variable
to the dux board so that the frequency was more or less a random choice.
Thanks for Sam for figuring that out.
Ian Abbott [Mon, 4 Feb 2008 16:47:54 +0000 (16:47 +0000)]
For separate kernel source and build directories, allow the kernel build
directory's Makefile to specify KERNELSRC using a relative path.
This avoids having to use the --with-kernelsrcdir option when configuring
Comedi for SuSE Linux's kernels.
Frank Mori Hess [Wed, 30 Jan 2008 16:39:06 +0000 (16:39 +0000)]
Modified output to be tab-delimited (for easier parsing later into a
html table).
Frank Mori Hess [Mon, 28 Jan 2008 21:09:42 +0000 (21:09 +0000)]
regenerated ChangeLog with "cvs2cl -T"
Frank Mori Hess [Mon, 28 Jan 2008 20:51:14 +0000 (20:51 +0000)]
bumped version for 0.7.76 release.
Frank Mori Hess [Mon, 28 Jan 2008 20:04:24 +0000 (20:04 +0000)]
Allow generation of devices.txt and drivers.txt to work
when builddir != srcdir.
Frank Mori Hess [Mon, 28 Jan 2008 20:03:04 +0000 (20:03 +0000)]
Suppress some compiler warnings
Frank Mori Hess [Mon, 28 Jan 2008 19:32:30 +0000 (19:32 +0000)]
Replaced an "if(0)" with an "#if 0".
Ian Abbott [Mon, 28 Jan 2008 13:54:16 +0000 (13:54 +0000)]
Fix bug in ni_pcidio_release_di_mite_channel() that prevented subsequent
commands working (it never set devpriv->di_mite_chan to NULL after calling
mite_release_channel()).
Ian Abbott [Wed, 16 Jan 2008 17:03:48 +0000 (17:03 +0000)]
Corrected number of channels for DO subdevice.
Ian Abbott [Mon, 14 Jan 2008 18:05:35 +0000 (18:05 +0000)]
In comedi_do_insn:
For INSN_WAIT, make sure insn->n is exactly 1.
For subdevice instructions, if subdevice is unused, return -EIO.
For subdevice instructions, if chanspec is wrong, return -EINVAL.
Ian Abbott [Mon, 14 Jan 2008 17:59:31 +0000 (17:59 +0000)]
In comedi_do_insn, #if'ed out the final check for return value of subdevice
insn function matching insn.n. Comedi documentation for userspace
comedi_do_insn allows a lower value to be returned and some drivers
blatently do so, particularly for configuration instructions.
Also added some XXX reminder comments for INSN_WAIT and INSN_CONFIG for
things that need to be fixed.
Ian Abbott [Mon, 14 Jan 2008 12:26:16 +0000 (12:26 +0000)]
Corrected test for INSN_WRITE data value exceeding maxdata. It failed on
subdevices that used per-channel maxdata values (maxdata_list).
Ian Abbott [Mon, 14 Jan 2008 12:13:26 +0000 (12:13 +0000)]
Applied comedi_indent script.
Bernd Porr [Sun, 13 Jan 2008 23:07:02 +0000 (23:07 +0000)]
Added a proper PWM subdevice for comedi.
PWM is started with INSN_CONFIG_ARM where the second argument
defines the time how long PWM will last. A zero indicates "forever".
PWM is stopped with INSN_CONFIG_DISARM. No further args.
The duty cycle is set via a comedi_data_write where maxdata defines
the 100% duty cycle.
The PWM period is set by INSN_CONFIG_PWM_SET_PERIOD where the second
argument is in nanoseconds, thus 1E9/frequency
INSN_CONFIG_PWM_GET_PERIOD retrieves the frequency which might have been
corrected by the driver
INSN_GET_PWM_STATUS queries if it's on or off
INSN_CONFIG_PWM_SET_H_BRIDGE allows the transmit the duty cycle with a polarity bit in the second argument.
See the usbdux driver and its PWM section.
Ian Abbott [Mon, 7 Jan 2008 11:05:21 +0000 (11:05 +0000)]
Only set SRF_RT subdevice flag if comedi_switch_to_rt(dev) succeeds.
Ian Abbott [Wed, 2 Jan 2008 17:41:47 +0000 (17:41 +0000)]
For COMEDI_DEVCONFIG ioctl, if argument is NULL, refuse to unconfigure the
device if any subdevices are busy or have mmap'ed buffers. The errno is
EBUSY in this case.
Ian Abbott [Wed, 2 Jan 2008 17:04:21 +0000 (17:04 +0000)]
Changed read, write, poll, and mmap file operations to use the per-device
mutex. The mutex is released during read and write operations that block.
Frank Mori Hess [Wed, 2 Jan 2008 02:17:43 +0000 (02:17 +0000)]
Added board entry for 6013.
Ian Abbott [Thu, 20 Dec 2007 15:12:22 +0000 (15:12 +0000)]
Once the linux build directory has been determined ($LINUX_DIR), try and
override the previous setting of the LINUX_KERNEL_RELEASE variable using
the release info from the Linux build directory. Information comes from
the UTS_RELEASE C macro. For kernel versions 2.6.18 and later this is
defined in include/linux/utsrelease.h. For earlier kernel versions it is
defined in include/linux/version.h.
Ian Abbott [Mon, 17 Dec 2007 16:43:04 +0000 (16:43 +0000)]
Some changes for separate Linux source and build trees.
Add LINUX_SRC_DIR variable to point to Linux source tree (LINUX_DIR points
to the Linux build tree). It can be set with a new --with-linuxsrcdir
option or determined automatically from the build tree.
Changed some configure tests to check the Linux source tree instead of the
build tree. The affected tests are COMEDI_CHECK_PCMCIA_PROBE,
COMEDI_CHECK_LINUX_KBUILD and COMEDI_CHECK_HAVE_MUTEX_H. The
COMEDI_CHECK_LINUX_KBUILD test has been simplified because it no longer
has to check for separate source and build trees.
Ian Abbott [Wed, 12 Dec 2007 14:55:14 +0000 (14:55 +0000)]
Use unlocked_ioctl file operation instead of ioctl if kernel supports it
and use a mutex in struct comedi_device.
Some parts of the driver still need to be changed to use the mutex.
Ian Abbott [Wed, 12 Dec 2007 14:51:57 +0000 (14:51 +0000)]
Check for include/linux/mutex.h in kernel source.
Ian Abbott [Wed, 12 Dec 2007 14:47:20 +0000 (14:47 +0000)]
Added compatibility header for <linux/mutex.h>.
Ian Abbott [Wed, 12 Dec 2007 13:47:00 +0000 (13:47 +0000)]
For non-Kbuild make, don't build addi-data drivers that use floating point,
but include source in EXTRA_DIST. (Kbuild make already skips these drivers.)
Ian Abbott [Wed, 12 Dec 2007 12:42:44 +0000 (12:42 +0000)]
Corrected type qualifiers for pc_DriverName in boardtype.
Ian Abbott [Wed, 12 Dec 2007 12:28:05 +0000 (12:28 +0000)]
Removed #defines for types (now they're all in addi_common.h).
Ian Abbott [Wed, 12 Dec 2007 12:27:00 +0000 (12:27 +0000)]
Use typedef instead of #define to define MS-Windows types. Add a few more
pointer types.
Ian Abbott [Wed, 12 Dec 2007 11:34:01 +0000 (11:34 +0000)]
Include <linux/ioctl32.h> if using old-style register_ioctl32_conversion.
Frank Mori Hess [Wed, 12 Dec 2007 03:12:55 +0000 (03:12 +0000)]
Converted initialization of board array to modern standard (indent does
a slightly less bad job of indenting it this way).
Ian Abbott [Wed, 5 Dec 2007 17:02:01 +0000 (17:02 +0000)]
For read and write, check if command still running in non-blocking mode as well.
Ian Abbott [Wed, 5 Dec 2007 14:45:49 +0000 (14:45 +0000)]
Check for various errors such as subdevice in range and support for commands.
Use comedi_set_subdevice_runflags and comedi_get_subdevice_runflags when
checking/modifying SRF_RT runflag.
Ian Abbott [Wed, 5 Dec 2007 14:41:47 +0000 (14:41 +0000)]
If comedi_switch_to_rt() is a macro it should stil have a return value.
Ian Abbott [Wed, 5 Dec 2007 12:52:15 +0000 (12:52 +0000)]
Use per-subdevice spin-lock instead of big_comedi_lock. Renamed existing
subdevice 'runflags_lock' to 'spin_lock' for more general use. (Could have
used a separate spin-lock for locking/unlocking subdevices, but there
shouldn't be much contention for the existing spin-lock used for setting/
getting runflags.)
Ian Abbott [Tue, 4 Dec 2007 15:30:39 +0000 (15:30 +0000)]
Define mmiowb() macro if necessary.
Ian Abbott [Tue, 4 Dec 2007 13:11:14 +0000 (13:11 +0000)]
No need to define kcalloc() compatibility function for kernel 2.6.9 onwards.
The kzalloc() compatibility function is still required for vanilla kernels
prior to 2.6.14, but some versions of RHEL4 2.6.9 kernel (e.g. 2.6.9-42)
already declare it, so use a macro to override it with our own version.
Ian Abbott [Mon, 3 Dec 2007 17:47:46 +0000 (17:47 +0000)]
Expanded documentation for the driver.
Ian Abbott [Mon, 3 Dec 2007 14:47:00 +0000 (14:47 +0000)]
Report error event when command stopped due to buffer overflow.
Ian Abbott [Mon, 3 Dec 2007 14:43:40 +0000 (14:43 +0000)]
Avoid setting s->async->inttrig to NULL in interrupt routine.
Ian Abbott [Mon, 3 Dec 2007 14:36:31 +0000 (14:36 +0000)]
Avoid setting s->async->inttrig to NULL in interrupt routine.
Ian Abbott [Mon, 3 Dec 2007 13:57:45 +0000 (13:57 +0000)]
For AO command, if scan_begin_src is TRIG_INT and not using DAC FIFO, need
to call comedi_event() in the inttrig function because it isn't being called
anywhere else.
Ian Abbott [Mon, 3 Dec 2007 13:31:49 +0000 (13:31 +0000)]
Avoid changing s->async->inttrig during an interrupt. In particular, do
not set it to NULL when stopping command during interrupt.
Ian Abbott [Fri, 30 Nov 2007 18:37:59 +0000 (18:37 +0000)]
Use DAC FIFO if the card has one (PCI230+ hardware version 2).
Ian Abbott [Fri, 30 Nov 2007 12:21:49 +0000 (12:21 +0000)]
Added enums for Amplicon DIO card clock and gate sources.
Ian Abbott [Thu, 29 Nov 2007 15:49:31 +0000 (15:49 +0000)]
For AO command test step 3, return 3 if external trigger flags have been
corrected.
Ian Abbott [Wed, 28 Nov 2007 14:48:18 +0000 (14:48 +0000)]
When stopping AO command, only stop timer if using it
(scan_begin_src==TRIG_TIMER).
Ian Abbott [Wed, 28 Nov 2007 11:12:17 +0000 (11:12 +0000)]
Release Z2-CT2 resource after AI command started if convert_src is neither
TRIG_TIMER nor TRIG_INT.
Ian Abbott [Tue, 27 Nov 2007 16:43:51 +0000 (16:43 +0000)]
Avoid using software conversion trigger as it doesn't work very well for
differential mode on some versions of PCI230/260. Use Z2 timer 2 output
instead and toggle the output in software to trigger a conversion. Note
that the ADC busy bit only works for software triggers in non-FIFO mode,
so for AI INSN_READ, use the FIFO and the FIFO status bits to check when
the conversion is complete.
Ian Abbott [Tue, 27 Nov 2007 13:17:02 +0000 (13:17 +0000)]
RTAI support was broken in comedi-0.7.75 due to missing RTAI_VERSION_CODE
and RTAI_MANGLE_VERSION in comedi/drivers/comedi_rt_timer.c.
Added #include <rtai_version.h> to include/linux/comedi_rt.h to fix it.
Ian Abbott [Tue, 27 Nov 2007 12:52:33 +0000 (12:52 +0000)]
Insert delay after AI internal conversion trigger (convert_src==TRIG_INT)
so we don't trigger more often than the hardware is capable of.
Ian Abbott [Mon, 26 Nov 2007 17:56:19 +0000 (17:56 +0000)]
Use programmable ADC FIFO interrupt trigger level and ADC FIFO level
registers on PCI230+/260+ to reduce number of interrupts required when
FIFO interrupt trigger level would otherwise be "trigger when not empty".
Bernd Porr [Sun, 25 Nov 2007 21:22:17 +0000 (21:22 +0000)]
Added PWM to the USBDUX. Also moved any synchronous commands to
EP1 which should reduce the latency dramatically because it is
single buffered which forces the host to wait (no race checks
needed anymore). The EP4 is now used for the PWM.
The bit patterns are generated in this driver
and the GPIF on the FX2 streams these automatically out through
the digital port.
Ian Abbott [Fri, 23 Nov 2007 17:09:08 +0000 (17:09 +0000)]
For AI command, allow scan_begin_src == EXT_TRIG for PCI260+ (but not PCI260).
It will use the EXTTRIG/EXTCONVCLK input on pin 17 instead of the PPIC0 input
that is used for PCI230.
Ian Abbott [Fri, 23 Nov 2007 16:47:44 +0000 (16:47 +0000)]
For AO command, support scan_begin_src == TRIG_INT. (Not terribly useful.)
Also, if scan_begin_src == TRIG_TIMER, make sure the timer gate is set high
to enable counting.
Ian Abbott [Fri, 23 Nov 2007 16:08:15 +0000 (16:08 +0000)]
For AI commands, support TRIG_INT for start_src, scan_begin_src and
convert_src, but not all at the same time.
Ian Abbott [Fri, 23 Nov 2007 15:05:16 +0000 (15:05 +0000)]
Increased maximum length of channel list for AI command to 256 to allow
a repeated subsequence of channels to be used with a reasonable number
of repeats. Can't make the maximum length too long or the generation of
N pulses using a monostable as a gate would generate too many pulses in
some circumstances.
Ian Abbott [Fri, 23 Nov 2007 14:55:04 +0000 (14:55 +0000)]
Support scan_begin_src == TRIG_TIMER for AI command, but not at same time
as AO command as it uses one of the same 8254 counters.
Also, gone back to using timer mode 3 (square wave) instead of mode 2 (pulse)
as it seems to induce less noise.
Ian Abbott [Fri, 23 Nov 2007 11:04:25 +0000 (11:04 +0000)]
Changed some macros. No functional changes.
Ian Abbott [Thu, 22 Nov 2007 18:20:20 +0000 (18:20 +0000)]
Overhauled setting up and handling of commands, internal timers, and
interrupts.
Frank Mori Hess [Wed, 21 Nov 2007 18:14:40 +0000 (18:14 +0000)]
Fixed offset for isolated digital input register on 1762.
Frank Mori Hess [Mon, 19 Nov 2007 22:42:33 +0000 (22:42 +0000)]
Added Jeremy Theler
Ian Abbott [Mon, 19 Nov 2007 12:26:41 +0000 (12:26 +0000)]
Changed types of some members of struct pci230_private and renamed 'ai_stop'
to 'ai_continuous' and 'ao_stop' to 'ao_continuous'. No functional changes.
Ian Abbott [Fri, 16 Nov 2007 14:34:46 +0000 (14:34 +0000)]
Reduced maximum speed (increased minimum period) for AO conversion
to 125 kHz (8000 ns).
Ian Abbott [Fri, 16 Nov 2007 14:07:55 +0000 (14:07 +0000)]
For ai_cmdtest, maximum AI convert rate depends on whether single-ended or
differential, and whether the card is a PCI230/260 or PCI230+/260+.
Ian Abbott [Fri, 16 Nov 2007 13:17:42 +0000 (13:17 +0000)]
Need to use 'do_div' macro for 64-bit division.
Ian Abbott [Thu, 15 Nov 2007 18:02:02 +0000 (18:02 +0000)]
For ai_cmdtest, check channel list starts with channel 0 if there is more
than one channel and the card is an older PCI230+ or PCI260+ with buggy
channel sequencing.
Ian Abbott [Thu, 15 Nov 2007 16:11:21 +0000 (16:11 +0000)]
Fix AI channel enables for AREF_DIFF if the hardware is PCI230+ or PCI260+
due to a difference in the way the register works between PCI230 and PCI230+
in differential mode.
Ian Abbott [Tue, 13 Nov 2007 12:01:08 +0000 (12:01 +0000)]
For AI command, when convert_src == TRIG_EXT, make interpretation of
convert_arg backwards compatible with previous versions if no flag bits
are set.
Frank Mori Hess [Mon, 12 Nov 2007 22:15:31 +0000 (22:15 +0000)]
Fixed sign error that prevented commands from aborting properly on
errors.
Ian Abbott [Mon, 12 Nov 2007 17:10:24 +0000 (17:10 +0000)]
Only added a comment.
Ian Abbott [Mon, 12 Nov 2007 16:45:45 +0000 (16:45 +0000)]
For AI command, changed interpretation of scan_begin_arg when scan_begin_src
is TRIG_EXT. Previously, 0 meant trigger on -ve edge, 1 meant +ve edge.
Now, the CR_INVERT flag is set to trigger on the -ve edge.
Ian Abbott [Mon, 12 Nov 2007 15:04:46 +0000 (15:04 +0000)]
The ADC half full flag flag and interrupt occurs at 2049 samples, not 2048
(i.e. it's an "over half full" flag since the FIFO size is 4096).
Ian Abbott [Mon, 12 Nov 2007 14:58:01 +0000 (14:58 +0000)]
Use arrays to look up ai gain bits and polarity.
Ian Abbott [Mon, 12 Nov 2007 14:16:05 +0000 (14:16 +0000)]
Stripped ".o" from driver name on "Driver:" line for consistency.
Ian Abbott [Mon, 12 Nov 2007 12:16:26 +0000 (12:16 +0000)]
For AI INSN_READ, check for out-of-range differential channel - only the
first half of the channel numbers can be used if analog ref is AREF_DIFF.
Frank Mori Hess [Sat, 10 Nov 2007 16:59:46 +0000 (16:59 +0000)]
Added new driver from jeremy theler <thelerg@ib.cnea.gov.ar> for
MicroAxial ADQ12-B.
Frank Mori Hess [Sat, 10 Nov 2007 16:53:17 +0000 (16:53 +0000)]
Adding trivial email address obfuscation, since some of the AUTHORS
files are linked to from the web page.
Ian Abbott [Fri, 9 Nov 2007 16:36:32 +0000 (16:36 +0000)]
In pci230_choose_clk_src(), widen the type of the comparison constant
6553600000 from ul to ull.
Ian Abbott [Fri, 9 Nov 2007 16:02:38 +0000 (16:02 +0000)]
Check channel lists in AI and AO cmdtest handlers if chanlist != NULL and
chanlist_len > 0.
Ian Abbott [Fri, 9 Nov 2007 15:39:24 +0000 (15:39 +0000)]
Minor line-length fixes.
Ian Abbott [Fri, 9 Nov 2007 15:23:42 +0000 (15:23 +0000)]
In cmdtest, use DPRINTK instead of comedi_error.
Ian Abbott [Fri, 9 Nov 2007 15:19:36 +0000 (15:19 +0000)]
For cmdtest, don't return 5 if chanlist_len == 0.
Ian Abbott [Fri, 9 Nov 2007 14:06:44 +0000 (14:06 +0000)]
For cmdtest, don't return error 5 if chanlist is NULL.
Ian Abbott [Fri, 9 Nov 2007 13:50:14 +0000 (13:50 +0000)]
For COMEDI_CMD ioctl, check chanlist_len > 0.
Ian Abbott [Fri, 9 Nov 2007 12:17:14 +0000 (12:17 +0000)]
I forgot to rename comedi_compat_ioctl_ function back to
comedi_compat_ioctl in the previous commit.
Ian Abbott [Fri, 9 Nov 2007 11:12:36 +0000 (11:12 +0000)]
Make the 'comedi_compat_ioctl' symbole a function (again) instead of a
macro (if HAVE_COMPAT_IOCTL is defined).
Ian Abbott [Thu, 8 Nov 2007 17:09:07 +0000 (17:09 +0000)]
Got rid of the timer subdevice as it was pretty useless and clashed with
the AO and AI subdevices. I may resurrect it as a counter subdevice at
some point.
Ian Abbott [Thu, 8 Nov 2007 17:02:36 +0000 (17:02 +0000)]
Use 64-bit ns value when determining clock source.
Ian Abbott [Thu, 8 Nov 2007 16:45:45 +0000 (16:45 +0000)]
Renamed pci_iobase to iobase1.