CVE-2026-41676

critical
Published 2026-04-24 · Modified 2026-05-05
CVSS v3
9.8
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
CVSS v2
VIR risk
9.8

Description

rust-openssl provides OpenSSL bindings for the Rust programming language. From 0.9.27 to before 0.10.78, 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. This vulnerability is fixed in 0.10.78.

Predictions

Exploit likelihood
97%
Patch ETA

Heuristic predictions, AS-IS, for prioritization only.

Mitigations

vendor Authored 2026-05-27

Vendor advisory: debian — https://security-tracker.debian.org/tracker/CVE-2026-41676

vendor Authored 2026-05-27

Vendor advisory: security-advisories@github.com — https://github.com/rust-openssl/rust-openssl/security/advisories/GHSA-pqf5-4pqq-29f5

OS impact

OSVersionStatusFixed in
debian debianbookwormaffected
debian debianbullseyeaffected
debian debianforkyaffected
debian debiansidfixed0.10.78-1
debian debiantrixieaffected

Package impact

EcosystemPackageVulnerableFixed
rust crates.ioopenssl>=0.9.27,<0.10.780.10.78

Application impact

VendorProductVersionsFixed
rust-openssl_projectrust-openssl{"startIncluding":"0.9.27","endExcluding":"0.10.78"}0.10.78

References

CWEs

CWE-131 CWE-787

Verify integrity in audit chain (admin only). AS-IS.