Re: DMA sampling and IIO

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




On 2/6/14, 1:56 AM, "Lars-Peter Clausen" <lars@xxxxxxxxxx> wrote:

>On 02/05/2014 07:42 PM, John Syn wrote:
>> I¹m working on a project that uses the ADE7878 Energy Measurement part
>> from Analog Devices. Currently there is an IIO device driver in the
>> staging/iio/meter folder, but I would like to extend this by adding high
>> speed sampling of the AC waveforms. The ADE7878 will continuously output
>> samples (8 Khz) of the voltage/current waveforms via an I2S interface. I
>> plan to use DMA to store these values in a buffer and then use IIO Ring
>> Buffer to access these values from User Space.
>>
>> Was this considered in the IIO framework and does anyone have any
>> suggestions on how I might proceed?
>
>Hi,
>
>We do have patches for better integration of DMA (especially for high
>speed 
>devices) into the IIO framework[1]. This is not yet upstream since it is
>still a bit WIP, but I'm confident that it will find it's way into
>upstream 
>soon. The patches are pretty isolated, so they can easily be applied on
>top 
>of a upstream tree.
I’d like to have a look at your DMA patch. Hopefully it will help point me
in the right direction.
>
>But with DMA you'll need a host component that supports this. The ADE7878
>driver on it's own can not do any DMA since it doesn't know how it is
>connected to the host system. I2S is typically used for audio and all I2S
>host driver reside in the audio subsystem. The tricky part will now be -
>if 
>there is already a I2S driver for your host system - how to bridge the
>audio 
>driver with the ADE7878 driver and expose the result as a DMA capable IIO
>device.
I’ll never understand why I2S is so integrated into the sound subsystem.
There are plenty applications of I2S that have nothing to do with sound. I
think I can make this work via an SPI interface, but with some patch work
because the ADE7878 will drive the SPI clock. I also plan to use EDMA to
store each measurement in a separate buffer (Voltage A, Voltage B, Voltage
C, Current A, etc) which will make processing each measurement channel
much easier. Question is, how to use IIO Ring Buffer given multiple
channels? 

Regards,
John
>
>- Lars
>
>[1] 
>https://github.com/analogdevicesinc/linux/commit/4edb9c9cbaf88047355c86e42
>1690262406d5eae
>


--
To unsubscribe from this list: send the line "unsubscribe linux-iio" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Input]     [Linux Kernel]     [Linux SCSI]     [X.org]

  Powered by Linux