FMI logo

Based on FMI 2.0 and FMI 3.0, this layered standard defines how to describe and implement XCP support for FMUs, which can either provide an XCP service or allow direct memory access via A2L files.

[Note: Although the document refers to versions 2.0 and 3.0 of the FMI standard, everything described in this document also applies to all subsequent minor versions. For further information on compatibility, see section Versioning and Layered Standards in the FMI 3.0 specification.]


Copyright © 2023-2024 The Modelica Association Project FMI.

This document is licensed under the Attribution-ShareAlike 4.0 International license. The code is released under the 2-Clause BSD License. The licenses text can be found in the LICENSE.txt file that accompanies this distribution.

1. Introduction

1.1. Intent of this Document

FMI 3.0 was extended also with virtual Electronic Control Units (virtual ECUs) in mind. Engineers can measure into ECUs using the XCP protocol [XCP15] and A2L variable descriptions [ASAP2]:

The ASAM MCD-1 XCP (Universal Measurement and Calibration Protocol) standard defines a bus-independent, master-slave communication protocol to connect ECUs with calibration systems. XCP is short for Universal Measurement and Calibration Protocol. The primary purpose of XCP is to adjust internal parameters and acquire the current values of internal variables of an ECU. The first letter X in XCP expresses the fact that the protocol is designed for a variety of bus systems. The standard consists of a base standard, which describes memory-oriented protocol services without direct dependencies on specific bus systems. Several associate standards contain the transport layer definitions for CAN, FlexRay, Ethernet (UDP/IP and TCP/IP), serial links (SPI and SCI) and USB.

— ASAM e.V.
https://www.asam.net/standards/detail/mcd-1-xcp

This layered standard describes how an FMU advertises its XCP capabilities to importers and MCD (Measurement - Calibration - Diagnostics) tools using the XCP protocol.

1.2. How to Read this Document

This document is about how to describe and implement XCP support for FMUs, either by an FMU with integrated XCP service or how to use an external XCP service to access data inside the FMU. To keep the descriptions brief and redundancy low, common concepts, which are used by both implementation types, are described once.

The standard document is in HTML allowing use of in-document links. By pressing "t", the table of contents can be displayed on the left side or hidden.

In key parts of this document, non-normative examples are used to help understand the standard.

Conventions used in this document:

  • Non-normative text is given in square brackets in italic font: [Especially examples are defined in this style.]

  • The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119 (regardless of formatting and capitalization).

1.3. Outline of the Approach

There are alternative implementations depending on the use case and data availability:

  1. The FMU implements one or more XCP slaves which provide access to measurement and calibration variables of the virtual ECU and handles the communication protocol with the XCP master in the MCD tool. The necessary information for an MCD tool is given in one or more variable description files which follow the ASAM MCD-2 MC standard (aka A2L, also [ASAP2]) and customarily carry the file extension .a2l. For further details see Section 4.

  2. An external XCP slave implementation accesses the memory of the virtual ECU to expose the XCP protocol to the MCD tool. In this case, the importer needs to provide such an XCP slave implementation using the A2L variable description file(s) provided by the FMU. fmi3IntermediateUpdateCallback calls or the clocks mechanism could be used to synchronize DAQ lists. For further details see Section 5.

It is also possible for an FMU to have integrated XCP services and to allow memory access for an external XCP service.

The importer might also use the A2L address, type, layout and scaling information to use direct memory access into the virtual ECU. As this approach does not use the standardized XCP protocol it is not further described in this layered standard.

This layered standard will have no effect on the FMU interface, nor the C-API behavior. If an XCP slave is implemented inside the FMU, it is recommended that it runs in its own thread and leaves the rest of the operation of the FMU unaffected.

The A2L/XCP standards allow to measure and calibrate variables synchronously to different types of events. These so called event channels are either time-based, angular-based, or non-deterministic, and are identified by a unique event channel number (also referred to as "measurement raster" in the XCP standard [XCP15]). The XCP service must be invoked with the defined event channel number in the thread which is executed for an event. Calibration and communication with the XCP master is typically performed in a background thread. The background thread must always be responsive to the XCP master within the defined communication timeout. Refer to the A2L/XCP standards for more information.

The XCP/A2L approach can not only be used for virtual ECUs, but also for plant models, if the FMU exporter generates appropriate A2L files.

2. Layered Standard Manifest File

This layered standard defines additional elements that carry relevant interface definitions and capability flags in the layered standard manifest file. Table 1 shows the attributes of the root element of fmi-ls-manifest.xml.

Table 1. Root Element Attribute Details.
Attribute Namespace Value Description

fmi-ls-name

http://fmi-standard.org/fmi-ls-manifest

org.fmi-standard.fmi-ls-xcp

Name of the layered standard in reverse domain name notation.

fmi-ls-version

http://fmi-standard.org/fmi-ls-manifest

1.0.0

Version of the layered standard. This layered standard uses semantic versioning, as defined in [PW13].

fmi-ls-description

http://fmi-standard.org/fmi-ls-manifest

Layered standard based on FMI 2.0 and FMI 3.0 for describing and implementing XCP support for FMUs, which can either provide an XCP service or allow direct memory access via A2L files.

String with a brief description of the layered standard that is suitable for display to users.

The root element must contain at least one, and can contain more than one Interface elements. Each such element specifies one set of interface information for calibration using one underlying variable description file (A2L). Multiple elements might be provided if there are different XCP slaves embedded in the FMU, or there are other reasons why multiple A2L variable description files that apply in parallel have to be provided.

Each Interface element has the following attributes:

Table 2. Interface Element Attribute Details.
Attribute Namespace Value Description

definition

Relative URI

This attribute must be a relative reference to a URI (formerly called a relative URI) to the A2L variable description file for this interface. It may not contain any dot segments, that is, complete path segments consisting only of . or ... It is resolved to an absolute URI using a base URI that depends on the relevant FMU target, as defined in Section 3.1.

types

List of CoSimulation, ModelExchange, ScheduledExecution, separated by a whitespace character

Optional attribute to restrict the applicability of the interface being defined to certain FMU interface types. The value is provided as a list of interface type names to which this interface applies. If the attribute is not provided, the interface applies to all available FMU interface types.

description

String

Optional human-readable description of the interface being defined.

containsXCPService

true or false

If true, the FMU provides its own XCP slave implementation. See Section 4. Defaults to false.

supportsDirectMemoryAccess

true or false

If true, the FMU allows direct memory access from the outside via the information provided in its variable description file. In most cases this mechanism will be used by an external XCP service provided by the importer. See Section 5. Defaults to false.

The attribute definition is required, all other attributes of Interface are optional. The FMU must provide a valid definition attribute and must set at least one of the attributes containsXCPService or supportsDirectMemoryAccess to true to comply with this layered standard.

Additionally the Interface element can contain one or more Variable elements, which assign relevant roles to existing FMU variables.

Each Variable element has the following attributes:

Table 3. Variable Element Attribute Details.
Attribute Namespace Value Description

name

Valid variable name

Name of a variable defined in the modelDescription.xml of the FMU.

role

Valid role enum value

Role of the variable. Must be a valid role as defined in Section 4.1.

Each Variable entry assigns a role to an existing variable. No variable shall occur in more than one Variable entry. No role shall occur in more than one Variable entry of one Interface, but can occur again in Variable entries of a different Interface. The set of allowed roles and their meaning is defined in Section 4.1.

An example of a manifest file for this layered standard is shown below:

<?xml version="1.0" encoding="UTF-8"?>
<fmiLayeredStandardManifest
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:noNamespaceSchemaLocation="../../schema/fmi3LayeredStandardXcpManifest.xsd"
    xmlns:fmi-ls="http://fmi-standard.org/fmi-ls-manifest"
    fmi-ls:fmi-ls-name="org.fmi-standard.fmi-ls-xcp"
    fmi-ls:fmi-ls-version="1.0.0"
    fmi-ls:fmi-ls-description="Layered standard based on FMI 2.0 and FMI 3.0 for describing and implementing XCP support for FMUs, which can either provide an XCP service or allow direct memory access via A2L files.">
    <Interface definition="vECU1.a2l" description="First embedded XCP service for internal vECU 1, supports both TCP/UDP with full control"
        containsXCPService="true">
        <Variable name="XCP.vECU1.TCP.Enable" role="XCPServiceTCPEnable"/>
        <Variable name="XCP.vECU1.TCP.Port" role="XCPServiceTCPPort"/>
        <Variable name="XCP.vECU1.TCP.ListenAddress" role="XCPServiceTCPListenAddress"/>
        <Variable name="XCP.vECU1.UDP.Enable" role="XCPServiceUDPEnable"/>
        <Variable name="XCP.vECU1.UDP.Port" role="XCPServiceUDPPort"/>
        <Variable name="XCP.vECU1.UDP.ListenAddress" role="XCPServiceUDPListenAddress"/>
    </Interface>
    <Interface definition="vECU2.a2l" description="Second embedded XCP service for internal vECU 2, TCP only, limited control"
        containsXCPService="true">
        <Variable name="XCP.vECU2.TCP.Enable" role="XCPServiceTCPEnable"/>
    </Interface>
    <Interface definition="vECU3Mem.a2l" description="Internal vECU 3 only via direct memory access"
        supportsDirectMemoryAccess="true"/>
    <Interface definition="vECU4Both.a2l" description="Internal vECU 4 with dual XCP and direct memory access, no control over XCP"
        containsXCPService="true"
        supportsDirectMemoryAccess="true"/>
    <Interface definition="vME.a2l" types="ModelExchange" description="Applicable definition solely for ModelExchange"
        supportsDirectMemoryAccess="true"/>
    <Interface definition="vCSSE.a2l" types="CoSimulation ScheduledExecution" description="Applicable definition for CS and SE"
        supportsDirectMemoryAccess="true"/>
</fmiLayeredStandardManifest>

3. Common Concepts

Independent of the selected implementation approach (see Section 1.3), the XCP behavior as seen by an external MCD tool (XCP master) shall be the same. The concepts defined in this chapter are common to both of the implementation approaches. The definitions that are specific to the particular implementation types are defined in Section 4 and Section 5.

3.1. Structure of the FMU Archive

The manifest file, any A2L variable description files and other files needed for XCP support are placed in /extra/org.fmi-standard.fmi-ls-xcp. [This allows these files to be added and modified after the FMU has been created without affecting any checksums.] The directory structure is analogous to the binaries directory structure, specific to the FMI version. The structure for an FMI 3.0 FMU is shown below. Details are described in the following sections.

documentation
   fmi-ls-xcp.{txt|html}           // Informal description how to use XCP/A2L for this FMU (optional).
extra/org.fmi-standard.fmi-ls-xcp  // Contains files related to XCP/A2L
   fmi-ls-manifest.xml             // The layered standard manifest file
   <definition1.a2l>               // Variable description of a source code FMU (optional)
   <definition2.a2l>               // Variable description of a source code FMU (optional)
   ...
   x86_64-windows
      <definition1.a2l>            // Variable description for Windows on Intel 64-bit (optional)
      <definition2.a2l>            // Variable description for Windows on Intel 64-bit (optional)
      ...
   x86-linux
      <definition1.a2l>            // Variable description for Linux on Intel 32-bit (optional)
      ...
   aarch32-linux
      <definition1.a2l>            // Variable description for Linux on ARM 32-bit (optional)
      ...
   x86_64-darwin
      <definition1.a2l>            // Variable description for macOS (optional)
      ...

The <definition1.a2l> and <definition2.a2l> above are the relative URI references of the corresponding definition attributes of Interface elements. The resultant absolute URI to the variable description file results from resolving the relative URI against the following base URI:

  • For a source code FMU target the base URI is the URI of the manifest file.

  • For a binary FMU target the base URI is the URI that results by replacing the file name part of the URI of the manifest file with a directory path component with the given target name of the relevant FMI version.

If multiple Interface elements are present in the manifest, then multiple A2L variable description files will be present at each level of the directory structure, as defined by their definition attribute values.

3.2. Documentation

When shipping an FMU with XCP/A2L support, it is recommended to provide the necessary information to the importer in the file documentation/fmi-ls-xcp.{txt|html}. For example, this might concern additional information on how to build the final A2L file, if the FMU is delivered as source code.

3.3. A2L Description Files

ASAM MCD-2 MC (aka ASAP2) defines the description format of the internal ECU variables used in measurement and calibration. Measurement & calibration systems (MC-systems) require this description for both the parameterization of scalar constants, curves and maps of the ECU software and for recording the system’s response via measurement variables during real-time testing. The description contains information about data types, dimensions, record layouts and memory locations of ECU variables. The standard also describes how the variable values are converted into human-readable quantities and displayed in an MC-system.

— ASAM e.V.
https://www.asam.net/standards/detail/mcd-2-mc

The A2L description depends on the FMU binary, for example, regarding memory addresses, and byte order. If an FMU archive contains multiple binaries for different platforms, the associated A2L files are placed into separate subdirectories below /extra/org.fmi-standard.fmi-ls-xcp following the same scheme as in the binaries directory, see Section 3.1.

All A2L files in the FMU should use the same XCP configuration, including the same protocol (TCP/UDP), ports, etc.

Note that the A2L files placed under the extra directory are not accessible to the FMU at runtime. Any files that shall be accessible to the FMU at runtime must (also) be placed into the resources directory as defined by the FMI standard.

A2L files may have a considerable size. If size is a concern, it may be decided to supply just a single platform and A2L file with an FMU.

All format versions of the A2L standard are allowed and it is the responsibility of the MCD tool to handle each format version correctly.

This layered standard forbids the use of the including mechanism of additional A2L files to simplify complete extraction and copying of the A2L file to a location where it is accessible by the MCD tool.

The handling of address information in the A2L file depends on the selected implementation approach for the XCP slave (FMU-internal or external, see Section 1.3) and on the FMU format (binary or source code FMU). See Section 4.3 and Section 5.3, respectively, for detailed information about address resolution.

3.4. XCP Protocol Settings

The A2L description shall include IF_DATA XCP elements to help MCD tools to connect and interact with the XCP service of the FMU more reliably and without user interaction. Parts of the IF_DATA XCP description depend on the machine where the FMU binary is executed, for example, the IP address and port.

The default IP address assigned by the FMU exporter should be a localhost IP address, that is one of the loopback interface IP addresses (127.0.0.1 for IPv4 or ::1 for IPv6), as this is the most fitting choice in many cases.

The requirement for the port number is, that it must be unique on the machine where the FMU binary is executed. Typically, a certain range of ports is reserved for this purpose. The FMU importer is responsible for checking if any conflicts of the defined IP addresses and port numbers occur in the context of the simulated system.

In the case of an internal XCP service, it is sometimes necessary for the FMU importer to override the default IP address and/or port number which was assigned by the FMU exporter. For more information about how to configure and handle the XCP service, see Section 4.1. In the case of an external XCP service the connection settings are under the control of the importer.

3.5. Source Code FMUs

An FMU may be delivered as source code together with a buildDescription.xml file. This case requires a common understanding of the A2L workflow between the FMU exporter and importer. In practice there are different flavors of the workflow depending on the specific use case.

The FMU exporter shall describe the measurement variables (MEASUREMENT), calibration parameters (CHARACTERISTIC) and related A2L elements of its application in the A2L file. The A2L file is necessarily incomplete as the details of the A2L description depend on the binary for the target platform. For example, the real addresses and memory segments are not known until the FMU binary is built. For information on how to deal with memory addresses refer to Section 4.3 or Section 5.3, respectively.

The A2L description is placed directly into the folder /extra/org.fmi-standard.fmi-ls-xcp if it is target-independent, or in target-specific subfolders otherwise (see Section 3.1).

The FMU importer is responsible for ensuring that the target-specific information in the A2L file is adapted to the target platform for which a source code FMU is built, before making the A2L file available to the MCD tool.

If additional information for the build process and A2L creation is required, it should be provided by the FMU exporter in /documentation/fmi-ls-xcp.{txt|html}.

3.6. Variable Visibility

The modelDescription.xml file publishes a certain set of variables and parameters. The A2L file also publishes a set of FMU variables and parameters. This standard expressly does not restrict the relationship between both sets of variables.

[As a matter of fact, it is quite likely that the variables published in modelDescription.xml is a minimal set required for connectivity reasons. The A2L file might publish a much larger set of variables and parameters that the user can selectively choose to measure or calibrate.

The details of the variable access are transparent from the viewpoint of an MCD tool, as this information is encapsulated in the A2L file.]

3.7. Numeric Effects of XCP Access

While measurement of FMU internal variables does not have a numeric effect on the FMU, so called calibration does. Calibration is the tuning of FMU internal parameters. Such changes will affect the numeric behavior of the FMU. If the FMU contains controller code, numeric stability or energy preservation laws are of lesser concern. On the other hand, plant models offering XCP access for parameter calibration may introduce surprising numerical effects in solvers that might require proper handling, like resetting solvers with every XCP write action.

It is therefore necessary to synchronize XCP variable access (read and write) with the state of the FMU. [For instance, time is not necessarily increasing monotonically in Model Exchange, and variable values might change within an fmi3DoStep call due to Intermediate Variable Access in Co-Simulation. Appropriate care must be taken when to serve XCP master requests to ensure simulation and measurement integrity.]

4. FMU with Integrated XCP Service

If the XCP slave is implemented in the FMU, the FMU is responsible for handling the communication protocol with the XCP master. The following sections describe how to configure and handle the internal XCP slave.

The FMU states that it contains an internal XCP slave implementation with the containsXCPService attribute in the fmi-ls-manifest.xml file.

[Figure 1 shows a typical design where the XCP slave (in the FMU) communicates with the XCP master (in the MCD tool) using a separate network channel, e.g., the IP stack of the host OS. Thus, the communication of the XCP service is not mixed with the simulated network communication of the ECU wrapped in the FMU. [1]

Figure 2 shows an alternative design where the XCP slave communicates via the COM stack of the virtual ECU as in a real ECU. In this case, the simulator has to provide access to the simulated network communication for the MCD tool. This design may be chosen if the XCP slave implementation is already part of a level-3 ECU code to be tested. [2]

XCP Communication via IP Stack
Figure 1. Direct communication of XCP master and XCP slave via the IP stack of the host OS.
XCP Communication via Virtual ECU COM Stack
Figure 2. Communication of XCP master and XCP slave via the COM stack of the virtual ECU.

The implementation of the XCP slave inside the FMU shall only use calls of the host OS, which leave the behavior of the FMU unaffected. This concerns, for example, host OS calls [3] needed for creation of an own background thread. Note that blocking OS calls should be avoided, because they may have an effect on other parts of the simulator outside the FMU.]

4.1. Configuring the XCP Protocol Settings

To avoid collisions in a simulation system with several XCP services, it can be necessary for the FMU importer to override the default port number the FMU listens on, which was assigned by the FMU exporter in the XCP slave implementation and in the A2L file (see Section 3.4).

Besides the listen port number, the user may also want to change or restrict the listen IP address, which is the IP address of the network interface to which the socket of the XCP service is bound and where it is listening for XCP client commands. In many cases, the listen IP address will be set to INADDR_ANY (0.0.0.0 for IPv4, :: for IPv6), allowing connections from any available network interface. However, it is possible to restrict the XCP service to listen only on a single interface. This is commonly done with the loopback addresses (127.0.0.1 for IPv4 and ::1 for IPv6), to only allow local connections.

Furthermore, it is likely valuable for the user to have the possibility to deactivate the internal XCP service to avoid certain problems with the environment, e.g., with anti-virus software or firewalls or when running the FMU in a container. The importer might also want to use an external XCP service even when an internal XCP service is available.

Therefore, if the XCP slave is embedded in the virtual ECU, the FMU should expose the following configuration capabilities as variables in the modelDescription.xml file, which are used to configure the embedded XCP slave (see Section 4.2). The variable that is provided for a capability is identified by providing a Variable element in the relevant Interface element of the manifest file, with the name of the variable and its role as the corresponding attribute values.

Enable XCP over TCP

Determines whether the TCP instance of the XCP service provided by the FMU shall be started.

Role

XCPServiceTCPEnable

Type

Boolean

Example Start Value

true

Requirement Type

Should be supplied, if the FMU provides an XCP service using TCP.

If not present

Defaults to true, so if the XCP slave supports TCP, it will be started.

TCP listen port number

TCP port number where the XCP slave listens for XCP protocol commands.

Role

XCPServiceTCPPort

Type

UInt16 / Integer

Example Start Value

In an agreed range of ports, e.g., 32768 to 39999.

Requirement Type

Should be supplied, if the FMU provides an XCP service using TCP.

If not present

Defaults to the protocol data values found in the relevant A2L file.

TCP listen IP address

IP address where the XCP slave listens for XCP protocol commands over TCP.

Role

XCPServiceTCPListenAddress

Type

String

Example Start Value

0.0.0.0 or ::0

Requirement Type

Should be supplied, if the FMU provides an XCP service using TCP.

If not present

Defaults to the protocol data values found in the relevant A2L file.

Enable XCP over UDP

Determines whether the UDP instance of the XCP service provided by the FMU shall be started.

Role

XCPServiceUDPEnable

Type

Boolean

Example Start Value

false

Requirement Type

Should be supplied, if the FMU provides an XCP service using UDP.

If not present

Defaults to true, so if the XCP slave supports UDP, it will be started.

UDP listen port number

UDP port number where the XCP slave listens for XCP protocol commands.

Role

XCPServiceUDPPort

Type

UInt16 / Integer

Example Start Value

In an agreed range of ports, e.g., 32768 to 39999.

Requirement Type

Should be supplied, if the FMU provides an XCP service using UDP.

If not present

Defaults to the protocol data values found in the relevant A2L file.

UDP listen IP address

IP address where the XCP slave listens for XCP protocol commands over UDP.

Role

XCPServiceUDPListenAddress

Type

String

Example Start Value

0.0.0.0 or ::0

Requirement Type

Should be supplied, if the FMU provides an XCP service using UDP.

If not present

Defaults to the protocol data values found in the relevant A2L file.

All variables that are defined must be defined as scalars with one of the following causality/variability combinations:

  • fixed structuralParameter (FMI 3.0 only): If the FMU defines the variables as structuralParameters, the XCP configuration can be changed during Configuration Mode. When the XCP service is started in fmi3ExitConfigurationMode, it is configured and running before the simulation starts, specifically before Initialization Mode is entered. For FMI 3.0, this is the most flexible variant and should be preferred over the other variants.

  • fixed parameter: If the FMU defines the variables as parameters, the FMU signals that it does not support Configuration Mode. For FMI 3.0, this means, the XCP service is started at the latest when Initialization Mode is entered. In case of FMI 2.0, the FMU should preferably start the XCP service in the fmi2SetupExperiment function. This allows for configuring the XCP service with the configuration parameters and ensuring that the service is running before the simulation starts. This is the preferred variant for FMI 2.0.

  • constant output: If the FMU is restricted to a fixed XCP configuration, it shall at least announce its configuration to the outside. This could be done via constant outputs that can be used in another model. It allows the importer to read the configuration and, e.g., react to port collisions without having to read the A2L file. With this variant the importer will not be able to deactivate the XCP service or to change the port number, which can lead to collisions when several FMUs are imported.

  • fixed/tunable calculatedParameter: This variant is similar to constant output. The FMU does not allow its XCP configuration to be changed directly, but it announces its configuration via calculatedParameters that depend on other parameters. With this variant the importer has no direct influence on activating or deactivating the XCP service or changing the port number, which can lead to collisions when several FMUs are imported.

[The variables above do not necessarily have to share the same causality/variability combination. However, e.g., a mixture of structuralParameters and parameters is not sensible. If Configuration Mode is supported, then structuralParameters should be used. On the other hand, an FMU could have parts of its XCP configuration fixed while leaving others configurable. In this case, a combination of, e.g., structuralParameters and constant outputs could make sense.]

The configuration variables are duplicated for both transport layers, TCP and UDP, as it is technically possible to have an XCP slave that uses TCP and UDP channels in parallel. The FMU shall only provide the corresponding variables for the protocols it supports.

Without knowing the concrete XCP slave implementation the importer cannot know if the different protocols can be used in parallel or only exclusively. In case the XCP service is not multi-session capable and both of the variables with role XCPServiceTCPEnable and XCPServiceUDPEnable are set to true, the FMU must return an error and provide a meaningful error message when exiting Configuration Mode. This information may also be provided in the documentation directory inside the FMU.

The importer of an FMU is responsible for keeping all occurrences of the port number consistent, including both the FMU configuration and the A2L file that is presented to the MCD tool.

4.2. Starting and Stopping the XCP Service

Since an XCP slave is implemented inside the FMU, the FMU is responsible for starting and stopping the internal XCP service.

Using FMI 3.0, the FMU should preferably expose its XCP configuration variables (see Section 5.1) as structuralParameters and start the XCP service during the first invocation of fmi3ExitConfigurationMode and shut it down during fmi3Terminate, if the FMU has no explicit power-up signal to simplify user interactions between simulator and MCD tool. If the FMU contains a virtual ECU with power-up control (K15), all built-in OS and Basic Software services (including XCP) should follow the normal power-up protocol.

If the simulator puts the FMU in Configuration Mode and sets the structural parameters with role XCPService{TCP|UDP}ListenAddress and XCPService{TCP|UDP}Port, the XCP slave shall use those parameters to set up the communication connection for the XCP protocol.

If the value of structural parameter with role XCPService{TCP|UDP}Enable is true, the XCP slave must be responsive for XCP commands on the corresponding channel (TCP/UDP) after leaving Configuration Mode. Thus, it is possible for the XCP master to perform calibration during the Instantiated state, for example, to set parameters before entering Initialization Mode. Note that reading values of calculated variables, which depend on an initialization function, is only possible after entering the Initialized super state with fmi3ExitInitializationMode.

If the variable with role XCPService{TCP|UDP}Enable is false, the internal XCP service must not be started with TCP/UDP, the network resources must not be used and no XCP service actions must be performed by the FMU on this channel during simulation. If both parameters are false the XCP service must not be started at all.

If Configuration Mode was not entered and the value of variable with role XCPService{TCP|UDP}Enable is true, the FMU must start the XCP service in fmi3EnterInitializationMode at the latest. In this case, it is not possible to perform calibration before Initialization Mode is entered or to configure the XCP connection settings.

If the importer re-enters Configuration Mode and reconfigures the parameters it is up to the FMU if it reacts to the parameter change or not.

Using FMI 2.0, the FMU should preferably expose its XCP configuration variables as parameters and start the XCP service during the first call of fmi2SetupExperiment and shut it down during fmi2Terminate if the FMU has no explicit power-up signal to simplify user interactions between simulator and MCD tool. The importer is responsible for calling fmi2SetupExperiment at least once and setting the parameters before fmi2SetupExperiment is called.

If the FMU does not expose its XCP configuration variables as structuralParameters using FMI 3.0, or as parameters using FMI 2.0, the importer will not have control over whether the internal XCP service should be started. In this case, the default value of the start attribute of the variable with role XCPService{TCP|UDP}Enable, if it exists, determines if the XCP service is started. If no variable of this role exists, then the XCP service is always started.

[Note that it is not possible to manually change the start value for any variable in the modelDescription.xml file to change the behavior of the internal XCP service. The start value merely reflects the default behavior coded into the FMU.]

4.3. Memory Address Resolution

Dependent on the FMU format and the XCP slave implementation inside the FMU, dealing with memory addresses of variables in the A2L file differs.

If the FMU is in binary format, that is, it is shipped with a shared library, the FMU exporter must provide values for the ECU addresses inside the A2L file, and the XCP slave inside the FMU is responsible for resolving the physical addresses from the address field values. [These address field values can be either real addresses or fixed target-independent indices that are used by the XCP slave implementation for getting variables during runtime.]

If the FMU is only shipped with source code, the memory addresses cannot be determined before building the binary, so the exporter cannot provide real addresses in the A2L file. In this case the address field values in the A2L file must be either fixed target-independent indices, which allow the FMU to resolve the addresses at runtime, or the A2L file only contains linker symbol links (SYMBOL_LINK). In the latter case, the importer or an external A2L tool is responsible for determining the actual variable addresses from the symbol links. These addresses must be relative to the base address of the built FMU binary. Refer to the ASAM MCD-2 MC standard for more information on symbol links and automatic address update.

If the FMU exporter does not use real (offset) addresses in the A2L file in the binary FMU case, or does not provide symbol links in the source code FMU case, attribute supportsDirectMemoryAccess in the fmi-ls-manifest.xml file must be set to false (see Section 5.3).

5. External XCP Service

An FMU might support XCP but does not bring along its own XCP slave implementation (attribute containsXCPService = false in the corresponding Interface element of the fmi-ls-manifest.xml file). In this case the FMU importer must provide its own implementation of an XCP slave.

It is also possible that the FMU does contain an internal XCP slave implementation but additionally allows the importer to access the memory of the virtual ECU with an external XCP service (attribute supportsDirectMemoryAccess = true). In this case it is the choice of the importer whether to use the FMU internal XCP slave or its own implementation. See Section 4.2 on how to deactivate the internal XCP service.

Although the XCP behavior for an internal and an external service is the same from the perspective of the MCD tool (XCP master), the operation of the external XCP service differs from the internal one in some points that are described in this chapter.

[Figure 3 shows a design where the XCP slave is implemented by the importer outside of the FMU. In this variant the XCP communication uses the IP stack of the host OS analogous to the design in Figure 1.]

XCP Communication external Slave
Figure 3. Communication of XCP master and external XCP slave via the IP stack of the host OS.

5.1. Configuring the XCP Protocol Settings

For an external XCP service no structural parameters for the XCP configuration are needed, because the importer has the entire control over the XCP service and is responsible for its configuration. [The importer should allow the user to set IP address and port number analogous to the variant with an internal XCP service.]

When an external XCP service is used, the importer has to make XCP service calls and is responsible for creating events for its XCP service. However, in contrast to the FMU with internal XCP support, the importer does not have the knowledge about the inner structure of the virtual ECU and therefore it is not able to create specific XCP events, e.g., one event for each task.

This means, by default, the importer can only make XCP calls at certain points in time, e.g., at communication points in Co-Simulation, ignoring specific task-related XCP events. The importer is responsible for matching the IF_DATA XCP section in the A2L file to the implementation of the XCP service. If necessary, the IF_DATA XCP section must be added or replaced in the A2L file delivered with the FMU, before making it available to the MCD tool. For example, the importer can create an event channel for a basic measurement raster and write the corresponding event definition into the IF_DATA XCP section of the A2L file.

If a Co-Simulation FMU announces that it makes use of the intermediate update callback function (attribute providesIntermediateUpdate = true of the Co-Simulation element), the importer may also create another event for the intermediate update raster and call the XCP service in each fmi3IntermediateUpdateCallback with the event channel number of this event.

Furthermore, if the FMU contains clocks, the importer might also provide the user with the ability to create separate XCP events for each clock. In this case the simulator is responsible for handling the mapping between clock and XCP event and must call the XCP service with the corresponding event channel when the associated clock is active just before leaving Event Mode.

5.2. Starting and Stopping the XCP Service

Since the XCP slave is implemented outside the FMU, the importer is responsible for starting and stopping the external XCP service. [Preferably, the start-up is performed sometime during the Instantiated state of the FMU to allow the XCP master to set parameters before entering Initialization Mode.]

5.3. Memory Address Resolution

Depending on the FMU format, dealing with memory addresses of variables in the A2L file differs.

In the binary FMU case, the A2L file must contain real addresses, which are relative to the base address of the FMU binary, allowing the external XCP slave to access the memory of the FMU correctly.

Since the external XCP slave can only make use of real addresses and in the case of source code FMUs there are no real addresses available yet, the A2l file must contain linker symbol links (SYMBOL_LINK). In this case, analogous to the use of an internal XCP slave, the importer or an external A2L tool is responsible for determining the actual variable addresses from the symbol links.

6. Known Limitations of this Standard

General limitations:

  • This standard forbids the use of the including mechanism of additional A2L files to simplify complete extraction and copying of the A2L file to a location where it is accessible by the MCD tool.

  • If the FMU contains target-specific binaries and target-specific source code for the same platform, the corresponding A2L files cannot be assigned uniquely. Therefore, this constellation is not applicable to this layered standard and the FMU exporter must decide between source code and binary files for this platform.

  • If the manifest attribute supportsDirectMemoryAccessViaA2L is set to true and an external XCP service is used, the importer must not instantiate the FMU more than once because a variable in the A2L file has only one associated memory address.

Limitations for binary FMUs:

  • Normally only variables in the memory segments owned by the main FMU binary <modelIdendifier>.{dll|so} are accessible by the XCP service. This usually encompasses variables defined in source code modules and in statically linked libraries. Accessing variables in the memory of indirectly loaded dynamic libraries requires a special implementation which is out-of-scope for this layered standard.

7. Contributions

  • Christian Bertsch, Robert Bosch GmbH, Germany

  • Matthias Blesken, dSPACE GmbH, Germany

  • Cláudio Gomes, Aarhus University, Denmark

  • Andreas Junghanns, Synopsys, Germany

  • Ulrich Kiffmeier, dSPACE GmbH, Germany

  • Pierre R. Mai, PMSF IT Consulting, Germany

  • Benedikt Menne, dSPACE GmbH, Germany

  • Torsten Sommer, Dassault Systèmes, Germany

  • Markus Süvern, dSPACE GmbH, Germany

  • Patrick Täuber, dSPACE GmbH, Germany

Contributions to this layered standard to the FMI standard are covered by the Corporate Contributors License Agreement (CCLA) of the Modelica Association Project FMI.

References


1. The network communication of FMUs is described by another layered standard. The details of network communication are out of scope here.
2. The same design could be used to access a diagnostic service, if it is implemented by the ECU code inside the FMU.
3. The term 'host OS' means the OS where the FMU process is executed. This could even be the OS inside a virtual machine connected to the simulator.