8.6. Known Issues

8.6.1. Code Generator cannot parse a file preproccesed with GCC 11

GCC 11 produces unexpected output when used as a preproccesor. This unexpected output causes an error in Code Generator.

This issue can be worked around with any of the steps below:

  • Disable the preprocessor (unless it is required): rtiddsgen -ppDisable ...

  • Explicitly set a different preprocessor: rtiddsgen -ppPath /path/to/cpp

  • Set a different PATH, where a different preprocessor is selected first: PATH=/path/to/cpp:${PATH} rtiddsgen...

  • Disable line markers in your preprocessor, e.g. for GCC: rtiddsgen -ppOption -P ...

[RTI Issue ID CODEGENII-1508]

8.6.2. AUTOSAR ErrorHook may create CPU overhead

If enabled during configuration, the AUTOSAR OS Hook ErrorHook may be called if Connext Micro tries to cancel an alarm that has already been signaled. There is no known workaround for this issue.

[RTI Issue ID MICRO-5367]

8.6.3. Maximum Number of Components Limited to 58

The maximum number of components that can be registered is limited to 58.

8.6.4. CMake version 3.6 or Higher is Required to Build VxWorks with CMake

Limitations in CMake prior to 3.6 required forcing the compiler to a specific path. However, this resulted in warnings from CMake 3.6 and higher that this feature has been deprecated and instead the CMAKE_TRY_COMPILE_TARGET_TYPE should be used to prevent linking.

Unless there are specific needs,there are no plans to support CMake prior to 3.6 when building for VxWorks.

8.6.5. Endpoint Discovery Requires Unique Object IDs Across All Remote Endpoints

When using static endpoint discovery (DPSE), RTI Connext Micro requires that the object_id for statically asserted remote endpoints must be unique across all remote endpoints, as opposed to just between remote endpoints within the same participant. Note, this restriction was incorrectly documented as removed in version 2.4.1.

8.6.6. Compiler warnings on VxWorks

When compiling for VxWorks 6.9 with the -Wconversion flag there are compiler warnings of the type:

warning: conversion to 'DDS_Boolean' from 'int' may alter its value

These compiler warnings seem to be an issue with GCC for VxWorks and can be ignored. The problem is that returning a value from a expression seems to always be treated as an unbounded int as opposed to an int with a value of 0 or 1 as the C standard dictates.

8.6.7. OSAPI Does Not Always Detect Endianess

osapi_cc_stdc.h detects the CPU endianness by checking GCC predefined macros, such as __BYTE_ORDER__. However, some versions of GCC does not set these macros, for example GCC for VxWorks. If osapi_cc_stdc.h does not find any of the flags, it incorrectly sets the CPU to little endian.

In this case it is important that one of the following preprocessor macros are defined:

  • RTI_ENDIAN_BIG The CPU is big-endian

  • RTI_ENDIAN_LITTLE The CPU is little-endian

NOTE: The VxWorks cmake toolchain file from RTI set these based on CPU type in the target name (–name option).

8.6.8. Missing Checks for max_routes_per reader and max_routes_per_writer

The DDS_DataReaderQos.reader_resource_limits.max_routes_per_writer and DDS_DataWriterQos.writer_resource_limits.max_routes_per_reader fields are missing a check that the values are in the range [1,2000]. The fields are also missing from the methods DDS_DataReaderQos_is_equal and DDS_DataWriterQos_is_equal, respectively.