FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license. In affected versions a missing offset validation may lead to an Out Of Bound Read in the function gdi_multi_opaque_rect. In particular there is no code to validate if the value multi_opaque_rect->numRectangles is less than 45. Looping through multi_opaque_rect->numRectangles without proper boundary checks can lead to Out-of-Bounds Read errors which will likely lead to a crash. This issue has been addressed in versions 2.11.0 and 3.0.0-beta3. Users are advised to upgrade. There are no known workarounds for this vulnerability.
{
"availability": "Available with Ubuntu Pro (Infra-only): https://ubuntu.com/pro",
"binaries": [
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "freerdp2-dev"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "freerdp2-shadow-x11"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "freerdp2-wayland"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "freerdp2-x11"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "libfreerdp-client2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "libfreerdp-server2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "libfreerdp-shadow-subsystem2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "libfreerdp-shadow2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "libfreerdp2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "libuwac0-0"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "libuwac0-dev"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "libwinpr-tools2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "libwinpr2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "libwinpr2-dev"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.18.04.4+esm2",
"binary_name": "winpr-utils"
}
]
}
{
"availability": "No subscription required",
"binaries": [
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "freerdp2-dev"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "freerdp2-shadow-x11"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "freerdp2-wayland"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "freerdp2-x11"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "libfreerdp-client2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "libfreerdp-server2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "libfreerdp-shadow-subsystem2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "libfreerdp-shadow2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "libfreerdp2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "libuwac0-0"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "libuwac0-dev"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "libwinpr-tools2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "libwinpr2-2"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "libwinpr2-dev"
},
{
"binary_version": "2.2.0+dfsg1-0ubuntu0.20.04.6",
"binary_name": "winpr-utils"
}
]
}
{
"availability": "No subscription required",
"binaries": [
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "freerdp2-dev"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "freerdp2-shadow-x11"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "freerdp2-wayland"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "freerdp2-x11"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "libfreerdp-client2-2"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "libfreerdp-server2-2"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "libfreerdp-shadow-subsystem2-2"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "libfreerdp-shadow2-2"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "libfreerdp2-2"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "libuwac0-0"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "libuwac0-dev"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "libwinpr-tools2-2"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "libwinpr2-2"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "libwinpr2-dev"
},
{
"binary_version": "2.6.1+dfsg1-3ubuntu2.5",
"binary_name": "winpr-utils"
}
]
}