CVE-2026-41676
CRITICAL9.8EPSS 0.07%rust-openssl: Deriver::derive and PkeyCtxRef::derive can overflow short buffers on OpenSSL 1.1.1
發布日:2026/4/22修改日:2026/5/5
描述
`Deriver::derive` (and `PkeyCtxRef::derive`) sets `len = buf.len()` and passes it as the in/out length to `EVP_PKEY_derive`, relying on OpenSSL to honor it. On OpenSSL 1.1.x, X25519, X448, DH and HKDF-extract ignore the incoming `*keylen`, unconditionally writing the full shared secret (32/56/prime-size bytes). A caller passing a short slice gets a heap/stack overflow from safe code. OpenSSL 3.x providers do check, so this only impacts older OpenSSL.
受影響套件(2)
- crates.io/openssl>= 0.9.27, < 0.10.78
- Debian/rust-opensslfrom 0
CVSS 分數
| 來源 | 版本 | 嚴重程度 | 向量 |
|---|---|---|---|
| osv | CVSS 4.0 | — | CVSS:4.0/AV:N/AC:L/AT:P/PR:N/UI:N/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N/E:U |
| osv | CVSS 3.1 | CRITICAL9.8 | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H |
參考連結(7)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2026-41676
- ADVISORYhttps://security-tracker.debian.org/tracker/CVE-2026-41676
- PATCHhttps://github.com/rust-openssl/rust-openssl
- WEBhttps://github.com/rust-openssl/rust-openssl/commit/09b425e5f59a2466d806e71a83a9a449c914c596
- WEBhttps://github.com/rust-openssl/rust-openssl/pull/2606
- WEBhttps://github.com/rust-openssl/rust-openssl/releases/tag/openssl-v0.10.78
- WEBhttps://github.com/rust-openssl/rust-openssl/security/advisories/GHSA-pqf5-4pqq-29f5