OpenDDS 3.21.0 is currently in development, so this list might change.
- TODO: Add your features here
- TODO: Add your fixes here
- TODO: Add your notes here
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