CVE-2023-3817

Issue summary: Checking excessively long DH keys or parameters may be very slow.

Impact summary: Applications that use the functions DH_check(), DH_check_ex()
or EVP_PKEY_param_check() to check a DH key or DH parameters may experience long
delays. Where the key or parameters that are being checked have been obtained
from an untrusted source this may lead to a Denial of Service.

The function DH_check() performs various checks on DH parameters. After fixing
CVE-2023-3446 it was discovered that a large q parameter value can also trigger
an overly long computation during some of these checks. A correct q value,
if present, cannot be larger than the modulus p parameter, thus it is
unnecessary to perform these checks if q is larger than p.

An application that calls DH_check() and supplies a key or parameters obtained
from an untrusted source could be vulnerable to a Denial of Service attack.

The function DH_check() is itself called by a number of other OpenSSL functions.
An application calling any of those other functions may similarly be affected.
The other functions affected by this are DH_check_ex() and
EVP_PKEY_param_check().

Also vulnerable are the OpenSSL dhparam and pkeyparam command line applications
when using the "-check" option.

The OpenSSL SSL/TLS implementation is not affected by this issue.

The OpenSSL 3.0 and 3.1 FIPS providers are not affected by this issue.
ProviderTypeBase ScoreAtk. VectorAtk. ComplexityPriv. RequiredVector
NISTNIST
5.3 MEDIUM
NETWORK
LOW
NONE
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L
opensslCNA
---
---
CVEADP
---
---
CISA-ADPADP
5.3 MEDIUM
NETWORK
LOW
NONE
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L
Base Score
CVSS 3.x
EPSS Score
Percentile: 50%
VendorProductVersion
opensslopenssl
3.0.0 ≤
𝑥
< 3.0.10
opensslopenssl
3.1.0 ≤
𝑥
< 3.1.2
opensslopenssl
1.0.2
opensslopenssl
1.0.2:beta1
opensslopenssl
1.0.2:beta2
opensslopenssl
1.0.2:beta3
opensslopenssl
1.0.2a:a
opensslopenssl
1.0.2b:b
opensslopenssl
1.0.2c:c
opensslopenssl
1.0.2d:d
opensslopenssl
1.0.2e:e
opensslopenssl
1.0.2f:f
opensslopenssl
1.0.2g:g
opensslopenssl
1.0.2h:h
opensslopenssl
1.0.2i:i
opensslopenssl
1.0.2j:j
opensslopenssl
1.0.2k:k
opensslopenssl
1.0.2l:l
opensslopenssl
1.0.2m:m
opensslopenssl
1.0.2n:n
opensslopenssl
1.0.2o:o
opensslopenssl
1.0.2p:p
opensslopenssl
1.0.2q:q
opensslopenssl
1.0.2r:r
opensslopenssl
1.0.2s:s
opensslopenssl
1.0.2t:t
opensslopenssl
1.0.2u:u
opensslopenssl
1.0.2v:v
opensslopenssl
1.0.2w:w
opensslopenssl
1.0.2x:x
opensslopenssl
1.0.2y:y
opensslopenssl
1.0.2za:za
opensslopenssl
1.0.2zb:zb
opensslopenssl
1.0.2zc:zc
opensslopenssl
1.0.2zd:zd
opensslopenssl
1.0.2ze:ze
opensslopenssl
1.0.2zf:zf
opensslopenssl
1.0.2zg:zg
opensslopenssl
1.0.2zh:zh
opensslopenssl
1.1.1
opensslopenssl
1.1.1:pre1
opensslopenssl
1.1.1:pre2
opensslopenssl
1.1.1:pre3
opensslopenssl
1.1.1:pre4
opensslopenssl
1.1.1:pre5
opensslopenssl
1.1.1:pre6
opensslopenssl
1.1.1:pre7
opensslopenssl
1.1.1:pre8
opensslopenssl
1.1.1:pre9
opensslopenssl
1.1.1a:a
opensslopenssl
1.1.1b:b
opensslopenssl
1.1.1c:c
opensslopenssl
1.1.1d:d
opensslopenssl
1.1.1e:e
opensslopenssl
1.1.1f:f
opensslopenssl
1.1.1g:g
opensslopenssl
1.1.1h:h
opensslopenssl
1.1.1i:i
opensslopenssl
1.1.1j:j
opensslopenssl
1.1.1k:k
opensslopenssl
1.1.1l:l
opensslopenssl
1.1.1m:m
opensslopenssl
1.1.1n:n
opensslopenssl
1.1.1o:o
opensslopenssl
1.1.1p:p
opensslopenssl
1.1.1q:q
opensslopenssl
1.1.1r:r
opensslopenssl
1.1.1s:s
opensslopenssl
1.1.1t:t
opensslopenssl
1.1.1u:u
𝑥
= Vulnerable software versions
Debian logo
Debian Releases
Debian Product
Codename
openssl
bullseye
1.1.1w-0+deb11u1
fixed
bullseye (security)
1.1.1w-0+deb11u2
fixed
bookworm
3.0.15-1~deb12u1
fixed
bookworm (security)
3.0.14-1~deb12u2
fixed
sid
3.3.2-2
fixed
trixie
3.3.2-2
fixed
Ubuntu logo
Ubuntu Releases
Ubuntu Product
Codename
edk2
oracular
needed
noble
needed
mantic
ignored
lunar
ignored
jammy
needed
focal
needed
bionic
needs-triage
xenial
needs-triage
trusty
ignored
nodejs
oracular
not-affected
noble
not-affected
mantic
not-affected
lunar
not-affected
jammy
needed
focal
not-affected
bionic
needs-triage
xenial
needs-triage
trusty
not-affected
openssl
oracular
not-affected
noble
not-affected
mantic
not-affected
lunar
Fixed 3.0.8-1ubuntu1.4
released
jammy
Fixed 3.0.2-0ubuntu1.12
released
focal
Fixed 1.1.1f-1ubuntu2.20
released
bionic
Fixed 1.1.1-1ubuntu2.1~18.04.23+esm3
released
xenial
Fixed 1.0.2g-1ubuntu4.20+esm10
released
trusty
not-affected
openssl1.0
oracular
dne
noble
dne
mantic
dne
lunar
dne
jammy
dne
focal
dne
bionic
Fixed 1.0.2n-1ubuntu5.13+esm1
released
xenial
dne
trusty
dne