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 PID_PROPERTY_LIST 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.
References
Link | Resource |
---|---|
https://github.com/eProsima/Fast-DDS/commit/349227005827e8a67a0406b823138b5068cc47dc | Third Party Advisory |
https://github.com/eProsima/Fast-DDS/security/advisories/GHSA-j297-rg6j-m7hx | Third Party Advisory |
https://www.debian.org/security/2023/dsa-5481 | Third Party Advisory |
History
No history.
MITRE Information
Status: PUBLISHED
Assigner: GitHub_M
Published: 2023-08-11T13:37:07.478Z
Updated: 2023-08-11T13:38:42.162Z
Reserved: 2023-08-07T16:27:27.074Z
Link: CVE-2023-39946
JSON object: View
NVD Information
Status : Analyzed
Published: 2023-08-11T14:15:13.483
Modified: 2023-08-22T14:21:30.250
Link: CVE-2023-39946
JSON object: View
Redhat Information
No data.