Comparison of TLS implementations

{{Short description|none}}

{{About|TLS libraries comparison|cryptographic libraries comparison|Comparison of cryptography libraries}}

{{redirect|Secure Transport|the transportation of valuables|Armored car (valuables)}}

The Transport Layer Security (TLS) protocol provides the ability to secure communications across or inside networks. This comparison of TLS implementations compares several of the most notable libraries. There are several TLS implementations which are free software and open source.

All comparison categories use the stable version of each implementation listed in the overview section. The comparison is limited to features that directly relate to the TLS protocol.

Overview

{{sort-under}}

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! Developed by

! Open source

! Software license

! Copyright holder

! Written in

! Latest stable version, release date

! Origin

Botan

| Jack Lloyd

| {{yes}}

| {{free|Simplified BSD License}}

| Jack Lloyd

| C++

| {{Latest stable software release/Botan}}

| US (Vermont)

BoringSSL

| Google

| {{yes}}

| {{free|OpenSSL-SSLeay dual-license, ISC license}}

| Eric Young, Tim Hudson, Sun, OpenSSL project, Google, and others

| C, C++, Go, assembly

| ??

| Australia/EU

Bouncy Castle

| The Legion of the Bouncy Castle Inc.

| {{Yes}}

| {{free|MIT License}}

| Legion of the Bouncy Castle Inc.

| Java, C#

| {{Latest stable software release/Bouncy Castle}}

| Australia

BSAFE

| Dell, formerly RSA Security

| {{no}}

| {{proprietary}}

| Dell

| Java, C, assembly

| SSL-J {{Latest stable software release/BSAFE SSL-J}}

Micro Edition Suite {{Latest stable software release/BSAFE Micro Edition Suite}}

| Australia

cryptlib

| Peter Gutmann

| {{yes}}

| {{free|Sleepycat License}} and commercial license

| Peter Gutmann

| C

| {{Latest stable software release/cryptlib}}

| NZ

GnuTLS

| GnuTLS project

| {{yes}}

| {{free|LGPL-2.1-or-later}}

| Free Software Foundation

| C

| {{wikidata|property|preferred|references|edit|Q1533305|P348|P548=Q2804309}} {{wikidata|qualifier|raw|preferred|single|Q1533305|P348|P548=Q2804309|P577}}

| EU (Greece and Sweden)

Java Secure Socket Extension (JSSE)

| Oracle

| {{Yes}}

| {{free|GNU GPLv2}} and commercial license

| Oracle

| Java

| {{Latest stable software release/Java (software platform)}}

| US

LibreSSL

| OpenBSD Project

| {{yes}}

| {{free|Apache-1.0, BSD-4-Clause, ISC, and public domain}}

| Eric Young, Tim Hudson, Sun, OpenSSL project, OpenBSD Project, and others

| C, assembly

| {{wikidata|property|preferred|references|edit|Q16590706|P348|P548=Q2804309}} {{wikidata|qualifier|raw|preferred|single|Q16590706|P348|P548=Q2804309|P577}}

| Canada

MatrixSSLThe features listed are for the closed source version

| PeerSec Networks

| {{yes}}

| {{free|GNU GPLv2+}} and commercial license

| PeerSec Networks

| C

| {{Latest stable software release/MatrixSSL}}

| US

Mbed TLS (previously PolarSSL)

| Arm

| {{yes}}

| {{free|Apache License 2.0, GNU GPLv2+}} and commercial license

| Arm Holdings

| C

| {{Latest stable software release/Mbed TLS}}

| EU (Netherlands)

Network Security Services (NSS)

| Mozilla, AOL, Red Hat, Sun, Oracle, Google and others

| {{yes}}

| {{free|MPL 2.0}}

| NSS contributors

| C, assembly

| {{Latest stable software release/Network Security Services}}

| US

OpenSSL

| OpenSSL project

| {{yes}}

| {{free|Apache-2.0}}

| Eric Young, Tim Hudson, Sun, OpenSSL project, and others

| C, assembly

| {{wikidata|property|preferred|references|edit|Q1052790|P348|P548=Q2804309}} {{wikidata|qualifier|raw|preferred|single|Q1052790|P348|P548=Q2804309|P577}}

| Australia/EU

Rustls

| Joe Birr-Pixton, Dirkjan Ochtman, Daniel McCarney, Josh Aas, and open source contributors

| {{yes}}

| {{free|Apache-2.0, MIT License and ISC}}

| Open source contributors

| Rust

| {{Latest stable software release/Rustls}}

| United Kingdom

s2n

| Amazon

| {{yes}}

| {{free|Apache License 2.0, GNU GPLv2+}} and commercial license

| Amazon.com, Inc.

| C

| Continuous

| US

Schannel

| Microsoft

| {{no}}

| {{proprietary}}

| Microsoft Corporation

|

| Windows 11, 2021-10-05

| US

Secure Transport

| Apple Inc.

| {{Yes}}

| {{free|APSL 2.0}}

| Apple Inc.

|

| 57337.20.44 (OS X 10.11.2), 2015-12-08

| US

wolfSSL (previously CyaSSL)

| wolfSSL{{cite web | url=https://www.wolfssl.com/wolfSSL/Products-wolfssl.html | title=wolfSSL product description | accessdate=2016-05-03}}

| {{yes}}

| {{free|GNU GPLv2+}} and commercial license

| wolfSSL Inc.{{cite web | url=https://www.wolfssl.com | title=wolfSSL Embedded SSL/TLS | accessdate=2016-05-03}}

| C, assembly

| {{Latest stable software release/wolfSSL}}

| US

Erlang/OTP SSL application

| Ericsson

| {{yes}}

| {{free|Apache License 2.0}}

| Ericsson

|Erlang

|OTP-21, 2018-06-19

|Sweden

class="sortbottom"

! Implementation

! Developed by

! Open source

! Software license

! Copyright owner

! Written in

! Latest stable version, release date

! Origin

{{Reflist|group=lower-alpha|refs=

Apache-2.0 for OpenSSL 3.0 and later releases. OpenSSL-SSLeay dual-license for any release before OpenSSL 3.0.

}}

<span class="anchor" id="TLS version support"></span>TLS/SSL protocol version support

Several versions of the TLS protocol exist. SSL 2.0 is a deprecated{{cite IETF |rfc=6176 |title=Prohibiting Secure Sockets Layer (SSL) Version 2.0}} protocol version with significant weaknesses. SSL 3.0 (1996) and TLS 1.0 (1999) are successors with two weaknesses in CBC-padding that were explained in 2001 by Serge Vaudenay.{{cite web|url=http://infoscience.epfl.ch/record/52417/files/IC_TECH_REPORT_200150.pdf|title=CBC-Padding: Security Flaws in SSL, IPsec, WTLS,...|first=Serge|last=Vaudenay|date=2001}} TLS 1.1 (2006) fixed only one of the problems, by switching to random initialization vectors (IV) for CBC block ciphers, whereas the more problematic use of mac-pad-encrypt instead of the secure pad-mac-encrypt was addressed with RFC 7366.{{cite IETF |rfc=7366 |title=Encrypt-then-MAC for Transport Layer Security (TLS) and Datagram Transport Layer Security}} A workaround for SSL 3.0 and TLS 1.0, roughly equivalent to random IVs from TLS 1.1, was widely adopted by many implementations in late 2011.{{cite web|url=https://www.educatedguesswork.org/2011/11/rizzoduong_beast_countermeasur.html|title=Rizzo/Duong BEAST Countermeasures|archive-url=https://web.archive.org/web/20160311153448/https://educatedguesswork.org/2011/11/rizzoduong_beast_countermeasur.html|archive-date=2016-03-11|url-status=dead}} In 2014, the POODLE vulnerability of SSL 3.0 was discovered, which takes advantage of the known vulnerabilities in CBC, and an insecure fallback negotiation used in browsers.{{cite web | url=https://www.openssl.org/~bodo/ssl-poodle.pdf | title=This POODLE Bites: Exploiting The SSL 3.0 Fallback | date=September 2014 | access-date=15 October 2014 |last1=Möller |first1=Bodo |last2=Duong |first2=Thai |last3=Kotowicz |first3=Krzysztof | archive-url=https://web.archive.org/web/20141015204410/https://www.openssl.org/~bodo/ssl-poodle.pdf | archive-date=15 October 2014 | url-status=dead}}

TLS 1.2 (2008) introduced a means to identify the hash used for digital signatures. While permitting the use of stronger hash functions for digital signatures in the future (rsa,sha256/sha384/sha512) over the SSL 3.0 conservative choice (rsa,sha1+md5), the TLS 1.2 protocol change inadvertently and substantially weakened the default digital signatures and provides (rsa,sha1) and even (rsa,md5).{{cite IETF |rfc=5246 |title=The Transport Layer Security (TLS) Protocol Version 1.2 |section=1.2 |sectionname=TLSv1.2's Major Differences from TLSv1.1}}

Datagram Transport Layer Security (DTLS or Datagram TLS) 1.0 is a modification of TLS 1.1 for a packet-oriented transport layer, where packet loss and packet reordering have to be tolerated. The revision DTLS 1.2 based on TLS 1.2 was published in January 2012.{{Cite IETF |rfc=6347}}

TLS 1.3 (2018) specified in RFC 8446 includes major optimizations and security improvements. QUIC (2021) specified in RFC 9000 and DTLS 1.3 (2022) specified in RFC 9147 builds on TLS 1.3. The publishing of TLS 1.3 and DTLS 1.3 obsoleted TLS 1.2 and DTLS 1.2.

Note that there are known vulnerabilities in SSL 2.0 and SSL 3.0. In 2021, IETF published RFC 8996 also forbidding negotiation of TLS 1.0, TLS 1.1, and DTLS 1.0 due to known vulnerabilities. NIST SP 800-52 requires support of TLS 1.3 by January 2024. Support of TLS 1.3 means that two compliant nodes will never negotiate TLS 1.2.

class="wikitable sortable sort-under mw-collapsible" style="text-align: left; font-size: smaller"
Implementation

! SSL 2.0 (insecure){{cite IETF|draft=draft-hickman-netscape-ssl-00|title=The SSL Protocol|date=19 April 1995|last1=Elgamal|first1=Taher|last2=Hickman|first2=Kipp E. B.}}

! SSL 3.0 (insecure){{cite IETF|rfc=6101}}

! TLS 1.0 (deprecated){{cite IETF|rfc=2246}}

! TLS 1.1 (deprecated){{cite IETF|rfc=4346}}

! TLS 1.2

! TLS 1.3

! DTLS 1.0 (deprecated){{cite IETF|rfc=4347}}

! DTLS 1.2

Botan

| {{yes|No}}

| {{yes|No}}{{cite web|url=http://botan.randombit.net/relnotes/1_11_13.html|title=Version 1.11.13, 2015-01-11 — Botan|date=2015-01-11|accessdate=2015-01-16|url-status=dead|archiveurl=https://web.archive.org/web/20150109154102/http://botan.randombit.net/relnotes/1_11_13.html|archivedate=2015-01-09}}

| {{yes|No}}

| {{yes|No}}

| {{yes}}

| {{yes}}

| {{yes|No}}

| {{yes}}

BoringSSL

|

|

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

Bouncy Castle

| {{Yes|No}}

| {{Yes|No}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{Partial|Yes}}
(draft version)

| {{okay|Yes}}

| {{yes}}

BSAFE SSL-J{{cite web| title = RSA BSAFE Technical Specification Comparison Tables| url = http://www.emc.com/collateral/data-sheet/11433-bsafe-tech-table.pdf| access-date = 2015-01-09| archive-url = https://web.archive.org/web/20150924043531/http://www.emc.com/collateral/data-sheet/11433-bsafe-tech-table.pdf| archive-date = 2015-09-24| url-status = dead}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|No}}

| {{yes|No}}

| {{yes}}

| {{yes}}

| {{yes|No}}

| {{no}}

cryptlib

| {{yes|No}}

| {{yes|Disabled by default at compile time}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

|

| {{yes|No}}

| {{no}}

GnuTLS

| {{yes|No}}

| {{yes|Disabled by default}}{{cite web|url=http://lists.gnutls.org/pipermail/gnutls-devel/2015-April/007535.html|title=[gnutls-devel] GnuTLS 3.4.0 released|date=2015-04-08|accessdate=2015-04-16}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes|Yes}}{{cite web|url=https://lists.gnupg.org/pipermail/gnutls-devel/2018-July/008584.html|title=[gnutls-devel] GnuTLS 3.6.3| date=2018-07-16|accessdate=2018-09-16}}

| {{okay|Yes}}

| {{yes}}

JSSE

| {{yes|No}}

| {{Yes|Disabled by default}}{{cite web|url=https://www.oracle.com/java/technologies/javase/8u31-relnotes.html|title=Java SE Development Kit 8, Update 31 Release Notes|access-date=2024-01-14}}

| {{Yes|Disabled by default}}{{cite web|url=https://bugs.openjdk.org/browse/JDK-8256490|title=Release Note: Disable TLS 1.0 and 1.1|accessdate=2024-01-14}}

| {{Yes|Disabled by default}}

| {{yes}}

| {{yes|Yes}}

| {{okay|Yes}}

| {{yes}}

LibreSSL

| {{yes|No}}{{cite web|url=https://marc.info/?l=openbsd-announce&m=141486254309079|title=OpenBSD 5.6 Released|date=2014-11-01|accessdate=2015-01-20}}

| {{yes|No}}{{cite web| title = LibreSSL 2.3.0 Released| url = https://marc.info/?l=openbsd-announce&m=144304330731220| date = 2015-09-23| accessdate = 2015-09-24}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}{{cite web| title = LibreSSL 3.3.3 Released| url = https://marc.info/?l=openbsd-announce&m=162009196519308| date = 2021-05-04| accessdate = 2021-05-04}}

MatrixSSL

| {{yes|No}}

| {{yes|Disabled by default at compile time}}{{cite web|url=http://www.matrixssl.org/news.html|title=MatrixSSL - News|accessdate=2014-11-09|url-status=dead|archiveurl=https://web.archive.org/web/20150214105056/http://www.matrixssl.org/news.html|archivedate=2015-02-14}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

Mbed TLS

| {{yes|No}}

| {{yes|No}}{{cite web | title = Mbed TLS 3.0.0 branch released | website = GitHub | url = https://github.com/ARMmbed/mbedtls/blob/93a3ca6caf20e0e1a90c86ee2fc03e9f1fb4ebfa/ChangeLog | date = 2021-07-07 | accessdate = 2021-08-13}}

| {{yes|No}}

| {{yes|No}}

| {{yes}}

| {{Partial|Yes}}
(experimental)

| {{okay|Yes}}{{cite web | title = mbed TLS 2.0.0 released | url = https://tls.mbed.org/tech-updates/releases/mbedtls-2.0.0-released | date = 2015-07-10 | accessdate = 2015-07-14}}

| {{yes}}

NSS

| {{yes|No}}

| {{yes|Disabled by default}}{{cite web|url=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.19_release_notes|work=Mozilla Developer Network|title=NSS 3.19 release notes|publisher=Mozilla|accessdate=2015-05-06|archive-date=2015-06-05|archive-url=https://web.archive.org/web/20150605054647/https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.19_release_notes|url-status=dead}}

| {{okay|Yes}}

| {{okay|Yes}}{{cite web|url=https://developer.mozilla.org/en-US/docs/NSS/NSS_3.14_release_notes|work=Mozilla Developer Network|title=NSS 3.14 release notes|publisher=Mozilla|accessdate=2012-10-27|archive-date=2013-01-17|archive-url=https://web.archive.org/web/20130117130029/https://developer.mozilla.org/en-US/docs/NSS/NSS_3.14_release_notes|url-status=dead}}

| {{yes}}{{cite web|url=https://developer.mozilla.org/en-US/docs/NSS/NSS_3.15.1_release_notes|work=Mozilla Developer Network|title=NSS 3.15.1 release notes|publisher=Mozilla|accessdate=2013-08-10}}

| {{yes}}{{cite web| url=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.39_release_notes#Notable_Changes_in_NSS_3.39| title=NSS 3.39 release notes| date=2018-08-31| work=Mozilla Developer Network| publisher=Mozilla| accessdate=2018-09-15| archive-date=2021-12-07| archive-url=https://web.archive.org/web/20211207014212/https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.39_release_notes#Notable_Changes_in_NSS_3.39| url-status=dead}}

| {{okay|Yes}}

| {{yes}}{{cite web| url=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.16.2_release_notes| title=NSS 3.16.2 release notes| date=2014-06-30| work=Mozilla Developer Network| publisher=Mozilla| accessdate=2014-06-30| archive-date=2021-12-07| archive-url=https://web.archive.org/web/20211207015257/https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.16.2_release_notes| url-status=dead}}

OpenSSL

| {{Yes|No}}

| {{yes|Disabled by default}}

| {{okay|Yes}}

| {{okay|Yes}}{{cite web|title=Major changes between OpenSSL 1.0.0h and OpenSSL 1.0.1 [14 Mar 2012] |url=https://www.openssl.org/news/openssl-1.0.1-notes.html |date=2012-03-14 |accessdate=2015-01-20 |url-status=dead |archiveurl=https://web.archive.org/web/20141205180836/http://www.openssl.org/news/openssl-1.0.1-notes.html |archivedate=December 5, 2014 }}

| {{yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}{{cite web|url=https://www.openssl.org/news/openssl-1.0.2-notes.html |title=Major changes between OpenSSL 1.0.1l and OpenSSL 1.0.2 [22 Jan 2015] |accessdate=2015-01-22 |url-status=dead |archiveurl=https://web.archive.org/web/20140904045720/http://www.openssl.org/news/openssl-1.0.2-notes.html |archivedate=September 4, 2014 }}

Rustls

| {{yes|No}}{{cite web|url=https://docs.rs/rustls/0.23.12/rustls/manual/_04_features/index.html |title=rustls implemented and unimplemented features documentation |accessdate=2024-08-28 }}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes}}

| {{yes}}

| {{yes|No}}

| {{no}}

s2n{{cite web| title = S2N Readme| website = GitHub| url = https://github.com/awslabs/s2n/blob/master/README.md| date = 2019-12-21}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes}}

| {{yes|No}}

| {{no}}

Schannel XP, 2003{{cite web|url=http://msdn.microsoft.com/en-us/library/aa380512.aspx|title=TLS Cipher Suites (Windows)|website=msdn.microsoft.com|date=14 July 2023 }}

| {{partial|Disabled by default in MSIE 7}}

| {{No|Enabled by default}}

| {{partial|Enabled by default in MSIE 7}}

| {{yes|No}}

| {{no}}

| {{No}}

| {{yes|No}}

| {{no}}

Schannel Vista{{cite web|url=http://msdn.microsoft.com/en-us/library/ff468651.aspx|title=TLS Cipher Suites in Windows Vista (Windows)|website=msdn.microsoft.com|date=25 October 2021 }}

| {{yes|Disabled by default}}

| {{No|Enabled by default}}

| {{okay|Yes}}

| {{yes|No}}

| {{no}}

| {{No}}

| {{yes|No}}

| {{no}}

Schannel 2008

| {{yes|Disabled by default}}

| {{No|Enabled by default}}

| {{okay|Yes}}

| {{Partial|Disabled by default (KB4019276)}}

| {{Partial|Disabled by default (KB4019276)}}

| {{No}}

| {{yes|No}}

| {{no}}

Schannel 7, 2008R2{{cite web|url=http://msdn.microsoft.com/en-us/library/aa374757.aspx|title=Cipher Suites in TLS/SSL (Schannel SSP) (Windows)|website=msdn.microsoft.com|date=14 July 2023 }}

| {{Yes|Disabled by default}}

| {{partial|Disabled by default in MSIE 11}}

| {{okay|Yes}}

| {{partial|Enabled by default in MSIE 11}}

| {{partial|Enabled by default in MSIE 11}}

| {{No}}

| {{okay|Yes}}{{cite web|title=An update is available that adds support for DTLS in Windows 7 SP1 and Windows Server 2008 R2 SP1|url=http://support.microsoft.com/kb/2574819/en-us|publisher=Microsoft|accessdate=13 November 2012}}

| {{no}}

Schannel 8, 2012

| {{Yes|Disabled by default}}

| {{No|Enabled by default}}

| {{okay|Yes}}

| {{partial|Disabled by default}}

| {{partial|Disabled by default}}

| {{No}}

| {{okay|Yes}}

| {{no}}

Schannel 8.1, 2012R2, 10 RTM & v1511

| {{Yes|Disabled by default}}

| {{partial|Disabled by default in MSIE 11}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No}}

| {{okay|Yes}}

| {{no}}

Schannel 10 v1607 / 2016{{Cite web |date=2022-05-25 |url=https://learn.microsoft.com/en-us/windows/win32/secauthn/protocols-in-tls-ssl--schannel-ssp- |title=Protocols in TLS/SSL (Schannel SSP) |publisher=Microsoft |accessdate=2023-11-18}}

| {{Yes|No}}

| {{Yes|Disabled by default}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No}}

| {{okay|Yes}}

| {{yes}}

Schannel 11 / 2022{{cite web |title=Protocols in TLS/SSL (Schannel SSP) |date=25 May 2022 |url=https://learn.microsoft.com/en-us/windows/win32/secauthn/protocols-in-tls-ssl--schannel-ssp- |access-date=6 November 2022}}

| {{Yes|No}}

| {{Yes|Disabled by default}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

Secure Transport

OS X 10.2-10.7, iOS 1-4

| {{No|Yes}}

| {{No|Yes}}

| {{okay|Yes}}

| {{yes|No}}

| {{no}}

|

| {{yes|No}}

| {{no}}

Secure Transport OS X 10.8-10.10, iOS 5-8

| {{Yes|No}}

| {{No|Yes}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

|

| {{okay|Yes}}

| {{no}}

Secure Transport OS X 10.11, iOS 9

| {{Yes|No}}

| {{Yes|No}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

|

| {{okay|Yes}}

| {{Unknown}}

Secure Transport OS X 10.13, iOS 11

| {{Yes|No}}

| {{Yes|No}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{Partial|Yes}}
(draft version){{cite web|url=https://twitter.com/bagder/status/972234259774820352|title=@badger: the 1.3 stuff is apparently in iOS 11 and macOS 10.13.|date=2018-03-09|accessdate=2018-03-09}}

| {{okay|Yes}}

| {{Unknown}}

wolfSSL

| {{yes|No}}

| {{yes|Disabled by default}}{{cite web|url=http://wolfssl.com/wolfSSL/Blog/Entries/2015/8/24_wolfSSL_3.6.6_is_Now_Available.html|title=[wolfssl] wolfSSL 3.6.6 Released|date=2015-08-20|accessdate=2015-08-24}}

| {{yes|Disabled by default}}{{cite web|url=https://www.wolfssl.com/wolfssl-3-13-0-now-available/|title=[wolfssl] wolfSSL 3.13.0 Released|date=2017-12-21|accessdate=2022-01-17}}

| {{okay|Yes}}

| {{yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

Erlang/OTP SSL application{{cite web|url=https://www.erlang.org/doc/apps/ssl/standards_compliance.html|title=Erlang -- Standards Compliance}}

| {{yes|No}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes}}

| {{okay|Partially}} {{cite web|url=https://www.erlang.org/doc/apps/ssl/standards_compliance.html#tls-1.3|title=Erlang OTP SSL application TLS 1.3 compliance table}}

| {{yes|Disabled by default}}

| {{yes}}

class="sortbottom"

! Implementation

! SSL 2.0 (insecure)

! SSL 3.0 (insecure)

! TLS 1.0 (deprecated)

! TLS 1.1 (deprecated)

! TLS 1.2

! TLS 1.3

! DTLS 1.0 (deprecated)

! DTLS 1.2

{{Reflist|group=lower-alpha|refs=

SSL 2.0 client hello is supported for backward compatibility reasons even though SSL 2.0 is not supported.

Server-side implementation of the SSL/TLS protocol still supports processing of received v2-compatible client hello messages.{{cite web|url=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.24_release_notes|work=Mozilla Developer Network|title=NSS 3.24 release notes|publisher=Mozilla|accessdate=2016-06-19|archive-date=2016-08-26|archive-url=https://web.archive.org/web/20160826100711/https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.24_release_notes|url-status=dead}}

Secure Transport: SSL 2.0 was discontinued in OS X 10.8. SSL 3.0 was discontinued in OS X 10.11 and iOS 9.TLS 1.1, 1.2 and DTLS are available on iOS 5.0 and later, and OS X 10.9 and later.{{cite web|url=https://developer.apple.com/library/ios/technotes/tn2287/|work=iOS Developer Library|title=Technical Note TN2287: iOS 5 and TLS 1.2 Interoperability Issues|publisher=Apple Inc.|accessdate=2012-05-03}}

As of SSL-J 7.0, support for TLS 1.0 and 1.1 has been removed

Since OTP 22

Since OTP 23

}}

NSA Suite B Cryptography

Required components for NSA Suite B Cryptography (RFC 6460) are:

Per CNSSP-15, the 256-bit elliptic curve (specified in FIPS 186-2), SHA-256, and AES with 128-bit keys are sufficient for protecting classified information up to the Secret level, while the 384-bit elliptic curve (specified in FIPS 186-2), SHA-384, and AES with 256-bit keys are necessary for the protection of Top Secret information.

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! TLS 1.2 Suite B

Botan

| {{yes}}

Bouncy Castle

| {{yes}}

BSAFE

| {{yes}}

cryptlib

| {{yes}}

GnuTLS

| {{yes}}

JSSE

| {{yes}}{{cite web|url=http://docs.oracle.com/javase/8/docs/technotes/guides/security/enhancements-8.html|title=Security Enhancements in JDK 8|website=docs.oracle.com}}

LibreSSL

| {{yes}}

MatrixSSL

| {{yes}}

Mbed TLS

| {{yes}}

NSS

| {{no}}{{cite web |url=https://bugzilla.mozilla.org/show_bug.cgi?id=663320 |title=Bug 663320 - (NSA-Suite-B-TLS) Implement RFC6460 (NSA Suite B profile for TLS) |publisher=Mozilla |accessdate=2014-05-19}}

OpenSSL

| {{yes}}

Rustls

| {{yes}}

S2n

|

Schannel

| {{yes}}{{Cite web | url=https://learn.microsoft.com/en-us/previous-versions/windows/it-pro/windows-server-2008-R2-and-2008/dd566200(v=ws.10) |title = Introducing Compliance to Suite B Cryptography| date=18 September 2012 }}

Secure Transport

| {{no}}

wolfSSL

| {{yes}}

class="sortbottom"

! Implementation

! TLS 1.2 Suite B

Certifications

Note that certain certifications have received serious negative criticism from people who are actually involved in them.{{Cite web|url=http://index.html/|archiveurl=https://web.archive.org/web/20131227190128/http://veridicalsystems.com/blog/secure-or-compliant-pick-one/|url-status=dead|title=Speeds and Feeds › Secure or Compliant, Pick One|archivedate=December 27, 2013}}

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
rowspan="2"|Implementation

! colspan="2"|FIPS 140-1, FIPS 140-2{{cite web|url=http://csrc.nist.gov/groups/STM/cmvp/documents/140-1/140val-all.htm|title=Search - Cryptographic Module Validation Program - CSRC|website=csrc.nist.gov|access-date=2014-03-18|archive-url=https://web.archive.org/web/20141226152243/http://csrc.nist.gov/groups/STM/cmvp/documents/140-1/140val-all.htm|archive-date=2014-12-26|url-status=dead}}

! FIPS 140-3

Level 1

! Level 2{{Disputed inline|FIPS140-2|date=January 2015}}

! Level 1

Botan{{cite web|url=http://botan.randombit.net/faq.html?highlight=fips#is-botan-fips-140-certified|title="Is botan FIPS 140 certified?" Frequently Asked Questions — Botan|access-date=2014-11-16|archive-url=https://web.archive.org/web/20141129042131/http://botan.randombit.net/faq.html?highlight=fips#is-botan-fips-140-certified|archive-date=2014-11-29|url-status=dead}}

|

|

|

Bouncy Castle

|{{yes|BC-FJA 1.0.0 (#2768)
BC-FJA 1.0.1 (#3152)}}

|

|

BSAFE SSL-J{{cite web|url=https://csrc.nist.gov/projects/cryptographic-module-validation-program/validated-modules/search|title=Search - Cryptographic Module Validation Program - CSRC|website=csrc.nist.gov|date=11 October 2016}}

| {{yes|Crypto-J 6.0 ([https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/1785 1785], [https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/1786 1786])
Crypto-J 6.1 / 6.1.1.0.1 ([https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/2057 2057], [https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/2058 2058])
Crypto-J 6.2 / 6.2.1.1 ([https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/2468 2468], [https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/2469 2469])
Crypto-J 6.2.4 ([https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/3172 3172], [https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/3184 3184])
Crypto-J 6.2.5 ([https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/3819 #3819], [https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/3820 #3820])
Crypto-J 6.3 ([https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/4696 #4696], [https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/4697 #4697])}}

|

|{{yes|Crypto-J 7.0 ([https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/4892 4892])}}

cryptlib{{cite web|url=http://www.cs.auckland.ac.nz/~pgut001/cryptlib/faq.html#Q8|archive-url=https://web.archive.org/web/20131011085917/http://www.cs.auckland.ac.nz/~pgut001/cryptlib/faq.html#Q8|url-status=dead|archive-date=11 October 2013|title=cryptlib|date=11 October 2013}}

|

|

|

GnuTLS{{cite web |title=B.5 Certification |url=https://www.gnutls.org/manual/gnutls.html#Certification |website=GnuTLS 3.7.7 |access-date=26 September 2022}}

| {{yes|Red Hat Enterprise Linux GnuTLS Cryptographic Module (#2780)}}

|

|

JSSE

|

|

|

LibreSSL

| no support

|

|

MatrixSSL{{cite web|url=http://cdn2.hubspot.net/hub/327778/file-618993629-pdf/Matrix+SSL-3.pdf|title=Matrix SSL Toolkit|publisher=}}

| {{yes|SafeZone FIPS Cryptographic Module: 1.1 (#2389)}}

|

|

Mbed TLS{{cite web|url=https://mbed-tls.readthedocs.io/en/latest/kb/generic/is-mbedtls-fips-certified/|title=Is mbed TLS FIPS certified? - Mbed TLS documentation|website=Mbed TLS documentation}}

|

|

|

NSS{{cite web|url=https://wiki.mozilla.org/FIPS_Validation|title=FIPS Validation - MozillaWiki|website=wiki.mozilla.org}}

| {{yes|Network Security Services: 3.2.2 (#247)
Network Security Services Cryptographic Module: 3.11.4 (#815), 3.12.4 (#1278), 3.12.9.1 (#1837)}}

| {{yes|Netscape Security Module: 1 (#7with Sun Sparc 5 w/ Sun Solaris v 2.4SE (ITSEC-rated)), 1.01 (#47with Sun Ultra-5 w/ Sun Trusted Solaris version 2.5.1 (ITSEC-rated))
Network Security Services: 3.2.2 (#248with Solaris v8.0 with AdminSuite 3.0.1 as specified in UK IT SEC CC Report No. P148 EAL4 on a SUN SPARC Ultra-1)
Network Security Services Cryptographic Module: 3.11.4 (#814with these platforms; Red Hat Enterprise Linux Version 4 Update 1 AS on IBM xSeries 336 with Intel Xeon CPU, Trusted Solaris 8 4/01 on Sun Blade 2500 Workstation with UltraSPARC IIIi CPU), 3.12.4 (#1279, #1280with these platforms; Red Hat Enterprise Linux v5 running on an IBM System x3550, Red Hat Enterprise Linux v5 running on an HP ProLiant DL145, Sun Solaris 10 5/08 running on a Sun SunBlade 2000 workstation, Sun Solaris 10 5/08 running on a Sun W2100z workstation)}}

|

OpenSSL{{cite web|url=https://www.openssl.org/docs/fips/fipsnotes.html|title=OpenSSL and FIPS 140-2|access-date=2014-11-15|archive-url=https://web.archive.org/web/20130528170840/http://www.openssl.org/docs/fips/fipsnotes.html|archive-date=2013-05-28|url-status=dead}}

| {{yes|OpenSSL FIPS Object Module: 1.0 (#624), 1.1.1 (#733), 1.1.2 (#918), 1.2, 1.2.1, 1.2.2, 1.2.3 or 1.2.4 (#1051)
2.0, 2.0.1, 2.0.2, 2.0.3, 2.0.4, 2.0.5, 2.0.6, 2.0.7 or 2.0.8 (#1747)}}

|

|

Rustls

|

|

| {{yes|aws-lc FIPS module{{cite web|url=https://docs.rs/rustls/0.23.12/rustls/manual/_06_fips/index.html|title=rustls FIPS documentation|accessdate=2024-08-28}} ([https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/4759 #4759])}}

Schannel{{Cite web|url=https://technet.microsoft.com/en-us/library/security/cc750357.aspx#_Microsoft_FIPS_140|title=Microsoft FIPS 140 Validated Cryptographic Modules}}

| {{yes|Cryptographic modules in Windows NT 4.0, 95, 95, 2000, XP, Server 2003, CE 5, CE 6, Mobile 6.x, Vista, Server 2008, 7, Server 2008 R2, 8, Server 2012, RT, Surface, Phone 8
See details on [https://technet.microsoft.com/en-us/library/security/cc750357.aspx#_Microsoft_FIPS_140 Microsoft FIPS 140 Validated Cryptographic Modules]}}

|

|

Secure Transport

| {{yes|Apple FIPS Cryptographic Module: 1.0 (OS X 10.6, #1514), 1.1 (OS X 10.7, #1701)
Apple OS X CoreCrypto Module; CoreCrypto Kernel Module: 3.0 (OS X 10.8, #1964, #1956), 4.0 (OS X 10.9, #2015, #2016)
Apple iOS CoreCrypto Module; CoreCrypto Kernel Module: 3.0 (iOS 6, #1963, #1944), 4.0 (iOS 7, #2020, #2021)}}

|

|

wolfSSL{{cite web|url=http://www.wolfssl.com/yaSSL/fips.html|title=wolfCrypt FIPS 140-2 Information - wolfSSL Embedded SSL/TLS Library|publisher=}}

| {{yes|wolfCrypt FIPS Module: 4.0 (#3389)
See details on [https://csrc.nist.gov/Projects/cryptographic-module-validation-program/Certificate/3389 NIST certificate] for validated Operating Environments
wolfCrypt FIPS Module: 3.6.0 (#2425)
See details on [https://csrc.nist.gov/projects/cryptographic-module-validation-program/Certificate/2425 NIST certificate] for validated Operating Environments}}

|

| {{yes|wolfCrypt FIPS Module (#4178)
See details on [https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/4718 NIST certificate]}}

class="sortbottom"

! rowspan="2"|Implementation

! Level 1

! Level 2

! Level 1

colspan="2"|FIPS 140-1, FIPS 140-2

! colspan="1"|FIPS 140-3

{{Reflist |group="notes"}}

Key exchange algorithms (certificate-only)

This section lists the certificate verification functionality available in the various implementations.

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! RSA{{cite IETF|rfc=5246}}

! RSA-EXPORT (insecure)

! DHE-RSA (forward secrecy)

! DHE-DSS (forward secrecy)

! ECDH-ECDSA{{cite IETF|rfc=4492}}

! ECDHE-ECDSA (forward secrecy)

! ECDH-RSA

! ECDHE-RSA (forward secrecy)

! GOST R 34.10-94, 34.10-2001{{cite IETF |draft=draft-chudov-cryptopro-cptls-04 |title=GOST 28147-89 Cipher Suites for Transport Layer Security (TLS)}}

Botan

| {{yes|Disabled by default}}

| {{Yes|No}}

| {{yes}}

| {{yes|Disabled by default}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

BSAFE

| {{okay|Yes}}

| {{Yes|No}}

| {{yes}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes|No}}

cryptlib

| {{okay|Yes}}

| {{Yes|No}}

| {{yes}}

| {{okay|Yes}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

| {{no}}

| {{yes|No}}

GnuTLS

| {{okay|Yes}}

| {{yes|No}}

| {{yes}}

| {{yes|Disabled by default}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

JSSE

| {{okay|Yes}}

| {{Yes|Disabled by default}}

| {{yes}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes|No}}

LibreSSL

| {{okay|Yes}}

| {{Yes|No}}

| {{yes}}

| {{okay|Yes}}

| {{Yes|No}}

| {{yes}}

| {{Yes|No}}

| {{yes}}

| {{okay|Yes}}{{cite web|title = LibreSSL 2.1.2 released|url = https://marc.info/?l=openbsd-announce&m=141809396501638| date = 2014-12-09| accessdate = 2015-01-20}}

MatrixSSL

| {{okay|Yes}}

| {{Yes|No}}

| {{yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes|No}}

Mbed TLS

| {{okay|Yes}}

| {{Yes|No}}

| {{yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes|No}}

NSS

| {{okay|Yes}}

| {{Yes|Disabled by default}}

| {{Yes}}{{cite web | url = https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.20_release_notes | title = NSS 3.20 release notes | publisher = Mozilla | date = 2015-08-19 | accessdate = 2015-08-20 | archive-date = 2021-12-07 | archive-url = https://web.archive.org/web/20211207015903/https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.20_release_notes | url-status = dead }}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes|No}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=518787|title=Bug 518787 - Add GOST crypto algorithm support in NSS |author=Mozilla.org|accessdate=2014-07-01}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=608725|title=Bug 608725 - Add Russian GOST cryptoalgorithms to NSS and Thunderbird |author=Mozilla.org|accessdate=2014-07-01}}

OpenSSL

| {{okay|Yes}}

| {{yes|No}}

| {{yes}}

| {{yes|Disabled by default}}

| {{Yes|No}}

| {{yes}}

| {{Yes|No}}

| {{yes}}

| {{okay|Yes}}{{Cite web|url=http://cvs.openssl.org/fileview|archiveurl=https://archive.today/20130415122812/http://cvs.openssl.org/fileview?f=openssl%2Fengines%2Fccgost%2FREADME.gost|url-status=dead|title=OpenSSL: CVS Web Interface|archive-date=2013-04-15|access-date=2014-11-12}}

Rustls

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

Schannel XP/2003

| {{okay|Yes}}

| {{No|Yes}}

| {{okay|No}}

| {{no|XP: Max 1024 bits
2003: 1024 bits only}}

| {{yes|No}}

| {{no}}

| {{yes|No}}

| {{no}}

| {{yes|No}}Extensions to support GOST in Schannel might be available.{{citation needed|date=November 2014}}

Schannel Vista/2008

| {{okay|Yes}}

| {{Yes|Disabled by default}}

| {{okay|No}}

| {{no|1024 bits by default}}{{Cite web | url=https://docs.microsoft.com/en-us/security-updates/SecurityAdvisories/2016/3174644 | title=Microsoft Security Advisory 3174644| date=14 October 2022}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

| {{partial|except AES_GCM}}

| {{yes|No}}

Schannel 8/2012

| {{okay|Yes}}

| {{Yes|Disabled by default}}

| {{partial|AES_GCM only}}{{cite web | url=https://technet.microsoft.com/library/security/MS14-066#ID0E5MAC | title=Microsoft Security Bulletin MS14-066 - Critical (Section Update FAQ) | publisher=Microsoft | date=November 11, 2014 | accessdate=11 November 2014}}{{cite web | url=http://blogs.microsoft.com/cybertrust/2014/11/11/hundreds-of-millions-of-microsoft-customers-now-benefit-from-best-in-class-encryption/ | title=Hundreds of Millions of Microsoft Customers Now Benefit from Best-in-Class Encryption | publisher=Microsoft Security | date=November 11, 2014 | accessdate=11 November 2014 | author=Thomlinson, Matt}}{{Cite web|url=https://support.microsoft.com/en-us/topic/update-adds-new-tls-cipher-suites-and-changes-cipher-suite-priorities-in-windows-8-1-and-windows-server-2012-r2-8e395e43-c8ef-27d8-b60c-0fc57d526d94|title=Update adds new TLS cipher suites and changes cipher suite priorities in Windows 8.1 and Windows Server 2012 R2|website=support.microsoft.com}}

| {{no|1024 bits by default}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

| {{partial|except AES_GCM}}

| {{yes|No}}

Schannel 7/2008R2, 8.1/2012R2

| {{okay|Yes}}

| {{Yes|Disabled by default}}

| {{yes}}

| {{okay|2048 bits by default}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

| {{partial|except AES_GCM}}

| {{yes|No}}

Schannel 10

| {{okay|Yes}}

| {{Yes|Disabled by default}}

| {{yes}}

| {{okay|2048 bits by default}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

Secure Transport OS X 10.6

| {{okay|Yes}}

| {{No|Yes}}

| {{partial|except AES_GCM}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{partial|except AES_GCM}}

| {{okay|yes}}

| {{partial|except AES_GCM}}

| {{yes|No}}

Secure Transport OS X 10.8-10.10

| {{okay|Yes}}

| {{Yes|No}}

| {{partial|except AES_GCM}}

| {{yes|No}}

| {{okay|Yes}}

| {{partial|except AES_GCM}}

| {{okay|Yes}}

| {{partial|except AES_GCM}}

| {{yes|No}}

Secure Transport OS X 10.11

| {{okay|Yes}}

| {{Yes|No}}

| {{yes}}

| {{yes|No}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

| {{yes}}

| {{yes|No}}

wolfSSL

| {{okay|Yes}}

| {{Yes|No}}

| {{yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes|No}}

Erlang/OTP SSL application

| {{okay|Yes}}

| {{yes|No}}

| {{yes}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes|No}}

class="sortbottom"

! Implementation

! RSA

! RSA-EXPORT (insecure)

! DHE-RSA (forward secrecy)

! DHE-DSS (forward secrecy)

! ECDH-ECDSA

! ECDHE-ECDSA (forward secrecy)

! ECDH-RSA

! ECDHE-RSA (forward secrecy)

! GOST R 34.10-94, 34.10-2001

Key exchange algorithms (alternative key-exchanges)

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! SRP{{cite IETF|rfc=5054}}

! SRP-DSS

! SRP-RSA

! PSK-RSA{{cite IETF|rfc=4279}}

! PSK

! DHE-PSK (forward secrecy)

! ECDHE-PSK (forward secrecy){{cite IETF|rfc=5489}}

! KRB5{{cite IETF|rfc=2712}}

! DH-ANON (insecure)

! ECDH-ANON (insecure)

Botan

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{yes}}

| {{no}}

| {{Yes|No}}

| {{Yes|No}}

BSAFE SSL-J

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}{{cite web|url=https://community.rsa.com/docs/DOC-95884|title=RSA BSAFE SSL-J 6.2.4 Release Notes|date=2018-09-05|archive-url=https://web.archive.org/web/20180910204318/https://community.rsa.com/docs/DOC-95884|archive-date=2018-09-10|url-status=dead}}

| {{no}}

| {{no}}

| {{no}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

cryptlib

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{yes}}

| {{no}}

| {{unknown}}

| {{Yes|No}}

| {{Yes|No}}

GnuTLS

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{Yes|Disabled by default}}

| {{Yes|Disabled by default}}

JSSE

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{Yes|Disabled by default}}

| {{Yes|Disabled by default}}

LibreSSL

| {{no}}{{cite web |url=https://marc.info/?l=openbsd-tech&m=140710904403657 |title=LibreSSL 2.0.4 released |accessdate=2014-08-04}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{No|Yes}}

| {{No|Yes}}

MatrixSSL

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{Yes|Disabled by default}}

| {{Yes|No}}

Mbed TLS

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{Yes|No}}

| {{Yes|No}}

NSS

| {{no}}{{cite web |url=https://bugzilla.mozilla.org/show_bug.cgi?id=405155 |title=Bug 405155 - add support for TLS-SRP, rfc5054 |publisher=Mozilla |accessdate=2014-01-25}}

| {{no}}

| {{no}}

| {{no}}{{cite web |url=https://bugzilla.mozilla.org/show_bug.cgi?id6435 |title=Bug 306435 - Mozilla browsers should support the new IETF TLS-PSK protocol to help reduce phishing |publisher=Mozilla |accessdate=2014-01-25}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{Yes|Client side only, disabled by default}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=1170510|title=Bug 1170510 - Implement NSS server side support for DH_anon |publisher=Mozilla|accessdate=2015-06-03}}

| {{Yes|Disabled by default}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=236245|title=Bug 236245 - Update ECC/TLS to conform to RFC 4492 |publisher=Mozilla|accessdate=2014-06-09}}

OpenSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{Yes}}{{cite web|url=https://www.openssl.org/news/changelog.html#x58|title=Changes between 0.9.6h and 0.9.7 [31 Dec 2002]|accessdate=2016-01-29}}

| {{Yes|Disabled by default}}{{cite web|url=https://www.openssl.org/news/changelog.html#x29|title=Changes between 0.9.8n and 1.0.0 [29 Mar 2010]|accessdate=2016-01-29}}

| {{Yes|Disabled by default}}

Rustls

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes|No}}

| {{yes|No}}

Schannel

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{Yes|No}}

| {{Yes|No}}

Secure Transport

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{unknown}}

| {{No|Yes}}

| {{No|Yes}}

wolfSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=https://www.wolfssl.com/wolfSSL/Docs-wolfssl-changelog.html|title=wolfSSL (Formerly CyaSSL) Release 3.9.0 (03/18/2016)|date=2016-03-18|accessdate=2016-04-05}}

| {{yes}}

| {{Yes|No}}

| {{Yes|No}}

Erlang/OTP SSL application

| {{yes |Disabled by default}}

| {{yes |Disabled by default}}

| {{yes |Disabled by default}}

| {{yes |Disabled by default}}

| {{yes |Disabled by default}}

| {{yes |Disabled by default}}

| {{No}}

| {{No}}

| {{yes |Disabled by default}}

| {{yes |Disabled by default}}

class="sortbottom"
Implementation

! SRP

! SRP-DSS

! SRP-RSA

! PSK-RSA

! PSK

! DHE-PSK (forward secrecy)

! ECDHE-PSK (forward secrecy)

! KRB5

! DH-ANON (insecure)

! ECDH-ANON (insecure)

Certificate verification methods

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! Application-defined

! PKIX path validation{{cite IETF|rfc=5280}}

! CRL{{cite IETF|rfc=3280}}

! OCSP{{cite IETF|rfc=2560}}

! DANE (DNSSEC){{cite IETF|rfc=6698}}{{cite IETF|rfc=7218}}

! CT{{cite IETF |title=Certificate Transparency |rfc=6962 |idlink=Certificate Transparency |last1=Laurie |authorlink1=Ben Laurie |first1=B. |last2=Langley |first2=A. |last3=Kasper |first3=E. |date=June 2013 |publisher=IETF |access-date=2020-08-31 |issn=2070-1721}}

Botan

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{unknown}}

Bouncy Castle

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{unknown}}

BSAFE

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{unknown}}

cryptlib

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{unknown}}

GnuTLS

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{unknown}}

JSSE

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

LibreSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{unknown}}

MatrixSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=http://www.matrixssl.org/blog/releases/matrixssl_3_8_3|title=MatrixSSL 3.8.3|accessdate=2017-01-18|archive-url=https://web.archive.org/web/20170119052959/http://www.matrixssl.org/blog/releases/matrixssl_3_8_3|archive-date=2017-01-19|url-status=dead}}

| {{no}}

| {{unknown}}

Mbed TLS

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}{{cite web|url=https://tls.mbed.org/tech-updates/blog/mbedtls-2.0-defaults-best-practices|title=mbed TLS 2.0 defaults implement best practices|accessdate=2017-01-18}}

| {{no}}

| {{unknown}}

NSS

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=672600|title=Bug 672600 - Use DNSSEC/DANE chain stapled into TLS handshake in certificate chain validation |publisher=Mozilla|accessdate=2014-06-18}}

| {{unknown}}

OpenSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

Rustls

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

s2n

|

|

| {{no}} {{Cite web |title=CRL Validation · Issue #3499 · aws/s2n-tls |url=https://github.com/aws/s2n-tls/issues/3499 |access-date=2022-11-01 |website=GitHub |language=en}}

| {{unknown}} {{Cite web |title=OCSP digest support for SHA-256 · Issue #2854 · aws/s2n-tls · GitHub |url=https://github.com/aws/s2n-tls/issues/2854 |access-date=2022-11-01 |website=GitHub |language=en}}

|

| {{unknown}} {{Cite web |title=[RFC 6962] s2n Client can Validate Signed Certificate Timestamp TLS Extension · Issue #457 · aws/s2n-tls · GitHub |url=https://github.com/aws/s2n-tls/issues/457 |access-date=2022-11-01 |website=GitHub |language=en}}

Schannel

| {{unknown}}

| {{yes}}

| {{yes}}{{cite web |url=https://technet.microsoft.com/en-us/library/ee619754(WS.10).aspx |title=How Certificate Revocation Works |author= |date=March 16, 2012 |website=Microsoft TechNet |publisher=Microsoft |accessdate=July 10, 2013}}

| {{yes}}

| {{no}}

| {{unknown}}

Secure Transport

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{unknown}}

wolfSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{unknown}}

Erlang/OTP SSL application

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{unknown}}

class="sortbottom"
Implementation

! Application-defined

! PKIX path validation

! CRL

! OCSP

! DANE (DNSSEC)

! CT

Encryption algorithms

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
rowspan="2"|Implementationcolspan="10"|Block cipher with mode of operationStream cipherNone
AES GCM

  • {{cite IETF|rfc=5288}}
  • {{cite IETF|rfc=5289}}

! AES CCM
RFC 6655, RFC 7251

! AES CBC

! Camellia GCM
{{cite IETF|rfc=6367}}

! Camellia CBC
{{cite IETF|rfc=5932}}

! ARIA GCM

! ARIA CBC
{{cite IETF|rfc=6209}}

! SEED CBC
{{cite IETF|rfc=4162}}

! {{nowrap|3DES EDE}} CBC
(insecure){{cite web|url=https://sweet32.info/|title=Sweet32: Birthday attacks on 64-bit block ciphers in TLS and OpenVPN|website=sweet32.info}}

! {{nowrap|GOST 28147-89}} CNT
(proposed)
This algorithm is not defined yet as TLS cipher suites in RFCs, is proposed in drafts.

! ChaCha20-Poly1305
{{cite IETF|rfc=7905}}

! Null
(insecure)
authentication only, no encryption

Botan

| {{yes}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|No}}

| {{yes}}{{cite web|url=http://botan.randombit.net/relnotes/1_11_12.html|title=Version 1.11.12, 2015-01-02 — Botan|date=2015-01-02|accessdate=2015-01-09}}

| {{yes|Not implemented}}

BoringSSL

| {{yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{yes}}

|

BSAFE SSL-J

| {{yes}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|No}}

| {{no}}

| {{Yes|Disabled by default}}

cryptlib

| {{yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{no}}

| {{yes|Not implemented}}

GnuTLS

| {{yes}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|Disabled by default}}{{cite web|url=https://lwn.net/Articles/731694/|title=gnutls 3.6.0|date=2017-09-21|accessdate=2018-01-07}}

| {{yes|No}}

| {{yes}}{{cite web|url=http://permalink.gmane.org/gmane.network.gnutls.general/4131|title=gnutls 3.4.12|date=2016-05-20|accessdate=2016-05-29|archive-url=https://web.archive.org/web/20161013015630/http://permalink.gmane.org/gmane.network.gnutls.general/4131|archive-date=2016-10-13|url-status=dead}}

| {{yes|Disabled by default}}

JSSE

| {{Yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|Disabled by default}}{{cite web|url=https://www.oracle.com/java/technologies/javase/10-0-1-relnotes.html|title=Java SE DevelopmentK Kit 10 - 10.0.1 Release Notes|date=2018-04-17|access-date=2024-01-14}}

| {{yes|No}}

| {{yes|Yes
(JDK 12+)}}{{cite web|url=https://www.oracle.com/java/technologies/javase/12-relnote-issues.html|title=JDK 12 Release Notes|access-date=2024-01-14}}

| {{yes|Disabled by default}}

LibreSSL

| {{yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{yes|Disabled by default}}

MatrixSSL

| {{yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{okay|Yes}}

| {{yes|Disabled by default}}

| {{yes|No}}

| {{yes}}{{cite web|url=https://github.com/matrixssl/matrixssl/blob/master/CHANGES.md#changes-in-383|title=Changes in 3.8.3|website=GitHub|accessdate=2016-06-19}}{{Dead link|date=July 2019 |bot=InternetArchiveBot |fix-attempted=yes }}

| {{yes|Disabled by default}}

Mbed TLS

| {{yes}}

| {{okay|Yes}} {{cite web|url=https://polarssl.org/tech-updates/releases/polarssl-1.3.8-released|title=PolarSSL 1.3.8 release notes|archive-url=https://web.archive.org/web/20140714220749/https://polarssl.org/tech-updates/releases/polarssl-1.3.8-released|archive-date=2014-07-14|url-status=dead}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{yes}}{{cite web|url=https://tls.mbed.org/tech-updates/releases/mbedtls-2.11.0-2.7.4-and-2.1.13-released|title=Mbed TLS 2.11.0, 2.7.4 and 2.1.13 released|accessdate=2018-08-30}}

| {{okay|Yes}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes}}{{cite web|url=https://tls.mbed.org/tech-updates/releases/mbedtls-2.12.0-2.7.5-and-2.1.14-released|title=Mbed TLS 2.12.0, 2.7.5 and 2.1.14 released|accessdate=2018-08-30}}

| {{yes|Disabled by default at compile time}}

NSS

| {{yes}}{{cite web|url=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.25_release_notes|work=Mozilla Developer Network|title=NSS 3.25 release notes|publisher=Mozilla|accessdate=2016-07-01|archive-date=2021-12-07|archive-url=https://web.archive.org/web/20211207020401/https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.25_release_notes|url-status=dead}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=940119|title=Bug 940119 - libssl does not support any TLS_ECDHE_*_CAMELLIA_*_GCM cipher suites|publisher=Mozilla|accessdate=2013-11-19}}This algorithm is implemented in an NSS fork used by Pale Moon.

| {{okay|Yes}}{{cite web|url=https://groups.google.com/forum/?hl=ja#!searchin/mozilla.dev.tech.crypto/camellia/mozilla.dev.tech.crypto/3NTvSYkF9MQ/O7Aj7oeiff8J|title=NSS 3.12 is released|accessdate=2013-11-19}}

| {{okay|No}}

| {{yes|No}}

| {{okay|Yes}}{{cite web|url=https://firefox-source-docs.mozilla.org/security/nss/legacy/nss_releases/nss_3.12.3_release_notes/index.html|work=Mozilla Developer Network|title=NSS 3.12.3 Release Notes|publisher=Mozilla|access-date=2023-04-01|archive-url=https://web.archive.org/web/20230402220534/https://firefox-source-docs.mozilla.org/security/nss/legacy/nss_releases/nss_3.12.3_release_notes/index.html|archive-date=2023-04-02|url-status=dead}}

| {{no|Yes}}

| {{yes|No}}

| {{yes}}{{cite web|url=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.23_release_notes|work=Mozilla Developer Network|title=NSS 3.23 release notes|publisher=Mozilla|accessdate=2016-03-09|archive-date=2021-04-14|archive-url=https://web.archive.org/web/20210414233905/https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.23_release_notes|url-status=dead}}

| {{yes|Disabled by default}}

OpenSSL

| {{yes}}{{cite web|url=https://github.com/openssl/openssl/blob/OpenSSL_1_0_1-stable/CHANGES|title=openssl/CHANGES at OpenSSL_1_0_1-stable · openssl/openssl|website=GitHub|accessdate=2015-01-20}}

| {{yes|Disabled by default}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|Disabled by default}}{{cite web|url=https://www.openssl.org/news/openssl-1.1.0-notes.html|title=OpenSSL 1.1.0 Series Release Notes|website=www.openssl.org|access-date=2016-09-03|archive-date=2018-03-17|archive-url=https://web.archive.org/web/20180317162208/https://www.openssl.org/news/openssl-1.1.0-notes.html|url-status=dead}}

| {{okay|Disabled by default}}{{cite web|url=https://www.openssl.org/news/openssl-1.1.1-notes.html|title=OpenSSL 1.1.1 Series Release Notes|website=www.openssl.org|archive-url=https://web.archive.org/web/20240116202037/https://www.openssl.org/news/openssl-1.1.1-notes.html|archive-date=2024-01-16|url-status=dead}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{okay|Yes}}

| {{yes}}

| {{yes|Disabled by default}}

Rustls

| {{yes}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes}}

| {{yes|Not implemented}}

Schannel XP/2003

| {{no}}

| {{yes|No}}

| {{Partial|2003 only}}{{Cite web|url=https://docs.microsoft.com/en-us/windows/win32/secauthn/cipher-suites-in-schannel|title=Cipher Suites in TLS/SSL (Schannel SSP) - Win32 apps|website=docs.microsoft.com|date=14 July 2023 }}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{no}}

| {{yes|Disabled by default}}

Schannel Vista/2008, 2008R2, 2012

| {{no}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{no}}

| {{yes|Disabled by default}}

Schannel 7, 8, 8.1/2012R2

| {{Partial|Yes except ECDHE_RSA}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{no}}

| {{yes|Disabled by default}}

Schannel 10{{cite web|url=https://dev.ssllabs.com/ssltest/viewClient.html?name=IE&version=11&platform=Win+10+Preview|title=Qualys SSL Labs - Projects / User Agent Capabilities: IE 11 / Win 10 Preview|website=dev.ssllabs.com|archive-url=https://web.archive.org/web/20230714075523/https://dev.ssllabs.com/ssltest/viewClient.html?name=IE&version=11&platform=Win+10+Preview|archive-date=2023-07-14|url-status=dead}}

| {{yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{no}}

| {{yes|Disabled by default}}

Secure Transport OS X 10.6 - 10.10

| {{no}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{no}}

| {{yes|Disabled by default}}

Secure Transport OS X 10.11

| {{yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{no}}

| {{yes|Disabled by default}}

wolfSSL

| {{yes}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{yes}}

| {{yes|Disabled by default}}

Erlang/OTP SSL application

| {{yes}}

| {{yes|No}}

| {{okay|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes| Disabled by default}}

| {{yes|No}}

|{{okay|Experimental}}

|{{yes|Disable by default}}

class="sortbottom"

! rowspan="2"|Implementation !! colspan="10"|Block cipher with mode of operation !! Stream cipher !! None

AES GCM

! AES CCM

! AES CBC

! Camellia GCM

! Camellia CBC

! ARIA GCM

! ARIA CBC

! SEED CBC

! {{nowrap|3DES EDE}} CBC
(insecure)

! {{nowrap|GOST 28147-89}} CNT
(proposed)

! ChaCha20-Poly1305

! Null
(insecure)

; Notes

{{Reflist|group="n"}}

= Obsolete algorithms =

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
rowspan="2"|Implementationcolspan="4"|Block cipher with mode of operationcolspan="2"|Stream cipher
IDEA CBC
{{refn|group="n"|name="removal_from_tls1.2"|IDEA and DES have been removed from TLS 1.2.RFC 5469}}(insecure){{Cite web | url=https://sweet32.info |title = Sweet32: Birthday attacks on 64-bit block ciphers in TLS and OpenVPN}}

! DES CBC
(insecure)

! DES-40 CBC
(EXPORT, insecure)
40 bits strength of cipher suites were designed to operate at reduced key lengths in order to comply with US regulations about the export of cryptographic software containing certain strong encryption algorithms (see Export of cryptography from the United States). These weak suites are forbidden in TLS 1.1 and later.

! RC2-40 CBC
(EXPORT, insecure)

! RC4-128
(insecure)
The RC4 attacks weaken or break RC4 used in SSL/TLS. Use of RC4 is prohibited by RFC 7465.

! RC4-40
(EXPORT, insecure)
The RC4 attacks weaken or break RC4 used in SSL/TLS.

Botan

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{Yes|No}}{{cite web|url=http://botan.randombit.net/relnotes/1_11_15.html|title=Version 1.11.15, 2015-03-08 — Botan|date=2015-03-08|accessdate=2015-03-11}}

| {{yes|No}}

BoringSSL

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|Disabled by default at compile time}}

| {{yes|No}}

BSAFE SSL-J

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

cryptlib

| {{yes|No}}

| {{yes|Disabled by default at compile time}}

| {{yes|No}}

| {{yes|No}}

| {{yes|Disabled by default at compile time}}

| {{yes|No}}

GnuTLS

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|No}}

JSSE

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}} {{cite web|url=http://docs.oracle.com/javase/8/docs/technotes/guides/security/SunProviders.html|title=Java Cryptography Architecture Oracle Providers Documentation|website=docs.oracle.com}}

LibreSSL

| {{no|Yes}}

| {{no|Yes}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

MatrixSSL

| {{no|Yes}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|No}}

Mbed TLS

| {{yes|No}}

| {{yes|Disabled by default at compile time}}

| {{yes|No}}

| {{yes|No}}

| {{yes|Disabled by default at compile time}}

| {{yes|No}}

NSS

| {{no|Yes}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{Partial|Lowest priority}}{{cite web|url=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.15.3_release_notes|work=Mozilla Developer Network|title=NSS 3.15.3 release notes|publisher=Mozilla|accessdate=2014-07-13|archive-date=2014-06-05|archive-url=https://web.archive.org/web/20140605001016/https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.15.3_release_notes|url-status=dead}}{{cite web|url=https://www.mozilla.org/security/announce/2013/mfsa2013-103.html|work=Mozilla|title=MFSA 2013-103: Miscellaneous Network Security Services (NSS) vulnerabilities|accessdate=2014-07-13}}

| {{yes|Disabled by default}}

OpenSSL

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{Yes|No}}

| {{Yes|No}}

| {{yes|Disabled by default}}

| {{Yes|No}}

Rustls

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

Schannel XP/2003

| {{yes|No}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

Schannel Vista/2008

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{no|Yes}}

| {{yes|Disabled by default}}

Schannel 7/2008R2

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{Partial|Lowest priority
will be disabled soon}}{{cite web|url=https://blogs.windows.com/msedgedev/2016/08/09/rc4-now-deprecated/|title=RC4 is now disabled in Microsoft Edge and Internet Explorer 11 - Microsoft Edge Dev BlogMicrosoft Edge Dev Blog|website=blogs.windows.com|date=2016-08-09}}

| {{yes|Disabled by default}}

Schannel 8/2012

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{Partial|Only as fallback}}

| {{yes|Disabled by default}}

Schannel 8.1/2012R2

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

Schannel 10

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

Secure Transport OS X 10.6

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

Secure Transport OS X 10.7

| {{no|Yes}}

| {{unknown}}

| {{unknown}}

| {{unknown}}

| {{no|Yes}}

| {{unknown}}

Secure Transport OS X 10.8-10.9

| {{no|Yes}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{no|Yes}}

| {{yes|Disabled by default}}

Secure Transport OS X 10.10-10.11

| {{no|Yes}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{Partial|Lowest priority}}

| {{yes|Disabled by default}}

Secure Transport macOS 10.12

| {{no|Yes}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

| {{yes|Disabled by default}}

wolfSSL

| {{yes|Disabled by default}}{{cite web|url=https://www.wolfssl.com/wolfSSL/Docs-wolfssl-changelog.html|title=wolfSSL (Formerly CyaSSL) Release 3.7.0 (10/26/2015)|date=2015-10-26|accessdate=2015-11-19}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|Disabled by default}}

| {{yes|No}}

Erlang/OTP SSL application

| {{yes |no}}

| {{yes |Disabled by default}}

| {{yes |no}}

| {{yes|no}}

| {{yes |Disabled by default}}

| {{yes|no}}

class="sortbottom"
rowspan="2"|Implementationcolspan="4"|Block cipher with mode of operationcolspan="2"|Stream cipher
IDEA CBC
(insecure)

! DES CBC
(insecure)

! DES-40 CBC
(EXPORT, insecure)

! RC2-40 CBC
(EXPORT, insecure)

! RC4-128
(insecure)

! RC4-40
(EXPORT, insecure)

; Notes

{{Reflist|group="n"}}

Supported elliptic curves

This section lists the supported elliptic curves by each implementation.

= Defined curves in RFC 8446 (for TLS 1.3) and RFC 8422, 7027 (for TLS 1.2 and earlier) =

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
applicable TLS version

! colspan="5"|TLS 1.3 and earlier

colspan="3"|TLS 1.2 and earlier
Implementation

! secp256r1
prime256v1
{{nowrap|NIST P-256}}
(0x0017,RFC 8446 23RFC 8422)

! secp384r1
{{nowrap|NIST P-384}}
(0x0018, 24)

! secp521r1
{{nowrap|NIST P-521}}
(0x0019, 25)

! X25519
(0x001D, 29)

! X448
(0x001E, 30)

! brainpoolP256r1
(26)RFC 7027

! brainpoolP384r1
(27)

! brainpoolP512r1
(28)

Botan

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{yes}}{{cite web|url=http://botan.randombit.net/relnotes/1_11_5.html|title=Version 1.11.5, 2013-11-10 — Botan|date=2013-11-10|accessdate=2015-01-23}}

| {{yes}}

| {{yes}}

BoringSSL

| {{yes}}

| {{yes}}

| {{okay|Yes}} (disabled by default)

| {{yes}}

| {{no}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

BSAFE

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

GnuTLS

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=http://nmav.gnutls.org/2016/05/gnutls-3-5-0.html|title=An overview of the new features in GnuTLS 3.5.0|date=2016-05-02|accessdate=2016-12-09}}

| {{yes}}{{cite web|url=https://lists.gnupg.org/pipermail/gnutls-help/2020-February/004621.html|title=gnutls 3.6.12|date=2020-02-01|accessdate=2021-08-31}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

JSSE

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes|Yes}}
x25519: JDK 13+{{cite web|url=https://jdk.java.net/13/release-notes|title=JDK 13 Early-Access Release Notes|accessdate=2019-06-20|archive-date=2020-04-01|archive-url=https://web.archive.org/web/20200401060808/http://jdk.java.net/13/release-notes|url-status=dead}}
Ed25519:JDK 15+{{cite web|url=https://bugs.openjdk.org/browse/JDK-8199231|title=JEP 339: Edwards-Curve Digital Signature Algorithm (EdDSA)|access-date=2024-01-14}}

| {{yes|Yes}}
x448: JDK 13+
Ed448: JDK 15+

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

LibreSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=https://ftp.openbsd.org/pub/OpenBSD/LibreSSL/libressl-2.5.1-relnotes.txt|title=LibreSSL 2.5.1 release notes |publisher=OpenBSD|date=2017-01-31|accessdate=2017-02-23}}

| {{no}}

| {{yes}}

| {{yes}}

| {{yes}}

MatrixSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{partial|TLS 1.3 only}}{{cite web|url=https://github.com/matrixssl/matrixssl/blob/4-0-0-open/doc/CHANGES_v4.0.md|title=MatrixSSL 4.0 changelog|website=GitHub|accessdate=2018-09-18}}

| {{no}}

| {{yes}}

| {{yes}}

| {{yes}}

Mbed TLS

| {{yes}}

| {{yes}}

| {{yes}}

| {{partial|Primitive only}}{{cite web|url=https://polarssl.org/tech-updates/releases/polarssl-1.3.3-released|title=PolarSSL 1.3.3 released|date=2013-12-31|access-date=2015-01-23|archive-url=https://web.archive.org/web/20140107122023/https://polarssl.org/tech-updates/releases/polarssl-1.3.3-released|archive-date=2014-01-07|url-status=dead}}

| {{partial|Primitive only}}{{cite web|url=https://tls.mbed.org/tech-updates/releases/mbedtls-2.9.0-2.7.3-and-2.1.12-released|title=Mbed TLS 2.9.0, 2.7.3 and 2.1.12 released|access-date=2018-08-30}}

| {{yes}}{{cite web|url=https://polarssl.org/tech-updates/releases/polarssl-1.3.1-released|title=PolarSSL 1.3.1 released|date=2013-10-15|access-date=2015-01-23|archive-url=https://web.archive.org/web/20150123084424/https://polarssl.org/tech-updates/releases/polarssl-1.3.1-released|archive-date=2015-01-23|url-status=dead}}

| {{yes}}

| {{yes}}

NSS

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=957105|title=Bug 957105 - Add support for curve25519 Key Exchange and UMAC MAC support for TLS |publisher=Mozilla|accessdate=2017-02-23}}

| {{no}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=1305243|title=Bug 1305243 - Support for X448 |publisher=Mozilla|accessdate=2022-08-04}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=1597057|title=Bug 1597057 - Curve448 or named Ed448-Goldilocks support needed (both X448 key exchange and Ed448 signature algorithm ) |publisher=Mozilla|accessdate=2022-08-04}}

| {{okay|No}}{{cite web |url=https://bugzilla.mozilla.org/show_bug.cgi?id=943639 |title=Bug 943639 - Support for Brainpool ECC Curve (rfc5639) |publisher=Mozilla |accessdate=2014-01-25}}

| {{okay|No}}

| {{okay|No}}

OpenSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web

| url = https://www.openssl.org/news/cl110.txt

| title = OpenSSL 1.1.0x Release Notes

| date = 25 August 2016

| access-date = 18 May 2018

| archive-date = 18 May 2018

| archive-url = https://web.archive.org/web/20180518200620/https://www.openssl.org/news/cl110.txt

| url-status = dead

}}{{cite web

| url = https://github.com/openssl/openssl/issues/487

| title = OpenSSL GitHub Issue #487 Tracker

| website = GitHub

| date = 2 December 2015

| access-date = 18 May 2018

}}

| {{yes}}{{cite web

| url = https://www.openssl.org/news/cl111.txt

| title = OpenSSL CHANGES

| date = 1 May 2018

| access-date = 18 May 2018

| archive-url = https://web.archive.org/web/20180518200747/https://www.openssl.org/news/cl111.txt

| archive-date = 18 May 2018

| url-status = dead

}}{{cite web

| url = https://github.com/openssl/openssl/issues/5049

| title = OpenSSL GitHub Issue #5049 Tracker

| website = GitHub

| date = 9 January 2018

| access-date = 18 May 2018

}}

| {{yes}}

| {{yes}}

| {{yes}}

Rustls

| {{yes}}

| {{yes}}

| {{no}}

| {{yes}}

| {{no}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

Schannel Vista/2008, 7/2008R2, 8/2012, 8.1/2012R2, 10

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

Secure Transport

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

wolfSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=https://www.wolfssl.com/wolfSSL/Docs-wolfssl-changelog.html|title=wolfSSL (Formerly CyaSSL) Release 3.4.6 (03/30/2015)|date=2015-03-30|accessdate=2015-11-19}}

| {{yes}}{{cite web|url=https://www.wolfssl.com/wolfSSL/Docs-wolfssl-changelog.html|title=wolfSSL Release 4.4.0 (04/22/2020)|date=2020-04-22|accessdate=2022-10-18}}

| {{yes}}

| {{yes}}

| {{yes}}

Erlang/OTP SSL application

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{yes}}

| {{yes}}

| {{yes}}

class="sortbottom"
Implementation

! secp256r1
prime256v1
{{nowrap|NIST P-256}}
(0x0017, 23)

! secp384r1
{{nowrap|NIST P-384}}
(0x0018, 24)

! secp521r1
{{nowrap|NIST P-521}}
(0x0019, 25)

! X25519
(0x001D, 29)

! X448
(0x001E, 30)

! brainpoolP256r1
(26)

! brainpoolP384r1
(27)

! brainpoolP512r1
(28)

= Deprecated curves in RFC 8422 =

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! sect163k1
{{nowrap|NIST K-163}}
(1)

! sect163r1
(2)

! sect163r2
{{nowrap|NIST B-163}}
(3)

! sect193r1
(4)

! sect193r2
(5)

! sect233k1
{{nowrap|NIST K-233}}
(6)

! sect233r1
{{nowrap|NIST B-233}}
(7)

! sect239k1
(8)

! sect283k1
{{nowrap|NIST K-283}}
(9)

! sect283r1
{{nowrap|NIST B-283}}
(10)

! sect409k1
{{nowrap|NIST K-409}}
(11)

! sect409r1
{{nowrap|NIST B-409}}
(12)

! sect571k1
{{nowrap|NIST K-571}}
(13)

! sect571r1
{{nowrap|NIST B-571}}
(14)

Botan

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

BoringSSL

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

BSAFE

| {{no|Yes}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes|No}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

GnuTLS

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

JSSE

| {{yes|Notes}}{{refn|group=lower-alpha|name="JSSEDisableEC"|These elliptic curves were "Disabled by Default" in current JDK families as part of JDK-8236730.{{cite web |title=Release Note: Weak Named Curves in TLS, CertPath, and Signed JAR Disabled by Default |url=https://bugs.openjdk.org/browse/JDK-8236730 |website=JDK Bug System (JBS) |access-date=25 December 2024}}}}{{refn|group=lower-alpha|name="JSSERemoveEC"|These elliptic curves were subsequently removed in JDK 16+ as part of JDK-8252601.{{cite web |title=Release Note: Removal of Legacy Elliptic Curves |url=https://bugs.openjdk.org/browse/JDK-8252601 |website=JDK Bug System (JBS) |access-date=25 December 2024}}}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

LibreSSL

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

MatrixSSL

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

Mbed TLS

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

NSS

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

OpenSSL

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

Rustls

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

Schannel Vista/2008, 7/2008R2, 8/2012, 8.1/2012R2, 10

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

Secure Transport

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

wolfSSL

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

| {{okay|No}}

Erlang/OTP SSL application

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

class="sortbottom"
Implementation

! sect163k1
{{nowrap|NIST K-163}}
(1)

! sect163r1
(2)

! sect163r2
{{nowrap|NIST B-163}}
(3)

! sect193r1
(4)

! sect193r2
(5)

! sect233k1
{{nowrap|NIST K-233}}
(6)

! sect233r1
{{nowrap|NIST B-233}}
(7)

! sect239k1
(8)

! sect283k1
{{nowrap|NIST K-283}}
(9)

! sect283r1
{{nowrap|NIST B-283}}
(10)

! sect409k1
{{nowrap|NIST K-409}}
(11)

! sect409r1
{{nowrap|NIST B-409}}
(12)

! sect571k1
{{nowrap|NIST K-571}}
(13)

! sect571r1
{{nowrap|NIST B-571}}
(14)

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! secp160k1
(15)

! secp160r1
(16)

! secp160r2
(17)

! secp192k1
(18)

! secp192r1
prime192v1
{{nowrap|NIST P-192}}
(19)

! secp224k1
(20)

! secp224r1
{{nowrap|NIST P-244}}
(21)

! secp256k1
(22)

! arbitrary prime curves
(0xFF01)Negotiation of arbitrary curves has been shown to be insecure for certain curve sizes {{cite conference|author=Mavrogiannopoulos, Nikos and Vercautern, Frederik and Velichkov, Vesselin and Preneel, Bart|title=A cross-protocol attack on the TLS protocol|book-title=Proceedings of the 2012 ACM conference on Computer and communications security|year=2012|isbn=978-1-4503-1651-4|url=https://www.cosic.esat.kuleuven.be/publications/article-2216.pdf|pages=62–72|publisher=Association for Computing Machinery|doi=10.1145/2382196.2382206}}

! arbitrary char2 curves
(0xFF02)

Botan

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

BoringSSL

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

BSAFE

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{no|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

GnuTLS

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{no|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

JSSE

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|Notes}}

| {{yes|No}}

| {{yes|No}}

LibreSSL

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes}}

| {{yes|No}}

| {{yes|No}}

MatrixSSL

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{no|Yes}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

Mbed TLS

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes}}

| {{yes|No}}

| {{yes|No}}

NSS

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes}}

| {{yes|No}}

| {{yes|No}}

OpenSSL

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes}}

| {{yes|No}}

| {{yes|No}}

Rustls

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

Schannel Vista/2008, 7/2008R2, 8/2012, 8.1/2012R2, 10

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

Secure Transport

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{yes|No}}

| {{no|Yes}}

| {{yes|No}}

| {{yes|No}}

| {{okay|No}}

| {{yes|No}}

| {{yes|No}}

wolfSSL

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes}}

| {{yes|No}}

| {{yes|No}}

Erlang/OTP SSL application

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{no|Yes}}

| {{yes}}

| {{yes|No}}

| {{yes|No}}

class="sortbottom"
Implementation

! secp160k1
(15)

! secp160r1
(16)

! secp160r2
(17)

! secp192k1
(18)

! secp192r1
prime192v1
{{nowrap|NIST P-192}}
(19)

! secp224k1
(20)

! secp224r1
{{nowrap|NIST P-244}}
(21)

! secp256k1
(22)

! arbitrary prime curves
(0xFF01)

! arbitrary char2 curves
(0xFF02)

; Notes

{{Reflist|group=lower-alpha}}

Data integrity

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! HMAC-MD5

! HMAC-SHA1

! HMAC-SHA256/384

! AEAD

! GOST 28147-89 IMIT

! GOST R 34.11-94

Botan

| {{No Y}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

BSAFE

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

cryptlib

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

GnuTLS

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

JSSE

| {{yes|Disabled by Default}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

LibreSSL

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{okay|Yes}}

MatrixSSL

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

Mbed TLS

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

NSS

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

OpenSSL

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{okay|Yes}}

| {{okay|Yes}}

Rustls

| {{No Y}}

| {{No Y}}

| {{No Y}}

| {{yes}}

| {{No Y}}

| {{No Y}}

Schannel XP/2003, Vista/2008

| {{Yes N}}

| {{okay|Yes}}

| {{partial|XP SP3, 2003 SP2 via hotfix}}
{{cite web|url=https://techcommunity.microsoft.com/blog/coreinfrastructureandsecurityblog/sha2-and-windows/1128617|title=SHA2 and Windows|access-date=2024-12-25}}

| {{no}}

| {{No Y}}

| {{No Y}}

Schannel 7/2008R2, 8/2012, 8.1/2012R2

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{partial|except ECDHE_RSA}}

| {{No Y}}

| {{No Y}}

Schannel 10

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

Secure Transport

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

wolfSSL

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

Erlang/OTP SSL application

| {{Yes N}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{yes}}

| {{No Y}}

| {{No Y}}

class="sortbottom"

! Implementation

! HMAC-MD5

! HMAC-SHA1

! HMAC-SHA256/384

! AEAD

! GOST 28147-89 IMIT

! GOST R 34.11-94

Compression

Note the CRIME security exploit takes advantage of TLS compression, so conservative implementations do not enable compression at the TLS level. HTTP compression is unrelated and unaffected by this exploit, but is exploited by the related BREACH attack.

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! DEFLATERFC 3749
(insecure)

Botan

| {{yes|No}}

BSAFE

| {{yes|No}}

cryptlib

| {{yes|No}}

GnuTLS

| {{yes|Disabled by default}}

JSSE

| {{yes|No}}

LibreSSL

| {{yes|No}}

MatrixSSL

| {{yes|Disabled by default}}

Mbed TLS

| {{yes|Disabled by default}}

NSS

| {{yes|Disabled by default}}

OpenSSL

| {{Yes|Disabled by default}}

Rustls

| {{yes|No}}

Schannel

| {{yes|No}}

Secure Transport

| {{yes|No}}

wolfSSL

| {{yes|Disabled by default}}

Erlang/OTP SSL application

| {{yes|No}}

class="sortbottom"

! Implementation

! DEFLATE

Extensions

In this section the extensions each implementation supports are listed. Note that the Secure Renegotiation extension is critical for HTTPS client security {{citation needed|date=August 2014}}. TLS clients not implementing it are vulnerable to attacks, irrespective of whether the client implements TLS renegotiation.

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! Secure Renegotiation
RFC 5746

! Server Name Indication
RFC 6066

! ALPN
RFC 7301

! Certificate Status Request

! OpenPGP
RFC 6091

! Supplemental Data
RFC 4680

! Session Ticket
{{cite IETF|rfc=5077}}

! Keying Material Exporter
{{cite IETF|rfc=5705}}

! Maximum Fragment Length

! Encrypt-then-MAC

! TLS Fallback SCSV
{{cite IETF|rfc=7507}}

! Extended Master Secret
RFC 7627

! ClientHello Padding
RFC 7685

! Raw Public Keys
RFC 7250

Botan

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=https://botan.randombit.net/news.html#version-1-11-16-2015-03-29|title=Version 1.11.16, 2015-03-29 — Botan|date=2016-03-29|accessdate=2016-09-08}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=http://botan.randombit.net/relnotes/1_11_10.html|title=Version 1.11.10, 2014-12-10 — Botan|date=2014-12-10|accessdate=2014-12-14}}

| {{yes}}{{cite web|url=http://botan.randombit.net/news.html#version-1-11-26-2016-01-04|title=Version 1.11.26, 2016-01-04 — Botan|date=2016-01-04|accessdate=2016-02-25}}

| {{no}}

| {{unknown}}

BSAFE SSL-J

| {{yes}}

| {{yes}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

cryptlib

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}Present, but disabled by default due to lack of use by any implementation.

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{unknown}}

GnuTLS

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=http://article.gmane.org/gmane.network.gnutls.general/3136|title=gnutls 3.2.0|accessdate=2015-01-26|archive-url=https://web.archive.org/web/20160131230710/http://article.gmane.org/gmane.network.gnutls.general/3136|archive-date=2016-01-31|url-status=dead}}

| {{yes}}

| {{no}}{{Cite web|url=https://lists.gnupg.org/pipermail/gnutls-help/2017-August/004364.html|title=[gnutls-help] GnuTLS 3.6.0 released|first=Nikos|last=Mavrogiannopoulos|date=August 21, 2017}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=http://permalink.gmane.org/gmane.comp.encryption.gpg.gnutls.devel/8267|title=gnutls 3.4.4|accessdate=2015-08-25|archive-url=https://web.archive.org/web/20170717020648/http://permalink.gmane.org/gmane.comp.encryption.gpg.gnutls.devel/8267|archive-date=2017-07-17|url-status=dead}}

| {{yes}}

| {{yes}}{{cite web|url=https://gnutls.org/manual/html_node/Priority-Strings.html|title=%DUMBFW priority keyword|accessdate=2017-04-30}}

| {{yes}}{{cite web|url=https://lists.gnupg.org/pipermail/gnutls-help/2019-January/004484.html|title=gnutls 3.6.6|date=2019-01-25|accessdate=2019-09-01}}

JSSE

| {{yes}}

| {{Yes}}

| {{Yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

LibreSSL

| {{yes}}

| {{yes}}

| {{yes}}{{cite web| title = LibreSSL 2.1.3 released| url = https://marc.info/?l=openbsd-announce&m=142193407304782| date = 2015-01-22| accessdate = 2015-01-22}}

| {{yes}}

| {{no}}

| {{no}}?

| {{yes}}

| {{yes}}?

| {{no}}

| {{no}}

| {{partial|Server side only}}{{cite web| title = LibreSSL 2.1.4 released| url = https://marc.info/?l=openbsd-announce&m=142543818707898| date = 2015-03-04| accessdate = 2015-03-04}}

| {{no}}

| {{yes}}

| {{no}}

MatrixSSL

| {{yes}}

| {{yes}}

| {{yes}}{{cite web |title = MatrixSSL - News |url = http://www.matrixssl.org/news.html |date = 2014-12-04 |accessdate = 2015-01-26 |url-status = dead |archiveurl = https://web.archive.org/web/20150214105056/http://www.matrixssl.org/news.html |archivedate = 2015-02-14 }}

| {{yes}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{yes}}

| {{no}}

| {{yes}}

| {{yes}}

| {{no}}

| {{unknown}}

Mbed TLS

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|title=Download overview - PolarSSL|url=https://polarssl.org/tech-updates/releases/polarssl-1.3.6-released|date=2014-04-11|access-date=2015-01-26|archive-date=2015-02-09|archive-url=https://web.archive.org/web/20150209195111/https://polarssl.org/tech-updates/releases/polarssl-1.3.6-released|url-status=dead}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{yes}}

| {{yes}}{{cite web|url=https://polarssl.org/tech-updates/releases/mbedtls-1.3.10-released|title=mbed TLS 1.3.10 released|date=2015-02-08|access-date=2015-02-09|archive-date=2015-02-09|archive-url=https://web.archive.org/web/20150209180352/https://polarssl.org/tech-updates/releases/mbedtls-1.3.10-released|url-status=dead}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

NSS

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=https://developer.mozilla.org/en-US/docs/NSS/NSS_3.15.5_release_notes|archive-url=https://archive.today/20150126155403/https://developer.mozilla.org/en-US/docs/NSS/NSS_3.15.5_release_notes|url-status=dead|archive-date=January 26, 2015|work=Mozilla Developer Network|title=NSS 3.15.5 release notes|publisher=Mozilla|accessdate=2015-01-26}}

| {{yes}}

| {{no}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=961416|title=Bug 961416 - Support RFC6091 - Using OpenPGP Keys for Transport Layer Security Authentication (TLS1.2) |publisher=Mozilla|accessdate=2014-06-18}}

| {{no}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}{{cite web|url=https://bugzilla.mozilla.org/show_bug.cgi?id=972145|title=Bug 972145 - Implement the encrypt-then-MAC TLS extension |publisher=Mozilla|accessdate=2014-11-06}}

| {{yes}}{{cite web|url=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.17.1_release_notes|title=NSS 3.17.1 release notes|accessdate=2014-10-17|archive-date=2019-04-19|archive-url=https://web.archive.org/web/20190419152214/https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.17.1_release_notes|url-status=dead}}

| {{yes}}{{cite web|url=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.21_release_notes|title=NSS 3.21 release notes|accessdate=2015-11-14|archive-date=2021-12-07|archive-url=https://web.archive.org/web/20211207025807/https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_3.21_release_notes|url-status=dead}}

| {{yes}}

| {{unknown}}

OpenSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}?

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=https://openssl-library.org/news/secadv/20141015.txt|title=OpenSSL Security Advisory [15 Oct 2014]|date=2014-10-15}}

| {{yes}}

| {{yes}}{{cite web|url=https://www.openssl.org/news/openssl-1.0.1-notes.html |title=Major changes between OpenSSL 1.0.1f and OpenSSL 1.0.1g [7 Apr 2014] |date=2014-04-07 |accessdate=2015-02-10 |url-status=dead |archive-url=https://web.archive.org/web/20150120120428/https://www.openssl.org/news/openssl-1.0.1-notes.html |archive-date=2015-01-20}}

| {{yes}}{{cite web|url=https://openssl-library.org/post/2023-11-06-openssl32/|title=OpenSSL Announces Final Release of OpenSSL 3.2.0|date=2023-11-23|access-date=2024-10-11}}

Rustls

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}} rustls does not implement earlier versions that would warrant protection against insecure downgrade

| {{yes}}

| {{no}}

| {{unknown}}

Schannel XP/2003

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{unknown}}

Schannel Vista/2008

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}{{cite web|url=https://learn.microsoft.com/en-us/security-updates/SecurityBulletins/2015/ms15-121|title=Microsoft Security Bulletin MS15-121|date=March 2023 |accessdate=2024-04-28}}

| {{no}}

| {{unknown}}

Schannel 7/2008R2

| {{yes}}

| {{yes}}

| {{no}}

| {{yes}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{unknown}}

Schannel 8/2012

| {{yes}}

| {{yes}}

| {{no}}

| {{yes}}

| {{no}}

| {{yes}}

| {{partial|Client side only}}{{cite web|url=https://learn.microsoft.com/en-us/previous-versions/windows/it-pro/windows-server-2012-R2-and-2012/hh831771(v=ws.11)|title=What's New in TLS/SSL (Schannel SSP)|date=31 August 2016 |accessdate=2024-04-28}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{unknown}}

Schannel 8.1/2012R2, 10

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{unknown}}

Secure Transport

| {{yes}}

| {{yes}}

| {{unknown}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{unknown}}

wolfSSL

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{yes}}

| {{yes}}{{cite web|url=https://www.wolfssl.com/wolfssl-version-4-2-0-now-available/|title=wolfSSL Version 4.2.0 is Now Available!|date=22 October 2019|accessdate=2021-08-13}}

| {{no}}

| {{yes}}

| {{no}}

| {{yes}}{{cite web|url=https://www.wolfssl.com/wolfssl-supports-raw-public-keys/|title=wolfSSL supports Raw Public Keys|date=August 2023 |accessdate=2024-10-25}}

Erlang/OTP SSL application

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

| {{unknown}}

class="sortbottom"

! Implementation

! Secure Renegotiation

! Server Name Indication

! ALPN

! Certificate Status Request

! OpenPGP

! Supplemental Data

! Session Ticket

! Keying Material Exporter

! Maximum Fragment Length

! Encrypt-then-MAC

! TLS Fallback SCSV

! Extended Master Secret

! ClientHello Padding

! Raw Public Keys

Assisted cryptography

This section lists the known ability of an implementation to take advantage of CPU instruction sets that optimize encryption, or utilize system specific devices that allow access to underlying cryptographic hardware for acceleration or for data separation.

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! PKCS #11 device

! Intel AES-NI

! VIA PadLock

! ARMv8-A

! Intel SHA

! NXP CAAM

! TPM 2.0

! NXP SE050

! Microchip ATECC

! STMicro STSAFE

! Maxim MAXQ

Botan

| {{yes}}{{cite web|url=https://botan.randombit.net/news.html#version-1-11-31-2016-08-30|title=Version 1.11.31, 2015-08-30 — Botan|date=2016-08-30|accessdate=2016-09-08}}

| {{yes}}

| {{no}}

| {{yes}}

|

| {{no}}

| {{yes}}{{cite web | url=https://botan.randombit.net/handbook/api_ref/tpm.html | title=Trusted Platform Module (TPM) — Botan }}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

BSAFE SSL-J {{refn|group=lower-alpha|Pure Java implementations relies on JVM processor optimization capabilities, such as OpenJDK support for AES-NI{{Cite web|url=https://openjdk.org/jeps/164|title=JEP 164: Leverage CPU Instructions for AES Cryptography|website=openjdk.org}}}}{{refn|group=lower-alpha|BSAFE SSL-J can be configured to run in native mode, using BSAFE Crypto-C Micro Edition to benefit from processor optimization.{{Cite web|url=https://sso.rsasecurity.com/sso/SSO?SPEntityID=rsalink&redirectreason=permissiondenied&referer=https%3A%2F%2Fcommunity.rsa.com%2Ft5%2Frsa-bsafe-archived-resources%2Frsa-bsafe-ssl-j-6-2-5-release-notes%2Fta-p%2F566951|title=RSA SecurID PASSCODE Request|website=sso.rsasecurity.com}}}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{no}}

| {{okay|Yes}}

| {{okay|Yes}}

| {{no}}

| {{no}}{{cite web | url=https://www.dell.com/support/kbdoc/en-my/000204717/comparison-of-bsafe-tls-libraries-micro-edition-suite-vs-ssl-j | title=Comparison of BSAFE TLS libraries: Micro Edition Suite vs SSL-J | Dell Malaysia }}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

cryptlib

| {{yes}}

| {{yes}}

| {{yes}}

| {{no}}

|

|

|

| {{no}}

| {{no}}

| {{no}}

| {{no}}

Crypto++

|

| {{yes}}

|

|

| {{yes}}

|

|

| {{no}}

| {{no}}

| {{no}}

| {{no}}

GnuTLS

| {{yes}}

| {{yes}}

| {{yes}}

| {{yes}}{{Cite web|url=https://lists.gnupg.org/pipermail/gnutls-devel/2016-October/008194.html|title=[gnutls-devel] gnutls 3.5.5|first=Nikos|last=Mavrogiannopoulos|date=October 9, 2016}}

| {{yes}}

|

| {{no}}{{cite web | url=https://www.gnutls.org/manual/html_node/Trusted-Platform-Module.html | title=Trusted Platform Module (GnuTLS 3.8.4) }}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

JSSE

| {{yes}}

| {{yes}}{{cite web|url=https://stackoverflow.com/questions/14259671/java-ssl-provider-with-aes-ni-support|title=Java SSL provider with AES-NI support|website=stackoverflow.com}}

| {{no}}

| {{no}}

|

| {{no}}

|

| {{no}}

| {{no}}

| {{no}}

| {{no}}

LibreSSL

| {{no}}

| {{yes}}

| {{yes}}

| {{no}}

|

|

|

| {{no}}

| {{no}}

| {{no}}

| {{no}}

MatrixSSL

| {{yes}}

| {{yes}}

| {{no}}

| {{yes}}

|

| {{no}}

|

| {{no}}

| {{no}}

| {{no}}

| {{no}}

Mbed TLS

| {{yes}}

| {{yes}}{{cite web | url=https://polarssl.org/tech-updates/releases/polarssl-1.3.3-released | title=PolarSSL 1.3.3 released | quote=We've incorporated support for AES-NI in our AES and GCM modules. | date=2013-12-31 | access-date=2014-01-07 | archive-url=https://web.archive.org/web/20140107122023/https://polarssl.org/tech-updates/releases/polarssl-1.3.3-released | archive-date=2014-01-07 | url-status=dead}}

| {{yes}}

| {{no}}

|

| {{no}}

|

| {{Partial}}{{cite web | url=https://github.com/NXP/plug-and-trust/tree/master?tab=readme-ov-file | title=NXP/Plug-and-trust | website=GitHub }}

| {{yes}}{{cite web | url=https://github.com/ARMmbed/mbed-os-atecc608a/ | title=ARMmbed/Mbed-os-atecc608a | website=GitHub }}

| {{no}}

| {{no}}

NSS

| {{yes}}Normally NSS's libssl performs all operations via the PKCS#11 interface, either to hardware or software tokens

| {{yes}}{{cite web | url=https://bugzilla.mozilla.org/show_bug.cgi?id=706024 | title=Bug 706024 - AES-NI enhancements to NSS on Sandy Bridge systems | accessdate=2013-09-28}}

| {{no}}{{cite web | url=https://bugzilla.mozilla.org/show_bug.cgi?id=479744 | title=Bug 479744 - RFE : VIA Padlock ACE support (hardware RNG, AES, SHA1 and SHA256) | accessdate=2014-04-11}}

| {{no}}

|

| {{no}}

|

| {{no}}

| {{no}}

| {{no}}

| {{no}}

OpenSSL

| {{yes}}{{cite web | url=https://habrahabr.ru/post/134725/ | title=Подключаем Рутокен ЭЦП к OpenSSL | date=16 December 2011 |lang=ru}}{{cite web | url=http://forum.rutoken.ru/topic/1639/ | title=Поддержка Рутокен ЭЦП в OpenSSL (Страница 1) — Рутокен и Open Source — Форум Рутокен |lang=ru}}{{cite web | url=https://dev.rutoken.ru/pages/viewpage.action?pageId=18055184 | title=OpenSSL ГОСТ | archive-url=https://web.archive.org/web/20180623005200/https://dev.rutoken.ru/pages/viewpage.action?pageId=18055184 | archive-date=2018-06-23 | url-status=dead | lang=ru}}

| {{yes}}

| {{yes}}

| {{yes}}{{cite web|url=http://git.openssl.org/gitweb/?p=openssl.git;a=commitdiff;h=ddacb8f27ba4c8a8d51c306c150e1a8703b008f2|title=git.openssl.org Git - openssl.git/commitdiff|website=git.openssl.org}}

| {{yes}}

| {{Partial}}

| {{Partial}}{{cite web | url=https://github.com/tpm2-software/tpm2-openssl | title=Tpm2-software/Tpm2-openssl | website=GitHub }}{{cite web | url=https://docs.openssl.org/3.0/man7/provider/ | title=Provider - OpenSSL Documentation }}

| {{Partial}}{{cite web | url=https://github.com/NXP/plug-and-trust/tree/master?tab=readme-ov-file | title=NXP/Plug-and-trust | website=GitHub }}

| {{no}}

| {{Partial}}{{cite web | url=https://www.st.com/en/embedded-software/stsw-stsa110-ssl.html | title=STSW-STSA110-SSL - STSAFE-A integration within OpenSSL security stack | website=STMicroelectronics}}

| {{no}}

Rustls

|

| {{yes}}

|

| {{yes}}

| {{yes}}

|

|

| {{no}}

| {{no}}

| {{no}}

| {{no}}

Schannel

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

|

| {{no}}

|

| {{no}}

| {{no}}

| {{no}}

| {{no}}

Secure Transport

| {{no}}

| {{Yes}}{{GitHub|https://github.com/apple-oss-distributions/Security/blob/Security-55179.13/sec/Security/SecECKey.c}}{{cite web |url=http://km.support.apple.com/library/APPLE/APPLECARE_ALLGEOS/HT5396/Crypto_Officer_Role_Guide_for_FIPS_140-2_Compliance_OS_X_Mountain_Lion_v10.8.pdf |title=Crypto Officer Role Guide for FIPS 140-2 Compliance OS X Mountain Lion v10.8 |publisher=Apple Inc. |date=2013}}

| {{no}}

| {{Yes}}

|

| {{no}}

|

| {{no}}

| {{no}}

| {{no}}

| {{no}}

wolfSSL

| {{yes}}

| {{yes}}

| {{no}}

| {{yes}}

|

| {{yes}}{{cite web|url=https://community.nxp.com/t5/i-MX-Processors/CAAM-support-in-wolfSSL/m-p/1013736|title=CAAM support in wolfSSL |date=10 March 2020|publisher=}}

| {{yes}}{{cite web|url=https://www.wolfssl.com/products/wolftpm/|title=wolfTPM Portable TPM 2.0 Library}}{{cite web|url=https://www.wolfssl.com/announcing-wolfssl-tpm-support-for-the-espressif-esp32/|title=Announcing wolfSSL TPM support for the Espressif ESP32|date=20 June 2024|publisher=}}

| {{yes}}{{cite web | url=https://www.wolfssl.com/wolfssl-ssl-tls-support-for-nxp-se050/ | title=WolfSSL SSL/TLS Support for NXP SE050 – wolfSSL | date=22 February 2024 }}

| {{yes}}{{cite web | url=https://www.wolfssl.com/blog-wolfssl-support-atecc608-crypto-coprocessor/ | title=WolfSSL support for the ATECC608 Crypto Coprocessor – wolfSSL | date=13 October 2021 }}

| {{yes}}{{cite web | url=https://www.wolfssl.com/wolfssl-support-stsafe-a100-crypto-coprocessor/ | title=WolfSSL support for STSAFE-A100 crypto coprocessor – wolfSSL | date=20 September 2018 }}

| {{yes}}{{cite web | url=https://www.wolfssl.com/support-maxq1065-wolfssl/ | title=Support for MAXQ1065 in wolfSSL – wolfSSL | date=29 November 2022 }}

class="sortbottom"

! Implementation

! PKCS #11 device

! Intel AES-NI

! VIA PadLock

! ARMv8-A

! Intel SHA

! NXP CAAM

! TPM 2.0

! NXP SE050

! Microchip ATECC

! STMicro STSAFE

! Maxim MAXQ

{{Reflist|group=lower-alpha}}

System-specific backends

This section lists the ability of an implementation to take advantage of the available operating system specific backends, or even the backends provided by another implementation.

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! /dev/crypto

! af_alg

! Windows CSP

! CommonCrypto

! OpenSSL engine

Botan

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{partial}}

BSAFE

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

cryptlib

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

GnuTLS

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{no}}

JSSE

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

LibreSSL

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}{{cite web| title = LibreSSL 2.2.1 Released| url = http://marc.info/?l=openbsd-announce&m=143635991232240| date = 2015-07-08| accessdate = 2016-01-30}}

MatrixSSL

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{yes}}

Mbed TLS

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

NSS

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{no}}

OpenSSL

| {{yes}}

| {{yes}}

| {{no}}

| {{no}}

| {{yes}}

Rustls

| {{no}}

| {{yes}} {{cite web|title=ktls integration for rustls|website=GitHub |accessdate=2024-08-29|url=https://github.com/rustls/ktls}}

| {{no}}

| {{no}}

| {{no}}

Schannel

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

| {{no}}

Secure Transport

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

| {{no}}

wolfSSL

| {{yes}}

| {{yes}}

| {{partial}}

| {{no}}

| {{yes}}{{cite web| title = wolfProvider| url = https://www.wolfssl.com/wolfengine-openssl-provider-solution-now-public/ |date = 2021-11-10| accessdate = 2022-01-17}}

Erlang/OTP SSL application

| {{no}}

| {{no}}

| {{no}}

| {{no}}

| {{yes}}

class="sortbottom"

! Implementation

! /dev/crypto

! af_alg

! Windows CSP

! CommonCrypto

! OpenSSL engine

Cryptographic module/token support

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! TPM support

! Hardware token support

! Objects identified via

Botan

| {{partial}}

| {{yes|PKCS #11}}

|

BSAFE SSL-J

| {{no}}

| {{no}}

|

cryptlib

| {{no}}

| {{yes|PKCS #11}}

| User-defined label

GnuTLS

| {{yes}}

| {{yes|PKCS #11}}

| RFC 7512 PKCS #11 URLs{{cite IETF |rfc=7512 |title=The PKCS #11 URI Scheme}}

JSSE

| {{no}}

| {{yes|PKCS11 Java Cryptography Architecture,
Java Cryptography Extension}}

|

LibreSSL

| {{yes}}

| {{partial|PKCS #11 (via 3rd party module)}}

| Custom method

MatrixSSL

| {{no}}

| {{yes|PKCS #11}}

|

Mbed TLS

| {{no}}

| {{yes|PKCS #11 (via libpkcs11-helper) or standard hooks}}

| Custom method

NSS

| {{no}}

| {{yes|PKCS #11}}

|

OpenSSL

| {{yes}}

| {{partial|PKCS #11 (via 3rd party module)}}{{cite web|url=https://github.com/OpenSC/libp11|title=libp11: PKCS#11 wrapper library|date=19 January 2018|publisher=|via=GitHub}}

| RFC 7512 PKCS #11 URLs

Rustls

| {{no}}

| {{yes|Microsoft CryptoAPI}} {{cite web|url=https://github.com/rustls/rustls-cng|title=Windows CNG bridge for rustls|website=GitHub |accessdate=2024-08-29}}

| Custom method

Schannel

| {{no}}

| {{yes|Microsoft CryptoAPI}}

| UUID, User-defined label

Secure Transport

|

|

|

wolfSSL

| {{yes}}

| {{yes|PKCS #11}}

|

class="sortbottom"

! Implementation

! TPM support

! Hardware token support

! Objects identified via

Code dependencies

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! Dependencies

! Optional dependencies

Botan

| C++20

| SQLite
zlib (compression)
bzip2 (compression)
liblzma (compression)
boost
trousers (TPM)

GnuTLS

| libc
nettle
gmp

| zlib (compression)
p11-kit (PKCS #11)
trousers (TPM)
libunbound (DANE)

JSSE

| Java

|

MatrixSSL

| none

| zlib (compression)

MatrixSSL-open

| libc or newlib

|

Mbed TLS

| libc

| libpkcs11-helper (PKCS #11)
zlib (compression)

NSS

| libc
libnspr4
libsoftokn3
libplc4
libplds4

| zlib (compression)

Rustls

| rust {{mono|core}} library

| rust {{mono|std}} library
zlib-rs (compression)
brotli (compression)
ring (cryptography)
aws-lc-rs (cryptography)

OpenSSL

| libc

| zlib (compression)
brotli (compression)
zstd (compression)

wolfSSL

| None

| libc
zlib (compression)

Erlang/OTP SSL application

| libcrypto (from OpenSSL), Erlang/OTP and its public_key, crypto and asn1 applications

| Erlang/OTP -inets (http fetching of CRLs)

class="sortbottom"

! Implementation

! Dependencies

! Optional dependencies

Development environment

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! Namespace

! Build tools

! API manual

! Crypto back-end

! {{clarify span|OpenSSL compatibility Layer|date=November 2013}}

Botan

| Botan::TLS

| Makefile

| Sphinx

| Included (pluggable)

| {{no}}

Bouncy Castle

| org.bouncycastle

| Java Development Environment

| Programmers reference manual (PDF)

| Included (pluggable)

| {{no}}

BSAFE SSL-J

|com.rsa.asn1{{cref2|group=dev_env_footnotes|a}}

com.rsa.certj{{cref2|group=dev_env_footnotes|b}}

com.rsa.jcp{{cref2|group=dev_env_footnotes|c}}

com.rsa.jsafe{{cref2|group=dev_env_footnotes|d}}

com.rsa.ssl{{cref2|group=dev_env_footnotes|e}}

com.rsa.jsse{{cref2|group=dev_env_footnotes|f}}

| Java class loader

| Javadoc, Developer's guide (HTML)

| Included

| {{no}}

cryptlib

| crypt*

| makefile, MSVC project workspaces

| Programmers reference manual (PDF), architecture design manual (PDF)

| Included (monolithic)

| {{no}}

GnuTLS

| gnutls_*

| Autoconf, automake, libtool

| Manual and API reference (HTML, PDF)

| External, libnettle

| {{yes}} (limited)

JSSE

| javax.net.ssl

sun.security.ssl

| Makefile

| API Reference (HTML) +

{{Javadoc:SE-guide|security/jsse/JSSERefGuide.html|JSSE Reference Guide}}

| Java Cryptography Architecture,
Java Cryptography Extension

| {{No}}

MatrixSSL

| matrixSsl_*

ps*

| Makefile, MSVC project workspaces, Xcode projects for OS X and iOS

| API Reference (PDF), Integration Guide

| Included (pluggable)

| {{yes}} (Subset: SSL_read, SSL_write, etc.)

Mbed TLS

| mbedtls_ssl_*

mbedtls_sha1_*

mbedtls_md5_*

mbedtls_x509*

...

| Makefile, CMake, MSVC project workspaces, yotta

| API Reference + High Level and Module Level Documentation (HTML)

| Included (monolithic)

| {{no}}

NSS

| CERT_*

SEC_*

SECKEY_*

NSS_*

PK11_*

SSL_*

...

| Makefile

| Manual (HTML)

| Included, PKCS#11 basedOn the fly replaceable/augmentable.

| {{yes}} (separate package called nss_compat_ossl{{cite web|url=http://fedoraproject.org/wiki/Nss_compat_ossl|title=Nss compat ossl - Fedora Project Wiki|website=fedoraproject.org}})

OpenSSL

| SSL_*

SHA1_*

MD5_*

EVP_*

...

| Makefile

| Man pages

| Included (monolithic)

| {{N/a}}

Rustls

| {{code|rustls::}}

| cargo

| [https://docs.rs/rustls/0.23.12/rustls/ API reference] and [https://docs.rs/rustls/0.23.12/rustls/manual/ design manual]

| Two options included (pluggable)

| {{yes}}{{cite web|url=https://github.com/rustls/rustls-openssl-compat/|title=rustls-openssl compatibility layer|website=GitHub |accessdate=2024-08-29}} (subset)

wolfSSL

| wolfSSL_*

CyaSSL_*

SSL_*

| Autoconf, automake, libtool, MSVC project workspaces, XCode projects, CodeWarrior projects, MPLAB X projects, Keil, IAR, Clang, GCC, e2Studio

| Manual and API Reference (HTML, PDF)

| Included (monolithic)

| {{yes}} (about 60% of API)

class="sortbottom"

! Implementation

! Namespace

! Build tools

! API manual

! Crypto back-end

! OpenSSL compatibility layer

{{cnote2 begin | liststyle=lower-alpha}}

{{cnote2 | group=dev_env_footnotes| a | ASN.1 manipulation classes}}

{{cnote2 | group=dev_env_footnotes| b | Cert-J proprietary API}}

{{cnote2 | group=dev_env_footnotes| c | Certificate Path manipulation classes}}

{{cnote2 | group=dev_env_footnotes| d | Crypto-J proprietary API, JCE, CMS and PKI}} API

{{cnote2 | group=dev_env_footnotes| e | SSLJ proprietary API}}

{{cnote2 | group=dev_env_footnotes| f | JSSE API}}

{{cnote2 end}}

Portability concerns

class="wikitable sortable sort-under" style="text-align: left; font-size: smaller"
Implementation

! Platform requirements

! Network requirements

! Thread safety

! Random seed

! Able to cross-compile

! No OS (bare metal)

! Supported operating systems

Botan

| C++11

| None

| {{yes|Thread-safe}}

| Platform-dependent

| {{yes}}

|

| Windows, Linux, macOS, Android, iOS, FreeBSD, OpenBSD, Solaris, AIX, HP-UX, QNX, BeOS, IncludeOS

BSAFE SSL-J

| Java

| Java SE network components

| {{yes|Thread-safe}}

| Depends on java.security.SecureRandom

| {{yes}}

| {{no}}

| FreeBSD, Linux, macOS, Microsoft Windows, Android, AIX, Solaris

cryptlib

| C89

| POSIX send() and recv(). API to supply your own replacement

| {{yes|Thread-safe}}

| Platform-dependent, including hardware sources

| {{yes}}

| {{yes}}

| AMX, BeOS, ChorusOS, DOS, eCos, FreeRTOS/OpenRTOS, uItron, MVS, OS/2, Palm OS, QNX Neutrino, RTEMS, Tandem NonStop, ThreadX, uC/OS II, Unix (AIX, FreeBSD, HPUX, Linux, macOS, Solaris, etc.), VDK, VM/CMS, VxWorks, Win16, Win32, Win64, WinCE/PocketPC/etc, XMK

GnuTLS

| C89

| POSIX send() and recv(). API to supply your own replacement.

| {{partial|Thread-safe, needs custom mutex hooks if neither POSIX nor Windows threads are available.}}

| Platform dependent

| {{yes}}

| {{no}}

| Generally any POSIX platforms or Windows, commonly tested platforms include Linux, Win32/64, macOS, Solaris, OpenWRT, FreeBSD, NetBSD, OpenBSD.

JSSE

| Java

| Java SE network components

| {{yes|Thread-safe}}

| Depends on java.security.SecureRandom

| {{yes}}

|

| Java based, platform-independent

MatrixSSL

| C89

| None

| {{yes|Thread-safe}}

| Platform dependent

| {{yes}}

| {{yes}}

| All

Mbed TLS

| C89

| POSIX read() and write(). API to supply your own replacement.

| {{partial|Threading layer available (POSIX or own hooks)}}

| Random seed set through entropy pool

| {{yes}}

| {{yes}}

| Known to work on: Win32/64, Linux, macOS, Solaris, FreeBSD, NetBSD, OpenBSD, OpenWRT, iPhone (iOS), Xbox, Android, eCos, SeggerOS, RISC OS

NSS

| C89, NSPR{{cite web|url=https://www.mozilla.org/projects/nspr/|title=NSPR|website=Mozilla Developer Network}}

| NSPR PR_Send() and PR_Recv(). API to supply your own replacement.

| {{yes|Thread-safe}}

| Platform dependentFor Unix/Linux it uses /dev/urandom if available, for Windows it uses CAPI. For other platforms it gets data from clock, and tries to open system files. NSS has a set of platform dependent functions it uses to determine randomness.

| {{yes}} (but cumbersome)

| {{no}}

| AIX, Android, FreeBSD, NetBSD, OpenBSD, BeOS, HP-UX, IRIX, Linux, macOS, OS/2, Solaris, OpenVMS, Amiga DE, Windows, WinCE, Sony PlayStation

Rustls

| Rust (programming language)

| None

| {{yes|Thread-safe}}

| Platform dependent

| {{yes}}

| {{yes}}

| All supported by Rust (programming language)

OpenSSL

| C89

| None

| {{yes|Thread-safe}}

| Platform dependent

| {{yes}}

| {{no}}

| Unix-like, DOS (with djgpp), Windows, OpenVMS, NetWare, eCos

wolfSSL

| C89

| POSIX send() and recv(). API to supply your own replacement.

| {{yes|Thread-safe}}

| Random seed set through wolfCrypt

| {{yes}}

| {{yes}}

| Win32/64, Linux, macOS, Solaris, ThreadX, VxWorks, FreeBSD, NetBSD, OpenBSD, embedded Linux, Yocto Project, OpenEmbedded, WinCE, Haiku, OpenWRT, iPhone (iOS), Android, Nintendo Wii and Gamecube through DevKitPro, QNX, MontaVista, NonStop, TRON/ITRON/μITRON, eCos, Micrium μC/OS-III, FreeRTOS, SafeRTOS, NXP/Freescale MQX, Nucleus, TinyOS, HP/UX, AIX, ARC MQX, Keil RTX, TI-RTOS, uTasker, embOS, INtime, Mbed, uT-Kernel, RIOT, CMSIS-RTOS, FROSTED, Green Hills INTEGRITY, TOPPERS, PetaLinux, Apache mynewt

class="sortbottom"

! Implementation

! Platform requirements

! Network requirements

! Thread safety

! Random seed

! Able to cross-compile

! No OS (bare metal)

! Supported operating systems

See also

  • SCTP — with DTLS support
  • DCCP — with DTLS support
  • SRTP — with DTLS support (DTLS-SRTP) and Secure Real-Time Transport Control Protocol (SRTCP)

References

{{Reflist|30em}}

{{SSL/TLS}}

{{DEFAULTSORT:Comparison Of TLS implementations}}

Category:Cryptographic software

TLS implementations