Merge 5.16-rc3 into char-misc-next
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 29 Nov 2021 07:00:54 +0000 (08:00 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 29 Nov 2021 07:00:54 +0000 (08:00 +0100)
We need the char/misc fixes in here as well.

Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
174 files changed:
MAINTAINERS
drivers/accessibility/speakup/speakup_acntpc.c
drivers/accessibility/speakup/speakup_dtlk.c
drivers/accessibility/speakup/speakup_keypc.c
drivers/comedi/comedi.h [deleted file]
drivers/comedi/comedi_buf.c
drivers/comedi/comedi_fops.c
drivers/comedi/comedi_pci.c
drivers/comedi/comedi_pci.h [deleted file]
drivers/comedi/comedi_pcmcia.c
drivers/comedi/comedi_pcmcia.h [deleted file]
drivers/comedi/comedi_usb.c
drivers/comedi/comedi_usb.h [deleted file]
drivers/comedi/comedidev.h [deleted file]
drivers/comedi/comedilib.h [deleted file]
drivers/comedi/drivers.c
drivers/comedi/drivers/8255.c
drivers/comedi/drivers/8255.h [deleted file]
drivers/comedi/drivers/8255_pci.c
drivers/comedi/drivers/addi_apci_1032.c
drivers/comedi/drivers/addi_apci_1500.c
drivers/comedi/drivers/addi_apci_1516.c
drivers/comedi/drivers/addi_apci_1564.c
drivers/comedi/drivers/addi_apci_16xx.c
drivers/comedi/drivers/addi_apci_2032.c
drivers/comedi/drivers/addi_apci_2200.c
drivers/comedi/drivers/addi_apci_3120.c
drivers/comedi/drivers/addi_apci_3501.c
drivers/comedi/drivers/addi_apci_3xxx.c
drivers/comedi/drivers/addi_watchdog.c
drivers/comedi/drivers/adl_pci6208.c
drivers/comedi/drivers/adl_pci7x3x.c
drivers/comedi/drivers/adl_pci8164.c
drivers/comedi/drivers/adl_pci9111.c
drivers/comedi/drivers/adl_pci9118.c
drivers/comedi/drivers/adq12b.c
drivers/comedi/drivers/adv_pci1710.c
drivers/comedi/drivers/adv_pci1720.c
drivers/comedi/drivers/adv_pci1723.c
drivers/comedi/drivers/adv_pci1724.c
drivers/comedi/drivers/adv_pci1760.c
drivers/comedi/drivers/adv_pci_dio.c
drivers/comedi/drivers/aio_aio12_8.c
drivers/comedi/drivers/aio_iiro_16.c
drivers/comedi/drivers/amplc_dio200.c
drivers/comedi/drivers/amplc_dio200_common.c
drivers/comedi/drivers/amplc_dio200_pci.c
drivers/comedi/drivers/amplc_pc236.c
drivers/comedi/drivers/amplc_pc236_common.c
drivers/comedi/drivers/amplc_pc263.c
drivers/comedi/drivers/amplc_pci224.c
drivers/comedi/drivers/amplc_pci230.c
drivers/comedi/drivers/amplc_pci236.c
drivers/comedi/drivers/amplc_pci263.c
drivers/comedi/drivers/c6xdigio.c
drivers/comedi/drivers/cb_das16_cs.c
drivers/comedi/drivers/cb_pcidas.c
drivers/comedi/drivers/cb_pcidas64.c
drivers/comedi/drivers/cb_pcidda.c
drivers/comedi/drivers/cb_pcimdas.c
drivers/comedi/drivers/cb_pcimdda.c
drivers/comedi/drivers/comedi_8254.c
drivers/comedi/drivers/comedi_8254.h [deleted file]
drivers/comedi/drivers/comedi_8255.c
drivers/comedi/drivers/comedi_bond.c
drivers/comedi/drivers/comedi_isadma.c
drivers/comedi/drivers/comedi_isadma.h [deleted file]
drivers/comedi/drivers/comedi_parport.c
drivers/comedi/drivers/comedi_test.c
drivers/comedi/drivers/contec_pci_dio.c
drivers/comedi/drivers/dac02.c
drivers/comedi/drivers/daqboard2000.c
drivers/comedi/drivers/das08.c
drivers/comedi/drivers/das08_cs.c
drivers/comedi/drivers/das08_isa.c
drivers/comedi/drivers/das08_pci.c
drivers/comedi/drivers/das16.c
drivers/comedi/drivers/das16m1.c
drivers/comedi/drivers/das1800.c
drivers/comedi/drivers/das6402.c
drivers/comedi/drivers/das800.c
drivers/comedi/drivers/dmm32at.c
drivers/comedi/drivers/dt2801.c
drivers/comedi/drivers/dt2811.c
drivers/comedi/drivers/dt2814.c
drivers/comedi/drivers/dt2815.c
drivers/comedi/drivers/dt2817.c
drivers/comedi/drivers/dt282x.c
drivers/comedi/drivers/dt3000.c
drivers/comedi/drivers/dt9812.c
drivers/comedi/drivers/dyna_pci10xx.c
drivers/comedi/drivers/fl512.c
drivers/comedi/drivers/gsc_hpdi.c
drivers/comedi/drivers/icp_multi.c
drivers/comedi/drivers/ii_pci20kc.c
drivers/comedi/drivers/jr3_pci.c
drivers/comedi/drivers/ke_counter.c
drivers/comedi/drivers/me4000.c
drivers/comedi/drivers/me_daq.c
drivers/comedi/drivers/mf6x4.c
drivers/comedi/drivers/mite.c
drivers/comedi/drivers/mpc624.c
drivers/comedi/drivers/multiq3.c
drivers/comedi/drivers/ni_6527.c
drivers/comedi/drivers/ni_65xx.c
drivers/comedi/drivers/ni_660x.c
drivers/comedi/drivers/ni_670x.c
drivers/comedi/drivers/ni_at_a2150.c
drivers/comedi/drivers/ni_at_ao.c
drivers/comedi/drivers/ni_atmio.c
drivers/comedi/drivers/ni_atmio16d.c
drivers/comedi/drivers/ni_daq_700.c
drivers/comedi/drivers/ni_daq_dio24.c
drivers/comedi/drivers/ni_labpc.c
drivers/comedi/drivers/ni_labpc_common.c
drivers/comedi/drivers/ni_labpc_cs.c
drivers/comedi/drivers/ni_labpc_isadma.c
drivers/comedi/drivers/ni_labpc_pci.c
drivers/comedi/drivers/ni_mio_common.c
drivers/comedi/drivers/ni_mio_cs.c
drivers/comedi/drivers/ni_pcidio.c
drivers/comedi/drivers/ni_pcimio.c
drivers/comedi/drivers/ni_routes.c
drivers/comedi/drivers/ni_routes.h
drivers/comedi/drivers/ni_routing/ni_route_values.h
drivers/comedi/drivers/ni_routing/tools/.gitignore
drivers/comedi/drivers/ni_routing/tools/Makefile
drivers/comedi/drivers/ni_tio.h
drivers/comedi/drivers/ni_usb6501.c
drivers/comedi/drivers/pcl711.c
drivers/comedi/drivers/pcl724.c
drivers/comedi/drivers/pcl726.c
drivers/comedi/drivers/pcl730.c
drivers/comedi/drivers/pcl812.c
drivers/comedi/drivers/pcl816.c
drivers/comedi/drivers/pcl818.c
drivers/comedi/drivers/pcm3724.c
drivers/comedi/drivers/pcmad.c
drivers/comedi/drivers/pcmda12.c
drivers/comedi/drivers/pcmmio.c
drivers/comedi/drivers/pcmuio.c
drivers/comedi/drivers/quatech_daqp_cs.c
drivers/comedi/drivers/rtd520.c
drivers/comedi/drivers/rti800.c
drivers/comedi/drivers/rti802.c
drivers/comedi/drivers/s526.c
drivers/comedi/drivers/s626.c
drivers/comedi/drivers/ssv_dnp.c
drivers/comedi/drivers/usbdux.c
drivers/comedi/drivers/usbduxfast.c
drivers/comedi/drivers/usbduxsigma.c
drivers/comedi/drivers/vmk80xx.c
drivers/comedi/kcomedilib/kcomedilib_main.c
drivers/comedi/proc.c
drivers/comedi/range.c
drivers/firmware/xilinx/zynqmp.c
drivers/most/most_usb.c
drivers/soc/xilinx/zynqmp_power.c
drivers/virt/nitro_enclaves/Kconfig
drivers/virt/nitro_enclaves/ne_misc_dev.c
drivers/virt/nitro_enclaves/ne_misc_dev_test.c [new file with mode: 0644]
drivers/virt/nitro_enclaves/ne_pci_dev.c
include/linux/byteorder/generic.h
include/linux/comedi/comedi_8254.h [new file with mode: 0644]
include/linux/comedi/comedi_8255.h [new file with mode: 0644]
include/linux/comedi/comedi_isadma.h [new file with mode: 0644]
include/linux/comedi/comedi_pci.h [new file with mode: 0644]
include/linux/comedi/comedi_pcmcia.h [new file with mode: 0644]
include/linux/comedi/comedi_usb.h [new file with mode: 0644]
include/linux/comedi/comedidev.h [new file with mode: 0644]
include/linux/comedi/comedilib.h [new file with mode: 0644]
include/linux/firmware/xlnx-zynqmp.h
include/uapi/linux/comedi.h [new file with mode: 0644]
scripts/tags.sh

index 360e9aa..0533c00 100644 (file)
@@ -4724,6 +4724,8 @@ M:        Ian Abbott <abbotti@mev.co.uk>
 M:     H Hartley Sweeten <hsweeten@visionengravers.com>
 S:     Odd Fixes
 F:     drivers/comedi/
+F:     include/linux/comedi/
+F:     include/uapi/linux/comedi.h
 
 COMMON CLK FRAMEWORK
 M:     Michael Turquette <mturquette@baylibre.com>
index c1ec087..023172c 100644 (file)
@@ -247,7 +247,7 @@ static void synth_flush(struct spk_synth *synth)
 static int synth_probe(struct spk_synth *synth)
 {
        unsigned int port_val = 0;
-       int i = 0;
+       int i;
 
        pr_info("Probing for %s.\n", synth->long_name);
        if (port_forced) {
index 92838d3..a9dd5c4 100644 (file)
@@ -316,7 +316,7 @@ static struct synth_settings *synth_interrogate(struct spk_synth *synth)
 static int synth_probe(struct spk_synth *synth)
 {
        unsigned int port_val = 0;
-       int i = 0;
+       int i;
        struct synth_settings *sp;
 
        pr_info("Probing for DoubleTalk.\n");
index 311f4aa..1618be8 100644 (file)
@@ -254,7 +254,7 @@ static void synth_flush(struct spk_synth *synth)
 static int synth_probe(struct spk_synth *synth)
 {
        unsigned int port_val = 0;
-       int i = 0;
+       int i;
 
        pr_info("Probing for %s.\n", synth->long_name);
        if (port_forced) {
diff --git a/drivers/comedi/comedi.h b/drivers/comedi/comedi.h
deleted file mode 100644 (file)
index b5d00a0..0000000
+++ /dev/null
@@ -1,1528 +0,0 @@
-/* SPDX-License-Identifier: LGPL-2.0+ */
-/*
- * comedi.h
- * header file for COMEDI user API
- *
- * COMEDI - Linux Control and Measurement Device Interface
- * Copyright (C) 1998-2001 David A. Schleef <ds@schleef.org>
- */
-
-#ifndef _COMEDI_H
-#define _COMEDI_H
-
-#define COMEDI_MAJORVERSION    0
-#define COMEDI_MINORVERSION    7
-#define COMEDI_MICROVERSION    76
-#define VERSION        "0.7.76"
-
-/* comedi's major device number */
-#define COMEDI_MAJOR 98
-
-/*
- * maximum number of minor devices.  This can be increased, although
- * kernel structures are currently statically allocated, thus you
- * don't want this to be much more than you actually use.
- */
-#define COMEDI_NDEVICES 16
-
-/* number of config options in the config structure */
-#define COMEDI_NDEVCONFOPTS 32
-
-/*
- * NOTE: 'comedi_config --init-data' is deprecated
- *
- * The following indexes in the config options were used by
- * comedi_config to pass firmware blobs from user space to the
- * comedi drivers. The request_firmware() hotplug interface is
- * now used by all comedi drivers instead.
- */
-
-/* length of nth chunk of firmware data -*/
-#define COMEDI_DEVCONF_AUX_DATA3_LENGTH                25
-#define COMEDI_DEVCONF_AUX_DATA2_LENGTH                26
-#define COMEDI_DEVCONF_AUX_DATA1_LENGTH                27
-#define COMEDI_DEVCONF_AUX_DATA0_LENGTH                28
-/* most significant 32 bits of pointer address (if needed) */
-#define COMEDI_DEVCONF_AUX_DATA_HI             29
-/* least significant 32 bits of pointer address */
-#define COMEDI_DEVCONF_AUX_DATA_LO             30
-#define COMEDI_DEVCONF_AUX_DATA_LENGTH         31      /* total data length */
-
-/* max length of device and driver names */
-#define COMEDI_NAMELEN 20
-
-/* packs and unpacks a channel/range number */
-
-#define CR_PACK(chan, rng, aref)                                       \
-       ((((aref) & 0x3) << 24) | (((rng) & 0xff) << 16) | (chan))
-#define CR_PACK_FLAGS(chan, range, aref, flags)                                \
-       (CR_PACK(chan, range, aref) | ((flags) & CR_FLAGS_MASK))
-
-#define CR_CHAN(a)     ((a) & 0xffff)
-#define CR_RANGE(a)    (((a) >> 16) & 0xff)
-#define CR_AREF(a)     (((a) >> 24) & 0x03)
-
-#define CR_FLAGS_MASK  0xfc000000
-#define CR_ALT_FILTER  0x04000000
-#define CR_DITHER      CR_ALT_FILTER
-#define CR_DEGLITCH    CR_ALT_FILTER
-#define CR_ALT_SOURCE  0x08000000
-#define CR_EDGE                0x40000000
-#define CR_INVERT      0x80000000
-
-#define AREF_GROUND    0x00    /* analog ref = analog ground */
-#define AREF_COMMON    0x01    /* analog ref = analog common */
-#define AREF_DIFF      0x02    /* analog ref = differential */
-#define AREF_OTHER     0x03    /* analog ref = other (undefined) */
-
-/* counters -- these are arbitrary values */
-#define GPCT_RESET             0x0001
-#define GPCT_SET_SOURCE                0x0002
-#define GPCT_SET_GATE          0x0004
-#define GPCT_SET_DIRECTION     0x0008
-#define GPCT_SET_OPERATION     0x0010
-#define GPCT_ARM               0x0020
-#define GPCT_DISARM            0x0040
-#define GPCT_GET_INT_CLK_FRQ   0x0080
-
-#define GPCT_INT_CLOCK         0x0001
-#define GPCT_EXT_PIN           0x0002
-#define GPCT_NO_GATE           0x0004
-#define GPCT_UP                        0x0008
-#define GPCT_DOWN              0x0010
-#define GPCT_HWUD              0x0020
-#define GPCT_SIMPLE_EVENT      0x0040
-#define GPCT_SINGLE_PERIOD     0x0080
-#define GPCT_SINGLE_PW         0x0100
-#define GPCT_CONT_PULSE_OUT    0x0200
-#define GPCT_SINGLE_PULSE_OUT  0x0400
-
-/* instructions */
-
-#define INSN_MASK_WRITE                0x8000000
-#define INSN_MASK_READ         0x4000000
-#define INSN_MASK_SPECIAL      0x2000000
-
-#define INSN_READ              (0 | INSN_MASK_READ)
-#define INSN_WRITE             (1 | INSN_MASK_WRITE)
-#define INSN_BITS              (2 | INSN_MASK_READ | INSN_MASK_WRITE)
-#define INSN_CONFIG            (3 | INSN_MASK_READ | INSN_MASK_WRITE)
-#define INSN_DEVICE_CONFIG     (INSN_CONFIG | INSN_MASK_SPECIAL)
-#define INSN_GTOD              (4 | INSN_MASK_READ | INSN_MASK_SPECIAL)
-#define INSN_WAIT              (5 | INSN_MASK_WRITE | INSN_MASK_SPECIAL)
-#define INSN_INTTRIG           (6 | INSN_MASK_WRITE | INSN_MASK_SPECIAL)
-
-/* command flags */
-/* These flags are used in comedi_cmd structures */
-
-#define CMDF_BOGUS             0x00000001      /* do the motions */
-
-/* try to use a real-time interrupt while performing command */
-#define CMDF_PRIORITY          0x00000008
-
-/* wake up on end-of-scan events */
-#define CMDF_WAKE_EOS          0x00000020
-
-#define CMDF_WRITE             0x00000040
-
-#define CMDF_RAWDATA           0x00000080
-
-/* timer rounding definitions */
-#define CMDF_ROUND_MASK                0x00030000
-#define CMDF_ROUND_NEAREST     0x00000000
-#define CMDF_ROUND_DOWN                0x00010000
-#define CMDF_ROUND_UP          0x00020000
-#define CMDF_ROUND_UP_NEXT     0x00030000
-
-#define COMEDI_EV_START                0x00040000
-#define COMEDI_EV_SCAN_BEGIN   0x00080000
-#define COMEDI_EV_CONVERT      0x00100000
-#define COMEDI_EV_SCAN_END     0x00200000
-#define COMEDI_EV_STOP         0x00400000
-
-/* compatibility definitions */
-#define TRIG_BOGUS             CMDF_BOGUS
-#define TRIG_RT                        CMDF_PRIORITY
-#define TRIG_WAKE_EOS          CMDF_WAKE_EOS
-#define TRIG_WRITE             CMDF_WRITE
-#define TRIG_ROUND_MASK                CMDF_ROUND_MASK
-#define TRIG_ROUND_NEAREST     CMDF_ROUND_NEAREST
-#define TRIG_ROUND_DOWN                CMDF_ROUND_DOWN
-#define TRIG_ROUND_UP          CMDF_ROUND_UP
-#define TRIG_ROUND_UP_NEXT     CMDF_ROUND_UP_NEXT
-
-/* trigger sources */
-
-#define TRIG_ANY       0xffffffff
-#define TRIG_INVALID   0x00000000
-
-#define TRIG_NONE      0x00000001 /* never trigger */
-#define TRIG_NOW       0x00000002 /* trigger now + N ns */
-#define TRIG_FOLLOW    0x00000004 /* trigger on next lower level trig */
-#define TRIG_TIME      0x00000008 /* trigger at time N ns */
-#define TRIG_TIMER     0x00000010 /* trigger at rate N ns */
-#define TRIG_COUNT     0x00000020 /* trigger when count reaches N */
-#define TRIG_EXT       0x00000040 /* trigger on external signal N */
-#define TRIG_INT       0x00000080 /* trigger on comedi-internal signal N */
-#define TRIG_OTHER     0x00000100 /* driver defined */
-
-/* subdevice flags */
-
-#define SDF_BUSY       0x0001  /* device is busy */
-#define SDF_BUSY_OWNER 0x0002  /* device is busy with your job */
-#define SDF_LOCKED     0x0004  /* subdevice is locked */
-#define SDF_LOCK_OWNER 0x0008  /* you own lock */
-#define SDF_MAXDATA    0x0010  /* maxdata depends on channel */
-#define SDF_FLAGS      0x0020  /* flags depend on channel */
-#define SDF_RANGETYPE  0x0040  /* range type depends on channel */
-#define SDF_PWM_COUNTER 0x0080 /* PWM can automatically switch off */
-#define SDF_PWM_HBRIDGE 0x0100 /* PWM is signed (H-bridge) */
-#define SDF_CMD                0x1000  /* can do commands (deprecated) */
-#define SDF_SOFT_CALIBRATED    0x2000 /* subdevice uses software calibration */
-#define SDF_CMD_WRITE          0x4000 /* can do output commands */
-#define SDF_CMD_READ           0x8000 /* can do input commands */
-
-/* subdevice can be read (e.g. analog input) */
-#define SDF_READABLE   0x00010000
-/* subdevice can be written (e.g. analog output) */
-#define SDF_WRITABLE   0x00020000
-#define SDF_WRITEABLE  SDF_WRITABLE    /* spelling error in API */
-/* subdevice does not have externally visible lines */
-#define SDF_INTERNAL   0x00040000
-#define SDF_GROUND     0x00100000      /* can do aref=ground */
-#define SDF_COMMON     0x00200000      /* can do aref=common */
-#define SDF_DIFF       0x00400000      /* can do aref=diff */
-#define SDF_OTHER      0x00800000      /* can do aref=other */
-#define SDF_DITHER     0x01000000      /* can do dithering */
-#define SDF_DEGLITCH   0x02000000      /* can do deglitching */
-#define SDF_MMAP       0x04000000      /* can do mmap() */
-#define SDF_RUNNING    0x08000000      /* subdevice is acquiring data */
-#define SDF_LSAMPL     0x10000000      /* subdevice uses 32-bit samples */
-#define SDF_PACKED     0x20000000      /* subdevice can do packed DIO */
-
-/* subdevice types */
-
-/**
- * enum comedi_subdevice_type - COMEDI subdevice types
- * @COMEDI_SUBD_UNUSED:                Unused subdevice.
- * @COMEDI_SUBD_AI:            Analog input.
- * @COMEDI_SUBD_AO:            Analog output.
- * @COMEDI_SUBD_DI:            Digital input.
- * @COMEDI_SUBD_DO:            Digital output.
- * @COMEDI_SUBD_DIO:           Digital input/output.
- * @COMEDI_SUBD_COUNTER:       Counter.
- * @COMEDI_SUBD_TIMER:         Timer.
- * @COMEDI_SUBD_MEMORY:                Memory, EEPROM, DPRAM.
- * @COMEDI_SUBD_CALIB:         Calibration DACs.
- * @COMEDI_SUBD_PROC:          Processor, DSP.
- * @COMEDI_SUBD_SERIAL:                Serial I/O.
- * @COMEDI_SUBD_PWM:           Pulse-Width Modulation output.
- */
-enum comedi_subdevice_type {
-       COMEDI_SUBD_UNUSED,
-       COMEDI_SUBD_AI,
-       COMEDI_SUBD_AO,
-       COMEDI_SUBD_DI,
-       COMEDI_SUBD_DO,
-       COMEDI_SUBD_DIO,
-       COMEDI_SUBD_COUNTER,
-       COMEDI_SUBD_TIMER,
-       COMEDI_SUBD_MEMORY,
-       COMEDI_SUBD_CALIB,
-       COMEDI_SUBD_PROC,
-       COMEDI_SUBD_SERIAL,
-       COMEDI_SUBD_PWM
-};
-
-/* configuration instructions */
-
-/**
- * enum comedi_io_direction - COMEDI I/O directions
- * @COMEDI_INPUT:      Input.
- * @COMEDI_OUTPUT:     Output.
- * @COMEDI_OPENDRAIN:  Open-drain (or open-collector) output.
- *
- * These are used by the %INSN_CONFIG_DIO_QUERY configuration instruction to
- * report a direction.  They may also be used in other places where a direction
- * needs to be specified.
- */
-enum comedi_io_direction {
-       COMEDI_INPUT = 0,
-       COMEDI_OUTPUT = 1,
-       COMEDI_OPENDRAIN = 2
-};
-
-/**
- * enum configuration_ids - COMEDI configuration instruction codes
- * @INSN_CONFIG_DIO_INPUT:     Configure digital I/O as input.
- * @INSN_CONFIG_DIO_OUTPUT:    Configure digital I/O as output.
- * @INSN_CONFIG_DIO_OPENDRAIN: Configure digital I/O as open-drain (or open
- *                             collector) output.
- * @INSN_CONFIG_ANALOG_TRIG:   Configure analog trigger.
- * @INSN_CONFIG_ALT_SOURCE:    Configure alternate input source.
- * @INSN_CONFIG_DIGITAL_TRIG:  Configure digital trigger.
- * @INSN_CONFIG_BLOCK_SIZE:    Configure block size for DMA transfers.
- * @INSN_CONFIG_TIMER_1:       Configure divisor for external clock.
- * @INSN_CONFIG_FILTER:                Configure a filter.
- * @INSN_CONFIG_CHANGE_NOTIFY: Configure change notification for digital
- *                             inputs.  (New drivers should use
- *                             %INSN_CONFIG_DIGITAL_TRIG instead.)
- * @INSN_CONFIG_SERIAL_CLOCK:  Configure clock for serial I/O.
- * @INSN_CONFIG_BIDIRECTIONAL_DATA: Send and receive byte over serial I/O.
- * @INSN_CONFIG_DIO_QUERY:     Query direction of digital I/O channel.
- * @INSN_CONFIG_PWM_OUTPUT:    Configure pulse-width modulator output.
- * @INSN_CONFIG_GET_PWM_OUTPUT:        Get pulse-width modulator output configuration.
- * @INSN_CONFIG_ARM:           Arm a subdevice or channel.
- * @INSN_CONFIG_DISARM:                Disarm a subdevice or channel.
- * @INSN_CONFIG_GET_COUNTER_STATUS: Get counter status.
- * @INSN_CONFIG_RESET:         Reset a subdevice or channel.
- * @INSN_CONFIG_GPCT_SINGLE_PULSE_GENERATOR: Configure counter/timer as
- *                             single pulse generator.
- * @INSN_CONFIG_GPCT_PULSE_TRAIN_GENERATOR: Configure counter/timer as
- *                             pulse train generator.
- * @INSN_CONFIG_GPCT_QUADRATURE_ENCODER: Configure counter as a quadrature
- *                             encoder.
- * @INSN_CONFIG_SET_GATE_SRC:  Set counter/timer gate source.
- * @INSN_CONFIG_GET_GATE_SRC:  Get counter/timer gate source.
- * @INSN_CONFIG_SET_CLOCK_SRC: Set counter/timer master clock source.
- * @INSN_CONFIG_GET_CLOCK_SRC: Get counter/timer master clock source.
- * @INSN_CONFIG_SET_OTHER_SRC: Set counter/timer "other" source.
- * @INSN_CONFIG_GET_HARDWARE_BUFFER_SIZE: Get size (in bytes) of subdevice's
- *                             on-board FIFOs used during streaming
- *                             input/output.
- * @INSN_CONFIG_SET_COUNTER_MODE: Set counter/timer mode.
- * @INSN_CONFIG_8254_SET_MODE: (Deprecated) Same as
- *                             %INSN_CONFIG_SET_COUNTER_MODE.
- * @INSN_CONFIG_8254_READ_STATUS: Read status of 8254 counter channel.
- * @INSN_CONFIG_SET_ROUTING:   Set routing for a channel.
- * @INSN_CONFIG_GET_ROUTING:   Get routing for a channel.
- * @INSN_CONFIG_PWM_SET_PERIOD: Set PWM period in nanoseconds.
- * @INSN_CONFIG_PWM_GET_PERIOD: Get PWM period in nanoseconds.
- * @INSN_CONFIG_GET_PWM_STATUS: Get PWM status.
- * @INSN_CONFIG_PWM_SET_H_BRIDGE: Set PWM H bridge duty cycle and polarity for
- *                             a relay simultaneously.
- * @INSN_CONFIG_PWM_GET_H_BRIDGE: Get PWM H bridge duty cycle and polarity.
- * @INSN_CONFIG_GET_CMD_TIMING_CONSTRAINTS: Get the hardware timing restraints,
- *                             regardless of trigger sources.
- */
-enum configuration_ids {
-       INSN_CONFIG_DIO_INPUT = COMEDI_INPUT,
-       INSN_CONFIG_DIO_OUTPUT = COMEDI_OUTPUT,
-       INSN_CONFIG_DIO_OPENDRAIN = COMEDI_OPENDRAIN,
-       INSN_CONFIG_ANALOG_TRIG = 16,
-/*     INSN_CONFIG_WAVEFORM = 17, */
-/*     INSN_CONFIG_TRIG = 18, */
-/*     INSN_CONFIG_COUNTER = 19, */
-       INSN_CONFIG_ALT_SOURCE = 20,
-       INSN_CONFIG_DIGITAL_TRIG = 21,
-       INSN_CONFIG_BLOCK_SIZE = 22,
-       INSN_CONFIG_TIMER_1 = 23,
-       INSN_CONFIG_FILTER = 24,
-       INSN_CONFIG_CHANGE_NOTIFY = 25,
-
-       INSN_CONFIG_SERIAL_CLOCK = 26,  /*ALPHA*/
-       INSN_CONFIG_BIDIRECTIONAL_DATA = 27,
-       INSN_CONFIG_DIO_QUERY = 28,
-       INSN_CONFIG_PWM_OUTPUT = 29,
-       INSN_CONFIG_GET_PWM_OUTPUT = 30,
-       INSN_CONFIG_ARM = 31,
-       INSN_CONFIG_DISARM = 32,
-       INSN_CONFIG_GET_COUNTER_STATUS = 33,
-       INSN_CONFIG_RESET = 34,
-       INSN_CONFIG_GPCT_SINGLE_PULSE_GENERATOR = 1001,
-       INSN_CONFIG_GPCT_PULSE_TRAIN_GENERATOR = 1002,
-       INSN_CONFIG_GPCT_QUADRATURE_ENCODER = 1003,
-       INSN_CONFIG_SET_GATE_SRC = 2001,
-       INSN_CONFIG_GET_GATE_SRC = 2002,
-       INSN_CONFIG_SET_CLOCK_SRC = 2003,
-       INSN_CONFIG_GET_CLOCK_SRC = 2004,
-       INSN_CONFIG_SET_OTHER_SRC = 2005,
-       INSN_CONFIG_GET_HARDWARE_BUFFER_SIZE = 2006,
-       INSN_CONFIG_SET_COUNTER_MODE = 4097,
-       INSN_CONFIG_8254_SET_MODE = INSN_CONFIG_SET_COUNTER_MODE,
-       INSN_CONFIG_8254_READ_STATUS = 4098,
-       INSN_CONFIG_SET_ROUTING = 4099,
-       INSN_CONFIG_GET_ROUTING = 4109,
-       INSN_CONFIG_PWM_SET_PERIOD = 5000,
-       INSN_CONFIG_PWM_GET_PERIOD = 5001,
-       INSN_CONFIG_GET_PWM_STATUS = 5002,
-       INSN_CONFIG_PWM_SET_H_BRIDGE = 5003,
-       INSN_CONFIG_PWM_GET_H_BRIDGE = 5004,
-       INSN_CONFIG_GET_CMD_TIMING_CONSTRAINTS = 5005,
-};
-
-/**
- * enum device_configuration_ids - COMEDI configuration instruction codes global
- * to an entire device.
- * @INSN_DEVICE_CONFIG_TEST_ROUTE:     Validate the possibility of a
- *                                     globally-named route
- * @INSN_DEVICE_CONFIG_CONNECT_ROUTE:  Connect a globally-named route
- * @INSN_DEVICE_CONFIG_DISCONNECT_ROUTE:Disconnect a globally-named route
- * @INSN_DEVICE_CONFIG_GET_ROUTES:     Get a list of all globally-named routes
- *                                     that are valid for a particular device.
- */
-enum device_config_route_ids {
-       INSN_DEVICE_CONFIG_TEST_ROUTE = 0,
-       INSN_DEVICE_CONFIG_CONNECT_ROUTE = 1,
-       INSN_DEVICE_CONFIG_DISCONNECT_ROUTE = 2,
-       INSN_DEVICE_CONFIG_GET_ROUTES = 3,
-};
-
-/**
- * enum comedi_digital_trig_op - operations for configuring a digital trigger
- * @COMEDI_DIGITAL_TRIG_DISABLE:       Return digital trigger to its default,
- *                                     inactive, unconfigured state.
- * @COMEDI_DIGITAL_TRIG_ENABLE_EDGES:  Set rising and/or falling edge inputs
- *                                     that each can fire the trigger.
- * @COMEDI_DIGITAL_TRIG_ENABLE_LEVELS: Set a combination of high and/or low
- *                                     level inputs that can fire the trigger.
- *
- * These are used with the %INSN_CONFIG_DIGITAL_TRIG configuration instruction.
- * The data for the configuration instruction is as follows...
- *
- *   data[%0] = %INSN_CONFIG_DIGITAL_TRIG
- *
- *   data[%1] = trigger ID
- *
- *   data[%2] = configuration operation
- *
- *   data[%3] = configuration parameter 1
- *
- *   data[%4] = configuration parameter 2
- *
- *   data[%5] = configuration parameter 3
- *
- * The trigger ID (data[%1]) is used to differentiate multiple digital triggers
- * belonging to the same subdevice.  The configuration operation (data[%2]) is
- * one of the enum comedi_digital_trig_op values.  The configuration
- * parameters (data[%3], data[%4], and data[%5]) depend on the operation; they
- * are not used with %COMEDI_DIGITAL_TRIG_DISABLE.
- *
- * For %COMEDI_DIGITAL_TRIG_ENABLE_EDGES and %COMEDI_DIGITAL_TRIG_ENABLE_LEVELS,
- * configuration parameter 1 (data[%3]) contains a "left-shift" value that
- * specifies the input corresponding to bit 0 of configuration parameters 2
- * and 3.  This is useful if the trigger has more than 32 inputs.
- *
- * For %COMEDI_DIGITAL_TRIG_ENABLE_EDGES, configuration parameter 2 (data[%4])
- * specifies which of up to 32 inputs have rising-edge sensitivity, and
- * configuration parameter 3 (data[%5]) specifies which of up to 32 inputs
- * have falling-edge sensitivity that can fire the trigger.
- *
- * For %COMEDI_DIGITAL_TRIG_ENABLE_LEVELS, configuration parameter 2 (data[%4])
- * specifies which of up to 32 inputs must be at a high level, and
- * configuration parameter 3 (data[%5]) specifies which of up to 32 inputs
- * must be at a low level for the trigger to fire.
- *
- * Some sequences of %INSN_CONFIG_DIGITAL_TRIG instructions may have a (partly)
- * accumulative effect, depending on the low-level driver.  This is useful
- * when setting up a trigger that has more than 32 inputs, or has a combination
- * of edge- and level-triggered inputs.
- */
-enum comedi_digital_trig_op {
-       COMEDI_DIGITAL_TRIG_DISABLE = 0,
-       COMEDI_DIGITAL_TRIG_ENABLE_EDGES = 1,
-       COMEDI_DIGITAL_TRIG_ENABLE_LEVELS = 2
-};
-
-/**
- * enum comedi_support_level - support level for a COMEDI feature
- * @COMEDI_UNKNOWN_SUPPORT:    Unspecified support for feature.
- * @COMEDI_SUPPORTED:          Feature is supported.
- * @COMEDI_UNSUPPORTED:                Feature is unsupported.
- */
-enum comedi_support_level {
-       COMEDI_UNKNOWN_SUPPORT = 0,
-       COMEDI_SUPPORTED,
-       COMEDI_UNSUPPORTED
-};
-
-/**
- * enum comedi_counter_status_flags - counter status bits
- * @COMEDI_COUNTER_ARMED:              Counter is armed.
- * @COMEDI_COUNTER_COUNTING:           Counter is counting.
- * @COMEDI_COUNTER_TERMINAL_COUNT:     Counter reached terminal count.
- *
- * These bitwise values are used by the %INSN_CONFIG_GET_COUNTER_STATUS
- * configuration instruction to report the status of a counter.
- */
-enum comedi_counter_status_flags {
-       COMEDI_COUNTER_ARMED = 0x1,
-       COMEDI_COUNTER_COUNTING = 0x2,
-       COMEDI_COUNTER_TERMINAL_COUNT = 0x4,
-};
-
-/* ioctls */
-
-#define CIO 'd'
-#define COMEDI_DEVCONFIG _IOW(CIO, 0, struct comedi_devconfig)
-#define COMEDI_DEVINFO _IOR(CIO, 1, struct comedi_devinfo)
-#define COMEDI_SUBDINFO _IOR(CIO, 2, struct comedi_subdinfo)
-#define COMEDI_CHANINFO _IOR(CIO, 3, struct comedi_chaninfo)
-/* _IOWR(CIO, 4, ...) is reserved */
-#define COMEDI_LOCK _IO(CIO, 5)
-#define COMEDI_UNLOCK _IO(CIO, 6)
-#define COMEDI_CANCEL _IO(CIO, 7)
-#define COMEDI_RANGEINFO _IOR(CIO, 8, struct comedi_rangeinfo)
-#define COMEDI_CMD _IOR(CIO, 9, struct comedi_cmd)
-#define COMEDI_CMDTEST _IOR(CIO, 10, struct comedi_cmd)
-#define COMEDI_INSNLIST _IOR(CIO, 11, struct comedi_insnlist)
-#define COMEDI_INSN _IOR(CIO, 12, struct comedi_insn)
-#define COMEDI_BUFCONFIG _IOR(CIO, 13, struct comedi_bufconfig)
-#define COMEDI_BUFINFO _IOWR(CIO, 14, struct comedi_bufinfo)
-#define COMEDI_POLL _IO(CIO, 15)
-#define COMEDI_SETRSUBD _IO(CIO, 16)
-#define COMEDI_SETWSUBD _IO(CIO, 17)
-
-/* structures */
-
-/**
- * struct comedi_insn - COMEDI instruction
- * @insn:      COMEDI instruction type (%INSN_xxx).
- * @n:         Length of @data[].
- * @data:      Pointer to data array operated on by the instruction.
- * @subdev:    Subdevice index.
- * @chanspec:  A packed "chanspec" value consisting of channel number,
- *             analog range index, analog reference type, and flags.
- * @unused:    Reserved for future use.
- *
- * This is used with the %COMEDI_INSN ioctl, and indirectly with the
- * %COMEDI_INSNLIST ioctl.
- */
-struct comedi_insn {
-       unsigned int insn;
-       unsigned int n;
-       unsigned int __user *data;
-       unsigned int subdev;
-       unsigned int chanspec;
-       unsigned int unused[3];
-};
-
-/**
- * struct comedi_insnlist - list of COMEDI instructions
- * @n_insns:   Number of COMEDI instructions.
- * @insns:     Pointer to array COMEDI instructions.
- *
- * This is used with the %COMEDI_INSNLIST ioctl.
- */
-struct comedi_insnlist {
-       unsigned int n_insns;
-       struct comedi_insn __user *insns;
-};
-
-/**
- * struct comedi_cmd - COMEDI asynchronous acquisition command details
- * @subdev:            Subdevice index.
- * @flags:             Command flags (%CMDF_xxx).
- * @start_src:         "Start acquisition" trigger source (%TRIG_xxx).
- * @start_arg:         "Start acquisition" trigger argument.
- * @scan_begin_src:    "Scan begin" trigger source.
- * @scan_begin_arg:    "Scan begin" trigger argument.
- * @convert_src:       "Convert" trigger source.
- * @convert_arg:       "Convert" trigger argument.
- * @scan_end_src:      "Scan end" trigger source.
- * @scan_end_arg:      "Scan end" trigger argument.
- * @stop_src:          "Stop acquisition" trigger source.
- * @stop_arg:          "Stop acquisition" trigger argument.
- * @chanlist:          Pointer to array of "chanspec" values, containing a
- *                     sequence of channel numbers packed with analog range
- *                     index, etc.
- * @chanlist_len:      Number of channels in sequence.
- * @data:              Pointer to miscellaneous set-up data (not used).
- * @data_len:          Length of miscellaneous set-up data.
- *
- * This is used with the %COMEDI_CMD or %COMEDI_CMDTEST ioctl to set-up
- * or validate an asynchronous acquisition command.  The ioctl may modify
- * the &struct comedi_cmd and copy it back to the caller.
- *
- * Optional command @flags values that can be ORed together...
- *
- * %CMDF_BOGUS - makes %COMEDI_CMD ioctl return error %EAGAIN instead of
- * starting the command.
- *
- * %CMDF_PRIORITY - requests "hard real-time" processing (which is not
- * supported in this version of COMEDI).
- *
- * %CMDF_WAKE_EOS - requests the command makes data available for reading
- * after every "scan" period.
- *
- * %CMDF_WRITE - marks the command as being in the "write" (to device)
- * direction.  This does not need to be specified by the caller unless the
- * subdevice supports commands in either direction.
- *
- * %CMDF_RAWDATA - prevents the command from "munging" the data between the
- * COMEDI sample format and the raw hardware sample format.
- *
- * %CMDF_ROUND_NEAREST - requests timing periods to be rounded to nearest
- * supported values.
- *
- * %CMDF_ROUND_DOWN - requests timing periods to be rounded down to supported
- * values (frequencies rounded up).
- *
- * %CMDF_ROUND_UP - requests timing periods to be rounded up to supported
- * values (frequencies rounded down).
- *
- * Trigger source values for @start_src, @scan_begin_src, @convert_src,
- * @scan_end_src, and @stop_src...
- *
- * %TRIG_ANY - "all ones" value used to test which trigger sources are
- * supported.
- *
- * %TRIG_INVALID - "all zeroes" value used to indicate that all requested
- * trigger sources are invalid.
- *
- * %TRIG_NONE - never trigger (often used as a @stop_src value).
- *
- * %TRIG_NOW - trigger after '_arg' nanoseconds.
- *
- * %TRIG_FOLLOW - trigger follows another event.
- *
- * %TRIG_TIMER - trigger every '_arg' nanoseconds.
- *
- * %TRIG_COUNT - trigger when count '_arg' is reached.
- *
- * %TRIG_EXT - trigger on external signal specified by '_arg'.
- *
- * %TRIG_INT - trigger on internal, software trigger specified by '_arg'.
- *
- * %TRIG_OTHER - trigger on other, driver-defined signal specified by '_arg'.
- */
-struct comedi_cmd {
-       unsigned int subdev;
-       unsigned int flags;
-
-       unsigned int start_src;
-       unsigned int start_arg;
-
-       unsigned int scan_begin_src;
-       unsigned int scan_begin_arg;
-
-       unsigned int convert_src;
-       unsigned int convert_arg;
-
-       unsigned int scan_end_src;
-       unsigned int scan_end_arg;
-
-       unsigned int stop_src;
-       unsigned int stop_arg;
-
-       unsigned int *chanlist;
-       unsigned int chanlist_len;
-
-       short __user *data;
-       unsigned int data_len;
-};
-
-/**
- * struct comedi_chaninfo - used to retrieve per-channel information
- * @subdev:            Subdevice index.
- * @maxdata_list:      Optional pointer to per-channel maximum data values.
- * @flaglist:          Optional pointer to per-channel flags.
- * @rangelist:         Optional pointer to per-channel range types.
- * @unused:            Reserved for future use.
- *
- * This is used with the %COMEDI_CHANINFO ioctl to get per-channel information
- * for the subdevice.  Use of this requires knowledge of the number of channels
- * and subdevice flags obtained using the %COMEDI_SUBDINFO ioctl.
- *
- * The @maxdata_list member must be %NULL unless the %SDF_MAXDATA subdevice
- * flag is set.  The @flaglist member must be %NULL unless the %SDF_FLAGS
- * subdevice flag is set.  The @rangelist member must be %NULL unless the
- * %SDF_RANGETYPE subdevice flag is set.  Otherwise, the arrays they point to
- * must be at least as long as the number of channels.
- */
-struct comedi_chaninfo {
-       unsigned int subdev;
-       unsigned int __user *maxdata_list;
-       unsigned int __user *flaglist;
-       unsigned int __user *rangelist;
-       unsigned int unused[4];
-};
-
-/**
- * struct comedi_rangeinfo - used to retrieve the range table for a channel
- * @range_type:                Encodes subdevice index (bits 27:24), channel index
- *                     (bits 23:16) and range table length (bits 15:0).
- * @range_ptr:         Pointer to array of @struct comedi_krange to be filled
- *                     in with the range table for the channel or subdevice.
- *
- * This is used with the %COMEDI_RANGEINFO ioctl to retrieve the range table
- * for a specific channel (if the subdevice has the %SDF_RANGETYPE flag set to
- * indicate that the range table depends on the channel), or for the subdevice
- * as a whole (if the %SDF_RANGETYPE flag is clear, indicating the range table
- * is shared by all channels).
- *
- * The @range_type value is an input to the ioctl and comes from a previous
- * use of the %COMEDI_SUBDINFO ioctl (if the %SDF_RANGETYPE flag is clear),
- * or the %COMEDI_CHANINFO ioctl (if the %SDF_RANGETYPE flag is set).
- */
-struct comedi_rangeinfo {
-       unsigned int range_type;
-       void __user *range_ptr;
-};
-
-/**
- * struct comedi_krange - describes a range in a range table
- * @min:       Minimum value in millionths (1e-6) of a unit.
- * @max:       Maximum value in millionths (1e-6) of a unit.
- * @flags:     Indicates the units (in bits 7:0) OR'ed with optional flags.
- *
- * A range table is associated with a single channel, or with all channels in a
- * subdevice, and a list of one or more ranges.  A %struct comedi_krange
- * describes the physical range of units for one of those ranges.  Sample
- * values in COMEDI are unsigned from %0 up to some 'maxdata' value.  The
- * mapping from sample values to physical units is assumed to be nomimally
- * linear (for the purpose of describing the range), with sample value %0
- * mapping to @min, and the 'maxdata' sample value mapping to @max.
- *
- * The currently defined units are %UNIT_volt (%0), %UNIT_mA (%1), and
- * %UNIT_none (%2).  The @min and @max values are the physical range multiplied
- * by 1e6, so a @max value of %1000000 (with %UNIT_volt) represents a maximal
- * value of 1 volt.
- *
- * The only defined flag value is %RF_EXTERNAL (%0x100), indicating that the
- * range needs to be multiplied by an external reference.
- */
-struct comedi_krange {
-       int min;
-       int max;
-       unsigned int flags;
-};
-
-/**
- * struct comedi_subdinfo - used to retrieve information about a subdevice
- * @type:              Type of subdevice from &enum comedi_subdevice_type.
- * @n_chan:            Number of channels the subdevice supports.
- * @subd_flags:                A mixture of static and dynamic flags describing
- *                     aspects of the subdevice and its current state.
- * @timer_type:                Timer type.  Always set to %5 ("nanosecond timer").
- * @len_chanlist:      Maximum length of a channel list if the subdevice
- *                     supports asynchronous acquisition commands.
- * @maxdata:           Maximum sample value for all channels if the
- *                     %SDF_MAXDATA subdevice flag is clear.
- * @flags:             Channel flags for all channels if the %SDF_FLAGS
- *                     subdevice flag is clear.
- * @range_type:                The range type for all channels if the %SDF_RANGETYPE
- *                     subdevice flag is clear.  Encodes the subdevice index
- *                     (bits 27:24), a dummy channel index %0 (bits 23:16),
- *                     and the range table length (bits 15:0).
- * @settling_time_0:   Not used.
- * @insn_bits_support: Set to %COMEDI_SUPPORTED if the subdevice supports the
- *                     %INSN_BITS instruction, or to %COMEDI_UNSUPPORTED if it
- *                     does not.
- * @unused:            Reserved for future use.
- *
- * This is used with the %COMEDI_SUBDINFO ioctl which copies an array of
- * &struct comedi_subdinfo back to user space, with one element per subdevice.
- * Use of this requires knowledge of the number of subdevices obtained from
- * the %COMEDI_DEVINFO ioctl.
- *
- * These are the @subd_flags values that may be ORed together...
- *
- * %SDF_BUSY - the subdevice is busy processing an asynchronous command or a
- * synchronous instruction.
- *
- * %SDF_BUSY_OWNER - the subdevice is busy processing an asynchronous
- * acquisition command started on the current file object (the file object
- * issuing the %COMEDI_SUBDINFO ioctl).
- *
- * %SDF_LOCKED - the subdevice is locked by a %COMEDI_LOCK ioctl.
- *
- * %SDF_LOCK_OWNER - the subdevice is locked by a %COMEDI_LOCK ioctl from the
- * current file object.
- *
- * %SDF_MAXDATA - maximum sample values are channel-specific.
- *
- * %SDF_FLAGS - channel flags are channel-specific.
- *
- * %SDF_RANGETYPE - range types are channel-specific.
- *
- * %SDF_PWM_COUNTER - PWM can switch off automatically.
- *
- * %SDF_PWM_HBRIDGE - or PWM is signed (H-bridge).
- *
- * %SDF_CMD - the subdevice supports asynchronous commands.
- *
- * %SDF_SOFT_CALIBRATED - the subdevice uses software calibration.
- *
- * %SDF_CMD_WRITE - the subdevice supports asynchronous commands in the output
- * ("write") direction.
- *
- * %SDF_CMD_READ - the subdevice supports asynchronous commands in the input
- * ("read") direction.
- *
- * %SDF_READABLE - the subdevice is readable (e.g. analog input).
- *
- * %SDF_WRITABLE (aliased as %SDF_WRITEABLE) - the subdevice is writable (e.g.
- * analog output).
- *
- * %SDF_INTERNAL - the subdevice has no externally visible lines.
- *
- * %SDF_GROUND - the subdevice can use ground as an analog reference.
- *
- * %SDF_COMMON - the subdevice can use a common analog reference.
- *
- * %SDF_DIFF - the subdevice can use differential inputs (or outputs).
- *
- * %SDF_OTHER - the subdevice can use some other analog reference.
- *
- * %SDF_DITHER - the subdevice can do dithering.
- *
- * %SDF_DEGLITCH - the subdevice can do deglitching.
- *
- * %SDF_MMAP - this is never set.
- *
- * %SDF_RUNNING - an asynchronous command is still running.
- *
- * %SDF_LSAMPL - the subdevice uses "long" (32-bit) samples (for asynchronous
- * command data).
- *
- * %SDF_PACKED - the subdevice packs several DIO samples into a single sample
- * (for asynchronous command data).
- *
- * No "channel flags" (@flags) values are currently defined.
- */
-struct comedi_subdinfo {
-       unsigned int type;
-       unsigned int n_chan;
-       unsigned int subd_flags;
-       unsigned int timer_type;
-       unsigned int len_chanlist;
-       unsigned int maxdata;
-       unsigned int flags;
-       unsigned int range_type;
-       unsigned int settling_time_0;
-       unsigned int insn_bits_support;
-       unsigned int unused[8];
-};
-
-/**
- * struct comedi_devinfo - used to retrieve information about a COMEDI device
- * @version_code:      COMEDI version code.
- * @n_subdevs:         Number of subdevices the device has.
- * @driver_name:       Null-terminated COMEDI driver name.
- * @board_name:                Null-terminated COMEDI board name.
- * @read_subdevice:    Index of the current "read" subdevice (%-1 if none).
- * @write_subdevice:   Index of the current "write" subdevice (%-1 if none).
- * @unused:            Reserved for future use.
- *
- * This is used with the %COMEDI_DEVINFO ioctl to get basic information about
- * the device.
- */
-struct comedi_devinfo {
-       unsigned int version_code;
-       unsigned int n_subdevs;
-       char driver_name[COMEDI_NAMELEN];
-       char board_name[COMEDI_NAMELEN];
-       int read_subdevice;
-       int write_subdevice;
-       int unused[30];
-};
-
-/**
- * struct comedi_devconfig - used to configure a legacy COMEDI device
- * @board_name:                Null-terminated string specifying the type of board
- *                     to configure.
- * @options:           An array of integer configuration options.
- *
- * This is used with the %COMEDI_DEVCONFIG ioctl to configure a "legacy" COMEDI
- * device, such as an ISA card.  Not all COMEDI drivers support this.  Those
- * that do either expect the specified board name to match one of a list of
- * names registered with the COMEDI core, or expect the specified board name
- * to match the COMEDI driver name itself.  The configuration options are
- * handled in a driver-specific manner.
- */
-struct comedi_devconfig {
-       char board_name[COMEDI_NAMELEN];
-       int options[COMEDI_NDEVCONFOPTS];
-};
-
-/**
- * struct comedi_bufconfig - used to set or get buffer size for a subdevice
- * @subdevice:         Subdevice index.
- * @flags:             Not used.
- * @maximum_size:      Maximum allowed buffer size.
- * @size:              Buffer size.
- * @unused:            Reserved for future use.
- *
- * This is used with the %COMEDI_BUFCONFIG ioctl to get or configure the
- * maximum buffer size and current buffer size for a COMEDI subdevice that
- * supports asynchronous commands.  If the subdevice does not support
- * asynchronous commands, @maximum_size and @size are ignored and set to 0.
- *
- * On ioctl input, non-zero values of @maximum_size and @size specify a
- * new maximum size and new current size (in bytes), respectively.  These
- * will by rounded up to a multiple of %PAGE_SIZE.  Specifying a new maximum
- * size requires admin capabilities.
- *
- * On ioctl output, @maximum_size and @size and set to the current maximum
- * buffer size and current buffer size, respectively.
- */
-struct comedi_bufconfig {
-       unsigned int subdevice;
-       unsigned int flags;
-
-       unsigned int maximum_size;
-       unsigned int size;
-
-       unsigned int unused[4];
-};
-
-/**
- * struct comedi_bufinfo - used to manipulate buffer position for a subdevice
- * @subdevice:         Subdevice index.
- * @bytes_read:                Specify amount to advance read position for an
- *                     asynchronous command in the input ("read") direction.
- * @buf_write_ptr:     Current write position (index) within the buffer.
- * @buf_read_ptr:      Current read position (index) within the buffer.
- * @buf_write_count:   Total amount written, modulo 2^32.
- * @buf_read_count:    Total amount read, modulo 2^32.
- * @bytes_written:     Specify amount to advance write position for an
- *                     asynchronous command in the output ("write") direction.
- * @unused:            Reserved for future use.
- *
- * This is used with the %COMEDI_BUFINFO ioctl to optionally advance the
- * current read or write position in an asynchronous acquisition data buffer,
- * and to get the current read and write positions in the buffer.
- */
-struct comedi_bufinfo {
-       unsigned int subdevice;
-       unsigned int bytes_read;
-
-       unsigned int buf_write_ptr;
-       unsigned int buf_read_ptr;
-       unsigned int buf_write_count;
-       unsigned int buf_read_count;
-
-       unsigned int bytes_written;
-
-       unsigned int unused[4];
-};
-
-/* range stuff */
-
-#define __RANGE(a, b)  ((((a) & 0xffff) << 16) | ((b) & 0xffff))
-
-#define RANGE_OFFSET(a)                (((a) >> 16) & 0xffff)
-#define RANGE_LENGTH(b)                ((b) & 0xffff)
-
-#define RF_UNIT(flags)         ((flags) & 0xff)
-#define RF_EXTERNAL            0x100
-
-#define UNIT_volt              0
-#define UNIT_mA                        1
-#define UNIT_none              2
-
-#define COMEDI_MIN_SPEED       0xffffffffu
-
-/**********************************************************/
-/* everything after this line is ALPHA */
-/**********************************************************/
-
-/*
- * 8254 specific configuration.
- *
- * It supports two config commands:
- *
- * 0 ID: INSN_CONFIG_SET_COUNTER_MODE
- * 1 8254 Mode
- * I8254_MODE0, I8254_MODE1, ..., I8254_MODE5
- * OR'ed with:
- * I8254_BCD, I8254_BINARY
- *
- * 0 ID: INSN_CONFIG_8254_READ_STATUS
- * 1 <-- Status byte returned here.
- * B7 = Output
- * B6 = NULL Count
- * B5 - B0 Current mode.
- */
-
-enum i8254_mode {
-       I8254_MODE0 = (0 << 1), /* Interrupt on terminal count */
-       I8254_MODE1 = (1 << 1), /* Hardware retriggerable one-shot */
-       I8254_MODE2 = (2 << 1), /* Rate generator */
-       I8254_MODE3 = (3 << 1), /* Square wave mode */
-       I8254_MODE4 = (4 << 1), /* Software triggered strobe */
-       /* Hardware triggered strobe (retriggerable) */
-       I8254_MODE5 = (5 << 1),
-       /* Use binary-coded decimal instead of binary (pretty useless) */
-       I8254_BCD = 1,
-       I8254_BINARY = 0
-};
-
-/* *** BEGIN GLOBALLY-NAMED NI TERMINALS/SIGNALS *** */
-
-/*
- * Common National Instruments Terminal/Signal names.
- * Some of these have no NI_ prefix as they are useful for non-NI hardware, such
- * as those that utilize the PXI/RTSI trigger lines.
- *
- * NOTE ABOUT THE CHOICE OF NAMES HERE AND THE CAMELSCRIPT:
- *   The choice to use CamelScript and the exact names below is for
- *   maintainability, clarity, similarity to manufacturer's documentation,
- *   _and_ a mitigation for confusion that has plagued the use of these drivers
- *   for years!
- *
- *   More detail:
- *   There have been significant confusions over the past many years for users
- *   when trying to understand how to connect to/from signals and terminals on
- *   NI hardware using comedi.  The major reason for this is that the actual
- *   register values were exposed and required to be used by users.  Several
- *   major reasons exist why this caused major confusion for users:
- *   1) The register values are _NOT_ in user documentation, but rather in
- *     arcane locations, such as a few register programming manuals that are
- *     increasingly hard to find and the NI MHDDK (comments in example code).
- *     There is no one place to find the various valid values of the registers.
- *   2) The register values are _NOT_ completely consistent.  There is no way to
- *     gain any sense of intuition of which values, or even enums one should use
- *     for various registers.  There was some attempt in prior use of comedi to
- *     name enums such that a user might know which enums should be used for
- *     varying purposes, but the end-user had to gain a knowledge of register
- *     values to correctly wield this approach.
- *   3) The names for signals and registers found in the various register level
- *     programming manuals and vendor-provided documentation are _not_ even
- *     close to the same names that are in the end-user documentation.
- *
- *   Similar, albeit less, confusion plagued NI's previous version of their own
- *   drivers.  Earlier than 2003, NI greatly simplified the situation for users
- *   by releasing a new API that abstracted the names of signals/terminals to a
- *   common and intuitive set of names.
- *
- *   The names below mirror the names chosen and well documented by NI.  These
- *   names are exposed to the user via the comedilib user library.  By keeping
- *   the names below, in spite of the use of CamelScript, maintenance will be
- *   greatly eased and confusion for users _and_ comedi developers will be
- *   greatly reduced.
- */
-
-/*
- * Base of abstracted NI names.
- * The first 16 bits of *_arg are reserved for channel selection.
- * Since we only actually need the first 4 or 5 bits for all register values on
- * NI select registers anyways, we'll identify all values >= (1<<15) as being an
- * abstracted NI signal/terminal name.
- * These values are also used/returned by INSN_DEVICE_CONFIG_TEST_ROUTE,
- * INSN_DEVICE_CONFIG_CONNECT_ROUTE, INSN_DEVICE_CONFIG_DISCONNECT_ROUTE,
- * and INSN_DEVICE_CONFIG_GET_ROUTES.
- */
-#define NI_NAMES_BASE  0x8000u
-
-#define _TERM_N(base, n, x)    ((base) + ((x) & ((n) - 1)))
-
-/*
- * not necessarily all allowed 64 PFIs are valid--certainly not for all devices
- */
-#define NI_PFI(x)              _TERM_N(NI_NAMES_BASE, 64, x)
-/* 8 trigger lines by standard, Some devices cannot talk to all eight. */
-#define TRIGGER_LINE(x)                _TERM_N(NI_PFI(-1) + 1, 8, x)
-/* 4 RTSI shared MUXes to route signals to/from TRIGGER_LINES on NI hardware */
-#define NI_RTSI_BRD(x)         _TERM_N(TRIGGER_LINE(-1) + 1, 4, x)
-
-/* *** Counter/timer names : 8 counters max *** */
-#define NI_MAX_COUNTERS                8
-#define NI_COUNTER_NAMES_BASE  (NI_RTSI_BRD(-1)  + 1)
-#define NI_CtrSource(x)              _TERM_N(NI_COUNTER_NAMES_BASE, NI_MAX_COUNTERS, x)
-/* Gate, Aux, A,B,Z are all treated, at times as gates */
-#define NI_GATES_NAMES_BASE    (NI_CtrSource(-1) + 1)
-#define NI_CtrGate(x)          _TERM_N(NI_GATES_NAMES_BASE, NI_MAX_COUNTERS, x)
-#define NI_CtrAux(x)           _TERM_N(NI_CtrGate(-1)  + 1, NI_MAX_COUNTERS, x)
-#define NI_CtrA(x)             _TERM_N(NI_CtrAux(-1)   + 1, NI_MAX_COUNTERS, x)
-#define NI_CtrB(x)             _TERM_N(NI_CtrA(-1)     + 1, NI_MAX_COUNTERS, x)
-#define NI_CtrZ(x)             _TERM_N(NI_CtrB(-1)     + 1, NI_MAX_COUNTERS, x)
-#define NI_GATES_NAMES_MAX     NI_CtrZ(-1)
-#define NI_CtrArmStartTrigger(x) _TERM_N(NI_CtrZ(-1)    + 1, NI_MAX_COUNTERS, x)
-#define NI_CtrInternalOutput(x) \
-                     _TERM_N(NI_CtrArmStartTrigger(-1) + 1, NI_MAX_COUNTERS, x)
-/** external pin(s) labeled conveniently as Ctr<i>Out. */
-#define NI_CtrOut(x)   _TERM_N(NI_CtrInternalOutput(-1) + 1, NI_MAX_COUNTERS, x)
-/** For Buffered sampling of ctr -- x series capability. */
-#define NI_CtrSampleClock(x)   _TERM_N(NI_CtrOut(-1)   + 1, NI_MAX_COUNTERS, x)
-#define NI_COUNTER_NAMES_MAX   NI_CtrSampleClock(-1)
-
-enum ni_common_signal_names {
-       /* PXI_Star: this is a non-NI-specific signal */
-       PXI_Star = NI_COUNTER_NAMES_MAX + 1,
-       PXI_Clk10,
-       PXIe_Clk100,
-       NI_AI_SampleClock,
-       NI_AI_SampleClockTimebase,
-       NI_AI_StartTrigger,
-       NI_AI_ReferenceTrigger,
-       NI_AI_ConvertClock,
-       NI_AI_ConvertClockTimebase,
-       NI_AI_PauseTrigger,
-       NI_AI_HoldCompleteEvent,
-       NI_AI_HoldComplete,
-       NI_AI_ExternalMUXClock,
-       NI_AI_STOP, /* pulse signal that occurs when a update is finished(?) */
-       NI_AO_SampleClock,
-       NI_AO_SampleClockTimebase,
-       NI_AO_StartTrigger,
-       NI_AO_PauseTrigger,
-       NI_DI_SampleClock,
-       NI_DI_SampleClockTimebase,
-       NI_DI_StartTrigger,
-       NI_DI_ReferenceTrigger,
-       NI_DI_PauseTrigger,
-       NI_DI_InputBufferFull,
-       NI_DI_ReadyForStartEvent,
-       NI_DI_ReadyForTransferEventBurst,
-       NI_DI_ReadyForTransferEventPipelined,
-       NI_DO_SampleClock,
-       NI_DO_SampleClockTimebase,
-       NI_DO_StartTrigger,
-       NI_DO_PauseTrigger,
-       NI_DO_OutputBufferFull,
-       NI_DO_DataActiveEvent,
-       NI_DO_ReadyForStartEvent,
-       NI_DO_ReadyForTransferEvent,
-       NI_MasterTimebase,
-       NI_20MHzTimebase,
-       NI_80MHzTimebase,
-       NI_100MHzTimebase,
-       NI_200MHzTimebase,
-       NI_100kHzTimebase,
-       NI_10MHzRefClock,
-       NI_FrequencyOutput,
-       NI_ChangeDetectionEvent,
-       NI_AnalogComparisonEvent,
-       NI_WatchdogExpiredEvent,
-       NI_WatchdogExpirationTrigger,
-       NI_SCXI_Trig1,
-       NI_LogicLow,
-       NI_LogicHigh,
-       NI_ExternalStrobe,
-       NI_PFI_DO,
-       NI_CaseGround,
-       /* special internal signal used as variable source for RTSI bus: */
-       NI_RGOUT0,
-
-       /* just a name to make the next more convenient, regardless of above */
-       _NI_NAMES_MAX_PLUS_1,
-       NI_NUM_NAMES = _NI_NAMES_MAX_PLUS_1 - NI_NAMES_BASE,
-};
-
-/* *** END GLOBALLY-NAMED NI TERMINALS/SIGNALS *** */
-
-#define NI_USUAL_PFI_SELECT(x) (((x) < 10) ? (0x1 + (x)) : (0xb + (x)))
-#define NI_USUAL_RTSI_SELECT(x)        (((x) < 7) ? (0xb + (x)) : 0x1b)
-
-/*
- * mode bits for NI general-purpose counters, set with
- * INSN_CONFIG_SET_COUNTER_MODE
- */
-#define NI_GPCT_COUNTING_MODE_SHIFT 16
-#define NI_GPCT_INDEX_PHASE_BITSHIFT 20
-#define NI_GPCT_COUNTING_DIRECTION_SHIFT 24
-enum ni_gpct_mode_bits {
-       NI_GPCT_GATE_ON_BOTH_EDGES_BIT = 0x4,
-       NI_GPCT_EDGE_GATE_MODE_MASK = 0x18,
-       NI_GPCT_EDGE_GATE_STARTS_STOPS_BITS = 0x0,
-       NI_GPCT_EDGE_GATE_STOPS_STARTS_BITS = 0x8,
-       NI_GPCT_EDGE_GATE_STARTS_BITS = 0x10,
-       NI_GPCT_EDGE_GATE_NO_STARTS_NO_STOPS_BITS = 0x18,
-       NI_GPCT_STOP_MODE_MASK = 0x60,
-       NI_GPCT_STOP_ON_GATE_BITS = 0x00,
-       NI_GPCT_STOP_ON_GATE_OR_TC_BITS = 0x20,
-       NI_GPCT_STOP_ON_GATE_OR_SECOND_TC_BITS = 0x40,
-       NI_GPCT_LOAD_B_SELECT_BIT = 0x80,
-       NI_GPCT_OUTPUT_MODE_MASK = 0x300,
-       NI_GPCT_OUTPUT_TC_PULSE_BITS = 0x100,
-       NI_GPCT_OUTPUT_TC_TOGGLE_BITS = 0x200,
-       NI_GPCT_OUTPUT_TC_OR_GATE_TOGGLE_BITS = 0x300,
-       NI_GPCT_HARDWARE_DISARM_MASK = 0xc00,
-       NI_GPCT_NO_HARDWARE_DISARM_BITS = 0x000,
-       NI_GPCT_DISARM_AT_TC_BITS = 0x400,
-       NI_GPCT_DISARM_AT_GATE_BITS = 0x800,
-       NI_GPCT_DISARM_AT_TC_OR_GATE_BITS = 0xc00,
-       NI_GPCT_LOADING_ON_TC_BIT = 0x1000,
-       NI_GPCT_LOADING_ON_GATE_BIT = 0x4000,
-       NI_GPCT_COUNTING_MODE_MASK = 0x7 << NI_GPCT_COUNTING_MODE_SHIFT,
-       NI_GPCT_COUNTING_MODE_NORMAL_BITS =
-               0x0 << NI_GPCT_COUNTING_MODE_SHIFT,
-       NI_GPCT_COUNTING_MODE_QUADRATURE_X1_BITS =
-               0x1 << NI_GPCT_COUNTING_MODE_SHIFT,
-       NI_GPCT_COUNTING_MODE_QUADRATURE_X2_BITS =
-               0x2 << NI_GPCT_COUNTING_MODE_SHIFT,
-       NI_GPCT_COUNTING_MODE_QUADRATURE_X4_BITS =
-               0x3 << NI_GPCT_COUNTING_MODE_SHIFT,
-       NI_GPCT_COUNTING_MODE_TWO_PULSE_BITS =
-               0x4 << NI_GPCT_COUNTING_MODE_SHIFT,
-       NI_GPCT_COUNTING_MODE_SYNC_SOURCE_BITS =
-               0x6 << NI_GPCT_COUNTING_MODE_SHIFT,
-       NI_GPCT_INDEX_PHASE_MASK = 0x3 << NI_GPCT_INDEX_PHASE_BITSHIFT,
-       NI_GPCT_INDEX_PHASE_LOW_A_LOW_B_BITS =
-               0x0 << NI_GPCT_INDEX_PHASE_BITSHIFT,
-       NI_GPCT_INDEX_PHASE_LOW_A_HIGH_B_BITS =
-               0x1 << NI_GPCT_INDEX_PHASE_BITSHIFT,
-       NI_GPCT_INDEX_PHASE_HIGH_A_LOW_B_BITS =
-               0x2 << NI_GPCT_INDEX_PHASE_BITSHIFT,
-       NI_GPCT_INDEX_PHASE_HIGH_A_HIGH_B_BITS =
-               0x3 << NI_GPCT_INDEX_PHASE_BITSHIFT,
-       NI_GPCT_INDEX_ENABLE_BIT = 0x400000,
-       NI_GPCT_COUNTING_DIRECTION_MASK =
-               0x3 << NI_GPCT_COUNTING_DIRECTION_SHIFT,
-       NI_GPCT_COUNTING_DIRECTION_DOWN_BITS =
-               0x00 << NI_GPCT_COUNTING_DIRECTION_SHIFT,
-       NI_GPCT_COUNTING_DIRECTION_UP_BITS =
-               0x1 << NI_GPCT_COUNTING_DIRECTION_SHIFT,
-       NI_GPCT_COUNTING_DIRECTION_HW_UP_DOWN_BITS =
-               0x2 << NI_GPCT_COUNTING_DIRECTION_SHIFT,
-       NI_GPCT_COUNTING_DIRECTION_HW_GATE_BITS =
-               0x3 << NI_GPCT_COUNTING_DIRECTION_SHIFT,
-       NI_GPCT_RELOAD_SOURCE_MASK = 0xc000000,
-       NI_GPCT_RELOAD_SOURCE_FIXED_BITS = 0x0,
-       NI_GPCT_RELOAD_SOURCE_SWITCHING_BITS = 0x4000000,
-       NI_GPCT_RELOAD_SOURCE_GATE_SELECT_BITS = 0x8000000,
-       NI_GPCT_OR_GATE_BIT = 0x10000000,
-       NI_GPCT_INVERT_OUTPUT_BIT = 0x20000000
-};
-
-/*
- * Bits for setting a clock source with
- * INSN_CONFIG_SET_CLOCK_SRC when using NI general-purpose counters.
- */
-enum ni_gpct_clock_source_bits {
-       NI_GPCT_CLOCK_SRC_SELECT_MASK = 0x3f,
-       NI_GPCT_TIMEBASE_1_CLOCK_SRC_BITS = 0x0,
-       NI_GPCT_TIMEBASE_2_CLOCK_SRC_BITS = 0x1,
-       NI_GPCT_TIMEBASE_3_CLOCK_SRC_BITS = 0x2,
-       NI_GPCT_LOGIC_LOW_CLOCK_SRC_BITS = 0x3,
-       NI_GPCT_NEXT_GATE_CLOCK_SRC_BITS = 0x4,
-       NI_GPCT_NEXT_TC_CLOCK_SRC_BITS = 0x5,
-       /* NI 660x-specific */
-       NI_GPCT_SOURCE_PIN_i_CLOCK_SRC_BITS = 0x6,
-       NI_GPCT_PXI10_CLOCK_SRC_BITS = 0x7,
-       NI_GPCT_PXI_STAR_TRIGGER_CLOCK_SRC_BITS = 0x8,
-       NI_GPCT_ANALOG_TRIGGER_OUT_CLOCK_SRC_BITS = 0x9,
-       NI_GPCT_PRESCALE_MODE_CLOCK_SRC_MASK = 0x30000000,
-       NI_GPCT_NO_PRESCALE_CLOCK_SRC_BITS = 0x0,
-       /* divide source by 2 */
-       NI_GPCT_PRESCALE_X2_CLOCK_SRC_BITS = 0x10000000,
-       /* divide source by 8 */
-       NI_GPCT_PRESCALE_X8_CLOCK_SRC_BITS = 0x20000000,
-       NI_GPCT_INVERT_CLOCK_SRC_BIT = 0x80000000
-};
-
-/* NI 660x-specific */
-#define NI_GPCT_SOURCE_PIN_CLOCK_SRC_BITS(x)   (0x10 + (x))
-
-#define NI_GPCT_RTSI_CLOCK_SRC_BITS(x)         (0x18 + (x))
-
-/* no pfi on NI 660x */
-#define NI_GPCT_PFI_CLOCK_SRC_BITS(x)          (0x20 + (x))
-
-/*
- * Possibilities for setting a gate source with
- * INSN_CONFIG_SET_GATE_SRC when using NI general-purpose counters.
- * May be bitwise-or'd with CR_EDGE or CR_INVERT.
- */
-enum ni_gpct_gate_select {
-       /* m-series gates */
-       NI_GPCT_TIMESTAMP_MUX_GATE_SELECT = 0x0,
-       NI_GPCT_AI_START2_GATE_SELECT = 0x12,
-       NI_GPCT_PXI_STAR_TRIGGER_GATE_SELECT = 0x13,
-       NI_GPCT_NEXT_OUT_GATE_SELECT = 0x14,
-       NI_GPCT_AI_START1_GATE_SELECT = 0x1c,
-       NI_GPCT_NEXT_SOURCE_GATE_SELECT = 0x1d,
-       NI_GPCT_ANALOG_TRIGGER_OUT_GATE_SELECT = 0x1e,
-       NI_GPCT_LOGIC_LOW_GATE_SELECT = 0x1f,
-       /* more gates for 660x */
-       NI_GPCT_SOURCE_PIN_i_GATE_SELECT = 0x100,
-       NI_GPCT_GATE_PIN_i_GATE_SELECT = 0x101,
-       /* more gates for 660x "second gate" */
-       NI_GPCT_UP_DOWN_PIN_i_GATE_SELECT = 0x201,
-       NI_GPCT_SELECTED_GATE_GATE_SELECT = 0x21e,
-       /*
-        * m-series "second gate" sources are unknown,
-        * we should add them here with an offset of 0x300 when
-        * known.
-        */
-       NI_GPCT_DISABLED_GATE_SELECT = 0x8000,
-};
-
-#define NI_GPCT_GATE_PIN_GATE_SELECT(x)                (0x102 + (x))
-#define NI_GPCT_RTSI_GATE_SELECT(x)            NI_USUAL_RTSI_SELECT(x)
-#define NI_GPCT_PFI_GATE_SELECT(x)             NI_USUAL_PFI_SELECT(x)
-#define NI_GPCT_UP_DOWN_PIN_GATE_SELECT(x)     (0x202 + (x))
-
-/*
- * Possibilities for setting a source with
- * INSN_CONFIG_SET_OTHER_SRC when using NI general-purpose counters.
- */
-enum ni_gpct_other_index {
-       NI_GPCT_SOURCE_ENCODER_A,
-       NI_GPCT_SOURCE_ENCODER_B,
-       NI_GPCT_SOURCE_ENCODER_Z
-};
-
-enum ni_gpct_other_select {
-       /* m-series gates */
-       /* Still unknown, probably only need NI_GPCT_PFI_OTHER_SELECT */
-       NI_GPCT_DISABLED_OTHER_SELECT = 0x8000,
-};
-
-#define NI_GPCT_PFI_OTHER_SELECT(x)    NI_USUAL_PFI_SELECT(x)
-
-/*
- * start sources for ni general-purpose counters for use with
- * INSN_CONFIG_ARM
- */
-enum ni_gpct_arm_source {
-       NI_GPCT_ARM_IMMEDIATE = 0x0,
-       /*
-        * Start both the counter and the adjacent paired counter simultaneously
-        */
-       NI_GPCT_ARM_PAIRED_IMMEDIATE = 0x1,
-       /*
-        * If the NI_GPCT_HW_ARM bit is set, we will pass the least significant
-        * bits (3 bits for 660x or 5 bits for m-series) through to the
-        * hardware. To select a hardware trigger, pass the appropriate select
-        * bit, e.g.,
-        * NI_GPCT_HW_ARM | NI_GPCT_AI_START1_GATE_SELECT or
-        * NI_GPCT_HW_ARM | NI_GPCT_PFI_GATE_SELECT(pfi_number)
-        */
-       NI_GPCT_HW_ARM = 0x1000,
-       NI_GPCT_ARM_UNKNOWN = NI_GPCT_HW_ARM,   /* for backward compatibility */
-};
-
-/* digital filtering options for ni 660x for use with INSN_CONFIG_FILTER. */
-enum ni_gpct_filter_select {
-       NI_GPCT_FILTER_OFF = 0x0,
-       NI_GPCT_FILTER_TIMEBASE_3_SYNC = 0x1,
-       NI_GPCT_FILTER_100x_TIMEBASE_1 = 0x2,
-       NI_GPCT_FILTER_20x_TIMEBASE_1 = 0x3,
-       NI_GPCT_FILTER_10x_TIMEBASE_1 = 0x4,
-       NI_GPCT_FILTER_2x_TIMEBASE_1 = 0x5,
-       NI_GPCT_FILTER_2x_TIMEBASE_3 = 0x6
-};
-
-/*
- * PFI digital filtering options for ni m-series for use with
- * INSN_CONFIG_FILTER.
- */
-enum ni_pfi_filter_select {
-       NI_PFI_FILTER_OFF = 0x0,
-       NI_PFI_FILTER_125ns = 0x1,
-       NI_PFI_FILTER_6425ns = 0x2,
-       NI_PFI_FILTER_2550us = 0x3
-};
-
-/* master clock sources for ni mio boards and INSN_CONFIG_SET_CLOCK_SRC */
-enum ni_mio_clock_source {
-       NI_MIO_INTERNAL_CLOCK = 0,
-       /*
-        * Doesn't work for m-series, use NI_MIO_PLL_RTSI_CLOCK()
-        * the NI_MIO_PLL_* sources are m-series only
-        */
-       NI_MIO_RTSI_CLOCK = 1,
-       NI_MIO_PLL_PXI_STAR_TRIGGER_CLOCK = 2,
-       NI_MIO_PLL_PXI10_CLOCK = 3,
-       NI_MIO_PLL_RTSI0_CLOCK = 4
-};
-
-#define NI_MIO_PLL_RTSI_CLOCK(x)       (NI_MIO_PLL_RTSI0_CLOCK + (x))
-
-/*
- * Signals which can be routed to an NI RTSI pin with INSN_CONFIG_SET_ROUTING.
- * The numbers assigned are not arbitrary, they correspond to the bits required
- * to program the board.
- */
-enum ni_rtsi_routing {
-       NI_RTSI_OUTPUT_ADR_START1 = 0,
-       NI_RTSI_OUTPUT_ADR_START2 = 1,
-       NI_RTSI_OUTPUT_SCLKG = 2,
-       NI_RTSI_OUTPUT_DACUPDN = 3,
-       NI_RTSI_OUTPUT_DA_START1 = 4,
-       NI_RTSI_OUTPUT_G_SRC0 = 5,
-       NI_RTSI_OUTPUT_G_GATE0 = 6,
-       NI_RTSI_OUTPUT_RGOUT0 = 7,
-       NI_RTSI_OUTPUT_RTSI_BRD_0 = 8,
-       /* Pre-m-series always have RTSI clock on line 7 */
-       NI_RTSI_OUTPUT_RTSI_OSC = 12
-};
-
-#define NI_RTSI_OUTPUT_RTSI_BRD(x)     (NI_RTSI_OUTPUT_RTSI_BRD_0 + (x))
-
-/*
- * Signals which can be routed to an NI PFI pin on an m-series board with
- * INSN_CONFIG_SET_ROUTING.  These numbers are also returned by
- * INSN_CONFIG_GET_ROUTING on pre-m-series boards, even though their routing
- * cannot be changed.  The numbers assigned are not arbitrary, they correspond
- * to the bits required to program the board.
- */
-enum ni_pfi_routing {
-       NI_PFI_OUTPUT_PFI_DEFAULT = 0,
-       NI_PFI_OUTPUT_AI_START1 = 1,
-       NI_PFI_OUTPUT_AI_START2 = 2,
-       NI_PFI_OUTPUT_AI_CONVERT = 3,
-       NI_PFI_OUTPUT_G_SRC1 = 4,
-       NI_PFI_OUTPUT_G_GATE1 = 5,
-       NI_PFI_OUTPUT_AO_UPDATE_N = 6,
-       NI_PFI_OUTPUT_AO_START1 = 7,
-       NI_PFI_OUTPUT_AI_START_PULSE = 8,
-       NI_PFI_OUTPUT_G_SRC0 = 9,
-       NI_PFI_OUTPUT_G_GATE0 = 10,
-       NI_PFI_OUTPUT_EXT_STROBE = 11,
-       NI_PFI_OUTPUT_AI_EXT_MUX_CLK = 12,
-       NI_PFI_OUTPUT_GOUT0 = 13,
-       NI_PFI_OUTPUT_GOUT1 = 14,
-       NI_PFI_OUTPUT_FREQ_OUT = 15,
-       NI_PFI_OUTPUT_PFI_DO = 16,
-       NI_PFI_OUTPUT_I_ATRIG = 17,
-       NI_PFI_OUTPUT_RTSI0 = 18,
-       NI_PFI_OUTPUT_PXI_STAR_TRIGGER_IN = 26,
-       NI_PFI_OUTPUT_SCXI_TRIG1 = 27,
-       NI_PFI_OUTPUT_DIO_CHANGE_DETECT_RTSI = 28,
-       NI_PFI_OUTPUT_CDI_SAMPLE = 29,
-       NI_PFI_OUTPUT_CDO_UPDATE = 30
-};
-
-#define NI_PFI_OUTPUT_RTSI(x)          (NI_PFI_OUTPUT_RTSI0 + (x))
-
-/*
- * Signals which can be routed to output on a NI PFI pin on a 660x board
- * with INSN_CONFIG_SET_ROUTING.  The numbers assigned are
- * not arbitrary, they correspond to the bits required
- * to program the board.  Lines 0 to 7 can only be set to
- * NI_660X_PFI_OUTPUT_DIO.  Lines 32 to 39 can only be set to
- * NI_660X_PFI_OUTPUT_COUNTER.
- */
-enum ni_660x_pfi_routing {
-       NI_660X_PFI_OUTPUT_COUNTER = 1, /* counter */
-       NI_660X_PFI_OUTPUT_DIO = 2,     /* static digital output */
-};
-
-/*
- * NI External Trigger lines.  These values are not arbitrary, but are related
- * to the bits required to program the board (offset by 1 for historical
- * reasons).
- */
-#define NI_EXT_PFI(x)                  (NI_USUAL_PFI_SELECT(x) - 1)
-#define NI_EXT_RTSI(x)                 (NI_USUAL_RTSI_SELECT(x) - 1)
-
-/*
- * Clock sources for CDIO subdevice on NI m-series boards.  Used as the
- * scan_begin_arg for a comedi_command. These sources may also be bitwise-or'd
- * with CR_INVERT to change polarity.
- */
-enum ni_m_series_cdio_scan_begin_src {
-       NI_CDIO_SCAN_BEGIN_SRC_GROUND = 0,
-       NI_CDIO_SCAN_BEGIN_SRC_AI_START = 18,
-       NI_CDIO_SCAN_BEGIN_SRC_AI_CONVERT = 19,
-       NI_CDIO_SCAN_BEGIN_SRC_PXI_STAR_TRIGGER = 20,
-       NI_CDIO_SCAN_BEGIN_SRC_G0_OUT = 28,
-       NI_CDIO_SCAN_BEGIN_SRC_G1_OUT = 29,
-       NI_CDIO_SCAN_BEGIN_SRC_ANALOG_TRIGGER = 30,
-       NI_CDIO_SCAN_BEGIN_SRC_AO_UPDATE = 31,
-       NI_CDIO_SCAN_BEGIN_SRC_FREQ_OUT = 32,
-       NI_CDIO_SCAN_BEGIN_SRC_DIO_CHANGE_DETECT_IRQ = 33
-};
-
-#define NI_CDIO_SCAN_BEGIN_SRC_PFI(x)  NI_USUAL_PFI_SELECT(x)
-#define NI_CDIO_SCAN_BEGIN_SRC_RTSI(x) NI_USUAL_RTSI_SELECT(x)
-
-/*
- * scan_begin_src for scan_begin_arg==TRIG_EXT with analog output command on NI
- * boards.  These scan begin sources can also be bitwise-or'd with CR_INVERT to
- * change polarity.
- */
-#define NI_AO_SCAN_BEGIN_SRC_PFI(x)    NI_USUAL_PFI_SELECT(x)
-#define NI_AO_SCAN_BEGIN_SRC_RTSI(x)   NI_USUAL_RTSI_SELECT(x)
-
-/*
- * Bits for setting a clock source with
- * INSN_CONFIG_SET_CLOCK_SRC when using NI frequency output subdevice.
- */
-enum ni_freq_out_clock_source_bits {
-       NI_FREQ_OUT_TIMEBASE_1_DIV_2_CLOCK_SRC, /* 10 MHz */
-       NI_FREQ_OUT_TIMEBASE_2_CLOCK_SRC        /* 100 KHz */
-};
-
-/*
- * Values for setting a clock source with INSN_CONFIG_SET_CLOCK_SRC for
- * 8254 counter subdevices on Amplicon DIO boards (amplc_dio200 driver).
- */
-enum amplc_dio_clock_source {
-       /*
-        * Per channel external clock
-        * input/output pin (pin is only an
-        * input when clock source set to this value,
-        * otherwise it is an output)
-        */
-       AMPLC_DIO_CLK_CLKN,
-       AMPLC_DIO_CLK_10MHZ,    /* 10 MHz internal clock */
-       AMPLC_DIO_CLK_1MHZ,     /* 1 MHz internal clock */
-       AMPLC_DIO_CLK_100KHZ,   /* 100 kHz internal clock */
-       AMPLC_DIO_CLK_10KHZ,    /* 10 kHz internal clock */
-       AMPLC_DIO_CLK_1KHZ,     /* 1 kHz internal clock */
-       /*
-        * Output of preceding counter channel
-        * (for channel 0, preceding counter
-        * channel is channel 2 on preceding
-        * counter subdevice, for first counter
-        * subdevice, preceding counter
-        * subdevice is the last counter
-        * subdevice)
-        */
-       AMPLC_DIO_CLK_OUTNM1,
-       AMPLC_DIO_CLK_EXT,      /* per chip external input pin */
-       /* the following are "enhanced" clock sources for PCIe models */
-       AMPLC_DIO_CLK_VCC,      /* clock input HIGH */
-       AMPLC_DIO_CLK_GND,      /* clock input LOW */
-       AMPLC_DIO_CLK_PAT_PRESENT, /* "pattern present" signal */
-       AMPLC_DIO_CLK_20MHZ     /* 20 MHz internal clock */
-};
-
-/*
- * Values for setting a clock source with INSN_CONFIG_SET_CLOCK_SRC for
- * timer subdevice on some Amplicon DIO PCIe boards (amplc_dio200 driver).
- */
-enum amplc_dio_ts_clock_src {
-       AMPLC_DIO_TS_CLK_1GHZ,  /* 1 ns period with 20 ns granularity */
-       AMPLC_DIO_TS_CLK_1MHZ,  /* 1 us period */
-       AMPLC_DIO_TS_CLK_1KHZ   /* 1 ms period */
-};
-
-/*
- * Values for setting a gate source with INSN_CONFIG_SET_GATE_SRC for
- * 8254 counter subdevices on Amplicon DIO boards (amplc_dio200 driver).
- */
-enum amplc_dio_gate_source {
-       AMPLC_DIO_GAT_VCC,      /* internal high logic level */
-       AMPLC_DIO_GAT_GND,      /* internal low logic level */
-       AMPLC_DIO_GAT_GATN,     /* per channel external gate input */
-       /*
-        * negated output of counter channel minus 2
-        * (for channels 0 or 1, channel minus 2 is channel 1 or 2 on
-        * the preceding counter subdevice, for the first counter subdevice
-        * the preceding counter subdevice is the last counter subdevice)
-        */
-       AMPLC_DIO_GAT_NOUTNM2,
-       AMPLC_DIO_GAT_RESERVED4,
-       AMPLC_DIO_GAT_RESERVED5,
-       AMPLC_DIO_GAT_RESERVED6,
-       AMPLC_DIO_GAT_RESERVED7,
-       /* the following are "enhanced" gate sources for PCIe models */
-       AMPLC_DIO_GAT_NGATN = 6, /* negated per channel gate input */
-       /* non-negated output of counter channel minus 2 */
-       AMPLC_DIO_GAT_OUTNM2,
-       AMPLC_DIO_GAT_PAT_PRESENT, /* "pattern present" signal */
-       AMPLC_DIO_GAT_PAT_OCCURRED, /* "pattern occurred" latched */
-       AMPLC_DIO_GAT_PAT_GONE, /* "pattern gone away" latched */
-       AMPLC_DIO_GAT_NPAT_PRESENT, /* negated "pattern present" */
-       AMPLC_DIO_GAT_NPAT_OCCURRED, /* negated "pattern occurred" */
-       AMPLC_DIO_GAT_NPAT_GONE /* negated "pattern gone away" */
-};
-
-/*
- * Values for setting a clock source with INSN_CONFIG_SET_CLOCK_SRC for
- * the counter subdevice on the Kolter Electronic PCI-Counter board
- * (ke_counter driver).
- */
-enum ke_counter_clock_source {
-       KE_CLK_20MHZ,   /* internal 20MHz (default) */
-       KE_CLK_4MHZ,    /* internal 4MHz (option) */
-       KE_CLK_EXT      /* external clock on pin 21 of D-Sub */
-};
-
-#endif /* _COMEDI_H */
index 06bfc85..393966c 100644 (file)
@@ -9,8 +9,7 @@
 
 #include <linux/vmalloc.h>
 #include <linux/slab.h>
-
-#include "comedidev.h"
+#include <linux/comedi/comedidev.h>
 #include "comedi_internal.h"
 
 #ifdef PAGE_KERNEL_NOCACHE
index 763cea8..55a0cae 100644 (file)
@@ -23,7 +23,7 @@
 #include <linux/poll.h>
 #include <linux/device.h>
 #include <linux/fs.h>
-#include "comedidev.h"
+#include <linux/comedi/comedidev.h>
 #include <linux/cdev.h>
 
 #include <linux/io.h>
index 54739af..cc25819 100644 (file)
@@ -9,8 +9,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /**
  * comedi_to_pci_dev() - Return PCI device attached to COMEDI device
diff --git a/drivers/comedi/comedi_pci.h b/drivers/comedi/comedi_pci.h
deleted file mode 100644 (file)
index 4e06944..0000000
+++ /dev/null
@@ -1,57 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0+ */
-/*
- * comedi_pci.h
- * header file for Comedi PCI drivers
- *
- * COMEDI - Linux Control and Measurement Device Interface
- * Copyright (C) 1997-2000 David A. Schleef <ds@schleef.org>
- */
-
-#ifndef _COMEDI_PCI_H
-#define _COMEDI_PCI_H
-
-#include <linux/pci.h>
-
-#include "comedidev.h"
-
-/*
- * PCI Vendor IDs not in <linux/pci_ids.h>
- */
-#define PCI_VENDOR_ID_KOLTER           0x1001
-#define PCI_VENDOR_ID_ICP              0x104c
-#define PCI_VENDOR_ID_DT               0x1116
-#define PCI_VENDOR_ID_IOTECH           0x1616
-#define PCI_VENDOR_ID_CONTEC           0x1221
-#define PCI_VENDOR_ID_RTD              0x1435
-#define PCI_VENDOR_ID_HUMUSOFT         0x186c
-
-struct pci_dev *comedi_to_pci_dev(struct comedi_device *dev);
-
-int comedi_pci_enable(struct comedi_device *dev);
-void comedi_pci_disable(struct comedi_device *dev);
-void comedi_pci_detach(struct comedi_device *dev);
-
-int comedi_pci_auto_config(struct pci_dev *pcidev, struct comedi_driver *driver,
-                          unsigned long context);
-void comedi_pci_auto_unconfig(struct pci_dev *pcidev);
-
-int comedi_pci_driver_register(struct comedi_driver *comedi_driver,
-                              struct pci_driver *pci_driver);
-void comedi_pci_driver_unregister(struct comedi_driver *comedi_driver,
-                                 struct pci_driver *pci_driver);
-
-/**
- * module_comedi_pci_driver() - Helper macro for registering a comedi PCI driver
- * @__comedi_driver: comedi_driver struct
- * @__pci_driver: pci_driver struct
- *
- * Helper macro for comedi PCI drivers which do not do anything special
- * in module init/exit. This eliminates a lot of boilerplate. Each
- * module may only use this macro once, and calling it replaces
- * module_init() and module_exit()
- */
-#define module_comedi_pci_driver(__comedi_driver, __pci_driver) \
-       module_driver(__comedi_driver, comedi_pci_driver_register, \
-                       comedi_pci_driver_unregister, &(__pci_driver))
-
-#endif /* _COMEDI_PCI_H */
index bb273bb..c53aad0 100644 (file)
@@ -9,8 +9,7 @@
 
 #include <linux/module.h>
 #include <linux/kernel.h>
-
-#include "comedi_pcmcia.h"
+#include <linux/comedi/comedi_pcmcia.h>
 
 /**
  * comedi_to_pcmcia_dev() - Return PCMCIA device attached to COMEDI device
diff --git a/drivers/comedi/comedi_pcmcia.h b/drivers/comedi/comedi_pcmcia.h
deleted file mode 100644 (file)
index f2f6e77..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0+ */
-/*
- * comedi_pcmcia.h
- * header file for Comedi PCMCIA drivers
- *
- * COMEDI - Linux Control and Measurement Device Interface
- * Copyright (C) 1997-2000 David A. Schleef <ds@schleef.org>
- */
-
-#ifndef _COMEDI_PCMCIA_H
-#define _COMEDI_PCMCIA_H
-
-#include <pcmcia/cistpl.h>
-#include <pcmcia/ds.h>
-
-#include "comedidev.h"
-
-struct pcmcia_device *comedi_to_pcmcia_dev(struct comedi_device *dev);
-
-int comedi_pcmcia_enable(struct comedi_device *dev,
-                        int (*conf_check)(struct pcmcia_device *p_dev,
-                                          void *priv_data));
-void comedi_pcmcia_disable(struct comedi_device *dev);
-
-int comedi_pcmcia_auto_config(struct pcmcia_device *link,
-                             struct comedi_driver *driver);
-void comedi_pcmcia_auto_unconfig(struct pcmcia_device *link);
-
-int comedi_pcmcia_driver_register(struct comedi_driver *comedi_driver,
-                                 struct pcmcia_driver *pcmcia_driver);
-void comedi_pcmcia_driver_unregister(struct comedi_driver *comedi_driver,
-                                    struct pcmcia_driver *pcmcia_driver);
-
-/**
- * module_comedi_pcmcia_driver() - Helper macro for registering a comedi
- * PCMCIA driver
- * @__comedi_driver: comedi_driver struct
- * @__pcmcia_driver: pcmcia_driver struct
- *
- * Helper macro for comedi PCMCIA drivers which do not do anything special
- * in module init/exit. This eliminates a lot of boilerplate. Each
- * module may only use this macro once, and calling it replaces
- * module_init() and module_exit()
- */
-#define module_comedi_pcmcia_driver(__comedi_driver, __pcmcia_driver) \
-       module_driver(__comedi_driver, comedi_pcmcia_driver_register, \
-                       comedi_pcmcia_driver_unregister, &(__pcmcia_driver))
-
-#endif /* _COMEDI_PCMCIA_H */
index eea8ebf..d11ea14 100644 (file)
@@ -8,8 +8,7 @@
  */
 
 #include <linux/module.h>
-
-#include "comedi_usb.h"
+#include <linux/comedi/comedi_usb.h>
 
 /**
  * comedi_to_usb_interface() - Return USB interface attached to COMEDI device
diff --git a/drivers/comedi/comedi_usb.h b/drivers/comedi/comedi_usb.h
deleted file mode 100644 (file)
index 601e29d..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0+ */
-/* comedi_usb.h
- * header file for USB Comedi drivers
- *
- * COMEDI - Linux Control and Measurement Device Interface
- * Copyright (C) 1997-2000 David A. Schleef <ds@schleef.org>
- */
-
-#ifndef _COMEDI_USB_H
-#define _COMEDI_USB_H
-
-#include <linux/usb.h>
-
-#include "comedidev.h"
-
-struct usb_interface *comedi_to_usb_interface(struct comedi_device *dev);
-struct usb_device *comedi_to_usb_dev(struct comedi_device *dev);
-
-int comedi_usb_auto_config(struct usb_interface *intf,
-                          struct comedi_driver *driver, unsigned long context);
-void comedi_usb_auto_unconfig(struct usb_interface *intf);
-
-int comedi_usb_driver_register(struct comedi_driver *comedi_driver,
-                              struct usb_driver *usb_driver);
-void comedi_usb_driver_unregister(struct comedi_driver *comedi_driver,
-                                 struct usb_driver *usb_driver);
-
-/**
- * module_comedi_usb_driver() - Helper macro for registering a comedi USB driver
- * @__comedi_driver: comedi_driver struct
- * @__usb_driver: usb_driver struct
- *
- * Helper macro for comedi USB drivers which do not do anything special
- * in module init/exit. This eliminates a lot of boilerplate. Each
- * module may only use this macro once, and calling it replaces
- * module_init() and module_exit()
- */
-#define module_comedi_usb_driver(__comedi_driver, __usb_driver) \
-       module_driver(__comedi_driver, comedi_usb_driver_register, \
-                       comedi_usb_driver_unregister, &(__usb_driver))
-
-#endif /* _COMEDI_USB_H */
diff --git a/drivers/comedi/comedidev.h b/drivers/comedi/comedidev.h
deleted file mode 100644 (file)
index 0e1b95e..0000000
+++ /dev/null
@@ -1,1054 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0+ */
-/*
- * comedidev.h
- * header file for kernel-only structures, variables, and constants
- *
- * COMEDI - Linux Control and Measurement Device Interface
- * Copyright (C) 1997-2000 David A. Schleef <ds@schleef.org>
- */
-
-#ifndef _COMEDIDEV_H
-#define _COMEDIDEV_H
-
-#include <linux/dma-mapping.h>
-#include <linux/mutex.h>
-#include <linux/spinlock_types.h>
-#include <linux/rwsem.h>
-#include <linux/kref.h>
-
-#include "comedi.h"
-
-#define COMEDI_VERSION(a, b, c) (((a) << 16) + ((b) << 8) + (c))
-#define COMEDI_VERSION_CODE COMEDI_VERSION(COMEDI_MAJORVERSION, \
-       COMEDI_MINORVERSION, COMEDI_MICROVERSION)
-#define COMEDI_RELEASE VERSION
-
-#define COMEDI_NUM_BOARD_MINORS 0x30
-
-/**
- * struct comedi_subdevice - Working data for a COMEDI subdevice
- * @device: COMEDI device to which this subdevice belongs.  (Initialized by
- *     comedi_alloc_subdevices().)
- * @index: Index of this subdevice within device's array of subdevices.
- *     (Initialized by comedi_alloc_subdevices().)
- * @type: Type of subdevice from &enum comedi_subdevice_type.  (Initialized by
- *     the low-level driver.)
- * @n_chan: Number of channels the subdevice supports.  (Initialized by the
- *     low-level driver.)
- * @subdev_flags: Various "SDF" flags indicating aspects of the subdevice to
- *     the COMEDI core and user application.  (Initialized by the low-level
- *     driver.)
- * @len_chanlist: Maximum length of a channel list if the subdevice supports
- *     asynchronous acquisition commands.  (Optionally initialized by the
- *     low-level driver, or changed from 0 to 1 during post-configuration.)
- * @private: Private data pointer which is either set by the low-level driver
- *     itself, or by a call to comedi_alloc_spriv() which allocates storage.
- *     In the latter case, the storage is automatically freed after the
- *     low-level driver's "detach" handler is called for the device.
- *     (Initialized by the low-level driver.)
- * @async: Pointer to &struct comedi_async id the subdevice supports
- *     asynchronous acquisition commands.  (Allocated and initialized during
- *     post-configuration if needed.)
- * @lock: Pointer to a file object that performed a %COMEDI_LOCK ioctl on the
- *     subdevice.  (Initially NULL.)
- * @busy: Pointer to a file object that is performing an asynchronous
- *     acquisition command on the subdevice.  (Initially NULL.)
- * @runflags: Internal flags for use by COMEDI core, mostly indicating whether
- *     an asynchronous acquisition command is running.
- * @spin_lock: Generic spin-lock for use by the COMEDI core and the low-level
- *     driver.  (Initialized by comedi_alloc_subdevices().)
- * @io_bits: Bit-mask indicating the channel directions for a DIO subdevice
- *     with no more than 32 channels.  A '1' at a bit position indicates the
- *     corresponding channel is configured as an output.  (Initialized by the
- *     low-level driver for a DIO subdevice.  Forced to all-outputs during
- *     post-configuration for a digital output subdevice.)
- * @maxdata: If non-zero, this is the maximum raw data value of each channel.
- *     If zero, the maximum data value is channel-specific.  (Initialized by
- *     the low-level driver.)
- * @maxdata_list: If the maximum data value is channel-specific, this points
- *     to an array of maximum data values indexed by channel index.
- *     (Initialized by the low-level driver.)
- * @range_table: If non-NULL, this points to a COMEDI range table for the
- *     subdevice.  If NULL, the range table is channel-specific.  (Initialized
- *     by the low-level driver, will be set to an "invalid" range table during
- *     post-configuration if @range_table and @range_table_list are both
- *     NULL.)
- * @range_table_list: If the COMEDI range table is channel-specific, this
- *     points to an array of pointers to COMEDI range tables indexed by
- *     channel number.  (Initialized by the low-level driver.)
- * @chanlist: Not used.
- * @insn_read: Optional pointer to a handler for the %INSN_READ instruction.
- *     (Initialized by the low-level driver, or set to a default handler
- *     during post-configuration.)
- * @insn_write: Optional pointer to a handler for the %INSN_WRITE instruction.
- *     (Initialized by the low-level driver, or set to a default handler
- *     during post-configuration.)
- * @insn_bits: Optional pointer to a handler for the %INSN_BITS instruction
- *     for a digital input, digital output or digital input/output subdevice.
- *     (Initialized by the low-level driver, or set to a default handler
- *     during post-configuration.)
- * @insn_config: Optional pointer to a handler for the %INSN_CONFIG
- *     instruction.  (Initialized by the low-level driver, or set to a default
- *     handler during post-configuration.)
- * @do_cmd: If the subdevice supports asynchronous acquisition commands, this
- *     points to a handler to set it up in hardware.  (Initialized by the
- *     low-level driver.)
- * @do_cmdtest: If the subdevice supports asynchronous acquisition commands,
- *     this points to a handler used to check and possibly tweak a prospective
- *     acquisition command without setting it up in hardware.  (Initialized by
- *     the low-level driver.)
- * @poll: If the subdevice supports asynchronous acquisition commands, this
- *     is an optional pointer to a handler for the %COMEDI_POLL ioctl which
- *     instructs the low-level driver to synchronize buffers.  (Initialized by
- *     the low-level driver if needed.)
- * @cancel: If the subdevice supports asynchronous acquisition commands, this
- *     points to a handler used to terminate a running command.  (Initialized
- *     by the low-level driver.)
- * @buf_change: If the subdevice supports asynchronous acquisition commands,
- *     this is an optional pointer to a handler that is called when the data
- *     buffer for handling asynchronous commands is allocated or reallocated.
- *     (Initialized by the low-level driver if needed.)
- * @munge: If the subdevice supports asynchronous acquisition commands and
- *     uses DMA to transfer data from the hardware to the acquisition buffer,
- *     this points to a function used to "munge" the data values from the
- *     hardware into the format expected by COMEDI.  (Initialized by the
- *     low-level driver if needed.)
- * @async_dma_dir: If the subdevice supports asynchronous acquisition commands
- *     and uses DMA to transfer data from the hardware to the acquisition
- *     buffer, this sets the DMA direction for the buffer. (initialized to
- *     %DMA_NONE by comedi_alloc_subdevices() and changed by the low-level
- *     driver if necessary.)
- * @state: Handy bit-mask indicating the output states for a DIO or digital
- *     output subdevice with no more than 32 channels. (Initialized by the
- *     low-level driver.)
- * @class_dev: If the subdevice supports asynchronous acquisition commands,
- *     this points to a sysfs comediX_subdY device where X is the minor device
- *     number of the COMEDI device and Y is the subdevice number.  The minor
- *     device number for the sysfs device is allocated dynamically in the
- *     range 48 to 255.  This is used to allow the COMEDI device to be opened
- *     with a different default read or write subdevice.  (Allocated during
- *     post-configuration if needed.)
- * @minor: If @class_dev is set, this is its dynamically allocated minor
- *     device number.  (Set during post-configuration if necessary.)
- * @readback: Optional pointer to memory allocated by
- *     comedi_alloc_subdev_readback() used to hold the values written to
- *     analog output channels so they can be read back.  The storage is
- *     automatically freed after the low-level driver's "detach" handler is
- *     called for the device.  (Initialized by the low-level driver.)
- *
- * This is the main control structure for a COMEDI subdevice.  If the subdevice
- * supports asynchronous acquisition commands, additional information is stored
- * in the &struct comedi_async pointed to by @async.
- *
- * Most of the subdevice is initialized by the low-level driver's "attach" or
- * "auto_attach" handlers but parts of it are initialized by
- * comedi_alloc_subdevices(), and other parts are initialized during
- * post-configuration on return from that handler.
- *
- * A low-level driver that sets @insn_bits for a digital input, digital output,
- * or DIO subdevice may leave @insn_read and @insn_write uninitialized, in
- * which case they will be set to a default handler during post-configuration
- * that uses @insn_bits to emulate the %INSN_READ and %INSN_WRITE instructions.
- */
-struct comedi_subdevice {
-       struct comedi_device *device;
-       int index;
-       int type;
-       int n_chan;
-       int subdev_flags;
-       int len_chanlist;       /* maximum length of channel/gain list */
-
-       void *private;
-
-       struct comedi_async *async;
-
-       void *lock;
-       void *busy;
-       unsigned int runflags;
-       spinlock_t spin_lock;   /* generic spin-lock for COMEDI and drivers */
-
-       unsigned int io_bits;
-
-       unsigned int maxdata;   /* if maxdata==0, use list */
-       const unsigned int *maxdata_list;       /* list is channel specific */
-
-       const struct comedi_lrange *range_table;
-       const struct comedi_lrange *const *range_table_list;
-
-       unsigned int *chanlist; /* driver-owned chanlist (not used) */
-
-       int (*insn_read)(struct comedi_device *dev, struct comedi_subdevice *s,
-                        struct comedi_insn *insn, unsigned int *data);
-       int (*insn_write)(struct comedi_device *dev, struct comedi_subdevice *s,
-                         struct comedi_insn *insn, unsigned int *data);
-       int (*insn_bits)(struct comedi_device *dev, struct comedi_subdevice *s,
-                        struct comedi_insn *insn, unsigned int *data);
-       int (*insn_config)(struct comedi_device *dev,
-                          struct comedi_subdevice *s,
-                          struct comedi_insn *insn,
-                          unsigned int *data);
-
-       int (*do_cmd)(struct comedi_device *dev, struct comedi_subdevice *s);
-       int (*do_cmdtest)(struct comedi_device *dev,
-                         struct comedi_subdevice *s,
-                         struct comedi_cmd *cmd);
-       int (*poll)(struct comedi_device *dev, struct comedi_subdevice *s);
-       int (*cancel)(struct comedi_device *dev, struct comedi_subdevice *s);
-
-       /* called when the buffer changes */
-       int (*buf_change)(struct comedi_device *dev,
-                         struct comedi_subdevice *s);
-
-       void (*munge)(struct comedi_device *dev, struct comedi_subdevice *s,
-                     void *data, unsigned int num_bytes,
-                     unsigned int start_chan_index);
-       enum dma_data_direction async_dma_dir;
-
-       unsigned int state;
-
-       struct device *class_dev;
-       int minor;
-
-       unsigned int *readback;
-};
-
-/**
- * struct comedi_buf_page - Describe a page of a COMEDI buffer
- * @virt_addr: Kernel address of page.
- * @dma_addr: DMA address of page if in DMA coherent memory.
- */
-struct comedi_buf_page {
-       void *virt_addr;
-       dma_addr_t dma_addr;
-};
-
-/**
- * struct comedi_buf_map - Describe pages in a COMEDI buffer
- * @dma_hw_dev: Low-level hardware &struct device pointer copied from the
- *     COMEDI device's hw_dev member.
- * @page_list: Pointer to array of &struct comedi_buf_page, one for each
- *     page in the buffer.
- * @n_pages: Number of pages in the buffer.
- * @dma_dir: DMA direction used to allocate pages of DMA coherent memory,
- *     or %DMA_NONE if pages allocated from regular memory.
- * @refcount: &struct kref reference counter used to free the buffer.
- *
- * A COMEDI data buffer is allocated as individual pages, either in
- * conventional memory or DMA coherent memory, depending on the attached,
- * low-level hardware device.  (The buffer pages also get mapped into the
- * kernel's contiguous virtual address space pointed to by the 'prealloc_buf'
- * member of &struct comedi_async.)
- *
- * The buffer is normally freed when the COMEDI device is detached from the
- * low-level driver (which may happen due to device removal), but if it happens
- * to be mmapped at the time, the pages cannot be freed until the buffer has
- * been munmapped.  That is what the reference counter is for.  (The virtual
- * address space pointed by 'prealloc_buf' is freed when the COMEDI device is
- * detached.)
- */
-struct comedi_buf_map {
-       struct device *dma_hw_dev;
-       struct comedi_buf_page *page_list;
-       unsigned int n_pages;
-       enum dma_data_direction dma_dir;
-       struct kref refcount;
-};
-
-/**
- * struct comedi_async - Control data for asynchronous COMEDI commands
- * @prealloc_buf: Kernel virtual address of allocated acquisition buffer.
- * @prealloc_bufsz: Buffer size (in bytes).
- * @buf_map: Map of buffer pages.
- * @max_bufsize: Maximum allowed buffer size (in bytes).
- * @buf_write_count: "Write completed" count (in bytes, modulo 2**32).
- * @buf_write_alloc_count: "Allocated for writing" count (in bytes,
- *     modulo 2**32).
- * @buf_read_count: "Read completed" count (in bytes, modulo 2**32).
- * @buf_read_alloc_count: "Allocated for reading" count (in bytes,
- *     modulo 2**32).
- * @buf_write_ptr: Buffer position for writer.
- * @buf_read_ptr: Buffer position for reader.
- * @cur_chan: Current position in chanlist for scan (for those drivers that
- *     use it).
- * @scans_done: The number of scans completed.
- * @scan_progress: Amount received or sent for current scan (in bytes).
- * @munge_chan: Current position in chanlist for "munging".
- * @munge_count: "Munge" count (in bytes, modulo 2**32).
- * @munge_ptr: Buffer position for "munging".
- * @events: Bit-vector of events that have occurred.
- * @cmd: Details of comedi command in progress.
- * @wait_head: Task wait queue for file reader or writer.
- * @cb_mask: Bit-vector of events that should wake waiting tasks.
- * @inttrig: Software trigger function for command, or NULL.
- *
- * Note about the ..._count and ..._ptr members:
- *
- * Think of the _Count values being integers of unlimited size, indexing
- * into a buffer of infinite length (though only an advancing portion
- * of the buffer of fixed length prealloc_bufsz is accessible at any
- * time).  Then:
- *
- *   Buf_Read_Count <= Buf_Read_Alloc_Count <= Munge_Count <=
- *   Buf_Write_Count <= Buf_Write_Alloc_Count <=
- *   (Buf_Read_Count + prealloc_bufsz)
- *
- * (Those aren't the actual members, apart from prealloc_bufsz.) When the
- * buffer is reset, those _Count values start at 0 and only increase in value,
- * maintaining the above inequalities until the next time the buffer is
- * reset.  The buffer is divided into the following regions by the inequalities:
- *
- *   [0, Buf_Read_Count):
- *     old region no longer accessible
- *
- *   [Buf_Read_Count, Buf_Read_Alloc_Count):
- *     filled and munged region allocated for reading but not yet read
- *
- *   [Buf_Read_Alloc_Count, Munge_Count):
- *     filled and munged region not yet allocated for reading
- *
- *   [Munge_Count, Buf_Write_Count):
- *     filled region not yet munged
- *
- *   [Buf_Write_Count, Buf_Write_Alloc_Count):
- *     unfilled region allocated for writing but not yet written
- *
- *   [Buf_Write_Alloc_Count, Buf_Read_Count + prealloc_bufsz):
- *     unfilled region not yet allocated for writing
- *
- *   [Buf_Read_Count + prealloc_bufsz, infinity):
- *     unfilled region not yet accessible
- *
- * Data needs to be written into the buffer before it can be read out,
- * and may need to be converted (or "munged") between the two
- * operations.  Extra unfilled buffer space may need to allocated for
- * writing (advancing Buf_Write_Alloc_Count) before new data is written.
- * After writing new data, the newly filled space needs to be released
- * (advancing Buf_Write_Count).  This also results in the new data being
- * "munged" (advancing Munge_Count).  Before data is read out of the
- * buffer, extra space may need to be allocated for reading (advancing
- * Buf_Read_Alloc_Count).  After the data has been read out, the space
- * needs to be released (advancing Buf_Read_Count).
- *
- * The actual members, buf_read_count, buf_read_alloc_count,
- * munge_count, buf_write_count, and buf_write_alloc_count take the
- * value of the corresponding capitalized _Count values modulo 2^32
- * (UINT_MAX+1).  Subtracting a "higher" _count value from a "lower"
- * _count value gives the same answer as subtracting a "higher" _Count
- * value from a lower _Count value because prealloc_bufsz < UINT_MAX+1.
- * The modulo operation is done implicitly.
- *
- * The buf_read_ptr, munge_ptr, and buf_write_ptr members take the value
- * of the corresponding capitalized _Count values modulo prealloc_bufsz.
- * These correspond to byte indices in the physical buffer.  The modulo
- * operation is done by subtracting prealloc_bufsz when the value
- * exceeds prealloc_bufsz (assuming prealloc_bufsz plus the increment is
- * less than or equal to UINT_MAX).
- */
-struct comedi_async {
-       void *prealloc_buf;
-       unsigned int prealloc_bufsz;
-       struct comedi_buf_map *buf_map;
-       unsigned int max_bufsize;
-       unsigned int buf_write_count;
-       unsigned int buf_write_alloc_count;
-       unsigned int buf_read_count;
-       unsigned int buf_read_alloc_count;
-       unsigned int buf_write_ptr;
-       unsigned int buf_read_ptr;
-       unsigned int cur_chan;
-       unsigned int scans_done;
-       unsigned int scan_progress;
-       unsigned int munge_chan;
-       unsigned int munge_count;
-       unsigned int munge_ptr;
-       unsigned int events;
-       struct comedi_cmd cmd;
-       wait_queue_head_t wait_head;
-       unsigned int cb_mask;
-       int (*inttrig)(struct comedi_device *dev, struct comedi_subdevice *s,
-                      unsigned int x);
-};
-
-/**
- * enum comedi_cb - &struct comedi_async callback "events"
- * @COMEDI_CB_EOS:             end-of-scan
- * @COMEDI_CB_EOA:             end-of-acquisition/output
- * @COMEDI_CB_BLOCK:           data has arrived, wakes up read() / write()
- * @COMEDI_CB_EOBUF:           DEPRECATED: end of buffer
- * @COMEDI_CB_ERROR:           card error during acquisition
- * @COMEDI_CB_OVERFLOW:                buffer overflow/underflow
- * @COMEDI_CB_ERROR_MASK:      events that indicate an error has occurred
- * @COMEDI_CB_CANCEL_MASK:     events that will cancel an async command
- */
-enum comedi_cb {
-       COMEDI_CB_EOS           = BIT(0),
-       COMEDI_CB_EOA           = BIT(1),
-       COMEDI_CB_BLOCK         = BIT(2),
-       COMEDI_CB_EOBUF         = BIT(3),
-       COMEDI_CB_ERROR         = BIT(4),
-       COMEDI_CB_OVERFLOW      = BIT(5),
-       /* masks */
-       COMEDI_CB_ERROR_MASK    = (COMEDI_CB_ERROR | COMEDI_CB_OVERFLOW),
-       COMEDI_CB_CANCEL_MASK   = (COMEDI_CB_EOA | COMEDI_CB_ERROR_MASK)
-};
-
-/**
- * struct comedi_driver - COMEDI driver registration
- * @driver_name: Name of driver.
- * @module: Owning module.
- * @attach: The optional "attach" handler for manually configured COMEDI
- *     devices.
- * @detach: The "detach" handler for deconfiguring COMEDI devices.
- * @auto_attach: The optional "auto_attach" handler for automatically
- *     configured COMEDI devices.
- * @num_names: Optional number of "board names" supported.
- * @board_name: Optional pointer to a pointer to a board name.  The pointer
- *     to a board name is embedded in an element of a driver-defined array
- *     of static, read-only board type information.
- * @offset: Optional size of each element of the driver-defined array of
- *     static, read-only board type information, i.e. the offset between each
- *     pointer to a board name.
- *
- * This is used with comedi_driver_register() and comedi_driver_unregister() to
- * register and unregister a low-level COMEDI driver with the COMEDI core.
- *
- * If @num_names is non-zero, @board_name should be non-NULL, and @offset
- * should be at least sizeof(*board_name).  These are used by the handler for
- * the %COMEDI_DEVCONFIG ioctl to match a hardware device and its driver by
- * board name.  If @num_names is zero, the %COMEDI_DEVCONFIG ioctl matches a
- * hardware device and its driver by driver name.  This is only useful if the
- * @attach handler is set.  If @num_names is non-zero, the driver's @attach
- * handler will be called with the COMEDI device structure's board_ptr member
- * pointing to the matched pointer to a board name within the driver's private
- * array of static, read-only board type information.
- *
- * The @detach handler has two roles.  If a COMEDI device was successfully
- * configured by the @attach or @auto_attach handler, it is called when the
- * device is being deconfigured (by the %COMEDI_DEVCONFIG ioctl, or due to
- * unloading of the driver, or due to device removal).  It is also called when
- * the @attach or @auto_attach handler returns an error.  Therefore, the
- * @attach or @auto_attach handlers can defer clean-up on error until the
- * @detach handler is called.  If the @attach or @auto_attach handlers free
- * any resources themselves, they must prevent the @detach handler from
- * freeing the same resources.  The @detach handler must not assume that all
- * resources requested by the @attach or @auto_attach handler were
- * successfully allocated.
- */
-struct comedi_driver {
-       /* private: */
-       struct comedi_driver *next;     /* Next in list of COMEDI drivers. */
-       /* public: */
-       const char *driver_name;
-       struct module *module;
-       int (*attach)(struct comedi_device *dev, struct comedi_devconfig *it);
-       void (*detach)(struct comedi_device *dev);
-       int (*auto_attach)(struct comedi_device *dev, unsigned long context);
-       unsigned int num_names;
-       const char *const *board_name;
-       int offset;
-};
-
-/**
- * struct comedi_device - Working data for a COMEDI device
- * @use_count: Number of open file objects.
- * @driver: Low-level COMEDI driver attached to this COMEDI device.
- * @pacer: Optional pointer to a dynamically allocated acquisition pacer
- *     control.  It is freed automatically after the COMEDI device is
- *     detached from the low-level driver.
- * @private: Optional pointer to private data allocated by the low-level
- *     driver.  It is freed automatically after the COMEDI device is
- *     detached from the low-level driver.
- * @class_dev: Sysfs comediX device.
- * @minor: Minor device number of COMEDI char device (0-47).
- * @detach_count: Counter incremented every time the COMEDI device is detached.
- *     Used for checking a previous attachment is still valid.
- * @hw_dev: Optional pointer to the low-level hardware &struct device.  It is
- *     required for automatically configured COMEDI devices and optional for
- *     COMEDI devices configured by the %COMEDI_DEVCONFIG ioctl, although
- *     the bus-specific COMEDI functions only work if it is set correctly.
- *     It is also passed to dma_alloc_coherent() for COMEDI subdevices that
- *     have their 'async_dma_dir' member set to something other than
- *     %DMA_NONE.
- * @board_name: Pointer to a COMEDI board name or a COMEDI driver name.  When
- *     the low-level driver's "attach" handler is called by the handler for
- *     the %COMEDI_DEVCONFIG ioctl, it either points to a matched board name
- *     string if the 'num_names' member of the &struct comedi_driver is
- *     non-zero, otherwise it points to the low-level driver name string.
- *     When the low-lever driver's "auto_attach" handler is called for an
- *     automatically configured COMEDI device, it points to the low-level
- *     driver name string.  The low-level driver is free to change it in its
- *     "attach" or "auto_attach" handler if it wishes.
- * @board_ptr: Optional pointer to private, read-only board type information in
- *     the low-level driver.  If the 'num_names' member of the &struct
- *     comedi_driver is non-zero, the handler for the %COMEDI_DEVCONFIG ioctl
- *     will point it to a pointer to a matched board name string within the
- *     driver's private array of static, read-only board type information when
- *     calling the driver's "attach" handler.  The low-level driver is free to
- *     change it.
- * @attached: Flag indicating that the COMEDI device is attached to a low-level
- *     driver.
- * @ioenabled: Flag used to indicate that a PCI device has been enabled and
- *     its regions requested.
- * @spinlock: Generic spin-lock for use by the low-level driver.
- * @mutex: Generic mutex for use by the COMEDI core module.
- * @attach_lock: &struct rw_semaphore used to guard against the COMEDI device
- *     being detached while an operation is in progress.  The down_write()
- *     operation is only allowed while @mutex is held and is used when
- *     changing @attached and @detach_count and calling the low-level driver's
- *     "detach" handler.  The down_read() operation is generally used without
- *     holding @mutex.
- * @refcount: &struct kref reference counter for freeing COMEDI device.
- * @n_subdevices: Number of COMEDI subdevices allocated by the low-level
- *     driver for this device.
- * @subdevices: Dynamically allocated array of COMEDI subdevices.
- * @mmio: Optional pointer to a remapped MMIO region set by the low-level
- *     driver.
- * @iobase: Optional base of an I/O port region requested by the low-level
- *     driver.
- * @iolen: Length of I/O port region requested at @iobase.
- * @irq: Optional IRQ number requested by the low-level driver.
- * @read_subdev: Optional pointer to a default COMEDI subdevice operated on by
- *     the read() file operation.  Set by the low-level driver.
- * @write_subdev: Optional pointer to a default COMEDI subdevice operated on by
- *     the write() file operation.  Set by the low-level driver.
- * @async_queue: Storage for fasync_helper().
- * @open: Optional pointer to a function set by the low-level driver to be
- *     called when @use_count changes from 0 to 1.
- * @close: Optional pointer to a function set by the low-level driver to be
- *     called when @use_count changed from 1 to 0.
- * @insn_device_config: Optional pointer to a handler for all sub-instructions
- *     except %INSN_DEVICE_CONFIG_GET_ROUTES of the %INSN_DEVICE_CONFIG
- *     instruction.  If this is not initialized by the low-level driver, a
- *     default handler will be set during post-configuration.
- * @get_valid_routes: Optional pointer to a handler for the
- *     %INSN_DEVICE_CONFIG_GET_ROUTES sub-instruction of the
- *     %INSN_DEVICE_CONFIG instruction set.  If this is not initialized by the
- *     low-level driver, a default handler that copies zero routes back to the
- *     user will be used.
- *
- * This is the main control data structure for a COMEDI device (as far as the
- * COMEDI core is concerned).  There are two groups of COMEDI devices -
- * "legacy" devices that are configured by the handler for the
- * %COMEDI_DEVCONFIG ioctl, and automatically configured devices resulting
- * from a call to comedi_auto_config() as a result of a bus driver probe in
- * a low-level COMEDI driver.  The "legacy" COMEDI devices are allocated
- * during module initialization if the "comedi_num_legacy_minors" module
- * parameter is non-zero and use minor device numbers from 0 to
- * comedi_num_legacy_minors minus one.  The automatically configured COMEDI
- * devices are allocated on demand and use minor device numbers from
- * comedi_num_legacy_minors to 47.
- */
-struct comedi_device {
-       int use_count;
-       struct comedi_driver *driver;
-       struct comedi_8254 *pacer;
-       void *private;
-
-       struct device *class_dev;
-       int minor;
-       unsigned int detach_count;
-       struct device *hw_dev;
-
-       const char *board_name;
-       const void *board_ptr;
-       unsigned int attached:1;
-       unsigned int ioenabled:1;
-       spinlock_t spinlock;    /* generic spin-lock for low-level driver */
-       struct mutex mutex;     /* generic mutex for COMEDI core */
-       struct rw_semaphore attach_lock;
-       struct kref refcount;
-
-       int n_subdevices;
-       struct comedi_subdevice *subdevices;
-
-       /* dumb */
-       void __iomem *mmio;
-       unsigned long iobase;
-       unsigned long iolen;
-       unsigned int irq;
-
-       struct comedi_subdevice *read_subdev;
-       struct comedi_subdevice *write_subdev;
-
-       struct fasync_struct *async_queue;
-
-       int (*open)(struct comedi_device *dev);
-       void (*close)(struct comedi_device *dev);
-       int (*insn_device_config)(struct comedi_device *dev,
-                                 struct comedi_insn *insn, unsigned int *data);
-       unsigned int (*get_valid_routes)(struct comedi_device *dev,
-                                        unsigned int n_pairs,
-                                        unsigned int *pair_data);
-};
-
-/*
- * function prototypes
- */
-
-void comedi_event(struct comedi_device *dev, struct comedi_subdevice *s);
-
-struct comedi_device *comedi_dev_get_from_minor(unsigned int minor);
-int comedi_dev_put(struct comedi_device *dev);
-
-bool comedi_is_subdevice_running(struct comedi_subdevice *s);
-
-void *comedi_alloc_spriv(struct comedi_subdevice *s, size_t size);
-void comedi_set_spriv_auto_free(struct comedi_subdevice *s);
-
-int comedi_check_chanlist(struct comedi_subdevice *s,
-                         int n,
-                         unsigned int *chanlist);
-
-/* range stuff */
-
-#define RANGE(a, b)            {(a) * 1e6, (b) * 1e6, 0}
-#define RANGE_ext(a, b)                {(a) * 1e6, (b) * 1e6, RF_EXTERNAL}
-#define RANGE_mA(a, b)         {(a) * 1e6, (b) * 1e6, UNIT_mA}
-#define RANGE_unitless(a, b)   {(a) * 1e6, (b) * 1e6, 0}
-#define BIP_RANGE(a)           {-(a) * 1e6, (a) * 1e6, 0}
-#define UNI_RANGE(a)           {0, (a) * 1e6, 0}
-
-extern const struct comedi_lrange range_bipolar10;
-extern const struct comedi_lrange range_bipolar5;
-extern const struct comedi_lrange range_bipolar2_5;
-extern const struct comedi_lrange range_unipolar10;
-extern const struct comedi_lrange range_unipolar5;
-extern const struct comedi_lrange range_unipolar2_5;
-extern const struct comedi_lrange range_0_20mA;
-extern const struct comedi_lrange range_4_20mA;
-extern const struct comedi_lrange range_0_32mA;
-extern const struct comedi_lrange range_unknown;
-
-#define range_digital          range_unipolar5
-
-/**
- * struct comedi_lrange - Describes a COMEDI range table
- * @length: Number of entries in the range table.
- * @range: Array of &struct comedi_krange, one for each range.
- *
- * Each element of @range[] describes the minimum and maximum physical range
- * and the type of units.  Typically, the type of unit is %UNIT_volt
- * (i.e. volts) and the minimum and maximum are in millionths of a volt.
- * There may also be a flag that indicates the minimum and maximum are merely
- * scale factors for an unknown, external reference.
- */
-struct comedi_lrange {
-       int length;
-       struct comedi_krange range[];
-};
-
-/**
- * comedi_range_is_bipolar() - Test if subdevice range is bipolar
- * @s: COMEDI subdevice.
- * @range: Index of range within a range table.
- *
- * Tests whether a range is bipolar by checking whether its minimum value
- * is negative.
- *
- * Assumes @range is valid.  Does not work for subdevices using a
- * channel-specific range table list.
- *
- * Return:
- *     %true if the range is bipolar.
- *     %false if the range is unipolar.
- */
-static inline bool comedi_range_is_bipolar(struct comedi_subdevice *s,
-                                          unsigned int range)
-{
-       return s->range_table->range[range].min < 0;
-}
-
-/**
- * comedi_range_is_unipolar() - Test if subdevice range is unipolar
- * @s: COMEDI subdevice.
- * @range: Index of range within a range table.
- *
- * Tests whether a range is unipolar by checking whether its minimum value
- * is at least 0.
- *
- * Assumes @range is valid.  Does not work for subdevices using a
- * channel-specific range table list.
- *
- * Return:
- *     %true if the range is unipolar.
- *     %false if the range is bipolar.
- */
-static inline bool comedi_range_is_unipolar(struct comedi_subdevice *s,
-                                           unsigned int range)
-{
-       return s->range_table->range[range].min >= 0;
-}
-
-/**
- * comedi_range_is_external() - Test if subdevice range is external
- * @s: COMEDI subdevice.
- * @range: Index of range within a range table.
- *
- * Tests whether a range is externally reference by checking whether its
- * %RF_EXTERNAL flag is set.
- *
- * Assumes @range is valid.  Does not work for subdevices using a
- * channel-specific range table list.
- *
- * Return:
- *     %true if the range is external.
- *     %false if the range is internal.
- */
-static inline bool comedi_range_is_external(struct comedi_subdevice *s,
-                                           unsigned int range)
-{
-       return !!(s->range_table->range[range].flags & RF_EXTERNAL);
-}
-
-/**
- * comedi_chan_range_is_bipolar() - Test if channel-specific range is bipolar
- * @s: COMEDI subdevice.
- * @chan: The channel number.
- * @range: Index of range within a range table.
- *
- * Tests whether a range is bipolar by checking whether its minimum value
- * is negative.
- *
- * Assumes @chan and @range are valid.  Only works for subdevices with a
- * channel-specific range table list.
- *
- * Return:
- *     %true if the range is bipolar.
- *     %false if the range is unipolar.
- */
-static inline bool comedi_chan_range_is_bipolar(struct comedi_subdevice *s,
-                                               unsigned int chan,
-                                               unsigned int range)
-{
-       return s->range_table_list[chan]->range[range].min < 0;
-}
-
-/**
- * comedi_chan_range_is_unipolar() - Test if channel-specific range is unipolar
- * @s: COMEDI subdevice.
- * @chan: The channel number.
- * @range: Index of range within a range table.
- *
- * Tests whether a range is unipolar by checking whether its minimum value
- * is at least 0.
- *
- * Assumes @chan and @range are valid.  Only works for subdevices with a
- * channel-specific range table list.
- *
- * Return:
- *     %true if the range is unipolar.
- *     %false if the range is bipolar.
- */
-static inline bool comedi_chan_range_is_unipolar(struct comedi_subdevice *s,
-                                                unsigned int chan,
-                                                unsigned int range)
-{
-       return s->range_table_list[chan]->range[range].min >= 0;
-}
-
-/**
- * comedi_chan_range_is_external() - Test if channel-specific range is external
- * @s: COMEDI subdevice.
- * @chan: The channel number.
- * @range: Index of range within a range table.
- *
- * Tests whether a range is externally reference by checking whether its
- * %RF_EXTERNAL flag is set.
- *
- * Assumes @chan and @range are valid.  Only works for subdevices with a
- * channel-specific range table list.
- *
- * Return:
- *     %true if the range is bipolar.
- *     %false if the range is unipolar.
- */
-static inline bool comedi_chan_range_is_external(struct comedi_subdevice *s,
-                                                unsigned int chan,
-                                                unsigned int range)
-{
-       return !!(s->range_table_list[chan]->range[range].flags & RF_EXTERNAL);
-}
-
-/**
- * comedi_offset_munge() - Convert between offset binary and 2's complement
- * @s: COMEDI subdevice.
- * @val: Value to be converted.
- *
- * Toggles the highest bit of a sample value to toggle between offset binary
- * and 2's complement.  Assumes that @s->maxdata is a power of 2 minus 1.
- *
- * Return: The converted value.
- */
-static inline unsigned int comedi_offset_munge(struct comedi_subdevice *s,
-                                              unsigned int val)
-{
-       return val ^ s->maxdata ^ (s->maxdata >> 1);
-}
-
-/**
- * comedi_bytes_per_sample() - Determine subdevice sample size
- * @s: COMEDI subdevice.
- *
- * The sample size will be 4 (sizeof int) or 2 (sizeof short) depending on
- * whether the %SDF_LSAMPL subdevice flag is set or not.
- *
- * Return: The subdevice sample size.
- */
-static inline unsigned int comedi_bytes_per_sample(struct comedi_subdevice *s)
-{
-       return s->subdev_flags & SDF_LSAMPL ? sizeof(int) : sizeof(short);
-}
-
-/**
- * comedi_sample_shift() - Determine log2 of subdevice sample size
- * @s: COMEDI subdevice.
- *
- * The sample size will be 4 (sizeof int) or 2 (sizeof short) depending on
- * whether the %SDF_LSAMPL subdevice flag is set or not.  The log2 of the
- * sample size will be 2 or 1 and can be used as the right operand of a
- * bit-shift operator to multiply or divide something by the sample size.
- *
- * Return: log2 of the subdevice sample size.
- */
-static inline unsigned int comedi_sample_shift(struct comedi_subdevice *s)
-{
-       return s->subdev_flags & SDF_LSAMPL ? 2 : 1;
-}
-
-/**
- * comedi_bytes_to_samples() - Convert a number of bytes to a number of samples
- * @s: COMEDI subdevice.
- * @nbytes: Number of bytes
- *
- * Return: The number of bytes divided by the subdevice sample size.
- */
-static inline unsigned int comedi_bytes_to_samples(struct comedi_subdevice *s,
-                                                  unsigned int nbytes)
-{
-       return nbytes >> comedi_sample_shift(s);
-}
-
-/**
- * comedi_samples_to_bytes() - Convert a number of samples to a number of bytes
- * @s: COMEDI subdevice.
- * @nsamples: Number of samples.
- *
- * Return: The number of samples multiplied by the subdevice sample size.
- * (Does not check for arithmetic overflow.)
- */
-static inline unsigned int comedi_samples_to_bytes(struct comedi_subdevice *s,
-                                                  unsigned int nsamples)
-{
-       return nsamples << comedi_sample_shift(s);
-}
-
-/**
- * comedi_check_trigger_src() - Trivially validate a comedi_cmd trigger source
- * @src: Pointer to the trigger source to validate.
- * @flags: Bitmask of valid %TRIG_* for the trigger.
- *
- * This is used in "step 1" of the do_cmdtest functions of comedi drivers
- * to validate the comedi_cmd triggers. The mask of the @src against the
- * @flags allows the userspace comedilib to pass all the comedi_cmd
- * triggers as %TRIG_ANY and get back a bitmask of the valid trigger sources.
- *
- * Return:
- *     0 if trigger sources in *@src are all supported.
- *     -EINVAL if any trigger source in *@src is unsupported.
- */
-static inline int comedi_check_trigger_src(unsigned int *src,
-                                          unsigned int flags)
-{
-       unsigned int orig_src = *src;
-
-       *src = orig_src & flags;
-       if (*src == TRIG_INVALID || *src != orig_src)
-               return -EINVAL;
-       return 0;
-}
-
-/**
- * comedi_check_trigger_is_unique() - Make sure a trigger source is unique
- * @src: The trigger source to check.
- *
- * Return:
- *     0 if no more than one trigger source is set.
- *     -EINVAL if more than one trigger source is set.
- */
-static inline int comedi_check_trigger_is_unique(unsigned int src)
-{
-       /* this test is true if more than one _src bit is set */
-       if ((src & (src - 1)) != 0)
-               return -EINVAL;
-       return 0;
-}
-
-/**
- * comedi_check_trigger_arg_is() - Trivially validate a trigger argument
- * @arg: Pointer to the trigger arg to validate.
- * @val: The value the argument should be.
- *
- * Forces *@arg to be @val.
- *
- * Return:
- *     0 if *@arg was already @val.
- *     -EINVAL if *@arg differed from @val.
- */
-static inline int comedi_check_trigger_arg_is(unsigned int *arg,
-                                             unsigned int val)
-{
-       if (*arg != val) {
-               *arg = val;
-               return -EINVAL;
-       }
-       return 0;
-}
-
-/**
- * comedi_check_trigger_arg_min() - Trivially validate a trigger argument min
- * @arg: Pointer to the trigger arg to validate.
- * @val: The minimum value the argument should be.
- *
- * Forces *@arg to be at least @val, setting it to @val if necessary.
- *
- * Return:
- *     0 if *@arg was already at least @val.
- *     -EINVAL if *@arg was less than @val.
- */
-static inline int comedi_check_trigger_arg_min(unsigned int *arg,
-                                              unsigned int val)
-{
-       if (*arg < val) {
-               *arg = val;
-               return -EINVAL;
-       }
-       return 0;
-}
-
-/**
- * comedi_check_trigger_arg_max() - Trivially validate a trigger argument max
- * @arg: Pointer to the trigger arg to validate.
- * @val: The maximum value the argument should be.
- *
- * Forces *@arg to be no more than @val, setting it to @val if necessary.
- *
- * Return:
- *     0 if*@arg was already no more than @val.
- *     -EINVAL if *@arg was greater than @val.
- */
-static inline int comedi_check_trigger_arg_max(unsigned int *arg,
-                                              unsigned int val)
-{
-       if (*arg > val) {
-               *arg = val;
-               return -EINVAL;
-       }
-       return 0;
-}
-
-/*
- * Must set dev->hw_dev if you wish to dma directly into comedi's buffer.
- * Also useful for retrieving a previously configured hardware device of
- * known bus type.  Set automatically for auto-configured devices.
- * Automatically set to NULL when detaching hardware device.
- */
-int comedi_set_hw_dev(struct comedi_device *dev, struct device *hw_dev);
-
-/**
- * comedi_buf_n_bytes_ready - Determine amount of unread data in buffer
- * @s: COMEDI subdevice.
- *
- * Determines the number of bytes of unread data in the asynchronous
- * acquisition data buffer for a subdevice.  The data in question might not
- * have been fully "munged" yet.
- *
- * Returns: The amount of unread data in bytes.
- */
-static inline unsigned int comedi_buf_n_bytes_ready(struct comedi_subdevice *s)
-{
-       return s->async->buf_write_count - s->async->buf_read_count;
-}
-
-unsigned int comedi_buf_write_alloc(struct comedi_subdevice *s, unsigned int n);
-unsigned int comedi_buf_write_free(struct comedi_subdevice *s, unsigned int n);
-
-unsigned int comedi_buf_read_n_available(struct comedi_subdevice *s);
-unsigned int comedi_buf_read_alloc(struct comedi_subdevice *s, unsigned int n);
-unsigned int comedi_buf_read_free(struct comedi_subdevice *s, unsigned int n);
-
-unsigned int comedi_buf_write_samples(struct comedi_subdevice *s,
-                                     const void *data, unsigned int nsamples);
-unsigned int comedi_buf_read_samples(struct comedi_subdevice *s,
-                                    void *data, unsigned int nsamples);
-
-/* drivers.c - general comedi driver functions */
-
-#define COMEDI_TIMEOUT_MS      1000
-
-int comedi_timeout(struct comedi_device *dev, struct comedi_subdevice *s,
-                  struct comedi_insn *insn,
-                  int (*cb)(struct comedi_device *dev,
-                            struct comedi_subdevice *s,
-                            struct comedi_insn *insn, unsigned long context),
-                  unsigned long context);
-
-unsigned int comedi_handle_events(struct comedi_device *dev,
-                                 struct comedi_subdevice *s);
-
-int comedi_dio_insn_config(struct comedi_device *dev,
-                          struct comedi_subdevice *s,
-                          struct comedi_insn *insn, unsigned int *data,
-                          unsigned int mask);
-unsigned int comedi_dio_update_state(struct comedi_subdevice *s,
-                                    unsigned int *data);
-unsigned int comedi_bytes_per_scan_cmd(struct comedi_subdevice *s,
-                                      struct comedi_cmd *cmd);
-unsigned int comedi_bytes_per_scan(struct comedi_subdevice *s);
-unsigned int comedi_nscans_left(struct comedi_subdevice *s,
-                               unsigned int nscans);
-unsigned int comedi_nsamples_left(struct comedi_subdevice *s,
-                                 unsigned int nsamples);
-void comedi_inc_scan_progress(struct comedi_subdevice *s,
-                             unsigned int num_bytes);
-
-void *comedi_alloc_devpriv(struct comedi_device *dev, size_t size);
-int comedi_alloc_subdevices(struct comedi_device *dev, int num_subdevices);
-int comedi_alloc_subdev_readback(struct comedi_subdevice *s);
-
-int comedi_readback_insn_read(struct comedi_device *dev,
-                             struct comedi_subdevice *s,
-                             struct comedi_insn *insn, unsigned int *data);
-
-int comedi_load_firmware(struct comedi_device *dev, struct device *hw_dev,
-                        const char *name,
-                        int (*cb)(struct comedi_device *dev,
-                                  const u8 *data, size_t size,
-                                  unsigned long context),
-                        unsigned long context);
-
-int __comedi_request_region(struct comedi_device *dev,
-                           unsigned long start, unsigned long len);
-int comedi_request_region(struct comedi_device *dev,
-                         unsigned long start, unsigned long len);
-void comedi_legacy_detach(struct comedi_device *dev);
-
-int comedi_auto_config(struct device *hardware_device,
-                      struct comedi_driver *driver, unsigned long context);
-void comedi_auto_unconfig(struct device *hardware_device);
-
-int comedi_driver_register(struct comedi_driver *driver);
-void comedi_driver_unregister(struct comedi_driver *driver);
-
-/**
- * module_comedi_driver() - Helper macro for registering a comedi driver
- * @__comedi_driver: comedi_driver struct
- *
- * Helper macro for comedi drivers which do not do anything special in module
- * init/exit. This eliminates a lot of boilerplate. Each module may only use
- * this macro once, and calling it replaces module_init() and module_exit().
- */
-#define module_comedi_driver(__comedi_driver) \
-       module_driver(__comedi_driver, comedi_driver_register, \
-                       comedi_driver_unregister)
-
-#endif /* _COMEDIDEV_H */
diff --git a/drivers/comedi/comedilib.h b/drivers/comedi/comedilib.h
deleted file mode 100644 (file)
index 0223c9c..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0+ */
-/*
- * comedilib.h
- * Header file for kcomedilib
- *
- * COMEDI - Linux Control and Measurement Device Interface
- * Copyright (C) 1998-2001 David A. Schleef <ds@schleef.org>
- */
-
-#ifndef _LINUX_COMEDILIB_H
-#define _LINUX_COMEDILIB_H
-
-struct comedi_device *comedi_open(const char *path);
-int comedi_close(struct comedi_device *dev);
-int comedi_dio_get_config(struct comedi_device *dev, unsigned int subdev,
-                         unsigned int chan, unsigned int *io);
-int comedi_dio_config(struct comedi_device *dev, unsigned int subdev,
-                     unsigned int chan, unsigned int io);
-int comedi_dio_bitfield2(struct comedi_device *dev, unsigned int subdev,
-                        unsigned int mask, unsigned int *bits,
-                        unsigned int base_channel);
-int comedi_find_subdevice_by_type(struct comedi_device *dev, int type,
-                                 unsigned int subd);
-int comedi_get_n_channels(struct comedi_device *dev, unsigned int subdevice);
-
-#endif
index 750a6ff..8eb1f69 100644 (file)
@@ -17,8 +17,7 @@
 #include <linux/dma-direction.h>
 #include <linux/interrupt.h>
 #include <linux/firmware.h>
-
-#include "comedidev.h"
+#include <linux/comedi/comedidev.h>
 #include "comedi_internal.h"
 
 struct comedi_driver *comedi_drivers;
index e23335c..ced8ea0 100644 (file)
@@ -40,9 +40,8 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
-
-#include "8255.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
 
 static int dev_8255_attach(struct comedi_device *dev,
                           struct comedi_devconfig *it)
diff --git a/drivers/comedi/drivers/8255.h b/drivers/comedi/drivers/8255.h
deleted file mode 100644 (file)
index ceae3ca..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0+ */
-/*
- * module/8255.h
- * Header file for 8255
- *
- * COMEDI - Linux Control and Measurement Device Interface
- * Copyright (C) 1998 David A. Schleef <ds@schleef.org>
- */
-
-#ifndef _8255_H
-#define _8255_H
-
-#define I8255_SIZE             0x04
-
-#define I8255_DATA_A_REG       0x00
-#define I8255_DATA_B_REG       0x01
-#define I8255_DATA_C_REG       0x02
-#define I8255_CTRL_REG         0x03
-#define I8255_CTRL_C_LO_IO     BIT(0)
-#define I8255_CTRL_B_IO                BIT(1)
-#define I8255_CTRL_B_MODE      BIT(2)
-#define I8255_CTRL_C_HI_IO     BIT(3)
-#define I8255_CTRL_A_IO                BIT(4)
-#define I8255_CTRL_A_MODE(x)   ((x) << 5)
-#define I8255_CTRL_CW          BIT(7)
-
-struct comedi_device;
-struct comedi_subdevice;
-
-int subdev_8255_init(struct comedi_device *dev, struct comedi_subdevice *s,
-                    int (*io)(struct comedi_device *dev, int dir, int port,
-                              int data, unsigned long regbase),
-                    unsigned long regbase);
-
-int subdev_8255_mm_init(struct comedi_device *dev, struct comedi_subdevice *s,
-                       int (*io)(struct comedi_device *dev, int dir, int port,
-                                 int data, unsigned long regbase),
-                       unsigned long regbase);
-
-unsigned long subdev_8255_regbase(struct comedi_subdevice *s);
-
-#endif
index 5a810f0..0fec048 100644 (file)
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
-
-#include "8255.h"
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8255.h>
 
 enum pci_8255_boardid {
        BOARD_ADLINK_PCI7224,
index 81a246f..8eec6d9 100644 (file)
@@ -63,8 +63,8 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
 
-#include "../comedi_pci.h"
 #include "amcc_s5933.h"
 
 /*
index b04c15d..c94c785 100644 (file)
@@ -14,8 +14,8 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
 
-#include "../comedi_pci.h"
 #include "amcc_s5933.h"
 #include "z8536.h"
 
index 274ec9f..3c48b72 100644 (file)
@@ -14,8 +14,8 @@
  */
 
 #include <linux/module.h>
+#include <linux/comedi/comedi_pci.h>
 
-#include "../comedi_pci.h"
 #include "addi_watchdog.h"
 
 /*
index 06fc7ed..0cd4094 100644 (file)
@@ -68,8 +68,8 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
 
-#include "../comedi_pci.h"
 #include "addi_tcw.h"
 #include "addi_watchdog.h"
 
index c306aa4..ec2c321 100644 (file)
@@ -14,8 +14,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * Register I/O map
index e9a2b37..e048dfc 100644 (file)
@@ -16,8 +16,8 @@
 #include <linux/module.h>
 #include <linux/interrupt.h>
 #include <linux/slab.h>
+#include <linux/comedi/comedi_pci.h>
 
-#include "../comedi_pci.h"
 #include "addi_watchdog.h"
 
 /*
index 4c5aee7..00378c9 100644 (file)
@@ -14,8 +14,8 @@
  */
 
 #include <linux/module.h>
+#include <linux/comedi/comedi_pci.h>
 
-#include "../comedi_pci.h"
 #include "addi_watchdog.h"
 
 /*
index 1ed3b33..28a242e 100644 (file)
@@ -14,8 +14,8 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
 
-#include "../comedi_pci.h"
 #include "amcc_s5933.h"
 
 /*
index f0c9642..ecb5552 100644 (file)
@@ -41,8 +41,8 @@
  */
 
 #include <linux/module.h>
+#include <linux/comedi/comedi_pci.h>
 
-#include "../comedi_pci.h"
 #include "amcc_s5933.h"
 
 /*
index a90d593..bc72273 100644 (file)
@@ -15,8 +15,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #define CONV_UNIT_NS           BIT(0)
 #define CONV_UNIT_US           BIT(1)
index 69b323f..ed87ab4 100644 (file)
@@ -10,7 +10,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 #include "addi_tcw.h"
 #include "addi_watchdog.h"
 
index 9ae4cc5..b27354a 100644 (file)
@@ -24,8 +24,7 @@
 
 #include <linux/module.h>
 #include <linux/delay.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * PCI-6208/6216-GL register map
index 8fc4563..e9f22de 100644 (file)
@@ -46,8 +46,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "plx9052.h"
 
index d5e1bda..0c513a6 100644 (file)
@@ -19,8 +19,7 @@
 
 #include <linux/kernel.h>
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #define PCI8164_AXIS(x)                ((x) * 0x08)
 #define PCI8164_CMD_MSTS_REG   0x00
index a062c5a..c50f942 100644 (file)
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8254.h>
 
 #include "plx9052.h"
-#include "comedi_8254.h"
 
 #define PCI9111_FIFO_HALF_SIZE 512
 
index cda3a42..9a816c7 100644 (file)
 #include <linux/gfp.h>
 #include <linux/interrupt.h>
 #include <linux/io.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8254.h>
 
 #include "amcc_s5933.h"
-#include "comedi_8254.h"
 
 /*
  * PCI BAR2 Register map (dev->iobase)
index d719f76..19d7651 100644 (file)
@@ -48,8 +48,7 @@
 
 #include <linux/module.h>
 #include <linux/delay.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /* address scheme (page 2.17 of the manual) */
 #define ADQ12B_CTREG           0x00
index 0906077..4f26399 100644 (file)
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8254.h>
 
-#include "../comedi_pci.h"
-
-#include "comedi_8254.h"
 #include "amcc_s5933.h"
 
 /*
index 2fcd7e8..2619591 100644 (file)
@@ -42,8 +42,7 @@
 
 #include <linux/module.h>
 #include <linux/delay.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * PCI BAR2 Register map (dev->iobase)
index 23660a9..e2aedb1 100644 (file)
@@ -32,8 +32,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * PCI Bar 2 I/O Register map (dev->iobase)
index e8ab573..bb43b7d 100644 (file)
@@ -38,8 +38,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * PCI bar 2 Register I/O map (dev->iobase)
index 6de8ab9..fcfc2e2 100644 (file)
@@ -22,8 +22,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * PCI-1760 Register Map
index 54c7419..efa3e46 100644 (file)
 
 #include <linux/module.h>
 #include <linux/delay.h>
-
-#include "../comedi_pci.h"
-
-#include "8255.h"
-#include "comedi_8254.h"
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8255.h>
+#include <linux/comedi/comedi_8254.h>
 
 /*
  * Register offset definitions
index 4829115..30b8a32 100644 (file)
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
-
-#include "comedi_8254.h"
-#include "8255.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
+#include <linux/comedi/comedi_8254.h>
 
 /*
  * Register map
index fe38762..b00fab0 100644 (file)
@@ -30,8 +30,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 #define AIO_IIRO_16_RELAY_0_7          0x00
 #define AIO_IIRO_16_INPUT_0_7          0x01
index fa19c9e..4544bcd 100644 (file)
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 #include "amplc_dio200.h"
 
index a345413..ff651f2 100644 (file)
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>  /* only for register defines */
+#include <linux/comedi/comedi_8254.h>
 
 #include "amplc_dio200.h"
-#include "comedi_8254.h"
-#include "8255.h"              /* only for register defines */
 
 /* 200 series registers */
 #define DIO200_IO_SIZE         0x20
index 1bd7a42..527994d 100644 (file)
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "amplc_dio200.h"
 
index c377af1..b21e0c9 100644 (file)
@@ -32,8 +32,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 #include "amplc_pc236.h"
 
index 981d281..9f4f89b 100644 (file)
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
 
 #include "amplc_pc236.h"
-#include "8255.h"
 
 static void pc236_intr_update(struct comedi_device *dev, bool enable)
 {
index 68da609..d7f088a 100644 (file)
@@ -25,7 +25,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /* PC263 registers */
 #define PC263_DO_0_7_REG       0x00
index bcf6d61..5a04e55 100644 (file)
 #include <linux/module.h>
 #include <linux/interrupt.h>
 #include <linux/slab.h>
-
-#include "../comedi_pci.h"
-
-#include "comedi_8254.h"
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8254.h>
 
 /*
  * PCI224/234 i/o space 1 (PCIBAR2) registers.
index 8911dc2..92ba8b8 100644 (file)
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
-
-#include "comedi_8254.h"
-#include "8255.h"
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8255.h>
+#include <linux/comedi/comedi_8254.h>
 
 /*
  * PCI230 PCI configuration register information
index e7f6fa4..482eb26 100644 (file)
@@ -34,8 +34,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "amplc_pc236.h"
 #include "plx9052.h"
index 9217973..1609665 100644 (file)
@@ -24,8 +24,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /* PCI263 registers */
 #define PCI263_DO_0_7_REG      0x00
index 786fd15..14b90d1 100644 (file)
@@ -30,8 +30,7 @@
 #include <linux/timer.h>
 #include <linux/io.h>
 #include <linux/pnp.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register I/O map
index a5d171e..8e0d2fa 100644 (file)
 #include <linux/module.h>
 #include <linux/interrupt.h>
 #include <linux/delay.h>
-
-#include "../comedi_pcmcia.h"
-
-#include "comedi_8254.h"
+#include <linux/comedi/comedi_pcmcia.h>
+#include <linux/comedi/comedi_8254.h>
 
 /*
  * Register I/O map
index 2f20bd5..0c7576b 100644 (file)
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8255.h>
+#include <linux/comedi/comedi_8254.h>
 
-#include "../comedi_pci.h"
-
-#include "comedi_8254.h"
-#include "8255.h"
 #include "amcc_s5933.h"
 
 #define AI_BUFFER_SIZE         1024    /* max ai fifo size */
index 41a8fea..ca6038a 100644 (file)
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8255.h>
 
-#include "../comedi_pci.h"
-
-#include "8255.h"
 #include "plx9080.h"
 
 #define TIMER_BASE 25          /*  40MHz master clock */
index 78cf160..c52204a 100644 (file)
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
-
-#include "8255.h"
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8255.h>
 
 #define EEPROM_SIZE    128     /*  number of entries in eeprom */
 /* maximum number of ao channels for supported boards */
index 2292f69..8bdb007 100644 (file)
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8255.h>
+#include <linux/comedi/comedi_8254.h>
 
-#include "../comedi_pci.h"
-
-#include "comedi_8254.h"
 #include "plx9052.h"
-#include "8255.h"
 
 /*
  * PCI Bar 1 Register map
index 21fc7b3..bf8093a 100644 (file)
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
-
-#include "8255.h"
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8255.h>
 
 /* device ids of the cards we support -- currently only 1 card supported */
 #define PCI_ID_PCIM_DDA06_16           0x0053
index 4bf5daa..b4185c1 100644 (file)
 #include <linux/module.h>
 #include <linux/slab.h>
 #include <linux/io.h>
-
-#include "../comedidev.h"
-
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8254.h>
 
 static unsigned int __i8254_read(struct comedi_8254 *i8254, unsigned int reg)
 {
diff --git a/drivers/comedi/drivers/comedi_8254.h b/drivers/comedi/drivers/comedi_8254.h
deleted file mode 100644 (file)
index d826441..0000000
+++ /dev/null
@@ -1,134 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0+ */
-/*
- * comedi_8254.h
- * Generic 8254 timer/counter support
- * Copyright (C) 2014 H Hartley Sweeten <hsweeten@visionengravers.com>
- *
- * COMEDI - Linux Control and Measurement Device Interface
- * Copyright (C) 2000 David A. Schleef <ds@schleef.org>
- */
-
-#ifndef _COMEDI_8254_H
-#define _COMEDI_8254_H
-
-#include <linux/types.h>
-
-struct comedi_device;
-struct comedi_insn;
-struct comedi_subdevice;
-
-/*
- * Common oscillator base values in nanoseconds
- */
-#define I8254_OSC_BASE_10MHZ   100
-#define I8254_OSC_BASE_5MHZ    200
-#define I8254_OSC_BASE_4MHZ    250
-#define I8254_OSC_BASE_2MHZ    500
-#define I8254_OSC_BASE_1MHZ    1000
-#define I8254_OSC_BASE_100KHZ  10000
-#define I8254_OSC_BASE_10KHZ   100000
-#define I8254_OSC_BASE_1KHZ    1000000
-
-/*
- * I/O access size used to read/write registers
- */
-#define I8254_IO8              1
-#define I8254_IO16             2
-#define I8254_IO32             4
-
-/*
- * Register map for generic 8254 timer (I8254_IO8 with 0 regshift)
- */
-#define I8254_COUNTER0_REG             0x00
-#define I8254_COUNTER1_REG             0x01
-#define I8254_COUNTER2_REG             0x02
-#define I8254_CTRL_REG                 0x03
-#define I8254_CTRL_SEL_CTR(x)          ((x) << 6)
-#define I8254_CTRL_READBACK(x)         (I8254_CTRL_SEL_CTR(3) | BIT(x))
-#define I8254_CTRL_READBACK_COUNT      I8254_CTRL_READBACK(4)
-#define I8254_CTRL_READBACK_STATUS     I8254_CTRL_READBACK(5)
-#define I8254_CTRL_READBACK_SEL_CTR(x) (2 << (x))
-#define I8254_CTRL_RW(x)               (((x) & 0x3) << 4)
-#define I8254_CTRL_LATCH               I8254_CTRL_RW(0)
-#define I8254_CTRL_LSB_ONLY            I8254_CTRL_RW(1)
-#define I8254_CTRL_MSB_ONLY            I8254_CTRL_RW(2)
-#define I8254_CTRL_LSB_MSB             I8254_CTRL_RW(3)
-
-/* counter maps zero to 0x10000 */
-#define I8254_MAX_COUNT                        0x10000
-
-/**
- * struct comedi_8254 - private data used by this module
- * @iobase:            PIO base address of the registers (in/out)
- * @mmio:              MMIO base address of the registers (read/write)
- * @iosize:            I/O size used to access the registers (b/w/l)
- * @regshift:          register gap shift
- * @osc_base:          cascaded oscillator speed in ns
- * @divisor:           divisor for single counter
- * @divisor1:          divisor loaded into first cascaded counter
- * @divisor2:          divisor loaded into second cascaded counter
- * #next_div:          next divisor for single counter
- * @next_div1:         next divisor to use for first cascaded counter
- * @next_div2:         next divisor to use for second cascaded counter
- * @clock_src;         current clock source for each counter (driver specific)
- * @gate_src;          current gate source  for each counter (driver specific)
- * @busy:              flags used to indicate that a counter is "busy"
- * @insn_config:       driver specific (*insn_config) callback
- */
-struct comedi_8254 {
-       unsigned long iobase;
-       void __iomem *mmio;
-       unsigned int iosize;
-       unsigned int regshift;
-       unsigned int osc_base;
-       unsigned int divisor;
-       unsigned int divisor1;
-       unsigned int divisor2;
-       unsigned int next_div;
-       unsigned int next_div1;
-       unsigned int next_div2;
-       unsigned int clock_src[3];
-       unsigned int gate_src[3];
-       bool busy[3];
-
-       int (*insn_config)(struct comedi_device *dev,
-                          struct comedi_subdevice *s,
-                          struct comedi_insn *insn, unsigned int *data);
-};
-
-unsigned int comedi_8254_status(struct comedi_8254 *i8254,
-                               unsigned int counter);
-unsigned int comedi_8254_read(struct comedi_8254 *i8254, unsigned int counter);
-void comedi_8254_write(struct comedi_8254 *i8254,
-                      unsigned int counter, unsigned int val);
-
-int comedi_8254_set_mode(struct comedi_8254 *i8254,
-                        unsigned int counter, unsigned int mode);
-int comedi_8254_load(struct comedi_8254 *i8254,
-                    unsigned int counter, unsigned int val, unsigned int mode);
-
-void comedi_8254_pacer_enable(struct comedi_8254 *i8254,
-                             unsigned int counter1, unsigned int counter2,
-                             bool enable);
-void comedi_8254_update_divisors(struct comedi_8254 *i8254);
-void comedi_8254_cascade_ns_to_timer(struct comedi_8254 *i8254,
-                                    unsigned int *nanosec, unsigned int flags);
-void comedi_8254_ns_to_timer(struct comedi_8254 *i8254,
-                            unsigned int *nanosec, unsigned int flags);
-
-void comedi_8254_set_busy(struct comedi_8254 *i8254,
-                         unsigned int counter, bool busy);
-
-void comedi_8254_subdevice_init(struct comedi_subdevice *s,
-                               struct comedi_8254 *i8254);
-
-struct comedi_8254 *comedi_8254_init(unsigned long iobase,
-                                    unsigned int osc_base,
-                                    unsigned int iosize,
-                                    unsigned int regshift);
-struct comedi_8254 *comedi_8254_mm_init(void __iomem *mmio,
-                                       unsigned int osc_base,
-                                       unsigned int iosize,
-                                       unsigned int regshift);
-
-#endif /* _COMEDI_8254_H */
index b7ca465..5562b9c 100644 (file)
@@ -29,9 +29,8 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
-
-#include "8255.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
 
 struct subdev_8255_private {
        unsigned long regbase;
index 4392b59..78c39fa 100644 (file)
@@ -40,9 +40,9 @@
 #include <linux/module.h>
 #include <linux/string.h>
 #include <linux/slab.h>
-#include "../comedi.h"
-#include "../comedilib.h"
-#include "../comedidev.h"
+#include <linux/comedi.h>
+#include <linux/comedi/comedilib.h>
+#include <linux/comedi/comedidev.h>
 
 struct bonded_device {
        struct comedi_device *dev;
index 479b58e..7009824 100644 (file)
@@ -9,10 +9,8 @@
 #include <linux/delay.h>
 #include <linux/dma-mapping.h>
 #include <asm/dma.h>
-
-#include "../comedidev.h"
-
-#include "comedi_isadma.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_isadma.h>
 
 /**
  * comedi_isadma_program - program and enable an ISA DMA transfer
diff --git a/drivers/comedi/drivers/comedi_isadma.h b/drivers/comedi/drivers/comedi_isadma.h
deleted file mode 100644 (file)
index 9d2b12d..0000000
+++ /dev/null
@@ -1,114 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0+ */
-/*
- * COMEDI ISA DMA support functions
- * Copyright (c) 2014 H Hartley Sweeten <hsweeten@visionengravers.com>
- */
-
-#ifndef _COMEDI_ISADMA_H
-#define _COMEDI_ISADMA_H
-
-#include <linux/types.h>
-
-struct comedi_device;
-struct device;
-
-/*
- * These are used to avoid issues when <asm/dma.h> and the DMA_MODE_
- * defines are not available.
- */
-#define COMEDI_ISADMA_READ     0
-#define COMEDI_ISADMA_WRITE    1
-
-/**
- * struct comedi_isadma_desc - cookie for ISA DMA
- * @virt_addr: virtual address of buffer
- * @hw_addr:   hardware (bus) address of buffer
- * @chan:      DMA channel
- * @maxsize:   allocated size of buffer (in bytes)
- * @size:      transfer size (in bytes)
- * @mode:      DMA_MODE_READ or DMA_MODE_WRITE
- */
-struct comedi_isadma_desc {
-       void *virt_addr;
-       dma_addr_t hw_addr;
-       unsigned int chan;
-       unsigned int maxsize;
-       unsigned int size;
-       char mode;
-};
-
-/**
- * struct comedi_isadma - ISA DMA data
- * @dev:       device to allocate non-coherent memory for
- * @desc:      cookie for each DMA buffer
- * @n_desc:    the number of cookies
- * @cur_dma:   the current cookie in use
- * @chan:      the first DMA channel requested
- * @chan2:     the second DMA channel requested
- */
-struct comedi_isadma {
-       struct device *dev;
-       struct comedi_isadma_desc *desc;
-       int n_desc;
-       int cur_dma;
-       unsigned int chan;
-       unsigned int chan2;
-};
-
-#if IS_ENABLED(CONFIG_ISA_DMA_API)
-
-void comedi_isadma_program(struct comedi_isadma_desc *desc);
-unsigned int comedi_isadma_disable(unsigned int dma_chan);
-unsigned int comedi_isadma_disable_on_sample(unsigned int dma_chan,
-                                            unsigned int size);
-unsigned int comedi_isadma_poll(struct comedi_isadma *dma);
-void comedi_isadma_set_mode(struct comedi_isadma_desc *desc, char dma_dir);
-
-struct comedi_isadma *comedi_isadma_alloc(struct comedi_device *dev,
-                                         int n_desc, unsigned int dma_chan1,
-                                         unsigned int dma_chan2,
-                                         unsigned int maxsize, char dma_dir);
-void comedi_isadma_free(struct comedi_isadma *dma);
-
-#else  /* !IS_ENABLED(CONFIG_ISA_DMA_API) */
-
-static inline void comedi_isadma_program(struct comedi_isadma_desc *desc)
-{
-}
-
-static inline unsigned int comedi_isadma_disable(unsigned int dma_chan)
-{
-       return 0;
-}
-
-static inline unsigned int
-comedi_isadma_disable_on_sample(unsigned int dma_chan, unsigned int size)
-{
-       return 0;
-}
-
-static inline unsigned int comedi_isadma_poll(struct comedi_isadma *dma)
-{
-       return 0;
-}
-
-static inline void comedi_isadma_set_mode(struct comedi_isadma_desc *desc,
-                                         char dma_dir)
-{
-}
-
-static inline struct comedi_isadma *
-comedi_isadma_alloc(struct comedi_device *dev, int n_desc,
-                   unsigned int dma_chan1, unsigned int dma_chan2,
-                   unsigned int maxsize, char dma_dir)
-{
-       return NULL;
-}
-
-static inline void comedi_isadma_free(struct comedi_isadma *dma)
-{
-}
-
-#endif /* !IS_ENABLED(CONFIG_ISA_DMA_API) */
-
-#endif /* #ifndef _COMEDI_ISADMA_H */
index 5338b5e..098738a 100644 (file)
@@ -57,8 +57,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register map
index cbc225e..0b5c0af 100644 (file)
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
-
+#include <linux/comedi/comedidev.h>
 #include <asm/div64.h>
-
 #include <linux/timer.h>
 #include <linux/ktime.h>
 #include <linux/jiffies.h>
index b8fdd9c..41d42ff 100644 (file)
@@ -18,8 +18,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * Register map
index 5ef8114..4b011d6 100644 (file)
@@ -25,8 +25,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * The output range is selected by jumpering pins on the I/O connector.
index f64e747..c0a4e1b 100644 (file)
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8255.h>
 
-#include "../comedi_pci.h"
-
-#include "8255.h"
 #include "plx9080.h"
 
 #define DB2K_FIRMWARE          "daqboard2000_firmware.bin"
index b50743c..f8ab3af 100644 (file)
  */
 
 #include <linux/module.h>
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
+#include <linux/comedi/comedi_8254.h>
 
-#include "../comedidev.h"
-
-#include "8255.h"
-#include "comedi_8254.h"
 #include "das08.h"
 
 /*
index 223479f..6075efc 100644 (file)
@@ -30,8 +30,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pcmcia.h"
+#include <linux/comedi/comedi_pcmcia.h>
 
 #include "das08.h"
 
index 8c4cfa8..3d43b77 100644 (file)
@@ -29,7 +29,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 #include "das08.h"
 
index 1cd9033..982f3ab 100644 (file)
@@ -23,8 +23,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "das08.h"
 
index 4ac2622..937a69c 100644 (file)
 #include <linux/module.h>
 #include <linux/slab.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
-
-#include "comedi_isadma.h"
-#include "comedi_8254.h"
-#include "8255.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
+#include <linux/comedi/comedi_8254.h>
+#include <linux/comedi/comedi_isadma.h>
 
 #define DAS16_DMA_SIZE 0xff00  /*  size in bytes of allocated dma buffer */
 
index 75f3dbb..275effb 100644 (file)
 #include <linux/module.h>
 #include <linux/slab.h>
 #include <linux/interrupt.h>
-#include "../comedidev.h"
-
-#include "8255.h"
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
+#include <linux/comedi/comedi_8254.h>
 
 /*
  * Register map (dev->iobase)
index f50891a..f09608c 100644 (file)
 #include <linux/interrupt.h>
 #include <linux/slab.h>
 #include <linux/io.h>
-
-#include "../comedidev.h"
-
-#include "comedi_isadma.h"
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8254.h>
+#include <linux/comedi/comedi_isadma.h>
 
 /* misc. defines */
 #define DAS1800_SIZE           16      /* uses 16 io addresses */
index 96f4107..1af3945 100644 (file)
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
-
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8254.h>
 
 /*
  * Register I/O map
index bc08324..4ca33f4 100644 (file)
 #include <linux/module.h>
 #include <linux/interrupt.h>
 #include <linux/delay.h>
-
-#include "../comedidev.h"
-
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8254.h>
 
 #define N_CHAN_AI             8        /*  number of analog input channels */
 
index 56682f0..fe023c7 100644 (file)
@@ -29,9 +29,8 @@
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
-#include "../comedidev.h"
-
-#include "8255.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
 
 /* Board register addresses */
 #define DMM32AT_AI_START_CONV_REG      0x00
index 0d571d8..230d250 100644 (file)
@@ -31,7 +31,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 #include <linux/delay.h>
 
 #define DT2801_TIMEOUT 1000
index 0eb5e6b..dbb9f38 100644 (file)
@@ -40,8 +40,7 @@
 #include <linux/module.h>
 #include <linux/interrupt.h>
 #include <linux/delay.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register I/O map
index ed44ce0..c98a5a4 100644 (file)
@@ -27,8 +27,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-#include "../comedidev.h"
-
+#include <linux/comedi/comedidev.h>
 #include <linux/delay.h>
 
 #define DT2814_CSR 0
index 5906f32..03ba2fd 100644 (file)
@@ -43,8 +43,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
-
+#include <linux/comedi/comedidev.h>
 #include <linux/delay.h>
 
 #define DT2815_DATA 0
index 7c1463e..6738045 100644 (file)
@@ -25,7 +25,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 #define DT2817_CR 0
 #define DT2817_DATA 1
index 2656b4b..4ae80e6 100644 (file)
 #include <linux/gfp.h>
 #include <linux/interrupt.h>
 #include <linux/io.h>
-
-#include "../comedidev.h"
-
-#include "comedi_isadma.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_isadma.h>
 
 /*
  * Register map
index ec27aa4..fc6e9c3 100644 (file)
@@ -43,8 +43,7 @@
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * PCI BAR0 - dual-ported RAM location definitions (dev->mmio)
index 704b04d..b37b9d8 100644 (file)
@@ -34,8 +34,7 @@
 #include <linux/errno.h>
 #include <linux/slab.h>
 #include <linux/uaccess.h>
-
-#include "../comedi_usb.h"
+#include <linux/comedi/comedi_usb.h>
 
 #define DT9812_DIAGS_BOARD_INFO_ADDR   0xFBFF
 #define DT9812_MAX_WRITE_CMD_PIPE_SIZE 32
index c224422..407a038 100644 (file)
@@ -26,8 +26,7 @@
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/mutex.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #define READ_TIMEOUT 50
 
index b715f30..139e801 100644 (file)
@@ -21,8 +21,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
-
+#include <linux/comedi/comedidev.h>
 #include <linux/delay.h>
 
 /*
index e35e4a7..c09d135 100644 (file)
@@ -34,8 +34,7 @@
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "plx9080.h"
 
index 16d2b78..ac4b11d 100644 (file)
@@ -36,8 +36,7 @@
 
 #include <linux/module.h>
 #include <linux/delay.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #define ICP_MULTI_ADC_CSR      0x00    /* R/W: ADC command/status register */
 #define ICP_MULTI_ADC_CSR_ST   BIT(0)  /* Start ADC */
index 399255d..4a19bf8 100644 (file)
@@ -30,7 +30,7 @@
 
 #include <linux/module.h>
 #include <linux/io.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register I/O map
index f963080..951c23f 100644 (file)
@@ -35,8 +35,7 @@
 #include <linux/jiffies.h>
 #include <linux/slab.h>
 #include <linux/timer.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "jr3_pci.h"
 
index bef1b20..b825cf6 100644 (file)
@@ -19,8 +19,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * PCI BAR 0 Register I/O map
index 0d3d4ca..9aea02b 100644 (file)
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8254.h>
 
-#include "../comedi_pci.h"
-
-#include "comedi_8254.h"
 #include "plx9052.h"
 
 #define ME4000_FIRMWARE                "me4000_firmware.bin"
index ef18e38..076b150 100644 (file)
@@ -23,8 +23,7 @@
 #include <linux/module.h>
 #include <linux/interrupt.h>
 #include <linux/sched.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "plx9052.h"
 
index 9da8dd7..14f1d5e 100644 (file)
@@ -18,8 +18,7 @@
 
 #include <linux/module.h>
 #include <linux/delay.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /* Registers present in BAR0 memory region */
 #define MF624_GPIOC_REG                0x54
index 70960e3..88f3cd6 100644 (file)
@@ -38,8 +38,7 @@
 #include <linux/module.h>
 #include <linux/slab.h>
 #include <linux/log2.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "mite.h"
 
index 646f4c0..9e51ff5 100644 (file)
@@ -44,8 +44,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
-
+#include <linux/comedi/comedidev.h>
 #include <linux/delay.h>
 
 /* Offsets of different ports */
index c1897ae..07ff538 100644 (file)
@@ -26,8 +26,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register map
index f1a45cf..ac58200 100644 (file)
@@ -20,8 +20,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * PCI BAR1 - Register memory map
index 7cd8497..58334de 100644 (file)
@@ -49,8 +49,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 /*
  * PCI BAR1 Register Map
index e60d012..0679bc3 100644 (file)
@@ -26,8 +26,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "mite.h"
 #include "ni_tio.h"
index c197e47..c875d25 100644 (file)
@@ -24,8 +24,7 @@
 #include <linux/module.h>
 #include <linux/interrupt.h>
 #include <linux/slab.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #define AO_VALUE_OFFSET                        0x00
 #define        AO_CHAN_OFFSET                  0x0c
index 10ad7b8..df8d219 100644 (file)
 #include <linux/interrupt.h>
 #include <linux/slab.h>
 #include <linux/io.h>
-
-#include "../comedidev.h"
-
-#include "comedi_isadma.h"
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8254.h>
+#include <linux/comedi/comedi_isadma.h>
 
 #define A2150_DMA_BUFFER_SIZE  0xff00  /*  size in bytes of dma buffer */
 
index 2a0fb4d..9f3147b 100644 (file)
  */
 
 #include <linux/module.h>
-
-#include "../comedidev.h"
-
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8254.h>
 
 /*
  * Register map
index 56c78da..8876a1d 100644 (file)
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-#include "../comedidev.h"
-
+#include <linux/comedi/comedidev.h>
 #include <linux/isapnp.h>
+#include <linux/comedi/comedi_8255.h>
 
 #include "ni_stc.h"
-#include "8255.h"
 
 /* AT specific setup */
 static const struct ni_board_struct ni_boards[] = {
index dffce1a..9fa9025 100644 (file)
@@ -39,9 +39,8 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-#include "../comedidev.h"
-
-#include "8255.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
 
 /* Configuration and Status Registers */
 #define COM_REG_1      0x00    /* wo 16 */
index d40fc89..0ef20e9 100644 (file)
@@ -41,8 +41,7 @@
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pcmcia.h"
+#include <linux/comedi/comedi_pcmcia.h>
 
 /* daqcard700 registers */
 #define DIO_W          0x04    /* WO 8bit */
index 44fb65a..4877331 100644 (file)
@@ -23,9 +23,8 @@
  */
 
 #include <linux/module.h>
-#include "../comedi_pcmcia.h"
-
-#include "8255.h"
+#include <linux/comedi/comedi_pcmcia.h>
+#include <linux/comedi/comedi_8255.h>
 
 static int dio24_auto_attach(struct comedi_device *dev,
                             unsigned long context)
index 1f4a07b..b25a8e1 100644 (file)
@@ -48,8 +48,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 #include "ni_labpc.h"
 #include "ni_labpc_isadma.h"
index dd97946..7632496 100644 (file)
 #include <linux/io.h>
 #include <linux/delay.h>
 #include <linux/slab.h>
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
+#include <linux/comedi/comedi_8254.h>
 
-#include "../comedidev.h"
-
-#include "comedi_8254.h"
-#include "8255.h"
 #include "ni_labpc.h"
 #include "ni_labpc_regs.h"
 #include "ni_labpc_isadma.h"
index 4f7e2fe..62fecb5 100644 (file)
@@ -38,8 +38,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pcmcia.h"
+#include <linux/comedi/comedi_pcmcia.h>
 
 #include "ni_labpc.h"
 
index a551aca..0652ca8 100644 (file)
 
 #include <linux/module.h>
 #include <linux/slab.h>
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_isadma.h>
 
-#include "../comedidev.h"
-
-#include "comedi_isadma.h"
 #include "ni_labpc.h"
 #include "ni_labpc_regs.h"
 #include "ni_labpc_isadma.h"
index ec180b0..e2a44bb 100644 (file)
@@ -22,8 +22,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "ni_labpc.h"
 
index 4f80a49..d399985 100644 (file)
@@ -43,7 +43,7 @@
 #include <linux/interrupt.h>
 #include <linux/sched.h>
 #include <linux/delay.h>
-#include "8255.h"
+#include <linux/comedi/comedi_8255.h>
 #include "mite.h"
 
 /* A timeout count */
index 4f37b4e..796f0b7 100644 (file)
 
 #include <linux/module.h>
 #include <linux/delay.h>
+#include <linux/comedi/comedi_pcmcia.h>
+#include <linux/comedi/comedi_8255.h>
 
-#include "../comedi_pcmcia.h"
 #include "ni_stc.h"
-#include "8255.h"
 
 /*
  *  AT specific setup
index 623f8d0..2d58e83 100644 (file)
@@ -42,8 +42,7 @@
 #include <linux/delay.h>
 #include <linux/interrupt.h>
 #include <linux/sched.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "mite.h"
 
index 6c813a4..0b05532 100644 (file)
@@ -94,9 +94,7 @@
 
 #include <linux/module.h>
 #include <linux/delay.h>
-
-#include "../comedi_pci.h"
-
+#include <linux/comedi/comedi_pci.h>
 #include <asm/byteorder.h>
 
 #include "ni_stc.h"
index f0f8cd4..f24eeb4 100644 (file)
@@ -21,8 +21,7 @@
 #include <linux/slab.h>
 #include <linux/bsearch.h>
 #include <linux/sort.h>
-
-#include "../comedi.h"
+#include <linux/comedi.h>
 
 #include "ni_routes.h"
 #include "ni_routing/ni_route_values.h"
index 0369823..cff8a46 100644 (file)
@@ -27,7 +27,7 @@
 #include <linux/bitops.h>
 #endif
 
-#include "../comedi.h"
+#include <linux/comedi.h>
 
 /**
  * struct ni_route_set - Set of destinations with a common source.
index 6e358ef..8088008 100644 (file)
@@ -20,7 +20,7 @@
 #ifndef _COMEDI_DRIVERS_NI_ROUTINT_NI_ROUTE_VALUES_H
 #define _COMEDI_DRIVERS_NI_ROUTINT_NI_ROUTE_VALUES_H
 
-#include "../../comedi.h"
+#include <linux/comedi.h>
 #include <linux/types.h>
 
 /*
index 6e92a06..3121210 100644 (file)
@@ -3,7 +3,7 @@
 #      ni_route_values.h
 #      ni_device_routes.h
 # in order to do this, we are also generating a python representation (using
-# ctypesgen) of ../../comedi.h.
+# ctypesgen) of ../../../../../include/uapi/linux/comedi.h.
 # This allows us to sort NI signal/terminal names numerically to use a binary
 # search through the device_routes tables to find valid routes.
 
@@ -30,13 +30,21 @@ ALL:
 
 everything : csv-files c-files csv-blank
 
-CPPFLAGS=-D"BIT(x)=(1UL<<(x))" -D__user=
+CPPFLAGS = -D__user=
+INC_UAPI = ../../../../../include/uapi
 
-comedi_h.py : ../../../comedi.h
+comedi_h.py: $(INC_UAPI)/linux/comedi.h
        ctypesgen $< --include "sys/ioctl.h" --cpp 'gcc -E $(CPPFLAGS)' -o $@
 
-convert_c_to_py: all_cfiles.c
-       gcc -g convert_c_to_py.c -o convert_c_to_py -std=c99
+convert_c_to_py: all_cfiles.c linux/comedi.h
+       gcc -g -I. convert_c_to_py.c -o convert_c_to_py -std=c99
+
+# Create a local 'linux/comedi.h' for use when compiling 'convert_c_to_py.c'
+# with the '-I.' option.  (Cannot specify '-I../../../../../include/uapi'
+# because that interferes with inclusion of other system headers.)
+linux/comedi.h: $(INC_UAPI)/linux/comedi.h
+       mkdir -p linux
+       ln -snf ../$< $@
 
 ni_values.py: convert_c_to_py
        ./convert_c_to_py
@@ -44,7 +52,7 @@ ni_values.py: convert_c_to_py
 csv-files : ni_values.py comedi_h.py
        ./convert_py_to_csv.py
 
-csv-blank :
+csv-blank : comedi_h.py
        ./make_blank_csv.py
        @echo New blank csv signal table in csv/blank_route_table.csv
 
@@ -62,17 +70,16 @@ clean-partial :
        $(RM) -rf comedi_h.py ni_values.py convert_c_to_py all_cfiles.c *.pyc \
                __pycache__/
 
-clean : partial_clean
-       $(RM) -rf c/ csv/
+clean : clean-partial
+       $(RM) -rf c/ csv/ linux/
 
 # Note:  One could also use ctypeslib in order to generate these files.  The
 # caveat is that ctypeslib does not do a great job at handling macro functions.
 # The make rules are as follows:
-# comedi.h.xml : ../../comedi.h
+# comedi.h.xml : $(INC_UAPI)/linux/comedi.h
 #      # note that we have to use PWD here to avoid h2xml finding a system
 #      # installed version of the comedilib/comedi.h file
-#      h2xml ${PWD}/../../comedi.h -c -D__user="" -D"BIT(x)=(1<<(x))" \
-#              -o comedi.h.xml
+#      h2xml ${PWD}/$(INC_UAPI)/linux/comedi.h -c D__user="" -o comedi.h.xml
 #
 # comedi_h.py : comedi.h.xml
 #      xml2py ./comedi.h.xml -o comedi_h.py
index e7b0571..9ae2221 100644 (file)
@@ -8,7 +8,7 @@
 #ifndef _COMEDI_NI_TIO_H
 #define _COMEDI_NI_TIO_H
 
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 enum ni_gpct_register {
        NITIO_G0_AUTO_INC,
index c42987b..0dd9edf 100644 (file)
@@ -87,8 +87,7 @@
 #include <linux/kernel.h>
 #include <linux/module.h>
 #include <linux/slab.h>
-
-#include "../comedi_usb.h"
+#include <linux/comedi/comedi_usb.h>
 
 #define        NI6501_TIMEOUT  1000
 
index bd6f42f..05172c5 100644 (file)
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
-
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8254.h>
 
 /*
  * I/O port register map
index 1a57992..948a057 100644 (file)
@@ -25,9 +25,8 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
-
-#include "8255.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
 
 struct pcl724_board {
        const char *name;
index 88f25d7..0430630 100644 (file)
@@ -50,8 +50,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 #define PCL726_AO_MSB_REG(x)   (0x00 + ((x) * 2))
 #define PCL726_AO_LSB_REG(x)   (0x01 + ((x) * 2))
index 32a2912..d2733cd 100644 (file)
@@ -25,7 +25,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register map
index b87ab38..70dbc12 100644 (file)
 #include <linux/gfp.h>
 #include <linux/delay.h>
 #include <linux/io.h>
-
-#include "../comedidev.h"
-
-#include "comedi_isadma.h"
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8254.h>
+#include <linux/comedi/comedi_isadma.h>
 
 /*
  * Register I/O map
index c368a33..a5e5320 100644 (file)
 #include <linux/delay.h>
 #include <linux/io.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
-
-#include "comedi_isadma.h"
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8254.h>
+#include <linux/comedi/comedi_isadma.h>
 
 /*
  * Register I/O map
index f4b4a68..29e503d 100644 (file)
 #include <linux/delay.h>
 #include <linux/io.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
-
-#include "comedi_isadma.h"
-#include "comedi_8254.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8254.h>
+#include <linux/comedi/comedi_isadma.h>
 
 /*
  * Register I/O map
index 0cb1ad0..e4103f9 100644 (file)
@@ -24,9 +24,8 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
-
-#include "8255.h"
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedi_8255.h>
 
 /*
  * Register I/O Map
index eec89a0..976eda4 100644 (file)
@@ -29,7 +29,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 #define PCMAD_STATUS           0
 #define PCMAD_LSB              1
index 14ab1f0..611f13b 100644 (file)
@@ -40,7 +40,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /* AI range is not configurable, it's set by jumpers on the board */
 static const struct comedi_lrange pcmda12_ranges = {
index 24a9568..c240223 100644 (file)
@@ -66,8 +66,7 @@
 #include <linux/module.h>
 #include <linux/interrupt.h>
 #include <linux/slab.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register I/O map
index b299d64..33b24db 100644 (file)
@@ -65,8 +65,7 @@
 
 #include <linux/module.h>
 #include <linux/interrupt.h>
-
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register I/O map
index fe4408e..2a76c75 100644 (file)
@@ -41,8 +41,7 @@
  */
 
 #include <linux/module.h>
-
-#include "../comedi_pcmcia.h"
+#include <linux/comedi/comedi_pcmcia.h>
 
 /*
  * Register I/O map
index 2d99a64..7e0ec1a 100644 (file)
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
+#include <linux/comedi/comedi_pci.h>
+#include <linux/comedi/comedi_8254.h>
 
-#include "../comedi_pci.h"
-
-#include "comedi_8254.h"
 #include "plx9080.h"
 
 /*
index 327fd93..1b02e47 100644 (file)
@@ -42,7 +42,7 @@
 #include <linux/module.h>
 #include <linux/delay.h>
 #include <linux/interrupt.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register map
index 195e2b1..d66762a 100644 (file)
@@ -22,7 +22,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register I/O map
index 085cf5b..9245c67 100644 (file)
@@ -27,7 +27,7 @@
  */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /*
  * Register I/O map
index e7aba93..0e5f9a9 100644 (file)
@@ -55,8 +55,7 @@
 #include <linux/interrupt.h>
 #include <linux/kernel.h>
 #include <linux/types.h>
-
-#include "../comedi_pci.h"
+#include <linux/comedi/comedi_pci.h>
 
 #include "s626.h"
 
index 016d315..813bd08 100644 (file)
@@ -19,7 +19,7 @@
 /* include files ----------------------------------------------------------- */
 
 #include <linux/module.h>
-#include "../comedidev.h"
+#include <linux/comedi/comedidev.h>
 
 /* Some global definitions: the registers of the DNP ----------------------- */
 /*                                                                           */
index 0350f30..92d514b 100644 (file)
@@ -73,8 +73,7 @@
 #include <linux/input.h>
 #include <linux/fcntl.h>
 #include <linux/compiler.h>
-
-#include "../comedi_usb.h"
+#include <linux/comedi/comedi_usb.h>
 
 /* constants for firmware upload and download */
 #define USBDUX_FIRMWARE                "usbdux_firmware.bin"
index 4af0129..39faae0 100644 (file)
@@ -40,7 +40,7 @@
 #include <linux/input.h>
 #include <linux/fcntl.h>
 #include <linux/compiler.h>
-#include "../comedi_usb.h"
+#include <linux/comedi/comedi_usb.h>
 
 /*
  * timeout for the USB-transfer
index 54d7605..2aaeaf4 100644 (file)
@@ -40,8 +40,7 @@
 #include <linux/fcntl.h>
 #include <linux/compiler.h>
 #include <asm/unaligned.h>
-
-#include "../comedi_usb.h"
+#include <linux/comedi/comedi_usb.h>
 
 /* timeout for the USB-transfer in ms*/
 #define BULK_TIMEOUT 1000
index 4b00a9e..46023ad 100644 (file)
@@ -35,8 +35,7 @@
 #include <linux/slab.h>
 #include <linux/poll.h>
 #include <linux/uaccess.h>
-
-#include "../comedi_usb.h"
+#include <linux/comedi/comedi_usb.h>
 
 enum {
        DEVICE_VMK8055,
index df9bba1..43fbe1a 100644 (file)
@@ -16,9 +16,9 @@
 #include <linux/mm.h>
 #include <linux/io.h>
 
-#include "../comedi.h"
-#include "../comedilib.h"
-#include "../comedidev.h"
+#include <linux/comedi.h>
+#include <linux/comedi/comedidev.h>
+#include <linux/comedi/comedilib.h>
 
 MODULE_AUTHOR("David Schleef <ds@schleef.org>");
 MODULE_DESCRIPTION("Comedi kernel library");
index 8bc8e42..2e44966 100644 (file)
@@ -13,7 +13,7 @@
  * was cool.
  */
 
-#include "comedidev.h"
+#include <linux/comedi/comedidev.h>
 #include "comedi_internal.h"
 #include <linux/proc_fs.h>
 #include <linux/seq_file.h>
index a4e6fe0..8f43cf8 100644 (file)
@@ -8,7 +8,7 @@
  */
 
 #include <linux/uaccess.h>
-#include "comedidev.h"
+#include <linux/comedi/comedidev.h>
 #include "comedi_internal.h"
 
 const struct comedi_lrange range_bipolar10 = { 1, {BIP_RANGE(10)} };
index 3dd45a7..c2828ee 100644 (file)
@@ -160,7 +160,7 @@ static noinline int do_fw_call_hvc(u64 arg0, u64 arg1, u64 arg2,
  *
  * Return: Returns status, either success or error+reason
  */
-static int zynqmp_pm_feature(u32 api_id)
+int zynqmp_pm_feature(const u32 api_id)
 {
        int ret;
        u32 ret_payload[PAYLOAD_ARG_CNT];
@@ -197,6 +197,7 @@ static int zynqmp_pm_feature(u32 api_id)
 
        return ret;
 }
+EXPORT_SYMBOL_GPL(zynqmp_pm_feature);
 
 /**
  * zynqmp_pm_invoke_fn() - Invoke the system-level platform management layer
@@ -1116,6 +1117,29 @@ int zynqmp_pm_aes_engine(const u64 address, u32 *out)
 }
 EXPORT_SYMBOL_GPL(zynqmp_pm_aes_engine);
 
+/**
+ * zynqmp_pm_register_notifier() - PM API for register a subsystem
+ *                                to be notified about specific
+ *                                event/error.
+ * @node:      Node ID to which the event is related.
+ * @event:     Event Mask of Error events for which wants to get notified.
+ * @wake:      Wake subsystem upon capturing the event if value 1
+ * @enable:    Enable the registration for value 1, disable for value 0
+ *
+ * This function is used to register/un-register for particular node-event
+ * combination in firmware.
+ *
+ * Return: Returns status, either success or error+reason
+ */
+
+int zynqmp_pm_register_notifier(const u32 node, const u32 event,
+                               const u32 wake, const u32 enable)
+{
+       return zynqmp_pm_invoke_fn(PM_REGISTER_NOTIFIER, node, event,
+                                  wake, enable, NULL);
+}
+EXPORT_SYMBOL_GPL(zynqmp_pm_register_notifier);
+
 /**
  * zynqmp_pm_system_shutdown - PM call to request a system shutdown or restart
  * @type:      Shutdown or restart? 0 for shutdown, 1 for restart
index acabb77..73258b2 100644 (file)
@@ -831,7 +831,7 @@ static ssize_t value_show(struct device *dev, struct device_attribute *attr,
        int err;
 
        if (sysfs_streq(name, "arb_address"))
-               return snprintf(buf, PAGE_SIZE, "%04x\n", dci_obj->reg_addr);
+               return sysfs_emit(buf, "%04x\n", dci_obj->reg_addr);
 
        if (sysfs_streq(name, "arb_value"))
                reg_addr = dci_obj->reg_addr;
@@ -843,7 +843,7 @@ static ssize_t value_show(struct device *dev, struct device_attribute *attr,
        if (err < 0)
                return err;
 
-       return snprintf(buf, PAGE_SIZE, "%04x\n", val);
+       return sysfs_emit(buf, "%04x\n", val);
 }
 
 static ssize_t value_store(struct device *dev, struct device_attribute *attr,
index c556623..76478fe 100644 (file)
@@ -46,12 +46,6 @@ static const char *const suspend_modes[] = {
 
 static enum pm_suspend_mode suspend_mode = PM_SUSPEND_MODE_STD;
 
-enum pm_api_cb_id {
-       PM_INIT_SUSPEND_CB = 30,
-       PM_ACKNOWLEDGE_CB,
-       PM_NOTIFY_CB,
-};
-
 static void zynqmp_pm_get_callback_data(u32 *buf)
 {
        zynqmp_pm_invoke_fn(GET_CALLBACK_DATA, 0, 0, 0, 0, buf);
index f53740b..2d3d981 100644 (file)
@@ -14,3 +14,12 @@ config NITRO_ENCLAVES
 
          To compile this driver as a module, choose M here.
          The module will be called nitro_enclaves.
+
+config NITRO_ENCLAVES_MISC_DEV_TEST
+       bool "Tests for the misc device functionality of the Nitro Enclaves"
+       depends on NITRO_ENCLAVES && KUNIT=y
+       help
+         Enable KUnit tests for the misc device functionality of the Nitro
+         Enclaves. Select this option only if you will boot the kernel for
+         the purpose of running unit tests (e.g. under UML or qemu). If
+         unsure, say N.
index 8939612..51ba4ca 100644 (file)
@@ -24,6 +24,7 @@
 #include <linux/nitro_enclaves.h>
 #include <linux/pci.h>
 #include <linux/poll.h>
+#include <linux/range.h>
 #include <linux/slab.h>
 #include <linux/types.h>
 #include <uapi/linux/vm_sockets.h>
@@ -125,6 +126,16 @@ struct ne_cpu_pool {
 
 static struct ne_cpu_pool ne_cpu_pool;
 
+/**
+ * struct ne_phys_contig_mem_regions - Contiguous physical memory regions.
+ * @num:       The number of regions that currently has.
+ * @regions:   The array of physical memory regions.
+ */
+struct ne_phys_contig_mem_regions {
+       unsigned long num;
+       struct range  *regions;
+};
+
 /**
  * ne_check_enclaves_created() - Verify if at least one enclave has been created.
  * @void:      No parameters provided.
@@ -824,6 +835,72 @@ static int ne_sanity_check_user_mem_region_page(struct ne_enclave *ne_enclave,
        return 0;
 }
 
+/**
+ * ne_sanity_check_phys_mem_region() - Sanity check the start address and the size
+ *                                     of a physical memory region.
+ * @phys_mem_region_paddr : Physical start address of the region to be sanity checked.
+ * @phys_mem_region_size  : Length of the region to be sanity checked.
+ *
+ * Context: Process context. This function is called with the ne_enclave mutex held.
+ * Return:
+ * * 0 on success.
+ * * Negative return value on failure.
+ */
+static int ne_sanity_check_phys_mem_region(u64 phys_mem_region_paddr,
+                                          u64 phys_mem_region_size)
+{
+       if (phys_mem_region_size & (NE_MIN_MEM_REGION_SIZE - 1)) {
+               dev_err_ratelimited(ne_misc_dev.this_device,
+                                   "Physical mem region size is not multiple of 2 MiB\n");
+
+               return -EINVAL;
+       }
+
+       if (!IS_ALIGNED(phys_mem_region_paddr, NE_MIN_MEM_REGION_SIZE)) {
+               dev_err_ratelimited(ne_misc_dev.this_device,
+                                   "Physical mem region address is not 2 MiB aligned\n");
+
+               return -EINVAL;
+       }
+
+       return 0;
+}
+
+/**
+ * ne_merge_phys_contig_memory_regions() - Add a memory region and merge the adjacent
+ *                                         regions if they are physically contiguous.
+ * @phys_contig_regions : Private data associated with the contiguous physical memory regions.
+ * @page_paddr :          Physical start address of the region to be added.
+ * @page_size :           Length of the region to be added.
+ *
+ * Context: Process context. This function is called with the ne_enclave mutex held.
+ * Return:
+ * * 0 on success.
+ * * Negative return value on failure.
+ */
+static int
+ne_merge_phys_contig_memory_regions(struct ne_phys_contig_mem_regions *phys_contig_regions,
+                                   u64 page_paddr, u64 page_size)
+{
+       unsigned long num = phys_contig_regions->num;
+       int rc = 0;
+
+       rc = ne_sanity_check_phys_mem_region(page_paddr, page_size);
+       if (rc < 0)
+               return rc;
+
+       /* Physically contiguous, just merge */
+       if (num && (phys_contig_regions->regions[num - 1].end + 1) == page_paddr) {
+               phys_contig_regions->regions[num - 1].end += page_size;
+       } else {
+               phys_contig_regions->regions[num].start = page_paddr;
+               phys_contig_regions->regions[num].end = page_paddr + page_size - 1;
+               phys_contig_regions->num++;
+       }
+
+       return 0;
+}
+
 /**
  * ne_set_user_memory_region_ioctl() - Add user space memory region to the slot
  *                                    associated with the current enclave.
@@ -843,9 +920,8 @@ static int ne_set_user_memory_region_ioctl(struct ne_enclave *ne_enclave,
        unsigned long max_nr_pages = 0;
        unsigned long memory_size = 0;
        struct ne_mem_region *ne_mem_region = NULL;
-       unsigned long nr_phys_contig_mem_regions = 0;
        struct pci_dev *pdev = ne_devs.ne_pci_dev->pdev;
-       struct page **phys_contig_mem_regions = NULL;
+       struct ne_phys_contig_mem_regions phys_contig_mem_regions = {};
        int rc = -EINVAL;
 
        rc = ne_sanity_check_user_mem_region(ne_enclave, mem_region);
@@ -866,9 +942,10 @@ static int ne_set_user_memory_region_ioctl(struct ne_enclave *ne_enclave,
                goto free_mem_region;
        }
 
-       phys_contig_mem_regions = kcalloc(max_nr_pages, sizeof(*phys_contig_mem_regions),
-                                         GFP_KERNEL);
-       if (!phys_contig_mem_regions) {
+       phys_contig_mem_regions.regions = kcalloc(max_nr_pages,
+                                                 sizeof(*phys_contig_mem_regions.regions),
+                                                 GFP_KERNEL);
+       if (!phys_contig_mem_regions.regions) {
                rc = -ENOMEM;
 
                goto free_mem_region;
@@ -901,26 +978,18 @@ static int ne_set_user_memory_region_ioctl(struct ne_enclave *ne_enclave,
                if (rc < 0)
                        goto put_pages;
 
-               /*
-                * TODO: Update once handled non-contiguous memory regions
-                * received from user space or contiguous physical memory regions
-                * larger than 2 MiB e.g. 8 MiB.
-                */
-               phys_contig_mem_regions[i] = ne_mem_region->pages[i];
+               rc = ne_merge_phys_contig_memory_regions(&phys_contig_mem_regions,
+                                                        page_to_phys(ne_mem_region->pages[i]),
+                                                        page_size(ne_mem_region->pages[i]));
+               if (rc < 0)
+                       goto put_pages;
 
                memory_size += page_size(ne_mem_region->pages[i]);
 
                ne_mem_region->nr_pages++;
        } while (memory_size < mem_region.memory_size);
 
-       /*
-        * TODO: Update once handled non-contiguous memory regions received
-        * from user space or contiguous physical memory regions larger than
-        * 2 MiB e.g. 8 MiB.
-        */
-       nr_phys_contig_mem_regions = ne_mem_region->nr_pages;
-
-       if ((ne_enclave->nr_mem_regions + nr_phys_contig_mem_regions) >
+       if ((ne_enclave->nr_mem_regions + phys_contig_mem_regions.num) >
            ne_enclave->max_mem_regions) {
                dev_err_ratelimited(ne_misc_dev.this_device,
                                    "Reached max memory regions %lld\n",
@@ -931,27 +1000,13 @@ static int ne_set_user_memory_region_ioctl(struct ne_enclave *ne_enclave,
                goto put_pages;
        }
 
-       for (i = 0; i < nr_phys_contig_mem_regions; i++) {
-               u64 phys_region_addr = page_to_phys(phys_contig_mem_regions[i]);
-               u64 phys_region_size = page_size(phys_contig_mem_regions[i]);
-
-               if (phys_region_size & (NE_MIN_MEM_REGION_SIZE - 1)) {
-                       dev_err_ratelimited(ne_misc_dev.this_device,
-                                           "Physical mem region size is not multiple of 2 MiB\n");
-
-                       rc = -EINVAL;
-
-                       goto put_pages;
-               }
-
-               if (!IS_ALIGNED(phys_region_addr, NE_MIN_MEM_REGION_SIZE)) {
-                       dev_err_ratelimited(ne_misc_dev.this_device,
-                                           "Physical mem region address is not 2 MiB aligned\n");
-
-                       rc = -EINVAL;
+       for (i = 0; i < phys_contig_mem_regions.num; i++) {
+               u64 phys_region_addr = phys_contig_mem_regions.regions[i].start;
+               u64 phys_region_size = range_len(&phys_contig_mem_regions.regions[i]);
 
+               rc = ne_sanity_check_phys_mem_region(phys_region_addr, phys_region_size);
+               if (rc < 0)
                        goto put_pages;
-               }
        }
 
        ne_mem_region->memory_size = mem_region.memory_size;
@@ -959,13 +1014,13 @@ static int ne_set_user_memory_region_ioctl(struct ne_enclave *ne_enclave,
 
        list_add(&ne_mem_region->mem_region_list_entry, &ne_enclave->mem_regions_list);
 
-       for (i = 0; i < nr_phys_contig_mem_regions; i++) {
+       for (i = 0; i < phys_contig_mem_regions.num; i++) {
                struct ne_pci_dev_cmd_reply cmd_reply = {};
                struct slot_add_mem_req slot_add_mem_req = {};
 
                slot_add_mem_req.slot_uid = ne_enclave->slot_uid;
-               slot_add_mem_req.paddr = page_to_phys(phys_contig_mem_regions[i]);
-               slot_add_mem_req.size = page_size(phys_contig_mem_regions[i]);
+               slot_add_mem_req.paddr = phys_contig_mem_regions.regions[i].start;
+               slot_add_mem_req.size = range_len(&phys_contig_mem_regions.regions[i]);
 
                rc = ne_do_request(pdev, SLOT_ADD_MEM,
                                   &slot_add_mem_req, sizeof(slot_add_mem_req),
@@ -974,7 +1029,7 @@ static int ne_set_user_memory_region_ioctl(struct ne_enclave *ne_enclave,
                        dev_err_ratelimited(ne_misc_dev.this_device,
                                            "Error in slot add mem [rc=%d]\n", rc);
 
-                       kfree(phys_contig_mem_regions);
+                       kfree(phys_contig_mem_regions.regions);
 
                        /*
                         * Exit here without put pages as memory regions may
@@ -987,7 +1042,7 @@ static int ne_set_user_memory_region_ioctl(struct ne_enclave *ne_enclave,
                ne_enclave->nr_mem_regions++;
        }
 
-       kfree(phys_contig_mem_regions);
+       kfree(phys_contig_mem_regions.regions);
 
        return 0;
 
@@ -995,7 +1050,7 @@ put_pages:
        for (i = 0; i < ne_mem_region->nr_pages; i++)
                put_page(ne_mem_region->pages[i]);
 free_mem_region:
-       kfree(phys_contig_mem_regions);
+       kfree(phys_contig_mem_regions.regions);
        kfree(ne_mem_region->pages);
        kfree(ne_mem_region);
 
@@ -1701,8 +1756,37 @@ static long ne_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
        return 0;
 }
 
+#if defined(CONFIG_NITRO_ENCLAVES_MISC_DEV_TEST)
+#include "ne_misc_dev_test.c"
+
+static inline int ne_misc_dev_test_init(void)
+{
+       return __kunit_test_suites_init(ne_misc_dev_test_suites);
+}
+
+static inline void ne_misc_dev_test_exit(void)
+{
+       __kunit_test_suites_exit(ne_misc_dev_test_suites);
+}
+#else
+static inline int ne_misc_dev_test_init(void)
+{
+       return 0;
+}
+
+static inline void ne_misc_dev_test_exit(void)
+{
+}
+#endif
+
 static int __init ne_init(void)
 {
+       int rc = 0;
+
+       rc = ne_misc_dev_test_init();
+       if (rc < 0)
+               return rc;
+
        mutex_init(&ne_cpu_pool.mutex);
 
        return pci_register_driver(&ne_pci_driver);
@@ -1713,6 +1797,8 @@ static void __exit ne_exit(void)
        pci_unregister_driver(&ne_pci_driver);
 
        ne_teardown_cpu_pool();
+
+       ne_misc_dev_test_exit();
 }
 
 module_init(ne_init);
diff --git a/drivers/virt/nitro_enclaves/ne_misc_dev_test.c b/drivers/virt/nitro_enclaves/ne_misc_dev_test.c
new file mode 100644 (file)
index 0000000..265797b
--- /dev/null
@@ -0,0 +1,157 @@
+// SPDX-License-Identifier: GPL-2.0
+
+#include <kunit/test.h>
+
+#define MAX_PHYS_REGIONS       16
+#define INVALID_VALUE          (~0ull)
+
+struct ne_phys_regions_test {
+       u64           paddr;
+       u64           size;
+       int           expect_rc;
+       unsigned long expect_num;
+       u64           expect_last_paddr;
+       u64           expect_last_size;
+} phys_regions_test_cases[] = {
+       /*
+        * Add the region from 0x1000 to (0x1000 + 0x200000 - 1):
+        *   Expected result:
+        *       Failed, start address is not 2M-aligned
+        *
+        * Now the instance of struct ne_phys_contig_mem_regions is:
+        *   num = 0
+        *   regions = {}
+        */
+       {0x1000, 0x200000, -EINVAL, 0, INVALID_VALUE, INVALID_VALUE},
+
+       /*
+        * Add the region from 0x200000 to (0x200000 + 0x1000 - 1):
+        *   Expected result:
+        *       Failed, size is not 2M-aligned
+        *
+        * Now the instance of struct ne_phys_contig_mem_regions is:
+        *   num = 0
+        *   regions = {}
+        */
+       {0x200000, 0x1000, -EINVAL, 0, INVALID_VALUE, INVALID_VALUE},
+
+       /*
+        * Add the region from 0x200000 to (0x200000 + 0x200000 - 1):
+        *   Expected result:
+        *       Successful
+        *
+        * Now the instance of struct ne_phys_contig_mem_regions is:
+        *   num = 1
+        *   regions = {
+        *       {start=0x200000, end=0x3fffff}, // len=0x200000
+        *   }
+        */
+       {0x200000, 0x200000, 0, 1, 0x200000, 0x200000},
+
+       /*
+        * Add the region from 0x0 to (0x0 + 0x200000 - 1):
+        *   Expected result:
+        *       Successful
+        *
+        * Now the instance of struct ne_phys_contig_mem_regions is:
+        *   num = 2
+        *   regions = {
+        *       {start=0x200000, end=0x3fffff}, // len=0x200000
+        *       {start=0x0,      end=0x1fffff}, // len=0x200000
+        *   }
+        */
+       {0x0, 0x200000, 0, 2, 0x0, 0x200000},
+
+       /*
+        * Add the region from 0x600000 to (0x600000 + 0x400000 - 1):
+        *   Expected result:
+        *       Successful
+        *
+        * Now the instance of struct ne_phys_contig_mem_regions is:
+        *   num = 3
+        *   regions = {
+        *       {start=0x200000, end=0x3fffff}, // len=0x200000
+        *       {start=0x0,      end=0x1fffff}, // len=0x200000
+        *       {start=0x600000, end=0x9fffff}, // len=0x400000
+        *   }
+        */
+       {0x600000, 0x400000, 0, 3, 0x600000, 0x400000},
+
+       /*
+        * Add the region from 0xa00000 to (0xa00000 + 0x400000 - 1):
+        *   Expected result:
+        *       Successful, merging case!
+        *
+        * Now the instance of struct ne_phys_contig_mem_regions is:
+        *   num = 3
+        *   regions = {
+        *       {start=0x200000, end=0x3fffff}, // len=0x200000
+        *       {start=0x0,      end=0x1fffff}, // len=0x200000
+        *       {start=0x600000, end=0xdfffff}, // len=0x800000
+        *   }
+        */
+       {0xa00000, 0x400000, 0, 3, 0x600000, 0x800000},
+
+       /*
+        * Add the region from 0x1000 to (0x1000 + 0x200000 - 1):
+        *   Expected result:
+        *       Failed, start address is not 2M-aligned
+        *
+        * Now the instance of struct ne_phys_contig_mem_regions is:
+        *   num = 3
+        *   regions = {
+        *       {start=0x200000, end=0x3fffff}, // len=0x200000
+        *       {start=0x0,      end=0x1fffff}, // len=0x200000
+        *       {start=0x600000, end=0xdfffff}, // len=0x800000
+        *   }
+        */
+       {0x1000, 0x200000, -EINVAL, 3, 0x600000, 0x800000},
+};
+
+static void ne_misc_dev_test_merge_phys_contig_memory_regions(struct kunit *test)
+{
+       struct ne_phys_contig_mem_regions phys_contig_mem_regions = {};
+       int rc = 0;
+       int i = 0;
+
+       phys_contig_mem_regions.regions = kunit_kcalloc(test, MAX_PHYS_REGIONS,
+                                                       sizeof(*phys_contig_mem_regions.regions),
+                                                       GFP_KERNEL);
+       KUNIT_ASSERT_TRUE(test, phys_contig_mem_regions.regions);
+
+       for (i = 0; i < ARRAY_SIZE(phys_regions_test_cases); i++) {
+               struct ne_phys_regions_test *test_case = &phys_regions_test_cases[i];
+               unsigned long num = 0;
+
+               rc = ne_merge_phys_contig_memory_regions(&phys_contig_mem_regions,
+                                                        test_case->paddr, test_case->size);
+               KUNIT_EXPECT_EQ(test, rc, test_case->expect_rc);
+               KUNIT_EXPECT_EQ(test, phys_contig_mem_regions.num, test_case->expect_num);
+
+               if (test_case->expect_last_paddr == INVALID_VALUE)
+                       continue;
+
+               num = phys_contig_mem_regions.num;
+               KUNIT_EXPECT_EQ(test, phys_contig_mem_regions.regions[num - 1].start,
+                               test_case->expect_last_paddr);
+               KUNIT_EXPECT_EQ(test, range_len(&phys_contig_mem_regions.regions[num - 1]),
+                               test_case->expect_last_size);
+       }
+
+       kunit_kfree(test, phys_contig_mem_regions.regions);
+}
+
+static struct kunit_case ne_misc_dev_test_cases[] = {
+       KUNIT_CASE(ne_misc_dev_test_merge_phys_contig_memory_regions),
+       {}
+};
+
+static struct kunit_suite ne_misc_dev_test_suite = {
+       .name = "ne_misc_dev_test",
+       .test_cases = ne_misc_dev_test_cases,
+};
+
+static struct kunit_suite *ne_misc_dev_test_suites[] = {
+       &ne_misc_dev_test_suite,
+       NULL
+};
index 40b49ec..6b81e8f 100644 (file)
@@ -376,7 +376,6 @@ static void ne_teardown_msix(struct pci_dev *pdev)
        free_irq(pci_irq_vector(pdev, NE_VEC_EVENT), ne_pci_dev);
 
        flush_work(&ne_pci_dev->notify_work);
-       flush_workqueue(ne_pci_dev->event_wq);
        destroy_workqueue(ne_pci_dev->event_wq);
 
        free_irq(pci_irq_vector(pdev, NE_VEC_REPLY), ne_pci_dev);
index 4b13e0a..c9a4c96 100644 (file)
@@ -190,7 +190,7 @@ static inline void be64_add_cpu(__be64 *var, u64 val)
 
 static inline void cpu_to_be32_array(__be32 *dst, const u32 *src, size_t len)
 {
-       int i;
+       size_t i;
 
        for (i = 0; i < len; i++)
                dst[i] = cpu_to_be32(src[i]);
@@ -198,7 +198,7 @@ static inline void cpu_to_be32_array(__be32 *dst, const u32 *src, size_t len)
 
 static inline void be32_to_cpu_array(u32 *dst, const __be32 *src, size_t len)
 {
-       int i;
+       size_t i;
 
        for (i = 0; i < len; i++)
                dst[i] = be32_to_cpu(src[i]);
diff --git a/include/linux/comedi/comedi_8254.h b/include/linux/comedi/comedi_8254.h
new file mode 100644 (file)
index 0000000..d826441
--- /dev/null
@@ -0,0 +1,134 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * comedi_8254.h
+ * Generic 8254 timer/counter support
+ * Copyright (C) 2014 H Hartley Sweeten <hsweeten@visionengravers.com>
+ *
+ * COMEDI - Linux Control and Measurement Device Interface
+ * Copyright (C) 2000 David A. Schleef <ds@schleef.org>
+ */
+
+#ifndef _COMEDI_8254_H
+#define _COMEDI_8254_H
+
+#include <linux/types.h>
+
+struct comedi_device;
+struct comedi_insn;
+struct comedi_subdevice;
+
+/*
+ * Common oscillator base values in nanoseconds
+ */
+#define I8254_OSC_BASE_10MHZ   100
+#define I8254_OSC_BASE_5MHZ    200
+#define I8254_OSC_BASE_4MHZ    250
+#define I8254_OSC_BASE_2MHZ    500
+#define I8254_OSC_BASE_1MHZ    1000
+#define I8254_OSC_BASE_100KHZ  10000
+#define I8254_OSC_BASE_10KHZ   100000
+#define I8254_OSC_BASE_1KHZ    1000000
+
+/*
+ * I/O access size used to read/write registers
+ */
+#define I8254_IO8              1
+#define I8254_IO16             2
+#define I8254_IO32             4
+
+/*
+ * Register map for generic 8254 timer (I8254_IO8 with 0 regshift)
+ */
+#define I8254_COUNTER0_REG             0x00
+#define I8254_COUNTER1_REG             0x01
+#define I8254_COUNTER2_REG             0x02
+#define I8254_CTRL_REG                 0x03
+#define I8254_CTRL_SEL_CTR(x)          ((x) << 6)
+#define I8254_CTRL_READBACK(x)         (I8254_CTRL_SEL_CTR(3) | BIT(x))
+#define I8254_CTRL_READBACK_COUNT      I8254_CTRL_READBACK(4)
+#define I8254_CTRL_READBACK_STATUS     I8254_CTRL_READBACK(5)
+#define I8254_CTRL_READBACK_SEL_CTR(x) (2 << (x))
+#define I8254_CTRL_RW(x)               (((x) & 0x3) << 4)
+#define I8254_CTRL_LATCH               I8254_CTRL_RW(0)
+#define I8254_CTRL_LSB_ONLY            I8254_CTRL_RW(1)
+#define I8254_CTRL_MSB_ONLY            I8254_CTRL_RW(2)
+#define I8254_CTRL_LSB_MSB             I8254_CTRL_RW(3)
+
+/* counter maps zero to 0x10000 */
+#define I8254_MAX_COUNT                        0x10000
+
+/**
+ * struct comedi_8254 - private data used by this module
+ * @iobase:            PIO base address of the registers (in/out)
+ * @mmio:              MMIO base address of the registers (read/write)
+ * @iosize:            I/O size used to access the registers (b/w/l)
+ * @regshift:          register gap shift
+ * @osc_base:          cascaded oscillator speed in ns
+ * @divisor:           divisor for single counter
+ * @divisor1:          divisor loaded into first cascaded counter
+ * @divisor2:          divisor loaded into second cascaded counter
+ * #next_div:          next divisor for single counter
+ * @next_div1:         next divisor to use for first cascaded counter
+ * @next_div2:         next divisor to use for second cascaded counter
+ * @clock_src;         current clock source for each counter (driver specific)
+ * @gate_src;          current gate source  for each counter (driver specific)
+ * @busy:              flags used to indicate that a counter is "busy"
+ * @insn_config:       driver specific (*insn_config) callback
+ */
+struct comedi_8254 {
+       unsigned long iobase;
+       void __iomem *mmio;
+       unsigned int iosize;
+       unsigned int regshift;
+       unsigned int osc_base;
+       unsigned int divisor;
+       unsigned int divisor1;
+       unsigned int divisor2;
+       unsigned int next_div;
+       unsigned int next_div1;
+       unsigned int next_div2;
+       unsigned int clock_src[3];
+       unsigned int gate_src[3];
+       bool busy[3];
+
+       int (*insn_config)(struct comedi_device *dev,
+                          struct comedi_subdevice *s,
+                          struct comedi_insn *insn, unsigned int *data);
+};
+
+unsigned int comedi_8254_status(struct comedi_8254 *i8254,
+                               unsigned int counter);
+unsigned int comedi_8254_read(struct comedi_8254 *i8254, unsigned int counter);
+void comedi_8254_write(struct comedi_8254 *i8254,
+                      unsigned int counter, unsigned int val);
+
+int comedi_8254_set_mode(struct comedi_8254 *i8254,
+                        unsigned int counter, unsigned int mode);
+int comedi_8254_load(struct comedi_8254 *i8254,
+                    unsigned int counter, unsigned int val, unsigned int mode);
+
+void comedi_8254_pacer_enable(struct comedi_8254 *i8254,
+                             unsigned int counter1, unsigned int counter2,
+                             bool enable);
+void comedi_8254_update_divisors(struct comedi_8254 *i8254);
+void comedi_8254_cascade_ns_to_timer(struct comedi_8254 *i8254,
+                                    unsigned int *nanosec, unsigned int flags);
+void comedi_8254_ns_to_timer(struct comedi_8254 *i8254,
+                            unsigned int *nanosec, unsigned int flags);
+
+void comedi_8254_set_busy(struct comedi_8254 *i8254,
+                         unsigned int counter, bool busy);
+
+void comedi_8254_subdevice_init(struct comedi_subdevice *s,
+                               struct comedi_8254 *i8254);
+
+struct comedi_8254 *comedi_8254_init(unsigned long iobase,
+                                    unsigned int osc_base,
+                                    unsigned int iosize,
+                                    unsigned int regshift);
+struct comedi_8254 *comedi_8254_mm_init(void __iomem *mmio,
+                                       unsigned int osc_base,
+                                       unsigned int iosize,
+                                       unsigned int regshift);
+
+#endif /* _COMEDI_8254_H */
diff --git a/include/linux/comedi/comedi_8255.h b/include/linux/comedi/comedi_8255.h
new file mode 100644 (file)
index 0000000..b2a5bc6
--- /dev/null
@@ -0,0 +1,42 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * comedi_8255.h
+ * Generic 8255 digital I/O subdevice support
+ *
+ * COMEDI - Linux Control and Measurement Device Interface
+ * Copyright (C) 1998 David A. Schleef <ds@schleef.org>
+ */
+
+#ifndef _COMEDI_8255_H
+#define _COMEDI_8255_H
+
+#define I8255_SIZE             0x04
+
+#define I8255_DATA_A_REG       0x00
+#define I8255_DATA_B_REG       0x01
+#define I8255_DATA_C_REG       0x02
+#define I8255_CTRL_REG         0x03
+#define I8255_CTRL_C_LO_IO     BIT(0)
+#define I8255_CTRL_B_IO                BIT(1)
+#define I8255_CTRL_B_MODE      BIT(2)
+#define I8255_CTRL_C_HI_IO     BIT(3)
+#define I8255_CTRL_A_IO                BIT(4)
+#define I8255_CTRL_A_MODE(x)   ((x) << 5)
+#define I8255_CTRL_CW          BIT(7)
+
+struct comedi_device;
+struct comedi_subdevice;
+
+int subdev_8255_init(struct comedi_device *dev, struct comedi_subdevice *s,
+                    int (*io)(struct comedi_device *dev, int dir, int port,
+                              int data, unsigned long regbase),
+                    unsigned long regbase);
+
+int subdev_8255_mm_init(struct comedi_device *dev, struct comedi_subdevice *s,
+                       int (*io)(struct comedi_device *dev, int dir, int port,
+                                 int data, unsigned long regbase),
+                       unsigned long regbase);
+
+unsigned long subdev_8255_regbase(struct comedi_subdevice *s);
+
+#endif
diff --git a/include/linux/comedi/comedi_isadma.h b/include/linux/comedi/comedi_isadma.h
new file mode 100644 (file)
index 0000000..9d2b12d
--- /dev/null
@@ -0,0 +1,114 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * COMEDI ISA DMA support functions
+ * Copyright (c) 2014 H Hartley Sweeten <hsweeten@visionengravers.com>
+ */
+
+#ifndef _COMEDI_ISADMA_H
+#define _COMEDI_ISADMA_H
+
+#include <linux/types.h>
+
+struct comedi_device;
+struct device;
+
+/*
+ * These are used to avoid issues when <asm/dma.h> and the DMA_MODE_
+ * defines are not available.
+ */
+#define COMEDI_ISADMA_READ     0
+#define COMEDI_ISADMA_WRITE    1
+
+/**
+ * struct comedi_isadma_desc - cookie for ISA DMA
+ * @virt_addr: virtual address of buffer
+ * @hw_addr:   hardware (bus) address of buffer
+ * @chan:      DMA channel
+ * @maxsize:   allocated size of buffer (in bytes)
+ * @size:      transfer size (in bytes)
+ * @mode:      DMA_MODE_READ or DMA_MODE_WRITE
+ */
+struct comedi_isadma_desc {
+       void *virt_addr;
+       dma_addr_t hw_addr;
+       unsigned int chan;
+       unsigned int maxsize;
+       unsigned int size;
+       char mode;
+};
+
+/**
+ * struct comedi_isadma - ISA DMA data
+ * @dev:       device to allocate non-coherent memory for
+ * @desc:      cookie for each DMA buffer
+ * @n_desc:    the number of cookies
+ * @cur_dma:   the current cookie in use
+ * @chan:      the first DMA channel requested
+ * @chan2:     the second DMA channel requested
+ */
+struct comedi_isadma {
+       struct device *dev;
+       struct comedi_isadma_desc *desc;
+       int n_desc;
+       int cur_dma;
+       unsigned int chan;
+       unsigned int chan2;
+};
+
+#if IS_ENABLED(CONFIG_ISA_DMA_API)
+
+void comedi_isadma_program(struct comedi_isadma_desc *desc);
+unsigned int comedi_isadma_disable(unsigned int dma_chan);
+unsigned int comedi_isadma_disable_on_sample(unsigned int dma_chan,
+                                            unsigned int size);
+unsigned int comedi_isadma_poll(struct comedi_isadma *dma);
+void comedi_isadma_set_mode(struct comedi_isadma_desc *desc, char dma_dir);
+
+struct comedi_isadma *comedi_isadma_alloc(struct comedi_device *dev,
+                                         int n_desc, unsigned int dma_chan1,
+                                         unsigned int dma_chan2,
+                                         unsigned int maxsize, char dma_dir);
+void comedi_isadma_free(struct comedi_isadma *dma);
+
+#else  /* !IS_ENABLED(CONFIG_ISA_DMA_API) */
+
+static inline void comedi_isadma_program(struct comedi_isadma_desc *desc)
+{
+}
+
+static inline unsigned int comedi_isadma_disable(unsigned int dma_chan)
+{
+       return 0;
+}
+
+static inline unsigned int
+comedi_isadma_disable_on_sample(unsigned int dma_chan, unsigned int size)
+{
+       return 0;
+}
+
+static inline unsigned int comedi_isadma_poll(struct comedi_isadma *dma)
+{
+       return 0;
+}
+
+static inline void comedi_isadma_set_mode(struct comedi_isadma_desc *desc,
+                                         char dma_dir)
+{
+}
+
+static inline struct comedi_isadma *
+comedi_isadma_alloc(struct comedi_device *dev, int n_desc,
+                   unsigned int dma_chan1, unsigned int dma_chan2,
+                   unsigned int maxsize, char dma_dir)
+{
+       return NULL;
+}
+
+static inline void comedi_isadma_free(struct comedi_isadma *dma)
+{
+}
+
+#endif /* !IS_ENABLED(CONFIG_ISA_DMA_API) */
+
+#endif /* #ifndef _COMEDI_ISADMA_H */
diff --git a/include/linux/comedi/comedi_pci.h b/include/linux/comedi/comedi_pci.h
new file mode 100644 (file)
index 0000000..2fb5066
--- /dev/null
@@ -0,0 +1,56 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * comedi_pci.h
+ * header file for Comedi PCI drivers
+ *
+ * COMEDI - Linux Control and Measurement Device Interface
+ * Copyright (C) 1997-2000 David A. Schleef <ds@schleef.org>
+ */
+
+#ifndef _COMEDI_PCI_H
+#define _COMEDI_PCI_H
+
+#include <linux/pci.h>
+#include <linux/comedi/comedidev.h>
+
+/*
+ * PCI Vendor IDs not in <linux/pci_ids.h>
+ */
+#define PCI_VENDOR_ID_KOLTER           0x1001
+#define PCI_VENDOR_ID_ICP              0x104c
+#define PCI_VENDOR_ID_DT               0x1116
+#define PCI_VENDOR_ID_IOTECH           0x1616
+#define PCI_VENDOR_ID_CONTEC           0x1221
+#define PCI_VENDOR_ID_RTD              0x1435
+#define PCI_VENDOR_ID_HUMUSOFT         0x186c
+
+struct pci_dev *comedi_to_pci_dev(struct comedi_device *dev);
+
+int comedi_pci_enable(struct comedi_device *dev);
+void comedi_pci_disable(struct comedi_device *dev);
+void comedi_pci_detach(struct comedi_device *dev);
+
+int comedi_pci_auto_config(struct pci_dev *pcidev, struct comedi_driver *driver,
+                          unsigned long context);
+void comedi_pci_auto_unconfig(struct pci_dev *pcidev);
+
+int comedi_pci_driver_register(struct comedi_driver *comedi_driver,
+                              struct pci_driver *pci_driver);
+void comedi_pci_driver_unregister(struct comedi_driver *comedi_driver,
+                                 struct pci_driver *pci_driver);
+
+/**
+ * module_comedi_pci_driver() - Helper macro for registering a comedi PCI driver
+ * @__comedi_driver: comedi_driver struct
+ * @__pci_driver: pci_driver struct
+ *
+ * Helper macro for comedi PCI drivers which do not do anything special
+ * in module init/exit. This eliminates a lot of boilerplate. Each
+ * module may only use this macro once, and calling it replaces
+ * module_init() and module_exit()
+ */
+#define module_comedi_pci_driver(__comedi_driver, __pci_driver) \
+       module_driver(__comedi_driver, comedi_pci_driver_register, \
+                       comedi_pci_driver_unregister, &(__pci_driver))
+
+#endif /* _COMEDI_PCI_H */
diff --git a/include/linux/comedi/comedi_pcmcia.h b/include/linux/comedi/comedi_pcmcia.h
new file mode 100644 (file)
index 0000000..a33dfb6
--- /dev/null
@@ -0,0 +1,48 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * comedi_pcmcia.h
+ * header file for Comedi PCMCIA drivers
+ *
+ * COMEDI - Linux Control and Measurement Device Interface
+ * Copyright (C) 1997-2000 David A. Schleef <ds@schleef.org>
+ */
+
+#ifndef _COMEDI_PCMCIA_H
+#define _COMEDI_PCMCIA_H
+
+#include <pcmcia/cistpl.h>
+#include <pcmcia/ds.h>
+#include <linux/comedi/comedidev.h>
+
+struct pcmcia_device *comedi_to_pcmcia_dev(struct comedi_device *dev);
+
+int comedi_pcmcia_enable(struct comedi_device *dev,
+                        int (*conf_check)(struct pcmcia_device *p_dev,
+                                          void *priv_data));
+void comedi_pcmcia_disable(struct comedi_device *dev);
+
+int comedi_pcmcia_auto_config(struct pcmcia_device *link,
+                             struct comedi_driver *driver);
+void comedi_pcmcia_auto_unconfig(struct pcmcia_device *link);
+
+int comedi_pcmcia_driver_register(struct comedi_driver *comedi_driver,
+                                 struct pcmcia_driver *pcmcia_driver);
+void comedi_pcmcia_driver_unregister(struct comedi_driver *comedi_driver,
+                                    struct pcmcia_driver *pcmcia_driver);
+
+/**
+ * module_comedi_pcmcia_driver() - Helper macro for registering a comedi
+ * PCMCIA driver
+ * @__comedi_driver: comedi_driver struct
+ * @__pcmcia_driver: pcmcia_driver struct
+ *
+ * Helper macro for comedi PCMCIA drivers which do not do anything special
+ * in module init/exit. This eliminates a lot of boilerplate. Each
+ * module may only use this macro once, and calling it replaces
+ * module_init() and module_exit()
+ */
+#define module_comedi_pcmcia_driver(__comedi_driver, __pcmcia_driver) \
+       module_driver(__comedi_driver, comedi_pcmcia_driver_register, \
+                       comedi_pcmcia_driver_unregister, &(__pcmcia_driver))
+
+#endif /* _COMEDI_PCMCIA_H */
diff --git a/include/linux/comedi/comedi_usb.h b/include/linux/comedi/comedi_usb.h
new file mode 100644 (file)
index 0000000..5d17dd4
--- /dev/null
@@ -0,0 +1,41 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/* comedi_usb.h
+ * header file for USB Comedi drivers
+ *
+ * COMEDI - Linux Control and Measurement Device Interface
+ * Copyright (C) 1997-2000 David A. Schleef <ds@schleef.org>
+ */
+
+#ifndef _COMEDI_USB_H
+#define _COMEDI_USB_H
+
+#include <linux/usb.h>
+#include <linux/comedi/comedidev.h>
+
+struct usb_interface *comedi_to_usb_interface(struct comedi_device *dev);
+struct usb_device *comedi_to_usb_dev(struct comedi_device *dev);
+
+int comedi_usb_auto_config(struct usb_interface *intf,
+                          struct comedi_driver *driver, unsigned long context);
+void comedi_usb_auto_unconfig(struct usb_interface *intf);
+
+int comedi_usb_driver_register(struct comedi_driver *comedi_driver,
+                              struct usb_driver *usb_driver);
+void comedi_usb_driver_unregister(struct comedi_driver *comedi_driver,
+                                 struct usb_driver *usb_driver);
+
+/**
+ * module_comedi_usb_driver() - Helper macro for registering a comedi USB driver
+ * @__comedi_driver: comedi_driver struct
+ * @__usb_driver: usb_driver struct
+ *
+ * Helper macro for comedi USB drivers which do not do anything special
+ * in module init/exit. This eliminates a lot of boilerplate. Each
+ * module may only use this macro once, and calling it replaces
+ * module_init() and module_exit()
+ */
+#define module_comedi_usb_driver(__comedi_driver, __usb_driver) \
+       module_driver(__comedi_driver, comedi_usb_driver_register, \
+                       comedi_usb_driver_unregister, &(__usb_driver))
+
+#endif /* _COMEDI_USB_H */
diff --git a/include/linux/comedi/comedidev.h b/include/linux/comedi/comedidev.h
new file mode 100644 (file)
index 0000000..0a11509
--- /dev/null
@@ -0,0 +1,1053 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * comedidev.h
+ * header file for kernel-only structures, variables, and constants
+ *
+ * COMEDI - Linux Control and Measurement Device Interface
+ * Copyright (C) 1997-2000 David A. Schleef <ds@schleef.org>
+ */
+
+#ifndef _COMEDIDEV_H
+#define _COMEDIDEV_H
+
+#include <linux/dma-mapping.h>
+#include <linux/mutex.h>
+#include <linux/spinlock_types.h>
+#include <linux/rwsem.h>
+#include <linux/kref.h>
+#include <linux/comedi.h>
+
+#define COMEDI_VERSION(a, b, c) (((a) << 16) + ((b) << 8) + (c))
+#define COMEDI_VERSION_CODE COMEDI_VERSION(COMEDI_MAJORVERSION, \
+       COMEDI_MINORVERSION, COMEDI_MICROVERSION)
+#define COMEDI_RELEASE VERSION
+
+#define COMEDI_NUM_BOARD_MINORS 0x30
+
+/**
+ * struct comedi_subdevice - Working data for a COMEDI subdevice
+ * @device: COMEDI device to which this subdevice belongs.  (Initialized by
+ *     comedi_alloc_subdevices().)
+ * @index: Index of this subdevice within device's array of subdevices.
+ *     (Initialized by comedi_alloc_subdevices().)
+ * @type: Type of subdevice from &enum comedi_subdevice_type.  (Initialized by
+ *     the low-level driver.)
+ * @n_chan: Number of channels the subdevice supports.  (Initialized by the
+ *     low-level driver.)
+ * @subdev_flags: Various "SDF" flags indicating aspects of the subdevice to
+ *     the COMEDI core and user application.  (Initialized by the low-level
+ *     driver.)
+ * @len_chanlist: Maximum length of a channel list if the subdevice supports
+ *     asynchronous acquisition commands.  (Optionally initialized by the
+ *     low-level driver, or changed from 0 to 1 during post-configuration.)
+ * @private: Private data pointer which is either set by the low-level driver
+ *     itself, or by a call to comedi_alloc_spriv() which allocates storage.
+ *     In the latter case, the storage is automatically freed after the
+ *     low-level driver's "detach" handler is called for the device.
+ *     (Initialized by the low-level driver.)
+ * @async: Pointer to &struct comedi_async id the subdevice supports
+ *     asynchronous acquisition commands.  (Allocated and initialized during
+ *     post-configuration if needed.)
+ * @lock: Pointer to a file object that performed a %COMEDI_LOCK ioctl on the
+ *     subdevice.  (Initially NULL.)
+ * @busy: Pointer to a file object that is performing an asynchronous
+ *     acquisition command on the subdevice.  (Initially NULL.)
+ * @runflags: Internal flags for use by COMEDI core, mostly indicating whether
+ *     an asynchronous acquisition command is running.
+ * @spin_lock: Generic spin-lock for use by the COMEDI core and the low-level
+ *     driver.  (Initialized by comedi_alloc_subdevices().)
+ * @io_bits: Bit-mask indicating the channel directions for a DIO subdevice
+ *     with no more than 32 channels.  A '1' at a bit position indicates the
+ *     corresponding channel is configured as an output.  (Initialized by the
+ *     low-level driver for a DIO subdevice.  Forced to all-outputs during
+ *     post-configuration for a digital output subdevice.)
+ * @maxdata: If non-zero, this is the maximum raw data value of each channel.
+ *     If zero, the maximum data value is channel-specific.  (Initialized by
+ *     the low-level driver.)
+ * @maxdata_list: If the maximum data value is channel-specific, this points
+ *     to an array of maximum data values indexed by channel index.
+ *     (Initialized by the low-level driver.)
+ * @range_table: If non-NULL, this points to a COMEDI range table for the
+ *     subdevice.  If NULL, the range table is channel-specific.  (Initialized
+ *     by the low-level driver, will be set to an "invalid" range table during
+ *     post-configuration if @range_table and @range_table_list are both
+ *     NULL.)
+ * @range_table_list: If the COMEDI range table is channel-specific, this
+ *     points to an array of pointers to COMEDI range tables indexed by
+ *     channel number.  (Initialized by the low-level driver.)
+ * @chanlist: Not used.
+ * @insn_read: Optional pointer to a handler for the %INSN_READ instruction.
+ *     (Initialized by the low-level driver, or set to a default handler
+ *     during post-configuration.)
+ * @insn_write: Optional pointer to a handler for the %INSN_WRITE instruction.
+ *     (Initialized by the low-level driver, or set to a default handler
+ *     during post-configuration.)
+ * @insn_bits: Optional pointer to a handler for the %INSN_BITS instruction
+ *     for a digital input, digital output or digital input/output subdevice.
+ *     (Initialized by the low-level driver, or set to a default handler
+ *     during post-configuration.)
+ * @insn_config: Optional pointer to a handler for the %INSN_CONFIG
+ *     instruction.  (Initialized by the low-level driver, or set to a default
+ *     handler during post-configuration.)
+ * @do_cmd: If the subdevice supports asynchronous acquisition commands, this
+ *     points to a handler to set it up in hardware.  (Initialized by the
+ *     low-level driver.)
+ * @do_cmdtest: If the subdevice supports asynchronous acquisition commands,
+ *     this points to a handler used to check and possibly tweak a prospective
+ *     acquisition command without setting it up in hardware.  (Initialized by
+ *     the low-level driver.)
+ * @poll: If the subdevice supports asynchronous acquisition commands, this
+ *     is an optional pointer to a handler for the %COMEDI_POLL ioctl which
+ *     instructs the low-level driver to synchronize buffers.  (Initialized by
+ *     the low-level driver if needed.)
+ * @cancel: If the subdevice supports asynchronous acquisition commands, this
+ *     points to a handler used to terminate a running command.  (Initialized
+ *     by the low-level driver.)
+ * @buf_change: If the subdevice supports asynchronous acquisition commands,
+ *     this is an optional pointer to a handler that is called when the data
+ *     buffer for handling asynchronous commands is allocated or reallocated.
+ *     (Initialized by the low-level driver if needed.)
+ * @munge: If the subdevice supports asynchronous acquisition commands and
+ *     uses DMA to transfer data from the hardware to the acquisition buffer,
+ *     this points to a function used to "munge" the data values from the
+ *     hardware into the format expected by COMEDI.  (Initialized by the
+ *     low-level driver if needed.)
+ * @async_dma_dir: If the subdevice supports asynchronous acquisition commands
+ *     and uses DMA to transfer data from the hardware to the acquisition
+ *     buffer, this sets the DMA direction for the buffer. (initialized to
+ *     %DMA_NONE by comedi_alloc_subdevices() and changed by the low-level
+ *     driver if necessary.)
+ * @state: Handy bit-mask indicating the output states for a DIO or digital
+ *     output subdevice with no more than 32 channels. (Initialized by the
+ *     low-level driver.)
+ * @class_dev: If the subdevice supports asynchronous acquisition commands,
+ *     this points to a sysfs comediX_subdY device where X is the minor device
+ *     number of the COMEDI device and Y is the subdevice number.  The minor
+ *     device number for the sysfs device is allocated dynamically in the
+ *     range 48 to 255.  This is used to allow the COMEDI device to be opened
+ *     with a different default read or write subdevice.  (Allocated during
+ *     post-configuration if needed.)
+ * @minor: If @class_dev is set, this is its dynamically allocated minor
+ *     device number.  (Set during post-configuration if necessary.)
+ * @readback: Optional pointer to memory allocated by
+ *     comedi_alloc_subdev_readback() used to hold the values written to
+ *     analog output channels so they can be read back.  The storage is
+ *     automatically freed after the low-level driver's "detach" handler is
+ *     called for the device.  (Initialized by the low-level driver.)
+ *
+ * This is the main control structure for a COMEDI subdevice.  If the subdevice
+ * supports asynchronous acquisition commands, additional information is stored
+ * in the &struct comedi_async pointed to by @async.
+ *
+ * Most of the subdevice is initialized by the low-level driver's "attach" or
+ * "auto_attach" handlers but parts of it are initialized by
+ * comedi_alloc_subdevices(), and other parts are initialized during
+ * post-configuration on return from that handler.
+ *
+ * A low-level driver that sets @insn_bits for a digital input, digital output,
+ * or DIO subdevice may leave @insn_read and @insn_write uninitialized, in
+ * which case they will be set to a default handler during post-configuration
+ * that uses @insn_bits to emulate the %INSN_READ and %INSN_WRITE instructions.
+ */
+struct comedi_subdevice {
+       struct comedi_device *device;
+       int index;
+       int type;
+       int n_chan;
+       int subdev_flags;
+       int len_chanlist;       /* maximum length of channel/gain list */
+
+       void *private;
+
+       struct comedi_async *async;
+
+       void *lock;
+       void *busy;
+       unsigned int runflags;
+       spinlock_t spin_lock;   /* generic spin-lock for COMEDI and drivers */
+
+       unsigned int io_bits;
+
+       unsigned int maxdata;   /* if maxdata==0, use list */
+       const unsigned int *maxdata_list;       /* list is channel specific */
+
+       const struct comedi_lrange *range_table;
+       const struct comedi_lrange *const *range_table_list;
+
+       unsigned int *chanlist; /* driver-owned chanlist (not used) */
+
+       int (*insn_read)(struct comedi_device *dev, struct comedi_subdevice *s,
+                        struct comedi_insn *insn, unsigned int *data);
+       int (*insn_write)(struct comedi_device *dev, struct comedi_subdevice *s,
+                         struct comedi_insn *insn, unsigned int *data);
+       int (*insn_bits)(struct comedi_device *dev, struct comedi_subdevice *s,
+                        struct comedi_insn *insn, unsigned int *data);
+       int (*insn_config)(struct comedi_device *dev,
+                          struct comedi_subdevice *s,
+                          struct comedi_insn *insn,
+                          unsigned int *data);
+
+       int (*do_cmd)(struct comedi_device *dev, struct comedi_subdevice *s);
+       int (*do_cmdtest)(struct comedi_device *dev,
+                         struct comedi_subdevice *s,
+                         struct comedi_cmd *cmd);
+       int (*poll)(struct comedi_device *dev, struct comedi_subdevice *s);
+       int (*cancel)(struct comedi_device *dev, struct comedi_subdevice *s);
+
+       /* called when the buffer changes */
+       int (*buf_change)(struct comedi_device *dev,
+                         struct comedi_subdevice *s);
+
+       void (*munge)(struct comedi_device *dev, struct comedi_subdevice *s,
+                     void *data, unsigned int num_bytes,
+                     unsigned int start_chan_index);
+       enum dma_data_direction async_dma_dir;
+
+       unsigned int state;
+
+       struct device *class_dev;
+       int minor;
+
+       unsigned int *readback;
+};
+
+/**
+ * struct comedi_buf_page - Describe a page of a COMEDI buffer
+ * @virt_addr: Kernel address of page.
+ * @dma_addr: DMA address of page if in DMA coherent memory.
+ */
+struct comedi_buf_page {
+       void *virt_addr;
+       dma_addr_t dma_addr;
+};
+
+/**
+ * struct comedi_buf_map - Describe pages in a COMEDI buffer
+ * @dma_hw_dev: Low-level hardware &struct device pointer copied from the
+ *     COMEDI device's hw_dev member.
+ * @page_list: Pointer to array of &struct comedi_buf_page, one for each
+ *     page in the buffer.
+ * @n_pages: Number of pages in the buffer.
+ * @dma_dir: DMA direction used to allocate pages of DMA coherent memory,
+ *     or %DMA_NONE if pages allocated from regular memory.
+ * @refcount: &struct kref reference counter used to free the buffer.
+ *
+ * A COMEDI data buffer is allocated as individual pages, either in
+ * conventional memory or DMA coherent memory, depending on the attached,
+ * low-level hardware device.  (The buffer pages also get mapped into the
+ * kernel's contiguous virtual address space pointed to by the 'prealloc_buf'
+ * member of &struct comedi_async.)
+ *
+ * The buffer is normally freed when the COMEDI device is detached from the
+ * low-level driver (which may happen due to device removal), but if it happens
+ * to be mmapped at the time, the pages cannot be freed until the buffer has
+ * been munmapped.  That is what the reference counter is for.  (The virtual
+ * address space pointed by 'prealloc_buf' is freed when the COMEDI device is
+ * detached.)
+ */
+struct comedi_buf_map {
+       struct device *dma_hw_dev;
+       struct comedi_buf_page *page_list;
+       unsigned int n_pages;
+       enum dma_data_direction dma_dir;
+       struct kref refcount;
+};
+
+/**
+ * struct comedi_async - Control data for asynchronous COMEDI commands
+ * @prealloc_buf: Kernel virtual address of allocated acquisition buffer.
+ * @prealloc_bufsz: Buffer size (in bytes).
+ * @buf_map: Map of buffer pages.
+ * @max_bufsize: Maximum allowed buffer size (in bytes).
+ * @buf_write_count: "Write completed" count (in bytes, modulo 2**32).
+ * @buf_write_alloc_count: "Allocated for writing" count (in bytes,
+ *     modulo 2**32).
+ * @buf_read_count: "Read completed" count (in bytes, modulo 2**32).
+ * @buf_read_alloc_count: "Allocated for reading" count (in bytes,
+ *     modulo 2**32).
+ * @buf_write_ptr: Buffer position for writer.
+ * @buf_read_ptr: Buffer position for reader.
+ * @cur_chan: Current position in chanlist for scan (for those drivers that
+ *     use it).
+ * @scans_done: The number of scans completed.
+ * @scan_progress: Amount received or sent for current scan (in bytes).
+ * @munge_chan: Current position in chanlist for "munging".
+ * @munge_count: "Munge" count (in bytes, modulo 2**32).
+ * @munge_ptr: Buffer position for "munging".
+ * @events: Bit-vector of events that have occurred.
+ * @cmd: Details of comedi command in progress.
+ * @wait_head: Task wait queue for file reader or writer.
+ * @cb_mask: Bit-vector of events that should wake waiting tasks.
+ * @inttrig: Software trigger function for command, or NULL.
+ *
+ * Note about the ..._count and ..._ptr members:
+ *
+ * Think of the _Count values being integers of unlimited size, indexing
+ * into a buffer of infinite length (though only an advancing portion
+ * of the buffer of fixed length prealloc_bufsz is accessible at any
+ * time).  Then:
+ *
+ *   Buf_Read_Count <= Buf_Read_Alloc_Count <= Munge_Count <=
+ *   Buf_Write_Count <= Buf_Write_Alloc_Count <=
+ *   (Buf_Read_Count + prealloc_bufsz)
+ *
+ * (Those aren't the actual members, apart from prealloc_bufsz.) When the
+ * buffer is reset, those _Count values start at 0 and only increase in value,
+ * maintaining the above inequalities until the next time the buffer is
+ * reset.  The buffer is divided into the following regions by the inequalities:
+ *
+ *   [0, Buf_Read_Count):
+ *     old region no longer accessible
+ *
+ *   [Buf_Read_Count, Buf_Read_Alloc_Count):
+ *     filled and munged region allocated for reading but not yet read
+ *
+ *   [Buf_Read_Alloc_Count, Munge_Count):
+ *     filled and munged region not yet allocated for reading
+ *
+ *   [Munge_Count, Buf_Write_Count):
+ *     filled region not yet munged
+ *
+ *   [Buf_Write_Count, Buf_Write_Alloc_Count):
+ *     unfilled region allocated for writing but not yet written
+ *
+ *   [Buf_Write_Alloc_Count, Buf_Read_Count + prealloc_bufsz):
+ *     unfilled region not yet allocated for writing
+ *
+ *   [Buf_Read_Count + prealloc_bufsz, infinity):
+ *     unfilled region not yet accessible
+ *
+ * Data needs to be written into the buffer before it can be read out,
+ * and may need to be converted (or "munged") between the two
+ * operations.  Extra unfilled buffer space may need to allocated for
+ * writing (advancing Buf_Write_Alloc_Count) before new data is written.
+ * After writing new data, the newly filled space needs to be released
+ * (advancing Buf_Write_Count).  This also results in the new data being
+ * "munged" (advancing Munge_Count).  Before data is read out of the
+ * buffer, extra space may need to be allocated for reading (advancing
+ * Buf_Read_Alloc_Count).  After the data has been read out, the space
+ * needs to be released (advancing Buf_Read_Count).
+ *
+ * The actual members, buf_read_count, buf_read_alloc_count,
+ * munge_count, buf_write_count, and buf_write_alloc_count take the
+ * value of the corresponding capitalized _Count values modulo 2^32
+ * (UINT_MAX+1).  Subtracting a "higher" _count value from a "lower"
+ * _count value gives the same answer as subtracting a "higher" _Count
+ * value from a lower _Count value because prealloc_bufsz < UINT_MAX+1.
+ * The modulo operation is done implicitly.
+ *
+ * The buf_read_ptr, munge_ptr, and buf_write_ptr members take the value
+ * of the corresponding capitalized _Count values modulo prealloc_bufsz.
+ * These correspond to byte indices in the physical buffer.  The modulo
+ * operation is done by subtracting prealloc_bufsz when the value
+ * exceeds prealloc_bufsz (assuming prealloc_bufsz plus the increment is
+ * less than or equal to UINT_MAX).
+ */
+struct comedi_async {
+       void *prealloc_buf;
+       unsigned int prealloc_bufsz;
+       struct comedi_buf_map *buf_map;
+       unsigned int max_bufsize;
+       unsigned int buf_write_count;
+       unsigned int buf_write_alloc_count;
+       unsigned int buf_read_count;
+       unsigned int buf_read_alloc_count;
+       unsigned int buf_write_ptr;
+       unsigned int buf_read_ptr;
+       unsigned int cur_chan;
+       unsigned int scans_done;
+       unsigned int scan_progress;
+       unsigned int munge_chan;
+       unsigned int munge_count;
+       unsigned int munge_ptr;
+       unsigned int events;
+       struct comedi_cmd cmd;
+       wait_queue_head_t wait_head;
+       unsigned int cb_mask;
+       int (*inttrig)(struct comedi_device *dev, struct comedi_subdevice *s,
+                      unsigned int x);
+};
+
+/**
+ * enum comedi_cb - &struct comedi_async callback "events"
+ * @COMEDI_CB_EOS:             end-of-scan
+ * @COMEDI_CB_EOA:             end-of-acquisition/output
+ * @COMEDI_CB_BLOCK:           data has arrived, wakes up read() / write()
+ * @COMEDI_CB_EOBUF:           DEPRECATED: end of buffer
+ * @COMEDI_CB_ERROR:           card error during acquisition
+ * @COMEDI_CB_OVERFLOW:                buffer overflow/underflow
+ * @COMEDI_CB_ERROR_MASK:      events that indicate an error has occurred
+ * @COMEDI_CB_CANCEL_MASK:     events that will cancel an async command
+ */
+enum comedi_cb {
+       COMEDI_CB_EOS           = BIT(0),
+       COMEDI_CB_EOA           = BIT(1),
+       COMEDI_CB_BLOCK         = BIT(2),
+       COMEDI_CB_EOBUF         = BIT(3),
+       COMEDI_CB_ERROR         = BIT(4),
+       COMEDI_CB_OVERFLOW      = BIT(5),
+       /* masks */
+       COMEDI_CB_ERROR_MASK    = (COMEDI_CB_ERROR | COMEDI_CB_OVERFLOW),
+       COMEDI_CB_CANCEL_MASK   = (COMEDI_CB_EOA | COMEDI_CB_ERROR_MASK)
+};
+
+/**
+ * struct comedi_driver - COMEDI driver registration
+ * @driver_name: Name of driver.
+ * @module: Owning module.
+ * @attach: The optional "attach" handler for manually configured COMEDI
+ *     devices.
+ * @detach: The "detach" handler for deconfiguring COMEDI devices.
+ * @auto_attach: The optional "auto_attach" handler for automatically
+ *     configured COMEDI devices.
+ * @num_names: Optional number of "board names" supported.
+ * @board_name: Optional pointer to a pointer to a board name.  The pointer
+ *     to a board name is embedded in an element of a driver-defined array
+ *     of static, read-only board type information.
+ * @offset: Optional size of each element of the driver-defined array of
+ *     static, read-only board type information, i.e. the offset between each
+ *     pointer to a board name.
+ *
+ * This is used with comedi_driver_register() and comedi_driver_unregister() to
+ * register and unregister a low-level COMEDI driver with the COMEDI core.
+ *
+ * If @num_names is non-zero, @board_name should be non-NULL, and @offset
+ * should be at least sizeof(*board_name).  These are used by the handler for
+ * the %COMEDI_DEVCONFIG ioctl to match a hardware device and its driver by
+ * board name.  If @num_names is zero, the %COMEDI_DEVCONFIG ioctl matches a
+ * hardware device and its driver by driver name.  This is only useful if the
+ * @attach handler is set.  If @num_names is non-zero, the driver's @attach
+ * handler will be called with the COMEDI device structure's board_ptr member
+ * pointing to the matched pointer to a board name within the driver's private
+ * array of static, read-only board type information.
+ *
+ * The @detach handler has two roles.  If a COMEDI device was successfully
+ * configured by the @attach or @auto_attach handler, it is called when the
+ * device is being deconfigured (by the %COMEDI_DEVCONFIG ioctl, or due to
+ * unloading of the driver, or due to device removal).  It is also called when
+ * the @attach or @auto_attach handler returns an error.  Therefore, the
+ * @attach or @auto_attach handlers can defer clean-up on error until the
+ * @detach handler is called.  If the @attach or @auto_attach handlers free
+ * any resources themselves, they must prevent the @detach handler from
+ * freeing the same resources.  The @detach handler must not assume that all
+ * resources requested by the @attach or @auto_attach handler were
+ * successfully allocated.
+ */
+struct comedi_driver {
+       /* private: */
+       struct comedi_driver *next;     /* Next in list of COMEDI drivers. */
+       /* public: */
+       const char *driver_name;
+       struct module *module;
+       int (*attach)(struct comedi_device *dev, struct comedi_devconfig *it);
+       void (*detach)(struct comedi_device *dev);
+       int (*auto_attach)(struct comedi_device *dev, unsigned long context);
+       unsigned int num_names;
+       const char *const *board_name;
+       int offset;
+};
+
+/**
+ * struct comedi_device - Working data for a COMEDI device
+ * @use_count: Number of open file objects.
+ * @driver: Low-level COMEDI driver attached to this COMEDI device.
+ * @pacer: Optional pointer to a dynamically allocated acquisition pacer
+ *     control.  It is freed automatically after the COMEDI device is
+ *     detached from the low-level driver.
+ * @private: Optional pointer to private data allocated by the low-level
+ *     driver.  It is freed automatically after the COMEDI device is
+ *     detached from the low-level driver.
+ * @class_dev: Sysfs comediX device.
+ * @minor: Minor device number of COMEDI char device (0-47).
+ * @detach_count: Counter incremented every time the COMEDI device is detached.
+ *     Used for checking a previous attachment is still valid.
+ * @hw_dev: Optional pointer to the low-level hardware &struct device.  It is
+ *     required for automatically configured COMEDI devices and optional for
+ *     COMEDI devices configured by the %COMEDI_DEVCONFIG ioctl, although
+ *     the bus-specific COMEDI functions only work if it is set correctly.
+ *     It is also passed to dma_alloc_coherent() for COMEDI subdevices that
+ *     have their 'async_dma_dir' member set to something other than
+ *     %DMA_NONE.
+ * @board_name: Pointer to a COMEDI board name or a COMEDI driver name.  When
+ *     the low-level driver's "attach" handler is called by the handler for
+ *     the %COMEDI_DEVCONFIG ioctl, it either points to a matched board name
+ *     string if the 'num_names' member of the &struct comedi_driver is
+ *     non-zero, otherwise it points to the low-level driver name string.
+ *     When the low-lever driver's "auto_attach" handler is called for an
+ *     automatically configured COMEDI device, it points to the low-level
+ *     driver name string.  The low-level driver is free to change it in its
+ *     "attach" or "auto_attach" handler if it wishes.
+ * @board_ptr: Optional pointer to private, read-only board type information in
+ *     the low-level driver.  If the 'num_names' member of the &struct
+ *     comedi_driver is non-zero, the handler for the %COMEDI_DEVCONFIG ioctl
+ *     will point it to a pointer to a matched board name string within the
+ *     driver's private array of static, read-only board type information when
+ *     calling the driver's "attach" handler.  The low-level driver is free to
+ *     change it.
+ * @attached: Flag indicating that the COMEDI device is attached to a low-level
+ *     driver.
+ * @ioenabled: Flag used to indicate that a PCI device has been enabled and
+ *     its regions requested.
+ * @spinlock: Generic spin-lock for use by the low-level driver.
+ * @mutex: Generic mutex for use by the COMEDI core module.
+ * @attach_lock: &struct rw_semaphore used to guard against the COMEDI device
+ *     being detached while an operation is in progress.  The down_write()
+ *     operation is only allowed while @mutex is held and is used when
+ *     changing @attached and @detach_count and calling the low-level driver's
+ *     "detach" handler.  The down_read() operation is generally used without
+ *     holding @mutex.
+ * @refcount: &struct kref reference counter for freeing COMEDI device.
+ * @n_subdevices: Number of COMEDI subdevices allocated by the low-level
+ *     driver for this device.
+ * @subdevices: Dynamically allocated array of COMEDI subdevices.
+ * @mmio: Optional pointer to a remapped MMIO region set by the low-level
+ *     driver.
+ * @iobase: Optional base of an I/O port region requested by the low-level
+ *     driver.
+ * @iolen: Length of I/O port region requested at @iobase.
+ * @irq: Optional IRQ number requested by the low-level driver.
+ * @read_subdev: Optional pointer to a default COMEDI subdevice operated on by
+ *     the read() file operation.  Set by the low-level driver.
+ * @write_subdev: Optional pointer to a default COMEDI subdevice operated on by
+ *     the write() file operation.  Set by the low-level driver.
+ * @async_queue: Storage for fasync_helper().
+ * @open: Optional pointer to a function set by the low-level driver to be
+ *     called when @use_count changes from 0 to 1.
+ * @close: Optional pointer to a function set by the low-level driver to be
+ *     called when @use_count changed from 1 to 0.
+ * @insn_device_config: Optional pointer to a handler for all sub-instructions
+ *     except %INSN_DEVICE_CONFIG_GET_ROUTES of the %INSN_DEVICE_CONFIG
+ *     instruction.  If this is not initialized by the low-level driver, a
+ *     default handler will be set during post-configuration.
+ * @get_valid_routes: Optional pointer to a handler for the
+ *     %INSN_DEVICE_CONFIG_GET_ROUTES sub-instruction of the
+ *     %INSN_DEVICE_CONFIG instruction set.  If this is not initialized by the
+ *     low-level driver, a default handler that copies zero routes back to the
+ *     user will be used.
+ *
+ * This is the main control data structure for a COMEDI device (as far as the
+ * COMEDI core is concerned).  There are two groups of COMEDI devices -
+ * "legacy" devices that are configured by the handler for the
+ * %COMEDI_DEVCONFIG ioctl, and automatically configured devices resulting
+ * from a call to comedi_auto_config() as a result of a bus driver probe in
+ * a low-level COMEDI driver.  The "legacy" COMEDI devices are allocated
+ * during module initialization if the "comedi_num_legacy_minors" module
+ * parameter is non-zero and use minor device numbers from 0 to
+ * comedi_num_legacy_minors minus one.  The automatically configured COMEDI
+ * devices are allocated on demand and use minor device numbers from
+ * comedi_num_legacy_minors to 47.
+ */
+struct comedi_device {
+       int use_count;
+       struct comedi_driver *driver;
+       struct comedi_8254 *pacer;
+       void *private;
+
+       struct device *class_dev;
+       int minor;
+       unsigned int detach_count;
+       struct device *hw_dev;
+
+       const char *board_name;
+       const void *board_ptr;
+       unsigned int attached:1;
+       unsigned int ioenabled:1;
+       spinlock_t spinlock;    /* generic spin-lock for low-level driver */
+       struct mutex mutex;     /* generic mutex for COMEDI core */
+       struct rw_semaphore attach_lock;
+       struct kref refcount;
+
+       int n_subdevices;
+       struct comedi_subdevice *subdevices;
+
+       /* dumb */
+       void __iomem *mmio;
+       unsigned long iobase;
+       unsigned long iolen;
+       unsigned int irq;
+
+       struct comedi_subdevice *read_subdev;
+       struct comedi_subdevice *write_subdev;
+
+       struct fasync_struct *async_queue;
+
+       int (*open)(struct comedi_device *dev);
+       void (*close)(struct comedi_device *dev);
+       int (*insn_device_config)(struct comedi_device *dev,
+                                 struct comedi_insn *insn, unsigned int *data);
+       unsigned int (*get_valid_routes)(struct comedi_device *dev,
+                                        unsigned int n_pairs,
+                                        unsigned int *pair_data);
+};
+
+/*
+ * function prototypes
+ */
+
+void comedi_event(struct comedi_device *dev, struct comedi_subdevice *s);
+
+struct comedi_device *comedi_dev_get_from_minor(unsigned int minor);
+int comedi_dev_put(struct comedi_device *dev);
+
+bool comedi_is_subdevice_running(struct comedi_subdevice *s);
+
+void *comedi_alloc_spriv(struct comedi_subdevice *s, size_t size);
+void comedi_set_spriv_auto_free(struct comedi_subdevice *s);
+
+int comedi_check_chanlist(struct comedi_subdevice *s,
+                         int n,
+                         unsigned int *chanlist);
+
+/* range stuff */
+
+#define RANGE(a, b)            {(a) * 1e6, (b) * 1e6, 0}
+#define RANGE_ext(a, b)                {(a) * 1e6, (b) * 1e6, RF_EXTERNAL}
+#define RANGE_mA(a, b)         {(a) * 1e6, (b) * 1e6, UNIT_mA}
+#define RANGE_unitless(a, b)   {(a) * 1e6, (b) * 1e6, 0}
+#define BIP_RANGE(a)           {-(a) * 1e6, (a) * 1e6, 0}
+#define UNI_RANGE(a)           {0, (a) * 1e6, 0}
+
+extern const struct comedi_lrange range_bipolar10;
+extern const struct comedi_lrange range_bipolar5;
+extern const struct comedi_lrange range_bipolar2_5;
+extern const struct comedi_lrange range_unipolar10;
+extern const struct comedi_lrange range_unipolar5;
+extern const struct comedi_lrange range_unipolar2_5;
+extern const struct comedi_lrange range_0_20mA;
+extern const struct comedi_lrange range_4_20mA;
+extern const struct comedi_lrange range_0_32mA;
+extern const struct comedi_lrange range_unknown;
+
+#define range_digital          range_unipolar5
+
+/**
+ * struct comedi_lrange - Describes a COMEDI range table
+ * @length: Number of entries in the range table.
+ * @range: Array of &struct comedi_krange, one for each range.
+ *
+ * Each element of @range[] describes the minimum and maximum physical range
+ * and the type of units.  Typically, the type of unit is %UNIT_volt
+ * (i.e. volts) and the minimum and maximum are in millionths of a volt.
+ * There may also be a flag that indicates the minimum and maximum are merely
+ * scale factors for an unknown, external reference.
+ */
+struct comedi_lrange {
+       int length;
+       struct comedi_krange range[];
+};
+
+/**
+ * comedi_range_is_bipolar() - Test if subdevice range is bipolar
+ * @s: COMEDI subdevice.
+ * @range: Index of range within a range table.
+ *
+ * Tests whether a range is bipolar by checking whether its minimum value
+ * is negative.
+ *
+ * Assumes @range is valid.  Does not work for subdevices using a
+ * channel-specific range table list.
+ *
+ * Return:
+ *     %true if the range is bipolar.
+ *     %false if the range is unipolar.
+ */
+static inline bool comedi_range_is_bipolar(struct comedi_subdevice *s,
+                                          unsigned int range)
+{
+       return s->range_table->range[range].min < 0;
+}
+
+/**
+ * comedi_range_is_unipolar() - Test if subdevice range is unipolar
+ * @s: COMEDI subdevice.
+ * @range: Index of range within a range table.
+ *
+ * Tests whether a range is unipolar by checking whether its minimum value
+ * is at least 0.
+ *
+ * Assumes @range is valid.  Does not work for subdevices using a
+ * channel-specific range table list.
+ *
+ * Return:
+ *     %true if the range is unipolar.
+ *     %false if the range is bipolar.
+ */
+static inline bool comedi_range_is_unipolar(struct comedi_subdevice *s,
+                                           unsigned int range)
+{
+       return s->range_table->range[range].min >= 0;
+}
+
+/**
+ * comedi_range_is_external() - Test if subdevice range is external
+ * @s: COMEDI subdevice.
+ * @range: Index of range within a range table.
+ *
+ * Tests whether a range is externally reference by checking whether its
+ * %RF_EXTERNAL flag is set.
+ *
+ * Assumes @range is valid.  Does not work for subdevices using a
+ * channel-specific range table list.
+ *
+ * Return:
+ *     %true if the range is external.
+ *     %false if the range is internal.
+ */
+static inline bool comedi_range_is_external(struct comedi_subdevice *s,
+                                           unsigned int range)
+{
+       return !!(s->range_table->range[range].flags & RF_EXTERNAL);
+}
+
+/**
+ * comedi_chan_range_is_bipolar() - Test if channel-specific range is bipolar
+ * @s: COMEDI subdevice.
+ * @chan: The channel number.
+ * @range: Index of range within a range table.
+ *
+ * Tests whether a range is bipolar by checking whether its minimum value
+ * is negative.
+ *
+ * Assumes @chan and @range are valid.  Only works for subdevices with a
+ * channel-specific range table list.
+ *
+ * Return:
+ *     %true if the range is bipolar.
+ *     %false if the range is unipolar.
+ */
+static inline bool comedi_chan_range_is_bipolar(struct comedi_subdevice *s,
+                                               unsigned int chan,
+                                               unsigned int range)
+{
+       return s->range_table_list[chan]->range[range].min < 0;
+}
+
+/**
+ * comedi_chan_range_is_unipolar() - Test if channel-specific range is unipolar
+ * @s: COMEDI subdevice.
+ * @chan: The channel number.
+ * @range: Index of range within a range table.
+ *
+ * Tests whether a range is unipolar by checking whether its minimum value
+ * is at least 0.
+ *
+ * Assumes @chan and @range are valid.  Only works for subdevices with a
+ * channel-specific range table list.
+ *
+ * Return:
+ *     %true if the range is unipolar.
+ *     %false if the range is bipolar.
+ */
+static inline bool comedi_chan_range_is_unipolar(struct comedi_subdevice *s,
+                                                unsigned int chan,
+                                                unsigned int range)
+{
+       return s->range_table_list[chan]->range[range].min >= 0;
+}
+
+/**
+ * comedi_chan_range_is_external() - Test if channel-specific range is external
+ * @s: COMEDI subdevice.
+ * @chan: The channel number.
+ * @range: Index of range within a range table.
+ *
+ * Tests whether a range is externally reference by checking whether its
+ * %RF_EXTERNAL flag is set.
+ *
+ * Assumes @chan and @range are valid.  Only works for subdevices with a
+ * channel-specific range table list.
+ *
+ * Return:
+ *     %true if the range is bipolar.
+ *     %false if the range is unipolar.
+ */
+static inline bool comedi_chan_range_is_external(struct comedi_subdevice *s,
+                                                unsigned int chan,
+                                                unsigned int range)
+{
+       return !!(s->range_table_list[chan]->range[range].flags & RF_EXTERNAL);
+}
+
+/**
+ * comedi_offset_munge() - Convert between offset binary and 2's complement
+ * @s: COMEDI subdevice.
+ * @val: Value to be converted.
+ *
+ * Toggles the highest bit of a sample value to toggle between offset binary
+ * and 2's complement.  Assumes that @s->maxdata is a power of 2 minus 1.
+ *
+ * Return: The converted value.
+ */
+static inline unsigned int comedi_offset_munge(struct comedi_subdevice *s,
+                                              unsigned int val)
+{
+       return val ^ s->maxdata ^ (s->maxdata >> 1);
+}
+
+/**
+ * comedi_bytes_per_sample() - Determine subdevice sample size
+ * @s: COMEDI subdevice.
+ *
+ * The sample size will be 4 (sizeof int) or 2 (sizeof short) depending on
+ * whether the %SDF_LSAMPL subdevice flag is set or not.
+ *
+ * Return: The subdevice sample size.
+ */
+static inline unsigned int comedi_bytes_per_sample(struct comedi_subdevice *s)
+{
+       return s->subdev_flags & SDF_LSAMPL ? sizeof(int) : sizeof(short);
+}
+
+/**
+ * comedi_sample_shift() - Determine log2 of subdevice sample size
+ * @s: COMEDI subdevice.
+ *
+ * The sample size will be 4 (sizeof int) or 2 (sizeof short) depending on
+ * whether the %SDF_LSAMPL subdevice flag is set or not.  The log2 of the
+ * sample size will be 2 or 1 and can be used as the right operand of a
+ * bit-shift operator to multiply or divide something by the sample size.
+ *
+ * Return: log2 of the subdevice sample size.
+ */
+static inline unsigned int comedi_sample_shift(struct comedi_subdevice *s)
+{
+       return s->subdev_flags & SDF_LSAMPL ? 2 : 1;
+}
+
+/**
+ * comedi_bytes_to_samples() - Convert a number of bytes to a number of samples
+ * @s: COMEDI subdevice.
+ * @nbytes: Number of bytes
+ *
+ * Return: The number of bytes divided by the subdevice sample size.
+ */
+static inline unsigned int comedi_bytes_to_samples(struct comedi_subdevice *s,
+                                                  unsigned int nbytes)
+{
+       return nbytes >> comedi_sample_shift(s);
+}
+
+/**
+ * comedi_samples_to_bytes() - Convert a number of samples to a number of bytes
+ * @s: COMEDI subdevice.
+ * @nsamples: Number of samples.
+ *
+ * Return: The number of samples multiplied by the subdevice sample size.
+ * (Does not check for arithmetic overflow.)
+ */
+static inline unsigned int comedi_samples_to_bytes(struct comedi_subdevice *s,
+                                                  unsigned int nsamples)
+{
+       return nsamples << comedi_sample_shift(s);
+}
+
+/**
+ * comedi_check_trigger_src() - Trivially validate a comedi_cmd trigger source
+ * @src: Pointer to the trigger source to validate.
+ * @flags: Bitmask of valid %TRIG_* for the trigger.
+ *
+ * This is used in "step 1" of the do_cmdtest functions of comedi drivers
+ * to validate the comedi_cmd triggers. The mask of the @src against the
+ * @flags allows the userspace comedilib to pass all the comedi_cmd
+ * triggers as %TRIG_ANY and get back a bitmask of the valid trigger sources.
+ *
+ * Return:
+ *     0 if trigger sources in *@src are all supported.
+ *     -EINVAL if any trigger source in *@src is unsupported.
+ */
+static inline int comedi_check_trigger_src(unsigned int *src,
+                                          unsigned int flags)
+{
+       unsigned int orig_src = *src;
+
+       *src = orig_src & flags;
+       if (*src == TRIG_INVALID || *src != orig_src)
+               return -EINVAL;
+       return 0;
+}
+
+/**
+ * comedi_check_trigger_is_unique() - Make sure a trigger source is unique
+ * @src: The trigger source to check.
+ *
+ * Return:
+ *     0 if no more than one trigger source is set.
+ *     -EINVAL if more than one trigger source is set.
+ */
+static inline int comedi_check_trigger_is_unique(unsigned int src)
+{
+       /* this test is true if more than one _src bit is set */
+       if ((src & (src - 1)) != 0)
+               return -EINVAL;
+       return 0;
+}
+
+/**
+ * comedi_check_trigger_arg_is() - Trivially validate a trigger argument
+ * @arg: Pointer to the trigger arg to validate.
+ * @val: The value the argument should be.
+ *
+ * Forces *@arg to be @val.
+ *
+ * Return:
+ *     0 if *@arg was already @val.
+ *     -EINVAL if *@arg differed from @val.
+ */
+static inline int comedi_check_trigger_arg_is(unsigned int *arg,
+                                             unsigned int val)
+{
+       if (*arg != val) {
+               *arg = val;
+               return -EINVAL;
+       }
+       return 0;
+}
+
+/**
+ * comedi_check_trigger_arg_min() - Trivially validate a trigger argument min
+ * @arg: Pointer to the trigger arg to validate.
+ * @val: The minimum value the argument should be.
+ *
+ * Forces *@arg to be at least @val, setting it to @val if necessary.
+ *
+ * Return:
+ *     0 if *@arg was already at least @val.
+ *     -EINVAL if *@arg was less than @val.
+ */
+static inline int comedi_check_trigger_arg_min(unsigned int *arg,
+                                              unsigned int val)
+{
+       if (*arg < val) {
+               *arg = val;
+               return -EINVAL;
+       }
+       return 0;
+}
+
+/**
+ * comedi_check_trigger_arg_max() - Trivially validate a trigger argument max
+ * @arg: Pointer to the trigger arg to validate.
+ * @val: The maximum value the argument should be.
+ *
+ * Forces *@arg to be no more than @val, setting it to @val if necessary.
+ *
+ * Return:
+ *     0 if*@arg was already no more than @val.
+ *     -EINVAL if *@arg was greater than @val.
+ */
+static inline int comedi_check_trigger_arg_max(unsigned int *arg,
+                                              unsigned int val)
+{
+       if (*arg > val) {
+               *arg = val;
+               return -EINVAL;
+       }
+       return 0;
+}
+
+/*
+ * Must set dev->hw_dev if you wish to dma directly into comedi's buffer.
+ * Also useful for retrieving a previously configured hardware device of
+ * known bus type.  Set automatically for auto-configured devices.
+ * Automatically set to NULL when detaching hardware device.
+ */
+int comedi_set_hw_dev(struct comedi_device *dev, struct device *hw_dev);
+
+/**
+ * comedi_buf_n_bytes_ready - Determine amount of unread data in buffer
+ * @s: COMEDI subdevice.
+ *
+ * Determines the number of bytes of unread data in the asynchronous
+ * acquisition data buffer for a subdevice.  The data in question might not
+ * have been fully "munged" yet.
+ *
+ * Returns: The amount of unread data in bytes.
+ */
+static inline unsigned int comedi_buf_n_bytes_ready(struct comedi_subdevice *s)
+{
+       return s->async->buf_write_count - s->async->buf_read_count;
+}
+
+unsigned int comedi_buf_write_alloc(struct comedi_subdevice *s, unsigned int n);
+unsigned int comedi_buf_write_free(struct comedi_subdevice *s, unsigned int n);
+
+unsigned int comedi_buf_read_n_available(struct comedi_subdevice *s);
+unsigned int comedi_buf_read_alloc(struct comedi_subdevice *s, unsigned int n);
+unsigned int comedi_buf_read_free(struct comedi_subdevice *s, unsigned int n);
+
+unsigned int comedi_buf_write_samples(struct comedi_subdevice *s,
+                                     const void *data, unsigned int nsamples);
+unsigned int comedi_buf_read_samples(struct comedi_subdevice *s,
+                                    void *data, unsigned int nsamples);
+
+/* drivers.c - general comedi driver functions */
+
+#define COMEDI_TIMEOUT_MS      1000
+
+int comedi_timeout(struct comedi_device *dev, struct comedi_subdevice *s,
+                  struct comedi_insn *insn,
+                  int (*cb)(struct comedi_device *dev,
+                            struct comedi_subdevice *s,
+                            struct comedi_insn *insn, unsigned long context),
+                  unsigned long context);
+
+unsigned int comedi_handle_events(struct comedi_device *dev,
+                                 struct comedi_subdevice *s);
+
+int comedi_dio_insn_config(struct comedi_device *dev,
+                          struct comedi_subdevice *s,
+                          struct comedi_insn *insn, unsigned int *data,
+                          unsigned int mask);
+unsigned int comedi_dio_update_state(struct comedi_subdevice *s,
+                                    unsigned int *data);
+unsigned int comedi_bytes_per_scan_cmd(struct comedi_subdevice *s,
+                                      struct comedi_cmd *cmd);
+unsigned int comedi_bytes_per_scan(struct comedi_subdevice *s);
+unsigned int comedi_nscans_left(struct comedi_subdevice *s,
+                               unsigned int nscans);
+unsigned int comedi_nsamples_left(struct comedi_subdevice *s,
+                                 unsigned int nsamples);
+void comedi_inc_scan_progress(struct comedi_subdevice *s,
+                             unsigned int num_bytes);
+
+void *comedi_alloc_devpriv(struct comedi_device *dev, size_t size);
+int comedi_alloc_subdevices(struct comedi_device *dev, int num_subdevices);
+int comedi_alloc_subdev_readback(struct comedi_subdevice *s);
+
+int comedi_readback_insn_read(struct comedi_device *dev,
+                             struct comedi_subdevice *s,
+                             struct comedi_insn *insn, unsigned int *data);
+
+int comedi_load_firmware(struct comedi_device *dev, struct device *hw_dev,
+                        const char *name,
+                        int (*cb)(struct comedi_device *dev,
+                                  const u8 *data, size_t size,
+                                  unsigned long context),
+                        unsigned long context);
+
+int __comedi_request_region(struct comedi_device *dev,
+                           unsigned long start, unsigned long len);
+int comedi_request_region(struct comedi_device *dev,
+                         unsigned long start, unsigned long len);
+void comedi_legacy_detach(struct comedi_device *dev);
+
+int comedi_auto_config(struct device *hardware_device,
+                      struct comedi_driver *driver, unsigned long context);
+void comedi_auto_unconfig(struct device *hardware_device);
+
+int comedi_driver_register(struct comedi_driver *driver);
+void comedi_driver_unregister(struct comedi_driver *driver);
+
+/**
+ * module_comedi_driver() - Helper macro for registering a comedi driver
+ * @__comedi_driver: comedi_driver struct
+ *
+ * Helper macro for comedi drivers which do not do anything special in module
+ * init/exit. This eliminates a lot of boilerplate. Each module may only use
+ * this macro once, and calling it replaces module_init() and module_exit().
+ */
+#define module_comedi_driver(__comedi_driver) \
+       module_driver(__comedi_driver, comedi_driver_register, \
+                       comedi_driver_unregister)
+
+#endif /* _COMEDIDEV_H */
diff --git a/include/linux/comedi/comedilib.h b/include/linux/comedi/comedilib.h
new file mode 100644 (file)
index 0000000..0223c9c
--- /dev/null
@@ -0,0 +1,26 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * comedilib.h
+ * Header file for kcomedilib
+ *
+ * COMEDI - Linux Control and Measurement Device Interface
+ * Copyright (C) 1998-2001 David A. Schleef <ds@schleef.org>
+ */
+
+#ifndef _LINUX_COMEDILIB_H
+#define _LINUX_COMEDILIB_H
+
+struct comedi_device *comedi_open(const char *path);
+int comedi_close(struct comedi_device *dev);
+int comedi_dio_get_config(struct comedi_device *dev, unsigned int subdev,
+                         unsigned int chan, unsigned int *io);
+int comedi_dio_config(struct comedi_device *dev, unsigned int subdev,
+                     unsigned int chan, unsigned int io);
+int comedi_dio_bitfield2(struct comedi_device *dev, unsigned int subdev,
+                        unsigned int mask, unsigned int *bits,
+                        unsigned int base_channel);
+int comedi_find_subdevice_by_type(struct comedi_device *dev, int type,
+                                 unsigned int subd);
+int comedi_get_n_channels(struct comedi_device *dev, unsigned int subdevice);
+
+#endif
index 47fd4e5..077e894 100644 (file)
@@ -2,7 +2,7 @@
 /*
  * Xilinx Zynq MPSoC Firmware layer
  *
- *  Copyright (C) 2014-2019 Xilinx
+ *  Copyright (C) 2014-2021 Xilinx
  *
  *  Michal Simek <michal.simek@xilinx.com>
  *  Davorin Mista <davorin.mista@aggios.com>
 #define XILINX_ZYNQMP_PM_FPGA_FULL     0x0U
 #define XILINX_ZYNQMP_PM_FPGA_PARTIAL  BIT(0)
 
+/*
+ * Node IDs for the Error Events.
+ */
+#define EVENT_ERROR_PMC_ERR1   (0x28100000U)
+#define EVENT_ERROR_PMC_ERR2   (0x28104000U)
+#define EVENT_ERROR_PSM_ERR1   (0x28108000U)
+#define EVENT_ERROR_PSM_ERR2   (0x2810C000U)
+
+enum pm_api_cb_id {
+       PM_INIT_SUSPEND_CB = 30,
+       PM_ACKNOWLEDGE_CB = 31,
+       PM_NOTIFY_CB = 32,
+};
+
 enum pm_api_id {
        PM_GET_API_VERSION = 1,
+       PM_REGISTER_NOTIFIER = 5,
        PM_SYSTEM_SHUTDOWN = 12,
        PM_REQUEST_NODE = 13,
        PM_RELEASE_NODE = 14,
@@ -427,6 +442,9 @@ int zynqmp_pm_pinctrl_get_config(const u32 pin, const u32 param,
 int zynqmp_pm_pinctrl_set_config(const u32 pin, const u32 param,
                                 u32 value);
 int zynqmp_pm_load_pdi(const u32 src, const u64 address);
+int zynqmp_pm_register_notifier(const u32 node, const u32 event,
+                               const u32 wake, const u32 enable);
+int zynqmp_pm_feature(const u32 api_id);
 #else
 static inline int zynqmp_pm_get_api_version(u32 *version)
 {
@@ -658,6 +676,17 @@ static inline int zynqmp_pm_load_pdi(const u32 src, const u64 address)
 {
        return -ENODEV;
 }
+
+static inline int zynqmp_pm_register_notifier(const u32 node, const u32 event,
+                                             const u32 wake, const u32 enable)
+{
+       return -ENODEV;
+}
+
+static inline int zynqmp_pm_feature(const u32 api_id)
+{
+       return -ENODEV;
+}
 #endif
 
 #endif /* __FIRMWARE_ZYNQMP_H__ */
diff --git a/include/uapi/linux/comedi.h b/include/uapi/linux/comedi.h
new file mode 100644 (file)
index 0000000..7314e5e
--- /dev/null
@@ -0,0 +1,1528 @@
+/* SPDX-License-Identifier: LGPL-2.0+ WITH Linux-syscall-note */
+/*
+ * comedi.h
+ * header file for COMEDI user API
+ *
+ * COMEDI - Linux Control and Measurement Device Interface
+ * Copyright (C) 1998-2001 David A. Schleef <ds@schleef.org>
+ */
+
+#ifndef _COMEDI_H
+#define _COMEDI_H
+
+#define COMEDI_MAJORVERSION    0
+#define COMEDI_MINORVERSION    7
+#define COMEDI_MICROVERSION    76
+#define VERSION        "0.7.76"
+
+/* comedi's major device number */
+#define COMEDI_MAJOR 98
+
+/*
+ * maximum number of minor devices.  This can be increased, although
+ * kernel structures are currently statically allocated, thus you
+ * don't want this to be much more than you actually use.
+ */
+#define COMEDI_NDEVICES 16
+
+/* number of config options in the config structure */
+#define COMEDI_NDEVCONFOPTS 32
+
+/*
+ * NOTE: 'comedi_config --init-data' is deprecated
+ *
+ * The following indexes in the config options were used by
+ * comedi_config to pass firmware blobs from user space to the
+ * comedi drivers. The request_firmware() hotplug interface is
+ * now used by all comedi drivers instead.
+ */
+
+/* length of nth chunk of firmware data -*/
+#define COMEDI_DEVCONF_AUX_DATA3_LENGTH                25
+#define COMEDI_DEVCONF_AUX_DATA2_LENGTH                26
+#define COMEDI_DEVCONF_AUX_DATA1_LENGTH                27
+#define COMEDI_DEVCONF_AUX_DATA0_LENGTH                28
+/* most significant 32 bits of pointer address (if needed) */
+#define COMEDI_DEVCONF_AUX_DATA_HI             29
+/* least significant 32 bits of pointer address */
+#define COMEDI_DEVCONF_AUX_DATA_LO             30
+#define COMEDI_DEVCONF_AUX_DATA_LENGTH         31      /* total data length */
+
+/* max length of device and driver names */
+#define COMEDI_NAMELEN 20
+
+/* packs and unpacks a channel/range number */
+
+#define CR_PACK(chan, rng, aref)                                       \
+       ((((aref) & 0x3) << 24) | (((rng) & 0xff) << 16) | (chan))
+#define CR_PACK_FLAGS(chan, range, aref, flags)                                \
+       (CR_PACK(chan, range, aref) | ((flags) & CR_FLAGS_MASK))
+
+#define CR_CHAN(a)     ((a) & 0xffff)
+#define CR_RANGE(a)    (((a) >> 16) & 0xff)
+#define CR_AREF(a)     (((a) >> 24) & 0x03)
+
+#define CR_FLAGS_MASK  0xfc000000
+#define CR_ALT_FILTER  0x04000000
+#define CR_DITHER      CR_ALT_FILTER
+#define CR_DEGLITCH    CR_ALT_FILTER
+#define CR_ALT_SOURCE  0x08000000
+#define CR_EDGE                0x40000000
+#define CR_INVERT      0x80000000
+
+#define AREF_GROUND    0x00    /* analog ref = analog ground */
+#define AREF_COMMON    0x01    /* analog ref = analog common */
+#define AREF_DIFF      0x02    /* analog ref = differential */
+#define AREF_OTHER     0x03    /* analog ref = other (undefined) */
+
+/* counters -- these are arbitrary values */
+#define GPCT_RESET             0x0001
+#define GPCT_SET_SOURCE                0x0002
+#define GPCT_SET_GATE          0x0004
+#define GPCT_SET_DIRECTION     0x0008
+#define GPCT_SET_OPERATION     0x0010
+#define GPCT_ARM               0x0020
+#define GPCT_DISARM            0x0040
+#define GPCT_GET_INT_CLK_FRQ   0x0080
+
+#define GPCT_INT_CLOCK         0x0001
+#define GPCT_EXT_PIN           0x0002
+#define GPCT_NO_GATE           0x0004
+#define GPCT_UP                        0x0008
+#define GPCT_DOWN              0x0010
+#define GPCT_HWUD              0x0020
+#define GPCT_SIMPLE_EVENT      0x0040
+#define GPCT_SINGLE_PERIOD     0x0080
+#define GPCT_SINGLE_PW         0x0100
+#define GPCT_CONT_PULSE_OUT    0x0200
+#define GPCT_SINGLE_PULSE_OUT  0x0400
+
+/* instructions */
+
+#define INSN_MASK_WRITE                0x8000000
+#define INSN_MASK_READ         0x4000000
+#define INSN_MASK_SPECIAL      0x2000000
+
+#define INSN_READ              (0 | INSN_MASK_READ)
+#define INSN_WRITE             (1 | INSN_MASK_WRITE)
+#define INSN_BITS              (2 | INSN_MASK_READ | INSN_MASK_WRITE)
+#define INSN_CONFIG            (3 | INSN_MASK_READ | INSN_MASK_WRITE)
+#define INSN_DEVICE_CONFIG     (INSN_CONFIG | INSN_MASK_SPECIAL)
+#define INSN_GTOD              (4 | INSN_MASK_READ | INSN_MASK_SPECIAL)
+#define INSN_WAIT              (5 | INSN_MASK_WRITE | INSN_MASK_SPECIAL)
+#define INSN_INTTRIG           (6 | INSN_MASK_WRITE | INSN_MASK_SPECIAL)
+
+/* command flags */
+/* These flags are used in comedi_cmd structures */
+
+#define CMDF_BOGUS             0x00000001      /* do the motions */
+
+/* try to use a real-time interrupt while performing command */
+#define CMDF_PRIORITY          0x00000008
+
+/* wake up on end-of-scan events */
+#define CMDF_WAKE_EOS          0x00000020
+
+#define CMDF_WRITE             0x00000040
+
+#define CMDF_RAWDATA           0x00000080
+
+/* timer rounding definitions */
+#define CMDF_ROUND_MASK                0x00030000
+#define CMDF_ROUND_NEAREST     0x00000000
+#define CMDF_ROUND_DOWN                0x00010000
+#define CMDF_ROUND_UP          0x00020000
+#define CMDF_ROUND_UP_NEXT     0x00030000
+
+#define COMEDI_EV_START                0x00040000
+#define COMEDI_EV_SCAN_BEGIN   0x00080000
+#define COMEDI_EV_CONVERT      0x00100000
+#define COMEDI_EV_SCAN_END     0x00200000
+#define COMEDI_EV_STOP         0x00400000
+
+/* compatibility definitions */
+#define TRIG_BOGUS             CMDF_BOGUS
+#define TRIG_RT                        CMDF_PRIORITY
+#define TRIG_WAKE_EOS          CMDF_WAKE_EOS
+#define TRIG_WRITE             CMDF_WRITE
+#define TRIG_ROUND_MASK                CMDF_ROUND_MASK
+#define TRIG_ROUND_NEAREST     CMDF_ROUND_NEAREST
+#define TRIG_ROUND_DOWN                CMDF_ROUND_DOWN
+#define TRIG_ROUND_UP          CMDF_ROUND_UP
+#define TRIG_ROUND_UP_NEXT     CMDF_ROUND_UP_NEXT
+
+/* trigger sources */
+
+#define TRIG_ANY       0xffffffff
+#define TRIG_INVALID   0x00000000
+
+#define TRIG_NONE      0x00000001 /* never trigger */
+#define TRIG_NOW       0x00000002 /* trigger now + N ns */
+#define TRIG_FOLLOW    0x00000004 /* trigger on next lower level trig */
+#define TRIG_TIME      0x00000008 /* trigger at time N ns */
+#define TRIG_TIMER     0x00000010 /* trigger at rate N ns */
+#define TRIG_COUNT     0x00000020 /* trigger when count reaches N */
+#define TRIG_EXT       0x00000040 /* trigger on external signal N */
+#define TRIG_INT       0x00000080 /* trigger on comedi-internal signal N */
+#define TRIG_OTHER     0x00000100 /* driver defined */
+
+/* subdevice flags */
+
+#define SDF_BUSY       0x0001  /* device is busy */
+#define SDF_BUSY_OWNER 0x0002  /* device is busy with your job */
+#define SDF_LOCKED     0x0004  /* subdevice is locked */
+#define SDF_LOCK_OWNER 0x0008  /* you own lock */
+#define SDF_MAXDATA    0x0010  /* maxdata depends on channel */
+#define SDF_FLAGS      0x0020  /* flags depend on channel */
+#define SDF_RANGETYPE  0x0040  /* range type depends on channel */
+#define SDF_PWM_COUNTER 0x0080 /* PWM can automatically switch off */
+#define SDF_PWM_HBRIDGE 0x0100 /* PWM is signed (H-bridge) */
+#define SDF_CMD                0x1000  /* can do commands (deprecated) */
+#define SDF_SOFT_CALIBRATED    0x2000 /* subdevice uses software calibration */
+#define SDF_CMD_WRITE          0x4000 /* can do output commands */
+#define SDF_CMD_READ           0x8000 /* can do input commands */
+
+/* subdevice can be read (e.g. analog input) */
+#define SDF_READABLE   0x00010000
+/* subdevice can be written (e.g. analog output) */
+#define SDF_WRITABLE   0x00020000
+#define SDF_WRITEABLE  SDF_WRITABLE    /* spelling error in API */
+/* subdevice does not have externally visible lines */
+#define SDF_INTERNAL   0x00040000
+#define SDF_GROUND     0x00100000      /* can do aref=ground */
+#define SDF_COMMON     0x00200000      /* can do aref=common */
+#define SDF_DIFF       0x00400000      /* can do aref=diff */
+#define SDF_OTHER      0x00800000      /* can do aref=other */
+#define SDF_DITHER     0x01000000      /* can do dithering */
+#define SDF_DEGLITCH   0x02000000      /* can do deglitching */
+#define SDF_MMAP       0x04000000      /* can do mmap() */
+#define SDF_RUNNING    0x08000000      /* subdevice is acquiring data */
+#define SDF_LSAMPL     0x10000000      /* subdevice uses 32-bit samples */
+#define SDF_PACKED     0x20000000      /* subdevice can do packed DIO */
+
+/* subdevice types */
+
+/**
+ * enum comedi_subdevice_type - COMEDI subdevice types
+ * @COMEDI_SUBD_UNUSED:                Unused subdevice.
+ * @COMEDI_SUBD_AI:            Analog input.
+ * @COMEDI_SUBD_AO:            Analog output.
+ * @COMEDI_SUBD_DI:            Digital input.
+ * @COMEDI_SUBD_DO:            Digital output.
+ * @COMEDI_SUBD_DIO:           Digital input/output.
+ * @COMEDI_SUBD_COUNTER:       Counter.
+ * @COMEDI_SUBD_TIMER:         Timer.
+ * @COMEDI_SUBD_MEMORY:                Memory, EEPROM, DPRAM.
+ * @COMEDI_SUBD_CALIB:         Calibration DACs.
+ * @COMEDI_SUBD_PROC:          Processor, DSP.
+ * @COMEDI_SUBD_SERIAL:                Serial I/O.
+ * @COMEDI_SUBD_PWM:           Pulse-Width Modulation output.
+ */
+enum comedi_subdevice_type {
+       COMEDI_SUBD_UNUSED,
+       COMEDI_SUBD_AI,
+       COMEDI_SUBD_AO,
+       COMEDI_SUBD_DI,
+       COMEDI_SUBD_DO,
+       COMEDI_SUBD_DIO,
+       COMEDI_SUBD_COUNTER,
+       COMEDI_SUBD_TIMER,
+       COMEDI_SUBD_MEMORY,
+       COMEDI_SUBD_CALIB,
+       COMEDI_SUBD_PROC,
+       COMEDI_SUBD_SERIAL,
+       COMEDI_SUBD_PWM
+};
+
+/* configuration instructions */
+
+/**
+ * enum comedi_io_direction - COMEDI I/O directions
+ * @COMEDI_INPUT:      Input.
+ * @COMEDI_OUTPUT:     Output.
+ * @COMEDI_OPENDRAIN:  Open-drain (or open-collector) output.
+ *
+ * These are used by the %INSN_CONFIG_DIO_QUERY configuration instruction to
+ * report a direction.  They may also be used in other places where a direction
+ * needs to be specified.
+ */
+enum comedi_io_direction {
+       COMEDI_INPUT = 0,
+       COMEDI_OUTPUT = 1,
+       COMEDI_OPENDRAIN = 2
+};
+
+/**
+ * enum configuration_ids - COMEDI configuration instruction codes
+ * @INSN_CONFIG_DIO_INPUT:     Configure digital I/O as input.
+ * @INSN_CONFIG_DIO_OUTPUT:    Configure digital I/O as output.
+ * @INSN_CONFIG_DIO_OPENDRAIN: Configure digital I/O as open-drain (or open
+ *                             collector) output.
+ * @INSN_CONFIG_ANALOG_TRIG:   Configure analog trigger.
+ * @INSN_CONFIG_ALT_SOURCE:    Configure alternate input source.
+ * @INSN_CONFIG_DIGITAL_TRIG:  Configure digital trigger.
+ * @INSN_CONFIG_BLOCK_SIZE:    Configure block size for DMA transfers.
+ * @INSN_CONFIG_TIMER_1:       Configure divisor for external clock.
+ * @INSN_CONFIG_FILTER:                Configure a filter.
+ * @INSN_CONFIG_CHANGE_NOTIFY: Configure change notification for digital
+ *                             inputs.  (New drivers should use
+ *                             %INSN_CONFIG_DIGITAL_TRIG instead.)
+ * @INSN_CONFIG_SERIAL_CLOCK:  Configure clock for serial I/O.
+ * @INSN_CONFIG_BIDIRECTIONAL_DATA: Send and receive byte over serial I/O.
+ * @INSN_CONFIG_DIO_QUERY:     Query direction of digital I/O channel.
+ * @INSN_CONFIG_PWM_OUTPUT:    Configure pulse-width modulator output.
+ * @INSN_CONFIG_GET_PWM_OUTPUT:        Get pulse-width modulator output configuration.
+ * @INSN_CONFIG_ARM:           Arm a subdevice or channel.
+ * @INSN_CONFIG_DISARM:                Disarm a subdevice or channel.
+ * @INSN_CONFIG_GET_COUNTER_STATUS: Get counter status.
+ * @INSN_CONFIG_RESET:         Reset a subdevice or channel.
+ * @INSN_CONFIG_GPCT_SINGLE_PULSE_GENERATOR: Configure counter/timer as
+ *                             single pulse generator.
+ * @INSN_CONFIG_GPCT_PULSE_TRAIN_GENERATOR: Configure counter/timer as
+ *                             pulse train generator.
+ * @INSN_CONFIG_GPCT_QUADRATURE_ENCODER: Configure counter as a quadrature
+ *                             encoder.
+ * @INSN_CONFIG_SET_GATE_SRC:  Set counter/timer gate source.
+ * @INSN_CONFIG_GET_GATE_SRC:  Get counter/timer gate source.
+ * @INSN_CONFIG_SET_CLOCK_SRC: Set counter/timer master clock source.
+ * @INSN_CONFIG_GET_CLOCK_SRC: Get counter/timer master clock source.
+ * @INSN_CONFIG_SET_OTHER_SRC: Set counter/timer "other" source.
+ * @INSN_CONFIG_GET_HARDWARE_BUFFER_SIZE: Get size (in bytes) of subdevice's
+ *                             on-board FIFOs used during streaming
+ *                             input/output.
+ * @INSN_CONFIG_SET_COUNTER_MODE: Set counter/timer mode.
+ * @INSN_CONFIG_8254_SET_MODE: (Deprecated) Same as
+ *                             %INSN_CONFIG_SET_COUNTER_MODE.
+ * @INSN_CONFIG_8254_READ_STATUS: Read status of 8254 counter channel.
+ * @INSN_CONFIG_SET_ROUTING:   Set routing for a channel.
+ * @INSN_CONFIG_GET_ROUTING:   Get routing for a channel.
+ * @INSN_CONFIG_PWM_SET_PERIOD: Set PWM period in nanoseconds.
+ * @INSN_CONFIG_PWM_GET_PERIOD: Get PWM period in nanoseconds.
+ * @INSN_CONFIG_GET_PWM_STATUS: Get PWM status.
+ * @INSN_CONFIG_PWM_SET_H_BRIDGE: Set PWM H bridge duty cycle and polarity for
+ *                             a relay simultaneously.
+ * @INSN_CONFIG_PWM_GET_H_BRIDGE: Get PWM H bridge duty cycle and polarity.
+ * @INSN_CONFIG_GET_CMD_TIMING_CONSTRAINTS: Get the hardware timing restraints,
+ *                             regardless of trigger sources.
+ */
+enum configuration_ids {
+       INSN_CONFIG_DIO_INPUT = COMEDI_INPUT,
+       INSN_CONFIG_DIO_OUTPUT = COMEDI_OUTPUT,
+       INSN_CONFIG_DIO_OPENDRAIN = COMEDI_OPENDRAIN,
+       INSN_CONFIG_ANALOG_TRIG = 16,
+/*     INSN_CONFIG_WAVEFORM = 17, */
+/*     INSN_CONFIG_TRIG = 18, */
+/*     INSN_CONFIG_COUNTER = 19, */
+       INSN_CONFIG_ALT_SOURCE = 20,
+       INSN_CONFIG_DIGITAL_TRIG = 21,
+       INSN_CONFIG_BLOCK_SIZE = 22,
+       INSN_CONFIG_TIMER_1 = 23,
+       INSN_CONFIG_FILTER = 24,
+       INSN_CONFIG_CHANGE_NOTIFY = 25,
+
+       INSN_CONFIG_SERIAL_CLOCK = 26,  /*ALPHA*/
+       INSN_CONFIG_BIDIRECTIONAL_DATA = 27,
+       INSN_CONFIG_DIO_QUERY = 28,
+       INSN_CONFIG_PWM_OUTPUT = 29,
+       INSN_CONFIG_GET_PWM_OUTPUT = 30,
+       INSN_CONFIG_ARM = 31,
+       INSN_CONFIG_DISARM = 32,
+       INSN_CONFIG_GET_COUNTER_STATUS = 33,
+       INSN_CONFIG_RESET = 34,
+       INSN_CONFIG_GPCT_SINGLE_PULSE_GENERATOR = 1001,
+       INSN_CONFIG_GPCT_PULSE_TRAIN_GENERATOR = 1002,
+       INSN_CONFIG_GPCT_QUADRATURE_ENCODER = 1003,
+       INSN_CONFIG_SET_GATE_SRC = 2001,
+       INSN_CONFIG_GET_GATE_SRC = 2002,
+       INSN_CONFIG_SET_CLOCK_SRC = 2003,
+       INSN_CONFIG_GET_CLOCK_SRC = 2004,
+       INSN_CONFIG_SET_OTHER_SRC = 2005,
+       INSN_CONFIG_GET_HARDWARE_BUFFER_SIZE = 2006,
+       INSN_CONFIG_SET_COUNTER_MODE = 4097,
+       INSN_CONFIG_8254_SET_MODE = INSN_CONFIG_SET_COUNTER_MODE,
+       INSN_CONFIG_8254_READ_STATUS = 4098,
+       INSN_CONFIG_SET_ROUTING = 4099,
+       INSN_CONFIG_GET_ROUTING = 4109,
+       INSN_CONFIG_PWM_SET_PERIOD = 5000,
+       INSN_CONFIG_PWM_GET_PERIOD = 5001,
+       INSN_CONFIG_GET_PWM_STATUS = 5002,
+       INSN_CONFIG_PWM_SET_H_BRIDGE = 5003,
+       INSN_CONFIG_PWM_GET_H_BRIDGE = 5004,
+       INSN_CONFIG_GET_CMD_TIMING_CONSTRAINTS = 5005,
+};
+
+/**
+ * enum device_configuration_ids - COMEDI configuration instruction codes global
+ * to an entire device.
+ * @INSN_DEVICE_CONFIG_TEST_ROUTE:     Validate the possibility of a
+ *                                     globally-named route
+ * @INSN_DEVICE_CONFIG_CONNECT_ROUTE:  Connect a globally-named route
+ * @INSN_DEVICE_CONFIG_DISCONNECT_ROUTE:Disconnect a globally-named route
+ * @INSN_DEVICE_CONFIG_GET_ROUTES:     Get a list of all globally-named routes
+ *                                     that are valid for a particular device.
+ */
+enum device_config_route_ids {
+       INSN_DEVICE_CONFIG_TEST_ROUTE = 0,
+       INSN_DEVICE_CONFIG_CONNECT_ROUTE = 1,
+       INSN_DEVICE_CONFIG_DISCONNECT_ROUTE = 2,
+       INSN_DEVICE_CONFIG_GET_ROUTES = 3,
+};
+
+/**
+ * enum comedi_digital_trig_op - operations for configuring a digital trigger
+ * @COMEDI_DIGITAL_TRIG_DISABLE:       Return digital trigger to its default,
+ *                                     inactive, unconfigured state.
+ * @COMEDI_DIGITAL_TRIG_ENABLE_EDGES:  Set rising and/or falling edge inputs
+ *                                     that each can fire the trigger.
+ * @COMEDI_DIGITAL_TRIG_ENABLE_LEVELS: Set a combination of high and/or low
+ *                                     level inputs that can fire the trigger.
+ *
+ * These are used with the %INSN_CONFIG_DIGITAL_TRIG configuration instruction.
+ * The data for the configuration instruction is as follows...
+ *
+ *   data[%0] = %INSN_CONFIG_DIGITAL_TRIG
+ *
+ *   data[%1] = trigger ID
+ *
+ *   data[%2] = configuration operation
+ *
+ *   data[%3] = configuration parameter 1
+ *
+ *   data[%4] = configuration parameter 2
+ *
+ *   data[%5] = configuration parameter 3
+ *
+ * The trigger ID (data[%1]) is used to differentiate multiple digital triggers
+ * belonging to the same subdevice.  The configuration operation (data[%2]) is
+ * one of the enum comedi_digital_trig_op values.  The configuration
+ * parameters (data[%3], data[%4], and data[%5]) depend on the operation; they
+ * are not used with %COMEDI_DIGITAL_TRIG_DISABLE.
+ *
+ * For %COMEDI_DIGITAL_TRIG_ENABLE_EDGES and %COMEDI_DIGITAL_TRIG_ENABLE_LEVELS,
+ * configuration parameter 1 (data[%3]) contains a "left-shift" value that
+ * specifies the input corresponding to bit 0 of configuration parameters 2
+ * and 3.  This is useful if the trigger has more than 32 inputs.
+ *
+ * For %COMEDI_DIGITAL_TRIG_ENABLE_EDGES, configuration parameter 2 (data[%4])
+ * specifies which of up to 32 inputs have rising-edge sensitivity, and
+ * configuration parameter 3 (data[%5]) specifies which of up to 32 inputs
+ * have falling-edge sensitivity that can fire the trigger.
+ *
+ * For %COMEDI_DIGITAL_TRIG_ENABLE_LEVELS, configuration parameter 2 (data[%4])
+ * specifies which of up to 32 inputs must be at a high level, and
+ * configuration parameter 3 (data[%5]) specifies which of up to 32 inputs
+ * must be at a low level for the trigger to fire.
+ *
+ * Some sequences of %INSN_CONFIG_DIGITAL_TRIG instructions may have a (partly)
+ * accumulative effect, depending on the low-level driver.  This is useful
+ * when setting up a trigger that has more than 32 inputs, or has a combination
+ * of edge- and level-triggered inputs.
+ */
+enum comedi_digital_trig_op {
+       COMEDI_DIGITAL_TRIG_DISABLE = 0,
+       COMEDI_DIGITAL_TRIG_ENABLE_EDGES = 1,
+       COMEDI_DIGITAL_TRIG_ENABLE_LEVELS = 2
+};
+
+/**
+ * enum comedi_support_level - support level for a COMEDI feature
+ * @COMEDI_UNKNOWN_SUPPORT:    Unspecified support for feature.
+ * @COMEDI_SUPPORTED:          Feature is supported.
+ * @COMEDI_UNSUPPORTED:                Feature is unsupported.
+ */
+enum comedi_support_level {
+       COMEDI_UNKNOWN_SUPPORT = 0,
+       COMEDI_SUPPORTED,
+       COMEDI_UNSUPPORTED
+};
+
+/**
+ * enum comedi_counter_status_flags - counter status bits
+ * @COMEDI_COUNTER_ARMED:              Counter is armed.
+ * @COMEDI_COUNTER_COUNTING:           Counter is counting.
+ * @COMEDI_COUNTER_TERMINAL_COUNT:     Counter reached terminal count.
+ *
+ * These bitwise values are used by the %INSN_CONFIG_GET_COUNTER_STATUS
+ * configuration instruction to report the status of a counter.
+ */
+enum comedi_counter_status_flags {
+       COMEDI_COUNTER_ARMED = 0x1,
+       COMEDI_COUNTER_COUNTING = 0x2,
+       COMEDI_COUNTER_TERMINAL_COUNT = 0x4,
+};
+
+/* ioctls */
+
+#define CIO 'd'
+#define COMEDI_DEVCONFIG _IOW(CIO, 0, struct comedi_devconfig)
+#define COMEDI_DEVINFO _IOR(CIO, 1, struct comedi_devinfo)
+#define COMEDI_SUBDINFO _IOR(CIO, 2, struct comedi_subdinfo)
+#define COMEDI_CHANINFO _IOR(CIO, 3, struct comedi_chaninfo)
+/* _IOWR(CIO, 4, ...) is reserved */
+#define COMEDI_LOCK _IO(CIO, 5)
+#define COMEDI_UNLOCK _IO(CIO, 6)
+#define COMEDI_CANCEL _IO(CIO, 7)
+#define COMEDI_RANGEINFO _IOR(CIO, 8, struct comedi_rangeinfo)
+#define COMEDI_CMD _IOR(CIO, 9, struct comedi_cmd)
+#define COMEDI_CMDTEST _IOR(CIO, 10, struct comedi_cmd)
+#define COMEDI_INSNLIST _IOR(CIO, 11, struct comedi_insnlist)
+#define COMEDI_INSN _IOR(CIO, 12, struct comedi_insn)
+#define COMEDI_BUFCONFIG _IOR(CIO, 13, struct comedi_bufconfig)
+#define COMEDI_BUFINFO _IOWR(CIO, 14, struct comedi_bufinfo)
+#define COMEDI_POLL _IO(CIO, 15)
+#define COMEDI_SETRSUBD _IO(CIO, 16)
+#define COMEDI_SETWSUBD _IO(CIO, 17)
+
+/* structures */
+
+/**
+ * struct comedi_insn - COMEDI instruction
+ * @insn:      COMEDI instruction type (%INSN_xxx).
+ * @n:         Length of @data[].
+ * @data:      Pointer to data array operated on by the instruction.
+ * @subdev:    Subdevice index.
+ * @chanspec:  A packed "chanspec" value consisting of channel number,
+ *             analog range index, analog reference type, and flags.
+ * @unused:    Reserved for future use.
+ *
+ * This is used with the %COMEDI_INSN ioctl, and indirectly with the
+ * %COMEDI_INSNLIST ioctl.
+ */
+struct comedi_insn {
+       unsigned int insn;
+       unsigned int n;
+       unsigned int __user *data;
+       unsigned int subdev;
+       unsigned int chanspec;
+       unsigned int unused[3];
+};
+
+/**
+ * struct comedi_insnlist - list of COMEDI instructions
+ * @n_insns:   Number of COMEDI instructions.
+ * @insns:     Pointer to array COMEDI instructions.
+ *
+ * This is used with the %COMEDI_INSNLIST ioctl.
+ */
+struct comedi_insnlist {
+       unsigned int n_insns;
+       struct comedi_insn __user *insns;
+};
+
+/**
+ * struct comedi_cmd - COMEDI asynchronous acquisition command details
+ * @subdev:            Subdevice index.
+ * @flags:             Command flags (%CMDF_xxx).
+ * @start_src:         "Start acquisition" trigger source (%TRIG_xxx).
+ * @start_arg:         "Start acquisition" trigger argument.
+ * @scan_begin_src:    "Scan begin" trigger source.
+ * @scan_begin_arg:    "Scan begin" trigger argument.
+ * @convert_src:       "Convert" trigger source.
+ * @convert_arg:       "Convert" trigger argument.
+ * @scan_end_src:      "Scan end" trigger source.
+ * @scan_end_arg:      "Scan end" trigger argument.
+ * @stop_src:          "Stop acquisition" trigger source.
+ * @stop_arg:          "Stop acquisition" trigger argument.
+ * @chanlist:          Pointer to array of "chanspec" values, containing a
+ *                     sequence of channel numbers packed with analog range
+ *                     index, etc.
+ * @chanlist_len:      Number of channels in sequence.
+ * @data:              Pointer to miscellaneous set-up data (not used).
+ * @data_len:          Length of miscellaneous set-up data.
+ *
+ * This is used with the %COMEDI_CMD or %COMEDI_CMDTEST ioctl to set-up
+ * or validate an asynchronous acquisition command.  The ioctl may modify
+ * the &struct comedi_cmd and copy it back to the caller.
+ *
+ * Optional command @flags values that can be ORed together...
+ *
+ * %CMDF_BOGUS - makes %COMEDI_CMD ioctl return error %EAGAIN instead of
+ * starting the command.
+ *
+ * %CMDF_PRIORITY - requests "hard real-time" processing (which is not
+ * supported in this version of COMEDI).
+ *
+ * %CMDF_WAKE_EOS - requests the command makes data available for reading
+ * after every "scan" period.
+ *
+ * %CMDF_WRITE - marks the command as being in the "write" (to device)
+ * direction.  This does not need to be specified by the caller unless the
+ * subdevice supports commands in either direction.
+ *
+ * %CMDF_RAWDATA - prevents the command from "munging" the data between the
+ * COMEDI sample format and the raw hardware sample format.
+ *
+ * %CMDF_ROUND_NEAREST - requests timing periods to be rounded to nearest
+ * supported values.
+ *
+ * %CMDF_ROUND_DOWN - requests timing periods to be rounded down to supported
+ * values (frequencies rounded up).
+ *
+ * %CMDF_ROUND_UP - requests timing periods to be rounded up to supported
+ * values (frequencies rounded down).
+ *
+ * Trigger source values for @start_src, @scan_begin_src, @convert_src,
+ * @scan_end_src, and @stop_src...
+ *
+ * %TRIG_ANY - "all ones" value used to test which trigger sources are
+ * supported.
+ *
+ * %TRIG_INVALID - "all zeroes" value used to indicate that all requested
+ * trigger sources are invalid.
+ *
+ * %TRIG_NONE - never trigger (often used as a @stop_src value).
+ *
+ * %TRIG_NOW - trigger after '_arg' nanoseconds.
+ *
+ * %TRIG_FOLLOW - trigger follows another event.
+ *
+ * %TRIG_TIMER - trigger every '_arg' nanoseconds.
+ *
+ * %TRIG_COUNT - trigger when count '_arg' is reached.
+ *
+ * %TRIG_EXT - trigger on external signal specified by '_arg'.
+ *
+ * %TRIG_INT - trigger on internal, software trigger specified by '_arg'.
+ *
+ * %TRIG_OTHER - trigger on other, driver-defined signal specified by '_arg'.
+ */
+struct comedi_cmd {
+       unsigned int subdev;
+       unsigned int flags;
+
+       unsigned int start_src;
+       unsigned int start_arg;
+
+       unsigned int scan_begin_src;
+       unsigned int scan_begin_arg;
+
+       unsigned int convert_src;
+       unsigned int convert_arg;
+
+       unsigned int scan_end_src;
+       unsigned int scan_end_arg;
+
+       unsigned int stop_src;
+       unsigned int stop_arg;
+
+       unsigned int *chanlist;
+       unsigned int chanlist_len;
+
+       short __user *data;
+       unsigned int data_len;
+};
+
+/**
+ * struct comedi_chaninfo - used to retrieve per-channel information
+ * @subdev:            Subdevice index.
+ * @maxdata_list:      Optional pointer to per-channel maximum data values.
+ * @flaglist:          Optional pointer to per-channel flags.
+ * @rangelist:         Optional pointer to per-channel range types.
+ * @unused:            Reserved for future use.
+ *
+ * This is used with the %COMEDI_CHANINFO ioctl to get per-channel information
+ * for the subdevice.  Use of this requires knowledge of the number of channels
+ * and subdevice flags obtained using the %COMEDI_SUBDINFO ioctl.
+ *
+ * The @maxdata_list member must be %NULL unless the %SDF_MAXDATA subdevice
+ * flag is set.  The @flaglist member must be %NULL unless the %SDF_FLAGS
+ * subdevice flag is set.  The @rangelist member must be %NULL unless the
+ * %SDF_RANGETYPE subdevice flag is set.  Otherwise, the arrays they point to
+ * must be at least as long as the number of channels.
+ */
+struct comedi_chaninfo {
+       unsigned int subdev;
+       unsigned int __user *maxdata_list;
+       unsigned int __user *flaglist;
+       unsigned int __user *rangelist;
+       unsigned int unused[4];
+};
+
+/**
+ * struct comedi_rangeinfo - used to retrieve the range table for a channel
+ * @range_type:                Encodes subdevice index (bits 27:24), channel index
+ *                     (bits 23:16) and range table length (bits 15:0).
+ * @range_ptr:         Pointer to array of @struct comedi_krange to be filled
+ *                     in with the range table for the channel or subdevice.
+ *
+ * This is used with the %COMEDI_RANGEINFO ioctl to retrieve the range table
+ * for a specific channel (if the subdevice has the %SDF_RANGETYPE flag set to
+ * indicate that the range table depends on the channel), or for the subdevice
+ * as a whole (if the %SDF_RANGETYPE flag is clear, indicating the range table
+ * is shared by all channels).
+ *
+ * The @range_type value is an input to the ioctl and comes from a previous
+ * use of the %COMEDI_SUBDINFO ioctl (if the %SDF_RANGETYPE flag is clear),
+ * or the %COMEDI_CHANINFO ioctl (if the %SDF_RANGETYPE flag is set).
+ */
+struct comedi_rangeinfo {
+       unsigned int range_type;
+       void __user *range_ptr;
+};
+
+/**
+ * struct comedi_krange - describes a range in a range table
+ * @min:       Minimum value in millionths (1e-6) of a unit.
+ * @max:       Maximum value in millionths (1e-6) of a unit.
+ * @flags:     Indicates the units (in bits 7:0) OR'ed with optional flags.
+ *
+ * A range table is associated with a single channel, or with all channels in a
+ * subdevice, and a list of one or more ranges.  A %struct comedi_krange
+ * describes the physical range of units for one of those ranges.  Sample
+ * values in COMEDI are unsigned from %0 up to some 'maxdata' value.  The
+ * mapping from sample values to physical units is assumed to be nomimally
+ * linear (for the purpose of describing the range), with sample value %0
+ * mapping to @min, and the 'maxdata' sample value mapping to @max.
+ *
+ * The currently defined units are %UNIT_volt (%0), %UNIT_mA (%1), and
+ * %UNIT_none (%2).  The @min and @max values are the physical range multiplied
+ * by 1e6, so a @max value of %1000000 (with %UNIT_volt) represents a maximal
+ * value of 1 volt.
+ *
+ * The only defined flag value is %RF_EXTERNAL (%0x100), indicating that the
+ * range needs to be multiplied by an external reference.
+ */
+struct comedi_krange {
+       int min;
+       int max;
+       unsigned int flags;
+};
+
+/**
+ * struct comedi_subdinfo - used to retrieve information about a subdevice
+ * @type:              Type of subdevice from &enum comedi_subdevice_type.
+ * @n_chan:            Number of channels the subdevice supports.
+ * @subd_flags:                A mixture of static and dynamic flags describing
+ *                     aspects of the subdevice and its current state.
+ * @timer_type:                Timer type.  Always set to %5 ("nanosecond timer").
+ * @len_chanlist:      Maximum length of a channel list if the subdevice
+ *                     supports asynchronous acquisition commands.
+ * @maxdata:           Maximum sample value for all channels if the
+ *                     %SDF_MAXDATA subdevice flag is clear.
+ * @flags:             Channel flags for all channels if the %SDF_FLAGS
+ *                     subdevice flag is clear.
+ * @range_type:                The range type for all channels if the %SDF_RANGETYPE
+ *                     subdevice flag is clear.  Encodes the subdevice index
+ *                     (bits 27:24), a dummy channel index %0 (bits 23:16),
+ *                     and the range table length (bits 15:0).
+ * @settling_time_0:   Not used.
+ * @insn_bits_support: Set to %COMEDI_SUPPORTED if the subdevice supports the
+ *                     %INSN_BITS instruction, or to %COMEDI_UNSUPPORTED if it
+ *                     does not.
+ * @unused:            Reserved for future use.
+ *
+ * This is used with the %COMEDI_SUBDINFO ioctl which copies an array of
+ * &struct comedi_subdinfo back to user space, with one element per subdevice.
+ * Use of this requires knowledge of the number of subdevices obtained from
+ * the %COMEDI_DEVINFO ioctl.
+ *
+ * These are the @subd_flags values that may be ORed together...
+ *
+ * %SDF_BUSY - the subdevice is busy processing an asynchronous command or a
+ * synchronous instruction.
+ *
+ * %SDF_BUSY_OWNER - the subdevice is busy processing an asynchronous
+ * acquisition command started on the current file object (the file object
+ * issuing the %COMEDI_SUBDINFO ioctl).
+ *
+ * %SDF_LOCKED - the subdevice is locked by a %COMEDI_LOCK ioctl.
+ *
+ * %SDF_LOCK_OWNER - the subdevice is locked by a %COMEDI_LOCK ioctl from the
+ * current file object.
+ *
+ * %SDF_MAXDATA - maximum sample values are channel-specific.
+ *
+ * %SDF_FLAGS - channel flags are channel-specific.
+ *
+ * %SDF_RANGETYPE - range types are channel-specific.
+ *
+ * %SDF_PWM_COUNTER - PWM can switch off automatically.
+ *
+ * %SDF_PWM_HBRIDGE - or PWM is signed (H-bridge).
+ *
+ * %SDF_CMD - the subdevice supports asynchronous commands.
+ *
+ * %SDF_SOFT_CALIBRATED - the subdevice uses software calibration.
+ *
+ * %SDF_CMD_WRITE - the subdevice supports asynchronous commands in the output
+ * ("write") direction.
+ *
+ * %SDF_CMD_READ - the subdevice supports asynchronous commands in the input
+ * ("read") direction.
+ *
+ * %SDF_READABLE - the subdevice is readable (e.g. analog input).
+ *
+ * %SDF_WRITABLE (aliased as %SDF_WRITEABLE) - the subdevice is writable (e.g.
+ * analog output).
+ *
+ * %SDF_INTERNAL - the subdevice has no externally visible lines.
+ *
+ * %SDF_GROUND - the subdevice can use ground as an analog reference.
+ *
+ * %SDF_COMMON - the subdevice can use a common analog reference.
+ *
+ * %SDF_DIFF - the subdevice can use differential inputs (or outputs).
+ *
+ * %SDF_OTHER - the subdevice can use some other analog reference.
+ *
+ * %SDF_DITHER - the subdevice can do dithering.
+ *
+ * %SDF_DEGLITCH - the subdevice can do deglitching.
+ *
+ * %SDF_MMAP - this is never set.
+ *
+ * %SDF_RUNNING - an asynchronous command is still running.
+ *
+ * %SDF_LSAMPL - the subdevice uses "long" (32-bit) samples (for asynchronous
+ * command data).
+ *
+ * %SDF_PACKED - the subdevice packs several DIO samples into a single sample
+ * (for asynchronous command data).
+ *
+ * No "channel flags" (@flags) values are currently defined.
+ */
+struct comedi_subdinfo {
+       unsigned int type;
+       unsigned int n_chan;
+       unsigned int subd_flags;
+       unsigned int timer_type;
+       unsigned int len_chanlist;
+       unsigned int maxdata;
+       unsigned int flags;
+       unsigned int range_type;
+       unsigned int settling_time_0;
+       unsigned int insn_bits_support;
+       unsigned int unused[8];
+};
+
+/**
+ * struct comedi_devinfo - used to retrieve information about a COMEDI device
+ * @version_code:      COMEDI version code.
+ * @n_subdevs:         Number of subdevices the device has.
+ * @driver_name:       Null-terminated COMEDI driver name.
+ * @board_name:                Null-terminated COMEDI board name.
+ * @read_subdevice:    Index of the current "read" subdevice (%-1 if none).
+ * @write_subdevice:   Index of the current "write" subdevice (%-1 if none).
+ * @unused:            Reserved for future use.
+ *
+ * This is used with the %COMEDI_DEVINFO ioctl to get basic information about
+ * the device.
+ */
+struct comedi_devinfo {
+       unsigned int version_code;
+       unsigned int n_subdevs;
+       char driver_name[COMEDI_NAMELEN];
+       char board_name[COMEDI_NAMELEN];
+       int read_subdevice;
+       int write_subdevice;
+       int unused[30];
+};
+
+/**
+ * struct comedi_devconfig - used to configure a legacy COMEDI device
+ * @board_name:                Null-terminated string specifying the type of board
+ *                     to configure.
+ * @options:           An array of integer configuration options.
+ *
+ * This is used with the %COMEDI_DEVCONFIG ioctl to configure a "legacy" COMEDI
+ * device, such as an ISA card.  Not all COMEDI drivers support this.  Those
+ * that do either expect the specified board name to match one of a list of
+ * names registered with the COMEDI core, or expect the specified board name
+ * to match the COMEDI driver name itself.  The configuration options are
+ * handled in a driver-specific manner.
+ */
+struct comedi_devconfig {
+       char board_name[COMEDI_NAMELEN];
+       int options[COMEDI_NDEVCONFOPTS];
+};
+
+/**
+ * struct comedi_bufconfig - used to set or get buffer size for a subdevice
+ * @subdevice:         Subdevice index.
+ * @flags:             Not used.
+ * @maximum_size:      Maximum allowed buffer size.
+ * @size:              Buffer size.
+ * @unused:            Reserved for future use.
+ *
+ * This is used with the %COMEDI_BUFCONFIG ioctl to get or configure the
+ * maximum buffer size and current buffer size for a COMEDI subdevice that
+ * supports asynchronous commands.  If the subdevice does not support
+ * asynchronous commands, @maximum_size and @size are ignored and set to 0.
+ *
+ * On ioctl input, non-zero values of @maximum_size and @size specify a
+ * new maximum size and new current size (in bytes), respectively.  These
+ * will by rounded up to a multiple of %PAGE_SIZE.  Specifying a new maximum
+ * size requires admin capabilities.
+ *
+ * On ioctl output, @maximum_size and @size and set to the current maximum
+ * buffer size and current buffer size, respectively.
+ */
+struct comedi_bufconfig {
+       unsigned int subdevice;
+       unsigned int flags;
+
+       unsigned int maximum_size;
+       unsigned int size;
+
+       unsigned int unused[4];
+};
+
+/**
+ * struct comedi_bufinfo - used to manipulate buffer position for a subdevice
+ * @subdevice:         Subdevice index.
+ * @bytes_read:                Specify amount to advance read position for an
+ *                     asynchronous command in the input ("read") direction.
+ * @buf_write_ptr:     Current write position (index) within the buffer.
+ * @buf_read_ptr:      Current read position (index) within the buffer.
+ * @buf_write_count:   Total amount written, modulo 2^32.
+ * @buf_read_count:    Total amount read, modulo 2^32.
+ * @bytes_written:     Specify amount to advance write position for an
+ *                     asynchronous command in the output ("write") direction.
+ * @unused:            Reserved for future use.
+ *
+ * This is used with the %COMEDI_BUFINFO ioctl to optionally advance the
+ * current read or write position in an asynchronous acquisition data buffer,
+ * and to get the current read and write positions in the buffer.
+ */
+struct comedi_bufinfo {
+       unsigned int subdevice;
+       unsigned int bytes_read;
+
+       unsigned int buf_write_ptr;
+       unsigned int buf_read_ptr;
+       unsigned int buf_write_count;
+       unsigned int buf_read_count;
+
+       unsigned int bytes_written;
+
+       unsigned int unused[4];
+};
+
+/* range stuff */
+
+#define __RANGE(a, b)  ((((a) & 0xffff) << 16) | ((b) & 0xffff))
+
+#define RANGE_OFFSET(a)                (((a) >> 16) & 0xffff)
+#define RANGE_LENGTH(b)                ((b) & 0xffff)
+
+#define RF_UNIT(flags)         ((flags) & 0xff)
+#define RF_EXTERNAL            0x100
+
+#define UNIT_volt              0
+#define UNIT_mA                        1
+#define UNIT_none              2
+
+#define COMEDI_MIN_SPEED       0xffffffffu
+
+/**********************************************************/
+/* everything after this line is ALPHA */
+/**********************************************************/
+
+/*
+ * 8254 specific configuration.
+ *
+ * It supports two config commands:
+ *
+ * 0 ID: INSN_CONFIG_SET_COUNTER_MODE
+ * 1 8254 Mode
+ * I8254_MODE0, I8254_MODE1, ..., I8254_MODE5
+ * OR'ed with:
+ * I8254_BCD, I8254_BINARY
+ *
+ * 0 ID: INSN_CONFIG_8254_READ_STATUS
+ * 1 <-- Status byte returned here.
+ * B7 = Output
+ * B6 = NULL Count
+ * B5 - B0 Current mode.
+ */
+
+enum i8254_mode {
+       I8254_MODE0 = (0 << 1), /* Interrupt on terminal count */
+       I8254_MODE1 = (1 << 1), /* Hardware retriggerable one-shot */
+       I8254_MODE2 = (2 << 1), /* Rate generator */
+       I8254_MODE3 = (3 << 1), /* Square wave mode */
+       I8254_MODE4 = (4 << 1), /* Software triggered strobe */
+       /* Hardware triggered strobe (retriggerable) */
+       I8254_MODE5 = (5 << 1),
+       /* Use binary-coded decimal instead of binary (pretty useless) */
+       I8254_BCD = 1,
+       I8254_BINARY = 0
+};
+
+/* *** BEGIN GLOBALLY-NAMED NI TERMINALS/SIGNALS *** */
+
+/*
+ * Common National Instruments Terminal/Signal names.
+ * Some of these have no NI_ prefix as they are useful for non-NI hardware, such
+ * as those that utilize the PXI/RTSI trigger lines.
+ *
+ * NOTE ABOUT THE CHOICE OF NAMES HERE AND THE CAMELSCRIPT:
+ *   The choice to use CamelScript and the exact names below is for
+ *   maintainability, clarity, similarity to manufacturer's documentation,
+ *   _and_ a mitigation for confusion that has plagued the use of these drivers
+ *   for years!
+ *
+ *   More detail:
+ *   There have been significant confusions over the past many years for users
+ *   when trying to understand how to connect to/from signals and terminals on
+ *   NI hardware using comedi.  The major reason for this is that the actual
+ *   register values were exposed and required to be used by users.  Several
+ *   major reasons exist why this caused major confusion for users:
+ *   1) The register values are _NOT_ in user documentation, but rather in
+ *     arcane locations, such as a few register programming manuals that are
+ *     increasingly hard to find and the NI MHDDK (comments in example code).
+ *     There is no one place to find the various valid values of the registers.
+ *   2) The register values are _NOT_ completely consistent.  There is no way to
+ *     gain any sense of intuition of which values, or even enums one should use
+ *     for various registers.  There was some attempt in prior use of comedi to
+ *     name enums such that a user might know which enums should be used for
+ *     varying purposes, but the end-user had to gain a knowledge of register
+ *     values to correctly wield this approach.
+ *   3) The names for signals and registers found in the various register level
+ *     programming manuals and vendor-provided documentation are _not_ even
+ *     close to the same names that are in the end-user documentation.
+ *
+ *   Similar, albeit less, confusion plagued NI's previous version of their own
+ *   drivers.  Earlier than 2003, NI greatly simplified the situation for users
+ *   by releasing a new API that abstracted the names of signals/terminals to a
+ *   common and intuitive set of names.
+ *
+ *   The names below mirror the names chosen and well documented by NI.  These
+ *   names are exposed to the user via the comedilib user library.  By keeping
+ *   the names below, in spite of the use of CamelScript, maintenance will be
+ *   greatly eased and confusion for users _and_ comedi developers will be
+ *   greatly reduced.
+ */
+
+/*
+ * Base of abstracted NI names.
+ * The first 16 bits of *_arg are reserved for channel selection.
+ * Since we only actually need the first 4 or 5 bits for all register values on
+ * NI select registers anyways, we'll identify all values >= (1<<15) as being an
+ * abstracted NI signal/terminal name.
+ * These values are also used/returned by INSN_DEVICE_CONFIG_TEST_ROUTE,
+ * INSN_DEVICE_CONFIG_CONNECT_ROUTE, INSN_DEVICE_CONFIG_DISCONNECT_ROUTE,
+ * and INSN_DEVICE_CONFIG_GET_ROUTES.
+ */
+#define NI_NAMES_BASE  0x8000u
+
+#define _TERM_N(base, n, x)    ((base) + ((x) & ((n) - 1)))
+
+/*
+ * not necessarily all allowed 64 PFIs are valid--certainly not for all devices
+ */
+#define NI_PFI(x)              _TERM_N(NI_NAMES_BASE, 64, x)
+/* 8 trigger lines by standard, Some devices cannot talk to all eight. */
+#define TRIGGER_LINE(x)                _TERM_N(NI_PFI(-1) + 1, 8, x)
+/* 4 RTSI shared MUXes to route signals to/from TRIGGER_LINES on NI hardware */
+#define NI_RTSI_BRD(x)         _TERM_N(TRIGGER_LINE(-1) + 1, 4, x)
+
+/* *** Counter/timer names : 8 counters max *** */
+#define NI_MAX_COUNTERS                8
+#define NI_COUNTER_NAMES_BASE  (NI_RTSI_BRD(-1)  + 1)
+#define NI_CtrSource(x)              _TERM_N(NI_COUNTER_NAMES_BASE, NI_MAX_COUNTERS, x)
+/* Gate, Aux, A,B,Z are all treated, at times as gates */
+#define NI_GATES_NAMES_BASE    (NI_CtrSource(-1) + 1)
+#define NI_CtrGate(x)          _TERM_N(NI_GATES_NAMES_BASE, NI_MAX_COUNTERS, x)
+#define NI_CtrAux(x)           _TERM_N(NI_CtrGate(-1)  + 1, NI_MAX_COUNTERS, x)
+#define NI_CtrA(x)             _TERM_N(NI_CtrAux(-1)   + 1, NI_MAX_COUNTERS, x)
+#define NI_CtrB(x)             _TERM_N(NI_CtrA(-1)     + 1, NI_MAX_COUNTERS, x)
+#define NI_CtrZ(x)             _TERM_N(NI_CtrB(-1)     + 1, NI_MAX_COUNTERS, x)
+#define NI_GATES_NAMES_MAX     NI_CtrZ(-1)
+#define NI_CtrArmStartTrigger(x) _TERM_N(NI_CtrZ(-1)    + 1, NI_MAX_COUNTERS, x)
+#define NI_CtrInternalOutput(x) \
+                     _TERM_N(NI_CtrArmStartTrigger(-1) + 1, NI_MAX_COUNTERS, x)
+/** external pin(s) labeled conveniently as Ctr<i>Out. */
+#define NI_CtrOut(x)   _TERM_N(NI_CtrInternalOutput(-1) + 1, NI_MAX_COUNTERS, x)
+/** For Buffered sampling of ctr -- x series capability. */
+#define NI_CtrSampleClock(x)   _TERM_N(NI_CtrOut(-1)   + 1, NI_MAX_COUNTERS, x)
+#define NI_COUNTER_NAMES_MAX   NI_CtrSampleClock(-1)
+
+enum ni_common_signal_names {
+       /* PXI_Star: this is a non-NI-specific signal */
+       PXI_Star = NI_COUNTER_NAMES_MAX + 1,
+       PXI_Clk10,
+       PXIe_Clk100,
+       NI_AI_SampleClock,
+       NI_AI_SampleClockTimebase,
+       NI_AI_StartTrigger,
+       NI_AI_ReferenceTrigger,
+       NI_AI_ConvertClock,
+       NI_AI_ConvertClockTimebase,
+       NI_AI_PauseTrigger,
+       NI_AI_HoldCompleteEvent,
+       NI_AI_HoldComplete,
+       NI_AI_ExternalMUXClock,
+       NI_AI_STOP, /* pulse signal that occurs when a update is finished(?) */
+       NI_AO_SampleClock,
+       NI_AO_SampleClockTimebase,
+       NI_AO_StartTrigger,
+       NI_AO_PauseTrigger,
+       NI_DI_SampleClock,
+       NI_DI_SampleClockTimebase,
+       NI_DI_StartTrigger,
+       NI_DI_ReferenceTrigger,
+       NI_DI_PauseTrigger,
+       NI_DI_InputBufferFull,
+       NI_DI_ReadyForStartEvent,
+       NI_DI_ReadyForTransferEventBurst,
+       NI_DI_ReadyForTransferEventPipelined,
+       NI_DO_SampleClock,
+       NI_DO_SampleClockTimebase,
+       NI_DO_StartTrigger,
+       NI_DO_PauseTrigger,
+       NI_DO_OutputBufferFull,
+       NI_DO_DataActiveEvent,
+       NI_DO_ReadyForStartEvent,
+       NI_DO_ReadyForTransferEvent,
+       NI_MasterTimebase,
+       NI_20MHzTimebase,
+       NI_80MHzTimebase,
+       NI_100MHzTimebase,
+       NI_200MHzTimebase,
+       NI_100kHzTimebase,
+       NI_10MHzRefClock,
+       NI_FrequencyOutput,
+       NI_ChangeDetectionEvent,
+       NI_AnalogComparisonEvent,
+       NI_WatchdogExpiredEvent,
+       NI_WatchdogExpirationTrigger,
+       NI_SCXI_Trig1,
+       NI_LogicLow,
+       NI_LogicHigh,
+       NI_ExternalStrobe,
+       NI_PFI_DO,
+       NI_CaseGround,
+       /* special internal signal used as variable source for RTSI bus: */
+       NI_RGOUT0,
+
+       /* just a name to make the next more convenient, regardless of above */
+       _NI_NAMES_MAX_PLUS_1,
+       NI_NUM_NAMES = _NI_NAMES_MAX_PLUS_1 - NI_NAMES_BASE,
+};
+
+/* *** END GLOBALLY-NAMED NI TERMINALS/SIGNALS *** */
+
+#define NI_USUAL_PFI_SELECT(x) (((x) < 10) ? (0x1 + (x)) : (0xb + (x)))
+#define NI_USUAL_RTSI_SELECT(x)        (((x) < 7) ? (0xb + (x)) : 0x1b)
+
+/*
+ * mode bits for NI general-purpose counters, set with
+ * INSN_CONFIG_SET_COUNTER_MODE
+ */
+#define NI_GPCT_COUNTING_MODE_SHIFT 16
+#define NI_GPCT_INDEX_PHASE_BITSHIFT 20
+#define NI_GPCT_COUNTING_DIRECTION_SHIFT 24
+enum ni_gpct_mode_bits {
+       NI_GPCT_GATE_ON_BOTH_EDGES_BIT = 0x4,
+       NI_GPCT_EDGE_GATE_MODE_MASK = 0x18,
+       NI_GPCT_EDGE_GATE_STARTS_STOPS_BITS = 0x0,
+       NI_GPCT_EDGE_GATE_STOPS_STARTS_BITS = 0x8,
+       NI_GPCT_EDGE_GATE_STARTS_BITS = 0x10,
+       NI_GPCT_EDGE_GATE_NO_STARTS_NO_STOPS_BITS = 0x18,
+       NI_GPCT_STOP_MODE_MASK = 0x60,
+       NI_GPCT_STOP_ON_GATE_BITS = 0x00,
+       NI_GPCT_STOP_ON_GATE_OR_TC_BITS = 0x20,
+       NI_GPCT_STOP_ON_GATE_OR_SECOND_TC_BITS = 0x40,
+       NI_GPCT_LOAD_B_SELECT_BIT = 0x80,
+       NI_GPCT_OUTPUT_MODE_MASK = 0x300,
+       NI_GPCT_OUTPUT_TC_PULSE_BITS = 0x100,
+       NI_GPCT_OUTPUT_TC_TOGGLE_BITS = 0x200,
+       NI_GPCT_OUTPUT_TC_OR_GATE_TOGGLE_BITS = 0x300,
+       NI_GPCT_HARDWARE_DISARM_MASK = 0xc00,
+       NI_GPCT_NO_HARDWARE_DISARM_BITS = 0x000,
+       NI_GPCT_DISARM_AT_TC_BITS = 0x400,
+       NI_GPCT_DISARM_AT_GATE_BITS = 0x800,
+       NI_GPCT_DISARM_AT_TC_OR_GATE_BITS = 0xc00,
+       NI_GPCT_LOADING_ON_TC_BIT = 0x1000,
+       NI_GPCT_LOADING_ON_GATE_BIT = 0x4000,
+       NI_GPCT_COUNTING_MODE_MASK = 0x7 << NI_GPCT_COUNTING_MODE_SHIFT,
+       NI_GPCT_COUNTING_MODE_NORMAL_BITS =
+               0x0 << NI_GPCT_COUNTING_MODE_SHIFT,
+       NI_GPCT_COUNTING_MODE_QUADRATURE_X1_BITS =
+               0x1 << NI_GPCT_COUNTING_MODE_SHIFT,
+       NI_GPCT_COUNTING_MODE_QUADRATURE_X2_BITS =
+               0x2 << NI_GPCT_COUNTING_MODE_SHIFT,
+       NI_GPCT_COUNTING_MODE_QUADRATURE_X4_BITS =
+               0x3 << NI_GPCT_COUNTING_MODE_SHIFT,
+       NI_GPCT_COUNTING_MODE_TWO_PULSE_BITS =
+               0x4 << NI_GPCT_COUNTING_MODE_SHIFT,
+       NI_GPCT_COUNTING_MODE_SYNC_SOURCE_BITS =
+               0x6 << NI_GPCT_COUNTING_MODE_SHIFT,
+       NI_GPCT_INDEX_PHASE_MASK = 0x3 << NI_GPCT_INDEX_PHASE_BITSHIFT,
+       NI_GPCT_INDEX_PHASE_LOW_A_LOW_B_BITS =
+               0x0 << NI_GPCT_INDEX_PHASE_BITSHIFT,
+       NI_GPCT_INDEX_PHASE_LOW_A_HIGH_B_BITS =
+               0x1 << NI_GPCT_INDEX_PHASE_BITSHIFT,
+       NI_GPCT_INDEX_PHASE_HIGH_A_LOW_B_BITS =
+               0x2 << NI_GPCT_INDEX_PHASE_BITSHIFT,
+       NI_GPCT_INDEX_PHASE_HIGH_A_HIGH_B_BITS =
+               0x3 << NI_GPCT_INDEX_PHASE_BITSHIFT,
+       NI_GPCT_INDEX_ENABLE_BIT = 0x400000,
+       NI_GPCT_COUNTING_DIRECTION_MASK =
+               0x3 << NI_GPCT_COUNTING_DIRECTION_SHIFT,
+       NI_GPCT_COUNTING_DIRECTION_DOWN_BITS =
+               0x00 << NI_GPCT_COUNTING_DIRECTION_SHIFT,
+       NI_GPCT_COUNTING_DIRECTION_UP_BITS =
+               0x1 << NI_GPCT_COUNTING_DIRECTION_SHIFT,
+       NI_GPCT_COUNTING_DIRECTION_HW_UP_DOWN_BITS =
+               0x2 << NI_GPCT_COUNTING_DIRECTION_SHIFT,
+       NI_GPCT_COUNTING_DIRECTION_HW_GATE_BITS =
+               0x3 << NI_GPCT_COUNTING_DIRECTION_SHIFT,
+       NI_GPCT_RELOAD_SOURCE_MASK = 0xc000000,
+       NI_GPCT_RELOAD_SOURCE_FIXED_BITS = 0x0,
+       NI_GPCT_RELOAD_SOURCE_SWITCHING_BITS = 0x4000000,
+       NI_GPCT_RELOAD_SOURCE_GATE_SELECT_BITS = 0x8000000,
+       NI_GPCT_OR_GATE_BIT = 0x10000000,
+       NI_GPCT_INVERT_OUTPUT_BIT = 0x20000000
+};
+
+/*
+ * Bits for setting a clock source with
+ * INSN_CONFIG_SET_CLOCK_SRC when using NI general-purpose counters.
+ */
+enum ni_gpct_clock_source_bits {
+       NI_GPCT_CLOCK_SRC_SELECT_MASK = 0x3f,
+       NI_GPCT_TIMEBASE_1_CLOCK_SRC_BITS = 0x0,
+       NI_GPCT_TIMEBASE_2_CLOCK_SRC_BITS = 0x1,
+       NI_GPCT_TIMEBASE_3_CLOCK_SRC_BITS = 0x2,
+       NI_GPCT_LOGIC_LOW_CLOCK_SRC_BITS = 0x3,
+       NI_GPCT_NEXT_GATE_CLOCK_SRC_BITS = 0x4,
+       NI_GPCT_NEXT_TC_CLOCK_SRC_BITS = 0x5,
+       /* NI 660x-specific */
+       NI_GPCT_SOURCE_PIN_i_CLOCK_SRC_BITS = 0x6,
+       NI_GPCT_PXI10_CLOCK_SRC_BITS = 0x7,
+       NI_GPCT_PXI_STAR_TRIGGER_CLOCK_SRC_BITS = 0x8,
+       NI_GPCT_ANALOG_TRIGGER_OUT_CLOCK_SRC_BITS = 0x9,
+       NI_GPCT_PRESCALE_MODE_CLOCK_SRC_MASK = 0x30000000,
+       NI_GPCT_NO_PRESCALE_CLOCK_SRC_BITS = 0x0,
+       /* divide source by 2 */
+       NI_GPCT_PRESCALE_X2_CLOCK_SRC_BITS = 0x10000000,
+       /* divide source by 8 */
+       NI_GPCT_PRESCALE_X8_CLOCK_SRC_BITS = 0x20000000,
+       NI_GPCT_INVERT_CLOCK_SRC_BIT = 0x80000000
+};
+
+/* NI 660x-specific */
+#define NI_GPCT_SOURCE_PIN_CLOCK_SRC_BITS(x)   (0x10 + (x))
+
+#define NI_GPCT_RTSI_CLOCK_SRC_BITS(x)         (0x18 + (x))
+
+/* no pfi on NI 660x */
+#define NI_GPCT_PFI_CLOCK_SRC_BITS(x)          (0x20 + (x))
+
+/*
+ * Possibilities for setting a gate source with
+ * INSN_CONFIG_SET_GATE_SRC when using NI general-purpose counters.
+ * May be bitwise-or'd with CR_EDGE or CR_INVERT.
+ */
+enum ni_gpct_gate_select {
+       /* m-series gates */
+       NI_GPCT_TIMESTAMP_MUX_GATE_SELECT = 0x0,
+       NI_GPCT_AI_START2_GATE_SELECT = 0x12,
+       NI_GPCT_PXI_STAR_TRIGGER_GATE_SELECT = 0x13,
+       NI_GPCT_NEXT_OUT_GATE_SELECT = 0x14,
+       NI_GPCT_AI_START1_GATE_SELECT = 0x1c,
+       NI_GPCT_NEXT_SOURCE_GATE_SELECT = 0x1d,
+       NI_GPCT_ANALOG_TRIGGER_OUT_GATE_SELECT = 0x1e,
+       NI_GPCT_LOGIC_LOW_GATE_SELECT = 0x1f,
+       /* more gates for 660x */
+       NI_GPCT_SOURCE_PIN_i_GATE_SELECT = 0x100,
+       NI_GPCT_GATE_PIN_i_GATE_SELECT = 0x101,
+       /* more gates for 660x "second gate" */
+       NI_GPCT_UP_DOWN_PIN_i_GATE_SELECT = 0x201,
+       NI_GPCT_SELECTED_GATE_GATE_SELECT = 0x21e,
+       /*
+        * m-series "second gate" sources are unknown,
+        * we should add them here with an offset of 0x300 when
+        * known.
+        */
+       NI_GPCT_DISABLED_GATE_SELECT = 0x8000,
+};
+
+#define NI_GPCT_GATE_PIN_GATE_SELECT(x)                (0x102 + (x))
+#define NI_GPCT_RTSI_GATE_SELECT(x)            NI_USUAL_RTSI_SELECT(x)
+#define NI_GPCT_PFI_GATE_SELECT(x)             NI_USUAL_PFI_SELECT(x)
+#define NI_GPCT_UP_DOWN_PIN_GATE_SELECT(x)     (0x202 + (x))
+
+/*
+ * Possibilities for setting a source with
+ * INSN_CONFIG_SET_OTHER_SRC when using NI general-purpose counters.
+ */
+enum ni_gpct_other_index {
+       NI_GPCT_SOURCE_ENCODER_A,
+       NI_GPCT_SOURCE_ENCODER_B,
+       NI_GPCT_SOURCE_ENCODER_Z
+};
+
+enum ni_gpct_other_select {
+       /* m-series gates */
+       /* Still unknown, probably only need NI_GPCT_PFI_OTHER_SELECT */
+       NI_GPCT_DISABLED_OTHER_SELECT = 0x8000,
+};
+
+#define NI_GPCT_PFI_OTHER_SELECT(x)    NI_USUAL_PFI_SELECT(x)
+
+/*
+ * start sources for ni general-purpose counters for use with
+ * INSN_CONFIG_ARM
+ */
+enum ni_gpct_arm_source {
+       NI_GPCT_ARM_IMMEDIATE = 0x0,
+       /*
+        * Start both the counter and the adjacent paired counter simultaneously
+        */
+       NI_GPCT_ARM_PAIRED_IMMEDIATE = 0x1,
+       /*
+        * If the NI_GPCT_HW_ARM bit is set, we will pass the least significant
+        * bits (3 bits for 660x or 5 bits for m-series) through to the
+        * hardware. To select a hardware trigger, pass the appropriate select
+        * bit, e.g.,
+        * NI_GPCT_HW_ARM | NI_GPCT_AI_START1_GATE_SELECT or
+        * NI_GPCT_HW_ARM | NI_GPCT_PFI_GATE_SELECT(pfi_number)
+        */
+       NI_GPCT_HW_ARM = 0x1000,
+       NI_GPCT_ARM_UNKNOWN = NI_GPCT_HW_ARM,   /* for backward compatibility */
+};
+
+/* digital filtering options for ni 660x for use with INSN_CONFIG_FILTER. */
+enum ni_gpct_filter_select {
+       NI_GPCT_FILTER_OFF = 0x0,
+       NI_GPCT_FILTER_TIMEBASE_3_SYNC = 0x1,
+       NI_GPCT_FILTER_100x_TIMEBASE_1 = 0x2,
+       NI_GPCT_FILTER_20x_TIMEBASE_1 = 0x3,
+       NI_GPCT_FILTER_10x_TIMEBASE_1 = 0x4,
+       NI_GPCT_FILTER_2x_TIMEBASE_1 = 0x5,
+       NI_GPCT_FILTER_2x_TIMEBASE_3 = 0x6
+};
+
+/*
+ * PFI digital filtering options for ni m-series for use with
+ * INSN_CONFIG_FILTER.
+ */
+enum ni_pfi_filter_select {
+       NI_PFI_FILTER_OFF = 0x0,
+       NI_PFI_FILTER_125ns = 0x1,
+       NI_PFI_FILTER_6425ns = 0x2,
+       NI_PFI_FILTER_2550us = 0x3
+};
+
+/* master clock sources for ni mio boards and INSN_CONFIG_SET_CLOCK_SRC */
+enum ni_mio_clock_source {
+       NI_MIO_INTERNAL_CLOCK = 0,
+       /*
+        * Doesn't work for m-series, use NI_MIO_PLL_RTSI_CLOCK()
+        * the NI_MIO_PLL_* sources are m-series only
+        */
+       NI_MIO_RTSI_CLOCK = 1,
+       NI_MIO_PLL_PXI_STAR_TRIGGER_CLOCK = 2,
+       NI_MIO_PLL_PXI10_CLOCK = 3,
+       NI_MIO_PLL_RTSI0_CLOCK = 4
+};
+
+#define NI_MIO_PLL_RTSI_CLOCK(x)       (NI_MIO_PLL_RTSI0_CLOCK + (x))
+
+/*
+ * Signals which can be routed to an NI RTSI pin with INSN_CONFIG_SET_ROUTING.
+ * The numbers assigned are not arbitrary, they correspond to the bits required
+ * to program the board.
+ */
+enum ni_rtsi_routing {
+       NI_RTSI_OUTPUT_ADR_START1 = 0,
+       NI_RTSI_OUTPUT_ADR_START2 = 1,
+       NI_RTSI_OUTPUT_SCLKG = 2,
+       NI_RTSI_OUTPUT_DACUPDN = 3,
+       NI_RTSI_OUTPUT_DA_START1 = 4,
+       NI_RTSI_OUTPUT_G_SRC0 = 5,
+       NI_RTSI_OUTPUT_G_GATE0 = 6,
+       NI_RTSI_OUTPUT_RGOUT0 = 7,
+       NI_RTSI_OUTPUT_RTSI_BRD_0 = 8,
+       /* Pre-m-series always have RTSI clock on line 7 */
+       NI_RTSI_OUTPUT_RTSI_OSC = 12
+};
+
+#define NI_RTSI_OUTPUT_RTSI_BRD(x)     (NI_RTSI_OUTPUT_RTSI_BRD_0 + (x))
+
+/*
+ * Signals which can be routed to an NI PFI pin on an m-series board with
+ * INSN_CONFIG_SET_ROUTING.  These numbers are also returned by
+ * INSN_CONFIG_GET_ROUTING on pre-m-series boards, even though their routing
+ * cannot be changed.  The numbers assigned are not arbitrary, they correspond
+ * to the bits required to program the board.
+ */
+enum ni_pfi_routing {
+       NI_PFI_OUTPUT_PFI_DEFAULT = 0,
+       NI_PFI_OUTPUT_AI_START1 = 1,
+       NI_PFI_OUTPUT_AI_START2 = 2,
+       NI_PFI_OUTPUT_AI_CONVERT = 3,
+       NI_PFI_OUTPUT_G_SRC1 = 4,
+       NI_PFI_OUTPUT_G_GATE1 = 5,
+       NI_PFI_OUTPUT_AO_UPDATE_N = 6,
+       NI_PFI_OUTPUT_AO_START1 = 7,
+       NI_PFI_OUTPUT_AI_START_PULSE = 8,
+       NI_PFI_OUTPUT_G_SRC0 = 9,
+       NI_PFI_OUTPUT_G_GATE0 = 10,
+       NI_PFI_OUTPUT_EXT_STROBE = 11,
+       NI_PFI_OUTPUT_AI_EXT_MUX_CLK = 12,
+       NI_PFI_OUTPUT_GOUT0 = 13,
+       NI_PFI_OUTPUT_GOUT1 = 14,
+       NI_PFI_OUTPUT_FREQ_OUT = 15,
+       NI_PFI_OUTPUT_PFI_DO = 16,
+       NI_PFI_OUTPUT_I_ATRIG = 17,
+       NI_PFI_OUTPUT_RTSI0 = 18,
+       NI_PFI_OUTPUT_PXI_STAR_TRIGGER_IN = 26,
+       NI_PFI_OUTPUT_SCXI_TRIG1 = 27,
+       NI_PFI_OUTPUT_DIO_CHANGE_DETECT_RTSI = 28,
+       NI_PFI_OUTPUT_CDI_SAMPLE = 29,
+       NI_PFI_OUTPUT_CDO_UPDATE = 30
+};
+
+#define NI_PFI_OUTPUT_RTSI(x)          (NI_PFI_OUTPUT_RTSI0 + (x))
+
+/*
+ * Signals which can be routed to output on a NI PFI pin on a 660x board
+ * with INSN_CONFIG_SET_ROUTING.  The numbers assigned are
+ * not arbitrary, they correspond to the bits required
+ * to program the board.  Lines 0 to 7 can only be set to
+ * NI_660X_PFI_OUTPUT_DIO.  Lines 32 to 39 can only be set to
+ * NI_660X_PFI_OUTPUT_COUNTER.
+ */
+enum ni_660x_pfi_routing {
+       NI_660X_PFI_OUTPUT_COUNTER = 1, /* counter */
+       NI_660X_PFI_OUTPUT_DIO = 2,     /* static digital output */
+};
+
+/*
+ * NI External Trigger lines.  These values are not arbitrary, but are related
+ * to the bits required to program the board (offset by 1 for historical
+ * reasons).
+ */
+#define NI_EXT_PFI(x)                  (NI_USUAL_PFI_SELECT(x) - 1)
+#define NI_EXT_RTSI(x)                 (NI_USUAL_RTSI_SELECT(x) - 1)
+
+/*
+ * Clock sources for CDIO subdevice on NI m-series boards.  Used as the
+ * scan_begin_arg for a comedi_command. These sources may also be bitwise-or'd
+ * with CR_INVERT to change polarity.
+ */
+enum ni_m_series_cdio_scan_begin_src {
+       NI_CDIO_SCAN_BEGIN_SRC_GROUND = 0,
+       NI_CDIO_SCAN_BEGIN_SRC_AI_START = 18,
+       NI_CDIO_SCAN_BEGIN_SRC_AI_CONVERT = 19,
+       NI_CDIO_SCAN_BEGIN_SRC_PXI_STAR_TRIGGER = 20,
+       NI_CDIO_SCAN_BEGIN_SRC_G0_OUT = 28,
+       NI_CDIO_SCAN_BEGIN_SRC_G1_OUT = 29,
+       NI_CDIO_SCAN_BEGIN_SRC_ANALOG_TRIGGER = 30,
+       NI_CDIO_SCAN_BEGIN_SRC_AO_UPDATE = 31,
+       NI_CDIO_SCAN_BEGIN_SRC_FREQ_OUT = 32,
+       NI_CDIO_SCAN_BEGIN_SRC_DIO_CHANGE_DETECT_IRQ = 33
+};
+
+#define NI_CDIO_SCAN_BEGIN_SRC_PFI(x)  NI_USUAL_PFI_SELECT(x)
+#define NI_CDIO_SCAN_BEGIN_SRC_RTSI(x) NI_USUAL_RTSI_SELECT(x)
+
+/*
+ * scan_begin_src for scan_begin_arg==TRIG_EXT with analog output command on NI
+ * boards.  These scan begin sources can also be bitwise-or'd with CR_INVERT to
+ * change polarity.
+ */
+#define NI_AO_SCAN_BEGIN_SRC_PFI(x)    NI_USUAL_PFI_SELECT(x)
+#define NI_AO_SCAN_BEGIN_SRC_RTSI(x)   NI_USUAL_RTSI_SELECT(x)
+
+/*
+ * Bits for setting a clock source with
+ * INSN_CONFIG_SET_CLOCK_SRC when using NI frequency output subdevice.
+ */
+enum ni_freq_out_clock_source_bits {
+       NI_FREQ_OUT_TIMEBASE_1_DIV_2_CLOCK_SRC, /* 10 MHz */
+       NI_FREQ_OUT_TIMEBASE_2_CLOCK_SRC        /* 100 KHz */
+};
+
+/*
+ * Values for setting a clock source with INSN_CONFIG_SET_CLOCK_SRC for
+ * 8254 counter subdevices on Amplicon DIO boards (amplc_dio200 driver).
+ */
+enum amplc_dio_clock_source {
+       /*
+        * Per channel external clock
+        * input/output pin (pin is only an
+        * input when clock source set to this value,
+        * otherwise it is an output)
+        */
+       AMPLC_DIO_CLK_CLKN,
+       AMPLC_DIO_CLK_10MHZ,    /* 10 MHz internal clock */
+       AMPLC_DIO_CLK_1MHZ,     /* 1 MHz internal clock */
+       AMPLC_DIO_CLK_100KHZ,   /* 100 kHz internal clock */
+       AMPLC_DIO_CLK_10KHZ,    /* 10 kHz internal clock */
+       AMPLC_DIO_CLK_1KHZ,     /* 1 kHz internal clock */
+       /*
+        * Output of preceding counter channel
+        * (for channel 0, preceding counter
+        * channel is channel 2 on preceding
+        * counter subdevice, for first counter
+        * subdevice, preceding counter
+        * subdevice is the last counter
+        * subdevice)
+        */
+       AMPLC_DIO_CLK_OUTNM1,
+       AMPLC_DIO_CLK_EXT,      /* per chip external input pin */
+       /* the following are "enhanced" clock sources for PCIe models */
+       AMPLC_DIO_CLK_VCC,      /* clock input HIGH */
+       AMPLC_DIO_CLK_GND,      /* clock input LOW */
+       AMPLC_DIO_CLK_PAT_PRESENT, /* "pattern present" signal */
+       AMPLC_DIO_CLK_20MHZ     /* 20 MHz internal clock */
+};
+
+/*
+ * Values for setting a clock source with INSN_CONFIG_SET_CLOCK_SRC for
+ * timer subdevice on some Amplicon DIO PCIe boards (amplc_dio200 driver).
+ */
+enum amplc_dio_ts_clock_src {
+       AMPLC_DIO_TS_CLK_1GHZ,  /* 1 ns period with 20 ns granularity */
+       AMPLC_DIO_TS_CLK_1MHZ,  /* 1 us period */
+       AMPLC_DIO_TS_CLK_1KHZ   /* 1 ms period */
+};
+
+/*
+ * Values for setting a gate source with INSN_CONFIG_SET_GATE_SRC for
+ * 8254 counter subdevices on Amplicon DIO boards (amplc_dio200 driver).
+ */
+enum amplc_dio_gate_source {
+       AMPLC_DIO_GAT_VCC,      /* internal high logic level */
+       AMPLC_DIO_GAT_GND,      /* internal low logic level */
+       AMPLC_DIO_GAT_GATN,     /* per channel external gate input */
+       /*
+        * negated output of counter channel minus 2
+        * (for channels 0 or 1, channel minus 2 is channel 1 or 2 on
+        * the preceding counter subdevice, for the first counter subdevice
+        * the preceding counter subdevice is the last counter subdevice)
+        */
+       AMPLC_DIO_GAT_NOUTNM2,
+       AMPLC_DIO_GAT_RESERVED4,
+       AMPLC_DIO_GAT_RESERVED5,
+       AMPLC_DIO_GAT_RESERVED6,
+       AMPLC_DIO_GAT_RESERVED7,
+       /* the following are "enhanced" gate sources for PCIe models */
+       AMPLC_DIO_GAT_NGATN = 6, /* negated per channel gate input */
+       /* non-negated output of counter channel minus 2 */
+       AMPLC_DIO_GAT_OUTNM2,
+       AMPLC_DIO_GAT_PAT_PRESENT, /* "pattern present" signal */
+       AMPLC_DIO_GAT_PAT_OCCURRED, /* "pattern occurred" latched */
+       AMPLC_DIO_GAT_PAT_GONE, /* "pattern gone away" latched */
+       AMPLC_DIO_GAT_NPAT_PRESENT, /* negated "pattern present" */
+       AMPLC_DIO_GAT_NPAT_OCCURRED, /* negated "pattern occurred" */
+       AMPLC_DIO_GAT_NPAT_GONE /* negated "pattern gone away" */
+};
+
+/*
+ * Values for setting a clock source with INSN_CONFIG_SET_CLOCK_SRC for
+ * the counter subdevice on the Kolter Electronic PCI-Counter board
+ * (ke_counter driver).
+ */
+enum ke_counter_clock_source {
+       KE_CLK_20MHZ,   /* internal 20MHz (default) */
+       KE_CLK_4MHZ,    /* internal 4MHz (option) */
+       KE_CLK_EXT      /* external clock on pin 21 of D-Sub */
+};
+
+#endif /* _COMEDI_H */
index b24bfae..16d475b 100755 (executable)
@@ -140,71 +140,71 @@ dogtags()
 # - etags regular expressions have to match at the start of a line;
 #   a ^[^#] is prepended by setup_regex unless an anchor is already present
 regex_asm=(
-       '/^\(ENTRY\|_GLOBAL\)(\([[:alnum:]_\\]*\)).*/\2/'
+       '/^\(ENTRY\|_GLOBAL\)([[:space:]]*\([[:alnum:]_\\]*\)).*/\2/'
 )
 regex_c=(
-       '/^SYSCALL_DEFINE[0-9](\([[:alnum:]_]*\).*/sys_\1/'
-       '/^BPF_CALL_[0-9](\([[:alnum:]_]*\).*/\1/'
-       '/^COMPAT_SYSCALL_DEFINE[0-9](\([[:alnum:]_]*\).*/compat_sys_\1/'
-       '/^TRACE_EVENT(\([[:alnum:]_]*\).*/trace_\1/'
-       '/^TRACE_EVENT(\([[:alnum:]_]*\).*/trace_\1_rcuidle/'
-       '/^DEFINE_EVENT([^,)]*, *\([[:alnum:]_]*\).*/trace_\1/'
-       '/^DEFINE_EVENT([^,)]*, *\([[:alnum:]_]*\).*/trace_\1_rcuidle/'
-       '/^DEFINE_INSN_CACHE_OPS(\([[:alnum:]_]*\).*/get_\1_slot/'
-       '/^DEFINE_INSN_CACHE_OPS(\([[:alnum:]_]*\).*/free_\1_slot/'
-       '/^PAGEFLAG(\([[:alnum:]_]*\).*/Page\1/'
-       '/^PAGEFLAG(\([[:alnum:]_]*\).*/SetPage\1/'
-       '/^PAGEFLAG(\([[:alnum:]_]*\).*/ClearPage\1/'
-       '/^TESTSETFLAG(\([[:alnum:]_]*\).*/TestSetPage\1/'
-       '/^TESTPAGEFLAG(\([[:alnum:]_]*\).*/Page\1/'
-       '/^SETPAGEFLAG(\([[:alnum:]_]*\).*/SetPage\1/'
-       '/\<__SETPAGEFLAG(\([[:alnum:]_]*\).*/__SetPage\1/'
-       '/\<TESTCLEARFLAG(\([[:alnum:]_]*\).*/TestClearPage\1/'
-       '/\<__TESTCLEARFLAG(\([[:alnum:]_]*\).*/TestClearPage\1/'
-       '/\<CLEARPAGEFLAG(\([[:alnum:]_]*\).*/ClearPage\1/'
-       '/\<__CLEARPAGEFLAG(\([[:alnum:]_]*\).*/__ClearPage\1/'
-       '/^__PAGEFLAG(\([[:alnum:]_]*\).*/__SetPage\1/'
-       '/^__PAGEFLAG(\([[:alnum:]_]*\).*/__ClearPage\1/'
-       '/^PAGEFLAG_FALSE(\([[:alnum:]_]*\).*/Page\1/'
-       '/\<TESTSCFLAG(\([[:alnum:]_]*\).*/TestSetPage\1/'
-       '/\<TESTSCFLAG(\([[:alnum:]_]*\).*/TestClearPage\1/'
-       '/\<SETPAGEFLAG_NOOP(\([[:alnum:]_]*\).*/SetPage\1/'
-       '/\<CLEARPAGEFLAG_NOOP(\([[:alnum:]_]*\).*/ClearPage\1/'
-       '/\<__CLEARPAGEFLAG_NOOP(\([[:alnum:]_]*\).*/__ClearPage\1/'
-       '/\<TESTCLEARFLAG_FALSE(\([[:alnum:]_]*\).*/TestClearPage\1/'
-       '/^PAGE_TYPE_OPS(\([[:alnum:]_]*\).*/Page\1/'
-       '/^PAGE_TYPE_OPS(\([[:alnum:]_]*\).*/__SetPage\1/'
-       '/^PAGE_TYPE_OPS(\([[:alnum:]_]*\).*/__ClearPage\1/'
-       '/^TASK_PFA_TEST([^,]*, *\([[:alnum:]_]*\))/task_\1/'
-       '/^TASK_PFA_SET([^,]*, *\([[:alnum:]_]*\))/task_set_\1/'
-       '/^TASK_PFA_CLEAR([^,]*, *\([[:alnum:]_]*\))/task_clear_\1/'
-       '/^DEF_MMIO_\(IN\|OUT\)_[XD](\([[:alnum:]_]*\),[^)]*)/\2/'
-       '/^DEBUGGER_BOILERPLATE(\([[:alnum:]_]*\))/\1/'
-       '/^DEF_PCI_AC_\(\|NO\)RET(\([[:alnum:]_]*\).*/\2/'
-       '/^PCI_OP_READ(\(\w*\).*[1-4])/pci_bus_read_config_\1/'
-       '/^PCI_OP_WRITE(\(\w*\).*[1-4])/pci_bus_write_config_\1/'
-       '/\<DEFINE_\(RT_MUTEX\|MUTEX\|SEMAPHORE\|SPINLOCK\)(\([[:alnum:]_]*\)/\2/v/'
-       '/\<DEFINE_\(RAW_SPINLOCK\|RWLOCK\|SEQLOCK\)(\([[:alnum:]_]*\)/\2/v/'
-       '/\<DECLARE_\(RWSEM\|COMPLETION\)(\([[:alnum:]_]\+\)/\2/v/'
-       '/\<DECLARE_BITMAP(\([[:alnum:]_]*\)/\1/v/'
-       '/\(^\|\s\)\(\|L\|H\)LIST_HEAD(\([[:alnum:]_]*\)/\3/v/'
-       '/\(^\|\s\)RADIX_TREE(\([[:alnum:]_]*\)/\2/v/'
-       '/\<DEFINE_PER_CPU([^,]*, *\([[:alnum:]_]*\)/\1/v/'
-       '/\<DEFINE_PER_CPU_SHARED_ALIGNED([^,]*, *\([[:alnum:]_]*\)/\1/v/'
-       '/\<DECLARE_WAIT_QUEUE_HEAD(\([[:alnum:]_]*\)/\1/v/'
-       '/\<DECLARE_\(TASKLET\|WORK\|DELAYED_WORK\)(\([[:alnum:]_]*\)/\2/v/'
-       '/\(^\s\)OFFSET(\([[:alnum:]_]*\)/\2/v/'
-       '/\(^\s\)DEFINE(\([[:alnum:]_]*\)/\2/v/'
-       '/\<\(DEFINE\|DECLARE\)_HASHTABLE(\([[:alnum:]_]*\)/\2/v/'
-       '/\<DEFINE_ID\(R\|A\)(\([[:alnum:]_]\+\)/\2/'
-       '/\<DEFINE_WD_CLASS(\([[:alnum:]_]\+\)/\1/'
-       '/\<ATOMIC_NOTIFIER_HEAD(\([[:alnum:]_]\+\)/\1/'
-       '/\<RAW_NOTIFIER_HEAD(\([[:alnum:]_]\+\)/\1/'
-       '/\<DECLARE_FAULT_ATTR(\([[:alnum:]_]\+\)/\1/'
-       '/\<BLOCKING_NOTIFIER_HEAD(\([[:alnum:]_]\+\)/\1/'
-       '/\<DEVICE_ATTR_\(RW\|RO\|WO\)(\([[:alnum:]_]\+\)/dev_attr_\2/'
-       '/\<DRIVER_ATTR_\(RW\|RO\|WO\)(\([[:alnum:]_]\+\)/driver_attr_\2/'
-       '/\<\(DEFINE\|DECLARE\)_STATIC_KEY_\(TRUE\|FALSE\)\(\|_RO\)(\([[:alnum:]_]\+\)/\4/'
+       '/^SYSCALL_DEFINE[0-9]([[:space:]]*\([[:alnum:]_]*\).*/sys_\1/'
+       '/^BPF_CALL_[0-9]([[:space:]]*\([[:alnum:]_]*\).*/\1/'
+       '/^COMPAT_SYSCALL_DEFINE[0-9]([[:space:]]*\([[:alnum:]_]*\).*/compat_sys_\1/'
+       '/^TRACE_EVENT([[:space:]]*\([[:alnum:]_]*\).*/trace_\1/'
+       '/^TRACE_EVENT([[:space:]]*\([[:alnum:]_]*\).*/trace_\1_rcuidle/'
+       '/^DEFINE_EVENT([^,)]*,[[:space:]]*\([[:alnum:]_]*\).*/trace_\1/'
+       '/^DEFINE_EVENT([^,)]*,[[:space:]]*\([[:alnum:]_]*\).*/trace_\1_rcuidle/'
+       '/^DEFINE_INSN_CACHE_OPS([[:space:]]*\([[:alnum:]_]*\).*/get_\1_slot/'
+       '/^DEFINE_INSN_CACHE_OPS([[:space:]]*\([[:alnum:]_]*\).*/free_\1_slot/'
+       '/^PAGEFLAG([[:space:]]*\([[:alnum:]_]*\).*/Page\1/'
+       '/^PAGEFLAG([[:space:]]*\([[:alnum:]_]*\).*/SetPage\1/'
+       '/^PAGEFLAG([[:space:]]*\([[:alnum:]_]*\).*/ClearPage\1/'
+       '/^TESTSETFLAG([[:space:]]*\([[:alnum:]_]*\).*/TestSetPage\1/'
+       '/^TESTPAGEFLAG([[:space:]]*\([[:alnum:]_]*\).*/Page\1/'
+       '/^SETPAGEFLAG([[:space:]]*\([[:alnum:]_]*\).*/SetPage\1/'
+       '/\<__SETPAGEFLAG([[:space:]]*\([[:alnum:]_]*\).*/__SetPage\1/'
+       '/\<TESTCLEARFLAG([[:space:]]*\([[:alnum:]_]*\).*/TestClearPage\1/'
+       '/\<__TESTCLEARFLAG([[:space:]]*\([[:alnum:]_]*\).*/TestClearPage\1/'
+       '/\<CLEARPAGEFLAG([[:space:]]*\([[:alnum:]_]*\).*/ClearPage\1/'
+       '/\<__CLEARPAGEFLAG([[:space:]]*\([[:alnum:]_]*\).*/__ClearPage\1/'
+       '/^__PAGEFLAG([[:space:]]*\([[:alnum:]_]*\).*/__SetPage\1/'
+       '/^__PAGEFLAG([[:space:]]*\([[:alnum:]_]*\).*/__ClearPage\1/'
+       '/^PAGEFLAG_FALSE([[:space:]]*\([[:alnum:]_]*\).*/Page\1/'
+       '/\<TESTSCFLAG([[:space:]]*\([[:alnum:]_]*\).*/TestSetPage\1/'
+       '/\<TESTSCFLAG([[:space:]]*\([[:alnum:]_]*\).*/TestClearPage\1/'
+       '/\<SETPAGEFLAG_NOOP([[:space:]]*\([[:alnum:]_]*\).*/SetPage\1/'
+       '/\<CLEARPAGEFLAG_NOOP([[:space:]]*\([[:alnum:]_]*\).*/ClearPage\1/'
+       '/\<__CLEARPAGEFLAG_NOOP([[:space:]]*\([[:alnum:]_]*\).*/__ClearPage\1/'
+       '/\<TESTCLEARFLAG_FALSE([[:space:]]*\([[:alnum:]_]*\).*/TestClearPage\1/'
+       '/^PAGE_TYPE_OPS([[:space:]]*\([[:alnum:]_]*\).*/Page\1/'
+       '/^PAGE_TYPE_OPS([[:space:]]*\([[:alnum:]_]*\).*/__SetPage\1/'
+       '/^PAGE_TYPE_OPS([[:space:]]*\([[:alnum:]_]*\).*/__ClearPage\1/'
+       '/^TASK_PFA_TEST([^,]*,[[:space:]]*\([[:alnum:]_]*\))/task_\1/'
+       '/^TASK_PFA_SET([^,]*,[[:space:]]*\([[:alnum:]_]*\))/task_set_\1/'
+       '/^TASK_PFA_CLEAR([^,]*,[[:space:]]*\([[:alnum:]_]*\))/task_clear_\1/'
+       '/^DEF_MMIO_\(IN\|OUT\)_[XD]([[:space:]]*\([[:alnum:]_]*\),[^)]*)/\2/'
+       '/^DEBUGGER_BOILERPLATE([[:space:]]*\([[:alnum:]_]*\))/\1/'
+       '/^DEF_PCI_AC_\(\|NO\)RET([[:space:]]*\([[:alnum:]_]*\).*/\2/'
+       '/^PCI_OP_READ([[:space:]]*\(\w*\).*[1-4])/pci_bus_read_config_\1/'
+       '/^PCI_OP_WRITE([[:space:]]*\(\w*\).*[1-4])/pci_bus_write_config_\1/'
+       '/\<DEFINE_\(RT_MUTEX\|MUTEX\|SEMAPHORE\|SPINLOCK\)([[:space:]]*\([[:alnum:]_]*\)/\2/v/'
+       '/\<DEFINE_\(RAW_SPINLOCK\|RWLOCK\|SEQLOCK\)([[:space:]]*\([[:alnum:]_]*\)/\2/v/'
+       '/\<DECLARE_\(RWSEM\|COMPLETION\)([[:space:]]*\([[:alnum:]_]\+\)/\2/v/'
+       '/\<DECLARE_BITMAP([[:space:]]*\([[:alnum:]_]*\)/\1/v/'
+       '/\(^\|\s\)\(\|L\|H\)LIST_HEAD([[:space:]]*\([[:alnum:]_]*\)/\3/v/'
+       '/\(^\|\s\)RADIX_TREE([[:space:]]*\([[:alnum:]_]*\)/\2/v/'
+       '/\<DEFINE_PER_CPU([^,]*,[[:space:]]*\([[:alnum:]_]*\)/\1/v/'
+       '/\<DEFINE_PER_CPU_SHARED_ALIGNED([^,]*,[[:space:]]*\([[:alnum:]_]*\)/\1/v/'
+       '/\<DECLARE_WAIT_QUEUE_HEAD([[:space:]]*\([[:alnum:]_]*\)/\1/v/'
+       '/\<DECLARE_\(TASKLET\|WORK\|DELAYED_WORK\)([[:space:]]*\([[:alnum:]_]*\)/\2/v/'
+       '/\(^\s\)OFFSET([[:space:]]*\([[:alnum:]_]*\)/\2/v/'
+       '/\(^\s\)DEFINE([[:space:]]*\([[:alnum:]_]*\)/\2/v/'
+       '/\<\(DEFINE\|DECLARE\)_HASHTABLE([[:space:]]*\([[:alnum:]_]*\)/\2/v/'
+       '/\<DEFINE_ID\(R\|A\)([[:space:]]*\([[:alnum:]_]\+\)/\2/'
+       '/\<DEFINE_WD_CLASS([[:space:]]*\([[:alnum:]_]\+\)/\1/'
+       '/\<ATOMIC_NOTIFIER_HEAD([[:space:]]*\([[:alnum:]_]\+\)/\1/'
+       '/\<RAW_NOTIFIER_HEAD([[:space:]]*\([[:alnum:]_]\+\)/\1/'
+       '/\<DECLARE_FAULT_ATTR([[:space:]]*\([[:alnum:]_]\+\)/\1/'
+       '/\<BLOCKING_NOTIFIER_HEAD([[:space:]]*\([[:alnum:]_]\+\)/\1/'
+       '/\<DEVICE_ATTR_\(RW\|RO\|WO\)([[:space:]]*\([[:alnum:]_]\+\)/dev_attr_\2/'
+       '/\<DRIVER_ATTR_\(RW\|RO\|WO\)([[:space:]]*\([[:alnum:]_]\+\)/driver_attr_\2/'
+       '/\<\(DEFINE\|DECLARE\)_STATIC_KEY_\(TRUE\|FALSE\)\(\|_RO\)([[:space:]]*\([[:alnum:]_]\+\)/\4/'
        '/^SEQCOUNT_LOCKTYPE(\([^,]*\),[[:space:]]*\([^,]*\),[^)]*)/seqcount_\2_t/'
        '/^SEQCOUNT_LOCKTYPE(\([^,]*\),[[:space:]]*\([^,]*\),[^)]*)/seqcount_\2_init/'
 )