MSI/IRQ Latency Measurements with LM32, Etherbone and Saftlib
In autumn 2017, the latency of Message Signalled Interrupts (MSI) has been measured involving different layers of the timing receiver stack. The results are presented here.
Question
How much time does it take for interrupts to go through different layers of the Timing receiver stack?
Measurements
Numbers written on top of the distributions are mean values.
Saftlib (D-Bus + etherbone)
The travel time of an interrupt from the real-time hardware into the Linux user space is approximated by measuring the round trip time of a signal and interpreting this as two times the interrupt latency (i.e. interrupt latency = 0.5 * round trip time ). A measurement is started when a timing event is injected into the ECA via saftlib (Saftlib-start). The event deadline is zero, which means immediate execution. The measurement is stopped when a Saftlib interrupt is received from a
SoftwareActionSink that was triggered by the injected event (Saftlib-stop). This measurement gives an approximation of the interrupt latency in a Saftlib application, and the results are shown in the blue distribution in the figure above. The measurements have performed on a SCU 3 using the
Cherry Release. A schematic diagram of the setup can be seen below.
Etherbone
Additional time stamps are taken inside the (modified)
TimingReceiver Saftlib driver code before the etherbone function calls (etherbone-start), and just after receiving an MSI interrupt in the
SoftwareActionSink driver (etherbone-stop). This additional measurement gives an estimate of the interrupt latency in user space applications that use etherbone only (and no Saftlib, i.e. no D-Bus), and is shown as the green distribution in the green distribution in the figure above (again, latency = 0.5 * round trip time).
LM32
To measure the LM32 latency (how long it takes a timing event to affect a program running on an LM32 soft core processor), a different setup was used (see figure below) on an SCU3. Events with a known execution time were injected using saftlib command line tools. The ECA was configured to put these events into the ECA:Queue for the LM32 soft core processor. The LM32 was polling the queue and toggling an output which was fed into an input. The ECA:TLU was configured to create timing events on rising edges on this input, containing the timestamp of the rising edge. These events were read out using saftlib command line tools. The obtained timestamp of the rising edge was subtracted from the injected event execution time. The difference was interpreted as LM32 latency.
Older measurements
There is an older measurement from 2012 (see
publication). The older measurement has been done prior to the introduction of MSI interrupts. In comparison, the Etherbone latency presented above compares to the FESA latency in the previous measurement.
The following picture shows the previous measurements from 2012 (colors) in comparison to the most recent Etherbone latency measurement from 2017 (black).
--
MichaelReese - 29 Nov 2017