eprosima Fast DDS is a C++ implementation of the Data Distribution Service standard of the Object Management Group. Prior to versions 2.11.1, 2.10.2, 2.9.2, and 2.6.6, heap can be overflowed by providing a PIDPROPERTYLIST parameter that contains a CDR string with length larger than the size of actual content. In eprosima::fastdds::dds::ParameterPropertyList_t::push_back_helper
, memcpy
is called to first copy the octet'ized length and then to copy the data into properties_.data
. At the second memcpy, both data
and size
can be controlled by anyone that sends the CDR string to the discovery multicast port. This can remotely crash any Fast-DDS process. Versions 2.11.1, 2.10.2, 2.9.2, and 2.6.6 contain a patch for this issue.
{ "availability": "Available with Ubuntu Pro: https://ubuntu.com/pro", "ubuntu_priority": "medium", "binaries": [ { "binary_version": "2.5.0+ds-3ubuntu0.1~esm1", "binary_name": "fastdds-tools" }, { "binary_version": "2.5.0+ds-3ubuntu0.1~esm1", "binary_name": "fastdds-tools-dbgsym" }, { "binary_version": "2.5.0+ds-3ubuntu0.1~esm1", "binary_name": "libfastrtps-dev" }, { "binary_version": "2.5.0+ds-3ubuntu0.1~esm1", "binary_name": "libfastrtps-doc" }, { "binary_version": "2.5.0+ds-3ubuntu0.1~esm1", "binary_name": "libfastrtps2.5" }, { "binary_version": "2.5.0+ds-3ubuntu0.1~esm1", "binary_name": "libfastrtps2.5-dbgsym" } ] }
{ "availability": "No subscription required", "ubuntu_priority": "medium", "binaries": [ { "binary_version": "2.10.1+ds-3", "binary_name": "fastdds-tools" }, { "binary_version": "2.10.1+ds-3", "binary_name": "fastdds-tools-dbgsym" }, { "binary_version": "2.10.1+ds-3", "binary_name": "libfastrtps-dev" }, { "binary_version": "2.10.1+ds-3", "binary_name": "libfastrtps-doc" }, { "binary_version": "2.10.1+ds-3", "binary_name": "libfastrtps2.10" }, { "binary_version": "2.10.1+ds-3", "binary_name": "libfastrtps2.10-dbgsym" } ] }