ML-KEM#
In ML-KEM, the size of the public and private keys, the ciphertext, and shared secret is fixed. These values are still passed to the implementation, but if the implementation you are testing doesn’t require them, that may be the reason why.
Parameter set |
Private key |
Public Key |
Ciphertext |
Shared secret |
---|---|---|---|---|
|
1632 |
800 |
768 |
32 |
|
2400 |
1184 |
1088 |
32 |
|
3168 |
1568 |
1568 |
32 |
Encapsulation#
To test a function that encapsulates with ML-KEM, its name must conform to the following convention:
CC_MLKEM_<param set>_encaps
Its signature must be:
- void MLKEM_encaps(
- uint8_t *ct,
- size_t ctlen,
- uint8_t *ss,
- size_t sslen,
- const uint8_t *pk,
- size_t pklen,
- Parameters:
ct – [Out] A buffer to store the resulting ciphertext.
ctlen – [In] The size of the ciphertext buffer.
ss – [Out] A buffer to store the shared secret.
sslen – [In] The size of the shared secret buffer.
pk – [In] The public key.
pklen – [In] The size of the public key.
Examples:
ML-KEM-512:
void CC_MLKEM_512_encaps(uint8_t *ct, size_t ctlen,
uint8_t *ss, size_t sslen,
const uint8_t *pk, size_t pklen);
Decapsulation#
To test a function that decapsulates with ML-KEM, its name must conform to the following convention:
CC_MLKEM_<param set>_decaps
Its signature must be:
- int MLKEM_decaps(
- uint8_t *ss,
- size_t sslen,
- const uint8_t *ct,
- size_t ctlen,
- const uint8_t *pk,
- size_t pklen,
- Parameters:
ss – [Out] A buffer to store the decapsulated shared secret.
sslen – [In] The size of the shared secret buffer.
ct – [In] The ciphertext to decapsulate.
ctlen – [In] The size of the ciphertext.
sk – [In] The secret key.
sklen – [In] The size of the secret key.
Examples:
ML-KEM-512:
void CC_MLKEM_512_decaps(uint8_t *ss, size_t sslen,
const uint8_t *ct, size_t ctlen,
const uint8_t *sk, size_t sklen);