CVE-2025-47917
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 mbedtls_x509_string_to_names() 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 mbedtls_asn1_free_named_data_list() 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/cert_write and x509/cert_req are affected (use-after-free if the san string contains more than one DN).
EPSS 8.43% · 92.5th percentile
Risk Scores
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| arm | mbed_tls | 0 |
| Mbed | mbedtls | 0 |
| mbed | mbedtls | 0 |
Timeline
- Jul 20, 2025 CVE Published
- Jul 20, 2025 PoC Published
- Jul 21, 2025 EPSS Score
- Jul 30, 2025 EPSS Score
- Aug 8, 2025 EPSS Score
- Aug 26, 2025 EPSS Score
- Sep 4, 2025 EPSS Score
- Sep 13, 2025 EPSS Score
- Sep 17, 2025 EPSS Score
- Sep 17, 2025 PoC Published
- Sep 22, 2025 EPSS Score
- Oct 10, 2025 EPSS Score
References
- https://mbed-tls.readthedocs.io/en/latest/tech-updates/security-advisories/ url
- https://github.com/Mbed-TLS/mbedtls-docs/blob/main/security-advisories/mbedtls-security-advisory-2025-06-7.md url
- https://lists.debian.org/debian-lts-announce/2025/08/msg00025.html url
- https://lists.debian.org/debian-lts-announce/2025/08/msg00013.html url
- https://nvd.nist.gov/vuln/detail/CVE-2025-47917 advisory
- https://mbed-tls.readthedocs.io/en/latest/tech-updates/security-advisories url