Skip to content

Latest commit

 

History

History
1590 lines (1245 loc) · 101 KB

NEWS.md

File metadata and controls

1590 lines (1245 loc) · 101 KB

OpenDDS Releases

Version 3.29.1 of OpenDDS

Released 2024-07-31

Download this release on GitHub.

Read the documentation for this release on Read the Docs.

Fixes

  • Fixed code generation for fixed-size structs in Java that caused compilation errors. (PR #4752)

Version 3.29.0 of OpenDDS

Released 2024-07-26

Download this release on GitHub.

Read the documentation for this release on Read the Docs.

Additions

Platform Support and Dependencies

Removals

  • Removed OPENDDS_IGNORE_OPENDDSCONFIG_H_FILE macro. (PR #4687)
    • Users manually configuring a build will need to create dds/OpenDDSConfig.h which may be empty.

Fixes

  • When DCPSThreadStatusInterval is enabled, threads that run the ACE Reactor now use timers instead of a time-limited select() system call to update the InternalThreadBuiltInTopic. (PR #4677)
    • This allows the InternalThreadBuiltInTopic to be updated accurately on systems that suspend/resume and are configured for boottime timers.
  • [rtps_discovery] MaxSpdpSequenceMsgResetChecks is recognized again. (PR #4696)
  • RtpsRelay: Recognize clients that are using different IP addresses for SPDP and SEDP. (PR #4718)
  • Fixed memory leak of remote locators in the RTPS/UDP transport. (PR #4731)

Documentation

Version 3.28.1 of OpenDDS

Released 2024-05-02

Download this release on GitHub.

Read the documentation for this release on Read the Docs.

Additions

  • Added OPENDDS_COMPILE_WARNINGS and configure option --compile-warnings=[WARNING|ERROR] to enable additional compiler warnings and treating them as errors. (PR #4558)
  • Add a configure script option for MPC options requiring a value. (PR #4574)
    • For example, ./configure --mpc:value_template build_flags+="-Wall -Werror".

Platform Support and Dependencies

  • Building with CMake
    • Fixed CMake saying it's missing the ACE library when using OPENDDS_ACE_TAO_SRC with an ACE/TAO outside of the build directory. (PR #4604)

Removals

  • Values passed to the configure script via --mpcopts are no longer split on spaces. (PR #4574)
    • For example, ./configure --mpcopts="-value_template build_flags+=-Wall -Werror" must now be written as ./configure --mpcopts=-value_template --mpcopts="build_flags+=-Wall -Werror".

Fixes

  • Fixed incorrect usage of OpenSSL in gov_gen application. (PR #4591)
  • Fix bug where Service_Participant::type_object_encoding doesn't return configured value. (PR #4593)
  • Do not send heartbeats during a fragmented send in rtps_udp. (PR #4603)

Documentation

Version 3.28.0 of OpenDDS

Released 2024-04-16

Download this release on GitHub.

Read the documentation for this release on Read the Docs.

Additions

  • Added an XCDR2 value writer that can be used to serialize static and dynamic samples to XCDR2 encoding format. (PR #4421)
  • Added utility to flatten the index to a multi-dimensional array represented by dynamic data. (PR #4421)
  • A new header, dds/OpenDDSConfig.h is generated by configure or CMake. (PR #4482, PR #4498)
    • Users manually configuring a build will need to create this file, which may be empty, or add #define OPENDDS_IGNORE_OPENDDSCONFIG_H_FILE to their ace/config.h file.
    • See dds/OpenDDSConfig.h.in for details.
  • ConfigStore
  • The @value(x) annotation is now supported on IDL enumerators when using the IDL-to-C++11 mapping. (PR #4519)
  • The IDL for the Shapes example was updated for interoperability. (PR #4528)
  • Added [rtps_discovery] SpdpUserTag. (PR #4533)
  • The data type for the OpenDDS-specific Built-in ParticipantLocation Topic now includes the lease duration. (PR #4545)
  • Allow compile-time configuration of CLOCK_BOOTTIME as the clock used for timers (PR #4568)
    • If the platform supports it, this can be done using --boottime when building with the configure script or OPENDDS_BOOTTIME_TIMERS when building with CMake.

Platform Support and Dependencies

Fixes

Documentation

Version 3.27.0 of OpenDDS

Released 2024-02-07

Download this release on GitHub.

Read the documentation for this release on Read the Docs.

Additions

Platform Support and Dependencies

  • Improved support for configure script detection of clang on Linux (PR #4449)
  • When using Visual C++, OpenDDS can now be configured using --std=c++NN (NN = 17 or 20). (PR #4452)

Fixes

  • Updated the read and write semantics of DynamicData for union, expandable collections (sequence and string), and optional member of an aggregated type. (PR #4278)
  • Fixed memory leak where instances were not cleaned up with exclusive ownership. (PR #4343)
  • Removed the special handling for sequence members with length code of 5,6, or 7. (PR #4376)
  • Reading data from a dynamic data object for a primitive type now must use MEMBER_ID_INVALID id. (PR #4376)
  • create_datawriter and create_datareader check if the topic belongs to the same participant as the publisher/subscriber. (PR #4398)
  • Fixed uninitialized durability_service in Topic QoS when using QoS-XML. (PR #4424)
  • Fixed a bug where compiling IDL with -Lc++11 -Gequality produced code outside of a namespace that didn't compile. (PR #4450)
  • SedpLocalAddress now defaults to DCPSDefaultAddress to behave like SpdpLocalAddress and local_address. (PR #4451)

Notes

  • TheParticipantFactory* will now return a null pointer when DCPSConfigFile doesn't exist. (PR #4372)

Version 3.26.1 of OpenDDS

Released 2023-11-14

Download this release on GitHub.

Read the documentation for this release on Read the Docs.

Fixes

  • Building with CMake

    • Fixed Issue #4328, where each run of CMake effectively always appended the MPC features to default.features in ACE. (PR #4330)
  • Fixed a corner case in RTPS ParameterList parsing (PR #4336)

  • Reject some types of invalid RTPS DataFrag submessages (PR #4348)

Version 3.26.0 of OpenDDS

Released 2023-10-23

Download this release on GitHub.

Read the documentation for this release on Read the Docs.

Additions

Deprecations

Fixes

  • Improved the subject name parsing to better conform to the DDS Security spec. (PR #4201)

    • The order of attributes in subject names is now significant when comparing them.
  • Remove from TypeLookupService when remote endpoint is removed from SEDP (PR #4216)

  • WaitSet is now notified when DataWriter liveliness is lost. (PR #4223)

  • ICE doesn't use IPv4-mapped IPv6 addresses anymore. (PR #4230)

  • Efficiency: Remove per-element locking in JobQueue (PR #4253)

  • RtpsRelay: fixed bug in record_activity's use of remove in GuidAddrSet (PR #4254)

  • Fix warnings in typeobject_generator when using TAO 3 (PR #4262)

  • Fix null pointer when participant is absent when updating locators (PR #4265)

  • Initialize variables in TypeObject to silence warnings (PR #4292)

  • RtpsRelay: Use ACE_Message_Block's locking strategy for cached SPDP to fix tsan warning (PR #4293)

  • Fix tsan warning in ReactorTask (PR #4298)

Documentation

  • Removed documentation for -Grapidjson option of opendds_idl that was removed in 3.20.0 (PR #4231)
  • Remove reference to mailing lists (PR #4234)
  • Restructured parts of DDS Security page and expanded documentation of some XML security document elements. (PR #4281)
  • OS-specific instructions will now be automatically selected based on the browser's user agent. (PR #4281)
  • OMG specification section references are now links to that section in the specification PDF. (PR #4281)
  • Move build and install instructions to DevGuide (PR #4294)
  • Incorporate the quick start guides, FAQ, and shapes demo into the DevGuide. (PR #4297)

Notes

  • Using Perl 5.38.0 might prevent TAO from building properly, see here for details.

Version 3.25.0 of OpenDDS

Released 2023-07-20

Download this release on GitHub.

Read the documentation for this release on Read the Docs.

Additions

Security

  • Fixed null pointer exception caused by RTPS Parameters with incorrect zero size. (PR #4197)

Fixes

  • CMake Config Package

    • Made linking dependencies and macro definitions closer match using MPC with OpenDDS and TAO. (PR #4140)
    • Fixed issues with passing OPENDDS_IDL_OPTIONS -SI to opendds_target_sources. (PR #4140)
  • Fixed issue deserializing bounded sequences with JSON (PR #4150)

    • The deserialization will fail if the JSON input contains more elements than the bounded sequence can hold.
  • Updated the RtpsRelay's tracking of client IP addresses so they are removed when no longer used. (PR #4202)

    • The RtpsRelay configuration option -MaxAddrSetSize was renamed to -MaxIpsPerClient

Documentation

Notes

  • CMake Config Package

    • OPENDDS_TARGET_SOURCES is now called opendds_target_sources. (PR #4140)

      • CMake macros and functions names are case insensitive, so this should have no effect on CMake code.

Version 3.24.2 of OpenDDS

OpenDDS 3.24.2 was released on Jun 30 2023.

Security:

  • Fixed a vulnerability in the rtps_udp transport where an acknowledgement sequence number beyond the maximum expected by the writer leads to an assert and incorrect state. (#4155)
    • Thanks to Seulbae Kim (@squizz617) for discovering this.

Fixes:

  • Fixed leaked shared memory by the shared memory transport. (#4171)
  • Fixed bug introduced by #4120 (#4180, #4184)
    • The fix introduced in #4120 causes the TransportClient to silently drop messages when the client's guid is not initialized. This causes issues for TransportClients that send messages to the transport before association. One such example is a DataWriter with liveliness configured. The DataWriter will send liveliness messages to the transport (which will be dropped) and hang waiting for them to be delivered.
    • The solution was set the guid for a TransportClient before calling any method that uses the guid.

Notes:

  • #4180 required changes in InfoRepoDiscovery's IDL, so InfoRepo compatibility with older versions has been broken.

Version 3.24.1 of OpenDDS

OpenDDS 3.24.1 was released on Apr 21 2023.

Fixes:

  • Fixed compile warnings in TypeSupport that can happen with GCC and -O2 or higher (#4117)
  • Fixed compile error in TypeSupport for IDL that contains a typedef of a typedef (#4117)
  • Fixed bug in the tcp transport where readers and writers can fail to associate (#4120)
  • Fixed issue in some headers that could leak #pragma pack (push, 8) into user code on Visual Studio (#4123)
  • Fixed theoretical infinite loop in rtps_udp transport code (#4124)

Documentation:

  • Removed invalid links and references in README and the Developer's Guide and fixed other minor issues (#4115, #4116, #4121, #4126)
  • Changed theme used by the Sphinx documentation to make the Developer's Guide easier to navigate (#4127)
  • Added copy buttons to embedded code and code-like examples (#4127)

Version 3.24.0 of OpenDDS

OpenDDS 3.24.0 was released on Apr 11 2023.

Additions:

  • The OpenDDS Developer's Guide is now available at https://opendds.readthedocs.io/ (#4051, #4094, #4092, #4100, #4101, #4095, #4103, #4102, #4104, #4105)
    • The Sphinx/reStructuredText source for this new format is now located in the repo at docs/devguide
  • DOCGroup ACE6/TAO2 is now the default ACE/TAO for OpenDDS, OCI ACE/TAO is no longer supported (#4069)
  • Dynamic content subscription (#3988)
    • This allows DynamicDataReaders to use QueryCondition and ContentFilteredTopic and allows DynamicDataWriters to do filtering on behalf of matched DataReaders that use ContentFilteredTopic.
  • DynamicData:
    • Can now read and write enum members as strings (#4022)
    • get_int64_value and get_uint64_value can now cast from different types (#4078)
    • DynamicDataImpl now uses lazy initialization to reduce memory usage (#4024)
  • Added aliases for IDL types from XTypes spec such as DDS::UInt32 (#3994)
    • See DdsDcpsCore.idl for all of them.
  • Added PublicationMatchedStatus Current Count To RtpsRelay Statistics (#4006)
  • Allow reassembly of overlapping fragment ranges in RTPS (#4035, #4047)
  • Can now cross-compile on macOS (#4048)
  • Added hardening features to RtpsRelay (#4045)
    • These are configured with the new options -MaxAddrSetSize and -RejectedAddressDuration.
  • Added OPENDDS_AUTO_LINK_DCPS and OPENDDS_USE_CORRECT_INCLUDE_SCOPE global options to the CMake package (#4071)
  • Expanded support for using C++ keywords in IDL (#4073)
  • Improved support for anonymous types in unions branches (#4078)
  • IDL file and generated TypeSupport.idl can now be in different directories (#4077)

Fixes:

  • Fixed rtps_relay_address_change deadlocks (#3989)
  • Fixed RtpsUdpTransport data race from relay_stun_mutex_ (#3990)
  • Fixed invalid socket handles in RtpsUdpTransport (#4002)
  • Fixed index increment in GuidPartitionTable::prepare_relay_partitions (#4005)
  • Fixed a bug in content filtering with enum comparisons on serialized samples (#4038)
  • Fixed transport config and transport instance derived from template conflicting (#4058)
  • Improved reliability of the shared memory transport (#4028)
  • Secure writers and readers in same participant can now associate (#4041)
  • Fixed issue with using -o in tao_idl/opendds_idl options in OPENDDS_TARGET_SOURCES and those directories are now automatically included (#4071)
  • XTypes (#4078):
    • TypeObjects struct and union members used to be sorted by member ID, but they are now sorted by declaration order as the XTypes spec calls for. By default member IDs increment starting at 0, and in that case the TypeObjects will be the same. If @autoid(hash), --default-autoid hash, or @id(ID) are being used then the order could be different. This could cause some reader/writer matching incompatibility with older versions of OpenDDS:
      • Topics with final and appendable structs will no longer match.
      • If DISALLOW_TYPE_COERCION QoS is being used, then all topics where the order differ will not longer match. Note that this is true for any time the type hash changes.
      • Pass the --old-typeobject-member-order option to opendds_idl to use the non-standard order.
    • The size of XCDR2 member parameters in mutable structs and unions is now correctly interpreted when the "length code" is 5, 6, or 7.
      • This is an optimization that OpenDDS doesn't serialize samples with, so this could only be an issue when dealing with samples from other DDS implementations.
    • DynamicDataImpl (DynamicData made by DynamicDataFactory that can be passed to DynamicDataWriter):
      • get_member_id_at_index now returns ids for members that haven't been initialized yet.
      • Fixed incorrect serialization of keyed unions for instance registration, disposal, and unregistration samples.
      • Fixed errors from serializing some cases of arrays and sequences.

Notes:

  • Release files will only be uploaded to GitHub from now on
  • OpenDDS::DCPS::RepoId has been removed, if needed use OpenDDS::DCPS::GUID_t instead (#3972)

Version 3.23.1 of OpenDDS

OpenDDS 3.23.1 was released on Feb 1 2023.

Fixes:

  • Addressed a DDS Security issue where participants can sign their own permissions file if the same CA is used for both identity and permissions (#3992)
  • Addressed CVE-2023-23932, where untrusted sources can use invalid CDR strings in RTPS messages to crash OpenDDS applications (#4010, #4016, #4018)
    • Thanks to Seulbae Kim (@squizz617) for discovering this.
  • Fixed an issue in DynamicData::get_*_values and print_dynamic_data (#3952)
  • Fixed a bug where DynamicDataReader wouldn't be able to read a topic type with final or mutable extensibility (#3993)
  • Fixed race conditions involving reference counted objects (#3999)

Version 3.23.0 of OpenDDS

OpenDDS 3.23.0 was released on Dec 21 2022.

Additions:

  • DataRepresentationQosPolicy and TypeConsistencyEnforcementQosPolicy can be set through XML (#3763)
  • RTPS send queue performance improvements (#3794)
  • Cross-compiling improvements (#3853)
  • New support for DynamicDataWriter and enhanced support for DynamicDataReader (#3827, #3727, #3871, #3718, #3830, #3893, #3904, #3885, #3933, #3935)
  • New config option for RtpsDiscovery SpdpRequestRandomPort (#3903)
  • New opendds_mwc.pl Wrapper Script (#3821, #3913)
  • Improve support for loading signed documents (#3864)

Fixes:

  • Unauthenticated participant leads to invalid iterator (#3748)
  • Shmem Association race (#3549)
  • Shmem and tcp null pointer (#3779)
  • Submodule checkout on Windows (#3812)

Notes:

Version 3.22.0 of OpenDDS

OpenDDS 3.22.0 was released on Sep 16 2022.

Additions:

  • Sequences in FACE mapping: support == for any type (#3604)
  • Implement instance security methods from DDS Security Spec (#3557)
  • Added meta-discovery server to RtpsRelay (#3655)
  • Support building for VxWorks 21.03 (#3723, #3740)
  • Alive and active flags now have timestamps in RtpsRelay (#3579)
  • Static initializers for registration of TypeSupport objects (#3736)

Fixes:

  • Fixed bug where partitions for RtpsRelay client were not updated (#3583)
  • Fixed data race on status flag which causes missing listener invocation for BIT readers (#3584)
  • Fixed bug where SEDP removes crypto handles before dissassociating (#3597)
  • Fixed null BIT subscriber in ConnectionRecord (#3610)
  • Fixed bug where user data reverts to original for RtpsRelay clients (#3613)
  • Removed warning about unexpected register in MulticastManager (#3608)
  • Fixed reference counting issue that blocks SPDP shutdown (#3619)
  • Fixed dds_suppress_anys=0 (#3656)
  • Ignore interfaces with no FQDN in AddressLookup (#3660)
  • Fixed memory leak where DataWriter doesn't remove unregistered instances (#3684)
  • Update TransportClient's use of PendingAssoc's lock (#3652)
  • Clone Google Test and RapidJSON if not found (#3691)
  • Set extensibility on enums (#3686)
  • Do not use fixed-size buffer for partition parsing (#3704)
  • Prevent Use Of IPv4-mapped IPv6 'Any' Addresses In RTPS Locators (#3713)
  • Fix SEGV in shutdown when using monitor (#3732)
  • Crash from missing BIT reader in shutdown (#3741)

Notes:

  • Removed wait param in TransportRegistry::create_inst (#3644)
  • Changed Multicast Group Join Errors to Warnings (#3558)
  • Remove Leading :: from TypeObject Names (#3679)
  • Updates to the ValueReader/ValueWriter/ValueDispatcher framework (#3719)
  • Updates to Dockerfile (#3737)

Version 3.21.0 of OpenDDS

OpenDDS 3.21.0 was released on Jun 24 2022.

Additions:

  • Reduced code generation for XTypes (#3456)
  • ValueWriter::begin_struct_member now takes a member descriptor for identifying key fields (#3459)
  • Added detailed logging for invalid QoS (#3475)
  • Added example usage for inspect (#3493)
  • RTPS:
    • Added debug logging for non-final RTPS messages (#3504)
    • ConnectionRecord now reports the round-trip latency to the RtpsRelay (#3506)

Fixes:

  • Add locking to RecorderImpl (#3531)
  • Fixed minor issues with choosing addresses and hostnames in NetworkResource (#3527)
  • RTPS:
    • PropertySeq now checks for invalid length (#3432)
    • UseXTypes RTPS discovery option now accepts descriptive values (#3493)
      • This was added in OpenDDS 3.20.0, but wasn't functional.
    • Performance improvements for RTPS (#3500, #3508)
    • Fixed a bug where heartbeats were being sent to readers that didn't exist anymore (#3540)

Version 3.20.0 of OpenDDS

OpenDDS 3.20.0 was released on Mar 25 2022.

Additions:

  • Added the host_name shared memory transport config option (#3386)
  • Added an example test for demonstrating issues (#3322)
  • Added the --old-typeobject-encoding option to opendds_idl for compatibility with TypeObject before OpenDDS 3.18.0 (#3263)
  • Added return code to ServiceParticipant::shutdown() (#3159, #3270)
  • CMake Module:
    • Improved support for installing CMake projects that use OpenDDS (#3315, #3354, #3367, #3368, #3393)
      • OpenDDS, ACE, and TAO libraries can now be installed using install(IMPORTED_RUNTIME_ARTIFACTS) if using CMake 3.21 or later
        • To help facilitate this, a new function called opendds_get_library_dependencies has been added.
      • To help install generated files, OPENDDS_TARGET_SOURCES now adds lists of the files that where passed in and generated that are part of the PUBLIC and INTERFACE scopes as properties on the target
      • See docs/cmake.md for details on all of these new features
    • Added an OPENDDS_DEFAULT_SCOPE option that allows changing the default scope of OPENDDS_TARGET_SOURCES (#3315)
    • Support INSTALL_LIB being used with make install to change the name of the lib directory (#2879)
      • NOTE: This required changing the CMake module installation destination from lib to share.

Platform Support and Dependencies:

  • Support for Visual Studio 2022 (#3267)
  • Updated to work with the C++20 standard library (#3288)
  • Support for OpenSSL 3.0.1 and later (#3358, #3404)
  • Updated Wireshark dissector to work with GLib 2.68 and later (#2918)
  • Removed Boost as an optional dependency (#3323)
  • Updated the RapidJSON submodule (#3284)

Fixes:

  • Fixed issue preventing 2 sequence<string> anonymous types in the same struct (#3415)
  • Fixed issues with entity association when using the multicast transport (#3377)
  • Fixed issue #3268, a segfault in opendds_idl (#3374)
  • Fixed thread safety of DataReaderImpl_T's allocator (#3335, #3403)
  • Improvements to how data representation is handled (#3233)
  • Fixed instance lifetime issue with assert_liveliness (#3241)
  • RTPS:
    • Improved internal handling of remote addresses to reduce initial traffic (#3375)
    • General ICE improvements (#3298, #3218)
    • Improvements to RtpsRelay (#3257, #3240, #3237)
    • Check for invalid RTPS Parameter length (#3405)
  • CMake Module:
    • Fixed issue when using install(EXPORT) on a target used with OPENDDS_TARGET_SOURCES (#3315)
    • Fixed issue #1297 where opendds_idl generates an incorrect include path (#3315)

Version 3.19.0 of OpenDDS

OpenDDS 3.19.0 was released on Dec 10 2021.

Additions:

  • XTypes: Dynamic Language Binding (#2976)
    • Read support only in this version
    • New inspect tool that prints data samples read from a topic in text form
    • See section 16.7 of the Developer's Guide for details
  • CDR Encapsulation support for non-rtps_udp transports (#3135)
    • When XCDR2 is enabled in DataRepresentationQosPolicy, these transports can use mutable and extensible extensibility
  • Enhanced RtpsRelay support (#3208, #3116, #3094)
  • RTPS transport-level statistics (#3166)
  • Made the allocators in TransportReceiveStrategy configurable (#3170)
  • Option to simulate lossy network (#3138)
  • Configurable maximum participants in discovery (#3145)
  • Extend ValueWriter/ValueReader with array based operations (#3140)
  • Extend RawDataSample with the header to support XCDR2 streams (#3028)
  • DCPSLogLevel config option, see section 7.6 of the Developer's Guide for details (#3113, #3158)

Fixes:

  • Source IP check override configuration (#3195)
  • Update use of receive address in RtpsUdpDataLink::accumulate_addresses (#3191)
  • Updated Node.js/V8 support (#3188, #3177)
  • Better support for DDS Security static library builds (#3122)
  • TransportReceiveStrategy: fixed issue with response queue (#3136)
  • Remove broken fragment resend early return check (#3095)
  • Added special-case handling for PID_PROPERTY_LIST interop (#3057)
  • SEDP sequencing (#3068, #3116)
  • MultiTopic robustness (#2988)
  • Fixed issue with find_package(Threads) on recent CMake releases when calling find_package(OpenDDS) before a C/C++ project has been declared (#3093)

Notes:

  • configure: Add vs2022 as a compiler option (#3169)
  • MSVC++ 12.0 updates (#3075)
  • Fixed dependency cycle when OPENDDS_TARGET_SOURCES is used on a CMake target that also has Qt MOC source files (#3093)

Version 3.18.1 of OpenDDS

OpenDDS 3.18.1 was released on Sep 24 2021.

Fixes:

  • Improve RTPS messaging behaviors under IPv6 (#2923)
  • Fixed a few rtps_udp transport issues (#2954, #2997, #2998, #3009, #3013, #3027)
  • Configurable parameters for RTPS Discovery lease durations (#2999)
  • Auth resend backs off (more delay over time) (#2937, #2984)
  • Input validity check for RTPS Parameters (#2917), sequences (#2944), addresses (#2981, #3016), locators (#3000)
  • Fragment reassembly fixes (#2960)
  • Type lookup service fixes (#2941)
  • Fixed generation of unreachable code in operator<< (#2962)
  • RtpsRelay logging and related changes (#2936, #2980, #2979, #2978, 2987, #2996, #2832)
  • XML QoS loader can now use custom error handlers (#2961)
  • CMake: Prevent Duplicate BUILD_DLL creation (#2977)
  • CMake: Assign runtime library tao_idl on MSVC (#2990)

Version 3.18.0 of OpenDDS

OpenDDS 3.18.0 was released on Aug 24 2021.

Additions:

  • IDL4 explicitly-named integer types (#2814, #2857, #2862)
    • The existing IDL integer types, short, long, and long long, now have new aliases, which are int16, int32, and int64 respectively, along with unsigned versions of them like uint32.
    • There are also two new distinct integer types: int8 and uint8.
  • RTPS:
    • Added the LeaseExtension RTPS discovery config option that extends the lease of discovered participants (#2869)
    • Added the SedpPassiveConnectDuration RTPS discovery config option (#2847)
    • Improved reassembly of fragments by adding an expiration to them (#2848)
      • Added the SedpFragmentReassemblyTimeout RTPS discovery config option to control this.
    • Use preallocated buffers in RtpsUdpDataLink (#2901)
      • Added the anticipated_fragments RTPS transport config option to scale how much memory is preallocated for packet customization and fragments buffers.
    • To try to reduce possible network congestion, temporarily increase the heartbeat send period while they go unanswered (#2911, #2913, #2915)
    • Added the SendBufferSize and RecvBufferSize RTPS discovery config options to set the buffer sizes for the sockets used for discovery (#2935)
  • The QoS XML Handler can now take input from a string (#2439)

Fixes:

  • RTPS:
    • Fixed RtpsUdpDataLink leaking remote writers on failed associations (#2812)
    • Fixed TypeObject encoding compatibly and consistency issues (#2749, #2804)
    • Fixed local/local RTPS associations not properly notifying liveliness (#2783)
    • Fixed durable data not being delivered in the right order (#2728)
    • RtpsUdpDataLink will no longer purge durable data (#2690)
    • Fixed writers of fragmented data samples having issues reconnecting with readers (#2930)
    • Fixed non-durable readers receiving historical samples (#2914)
    • Fixed issues with security permissions and governance XML file parsing (#2896, #2912, #2916)
      • <id_range>s in domain id sets can now omit <max> in permissions and governance files.
        • This means <id_range><min>0</min></id_range> will now mean all domains.
      • Fix date/time in <not_before> and <not_after> in permissions grants always being interpreted as local time and fix issues with parsing time zone offsets.
      • Fixed settings for multiple <domain_rule>s in governance files ending up just being copies of the first domain rule.
      • Allow using 1/0 in addition to TRUE/FALSE and true/false for boolean values.
    • RtpsRelay fixes and improvements (#2899, #2895, #2887, #2884, #2864, #2881, #2776, #2761, #2751, #2717, #2710, #2927, #2929, #2928, #2921)
  • Fixed Topics returned from find_topic not being distinct entities (#2731)
  • Try to workaround faulty DNS when getting the FQDN (#2677)
  • Fixed configure --wireshark-cmake not working on Linux (#2679)
  • Fixed an invalid memory write in SporadicTask (#2685)
  • Fixed occasional deadlocks in DataReaderImpl and SubscriberImpl associated with presentation QoS (#2886, #2903)
  • make install:
    • Use $(INSTALL_LIB) instead of hardcoded lib for Java-related files (#2740)
    • Use relative links in $(INSTALL_PREFIX)/share (#2780)
    • Fix headers unnecessarily getting installed to $(INSTALL_PREFIX)/include/DCPS (#2864)

Notes:

  • Fixed a spelling error for the DCPSChunkAssociationMultiplier config option (#2723)
    • The old spelling, DCPSChunkAssociationMutltiplier (with an extra "t" in "Multiplier"), will continue to also be accepted for the time being.

Version 3.17.0 of OpenDDS

OpenDDS 3.17.0 was released on May 18 2021.

Additions:

  • Support for converting samples to and from JSON (#2312)
    • This requires RapidJSON, so it is now installed along with OpenDDS if it was configured (#2426)
      • NOTE: This might conflict with an existing RapidJSON installation.
  • Support for ignore_member_names in the XTypes type consistency enforcement QoS (#2364)
  • Internal tracking of and reuse of instance handles (#2530, #2557)
  • --install-origin-relative configure script option for installing with RPATH relative to $ORIGIN (#2651)
  • RTPS:
    • RTPS message logging (#2458)
    • RTPS performance logging (#2477)
    • Add logging to measure latency of RTPS discovery and association (#2511)
    • Consolidate RTPS messages based on time (#2534)
    • RtpsUdpDataLink can now handle more than one unicast address (#2653)

Fixes:

  • DiscoveryBase: additional iterator checks (#2421)
  • Improve memory usage (#2481)
  • Allow Java with linux-cross in configure script, Fixes #2518 (#2519)
  • Fix listeners not being invoked when remote participant times out (#2602, #2650)
  • RTPS:
    • RtpsRelay improvements (#2402, #2442, #2484, #2578, #2598)
    • RtpsUdpDataLink::flush_send_queue_task_ cleanup (#2544)
  • Security:
    • Auth plugin: check for one of the expected handshake message types (#2551)
    • Fixed re-keying the endpoints that use derived keys (#2623)
  • Type Support Generation:
    • Use a leading :: to qualify generated C++ scoped names (#2350)
    • opendds_idl fix for underscore fields (#2377)
    • Make initialization of static XTypes type support data tread-safe in C++03 (#2362, #2389)
    • Clean up JNI local references, fixes runtime issues with large types (#2465, #2497)
    • Corrected serialization for XCDR2 mutable unions. (#2471)
    • Fix for include of a TAO pidl sequence using the TAO_ROOT-based path (#2566)
    • Generate Typecode identifiers needed by tao_idl when using C++11 Mapping (#2582, #2627)
    • Support IDL modules and topic types that are C++ or IDL keywords (#2608, #2665, #2668)
  • CMake Module:
    • Fix an issue where a type support library's export header was expected to exist before it was created (#2495)
    • Use CMAKE_CXX_COMPILER as the preprocessor for opendds_idl and tao_idl so a compiler is no longer required on the path. (#2503)
    • Fix compatibility with CMake 3.3 (#2562)
    • Subsequent calls to find_package(OpenDDS) no longer cause a fatal error (#2616)
      • NOTE: OPENDDS_ALLOW_ENV_CHANGE optionally allowed this before, so it is no longer needed and has been removed.

Notes:

  • OPENDDS_VERSION and other version indicators now includes the ".0" at the end for minor releases like this one. (#2563)
    • NOTE: Release archive filenames and Git tags will retain the old version pattern for now.
  • CMake Module: CMAKE_CXX_STANDARD will no longer be set on Unix platforms. This will have to be correctly set by the user (#2616)

Version 3.16 of OpenDDS

OpenDDS 3.16 was released on Jan 27 2021.

Additions:

  • XTypes (#1633)
    • Initial implementation of the OMG DDS XTypes version 1.3 specification
    • Allows different IDL definitions to be used in the same topics and for these definitions to evolve while remaining compatible
    • Includes new RTPS discovery options, QoS policies, opendds_idl options, and IDL annotations
    • See the new "XTypes" chapter in the Developer's Guide for more information
  • Added new version macros to dds/Version.h (#2333)
    • NOTE: Version macros starting with DDS_ have been deprecated and will be removed in OpenDDS 4.0.
  • Configure Script:
    • Added --doc-group3 option for using DOC Group ACE7/TAO3 (#2336)
    • Added --workspace option for using a custom MPC workspace file (#2262)
  • Android:
    • Support for adapting to network changes in Android apps targeting API 30+ (#2237)
    • Support for building with the Android NDK directly (Only supported with ACE7/TAO3) (#2296)
    • See docs/android.md for more information
  • RTPS performance improvements (#2325)

Fixes:

  • Fixed port in RTPS discovery spdp_local_address configuration being ignored (#2272)
  • Fixed Participant Location Built-in Topic Updates being ignored (#2255)
  • Fixed Internal Thread Status Built-in Topic Updates being ignored (#2247)
    • NOTE: The IDL of the topic has changed.

Notes:

  • For the rtps_udp transport, the default encoding of DataWriters changed from classic CDR to XCDR2. To maintain interoperability with pre-3.16 OpenDDS and other DDS implementations, the first element of representation.value of DataWriterQos must be set to DDS::XCDR_DATA_REPRESENTATION or the non-OpenDDS 3.16 DataReader must be set up with DDS::XCDR2_DATA_REPRESENTATION if supported. DataReaders will continue to be interoperable by default.
  • Removed max_bundle_size rtps_udp transport option (#2249)
  • Replaced old performance-tests/bench with new Bench 2 framework (#2340, #2346)

Version 3.15 of OpenDDS

OpenDDS 3.15 was released on Dec 22 2020.

Additions:

  • Scalability and performance improvements (#1525, #1610, #1616, #1662, #1792, #1927)
  • Support for dynamic configuration of discovery and transport from config file templates (#1764)
  • Some forms of IDL4 Anonymous Types are supported, see Developer's Guide (#1754)
  • Added the Observer interface, which allows untyped access to data samples (#1851)
  • Built-In Topics with RTPS Discovery support disconnect/reconnect cycles (#1924)
    • This feature required adopting the upcoming DDS spec (1.5) change to BuiltinTopicKey_t: it is now based on a 16-byte opaque identifier.
  • Added an OpenDDS-specific Built-In Topic for internal thread status reporting (#1906)
  • Added an option to omit DomainParticipant's USER_DATA QoS from in-the-clear messages when security is enabled (#2066)
  • Added options to the CMake module, see docs/cmake.md (#2075)

Platform Support and Dependencies:

  • Improved Android support (#1634, #2171)
  • Improved IPv6 support (#1639)
  • The only DOCGroup ACE/TAO versions supported are the current releases from the 6.x/2.x series (#2070)
  • Compatibility with Wireshark 3.4 (#2076)

Fixes:

  • Fixed bugs in RtpsRelay/ICE/STUN (#1595, #1605, #1603, #1628, #1625, #1636)
  • Fixed some rtps_udp fragmentation issues (#1643, #1800, #1884)
  • Fixed an rtps_udp protocol issue (#1654)
  • Fixed bug with wrong status mask used for publication matched event (#1659)
  • Fixed a bug where SpdpLocalAddress was parsed incorrectly (#1743)
  • Improve efficiency of waiting on pending writes (#1831)
  • Reduced the chances for GUID collision in RTPS Discovery multi-domain processes (#2107)
  • Explicit initialization of reliable RTPS readers to more closely follow DDS spec (#2146)

Notes:

  • Passing C++ source files to the OPENDDS_TARGET_SOURCES macro in the CMake module is now deprecated (#1741)

Version 3.14.1 of OpenDDS

OpenDDS 3.14.1 was released on Nov 20 2020.

Fixes:

  • Improved robustness when using multiple secure participants in the same process (#1593)
  • Content filter fix for instance registration with non-key filters (#1596)
  • Prevent Potential Infinite Processing Loop in ReactorInterceptor (#1598)
  • Android platform improvements (#1626)
  • Network Config Modifier bugfix (#1648)
  • Fix deadlock in OfferedDeadlineWatchdog (#1567)
  • IDL-to-C++11: corrected mapping of enum constants when enum is in a module (#1661)
  • IDL-to-C++11: fix for enum-discriminated unions (#1950)
  • Fixed a corner case for IDL union code generation in Java (#1671, #1676)
  • Fixed Java code generation when an included IDL file has @topic (#1695)
  • Correctly handle duplicate underlying array types within idl2jni (#1780)
  • Participants can reauthenticate and exchange data after network partition (#1723)
  • DCPSDefaultAddress parsing and integration with NetworkConfigMonitor (#1727, #1752, #2021)
  • Security: checking permissions based on Partition QoS (#1733)
  • Allow Built-in Security Plugin to be Reloaded in a Static Build (#1737)
  • Prevent invalid access in TransportClient::PendingAssocTimer::ScheduleCommand during shutdown (#1811)
  • Additional validity check for submessage parsing (#1844)
  • Reader Data Lifecycle QoS configurability for Built-In Topics (#1940)
  • Fix NetworkInterface interaction with MulticastInterface addresses (#1956)
  • Fixed loopback interface multicast joins (#1964)
  • Fixed usage of netlink sockets for LinuxNetworkConfigMonitor (#1985)
  • Fixed bug in zero-copy sequences that grow from a nonzero length (#2039)
  • CMake Module:
    • Fixed OPENDDS_TARGET_SOURCES setting global include paths. (#1741)
    • Fixed situations requiring C++ source files to be passed to OPENDDS_TARGET_SOURCES. (#1741)

Additions:

  • Support for the C++11 mapping in the CMake module. -Lc++11 can now be passed with OPENDDS_IDL_OPTIONS in OPENDDS_TARGET_SOURCES. (#1728, #1736)

Version 3.14 of OpenDDS

OpenDDS 3.14 was released on Mar 5 2020.

Additions:

  • XTypes IDL annotations for topic types, Union topic types (#1067, #1422):
    • #pragma DCPS_DATA_TYPE and #pragma DCPS_DATA_KEY are now deprecated in favor of the @topic and @key IDL annotations.
    • Like structures, unions can now be used to define a topic.
    • See section 2.1.1 of the OpenDDS 3.14 Developer's Guide for more information on both of these features.
    • See docs/migrating_to_topic_type_annotations.md for a guide on how to migrate existing IDL to use topic type annotations.
  • Added a C++11 mode to opendds_idl's code generation (#954, #1030, #1379)
  • RtpsRelay, a server that assists with peer-based discovery on the internet, see the "Internet-Enabled RTPS" Chapter in the Developer's Guide (#1057, #1068, #1286, #1341)
  • Support for IETF ICE for NAT firewall traversal, see the "Internet-Enabled RTPS" Chapter in the Developer's Guide (#1069)
  • Dynamic network interface changes on supported platforms (#1365, #1551)
  • An OpenDDS-specific Built-In Topic to report network location/connection details (#1389)
  • Performance improvements to RTPS Discovery and the RTPS_UDP transport (#1045, #1177, #1138, #1202, #1251, #1260, #1262, #1265, #1324, #1402)
  • CMake package for building applications that use OpenDDS, see docs/cmake.md (#981)
  • Query Condition and Content-Filtered Topic can filter dispose/unregister messages (#900)
  • Support for publishing using the Node.js module with V8 (#1065)
  • opendds_idl can generate code to convert IDL structures to RapidJSON (#1097, #1254)
  • Full-message protection (RTPS Protection) in DDS Security (#1280)
  • RTPS protocol version 2.4 (#1367, #1374, #1364, #1359, #1404, #1381, #1518, #1522, #1530, #1540)
  • TCP transport: configurable connection timeout (#1493)
  • A new benchmarking and performance analysis tool in performance-tests/bench_2 (#1546)

Platform Support and Dependencies:

  • Support for Java Development Kit up to version 12 (#1137)
  • Monitor GUI and the ishapes example now use Qt5, see docs/qt.md (#929, #932, #1083)
  • Improved Android support, see docs/android.md (#1066, #1446)
  • iOS support (#1535, #1545, #1551)
  • Updated dissector to work with Wireshark 3 (#1080)

Fixes:

  • DDS Security improvements (#1310, #1482, #1531)
  • Java API can now be used on Android (#1156)
  • Support equals() and hashCode() in Java (#1331)
  • Improved Java bindings builds (#1146, #1157, #1160, #1167)
  • InconsistentTopicStatus support in RTPS Discovery (#1158, #1164)
  • Presentation QoS coherent_access (#1094)
  • RTPS_UDP transport supports combination of best effort and reliable readers of the same writer (#1449)
  • Improved support for fragmented data (#1474, #1547)
  • Topics need to be enabled to use with DataReader/Writer (#1193)
  • TCP Reconnect (#1273, #1464, #1487, #1497, #1501, #1506, #1519, #1523, #1526)
  • Shared memory transport improvements (#1301)
  • GuardCondition _narrow (#1407)
  • "make install" with DESTDIR (#1429, #1440)
  • Support for multiple transport instances in the same transport configuration (#1465)
  • The reliability QoS for DataWriters and Topics is now immutable, matching the DDS 1.4 spec (#1584)

Notes:

  • The configure script now defaults to not including tests (#1287)
  • Removed obsolete -Gws option in opendds_idl. This option produced sample descriptions for the Wireshark dissector before OpenDDS v3.7. (#966, #1031)

Version 3.13.3 of OpenDDS

Released Fri Oct 11 16:13:35 UTC 2019

Fixes:

  • Updated IDL V8 generation to use decimal strings (#1055)
  • Updated Dissector for Wireshark 3.0 (#1080)
  • Added support for Visual Studio 2019 (#1053)
  • .NET compatibility (#1096)
  • Security: improved support for DH keys (#1092)
  • Security: general updates (#1091, #1101, #1118)
  • GoogleTest version update (#1112, #1115)
  • Improved performance of GUID comparison and lookup (#1128, #1133)
  • Fixed Monitor library interaction with DomainParticipant (#1132)
  • Configure script MSVC version detection (#1141)
  • Security with some submessages encoded and some plain (#1166)
  • Receive Strategy buffer management (#1192)
  • Error check in TcpTransport::configure_i (#1209)
  • Service Participant, Reactors, and signals (#1206, #1215, #1231)
  • Modeling SDK Eclipse plugins updated to latest Eclipse (#1222)
  • Secure discovery for unregister/dispose (#1225, #1227, #1232)
  • InstanceState and reactor interceptor with reader data lifecycle (#1237, #1248)
  • Serializer: input validity check when aligning (#1239)
  • Transport framework improvements (#1249)
  • Use monotonic time for relative timeouts on platforms that support it (#1272)
  • SPDP: start counter at a random value and detect bad sequence numbers (#1274)

Version 3.13.2 of OpenDDS

Fixes:

  • Service Participant, Transport Registry, RTPS libs updated to support certain Restart scenarios (#1081)
  • Wrong entity_refs_ counter when deleting data reader in the TopicDescriptionImpl (#936)
  • Add an include required for std::back_inserter (#965)
  • DDS Security on VxWorks7 (#968)
  • Fix unregister with nil handle (#1064)
  • Install with java: Fix classpath for i2jrt.jar and i2jrt_compact.jar in .mpbs (#1079)

Version 3.13.1 of OpenDDS

Fixes:

  • rtps_udp: enhanced generation of gaps for durable data (#1001)
  • rtps_udp transport: improved handling of socket errors (#1002)
  • Fixed a bug in contains_entity for DataReaders (#944)
  • Fixed set_qos method for not enabled DataWriters and DataReaders (#955)
  • Fixed requiring Conditions to be cleaned up in DataReaders (#958)
  • Fixed a locking issue in transport with Security enabled (#933)
  • Fixed total_count fields in on Offered/RequestedDeadlineMissed (#969)
  • Security: Fixing uninitialized values reported by valgrind
  • Support static builds with DDS Security enabled (#967)
  • Fixing build when no-builtin-topic and security flags are both configured
  • Configure: fixed detection of MSVC compiler versions
  • Configure on Windows: allow Perl to be located in a directory with spaces
  • Configure: follow redirects if using curl to download (#1025)
  • Configure: Android support (#964)
  • Configure: added for --host-tools option (part of #968)
  • Make install awareness of user_macros.GNU and improved Java bindings support (#1022)

Version 3.13 of OpenDDS

Additions:

  • Includes a beta implementation of the OMG DDS Security 1.1 specification
  • Monitor library can be enabled with -DCPSMonitor 1 or ini file
  • Updated Wireshark dissector now supports Wireshark version 2.x
  • MultiTopic: use Topic's QoS when creating constituent data readers

Fixes:

  • Memory management improvements
  • Command-line argument -DCPSRTISerialization takes a 0/1 parameter
  • Further refined fix for RtpsUdpDataLink::remove_sample locking
  • Improved Java bindings build process when using GNU Make
  • RTPS interoperability fixes from testing at OMG conferences
  • OpenDDS can be completely shut down and restarted within a process
  • Improved code generation for IDL unions, including in Javascript/V8
  • Fix for in-process messaging in FACE TSS (PR #819)
  • Fix for ReadCondition leak in OpenDDS::FaceTSS::receive_message (PR #832)
  • TCP reconnect enhancements
  • Removed unused sequence number tracking in DataReaderImpl
  • Fixed a memory leak in content filtering on the subscriber side
  • rtps_udp transport: improved handling of socket errors
  • RTPS discovery: avoid skipping sequence numbers in SEDP
  • InfoRepo: improved persistence with Built-in Topics

Notes:

  • The contrib directory, which contained unmaintained code, was removed

Version 3.12 of OpenDDS

Fixes:

  • RtpsUdpDataLink::remove_sample locking
  • track latency only when needed for LatencyBudget QoS or statistics
  • corrected counters for sample rejected/lost liveliness lost total_count_change
  • get_key_value() corrected return value for errors
  • setting DCPSBitTransportPort without DCPSBitTransportIPAddress had no effect
  • writer side association wasn't removed after the the reader had unsubscribed
  • memory leaks
  • issue with unregistered instances when deleting DataWriter
  • problem with multiple transport instances in a single transport config
  • EntityFactory QoS didn't enable child objects when the factory was enabled

Notes:

  • configure supports ACE+TAO from DOCGroup repository as an option
  • configure improvements for using external ACE+TAO, cross-compiling on Windows
  • coverity fixes
  • improved Bench performance test
  • Docker Hub now has an OpenDDS docker image

Version 3.11 of OpenDDS

Additions:

  • Support for Visual Studio 2017
  • Content-filter expressions can now use 64-bit integer literals
  • tcp transport has a new wait_for_acknowledgements implementation
  • DataWriter's HISTORY QoS processing now allows replacing old samples with new ones without blocking

Fixes:

  • Improved robustness of DEADLINE QoS processing
  • Uses of content-filter expressions are now checked for the correct number of parameters
  • Fixed versioned namespace support
  • Improved support for IPv6
  • Improved robustness of rtps_udp transport, especially when used with static discovery
  • Use of the constant PARTICIPANT_QOS_DEFAULT no longer initializes the domain participant factory
  • Bug fixes in the OpenDDS Wireshark dissector (for sample dissection)

Notes:

  • The QoS XML Handler library is now decoupled from DDS4CCM, it requires xerces

Version 3.10 of OpenDDS

Additions:

  • Added support for versioned namespaces
  • Reworked TypeSupport implementation in order to reduce exposure of internal headers to user code
  • Added read/take_instance_w_condition (not in DDS spec)
  • Time Based Filter QoS: fixed GitHub issue #268, samples can now be held and delivered after the timeout
  • C++11 updates to the ishapes example: make use of C++11 shared_ptr and to_string instead of using boost
  • When C++11 is enabled, use noexcept(false) where necessary
  • Extended TypeSupport to allow unregistering of types from a domain participant (not in DDS spec)
  • RtpsDiscovery: allow config to specify which interface's MAC addr is used in GUIDs
  • Wireshark dissector updates: support for more IDL constructs in data sample dissection

Fixes:

  • Liveliness QoS: fixed incorrect "liveliness lost" for automatic liveliness with sporadic writers
  • Fixed RTPS ParticipantMessageData entityIds used by automatic and by-participant liveliness
  • Fixed make install problem when DESTDIR is specified
  • Allow fallback to next transport implementation when active side fails to connect using the first one
  • Updated TypeSupport::get_type_name() to match the DDS spec

Stability Improvements:

  • Fixed many issues included in recent Coverity Scan defect reports
  • Fixed a few reference counting issues in internal classes

Notes:

  • This is the final version we will test with TAO 2.0a, please upgrade to a newer TAO (see README.md)

Version 3.9 of OpenDDS

  • Updated how DataWriter QoS is interpreted by internal data structures:

    • RESOURCE_LIMITS.max_samples_per_instance controls total samples that can be stored per instance, independent of HISTORY
    • HISTORY.depth controls number of samples (per instance) that will be made available to late-joining readers if DURABILITY is enabled
      • KEEP_ALL history uses max_samples_per_instance as its depth
    • WriteDataContainer is more eager to remove samples that are no longer needed
    • WriteDataContainer will not remove samples that are required to implement DURABILITY, hence if RELIABILITY is enabled this can block a write() just like other "no resource available" scenarios
  • Fixed an RTPS interoperability issue with the new ParticipantMessageData messages (used for liveliness)

  • Enhanced RTPS support for DURABILITY QoS enabling faster reader/writer associations when DURABILITY is in use (set to TRANSIENT_LOCAL)

  • RTPS Discovery has a new option "SpdpLocalAddress" which can be used to bind SPDP's socket to a particular network interface

  • InfoRepo discovery will use TAO's BiDir GIOP feature to reduce number of sockets needed (disable with -DCPSBidirGIOP 0)

  • Intermediate Type Language (itl), a helper library used by the OpenDDS wireshark dissector, is now included in the source tree in tools/IntermediateTypeLang. itl depends on the 3rd-pary lib rapidjson. When running the configure script, use --rapidjson=

  • Corrected makefile generation for Java bindings with IDL bounded strings

  • Fixed a bug where some header files would be missing from "make install"

  • "make install" now works with Java bindings

  • Configure script: now supports FreeBSD, Mac OS X El Capitan, and cross-compiles for Linux targets (Raspberry Pi and Intel Edison tested). The configure script attempts to find the JDK if invoked with --java.

  • cross-compilation now works with Java bindings, including use of JRE compact1

Version 3.8 of OpenDDS

  • Improved support for Safety Profile

  • OpenDDS multicast transport (reliable mode) now guarantees in-order delivery

  • Added a "default address" configuration parameter that sets an overall default for binding to a specific network interface

  • Fixed bugs in transport framework, udp transport, InfoRepo discovery, static discovery, and the Liveliness and Durability QoS policies

Version 3.7 of OpenDDS

Additions:

  • Implements FACE Transport Services API v2.1, FACE safety base and FACE safety extended profiles (Future Airborne Capability Environment).
  • Implements DDS 1.4 and RTPS 2.2.
  • Support allocations from memory pool in safety profile builds. Introduced standard library containers and strings, as well as TAO sequences that allocate from this pool.
  • To support FACE TS, the IDL struct DDS::SampleInfo has a new field opendds_reserved_publication_seq as an extension to the DDS specification.
  • Updated opendds_idl for FACE support, moving some of the code-generation from tao_idl to opendds_idl when targeting FACE TS.
  • Support IDL fixed type inside of DCPS_DATA_TYPE (used with FACE TS).
  • Type-specific DataWriterImpl and DataReaderImpl are now templates. Code generation now introduces a typedef of these.
  • Content filtering now supports modulus (MOD) operator as an extension.
  • Added a static (configuration-based) discovery mechanism.
  • RTPS Discovery is now supported when OpenDDS is built without built-in topics.
  • RTPS Discovery has a new configuration parameter SedpLocalAddress which configures the rtps_udp transport used internally by discovery in the same way that local_address configures a user-created rtps_udp transport instance.
  • Support non-default liveliness QOS in rtps_udp transport.
  • Support wait_for_acknowledgements in rtps_udp transport.
  • Support command line option -DCPSRTISerialization when integrating with RTI DDS using RTPS, to account for a different serialization algorithm.
  • Configure script handles some cross-compile builds and safety profile.
  • Support for new Visual Studio compilers (vc11, vc12, and vc14).
  • Support for clang builds on Mac OS X.
  • Removed support for old GCC compilers (<= 3.3).
  • opendds_idl command-line option -Gitl is a replacement for -Gws. Wireshark dissector now reads ITL files, rather than .ini files.

Fixes:

  • Fixed many tests for minimum profile builds.
  • Enforced correct behavior of a reliable data writer when history QoS is set to KEEP_LAST with depth=1.
  • opendds_idl can now be specified in user_macros.GNU instead of always assuming it is in $DDS_ROOT/bin (for -type gnuace builds).
  • Fixed initial IPv6 support in windows builds.
  • Fixed disassociate handling of local entities on loopback interface.
  • Corrected wait_for_acknowedgements for non-reliable writers to return success immediately.
  • Allow disassociating readers to finish processing messages from active writer before removing.
  • Remove TcpDataLink from DataLinkSet when connect() fails. Previously, the datalink would remain and would be seen as a fully-connected datalink by new associations.
  • DCPSTransportDebugLevel 1 messages are now association-oriented.
  • Fixed durable resend out-of-order handling for rtps_udp transport.
  • Fixed handling of acknowledgements during shutdown of rtps_udp data link.
  • RTPS Discovery now ignores 'RTPX' messages seen during RTI integration.
  • Dissection of unions in wireshark dissector (requires ITL).
  • Corrected reference counting scheme for Recorder and Replayer objects: the reference-counted handle types changed from _rch to _var.

Notes:

Version 3.6 of OpenDDS

Notes:

  • The discovery framework of OpenDDS has been refactored to be more asynchronous. This should make discovery faster and more reliable for both publishing and subscribing clients, regardless of the discovery mechanism used (RTPS or InfoRepo).

  • DataWriters now release locks more quickly than before. This allows the transport to be available to more threads when compared to 3.5.1.

  • Improved DDS specification compliance with regards to reliability, resource limits, and history qos settings. Specifically, reliable data writers may block for max_blocking_time and potentially return DDS::RETCODE_TIMEOUT in situations where they would have simply written the data in older version of OpenDDS. The new behavior is required by the DDS specification, see section 2.2.2.4.2.11 of the version 1.4 specification for details. This change affects various operations of the data writer interface including the write and register operations.

Additions:

  • The wireshark dissector now supports wireshark versions 1.8.x, 1.10.x, 1.12.x, and 1.99.1.

  • The modeling framework now support Eclipse 4.4 (Luna) and GMF 3.1.x

  • Added a public_address option for the tcp transport. This option allows a tcp transport instance to listen on one address (local_address) while advertising another address (public_address) to discovery. This feature was used to allow a proxy process between the subscriber and publisher in the TcpReconnect test, but may also be useful in other deployment scenarios, especially using OpenDDS through a firewall.

Fixes:

  • There were a number of concurrency and thread utilization improvements. These changes fixed a number of threading issues as well as improving the efficiency of publication.

  • Fixed some issues with RTPS discovery.

  • Fixed a number of issues related to the reconnect functionality of the tcp transport.

  • Fixed some bugs in the OpenDDS IPv6 support.

  • Eliminate duplicate samples received during durable resend.

  • Fixed memory leak at shutdown time in modeling library.

Tests:

  • Many updates to make test results more complete and deterministic.

  • Added a TcpReconnect test that exercised the ability of the tcp transport to seamlessly reconnect OpenDDS clients when the transport layer drops a connection.

  • Added a WriteDataContainer unit test to verify data writer memory management compliance with the DDS specification.

  • Added a PubScalability test that was used to test association and publications with large numbers of subscribers.

  • Added a packet reassembly unit test.

Version 3.5.1 of OpenDDS

Notes:

  • Due to addition control messages in the 3.5.1 release, mixing 3.5.0 and 3.5.1 releases should work properly, but the 3.5.0 data readers can emit the following error message when associating with a durable 3.5.1 data writer: ERROR: DataReaderImpl::data_received unexpected message_id = 11 Upgrade all endpoints to 3.5.1 to remove this error message.

Additions:

  • Support later (>= 4.7) versions of GCC compilers, and later (>= 2.0a) builds of TAO. Configure script now downloads 2.2a by default.

  • Added IDL compiler support for typedef of string fields within unions. Added Java IDL compiler support for struct forward declarations.

  • Updated UML design diagrams to reflect current code base.

Fixes:

  • DCPSInfoRepo no longer informs a subscriber about a crashed or killed publisher. This made associations of current publishers and subscribers delayed until timeout was reached.

  • Fixed deadlock condition in send_delayed_notifications() resulting from multiple datawriters.

  • Fixed deadlock in DataLinkSet::send_control().

  • Fixed deadlock in WaitSet::wait() and DataReaderImpl::data_received().

  • Fixed multicast transport with multiple participants in a single process.

  • Fixed parsing of -ReassociateDelay argument by DCPSInfoRepo.

  • Fixed crash of long-lived zero-copy sequence when it is destroyed and crash of zero-copy sequence accessing released instances.

  • Fixed unprotected access to DataWriterImpl::reader_info_, and TransportSendStrategy::pkt_chain_.

  • Fixed multiple RTPS crashes when participant is being deleted.

  • Fixed RTPS crash when a data reader is being deleted.

  • Fixed problem for non-unique repo ids for multicast when multiple (non-federated) DCPSInfoRepos are used on the same network.

  • Fixed crash caused by back-pressure in transport causing the most recent sample for an instance to be dropped.

  • Fixed error in reconstruction logic for fragmentation of udp and multicast transport packets.

  • Fixed PublisherImpl and SubscriberImpl to properly set a DataWriterImpl or DataReaderImpl entity's deleted flag during deletion to allow association checks to properly identify entities that are being deleted and not proceed in association.

  • Fixed problem for persisted DCPSInfoRepo where persisted participants were never dissociating.

  • Fixed activity improperly occuring when a partipant is being deleted that caused pure virtual function calls. In one case, waiting now takes place during deletion of a data writer until all control messages sent during unregistration of instances are account for. In another case fixed so TransportSendControlElement will delete itself before it reports to the listener that the message has been delivered/dropped.

Tests:

  • Many updates to make test results more deterministic.

  • Added Reliability test.

  • Added ManyToMany test to test associations with additional participants, publishers, subcribers, data readers and data writers.

  • Added PersistentInfoRepo test.

  • Restored thrasher medium and high test cases.

  • Rewrite Priority test to make it verify proper QOS functionality.

  • Rewrite LargeSample test to make it verify message contents are as expected.

Version 3.5 of OpenDDS

  • Updates to RTPS support resulting from both interoperability testing (March 2013 OMG meeting) and user feedback.

  • Fixed a bug in the DataReader relating to the Deadline timer.

  • Generated TypeSupportImpl classes now contain nested typedefs that facilitate programming with C++ templates. See tests/DCPS/ManyTopicTest for an example of usage.

  • Added config options to bind RTPS-related multicast sockets to specific network interfaces. See the ChangeLog for details.

  • Fixed an opendds_idl code generated bug when typedefs of basic types are used as fields of structs.

  • Corrected a number of other bugs related to discovery and scaling.

Version 3.4.1 of OpenDDS

  • Added a new option to opendds_idl, -Wb,v8, which generates type support for copying DCPS structs from C++ objects to JavaScript objects -- requires the V8 JavaScript engine. See https://npmjs.org/package/opendds for OpenDDS integration with Node.js.

  • Fixed a bug in serialization with misaligned reads. It only impacts certain platforms with strict alignment requirements such as SPARC/SunCC.

  • Clang 3.2 is now a supported compiler.

  • Fixed a bug in the rtps_udp transport, in certain cases an invalid Gap submessage was sent which can result in data samples not being received.

Version 3.4 of OpenDDS

  • Added new OpenDDS-specific APIs for sending and receiving untyped data, (does not require code generation from IDL data structures). See the Recorder and Replayer classes and the test in tests/DCPS/RecorderReplayer.

  • Implemented the ability to send fragmented data with the rtps_udp transport.

  • Fixed a bug in copy_from_topic_qos(): the Ownership policy is now copied.

  • The optimization of publisher-side content filtering now applies to durable data in addition to newly written data samples.

  • As with versions before 3.2, the DCPSInfoRepo object reference is allowed to fail to resolve. If it fails, the current operation can be re-tried at a later time when the DCPSInfoRepo server is available.

  • Added a new option for per-domain default transport configurations.

  • Corrected IDL string constants for QoS policy names which were wrong in the DDS spec (GROUPDATA and TRANSPORTPRIORITY ..._QOS_POLICY_NAME). These are not used anywhere in OpenDDS.

Version 3.3 of OpenDDS

  • If an instance of a transport can't be set up, an exception is thrown so that different configuration parameters can be attempted by the user.

  • Corrected the mapping of Priority QoS to DiffServ CodePoint DS subfield.

  • For thread-per-connection send, if no explicit scheduling policy has been configured, OpenDDS will now inherit the current thread's policy/priority.

  • Fixed a possible deadlock of RTPS discovery on Windows.

  • Added non-blocking I/O setting to tcp sockets, VxWorks 6.4 required it.

  • Fixed various bugs in deadline and ownership QoS.

  • Improved multicast transport's robustness during handshaking when many connections are set up at the same time, and also allow for multicast to skip over received datagrams that don't have the expected header values.

  • Multicast transport configuration can now specify a local network interface which will be used to join the multicast group.

  • The support for the generation of the DDS4CCM needed LEM library has been moved to CIAO DDS4CCM. This removed the optional dependency on CIAO.

Version 3.2 of OpenDDS

  • Added a new transport type: Shared Memory Use shmem as the short name (in place of "tcp", "udp", "multicast", etc.). See dds/DCPS/transport/shmem/ShmemInst.h for configurable parameters.

  • The udp transport now supports setting IP DSCP (DiffServ CodePoint) based on the writer's TRANSPORT_PRIORITY QoS value.

  • Fixed bugs in udp and multicast transports, including reassembly of fragments.

  • Made several changes in order to support CIAO 1.1.2 with DDS4CCM. From this version DDS4CCM has support for OpenDDS as DDS vendor. Check the CIAO release notes for details on what has been ported.

  • Added new QOS_XML library with which QoS settings can be done through an XML file. Used at this moment by the CIAO DDS4CCM implementation.

  • Implemented rejection of samples due to exceeding max_instances and max_samples.

  • Made the RTPS discovery and transport code more robust.

  • Refactored InfoRepo-based discovery into its own library. This reduces the dependency on TAO such that certain TAO libraries will no longer be loaded unless they are needed for InfoRepo-based discovery.

  • For IDL files that only contain local interfaces, the generation of server-side TAO code was suppressed. The suppression applies to DdsDcps*.idl. This means, for example, that code that was including DdsDcpsSubscriptionS.h needs to be changed to include DdsDcpsSubscriptionC.h.

  • To reduce library size, OpenDDS can now be conditionally compiled to exclude profiles discussed in the Compliance section of the DDS spec. See section 1.3.3 in the Developer's Guide for more information.

Version 3.1 of OpenDDS

  • This release includes the initial implementation of DDS Interoperability in OpenDDS, using the DDS-RTPS spec v2.1 from the OMG (formal/2010-11-01).

    RTPS support in OpenDDS consists of two main features:

    • A pluggable transport implementation, known as "rtps_udp" because it implements the UDP PSM of the DDS-RTPS spec. This is a peer of the existing OpenDDS-native transports: "tcp", "udp", and "multicast".

    • A new discovery mechanism for RTPS's distributed discovery. This can replace the DCPSInfoRepo in existing OpenDDS deployments.

    Neither of these features is enabled by default. See the OpenDDS Developer's Guide chapter 7 for configuration details. Also, note that not every OpenDDS feature (for example, certain QoS values) is supported with RTPS in the initial implementation. These exceptions are documented in the Developer's Guide sections 7.3.3 and 7.4.5.5.

  • Changed set_qos() of DataWriter, DataReader, Publisher and Subscriber so when provided a QoS value incompatible with an existing association, that the value will be changed, association will be broken, and RETCODE_OK returned. Previously, if any association would be broken, no change would take place and false would be returned. New version is compatible with DDS spec.

  • OpenDDS udp transport enhancements:

    • Added send_buffer_size and rcv_buffer_size parameters to the udp transport configuration.
    • The default local address will use DNS host names instead of IP addresses.
    • Added support for IPv6 when ACE is built with IPv6 support.
  • OpenDDS multicast transport enhancements:

    • Added a configuration parameter "async_send" (defaults to false) that will send multicast datagrams using async I/O if supported by the platform. As of now this is only implemented on Windows. It could be extended to Unix aio_*() functions in theory, but these are generally not preferred and the regular socket functions are sufficiently fast.
  • Removed DataReaderQosExt from DdsDcpsSubscriptionExt.idl. This was only being used to provide a non-standard-compliant backwards-compatibility setting to get the DURABILITY QoS behavior matching that of OpenDDS v1.2 and earlier. It was not being used in any OpenDDS code.

Version 3.0.1 of OpenDDS

  • The DCPSInfoRepo reassociates Built in Topic connections for existing datareaders and datawriters when restarted from persistence.

  • The opendds_idl compiler will now print a warning about not including TAO's orb.idl file when a file named orb.idl is included.

  • Fixed a bug where the timeout for passive_connect_duration was ignored.

  • Fixed multiple bugs in fragmentation/reassembly used for udp and multicast.

  • Fixed multicast loopback and session re-use problems.

  • Fixed a bug with memory management for the TransportCustomizedElement used in publisher-side content filtering.

  • New example Messenger.minimal - which is like messenger, but streamlined for new users to understand the whole easier.

Version 3.0 of OpenDDS

  • Transport configuration has undergone a major redesign and any existing transport application code or transport configuration files need to be updated. See the Developer's Guide for details of the design. See $DDS_ROOT/docs/OpenDDS_3.0_Transition.txt for a description on how to migrate your applications to the OpenDDS 3.0 design. As a part of this design OpenDDS gains the following capabilities:

    • Most applications can do all transport configuration via configuration files (no transport source code required).
    • Individual writers and readers can now support multiple transports.
  • The simpleTcp transport was renamed to tcp (the directory containing its source code was also renamed).

  • The udp transport no longer required a local_address when being configured. If not specified, the property defaults to a value selected by the operating system (similar to the tcp transport).

  • Details of the OpenDDS Modeling SDK changes in this release are documented in the Eclipse-based help, see OpenDDS Modeling SDK Guide -> Getting Started -> Introduction to the OpenDDS Modeling SDK.

  • First release of OpenDDS Real-Time Data (RTD) for Excel an Excel Add-in and RTD Server. It allows visualization of an operating OpenDDS system from within Excel. It gives a tree view of a repository that mirrors the stand-alone OpenDDS Monitor application's tree view, but with the additional capabilities to automatically restart monitoring of a repository when a saved workbook is opened, monitoring multiple repositories simultaneously, and snapshot a repository monitor tree view.

  • Wireshark dissector improvements include removal of the restriction that inforepo IOR be placed in a special file. Dissector config files can now be generated by opendds_idl.

  • The monitor tool has a new view which is an alternate to the Graphviz view. The Node view uses Qt gui elements to model the OpenDDS system. Users can manipulate Node view graphs before saving them to PNG files.

NEWS for Previous Major Versions