Released 2023-10-23
Download this release on GitHub.
Read the documenation for this release on Read the Docs.
-
OpenDDS can now be built using CMake for most common scenarios. (PR #4203, PR #4214)
- This is still considered somewhat experimental as it doesn't support everything that an MPC-built OpenDDS currently can.
- See Building OpenDDS Using CMake for details.
-
Convert transport configurations (
rtps_udp
,multicast
,shmem
,tcp
,udp
) uses key-value store. (PR #4162, PR #4270, PR #4272, PR #4241, PR #4242, PR #4243, PR #4249, PR #4255) -
CMake Config Package
-
Added
opendds_install_interface_files
to help install IDL files and the files generated from them. (PR #4203, PR #4214) -
Added
OPENDDS_HOST_TOOLS
andOPENDDS_ACE_TAO_HOST_TOOLS
to allow cross compiling applications with both MPC and CMake-built OpenDDS. (PR #4203, PR #4214) -
- Added
opendds_target_sources(INCLUDE_BASE)
to preserve the directory structure of the IDL files for compiling the resulting generated files and installing everything usingopendds_install_interface_files
. (PR #4203, PR #4214) - Added
opendds_target_sources(USE_VERSIONED_NAMESPACE)
as a shortcut to the-Wb,versioning_\*
IDL compiler options. (PR #4203, PR #4214)
- Added
-
-
Support sending DynamicDataAdapter sample via DynamicDataWriter (PR #4226)
-
Added export macro to ConditionImpl (PR #4295)
- Deprecated
OPENDDS_FILENAME_ONLY_INCLUDES
in favor ofopendds_target_sources(INCLUDE_BASE)
. (PR #4203, PR #4214)
-
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)
- Remove -Grapidjson flag [opendds_idl] (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)
- Using Perl 5.38.0 might prevent TAO from building properly, see here for details.
Released 2023-07-20
Download this release on GitHub.
Read the documenation for this release on Read the Docs.
-
The Observer interface now has support for dispose and unregister. (PR #4137)
-
OpenDDS now stores configuration information in a key-value store. (PR #4138, PR #4134, PR #4151)
-
Configuration values can be set via API, config file, or command line.
- Currently applies to the common section and common transport configuration.
-
-
Added
encode_to_string
,encode_to_bytes
,decode_from_string
, anddecode_from_bytes
toTypeSupport
. (PR #4144, PR #4122, PR #4133, PR #4135)- These methods convert samples to and from other formats.
- Currently only
OpenDDS::DCPS::JSON_DATA_REPRESENTATION
is supported.
-
Add
-Gequality
option to opendds_idl to generate==
and!=
for structs and unions. (PR #4154)- The members of the struct or union must have a type that could appear in a DDS topic and be supported by opendds_idl.
- The motivation for this change was to make the generated code more useful as many users go on to define these operators.
-
CMake Config Package
-
Added executable targets. (PR #4160)
-
OPENDDS_CMAKE_VERBOSE
output has been expanded, but now accepts a list of categories to control how much is logged. (PR #4160) -
Added
opendds_export_header
to generate an export header. (PR #4160) -
- Added
opendds_target_sources(GENERATE_SERVER_SKELETONS)
to allowtao_idl
to generate code for CORBA servers. (PR #4140) - Added
opendds_target_sources(AUTO_LINK)
as a fine-grained version ofOPENDDS_AUTO_LINK_DCPS
. (PR #4140) - Added
opendds_target_sources(SKIP_TAO_IDL)
to disabletao_idl
. (PR #4140) - Added
opendds_target_sources(SKIP_OPENDDS_IDL)
to disableopendds_idl
. (PR #4140) - Added
opendds_target_sources(USE_EXPORT)
to allow overriding the generated export header with an existing one. (PR #4160)
- Added
-
Libraries and features can be passed to
find_package(OpenDDS COMPONENTS)
to change what is required. (PR #4160, PR #4140)- See Components for details.
-
- Fixed null pointer exception caused by RTPS Parameters with incorrect zero size. (PR #4197)
-
CMake Config Package
-
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
-
Moved various markdown files into the Sphinx documentation so that they are now included along with the Developer's Guide: (PR #4139)
INSTALL.md
is now Building and Installing.docs/dependencies.md
is now Dependencies.docs/cmake.md
is now Using OpenDDS in a CMake Project.docs/android.md
is now Android.docs/ios.md
is now iOS.
-
Restructured how the documentation is presented to cleanly separate the Developer's Guide and internal documentation. (PR #4139)
-
Added a proper main page. (PR #4139)
-
In addition to
NEWS.md
, started adding release notes to Release Notes. (PR #4125)
-
CMake Config Package
-
OPENDDS_TARGET_SOURCES
is now calledopendds_target_sources
. (PR #4140)- CMake macros and functions names are case insensitive, so this should have no effect on CMake code.
-
OpenDDS 3.24.2 was released on Jun 30 2023.
- 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.
- Fixed leaked shared memory by the shared memory transport. (#4171)
- For a 100% fix, a new ACE version including DOCGroup/ACE_TAO#2077 must be used.
- 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.
- #4180 required changes in InfoRepoDiscovery's IDL, so InfoRepo compatibility with older versions has been broken.
OpenDDS 3.24.1 was released on Apr 21 2023.
- 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)
- 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)
OpenDDS 3.24.0 was released on Apr 11 2023.
- 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
- The Sphinx/reStructuredText source for this new format is now located in the repo at
- 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
DynamicDataReader
s to useQueryCondition
andContentFilteredTopic
and allowsDynamicDataWriter
s to do filtering on behalf of matchedDataReader
s that useContentFilteredTopic
.
- This allows
DynamicData
:- Can now read and write enum members as strings (#4022)
get_int64_value
andget_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.
- See
- 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
.
- These are configured with the new options
- Added
OPENDDS_AUTO_LINK_DCPS
andOPENDDS_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)
- 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
intao_idl
/opendds_idl
options inOPENDDS_TARGET_SOURCES
and those directories are now automatically included (#4071) - XTypes (#4078):
TypeObject
s 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 theTypeObject
s 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 toopendds_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 byDynamicDataFactory
that can be passed toDynamicDataWriter
):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.
- Release files will only be uploaded to GitHub from now on
OpenDDS::DCPS::RepoId
has been removed, if needed useOpenDDS::DCPS::GUID_t
instead (#3972)
OpenDDS 3.23.1 was released on Feb 1 2023.
- 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
andprint_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)
OpenDDS 3.23.0 was released on Dec 21 2022.
- 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)
- Unauthenticated participant leads to invalid iterator (#3748)
- Shmem Association race (#3549)
- Shmem and tcp null pointer (#3779)
- Submodule checkout on Windows (#3812)
- Docker images are built for release tags https://github.com/objectcomputing/OpenDDS/pkgs/container/opendds (#3776)
OpenDDS 3.22.0 was released on Sep 16 2022.
- 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)
- 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)
- Removed wait param in TransportRegistry::create_inst (#3644)
- Changed Multicast Group Join Errors to Warnings (#3558)
- Remove Leading
::
fromTypeObject
Names (#3679) - Updates to the ValueReader/ValueWriter/ValueDispatcher framework (#3719)
- Updates to Dockerfile (#3737)
OpenDDS 3.21.0 was released on Jun 24 2022.
- 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)
- 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)
OpenDDS 3.20.0 was released on Mar 25 2022.
- Added the
host_name
shared memory transport config option (#3386) - Added an example test for demonstrating issues (#3322)
- Added the
--old-typeobject-encoding
option toopendds_idl
for compatibility withTypeObject
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 facilitate this, a new function called
- To help install generated files,
OPENDDS_TARGET_SOURCES
now adds lists of the files that where passed in and generated that are part of thePUBLIC
andINTERFACE
scopes as properties on the target - See
docs/cmake.md
for details on all of these new features
- OpenDDS, ACE, and TAO libraries can now be installed using
- Added an
OPENDDS_DEFAULT_SCOPE
option that allows changing the default scope ofOPENDDS_TARGET_SOURCES
(#3315) - Support
INSTALL_LIB
being used withmake install
to change the name of thelib
directory (#2879)- NOTE: This required changing the CMake module installation destination from
lib
toshare
.
- NOTE: This required changing the CMake module installation destination from
- Improved support for installing CMake projects that use OpenDDS (#3315, #3354, #3367, #3368, #3393)
- 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)
- 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 withOPENDDS_TARGET_SOURCES
(#3315) - Fixed issue #1297 where
opendds_idl
generates an incorrect include path (#3315)
- Fixed issue when using
OpenDDS 3.19.0 was released on Dec 10 2021.
- 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)
- 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 callingfind_package(OpenDDS)
before a C/C++ project has been declared (#3093)
- 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)
OpenDDS 3.18.1 was released on Sep 24 2021.
- 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)
OpenDDS 3.18.0 was released on Aug 24 2021.
- IDL4 explicitly-named integer types (#2814, #2857, #2862)
- The existing IDL integer types,
short
,long
, andlong long
, now have new aliases, which areint16
,int32
, andint64
respectively, along with unsigned versions of them likeuint32
. - There are also two new distinct integer types:
int8
anduint8
.
- The existing IDL integer types,
- 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.
- Added the
- 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.
- Added the
- To try to reduce possible network congestion, temporarily increase the heartbeat send period while they go unanswered (#2911, #2913, #2915)
- Added the
SendBufferSize
andRecvBufferSize
RTPS discovery config options to set the buffer sizes for the sockets used for discovery (#2935)
- Added the
- The QoS XML Handler can now take input from a string (#2439)
- 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.
- This means
- 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 toTRUE
/FALSE
andtrue
/false
for boolean values.
- RtpsRelay fixes and improvements (#2899, #2895, #2887, #2884, #2864, #2881, #2776, #2761, #2751, #2717, #2710, #2927, #2929, #2928, #2921)
- Fixed
- Fixed
Topic
s returned fromfind_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
andSubscriberImpl
associated with presentation QoS (#2886, #2903) make install
:- Use
$(INSTALL_LIB)
instead of hardcodedlib
for Java-related files (#2740) - Use relative links in
$(INSTALL_PREFIX)/share
(#2780) - Fix headers unnecessarily getting installed to
$(INSTALL_PREFIX)/include/DCPS
(#2864)
- Use
- 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.
- The old spelling,
OpenDDS 3.17.0 was released on May 18 2021.
- 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.
- This requires RapidJSON, so it is now installed along with OpenDDS if it was configured (#2426)
- 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)
- 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)
- Use a leading
- 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 foropendds_idl
andtao_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.
- NOTE:
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)
OpenDDS 3.16 was released on Jan 27 2021.
- 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.
- NOTE: Version macros starting with
- Configure Script:
- Added
--doc-group3
option for using DOC Group ACE7/TAO3 (#2336) - Added
--workspace
option for using a custom MPC workspace file (#2262)
- Added
- 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)
- 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.
- 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 ofrepresentation.value
ofDataWriterQos
must be set toDDS::XCDR_DATA_REPRESENTATION
or the non-OpenDDS 3.16 DataReader must be set up withDDS::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)
OpenDDS 3.15 was released on Dec 22 2020.
- 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)
- 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)
- 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)
- Passing C++ source files to the
OPENDDS_TARGET_SOURCES
macro in the CMake module is now deprecated (#1741)
OpenDDS 3.14.1 was released on Nov 20 2020.
- 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)
- Fixed
- Support for the C++11 mapping in the CMake module.
-Lc++11
can now be passed withOPENDDS_IDL_OPTIONS
inOPENDDS_TARGET_SOURCES
. (#1728, #1736)
OpenDDS 3.14 was released on Mar 5 2020.
- 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)
- 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)
- 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)
- The configure script now defaults to not including tests (#1287)
- Removed obsolete
-Gws
option inopendds_idl
. This option produced sample descriptions for the Wireshark dissector before OpenDDS v3.7. (#966, #1031)
Released Fri Oct 11 16:13:35 UTC 2019
- 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)
- 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)
- 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)
- 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
- 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
- The contrib directory, which contained unmaintained code, was removed
- 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
- 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
- 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
- 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)
- The QoS XML Handler library is now decoupled from DDS4CCM, it requires xerces
- 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
andto_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
- 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
- Fixed many issues included in recent Coverity Scan defect reports
- Fixed a few reference counting issues in internal classes
- This is the final version we will test with TAO 2.0a, please upgrade to a newer TAO (see README.md)
-
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
-
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
- 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.
- 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.
- OCI no longer builds with vc71, vc8, and GCC 4.1.1. If you require support of these older platforms contact [email protected].
- The project repository is now at https://github.com/objectcomputing/OpenDDS
-
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.
-
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.
-
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.
-
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.
- 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.
-
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.
-
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.
-
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.
-
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.
-
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.
-
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.
-
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.
-
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.
-
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.
-
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.
-
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 OpenDDS release 2.X versions are archived in docs/history/NEWS-2.md
- NEWS for OpenDDS release 1.X versions are archived in docs/history/NEWS-1.md
- NEWS for OpenDDS release 0.X versions are archived in docs/history/NEWS-0.md