Re: Implementing real-time embedded system to sample from five SPI ADCs

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

 



Hi Nicholas,

according to what I understood, you want to use the data coming from your ADCs in a userspace application which implements the control loop.

I think there is a good chance you can then do all the steps (1)-(3) within an userspace application. However, I am not 100% certain about the best solution to implement (2) on this setup. May be anybody else knows something about the maximum sample frequency, but this also depends on how complicated your algorithms are.

Here [1] you can find a good example on how to write a RT userspace application. Using the SPI character devices it should also be possible to talk to your hardware.

Regards,
Andre


[1] https://rt.wiki.kernel.org/index.php/RT_PREEMPT_HOWTO


On 11/04/2010 12:06 AM, Nicholas Kinar wrote:
Hello,

I would like to implement a real-time embedded Linux system on an
AT91SAM ARM processor. Attached to the SPI bus of this processor are 5
Analog-to-Digital converters (ADCs) that can be read using the Linux SPI
bus subsystem.

The ADCs are sampled by having the AT91SAM ARM processor toggle a GPIO
at a rate of at least 1 KHz. The GPIO is attached to a pin on the ADC. A
high voltage level on this pin instructs all of the ADCs to take a
sample. The sample is then read over the SPI bus by the embedded system
master. This implies that data will be read from each SPI slave device
every (1 / 1000 Hz) = 1.0e-3 seconds.

I am wondering if the following could be done with real-time Linux:

(1) I would have to write a Linux kernel module to toggle the GPIO pin.
The rate of toggling would be controlled by a high-resolution timer, and
would occur with a period of at least 1 kHz.
(2) After the GPIO is brought to a high voltage level, the master must
wait for at least 3.7 microseconds before reading from the SPI bus.
(3) Each ADC would be read in sequential order.

The ADC being used is the AD7691 from Analog Devices
(http://www.analog.com/static/imported-files/data_sheets/AD7691.pdf).

The data from the ADCs could be used in a real-time control system loop.
Can this be done with real-time Linux, or is the latency too high? What
is the maximum rate at which I could read data from these ADCs? Could it
be 10 kHz or even 100 kHz?

Nicholas


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



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


[Index of Archives]     [RT Stable]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Video 4 Linux]     [Device Mapper]

  Powered by Linux