Implementation of local area network extension for instrumentation standard trigger capabilities in advanced data acquisition platforms by López Navarro, Juan Manuel et al.
Implementation of local area network extension for instrumentation
standard trigger capabilities in advanced data acquisition platformsa…
J. M. López,1 M. Ruiz,1 E. Barrera,1 G. de Arcas,1 and J. Vega2
1Grupo de Investigación en Instrumentación y Acústica Aplicada, Universidad Politécnica de Madrid,
Crta. Valencia Km-7, Madrid 28031, Spain
2Asociación EURATOM/CIEMAT para Fusión, Madrid 28040, Spain
Presented 14 May 2008; received 11 May 2008; accepted 14 July 2008;
published online 31 October 2008
Synchronization mechanisms are an essential part of the real-time distributed data acquisition
systems DASs used in fusion experiments. Traditionally, they have been based on the use of digital
signals. The approach known as local area network extension for instrumentation LXI provides a
set of very powerful synchronization and trigger mechanisms. The Intelligent Test Measurement
System ITMS is a new platform designed to implement distributed data acquisition and fast data
processing for fusion experiments. It is based on COMPATPCI technology and its extension to
instrumentation PXI. Hardware and software elements have been developed to include LXI trigger
and synchronization mechanisms in this platform in order to obtain a class A LXI instrument. This
paper describes the implementation of such a system, involving the following components:
commercial hardware running a Linux operating system; a real-time extension to an operating
system and network RTAI and RTNET, which implements a software precision time protocol PTP
using IEEE1588; an ad hoc PXI module to support hardware implementation of PTP-IEEE 1588;
and the multipoint, low-voltage differential signaling hardware LXI trigger bus. © 2008 American
Institute of Physics.
DOI: 10.1063/1.2968694
I. INTRODUCTION
Most advanced data acquisition systems DASs cur-
rently used in scientific experiments, such as fusion devices,
are distributed systems made of a set of instruments housed
in a chassis. This requires powerful triggering mechanisms
that serve to synchronize the start of data acquisition DAQ
by the different units in the system. Such systems allow si-
multaneous detection of events using multiple instruments
over the course of the experiment. This is of increasing rel-
evance as the shot duration in fusion devices increases, and it
is essential in long-pulse devices. In addition, when the dis-
tributed DAQ units also possess processing capability, spe-
cific experimental events can be detected by one chassis and
transmitted to the others in the system.
The hardware architectures used most extensively for
DAQ in nuclear fusion experiments are based on modular
instrumentation that is housed in a chassis, as in the case of
COMPACTPCI and PXI. All of these technologies include pow-
erful local trigger and synchronization mechanisms to con-
trol the operation of the different instruments in the chassis.
These architectures generally do include a system controller
CPU that has a network adapter in order to receive the setup
parameters prior to each acquisition and in order to send the
raw or processed data to the central storage system once
DAQ is complete. However, the architectures usually lack
specific mechanisms to synchronize DAQ between different
chassis. Thus, the present paper presents a powerful trigger
and synchronization mechanism for event detection ED
across distributed DAS. It uses the trigger mechanisms de-
fined in the local area network LAN extension for
instrumentation1 LXI standard, and it is based on a versa-
tile DAQ and processing platform named ITMS, which has
been jointly developed by Universidad Politécnica de Madrid
and CIEMAT.2 This platform is available in both 3U PXI and
6U COMPATPCI format.
II. ITMS GENERAL SYSTEM ARCHITECTURE
Figure 1 shows the standard hardware and software ar-
chitectures of the ITMS platform. The hardware consists of
the following elements:
• One standard 3U PXI or 6U COMPACTPCI chassis, with a
standard embedded system CPU SCPU. SCPU is used
for the following purposes: to configure the DAQ cards, to
acquire data from the DAQ channels, to distribute the ac-
quired data among the system CPUs, and to process data
from desired channels.
• Several DAQ cards.
• Several peripheral CPU PCPU cards allocated in periph-
eral slots Inova ICP-PM-4 or Concurrent Technologies
PP300/022. PCPUs are used to process the data acquired
from desired channels. PCPUs increase the computing ca-
pacity of the PXI platform beyond that of typical PXI
aContributed paper, published as part of the Proceedings of the 17th Topical
Conference on High-Temperature Plasma Diagnostics, Albuquerque, New
Mexico, May 2008.
REVIEW OF SCIENTIFIC INSTRUMENTS 79, 10F335 2008
0034-6748/2008/7910/10F335/4/$23.00 © 2008 American Institute of Physics79, 10F335-1
Author complimentary copy. Redistribution subject to AIP license or copyright, see http://rsi.aip.org/rsi/copyright.jsp
systems, which are based only on the system’s CPU
controller.3
ITMS software architecture is based on three software mod-
ules that run both in the SCPU and in the PCPUs Fig. 1:
Setup&DAQ, dynamic data processing system DDPS, and
ED. These modules were developed using Linux kernel mod-
ules Fedora Core 5 based on RTAI version 3.5, the COMEDI
DAQ driver version 0.7.76, and LABVIEW software version
8.2.1.
The Setup&DAQ module controls the DAQ and data
distribution configuration linking different processing ele-
ments of the system PCPUs and SCPU. The user interface
was developed in LABVIEW, while the DAQ and distribution
aspects were coded using RTAI-Linux kernel modules. The
software controlling continuous data collection in the final
user applications was developed in C language and inte-
grated in LABVIEW code using code interface nodes.
The DDPS module runs the user-defined data processing
routines, which the user must develop in LABVIEW. The ED
module is a client-server application that runs in each CPU
SCPU or PCPUs. The client, which usually runs in the
PCPUs, detects events generated by the DDPS module and
sends them to the RTAI module. This module then generates a
message that will be sent to another PCPU/SCPU or DAS in
the system.
III. IMPLEMENTATION OF LXI TRIGGER MECHANISMS
ON THE ITMS PLATFORM
Trigger mechanisms defined in the LXI standard were
chosen in order to provide the ITMS platform with advanced
and efficient trigger mechanisms, which in turn, would allow
development of distributed acquisition and processing sys-
tems. The standard specifies the following trigger protocols:
Trigger over the LAN. The instrument receives a mes-
sage in a user datagram protocol UDP or internet protocol
IP packet containing trigger information. This mechanism
features a longer latency time than traditional hardware trig-
ger lines. Nevertheless, it is very useful for distributed appli-
cations in which it may be difficult to connect a physical
trigger signal among all subsystems due to costs or physical
limitations. All LXI class B and C instruments must comply
with these types of trigger mechanisms.
Precision time protocol IEEE1588 trigger. This type of
trigger uses a universal time coordinated clock UTC, as
required for LXI class A instruments. The instrument is trig-
gered when a predefined absolute time is reached. As long as
the clock is very precise, this type of trigger is useful because
it does not rely on a hardware line to connect all the systems.
The standard supports both hardware and software imple-
mentations of this mechanism. The ITMS platform features
both options: the SCPU and PCPUS implement the precision
time protocol PTP-IEEE1588 using software based on
RTAI/RTNET, and it also includes a hardware PXI hardware
module designed with commercial modules using the
IM3220 microcontroller. This microcontroller implements
the PTP-IEEE1588.
A. Implementation of the trigger mechanism on SCPU
and PCPUS
The SCPU and PCPUS in the ITMS platform are standard
3U or 6U boards running Linux with an RTAI real-time mod-
ule and the real-time network module RTNET.4,5 A software
application, ITMS-ED, was developed as an RTAI/RTNET kernel
module that implements the PTP protocol and manages the
board’s hardware clock.6 In addition, the application includes
a LABVIEW module that can receive events or messages aris-
ing during data processing and that can send them to the RTAI
module, which then generates LXI compliant, module-to-
module messages that include a timestamp. LXI Event iden-
FIG. 1. Color online Architecture of the basic ITMS system.
10F335-2 López et al. Rev. Sci. Instrum. 79, 10F335 2008
Author complimentary copy. Redistribution subject to AIP license or copyright, see http://rsi.aip.org/rsi/copyright.jsp
tifiers can be defined in this software module. The kernel
module keeps the SCPU and PCPUS clocks synchronized
with the master clock. Neither the SCPU nor the PCPUS
supports the generation of hardware signals for trigger pur-
poses.
B. Implementation of hardware trigger and sampling
rate clock signal for DAQ cards.
A PXI hardware module was developed to include the
generation of hardware trigger signals based on the LXI stan-
dard and sampling rate clocks for DAQs modules in the ITMS
platform. The PXI module has been implemented using two
commercial Imsys Technologies modules M20 and S20 and
a custom-made one. The M20 module includes an IM3220
microcontroller and dynamic random access memory re-
sources. The S20 module includes additional hardware to
support the Ethernet physical interface, RS232 and USB in-
terface, and digital input-output. The custom-made module
includes hardware to implement the digital trigger and clock
signals for DAQ ITMS modules, and the digital hardware to
support the multipoint, low-voltage differential signaling
hardware triggering.
The hardware functionalities provided by this PXI mod-
ule are the following:
• Support of the precision time protocol IEEE1588. The
IM3220 chip is based on reduced instruction set computer
RISC architecture and a field programmable field array
FPGA devoted to support network time stamping for
IEEE1588. This microcontroller includes a PTP protocol
engine implemented in assembler language and microcode,
and a software API to manage the engine.
• Implementation of the hardware trigger signaling mecha-
nisms required for class A LXI instruments and generation
of two sampling clock signals that can be used as the sam-
pling clock for ITMS DAQ cards. The module also gener-
ates the analog voltage proportional or related to the sam-
pling rate that is applied to channel 0 in DAQ cards.
A software application named trigger manager TM was
developed under the RUBUS operating system included with
IM3230 development tools. TM waits for UDP connections
and manages the PTP engine. Using a UDP socket, the TM
waits for LXI module-to-module message bearing informa-
tion about when a DAQ trigger signal is generated times-
tamp. The TM processes the message and programs the PTP
engine to generate the DAQ trigger signal. The uncertainty in
the value of the timestamp in the trigger signal is reported
with our results.
The TM also supports special LXI module-to-module
messages that change the sampling rate in the DAQ cards.
When the TM receives such a message in a UDP socket, it
proceeds to generate a new sampling clock and an analog
voltage for the channel 0 of DAQ cards. In addition, the TM
generates a new module-to-module message that includes
the timestamp of sampling rate change. This idea of an
adaptive sampling rate DAQ system has already been
described.3 In this situation, the most important thing is to
know when the sample frequency has been changed—i.e.,
the exact timestamp—and not the moment when the rest of
the modules become aware of this event.
Figure 2 shows how the abovementioned ITMS function-
alities can be used to create versatile and powerful distrib-
uted DASs. The trigger of the DASs, ttrigger, is controlled
using the PXI module based in IM3220. Its clock is synchro-
nized with a master clock implemented with a PCI
IEEE1588 card from National Instruments Fig. 2, steps 1
and 2. The system achieves a very low ttrigger uncertainty,
ttrigger, due to hardware implementation of the PTP proto-
col as described in the next paragraph. Once DAQ has be-
gun, the acquired data are processed in both the SCPU and
PCPUS LABVIEW applications. These applications can gener-
ate module-to-module LXI messages LXIMM depending
on the results of the data processing step 3. For example,
SCPU can detect the need to change the sampling rate during
DAQ, and it can send a message step 4 to the TM software
module running in IM3220 of the PXI module. As a result,
the sampling clock and the analog voltage connected to each
board’s analog input channel 0 are updated. It is important to
point out that the system has a certain latency interval since
high-level applications detect each event and signal this
event to the rest of the system step 5. This latency has two
terms, the first is due to the time necessary to detect the event
in the block of acquired data,3 and the second is due to
propagation of the LXI message throughout the network. The
former depends on several experimental parameters, includ-
FIG. 2. Color online Distributed DAQ system using an ITMS platform and
LXI trigger mechanisms.
10F335-3 LXI in advanced DAQ platforms Rev. Sci. Instrum. 79, 10F335 2008
Author complimentary copy. Redistribution subject to AIP license or copyright, see http://rsi.aip.org/rsi/copyright.jsp
ing buffer block length, sampling rate, and processing
algorithm,3 whereas the latter depends on network delay.
IV. EXPERIMENTAL RESULTS
The setup used to achieve the delays in the previously
described experiment comprises the following:
• a PC running a LABVIEW application using the NI PCI-
1588 card,
• a PXI chassis with a SCPU, one PCPU, the PXI module
designed based on the IM3220 PXI-IM3220, and two
6070E DAQ cards,
• a DGS-1008D switch from D-Link, and
• a Tektronix digital oscilloscope TDO TDS 754C
The first measurement is the deviation in time of the trigger
signal generated by PXI-IM3220 with respect to the master
clock NI PCI-1588. After 1 h, during which the clocks are
synchronized every 2 s, the LABVIEW application causes NI
PCI-1588 and PXI-IM3220 to generate a pulse using their
I /O available pins every 5 s. The TDO acquires both pulses
and the delay between edges is measured based on a refer-
ence edge generated by the NI PCI-1588. The mean delay
value obtained after an experimental run of 24 h was 97 ns
with a standard deviation of 165 ns. In the worst-case sce-
nario, based on these values and a coverage factor of 2 prob-
ability of 95%, the system is predicted to have an error of
one sample at 1 MS /s and four samples at 10 MS /s.
The second measurement is the latency time to change
the sampling rate. A Linux kernel module running in the PC
was developed to send an LXI message to the PXI-IM3220
using the UDP socket. At the same time, a pulse is generated
in a pin of the parallel port of the PC. When the TM, which
is running in PXI-IM3220, receives the LXI message, it pro-
grams the new sampling rate and generates another pulse. In
our experiment, the delay measured between the rising edges
of the pulses had a maximum value of 10 ms. This delay has
two terms, the first of which is the time required by the
Linux module to send the UDP packet to the network. This
value is on the order of 500 s.5 The second term is due to
the latency of the RUBUS operating system running in
IM3220. The latency has a quasiuniform distribution and
was found to vary between 2 and 9 ms in our experiments.
Finally, the deviation of SCPU and PCPU clocks are in the
same order of magnitude of the values presented in the work
of Correl et al.6
V. DISCUSSION
Trigger mechanisms defined by the LXI standard can be
very useful for creating distributed DAS for long-pulse fu-
sion devices. The PXI-IM3220 hardware module is an effec-
tive solution to control the start of DAQ in these systems,
with a very low uncertainty on the order of 200 ns. In addi-
tion, the combination of RTAI and RTNET applications allows
the user to achieve low-latency access to Ethernet, which is
very useful to signal events and allow synchronization in
distributed systems. In this implementation it is necessary to
improve the network response time for LXI messages of
PXI-IM3220 module. So, we are working in the design of a
new embedded hardware based in the use of DP83640 chip
hardware support for ethernet and PTP timestamping.
Finally, this solution has been tested using two systems
like shown in Fig. 1 and one master clock PC with
NI-IEEE1588 in the same network segment. The results ob-
tained are the same presented in the previous section.
ACKNOWLEDGMENTS
The authors wish to express their gratitude to the
Spanish Ministry of Education and Science for support
Project No. DPI 2006-06624.
1 LXI Standard Rev. 1.2.01. Nov 2007, LXI consortium, Inc.
2 M. Ruiz, E. Barrera, S. López, and D. Machón, Rev. Sci. Instrum. 75,
4261 2004.
3 M. Ruiz, J. M. López, G. de Arcas, E. Barrera, R. Melendez, and J. Vega,
Fusion Eng. Des. 83, 358 2008.
4 RTNET http://www.rts.unihannover.de/rtnet.
5 A. Luchetta, A. Barbalace, G. Manduchi, A. Soppelsa, and C. Taliercio,
Fusion Eng. Des. 83, 520 2008.
6 K. Correll, N. Barendt, and M. Branicky, http://ptpd.sourceforge.net.
10F335-4 López et al. Rev. Sci. Instrum. 79, 10F335 2008
Author complimentary copy. Redistribution subject to AIP license or copyright, see http://rsi.aip.org/rsi/copyright.jsp
