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).
{
"license": "CC-BY-4.0",
"sources": [
{
"imported": "2025-11-20T23:04:03.217Z",
"modified": "2025-11-03T20:19:05.870Z",
"id": "CVE-2025-47917",
"url": "https://services.nvd.nist.gov/rest/json/cves/2.0?cveId=CVE-2025-47917",
"published": "2025-07-20T19:15:23.847Z",
"html_url": "https://nvd.nist.gov/vuln/detail/CVE-2025-47917"
}
]
}