

**ITEA2 Project** Call 6 11025 2012 - 2015

Work-Package 7: "Toolchain"

# Model evaluation report: SystemC model of UNISIG Subset-026-3 3.5 Management of Radio Communication (MoRC)

Roberto Kretschmer, Stefan Rieger

May 2013



#### Funded by:















This page is intentionally left blank

Work-Package 7: "Toolchain"

OETCS May 2013

# Model evaluation report: SystemC model of UNISIG Subset-026-3 3.5 Management of Radio Communication (MoRC)

Roberto Kretschmer, Stefan Rieger

TWT GmbH Science and Innovation Bernhäuser Straße 40-42 73765 Neuhausen

Model Description

Prepared for openETCS@ITEA2 Project

Disclaimer: This work is licensed under the "openETCS Open License Terms" (oOLT) dual Licensing: European Union Public Licence (EUPL v.1.1+) AND Creative Commons Attribution-ShareAlike 3.0 – (cc by-sa 3.0)

THE WORK IS PROVIDED UNDER OPENETCS OPEN LICENSE TERMS (OOLT) WHICH IS A DUAL LICENSE AGREEMENT INCLUDING THE TERMS OF THE EUROPEAN UNION PUBLIC LICENSE (VERSION 1.1 OR ANY LATER VERSION) AND THE TERMS OF THE CREATIVE COMMONS PUBLIC LICENSE ("CCPL"). THE WORK IS PROTECTED BY COPYRIGHT AND/OR OTHER APPLICABLE LAW. ANY USE OF THE WORK OTHER THAN AS AUTHORIZED UNDER THIS OLT LICENSE OR COPYRIGHT LAW IS PROHIBITED.

BY EXERCISING ANY RIGHTS TO THE WORK PROVIDED HERE, YOU ACCEPT AND AGREE TO BE BOUND BY THE TERMS OF THIS LICENSE. TO THE EXTENT THIS LICENSE MAY BE CONSIDERED TO BE A CONTRACT, THE LICENSOR GRANTS YOU THE RIGHTS CONTAINED HERE IN CONSIDERATION OF YOUR ACCEPTANCE OF SUCH TERMS AND CONDITIONS.

http://creativecommons.org/licenses/by-sa/3.0/

http://joinup.ec.europa.eu/software/page/eupl/licence-eupl

# Table of Contents

| 1 | Short Introduction to Formalism and Tool |                                   |    |
|---|------------------------------------------|-----------------------------------|----|
|   | 1.1                                      | SystemC Evaluation Models for WP7 | 5  |
|   | 1.2                                      | Basic Concepts of SystemC         | 5  |
| 2 | Modeling Strategy                        |                                   |    |
|   | 2.1                                      | Modeling Strategy: SysML          | 9  |
|   | 2.2                                      | Modeling Strategy: Code Synthesis | 12 |
| 3 | Mode                                     | l Overview                        | 12 |
| 4 | Mode                                     | l Benefits                        | 12 |
| 5 | Detailed Model Description               |                                   | 12 |
|   | 5.1                                      | Technical Realization SysML       | 12 |
|   | 5.2                                      | Technical Realization SystemC     | 12 |
|   | 5.3                                      | Compilation of the Model          | 1⊿ |

# Figures and Tables

# **Figures**

| Figure 1. Interconnected SystemC Modules                                                | 6    |
|-----------------------------------------------------------------------------------------|------|
| Figure 2. Eclipse IDE with enabled Papyrus plugin, showing the SUT SysML model          |      |
| Figure 3. Top level SysML block definition diagram.                                     | . 11 |
| Figure 4. Example of the internal block diagram of the simulator.                       | . 11 |
| Figure 5. Using the Eclipse model editor to create UML template signatures and bindings | . 13 |

## **Tables**

#### 1 Short Introduction to Formalism and Tool

SystemC is a C++ library providing an event-driven simulation interface suitable for electronic system level design. It enables a system designer to simulate concurrent processes. SystemC processes can communicate in a simulated real-time environment, using channels of different data types (all C++ types and user defined types are supported). SystemC supports hardware and software synthesis (with the corresponding tools). SystemC models are executable.

#### 1.1 SystemC Evaluation Models for WP7

Within the context of Work Package 7 we are working on two different models:

- A SystemC model for Subset 026, Section 3.5, "Radio Communication" which is currently developed by TWT
- A SystemC model regarding the braking curves in Subset 026. This model is being developed by the University of Rostock

At the moment (May 2013), the models are still in an incomplete state but at least a basic version of the radio communication model is ready for assessment. We will provide updates in alignment with the review process as soon as we are able to integrate additional features. As the scope of WP7 is *not* to provide a complete system model, we believe that also incomplete models are suitable to get an idea of the modeling language and judge its suitability for application within the project.

#### **Purpose of this Documentation**

This documentation shall give a short introduction to SystemC, to our modeling process, which is based on a top-down approach based on SysML and code generation thereof, and the structure of our models.

#### 1.2 Basic Concepts of SystemC

A SystemC model is constructed of so-called *modules*, C++ classes derived from a common base class sc\_module. Modules may be nested and are interconnected by *channels*. There is a variety of different pre-defined channels, such as signal-channels (behavior as a shared variable or a hardware wire) or FIFO-queues. In addition, it is possible to define custom, complex channels. Modules usually contain *threads* and *event-triggered methods* that are executed in parallel. Threads and methods may register/wait for certain events in the system, such as the transmission of a message via a channel or a value change of a signal.

## 1.2.1 Defining Modules, Ports and Channels

Figure 1 depicts a simple example structure of a SystemC model. Here we have three modules, where Module A is a sub-module of Module B. Modules B and C are interconnected with two channels. The upper one is a FIFO queue providing a buffered message channel, whereas the lower connection is realized by a signal channel transmitting data directly. For connecting channels, modules provide *ports*. Ports are pre-defined interfaces supporting, e.g., reading or writing operations. Ports are often directed, i.e., there are input and output ports.

To realize the structure from Figure 1 we could declare the modules as follows:



Figure 1. Interconnected SystemC Modules

```
SC_MODULE( ModuleA ) {
2
   };
3
   SC MODULE(ModuleB) {
       sc_port < sc_fifo_out_if < int > > port1;
6
       sc_port < sc_signal_in_if < int > > port2;
7
      ModuleA subsystem;
10
11
12
   };
13
   SC MODULE(ModuleC) {
14
       sc_port < sc_fifo_in_if < int > > port3;
15
       sc_port < sc_signal_inout_if < int > > port4;
16
17
   };
18
```

As you can see, the ports are declared with the corresponding type (in this case sc\_fifo\_out\_if, sc\_fifo\_in\_if, sc\_signal\_in\_if, and sc\_signal\_inout\_if<sup>1</sup>) which are interfaces to the corresponding channels and specified as C++ template parameter. In this example all interfaces have been set up for the message/signal type int<sup>2</sup>.

#### 1.2.2 Connecting the Modules

Although we have defined all three modules, the interconnections are not defined yet as no module has been instantiated and the connections between the modules have not been established by providing the corresponding channels. This could be done as follows in the sc\_main function:

```
int sc_main(int argc, char* argv[]) {
    ...

// Instantiate modules
    ModuleB b("ModuleB instance");
    ModuleC c("ModuleC instance");
```

<sup>&</sup>lt;sup>1</sup>Note that SystemC does not provide an interface that only allows writing to and not reading from signal channels. This makes sense as a read has no effect on the state of the channel (in contrary to FIFO channels). Alternatively one could use sc\_out<int> instead of sc\_port<sc\_signal\_inout\_if<int> >. We use the latter to get a unified notation for ports and to simplify code generation from, e.g., SysML.

<sup>&</sup>lt;sup>2</sup>Note that it is necessary to specify a type here. Of course, also custom types may be used.

```
// Instantiate channels
7
      sc_fifo <int> fifo;
8
      sc_signal <int > signal;
9
10
      // Bind ports to channels
11
      b.port1(fifo);
12
      c.port3(fifo);
13
      b.port2(signal);
14
      c.port4(signal);
15
16
17
  }
```

#### 1.2.3 Writing to and Reading from Ports and Channels

There is no unified way to access ports or channels as they may be intended for different purposes. E.g, where for a signal a single value suffices one could define a channel type that includes addressing and payload to simulate network protocols. For the predefined channels, such as sc\_signal and sc\_fifo methods write and read are supported to write values to and read values from a channel/port, respectively. The semantics in those cases, however, is different:

While for sc\_signal writes and reads are executed immediately and do not have any precondition, writes to and reads from sc\_fifo are blocking if the buffer is full on write or no data is available on read. However, there are also non-blocking versions (nb\_write and nb\_read) that terminate immediately and a return value may be used to determine whether actually any data was written/read.

Thus, in our example write or read operations could look as follows:

```
// In sc_main using the channels:
2
  fifo.write(1);
                               // blocks if FIFO buffer is full
3
  int x = signal.read(); // returns immediately
4
6
  . . .
  // In Module 3 using ports:
  while(true) {
                               // reads from FIFO ports are often executed
10
                               // in a loop as the operation is blocking
11
12
      int x = port3->read(); // blocks until data is available
13
14
15
  }
16
17
  port4 -> write (0);
                              // Non-blocking write to a signal port
18
19
```

In the above code listing it is evident that the access to the ports from the modules is preceded by the -> operator. This is not necessary when directly writing to the channels.

#### 1.2.4 Threads and Event-Triggered Methods

SystemC make heavy use of concurrency and employs an event-based architecture. Events, such as the change of a signal value, can trigger actions. SystemC provides two concepts for this, both of which are realized as member functions within a SystemC module:

**Threads** (SC\_THREAD) are versatile processes that can be halted at any moment and any number of times during their execution by using a wait statement. A thread is run only once. Often, a thread is meant to run for the whole duration of the simulation. This can be achieved by using an infinite loop. A thread can be suspended for a certain amount of time or until an event occurs. The events that a thread is sensitive to are not necessarily statically defined.

**Methods** (SC\_METHOD) will run more than once when they are triggered by an event and cannot be suspended during their execution. In addition, they usually have a static sensitivity list.

Let us look again at our example. In Module C we could define a thread that waits for an incoming integer on Port 3 (FIFO channel) and then writes it out to Port 4 (signal channel). This can be done as follows:

```
SC_MODULE( ModuleC ) {
      sc_port < sc_fifo_in_if < int > > port3;
2
      sc_port < sc_signal_inout_if <int> > port4;
3
4
5
      void mythread(){
6
          while (true) {
             int x = port3 \rightarrow read(); // Read from FIFO
             cout << "Read value" << x << " from Port 3 \n";
10
             port4 \rightarrow write(x);
                                         // Write to signal
          }
11
      }
12
13
      // Module constructor, here by using the default macro; can
14
      // also be defined manually if additional parameters are necessary
15
      SC CTOR(ModuleC){
16
         SC_THREAD(mythread); // Thread initialization
17
18
   };
19
```

Equivalently, one could also use the non-blocking read of the FIFO and explicitly use the wait statement:

```
void mythread(){
    while(true){
        wait(port3->data_written_event());
        int x;
        port3->nbread(x); //Non-blocking read
        cout << "Read value " << x << " from Port 3 \n";
        port4->write(x);
    }
}
```

In Module B we possibly want to output the state of the signal connected to Port 2 when its value changes. This can be accomplished as follows:

```
SC_MODULE( Module B ) {
      sc_port < sc_fifo_out_if < int > > port1;
2
      sc_port < sc_signal_in_if < int > > port2;
3
4
5
      void print_change(){
        cout << "Port 2 value changed to " << port2->read() << endl;</pre>
8
      SC_CTOR(ModuleB){
10
         SC_METHOD(print_change); // Initialize event-triggered method
11
12
          sensitive << port2;
                                       // Make method sensitive to events on port2
      }
13
14
15
   };
```

Thus, whenever the signal connected to Port 2 changes its value, the method print\_change is called. Please note, that in our model of the ETCS radio communication setup we do not use SC\_METHODs for a more streamlined approach. Everything that can be done with SC\_METHODs can be also done with SC\_THREADs.

#### 1.2.5 The SystemC Simulation Scheduler

Here we will later-on add some information about the SystemC simulation scheduler.

# 2 Modeling Strategy

### 2.1 Modeling Strategy: SysML

In the following we shortly introduce the basic modeling strategy, which is based on the decision to use SysML as high level modeling language. In line with the openETCS proposal we developed a modeling workflow of radio communication (MoRC) based on Subset 026, Section 3.5, "Radio Communication" of the ETCS standard following a model driven approach, which is based on available open source tools. The main goal of this approach is a step-wise refinement of models of the SUT to executable code. One obvious question in this regards is what underlying engineering process one chooses, i.e. which steps or abstractions levels are suitable for the development of the SUT. On the one hand SystemC allows the definition of system level descriptions on TLM level which can later be enhanced with further details or the selection of a certain Model of Computation respectively. On the other hand even at the TLM level SystemC might be regarded as too detailed for early stages of system development. Here one is rather interested in high level modeling languages such as UML or SysML which are well suited for the overall system concept and for easy communication with stakeholders of diverse expertise. However there is a semantical gap between these high level modeling languages and the executable code. In the literature different approaches are suggested to bridge this gap between UML/SysML and SystemC. These are mainly realized by defining UML profiles to extend SysML by introducing stereotypes that represent SystemC constructs, e.g., [??]. In our approach we describe use the standard SysML stereotypes to model the MoRC and infer automatically a TLM description in SystemC using code generation. One advantage is that the modeler is not required to learn new language elements. However, since the code generation fixes the semantics of a given SysML model element to a certain SystemC construct the modeler needs to have a basic understanding of this mapping in order to achieve the intended result.



Figure 2. Eclipse IDE with enabled Papyrus plugin, showing the SUT SysML model.

SysML is models consist of structural and behavior elements. In our workflow we first created a top level block diagram. Blocks represent the fundamental structural unit of the SysML model. To create the SysML model we use the Eclipse modeling framework (Indigo version) with activated Papyrus plug in. Papyrus doesn't support the newest version of SysML 1.3, i.e. full and proxy ports are not defined instead we have used flow ports, which is sufficient for our needs. An example of the Eclipse user interface with activated papyrus perspective is shown in Figure 2.

Figure 3 shows the top level block diagram. This diagram also shows two packages, which are embedded in the top level package, which is called SystemCModel. The two nested packages are "'TE"' for the test environment and the SUT package, which contains the actual MoRC model. The use of package allows for a better organization of the overall model and are later mapped to different SystemC namespaces (see below). This way the test environment is clearly separated from all the SUT parts. The TE is needed in order to model how the SUT can be stimulated and eventually simulate it's behavior with the SystemC runtime environment. To distinguish blocks that form the SystemC modules from other block, e.g. primitive and complex data types, we introduced the block sc\_moduleand create links of type "'Generalization"' (c.f. Fig. 3). The other blocks are "'RadioMessage"' which is a data type containing of the type of the message and type and interface definitions. The latter are used to specify, i.e. type the flow ports.

The block Simulatoris the main part of the TE, which is used to connect the instances of the modules and describe the behavior of the TE. At this point we use this block to model the interconnection of the MoRC to the EURORADIO and Trackside model components shown in the internal block definition diagram in Figure 4. Note that this block itself is not derived from sc\_module, i.e. it is not a SystemC module. The connectors in the internal block definition diagram shows the connection between the ports of the modules that were defined in the top level block diagram. Arrows in the flow ports indicate the direction of the data/signal flow, which can be either in, out, and inout. The type of the port shows the kind of data that is transmitted and the kind of connection: buffer, direct, fifo etc. In this case we connect the ports safe\_radio\_statuswith a signal and a simple Boolean value is transmitted. For the safe\_radio\_orderwe used a FIFO connection instead, which better captures the subset 26 requirements.



Figure 3. Top level SysML block definition diagram.



 $Figure \ 4. \ Example \ of \ the \ internal \ block \ diagram \ of \ the \ simulator.$ 

To realize the port types we introduce SystemC specific data types via interface and data type blocks (c.f. lower right part in Fig. 3). We added a redefinable template signature to each interface to be able to model the possibility to transmit different data types with the respective interface. The blocks realizing the interfaces (dashed line with arrow in Fig. 3) define a template binding assigning the template to the "'bool"' primitive. This template information is not shown in the block diagram and we had to use the model tree editor to realize these links, which is shown in Figure 5. The redefinable template signature includes defines a formal classifier template parameter which is substituted withe actual primitive type bool. These described characteristic SystemC model elements might later be added to a dedicated package for easy reuse in other SysML models.

The behavior of the MoRC is modeled with a state machine diagram, which we we will describe here in a upcoming version of this document.

## 2.2 Modeling Strategy: Code Synthesis

In this section we describe the code generation of the SysML model using the Eclipse framework and the Acceleo Plugin. In Eclipse our workflow is organized with two projects. The first, a Papyrus project, contains the the SysML model and the second is an Acceleo project that defines the SystemC code generation. The Acceleo plugin implements the MOF Model To Text Transformation Language (MOFM2T). Using the language one can traverse and query the SysML model tree to access all model elements and their attributes. The SysML/SystemC mapping definition is organized in modules containing templates. These templates are assigned to model elements. The principle of the template is What You Code Is What You Get (WYSIWYG), i.e. all text in the template that is not a MOFM2T language element is put in the transformation output. The language elements contain fundamental control flow constructs, such as loops and if statements as well as variable assignments. In addition it is possible to create files and to extend a template functionality by calling external Java services. For each module we included the SysML and UML profiles, which is needed to declare all types we use in our SysML model. This is achieved by adding the respective URIs when creating a new Acceleo project. The project is linked to our SysML model in the project creation wizard as well.

For the moment our code generator is able to create the structure of the model. For each module a one header and one cpp files is generated. In addition a main.cpp file is created which contains the channel binding according to the SysML model specification. In later version of this document we will describe the translation in more detail and include the transformation of the SysML state machines.

#### 3 Model Overview

These sections will be provided as soon as possible.

## 4 Model Benefits

### 5 Detailed Model Description

#### 5.1 Technical Realization SysML

SysML mit Eclipse, Interfaces, Templates



Figure 5. Using the Eclipse model editor to create UML template signatures and bindings

- 5.2 Technical Realization SystemC
- 5.2.1 Radio Communication Model
- 5.2.2 Braking Curves Model
- 5.3 Compilation of the Model