diff options
Diffstat (limited to 'Documentation/driver-api')
| -rw-r--r-- | Documentation/driver-api/dmaengine/client.rst | 2 | ||||
| -rw-r--r-- | Documentation/driver-api/iio/hw-consumer.rst | 51 | ||||
| -rw-r--r-- | Documentation/driver-api/iio/index.rst | 1 | ||||
| -rw-r--r-- | Documentation/driver-api/pci.rst | 3 | 
4 files changed, 53 insertions, 4 deletions
| diff --git a/Documentation/driver-api/dmaengine/client.rst b/Documentation/driver-api/dmaengine/client.rst index 6245c99af8c1..fbbb2831f29f 100644 --- a/Documentation/driver-api/dmaengine/client.rst +++ b/Documentation/driver-api/dmaengine/client.rst @@ -185,7 +185,7 @@ The details of these operations are:        void dma_async_issue_pending(struct dma_chan *chan);  Further APIs: ------------- +-------------  1. Terminate APIs diff --git a/Documentation/driver-api/iio/hw-consumer.rst b/Documentation/driver-api/iio/hw-consumer.rst new file mode 100644 index 000000000000..8facce6a6733 --- /dev/null +++ b/Documentation/driver-api/iio/hw-consumer.rst @@ -0,0 +1,51 @@ +=========== +HW consumer +=========== +An IIO device can be directly connected to another device in hardware. in this +case the buffers between IIO provider and IIO consumer are handled by hardware. +The Industrial I/O HW consumer offers a way to bond these IIO devices without +software buffer for data. The implementation can be found under +:file:`drivers/iio/buffer/hw-consumer.c` + + +* struct :c:type:`iio_hw_consumer` — Hardware consumer structure +* :c:func:`iio_hw_consumer_alloc` — Allocate IIO hardware consumer +* :c:func:`iio_hw_consumer_free` — Free IIO hardware consumer +* :c:func:`iio_hw_consumer_enable` — Enable IIO hardware consumer +* :c:func:`iio_hw_consumer_disable` — Disable IIO hardware consumer + + +HW consumer setup +================= + +As standard IIO device the implementation is based on IIO provider/consumer. +A typical IIO HW consumer setup looks like this:: + +	static struct iio_hw_consumer *hwc; + +	static const struct iio_info adc_info = { +		.read_raw = adc_read_raw, +	}; + +	static int adc_read_raw(struct iio_dev *indio_dev, +				struct iio_chan_spec const *chan, int *val, +				int *val2, long mask) +	{ +		ret = iio_hw_consumer_enable(hwc); + +		/* Acquire data */ + +		ret = iio_hw_consumer_disable(hwc); +	} + +	static int adc_probe(struct platform_device *pdev) +	{ +		hwc = devm_iio_hw_consumer_alloc(&iio->dev); +	} + +More details +============ +.. kernel-doc:: include/linux/iio/hw-consumer.h +.. kernel-doc:: drivers/iio/buffer/industrialio-hw-consumer.c +   :export: + diff --git a/Documentation/driver-api/iio/index.rst b/Documentation/driver-api/iio/index.rst index e5c3922d1b6f..7fba341bd8b2 100644 --- a/Documentation/driver-api/iio/index.rst +++ b/Documentation/driver-api/iio/index.rst @@ -15,3 +15,4 @@ Contents:     buffers     triggers     triggered-buffers +   hw-consumer diff --git a/Documentation/driver-api/pci.rst b/Documentation/driver-api/pci.rst index 01a6c8b7d3a7..ca85e5e78b2c 100644 --- a/Documentation/driver-api/pci.rst +++ b/Documentation/driver-api/pci.rst @@ -25,9 +25,6 @@ PCI Support Library  .. kernel-doc:: drivers/pci/irq.c     :export: -.. kernel-doc:: drivers/pci/htirq.c -   :export: -  .. kernel-doc:: drivers/pci/probe.c     :export: |