Bug 2033761 (CVE-2021-4044) - CVE-2021-4044 openssl: invalid handling of X509_verify_cert() internal errors in libssl
Summary: CVE-2021-4044 openssl: invalid handling of X509_verify_cert() internal errors...
Keywords:
Status: CLOSED NOTABUG
Alias: CVE-2021-4044
Product: Security Response
Classification: Other
Component: vulnerability
Version: unspecified
Hardware: All
OS: Linux
medium
medium
Target Milestone: ---
Assignee: Red Hat Product Security
QA Contact:
URL:
Whiteboard:
Depends On: 2035148
Blocks: 2033763
TreeView+ depends on / blocked
 
Reported: 2021-12-17 19:28 UTC by Guilherme de Almeida Suckevicz
Modified: 2022-05-17 13:16 UTC (History)
38 users (show)

Fixed In Version: openssl 3.0.1
Doc Type: If docs needed, set a value
Doc Text:
A flaw was found in the way OpenSSL verified certificates via the X509_verify_cert() function. An internal error was not correctly validated causing application crashes or invalid application behavior.
Clone Of:
Environment:
Last Closed: 2022-05-17 13:16:02 UTC
Embargoed:


Attachments (Terms of Use)

Description Guilherme de Almeida Suckevicz 2021-12-17 19:28:41 UTC
Internally libssl in OpenSSL calls X509_verify_cert() on the client side to verify a certificate supplied by a server. That function may return a negative return value to indicate an internal error (for example out of memory). Such a negative return value is mishandled by OpenSSL and will cause an IO function (such as SSL_connect() or SSL_do_handshake()) to not indicate success and a subsequent call to SSL_get_error() to return the value SSL_ERROR_WANT_RETRY_VERIFY. This return value is only supposed to be returned by OpenSSL if the application has previously called SSL_CTX_set_cert_verify_callback(). Since most applications do not do this the SSL_ERROR_WANT_RETRY_VERIFY return value from SSL_get_error() will be totally unexpected and applications may not behave correctly as a result. The exact behaviour will depend on the application but it could result in crashes, infinite loops or other similar incorrect responses. This issue is made more serious in combination with a separate bug in OpenSSL 3.0 that will cause X509_verify_cert() to indicate an internal error when processing a certificate chain. This will occur where a certificate does not include the Subject Alternative Name extension but where a Certificate Authority has enforced name constraints. This issue can occur even with valid chains. By combining the two issues an attacker could induce incorrect, application dependent behaviour. Fixed in OpenSSL 3.0.1 (Affected 3.0.0).

Reference:
https://www.openssl.org/news/secadv/20211214.txt

Upstream patch:
https://git.openssl.org/gitweb/?p=openssl.git;a=commitdiff;h=758754966791c537ea95241438454aa86f91f256

Comment 4 Product Security DevOps Team 2022-05-17 13:15:58 UTC
This bug is now closed. Further updates for individual products will be reflected on the CVE page(s):

https://access.redhat.com/security/cve/cve-2021-4044


Note You need to log in before you can comment on or make changes to this bug.