3.3.1. General Compatibility 6.0.1

This section describes compatibility issues that affect the Connext suite in release 6.0.1. Unless noted otherwise, the issues in this section do not apply to Connext Micro.

Attention

For information on new and removed platforms and features in this release, see What’s New in 6.0.1. See also individual products’ Release Notes.

3.3.1.1. Wire Compatibility

3.3.1.1.1. RTPS Versions

For information about the RTPS versions supported for each Connext release, see Compatibility, in the RTI Connext DDS Core Libraries Release Notes (7.1.0).

3.3.1.1.2. Fragmentation is now independent of sample serialized size

In 6.0.1, when using a FlowController, the fragment size for a sample should be either (a) bytes_per_token or (b) the smallest of the message_size_max values across all transports installed with the DataWriter, whichever is less.

In previous releases, however, if the serialized size of the sample was smaller than or equal to the maximum message size of the transport with which the sample was sent, minus some protocol overhead (512 bytes by default), Connext chose the maximum message size of the transport as the fragment size, ignoring bytes_per_token, which may be smaller.

This behavior may have led to a bursty behavior of the FlowController that resulted in not sending fragments every period but sending them only when enough tokens were accumulated to send the full sample.

This problem has been resolved. (See RTI Issue ID CORE-9287 in “Fixes Related to Reliability Protocol and Wire Representation” in the RTI Connext Core Libraries Release Notes.) Now when the serialized size of a sample when using a FlowController is smaller than or equal to the maximum message size of the transport as described above, the fragment size for the sample is the lesser of (a) bytes_per_token or (b) the smallest of the message_size_max values across all transports installed with the DataWriter.

If you need to go back to the old behavior, before this fix, please contact support@rti.com.

3.3.1.2. Type System Compatibility

3.3.1.2.1. Wire representation of TypeObject

In 6.0.0, Connext enabled TypeObject compression by default to reduce bandwidth usage when exchanging endpoint discovery data. See Section 3.4.1.3.2. The compressed TypeObject (TypeObjectLb) deserialization depended on the DDS_DomainParticipantResourceLimitsQosPolicy’s type_object_max_serialized_length to control the maximum size of the buffer that Connext uses to uncompress the received compressed TypeObject.

Starting in 6.0.1, this uncompression buffer is no longer controlled by the DDS_DomainParticipantResourceLimitsQosPolicy’s type_object_max_serialized_length (default value: 8192 bytes). Instead, it is controlled by the DDS_DomainParticipantResourceLimitsQosPolicy’s type_object_max_deserialized_length (default value: DDS_LENGTH_UNLIMITED).

As a result, you can now configure Connext to only receive (but not propagate) compressed TypeObjects by setting type_object_max_serialized_length to zero and keeping type_object_max_deserialized_length set to DDS_LENGTH_UNLIMITED.

3.3.1.2.2. Incompatibility issues for Java and .Net when using XCDR2

Starting in 6.0.0, Connext supports the Extended Common Data Representation (CDR) encoding version 2 (XCDR2), in addition to version 1 (XCDR). XCDR2 is supported in both Connext and Connext Micro. See Section 3.4.1.3.1 for details.

Support for XCDR2 introduced some bugs in 6.0.0 that were addressed in 6.0.1. (For details, see RTI Issue IDs CODEGENII-1197, CODEGENII-1198, and CODEGENII-1206 in “What’s Fixed in 3.0.1” in the Code Generator Release Notes.) Fixing those bugs broke backward compatibility with 6.0.0. Therefore, applications in Java or .Net in release 6.0.1 or above may not interoperate with applications in another language in 6.0.0, and vice-versa (applications in Java or .Net in release 6.0.0 may not interoperate with applications in another language in 6.0.1 or above).

3.3.1.3. Other Compatibility Issues

3.3.1.3.1. Large data support for Multichannel and TopicQuery has been disabled

Due to the Known Issue described in “Multichannel and TopicQuery do not Work with Large Data in Some Cases,” in the RTI Connext Core Libraries Release Notes, large data support for Multichannel and TopicQuery has been disabled in release 6.0.1. If you need this functionality enabled as it was in 6.0.0, please contact RTI support (support@rti.com). This functionality has been re-enabled in 6.1.0.