Vulnerability Description
Starting from Rust 1.87.0 and before Rust 1.89.0, the tier 3 Cygwin target (`x86_64-pc-cygwin`) didn't correctly handle path separators, causing the standard library's Path API to ignore path components separated by backslashes. Due to this, programs compiled for Cygwin that validate paths could misbehave, potentially allowing path traversal attacks or malicious filesystem operations. Rust 1.89.0 fixes the issue by handling both Win32 and Unix style paths in the standard library for the Cygwin target. While we assess the severity of this vulnerability as "medium", please note that the tier 3 Cygwin compilation target is only available when building it from source: no pre-built binaries are distributed by the Rust project, and it cannot be installed through Rustup. Unless you manually compiled the `x86_64-pc-cygwin` target you are not affected by this vulnerability. Users of the tier 1 MinGW target (`x86_64-pc-windows-gnu`) are also explicitly not affected.
Related Weaknesses (CWE)
References
- https://github.com/rust-lang/rust/pull/141864
- https://groups.google.com/g/rustlang-security-announcements/c/oT9zCvLLYkw
FAQ
What is CVE-2025-11233?
CVE-2025-11233 is a documented vulnerability. Starting from Rust 1.87.0 and before Rust 1.89.0, the tier 3 Cygwin target (`x86_64-pc-cygwin`) didn't correctly handle path separators, causing the standard library's Path API to ignore path componen...
How severe is CVE-2025-11233?
CVSS scoring is not yet available for CVE-2025-11233. Check NVD for updates.
Is there a patch for CVE-2025-11233?
Check the references section above for vendor advisories and patch information. Review vendor security bulletins for remediation guidance.