Skip to content

Commit

Permalink
Add P-384 and X448 combined with ML-KEM-1024
Browse files Browse the repository at this point in the history
  • Loading branch information
tomato42 committed Sep 9, 2024
1 parent 2128d6c commit de4bde7
Showing 1 changed file with 97 additions and 10 deletions.
107 changes: 97 additions & 10 deletions draft-kwiatkowski-tls-ecdhe-mlkem.md
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,8 @@ informative:
ANSI: ANS X9.62-2005
--- abstract

This draft defines two hybrid key agreements for TLS 1.3: X25519MLKEM768 and SecP256r1MLKEM768, which combine
This draft defines four hybrid key agreements for TLS 1.3: X25519MLKEM768,
SecP256r1MLKEM768, X448MLKEM1024, and SecP384r1MLKEM1024 which combine
a post-quantum KEM with an elliptic curve Diffie-Hellman (ECDHE).

--- middle
Expand All @@ -74,9 +75,10 @@ a post-quantum KEM with an elliptic curve Diffie-Hellman (ECDHE).
ML-KEM is a key encapsulation method (KEM) defined in the {{FIPS203}}. It is designed to
withstand cryptanalytic attacks from quantum computers.

This document introduces two new supported groups for hybrid post-quantum key
agreements in TLS 1.3: X25519MLKEM768 and SecP256r1MLKEM768. Both combine ML-KEM-768 with
ECDH in the manner of {{hybrid}}.
This document introduces four new supported groups for hybrid post-quantum key
agreements in TLS 1.3: the X25519MLKEM768, SecP256r1MLKEM768,
X448MLKEM1024, and SecP384r1MLKEM1024 which combine ML-KEM with ECDH
in the manner of {{hybrid}}.

The first one uses X25519 {{rfc7748}} and is an update to X25519Kyber768Draft00 {{xyber}}, the
most widely deployed PQ/T hybrid combiner for TLS v1.3 deployed in 2024.
Expand All @@ -85,22 +87,30 @@ The second one uses secp256r1 (NIST P-256) {{ECDSA}} {{?DSS=DOI.10.6028/NIST.SP.
goal of this group is to support a use case that requires both shared secrets to be generated by
FIPS-approved mechanisms.

Both constructions aim to provide a FIPS-approved key-establishment scheme (as per {{SP56C}}).
The third one uses X448 {{rfc7748}}, as a higher security alternative to the
X25519.

The fourth one uses secp384r1 (NIST P-384) {{ECDSA}} {{?DSS=DOI.10.6028/NIST.SP.800-186}}.
The goal of this group is to provide support for high security environments
that require use of FIPS-approved mechanisms.

All constructions aim to provide a FIPS-approved key-establishment scheme (as per {{SP56C}}).

# Conventions and Definitions

{::boilerplate bcp14-tagged}

# Negotiated Groups

Both groups enable the derivation of TLS session keys using FIPS-approved schemes. NIST's
All groups enable the derivation of TLS session keys using FIPS-approved schemes. NIST's
special publication 800-56Cr2 {{SP56C}} approves the usage of HKDF
{{HKDF}} with two distinct shared secrets, with the condition that the first one is computed by
a FIPS-approved key-establishment scheme. FIPS also requires a certified implementation
of the scheme, which will remain more ubiqutous for secp256r1 in the coming years.

For this reason we put the ML-KEM-768 shared secret first in X25519MLKEM768,
and the secp256r1 shared secret first in SecP256r1MLKEM768.
For this reason we put the ML-KEM shared secret first in X25519MLKEM768
and X448MLKEM1024,
and the secp256r1 shared secret first in SecP256r1MLKEM768 and SecP384r1MLKEM1024.

## Construction

Expand All @@ -117,6 +127,18 @@ The ECDHE share is the serialized value of the uncompressed ECDH point represent
defined in Section 4.2.8.2 of {{!RFC8446}}. The size of the client share is 1249 bytes
(65 bytes for the secp256r1 part and 1184 bytes for ML-KEM).

When the X448MLKEM1024 group is negotiated, the client's key_exchange value
is the concatenation of the client's ML-KEM-1024 encapsulation key
and the client's X448 ephemeral share.
The size of the client share is 1624 bytes (1568 bytes for the ML-KEM part
and 56 bytes for the X448).

When the SecP384r1MLKEM1024 group is negotiated, the client's key_exchange value
is the concatenation of the secp384r1 ephemeral share and the ML-KEM-1024
encapsulation key. The ECDH share is serialised value of the uncompressed ECDH point
represenation as defined in Section 4.2.8.2 of {{!RFC8446}}. The size of the
client share is 1665 bytes (97 bytes for the secp384r1 and the 1568 for the ML-KEM).

### Server share

When the X25519MLKEM768 group is negotiated, the server's key exchange
Expand All @@ -130,7 +152,20 @@ in the same way as the client share and an ML-KEM ciphertext returned from encap
to the client's encapsulation key. The size of the server share is 1153 bytes (1088 bytes
for the ML-KEM part and 65 bytes for secp256r1).

For both groups, the server MUST perform the encapsulation key check
When the X448MLKEM1024 group is negotiated, the server's key exchange
value is the concatenation of an ML-KEM ciphertext returned from encapsulation
to the client's encapsulation key, and the server's ephemeral X448 share.
The size of the server share is 1624 bytes (1568 bytes for the ML-KEM part
and 56 bytes for X448).

When the SecP384r1MLKEM1024 group is negotiated, the server's key exchange
value is the concatenation of the server's ephemeral secp384r1 share
encoded in the same way as the client share and an ML-KEM ciphertext returned
from encapsulation to the client's encapsulation key. The size of the server
share is 1665 bytes (1568 bytes for the ML-KEM part and 97 bytes for
secp384r1)

For all groups, the server MUST perform the encapsulation key check
described in Section 7.2 of {{FIPS203}} on the client's encapsulation
key, and abort with an illegal_parameter alert if it fails.

Expand All @@ -146,6 +181,17 @@ shared secret elliptic curve point represented as an octet string as
defined in Section 7.4.2 of {{!RFC8446}}.
The size of the shared secret is 64 bytes (32 bytes for each part).

For X448MLKEM1024, the shared secret is the concatenation of the ML-KEM
shared secret and the X448 shared secret. The shared secret is 88 bytes
(56 bytes for the X448 part and 32 bytes for the ML-KEM part.

For SecP384r1MLKEM1024, the shared secret is the concatenation of the
ECDHE and ML-KEM shared secret. The ECDHE shared secret is the x-coordinate of the ECDH
shared secret elliptic curve point represented as an octet string as
defined in Section 7.4.2 of {{!RFC8446}}.
The size of the shared secret is 80 bytes (48 bytes for the ECDH part and
32 bytes for the ML-KEM part).

# Security Considerations

The same security considerations as those described in {{hybrid}} apply to the approach used by this document.
Expand All @@ -157,7 +203,7 @@ especially those that can be applied by remote attackers.

# IANA Considerations

This document requests/registers two new entries to the TLS Supported Groups registry, according
This document requests/registers four new entries to the TLS Supported Groups registry, according
to the procedures in {{Section 6 of tlsiana}}. These identifiers are to be used with the final,
ratified by NIST, version of ML-KEM which is specified in {{FIPS203}}.

Expand Down Expand Up @@ -201,6 +247,47 @@ ratified by NIST, version of ML-KEM which is specified in {{FIPS203}}.
Comment:
: Combining X25519 ECDH with ML-KEM-768

## SecP384r1MLKEM1024

Value:
: 4589 (0x11ED)

Description:
: SecP384r1MLKEM1024

DTLS-OK:
: Y

Recommended:
: N

Reference:
: This document

Comment:
: Combining secp384r1 ECDH with ML-KEM-1024

## X448MLKEM1024

Value:
: 4590 (0x11EE)

Description:
: X448MLKEM1024

DTLS-OK:
: Y

Recommended:
: N

Reference:
: This document

Comment:
: Combining X448 ECDH with ML-KEM-1024


## Obsoleted Supported Groups

This document obsoletes 25497 and 25498 in the TLS Supported Groups registry.
Expand Down

0 comments on commit de4bde7

Please sign in to comment.