Slow Control and Monitoring
Table of Contents
Introduction
The B2B system is a fairly simple device with a few inputs and outputs connected via interface boards with FPGA. The only difference is that those interface boards are not interconnected via a SCU-bus backplane but via the White Rabbit network service as low latency realtime field bus with upper bound latency. Data supply is done only via a the Central B2B Unit (CBU). Acquisition of get values can in principle be done via any Timing Receiver on the White Rabbit network.
Writing the set-values to the CBU is simple and straight-forward. The CBU is small lm32 firmware and shared library provides an interface to higher level applications.
Reading the get-values is even simpler. It does not even require B2B specific code, but only a subscription to timing messages via the saftlib.
At the time of this writing (March 2021) a simple command line interface (CLI) has been developed for supply with set-values. What turned out to be more challenging is the analysis and supply of get-values. A first approach was a 2nd CLI similar to the one for set-values. However, this turned out to grow further and further, became unmanageable and was soon retired to the garbage bin. Thus acquisition, processing and display of get-values has been replaced by a more modular approach.
Topology
Control and On-Line Diagnostic
digraph radius {
rankdir=TD;
node [style=filled shape=box width=1.3];
nodesep=0.5;
network [label="White Rabbit network" fillcolor="yellow" width = 18.0];
sis18sis18fesa [label="B2B_SIS18_EXT" fillcolor="green"]
sis18esrfesa [label="B2B_ESR_INJ" fillcolor="green"]
sis18ui [label="Config 1" fillcolor="dodgerblue"]
sis18eb [label="Etherbone" fillcolor="grey"]
sis18lib [label="B2B lib" fillcolor="grey"]
sis18cbu [label="SIS18 CBU" fillcolor="red"]
sis18pm [label="SIS18 PM" fillcolor="red"]
sis18kd [label="SIS18 KD_ext" fillcolor="red"]
sis18daq [label="SIS18 DAQ" fillcolor="grey"]
sis18cal [label="SIS18 Analysis" fillcolor="grey"]
sis18arch [label="SIS18 Archiver" fillcolor="grey"]
esresrfesa [label="B2B_ESR_EXT" fillcolor="green"]
esryrfesa [label="B2B_YR_INJ" fillcolor="green"]
esrui [label="Config 2" fillcolor="dodgerblue"]
esreb [label="Etherbone" fillcolor="grey"]
esrlib [label="B2B lib" fillcolor="grey"]
esrcbu [label="ESR CBU" fillcolor="red"]
esrpm [label="ESR PM" fillcolor="red"]
esrkd [label="ESR KD_X" fillcolor="red"]
esrdaq [label="ESR DAQ" fillcolor="grey"]
esrcal [label="ESR Analysis" fillcolor="grey"]
esrarch [label="ESR Archiver" fillcolor="grey"]
yryrfesa [label="B2B_YR_EXT" fillcolor="green"]
yrui [label="Config 3" fillcolor="dodgerblue"]
yreb [label="Etherbone" fillcolor="grey"]
yrlib [label="B2B lib" fillcolor="grey"]
yrcbu [label="YR CBU" fillcolor="red"]
yrpm [label="YR PM" fillcolor="red"]
yrkdi [label="YR KD_inj" fillcolor="red"]
yrkde [label="YR KD_ext" fillcolor="red"]
yrdaq [label="YR DAQ" fillcolor="grey"]
yrcal [label="YR Analysis" fillcolor="grey"]
yrarch [label="YR Archiver" fillcolor="grey"]
acodaq [label="ACO \n DAQ?\n analaysis?\n app? \n archiving?" fillcolor="cyan" shape="egg"]
viewer1 [label="Viewer 1" fillcolor="dodgerblue"]
viewer2 [label="Viewer 2" fillcolor="dodgerblue"]
viewer3 [label="Viewer 3" fillcolor="dodgerblue"]
viewer4 [label="Viewer 4" fillcolor="dodgerblue"]
sis18ui -> sis18lib
sis18sis18fesa -> sis18lib
sis18esrfesa -> sis18lib
sis18lib -> sis18eb
sis18eb -> sis18cbu
sis18pm -> network [dir="both" color="darkorchid1" lines=ortho]
sis18kd -> network [dir="both" color="darkorchid1"]
sis18cbu -> network [dir="both" color="darkorchid1"]
network -> sis18daq [color="darkorchid1"]
sis18daq -> sis18arch [color="darkseagreen4"]
sis18daq -> sis18cal [color="darkseagreen4"]
sis18daq -> viewer1 [color="darkseagreen4"]
sis18cal -> viewer1 [color="darkseagreen4"]
sis18daq -> viewer2 [color="darkseagreen4"]
sis18cal -> viewer2 [color="darkseagreen4"]
esrui -> esrlib
esresrfesa -> esrlib
esryrfesa -> esrlib
esrlib -> esreb
esreb -> esrcbu
esrpm -> network [dir="both" color="darkorchid1"]
esrkd -> network [dir="both" color="darkorchid1"]
esrcbu -> network [dir="both" color="darkorchid1"]
network -> esrdaq [color="darkorchid1"]
esrdaq -> esrarch [color="darkseagreen4"]
esrdaq -> esrcal [color="darkseagreen4"]
esrdaq -> viewer3 [color="darkseagreen4"]
esrcal -> viewer3 [color="darkseagreen4"]
esrdaq -> viewer4 [color="darkseagreen4"]
esrcal -> viewer4 [color="darkseagreen4"]
yrui -> yrlib
yryrfesa -> yrlib
yrlib -> yreb
yreb -> yrcbu
yrpm -> network [dir="both" color="darkorchid1"]
yrkdi -> network [dir="both" color="darkorchid1"]
yrkde -> network [dir="both" color="darkorchid1"]
yrcbu -> network [dir="both" color="darkorchid1"]
network -> yrdaq [color="darkorchid1"]
yrdaq -> yrarch [color="darkseagreen4"]
yrdaq -> yrcal [color="darkseagreen4"]
network -> acodaq [color="darkorchid1"]
}
Figure: Topology of the B2B system for three ring machines: Control (top), realtime layer (middle) and monitoring (bottom). Boxes and eggs denote components such as expert user interfaces (blue), instances of FESA classes (green), other x86 software (grey), firmware (red), the White Rabbit network (yellow) and a future-moon-landing-mission-solution spanning all layers of ACO (cyan, probably not required). Interconnections between components are indicated as arrows such as timing messages (magenta) and server client relationship implemented via DIM (darkseagreen). There may be none, one or multiple user interfaces for configuration or viewing. Details see text.
Control and Fieldbus Layer
The figure above shows the system topology for control and monitoring. The simplest part is control implemented in the x86 host system(s). One ore more command-line user interfaces (CLI) write set-values to the CBU firmware. The communication layer is Etherbone. However, the Etherbone layer is encapsulated in a shared 'B2B-library'. Writing set-values just requires calling a routine implemented in the library. Today (March 2021) the CLI is operated on the ASL cluster and uses Etherbone via the ACC network as 'middleware'; the only 'frontend software' for control is a socat process.
For 2022 the control layer will be extended by FEA classes. Each CBU will have two FESA classes (if applicable). One that receives the set-values for the extraction ring from LSA. Another one receives the set-values for the injeciton ring.
The fieldbus layer consists of lm32 interconnected via the White Rabbit network. The realtime communication is described
elsewhere.
On-Line Diagnostic
Monitoring turned out to be much more challenging. Especially the ability to diagnose potential issues and their history is of prime importance: Even more important than the get-values of the current transfer are statistical information such as average (mean) value, standard deviation and minimum and maximum value. It is important to provide these data for a longer time span, then just the time for which an application has been opened. Thus, statistical data must be provided in a separate analysis and data layer. Moreover, it must be possible to view the status of the B2B system from anywhere on the network. The implemented solution consists of a simple client-server architecture that follows the 'principle of separation of functions'. Each client or server is extremely simple and just a few hundreds lines of code.
- DAQ. A process that collects all timing messages relevant for B2B transfer. It uses saftlib as an interface to the timing system. It does not do any kind of data processing. This process implements a server the publishes set-values and get-values as services.
- Archiver. This process is a client and subscribes to set-values and get-values published by DAQ server. There is no processing of the data. The raw data are just written to a file. At present (March 2021) the file format is just a text file for two reasons. First, data types of set- and get-values might change and it must be possible to read 'old' data files even after data formats have changed. Second, text files allow easy import and further analysis in spread-sheet calculation programs.
- Analysis. A process that is a client and server at the same time.
- The client part subscribes to set-values and get-values published by the DAQ server. The data are analyzed and processed.
- The server part publishes the results of the analysis as services.
- Viewer. This is a client that subscribes to data published by DAQ and Analysis. It does not do any data processing but just displays the data.
DIM is used for client-server communication for the following reasons.
- extremely limited man-power during the development: a light-weight simple tool was needed
- well tested and widely used at CERN since the 1990s
- open source
- no infrastructure required
- well suited for home-office development during the Covid pandemic
- it is easy to setup small standalone test or development systems
Off-Line Diagnostic
Data written by the archiver are accessible for off-line analysis. Although
all data are written to file, the size of the data files is just a few Megabytes per day. So far, there are no dedicated off-line tools: Readily available tools are spreadsheet calculation and plotting tools such as gnuplot.
Control System Integration
The control user interface part can most likely be achieved by minor modifications of the ParamModi program. A FESA class as frontend software is required on each Frontend Computer hosting a CBU. The shared 'B2B library' can serve as an interface between the FESA class and the lm32 CBU firmware.
The diagnostic part is probably easy too, as only a minor fraction of the diagnostic parameters are of interest for the operators in the main control room.
Supervision
digraph radius {
rankdir=TD;
node [style=filled shape=box width=1.3];
nodesep=0.5;
fwmon1 [label="Mon 1" fillcolor="grey"]
eb1 [label="Etherbone" fillcolor="grey"]
lib1 [label="B2B lib" fillcolor="grey"]
fw1 [label="firmware 1" fillcolor="red"]
fwmon2 [label="Mon 2" fillcolor="grey"]
eb2 [label="Etherbone" fillcolor="grey"]
lib2 [label="B2B lib" fillcolor="grey"]
fw2 [label="firmware 2" fillcolor="red"]
viewer1 [label="Monview 1" fillcolor = "dodgerblue"]
viewer2 [label="Monview 2" fillcolor = "dodgerblue"]
fw1 -> eb1
eb1 -> lib1
lib1 -> fwmon1
fw2 -> eb2
eb2 -> lib2
lib2 -> fwmon2
fwmon1 -> viewer1 [color="darkseagreen4"]
fwmon1 -> viewer2 [color="darkseagreen4"]
fwmon2 -> viewer1 [color="darkseagreen4"]
fwmon2 -> viewer2 [color="darkseagreen4"]
}
Figure: Extremely simple supervision. Boxes denote components such as user interfaces (blue), other x86 software (grey) and firmware (red)/ Interconnections between components are indicated as arrows. Server-client relationship implemented via DIM are indicated with darkseagreen arrows. There may be none, one or multiple user interfaces viewing.
--
DietrichBeck - 24 June 2021