Mbed TLS before 3.6.4 allows a use-after-free in certain situations of applications that are developed in accordance with the documentation. The function mbedtlsx509stringtonames() takes a head argument that is documented as an output argument. The documentation does not suggest that the function will free that pointer; however, the function does call mbedtlsasn1freenameddatalist() on that argument, which performs a deep free(). As a result, application code that uses this function (relying only on documented behavior) is likely to still hold pointers to the memory blocks that were freed, resulting in a high risk of use-after-free or double-free. In particular, the two sample programs x509/certwrite and x509/cert_req are affected (use-after-free if the san string contains more than one DN).
{
"binaries": [
{
"binary_name": "libmbedcrypto0",
"binary_version": "2.2.1-2ubuntu0.3"
},
{
"binary_name": "libmbedtls-dev",
"binary_version": "2.2.1-2ubuntu0.3"
},
{
"binary_name": "libmbedtls10",
"binary_version": "2.2.1-2ubuntu0.3"
},
{
"binary_name": "libmbedx509-0",
"binary_version": "2.2.1-2ubuntu0.3"
}
]
}{
"binaries": [
{
"binary_name": "libmbedcrypto16",
"binary_version": "3.6.2-3ubuntu1"
},
{
"binary_name": "libmbedtls-dev",
"binary_version": "3.6.2-3ubuntu1"
},
{
"binary_name": "libmbedtls21",
"binary_version": "3.6.2-3ubuntu1"
},
{
"binary_name": "libmbedx509-7",
"binary_version": "3.6.2-3ubuntu1"
}
]
}{
"binaries": [
{
"binary_name": "libmbedcrypto1",
"binary_version": "2.8.0-1ubuntu0.1~esm1"
},
{
"binary_name": "libmbedtls-dev",
"binary_version": "2.8.0-1ubuntu0.1~esm1"
},
{
"binary_name": "libmbedtls10",
"binary_version": "2.8.0-1ubuntu0.1~esm1"
},
{
"binary_name": "libmbedx509-0",
"binary_version": "2.8.0-1ubuntu0.1~esm1"
}
],
"availability": "Available with Ubuntu Pro: https://ubuntu.com/pro"
}{
"binaries": [
{
"binary_name": "libmbedcrypto3",
"binary_version": "2.16.4-1ubuntu2+esm1"
},
{
"binary_name": "libmbedtls-dev",
"binary_version": "2.16.4-1ubuntu2+esm1"
},
{
"binary_name": "libmbedtls12",
"binary_version": "2.16.4-1ubuntu2+esm1"
},
{
"binary_name": "libmbedx509-0",
"binary_version": "2.16.4-1ubuntu2+esm1"
}
],
"availability": "Available with Ubuntu Pro: https://ubuntu.com/pro"
}{
"binaries": [
{
"binary_name": "libmbedcrypto7",
"binary_version": "2.28.0-1ubuntu0.1~esm1"
},
{
"binary_name": "libmbedtls-dev",
"binary_version": "2.28.0-1ubuntu0.1~esm1"
},
{
"binary_name": "libmbedtls14",
"binary_version": "2.28.0-1ubuntu0.1~esm1"
},
{
"binary_name": "libmbedx509-1",
"binary_version": "2.28.0-1ubuntu0.1~esm1"
}
],
"availability": "Available with Ubuntu Pro: https://ubuntu.com/pro"
}{
"binaries": [
{
"binary_name": "libmbedcrypto7t64",
"binary_version": "2.28.8-1ubuntu0.1~esm1"
},
{
"binary_name": "libmbedtls-dev",
"binary_version": "2.28.8-1ubuntu0.1~esm1"
},
{
"binary_name": "libmbedtls14t64",
"binary_version": "2.28.8-1ubuntu0.1~esm1"
},
{
"binary_name": "libmbedx509-1t64",
"binary_version": "2.28.8-1ubuntu0.1~esm1"
}
],
"availability": "Available with Ubuntu Pro: https://ubuntu.com/pro"
}