| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 1 | /* | 
|  | 2 | *  TLS 1.3 key schedule | 
|  | 3 | * | 
|  | 4 | *  Copyright The Mbed TLS Contributors | 
| Dave Rodgman | 16799db | 2023-11-02 19:47:20 +0000 | [diff] [blame] | 5 | *  SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 6 | */ | 
|  | 7 | #if !defined(MBEDTLS_SSL_TLS1_3_KEYS_H) | 
|  | 8 | #define MBEDTLS_SSL_TLS1_3_KEYS_H | 
|  | 9 |  | 
| Hanno Becker | 70d7fb0 | 2020-09-09 10:11:21 +0100 | [diff] [blame] | 10 | /* This requires MBEDTLS_SSL_TLS1_3_LABEL( idx, name, string ) to be defined at | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 11 | * the point of use. See e.g. the definition of mbedtls_ssl_tls13_labels_union | 
| Hanno Becker | a3a5a4e | 2020-09-08 11:33:48 +0100 | [diff] [blame] | 12 | * below. */ | 
| Jerry Yu | 0bbb397 | 2021-09-19 20:27:17 +0800 | [diff] [blame] | 13 | #define MBEDTLS_SSL_TLS1_3_LABEL_LIST                                             \ | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 14 | MBEDTLS_SSL_TLS1_3_LABEL(finished, "finished") \ | 
|  | 15 | MBEDTLS_SSL_TLS1_3_LABEL(resumption, "resumption") \ | 
|  | 16 | MBEDTLS_SSL_TLS1_3_LABEL(traffic_upd, "traffic upd") \ | 
|  | 17 | MBEDTLS_SSL_TLS1_3_LABEL(exporter, "exporter") \ | 
|  | 18 | MBEDTLS_SSL_TLS1_3_LABEL(key, "key") \ | 
|  | 19 | MBEDTLS_SSL_TLS1_3_LABEL(iv, "iv") \ | 
|  | 20 | MBEDTLS_SSL_TLS1_3_LABEL(c_hs_traffic, "c hs traffic") \ | 
|  | 21 | MBEDTLS_SSL_TLS1_3_LABEL(c_ap_traffic, "c ap traffic") \ | 
|  | 22 | MBEDTLS_SSL_TLS1_3_LABEL(c_e_traffic, "c e traffic") \ | 
|  | 23 | MBEDTLS_SSL_TLS1_3_LABEL(s_hs_traffic, "s hs traffic") \ | 
|  | 24 | MBEDTLS_SSL_TLS1_3_LABEL(s_ap_traffic, "s ap traffic") \ | 
|  | 25 | MBEDTLS_SSL_TLS1_3_LABEL(s_e_traffic, "s e traffic") \ | 
|  | 26 | MBEDTLS_SSL_TLS1_3_LABEL(e_exp_master, "e exp master") \ | 
|  | 27 | MBEDTLS_SSL_TLS1_3_LABEL(res_master, "res master") \ | 
|  | 28 | MBEDTLS_SSL_TLS1_3_LABEL(exp_master, "exp master") \ | 
|  | 29 | MBEDTLS_SSL_TLS1_3_LABEL(ext_binder, "ext binder") \ | 
|  | 30 | MBEDTLS_SSL_TLS1_3_LABEL(res_binder, "res binder") \ | 
|  | 31 | MBEDTLS_SSL_TLS1_3_LABEL(derived, "derived") \ | 
|  | 32 | MBEDTLS_SSL_TLS1_3_LABEL(client_cv, "TLS 1.3, client CertificateVerify") \ | 
|  | 33 | MBEDTLS_SSL_TLS1_3_LABEL(server_cv, "TLS 1.3, server CertificateVerify") | 
| Hanno Becker | e4435ea | 2020-09-08 10:43:52 +0100 | [diff] [blame] | 34 |  | 
| Gabor Mezei | e42d8bf | 2022-03-30 11:33:06 +0200 | [diff] [blame] | 35 | #define MBEDTLS_SSL_TLS1_3_CONTEXT_UNHASHED 0 | 
|  | 36 | #define MBEDTLS_SSL_TLS1_3_CONTEXT_HASHED   1 | 
|  | 37 |  | 
|  | 38 | #define MBEDTLS_SSL_TLS1_3_PSK_EXTERNAL   0 | 
|  | 39 | #define MBEDTLS_SSL_TLS1_3_PSK_RESUMPTION 1 | 
|  | 40 |  | 
|  | 41 | #if defined(MBEDTLS_SSL_PROTO_TLS1_3) | 
|  | 42 |  | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 43 | #define MBEDTLS_SSL_TLS1_3_LABEL(name, string)       \ | 
|  | 44 | const unsigned char name    [sizeof(string) - 1]; | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 45 |  | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 46 | union mbedtls_ssl_tls13_labels_union { | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 47 | MBEDTLS_SSL_TLS1_3_LABEL_LIST | 
|  | 48 | }; | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 49 | struct mbedtls_ssl_tls13_labels_struct { | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 50 | MBEDTLS_SSL_TLS1_3_LABEL_LIST | 
|  | 51 | }; | 
| Hanno Becker | a3a5a4e | 2020-09-08 11:33:48 +0100 | [diff] [blame] | 52 | #undef MBEDTLS_SSL_TLS1_3_LABEL | 
| Hanno Becker | e4435ea | 2020-09-08 10:43:52 +0100 | [diff] [blame] | 53 |  | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 54 | extern const struct mbedtls_ssl_tls13_labels_struct mbedtls_ssl_tls13_labels; | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 55 |  | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 56 | #define MBEDTLS_SSL_TLS1_3_LBL_LEN(LABEL)  \ | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 57 | sizeof(mbedtls_ssl_tls13_labels.LABEL) | 
| Jerry Yu | 0bbb397 | 2021-09-19 20:27:17 +0800 | [diff] [blame] | 58 |  | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 59 | #define MBEDTLS_SSL_TLS1_3_LBL_WITH_LEN(LABEL)  \ | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 60 | mbedtls_ssl_tls13_labels.LABEL,              \ | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 61 | MBEDTLS_SSL_TLS1_3_LBL_LEN(LABEL) | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 62 |  | 
| Max Fillinger | 5826883 | 2024-11-25 20:38:04 +0100 | [diff] [blame] | 63 | /* Maximum length of the label field in the HkdfLabel struct defined in | 
|  | 64 | * RFC 8446, Section 7.1, excluding the "tls13 " prefix. */ | 
|  | 65 | #define MBEDTLS_SSL_TLS1_3_HKDF_LABEL_MAX_LABEL_LEN 249 | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 66 |  | 
| Hanno Becker | 61baae7 | 2020-09-16 09:24:14 +0100 | [diff] [blame] | 67 | /* The maximum length of HKDF contexts used in the TLS 1.3 standard. | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 68 | * Since contexts are always hashes of message transcripts, this can | 
|  | 69 | * be approximated from above by the maximum hash size. */ | 
|  | 70 | #define MBEDTLS_SSL_TLS1_3_KEY_SCHEDULE_MAX_CONTEXT_LEN  \ | 
| Przemyslaw Stekiel | ab9b9d4 | 2022-09-14 13:51:07 +0200 | [diff] [blame] | 71 | PSA_HASH_MAX_SIZE | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 72 |  | 
|  | 73 | /* Maximum desired length for expanded key material generated | 
| Max Fillinger | 28916ac | 2024-10-29 18:49:30 +0100 | [diff] [blame] | 74 | * by HKDF-Expand-Label. This algorithm can output up to 255 * hash_size | 
|  | 75 | * bytes of key material where hash_size is the output size of the | 
|  | 76 | * underlying hash function. */ | 
|  | 77 | #define MBEDTLS_SSL_TLS1_3_KEY_SCHEDULE_MAX_EXPANSION_LEN \ | 
|  | 78 | (255 * MBEDTLS_TLS1_3_MD_MAX_SIZE) | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 79 |  | 
|  | 80 | /** | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 81 | * \brief            The \c HKDF-Expand-Label function from | 
|  | 82 | *                   the TLS 1.3 standard RFC 8446. | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 83 | * | 
|  | 84 | * <tt> | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 85 | *                   HKDF-Expand-Label( Secret, Label, Context, Length ) = | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 86 | *                       HKDF-Expand( Secret, HkdfLabel, Length ) | 
|  | 87 | * </tt> | 
|  | 88 | * | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 89 | * \param hash_alg   The identifier for the hash algorithm to use. | 
|  | 90 | * \param secret     The \c Secret argument to \c HKDF-Expand-Label. | 
| Xiaofei Bai | d25fab6 | 2021-12-02 06:36:27 +0000 | [diff] [blame] | 91 | *                   This must be a readable buffer of length | 
|  | 92 | *                   \p secret_len Bytes. | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 93 | * \param secret_len The length of \p secret in Bytes. | 
|  | 94 | * \param label      The \c Label argument to \c HKDF-Expand-Label. | 
| Xiaofei Bai | d25fab6 | 2021-12-02 06:36:27 +0000 | [diff] [blame] | 95 | *                   This must be a readable buffer of length | 
|  | 96 | *                   \p label_len Bytes. | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 97 | * \param label_len  The length of \p label in Bytes. | 
|  | 98 | * \param ctx        The \c Context argument to \c HKDF-Expand-Label. | 
| Xiaofei Bai | d25fab6 | 2021-12-02 06:36:27 +0000 | [diff] [blame] | 99 | *                   This must be a readable buffer of length \p ctx_len Bytes. | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 100 | * \param ctx_len    The length of \p context in Bytes. | 
|  | 101 | * \param buf        The destination buffer to hold the expanded secret. | 
| Xiaofei Bai | d25fab6 | 2021-12-02 06:36:27 +0000 | [diff] [blame] | 102 | *                   This must be a writable buffer of length \p buf_len Bytes. | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 103 | * \param buf_len    The desired size of the expanded secret in Bytes. | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 104 | * | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 105 | * \returns          \c 0 on success. | 
|  | 106 | * \return           A negative error code on failure. | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 107 | */ | 
|  | 108 |  | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 109 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 110 | int mbedtls_ssl_tls13_hkdf_expand_label( | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 111 | psa_algorithm_t hash_alg, | 
|  | 112 | const unsigned char *secret, size_t secret_len, | 
|  | 113 | const unsigned char *label, size_t label_len, | 
|  | 114 | const unsigned char *ctx, size_t ctx_len, | 
|  | 115 | unsigned char *buf, size_t buf_len); | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 116 |  | 
| Hanno Becker | 3385a4d | 2020-08-21 13:03:34 +0100 | [diff] [blame] | 117 | /** | 
|  | 118 | * \brief           This function is part of the TLS 1.3 key schedule. | 
|  | 119 | *                  It extracts key and IV for the actual client/server traffic | 
|  | 120 | *                  from the client/server traffic secrets. | 
|  | 121 | * | 
|  | 122 | * From RFC 8446: | 
|  | 123 | * | 
|  | 124 | * <tt> | 
|  | 125 | *   [sender]_write_key = HKDF-Expand-Label(Secret, "key", "", key_length) | 
|  | 126 | *   [sender]_write_iv  = HKDF-Expand-Label(Secret, "iv", "", iv_length)* | 
|  | 127 | * </tt> | 
|  | 128 | * | 
|  | 129 | * \param hash_alg      The identifier for the hash algorithm to be used | 
|  | 130 | *                      for the HKDF-based expansion of the secret. | 
|  | 131 | * \param client_secret The client traffic secret. | 
| Xiaofei Bai | d25fab6 | 2021-12-02 06:36:27 +0000 | [diff] [blame] | 132 | *                      This must be a readable buffer of size | 
|  | 133 | *                      \p secret_len Bytes | 
| Hanno Becker | 3385a4d | 2020-08-21 13:03:34 +0100 | [diff] [blame] | 134 | * \param server_secret The server traffic secret. | 
| Xiaofei Bai | d25fab6 | 2021-12-02 06:36:27 +0000 | [diff] [blame] | 135 | *                      This must be a readable buffer of size | 
|  | 136 | *                      \p secret_len Bytes | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 137 | * \param secret_len    Length of the secrets \p client_secret and | 
| Hanno Becker | 3385a4d | 2020-08-21 13:03:34 +0100 | [diff] [blame] | 138 | *                      \p server_secret in Bytes. | 
| Hanno Becker | 493ea7f | 2020-09-08 11:01:00 +0100 | [diff] [blame] | 139 | * \param key_len       The desired length of the key to be extracted in Bytes. | 
|  | 140 | * \param iv_len        The desired length of the IV to be extracted in Bytes. | 
| Hanno Becker | 3385a4d | 2020-08-21 13:03:34 +0100 | [diff] [blame] | 141 | * \param keys          The address of the structure holding the generated | 
|  | 142 | *                      keys and IVs. | 
|  | 143 | * | 
|  | 144 | * \returns             \c 0 on success. | 
|  | 145 | * \returns             A negative error code on failure. | 
|  | 146 | */ | 
|  | 147 |  | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 148 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 149 | int mbedtls_ssl_tls13_make_traffic_keys( | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 150 | psa_algorithm_t hash_alg, | 
|  | 151 | const unsigned char *client_secret, | 
|  | 152 | const unsigned char *server_secret, size_t secret_len, | 
|  | 153 | size_t key_len, size_t iv_len, | 
|  | 154 | mbedtls_ssl_key_set *keys); | 
| Hanno Becker | 3385a4d | 2020-08-21 13:03:34 +0100 | [diff] [blame] | 155 |  | 
| Hanno Becker | b35d522 | 2020-08-21 13:27:44 +0100 | [diff] [blame] | 156 | /** | 
|  | 157 | * \brief The \c Derive-Secret function from the TLS 1.3 standard RFC 8446. | 
|  | 158 | * | 
|  | 159 | * <tt> | 
|  | 160 | *   Derive-Secret( Secret, Label, Messages ) = | 
|  | 161 | *      HKDF-Expand-Label( Secret, Label, | 
|  | 162 | *                         Hash( Messages ), | 
|  | 163 | *                         Hash.Length ) ) | 
|  | 164 | * </tt> | 
|  | 165 | * | 
| Hanno Becker | 0c42fd9 | 2020-09-09 12:58:29 +0100 | [diff] [blame] | 166 | * \param hash_alg   The identifier for the hash function used for the | 
|  | 167 | *                   applications of HKDF. | 
|  | 168 | * \param secret     The \c Secret argument to the \c Derive-Secret function. | 
| Xiaofei Bai | d25fab6 | 2021-12-02 06:36:27 +0000 | [diff] [blame] | 169 | *                   This must be a readable buffer of length | 
|  | 170 | *                   \p secret_len Bytes. | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 171 | * \param secret_len The length of \p secret in Bytes. | 
| Hanno Becker | 0c42fd9 | 2020-09-09 12:58:29 +0100 | [diff] [blame] | 172 | * \param label      The \c Label argument to the \c Derive-Secret function. | 
| Xiaofei Bai | d25fab6 | 2021-12-02 06:36:27 +0000 | [diff] [blame] | 173 | *                   This must be a readable buffer of length | 
|  | 174 | *                   \p label_len Bytes. | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 175 | * \param label_len  The length of \p label in Bytes. | 
| Hanno Becker | 0c42fd9 | 2020-09-09 12:58:29 +0100 | [diff] [blame] | 176 | * \param ctx        The hash of the \c Messages argument to the | 
|  | 177 | *                   \c Derive-Secret function, or the \c Messages argument | 
| Xiaofei Bai | d25fab6 | 2021-12-02 06:36:27 +0000 | [diff] [blame] | 178 | *                   itself, depending on \p ctx_hashed. | 
|  | 179 | * \param ctx_len    The length of \p ctx in Bytes. | 
| Hanno Becker | 0c42fd9 | 2020-09-09 12:58:29 +0100 | [diff] [blame] | 180 | * \param ctx_hashed This indicates whether the \p ctx contains the hash of | 
|  | 181 | *                   the \c Messages argument in the application of the | 
|  | 182 | *                   \c Derive-Secret function | 
|  | 183 | *                   (value MBEDTLS_SSL_TLS1_3_CONTEXT_HASHED), or whether | 
|  | 184 | *                   it is the content of \c Messages itself, in which case | 
|  | 185 | *                   the function takes care of the hashing | 
|  | 186 | *                   (value MBEDTLS_SSL_TLS1_3_CONTEXT_UNHASHED). | 
|  | 187 | * \param dstbuf     The target buffer to write the output of | 
|  | 188 | *                   \c Derive-Secret to. This must be a writable buffer of | 
| Xiaofei Bai | d25fab6 | 2021-12-02 06:36:27 +0000 | [diff] [blame] | 189 | *                   size \p dtsbuf_len Bytes. | 
| Xiaofei Bai | 89b526d | 2021-11-23 06:31:16 +0000 | [diff] [blame] | 190 | * \param dstbuf_len The length of \p dstbuf in Bytes. | 
| Hanno Becker | b35d522 | 2020-08-21 13:27:44 +0100 | [diff] [blame] | 191 | * | 
|  | 192 | * \returns        \c 0 on success. | 
|  | 193 | * \returns        A negative error code on failure. | 
|  | 194 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 195 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 196 | int mbedtls_ssl_tls13_derive_secret( | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 197 | psa_algorithm_t hash_alg, | 
|  | 198 | const unsigned char *secret, size_t secret_len, | 
|  | 199 | const unsigned char *label, size_t label_len, | 
|  | 200 | const unsigned char *ctx, size_t ctx_len, | 
|  | 201 | int ctx_hashed, | 
|  | 202 | unsigned char *dstbuf, size_t dstbuf_len); | 
| Hanno Becker | b35d522 | 2020-08-21 13:27:44 +0100 | [diff] [blame] | 203 |  | 
| Hanno Becker | e9cccb4 | 2020-08-20 13:42:46 +0100 | [diff] [blame] | 204 | /** | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 205 | * \brief Derive TLS 1.3 early data key material from early secret. | 
|  | 206 | * | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 207 | *        This is a small wrapper invoking mbedtls_ssl_tls13_derive_secret() | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 208 | *        with the appropriate labels. | 
|  | 209 | * | 
|  | 210 | * <tt> | 
|  | 211 | *        Early Secret | 
|  | 212 | *             | | 
|  | 213 | *             +-----> Derive-Secret(., "c e traffic", ClientHello) | 
|  | 214 | *             |                      = client_early_traffic_secret | 
|  | 215 | *             | | 
|  | 216 | *             +-----> Derive-Secret(., "e exp master", ClientHello) | 
|  | 217 | *             .                      = early_exporter_master_secret | 
|  | 218 | *             . | 
|  | 219 | *             . | 
|  | 220 | * </tt> | 
|  | 221 | * | 
|  | 222 | * \note  To obtain the actual key and IV for the early data traffic, | 
|  | 223 | *        the client secret derived by this function need to be | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 224 | *        further processed by mbedtls_ssl_tls13_make_traffic_keys(). | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 225 | * | 
|  | 226 | * \note  The binder key, which is also generated from the early secret, | 
|  | 227 | *        is omitted here. Its calculation is part of the separate routine | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 228 | *        mbedtls_ssl_tls13_create_psk_binder(). | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 229 | * | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 230 | * \param hash_alg     The hash algorithm associated with the PSK for which | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 231 | *                     early data key material is being derived. | 
|  | 232 | * \param early_secret The early secret from which the early data key material | 
|  | 233 | *                     should be derived. This must be a readable buffer whose | 
|  | 234 | *                     length is the digest size of the hash algorithm | 
|  | 235 | *                     represented by \p md_size. | 
|  | 236 | * \param transcript   The transcript of the handshake so far, calculated with | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 237 | *                     respect to \p hash_alg. This must be a readable buffer | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 238 | *                     whose length is the digest size of the hash algorithm | 
|  | 239 | *                     represented by \p md_size. | 
|  | 240 | * \param derived      The address of the structure in which to store | 
|  | 241 | *                     the early data key material. | 
|  | 242 | * | 
|  | 243 | * \returns        \c 0 on success. | 
|  | 244 | * \returns        A negative error code on failure. | 
|  | 245 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 246 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 247 | int mbedtls_ssl_tls13_derive_early_secrets( | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 248 | psa_algorithm_t hash_alg, | 
|  | 249 | unsigned char const *early_secret, | 
|  | 250 | unsigned char const *transcript, size_t transcript_len, | 
|  | 251 | mbedtls_ssl_tls13_early_secrets *derived); | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 252 |  | 
|  | 253 | /** | 
|  | 254 | * \brief Derive TLS 1.3 handshake key material from the handshake secret. | 
|  | 255 | * | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 256 | *        This is a small wrapper invoking mbedtls_ssl_tls13_derive_secret() | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 257 | *        with the appropriate labels from the standard. | 
|  | 258 | * | 
|  | 259 | * <tt> | 
|  | 260 | *        Handshake Secret | 
|  | 261 | *              | | 
|  | 262 | *              +-----> Derive-Secret( ., "c hs traffic", | 
|  | 263 | *              |                      ClientHello...ServerHello ) | 
|  | 264 | *              |                      = client_handshake_traffic_secret | 
|  | 265 | *              | | 
|  | 266 | *              +-----> Derive-Secret( ., "s hs traffic", | 
|  | 267 | *              .                      ClientHello...ServerHello ) | 
|  | 268 | *              .                      = server_handshake_traffic_secret | 
|  | 269 | *              . | 
|  | 270 | * </tt> | 
|  | 271 | * | 
|  | 272 | * \note  To obtain the actual key and IV for the encrypted handshake traffic, | 
|  | 273 | *        the client and server secret derived by this function need to be | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 274 | *        further processed by mbedtls_ssl_tls13_make_traffic_keys(). | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 275 | * | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 276 | * \param hash_alg          The hash algorithm associated with the ciphersuite | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 277 | *                          that's being used for the connection. | 
|  | 278 | * \param handshake_secret  The handshake secret from which the handshake key | 
|  | 279 | *                          material should be derived. This must be a readable | 
|  | 280 | *                          buffer whose length is the digest size of the hash | 
|  | 281 | *                          algorithm represented by \p md_size. | 
|  | 282 | * \param transcript        The transcript of the handshake so far, calculated | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 283 | *                          with respect to \p hash_alg. This must be a readable | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 284 | *                          buffer whose length is the digest size of the hash | 
|  | 285 | *                          algorithm represented by \p md_size. | 
|  | 286 | * \param derived           The address of the structure in which to | 
|  | 287 | *                          store the handshake key material. | 
|  | 288 | * | 
|  | 289 | * \returns        \c 0 on success. | 
|  | 290 | * \returns        A negative error code on failure. | 
|  | 291 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 292 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 293 | int mbedtls_ssl_tls13_derive_handshake_secrets( | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 294 | psa_algorithm_t hash_alg, | 
|  | 295 | unsigned char const *handshake_secret, | 
|  | 296 | unsigned char const *transcript, size_t transcript_len, | 
|  | 297 | mbedtls_ssl_tls13_handshake_secrets *derived); | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 298 |  | 
|  | 299 | /** | 
|  | 300 | * \brief Derive TLS 1.3 application key material from the master secret. | 
|  | 301 | * | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 302 | *        This is a small wrapper invoking mbedtls_ssl_tls13_derive_secret() | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 303 | *        with the appropriate labels from the standard. | 
|  | 304 | * | 
|  | 305 | * <tt> | 
|  | 306 | *        Master Secret | 
|  | 307 | *              | | 
|  | 308 | *              +-----> Derive-Secret( ., "c ap traffic", | 
|  | 309 | *              |                      ClientHello...server Finished ) | 
|  | 310 | *              |                      = client_application_traffic_secret_0 | 
|  | 311 | *              | | 
|  | 312 | *              +-----> Derive-Secret( ., "s ap traffic", | 
|  | 313 | *              |                      ClientHello...Server Finished ) | 
|  | 314 | *              |                      = server_application_traffic_secret_0 | 
|  | 315 | *              | | 
|  | 316 | *              +-----> Derive-Secret( ., "exp master", | 
|  | 317 | *              .                      ClientHello...server Finished) | 
|  | 318 | *              .                      = exporter_master_secret | 
|  | 319 | *              . | 
|  | 320 | * </tt> | 
|  | 321 | * | 
|  | 322 | * \note  To obtain the actual key and IV for the (0-th) application traffic, | 
|  | 323 | *        the client and server secret derived by this function need to be | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 324 | *        further processed by mbedtls_ssl_tls13_make_traffic_keys(). | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 325 | * | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 326 | * \param hash_alg          The hash algorithm associated with the ciphersuite | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 327 | *                          that's being used for the connection. | 
|  | 328 | * \param master_secret     The master secret from which the application key | 
|  | 329 | *                          material should be derived. This must be a readable | 
|  | 330 | *                          buffer whose length is the digest size of the hash | 
|  | 331 | *                          algorithm represented by \p md_size. | 
|  | 332 | * \param transcript        The transcript of the handshake up to and including | 
|  | 333 | *                          the ServerFinished message, calculated with respect | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 334 | *                          to \p hash_alg. This must be a readable buffer whose | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 335 | *                          length is the digest size of the hash algorithm | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 336 | *                          represented by \p hash_alg. | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 337 | * \param derived           The address of the structure in which to | 
|  | 338 | *                          store the application key material. | 
|  | 339 | * | 
|  | 340 | * \returns        \c 0 on success. | 
|  | 341 | * \returns        A negative error code on failure. | 
|  | 342 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 343 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 344 | int mbedtls_ssl_tls13_derive_application_secrets( | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 345 | psa_algorithm_t hash_alg, | 
|  | 346 | unsigned char const *master_secret, | 
|  | 347 | unsigned char const *transcript, size_t transcript_len, | 
|  | 348 | mbedtls_ssl_tls13_application_secrets *derived); | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 349 |  | 
|  | 350 | /** | 
|  | 351 | * \brief Derive TLS 1.3 resumption master secret from the master secret. | 
|  | 352 | * | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 353 | *        This is a small wrapper invoking mbedtls_ssl_tls13_derive_secret() | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 354 | *        with the appropriate labels from the standard. | 
|  | 355 | * | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 356 | * \param hash_alg          The hash algorithm used in the application for which | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 357 | *                          key material is being derived. | 
|  | 358 | * \param application_secret The application secret from which the resumption master | 
|  | 359 | *                          secret should be derived. This must be a readable | 
|  | 360 | *                          buffer whose length is the digest size of the hash | 
|  | 361 | *                          algorithm represented by \p md_size. | 
|  | 362 | * \param transcript        The transcript of the handshake up to and including | 
|  | 363 | *                          the ClientFinished message, calculated with respect | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 364 | *                          to \p hash_alg. This must be a readable buffer whose | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 365 | *                          length is the digest size of the hash algorithm | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 366 | *                          represented by \p hash_alg. | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 367 | * \param transcript_len    The length of \p transcript in Bytes. | 
|  | 368 | * \param derived           The address of the structure in which to | 
|  | 369 | *                          store the resumption master secret. | 
|  | 370 | * | 
|  | 371 | * \returns        \c 0 on success. | 
|  | 372 | * \returns        A negative error code on failure. | 
|  | 373 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 374 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 375 | int mbedtls_ssl_tls13_derive_resumption_master_secret( | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 376 | psa_algorithm_t hash_alg, | 
|  | 377 | unsigned char const *application_secret, | 
|  | 378 | unsigned char const *transcript, size_t transcript_len, | 
|  | 379 | mbedtls_ssl_tls13_application_secrets *derived); | 
| Hanno Becker | ef5235b | 2021-05-24 06:39:41 +0100 | [diff] [blame] | 380 |  | 
|  | 381 | /** | 
| Hanno Becker | e9cccb4 | 2020-08-20 13:42:46 +0100 | [diff] [blame] | 382 | * \brief Compute the next secret in the TLS 1.3 key schedule | 
|  | 383 | * | 
|  | 384 | * The TLS 1.3 key schedule proceeds as follows to compute | 
|  | 385 | * the three main secrets during the handshake: The early | 
|  | 386 | * secret for early data, the handshake secret for all | 
|  | 387 | * other encrypted handshake messages, and the master | 
|  | 388 | * secret for all application traffic. | 
|  | 389 | * | 
|  | 390 | * <tt> | 
|  | 391 | *                    0 | 
|  | 392 | *                    | | 
|  | 393 | *                    v | 
|  | 394 | *     PSK ->  HKDF-Extract = Early Secret | 
|  | 395 | *                    | | 
|  | 396 | *                    v | 
|  | 397 | *     Derive-Secret( ., "derived", "" ) | 
|  | 398 | *                    | | 
|  | 399 | *                    v | 
|  | 400 | *  (EC)DHE -> HKDF-Extract = Handshake Secret | 
|  | 401 | *                    | | 
|  | 402 | *                    v | 
|  | 403 | *     Derive-Secret( ., "derived", "" ) | 
|  | 404 | *                    | | 
|  | 405 | *                    v | 
|  | 406 | *     0 -> HKDF-Extract = Master Secret | 
|  | 407 | * </tt> | 
|  | 408 | * | 
|  | 409 | * Each of the three secrets in turn is the basis for further | 
|  | 410 | * key derivations, such as the derivation of traffic keys and IVs; | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 411 | * see e.g. mbedtls_ssl_tls13_make_traffic_keys(). | 
| Hanno Becker | e9cccb4 | 2020-08-20 13:42:46 +0100 | [diff] [blame] | 412 | * | 
|  | 413 | * This function implements one step in this evolution of secrets: | 
|  | 414 | * | 
|  | 415 | * <tt> | 
|  | 416 | *                old_secret | 
|  | 417 | *                    | | 
|  | 418 | *                    v | 
|  | 419 | *     Derive-Secret( ., "derived", "" ) | 
|  | 420 | *                    | | 
|  | 421 | *                    v | 
|  | 422 | *     input -> HKDF-Extract = new_secret | 
|  | 423 | * </tt> | 
|  | 424 | * | 
|  | 425 | * \param hash_alg    The identifier for the hash function used for the | 
|  | 426 | *                    applications of HKDF. | 
|  | 427 | * \param secret_old  The address of the buffer holding the old secret | 
|  | 428 | *                    on function entry. If not \c NULL, this must be a | 
|  | 429 | *                    readable buffer whose size matches the output size | 
|  | 430 | *                    of the hash function represented by \p hash_alg. | 
|  | 431 | *                    If \c NULL, an all \c 0 array will be used instead. | 
|  | 432 | * \param input       The address of the buffer holding the additional | 
|  | 433 | *                    input for the key derivation (e.g., the PSK or the | 
|  | 434 | *                    ephemeral (EC)DH secret). If not \c NULL, this must be | 
|  | 435 | *                    a readable buffer whose size \p input_len Bytes. | 
|  | 436 | *                    If \c NULL, an all \c 0 array will be used instead. | 
|  | 437 | * \param input_len   The length of \p input in Bytes. | 
|  | 438 | * \param secret_new  The address of the buffer holding the new secret | 
|  | 439 | *                    on function exit. This must be a writable buffer | 
|  | 440 | *                    whose size matches the output size of the hash | 
|  | 441 | *                    function represented by \p hash_alg. | 
|  | 442 | *                    This may be the same as \p secret_old. | 
|  | 443 | * | 
|  | 444 | * \returns           \c 0 on success. | 
|  | 445 | * \returns           A negative error code on failure. | 
|  | 446 | */ | 
|  | 447 |  | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 448 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 449 | int mbedtls_ssl_tls13_evolve_secret( | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 450 | psa_algorithm_t hash_alg, | 
|  | 451 | const unsigned char *secret_old, | 
|  | 452 | const unsigned char *input, size_t input_len, | 
|  | 453 | unsigned char *secret_new); | 
| Hanno Becker | e9cccb4 | 2020-08-20 13:42:46 +0100 | [diff] [blame] | 454 |  | 
| Hanno Becker | b7d9bad | 2021-05-24 06:44:14 +0100 | [diff] [blame] | 455 | /** | 
|  | 456 | * \brief             Calculate a TLS 1.3 PSK binder. | 
|  | 457 | * | 
|  | 458 | * \param ssl         The SSL context. This is used for debugging only and may | 
|  | 459 | *                    be \c NULL if MBEDTLS_DEBUG_C is disabled. | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 460 | * \param hash_alg    The hash algorithm associated to the PSK \p psk. | 
| Hanno Becker | b7d9bad | 2021-05-24 06:44:14 +0100 | [diff] [blame] | 461 | * \param psk         The buffer holding the PSK for which to create a binder. | 
|  | 462 | * \param psk_len     The size of \p psk in bytes. | 
| Hanno Becker | c8d3ccd | 2021-05-26 04:47:29 +0100 | [diff] [blame] | 463 | * \param psk_type    This indicates whether the PSK \p psk is externally | 
| Hanno Becker | b7d9bad | 2021-05-24 06:44:14 +0100 | [diff] [blame] | 464 | *                    provisioned (#MBEDTLS_SSL_TLS1_3_PSK_EXTERNAL) or a | 
|  | 465 | *                    resumption PSK (#MBEDTLS_SSL_TLS1_3_PSK_RESUMPTION). | 
|  | 466 | * \param transcript  The handshake transcript up to the point where the | 
|  | 467 | *                    PSK binder calculation happens. This must be readable, | 
|  | 468 | *                    and its size must be equal to the digest size of | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 469 | *                    the hash algorithm represented by \p hash_alg. | 
| Hanno Becker | b7d9bad | 2021-05-24 06:44:14 +0100 | [diff] [blame] | 470 | * \param result      The address at which to store the PSK binder on success. | 
|  | 471 | *                    This must be writable, and its size must be equal to the | 
|  | 472 | *                    digest size of  the hash algorithm represented by | 
| Gabor Mezei | 07732f7 | 2022-03-26 17:04:19 +0100 | [diff] [blame] | 473 | *                    \p hash_alg. | 
| Hanno Becker | b7d9bad | 2021-05-24 06:44:14 +0100 | [diff] [blame] | 474 | * | 
|  | 475 | * \returns           \c 0 on success. | 
|  | 476 | * \returns           A negative error code on failure. | 
|  | 477 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 478 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 479 | int mbedtls_ssl_tls13_create_psk_binder(mbedtls_ssl_context *ssl, | 
|  | 480 | const psa_algorithm_t hash_alg, | 
|  | 481 | unsigned char const *psk, size_t psk_len, | 
|  | 482 | int psk_type, | 
|  | 483 | unsigned char const *transcript, | 
|  | 484 | unsigned char *result); | 
| Hanno Becker | b7d9bad | 2021-05-24 06:44:14 +0100 | [diff] [blame] | 485 |  | 
| Hanno Becker | c94060c | 2021-03-22 07:50:44 +0000 | [diff] [blame] | 486 | /** | 
|  | 487 | * \bref Setup an SSL transform structure representing the | 
|  | 488 | *       record protection mechanism used by TLS 1.3 | 
|  | 489 | * | 
|  | 490 | * \param transform    The SSL transform structure to be created. This must have | 
|  | 491 | *                     been initialized through mbedtls_ssl_transform_init() and | 
|  | 492 | *                     not used in any other way prior to calling this function. | 
|  | 493 | *                     In particular, this function does not clean up the | 
|  | 494 | *                     transform structure prior to installing the new keys. | 
|  | 495 | * \param endpoint     Indicates whether the transform is for the client | 
|  | 496 | *                     (value #MBEDTLS_SSL_IS_CLIENT) or the server | 
|  | 497 | *                     (value #MBEDTLS_SSL_IS_SERVER). | 
|  | 498 | * \param ciphersuite  The numerical identifier for the ciphersuite to use. | 
|  | 499 | *                     This must be one of the identifiers listed in | 
|  | 500 | *                     ssl_ciphersuites.h. | 
|  | 501 | * \param traffic_keys The key material to use. No reference is stored in | 
|  | 502 | *                     the SSL transform being generated, and the caller | 
|  | 503 | *                     should destroy the key material afterwards. | 
|  | 504 | * \param ssl          (Debug-only) The SSL context to use for debug output | 
|  | 505 | *                     in case of failure. This parameter is only needed if | 
|  | 506 | *                     #MBEDTLS_DEBUG_C is set, and is ignored otherwise. | 
|  | 507 | * | 
|  | 508 | * \return             \c 0 on success. In this case, \p transform is ready to | 
|  | 509 | *                     be used with mbedtls_ssl_transform_decrypt() and | 
|  | 510 | *                     mbedtls_ssl_transform_encrypt(). | 
|  | 511 | * \return             A negative error code on failure. | 
|  | 512 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 513 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 514 | int mbedtls_ssl_tls13_populate_transform(mbedtls_ssl_transform *transform, | 
|  | 515 | int endpoint, | 
|  | 516 | int ciphersuite, | 
|  | 517 | mbedtls_ssl_key_set const *traffic_keys, | 
|  | 518 | mbedtls_ssl_context *ssl); | 
| Hanno Becker | c94060c | 2021-03-22 07:50:44 +0000 | [diff] [blame] | 519 |  | 
| Jerry Yu | 89ea321 | 2021-09-09 14:31:24 +0800 | [diff] [blame] | 520 | /* | 
|  | 521 | * TLS 1.3 key schedule evolutions | 
|  | 522 | * | 
| Jerry Yu | c1ddeef | 2021-10-08 15:14:45 +0800 | [diff] [blame] | 523 | *   Early -> Handshake -> Application | 
| Jerry Yu | 89ea321 | 2021-09-09 14:31:24 +0800 | [diff] [blame] | 524 | * | 
| Xiaofei Bai | 746f948 | 2021-11-12 08:53:56 +0000 | [diff] [blame] | 525 | * Small wrappers around mbedtls_ssl_tls13_evolve_secret(). | 
| Jerry Yu | 89ea321 | 2021-09-09 14:31:24 +0800 | [diff] [blame] | 526 | */ | 
|  | 527 |  | 
|  | 528 | /** | 
| Jerry Yu | c1ddeef | 2021-10-08 15:14:45 +0800 | [diff] [blame] | 529 | * \brief Begin TLS 1.3 key schedule by calculating early secret. | 
| Jerry Yu | 89ea321 | 2021-09-09 14:31:24 +0800 | [diff] [blame] | 530 | * | 
|  | 531 | *        The TLS 1.3 key schedule can be viewed as a simple state machine | 
|  | 532 | *        with states Initial -> Early -> Handshake -> Application, and | 
|  | 533 | *        this function represents the Initial -> Early transition. | 
|  | 534 | * | 
| Jerry Yu | 89ea321 | 2021-09-09 14:31:24 +0800 | [diff] [blame] | 535 | * \param ssl  The SSL context to operate on. | 
|  | 536 | * | 
|  | 537 | * \returns    \c 0 on success. | 
|  | 538 | * \returns    A negative error code on failure. | 
|  | 539 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 540 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 541 | int mbedtls_ssl_tls13_key_schedule_stage_early(mbedtls_ssl_context *ssl); | 
| Jerry Yu | 4925ef5 | 2021-09-09 14:42:55 +0800 | [diff] [blame] | 542 |  | 
| Jerry Yu | 61e35e0 | 2021-09-16 18:59:08 +0800 | [diff] [blame] | 543 | /** | 
| Jerry Yu | ff22698 | 2022-04-16 16:52:57 +0800 | [diff] [blame] | 544 | * \brief Compute TLS 1.3 resumption master secret. | 
|  | 545 | * | 
|  | 546 | * \param ssl  The SSL context to operate on. This must be in | 
|  | 547 | *             key schedule stage \c Application, see | 
|  | 548 | *             mbedtls_ssl_tls13_key_schedule_stage_application(). | 
|  | 549 | * | 
|  | 550 | * \returns    \c 0 on success. | 
|  | 551 | * \returns    A negative error code on failure. | 
|  | 552 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 553 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 554 | int mbedtls_ssl_tls13_compute_resumption_master_secret(mbedtls_ssl_context *ssl); | 
| Jerry Yu | ff22698 | 2022-04-16 16:52:57 +0800 | [diff] [blame] | 555 |  | 
|  | 556 | /** | 
| XiaokangQian | c5c39d5 | 2021-11-09 11:55:10 +0000 | [diff] [blame] | 557 | * \brief Calculate the verify_data value for the client or server TLS 1.3 | 
|  | 558 | * Finished message. | 
| XiaokangQian | aa5f5c1 | 2021-09-18 06:20:25 +0000 | [diff] [blame] | 559 | * | 
|  | 560 | * \param ssl  The SSL context to operate on. This must be in | 
|  | 561 | *             key schedule stage \c Handshake, see | 
| XiaokangQian | 4cab024 | 2021-10-12 08:43:37 +0000 | [diff] [blame] | 562 | *             mbedtls_ssl_tls13_key_schedule_stage_application(). | 
| XiaokangQian | c5c39d5 | 2021-11-09 11:55:10 +0000 | [diff] [blame] | 563 | * \param dst        The address at which to write the verify_data value. | 
| XiaokangQian | aa5f5c1 | 2021-09-18 06:20:25 +0000 | [diff] [blame] | 564 | * \param dst_len    The size of \p dst in bytes. | 
|  | 565 | * \param actual_len The address at which to store the amount of data | 
|  | 566 | *                   actually written to \p dst upon success. | 
| XiaokangQian | aaa0e19 | 2021-11-10 03:07:04 +0000 | [diff] [blame] | 567 | * \param which      The message to calculate the `verify_data` for: | 
| XiaokangQian | aa5f5c1 | 2021-09-18 06:20:25 +0000 | [diff] [blame] | 568 | *                   - #MBEDTLS_SSL_IS_CLIENT for the Client's Finished message | 
|  | 569 | *                   - #MBEDTLS_SSL_IS_SERVER for the Server's Finished message | 
|  | 570 | * | 
|  | 571 | * \note       Both client and server call this function twice, once to | 
|  | 572 | *             generate their own Finished message, and once to verify the | 
|  | 573 | *             peer's Finished message. | 
|  | 574 |  | 
|  | 575 | * \returns    \c 0 on success. | 
|  | 576 | * \returns    A negative error code on failure. | 
|  | 577 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 578 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 579 | int mbedtls_ssl_tls13_calculate_verify_data(mbedtls_ssl_context *ssl, | 
|  | 580 | unsigned char *dst, | 
|  | 581 | size_t dst_len, | 
|  | 582 | size_t *actual_len, | 
|  | 583 | int which); | 
| XiaokangQian | aa5f5c1 | 2021-09-18 06:20:25 +0000 | [diff] [blame] | 584 |  | 
| Jerry Yu | 91b560f | 2022-11-04 14:10:34 +0800 | [diff] [blame] | 585 | #if defined(MBEDTLS_SSL_EARLY_DATA) | 
|  | 586 | /** | 
|  | 587 | * \brief Compute TLS 1.3 early transform | 
|  | 588 | * | 
| Jerry Yu | b094e12 | 2022-11-21 13:03:47 +0800 | [diff] [blame] | 589 | * \param ssl  The SSL context to operate on. | 
| Jerry Yu | 91b560f | 2022-11-04 14:10:34 +0800 | [diff] [blame] | 590 | * | 
|  | 591 | * \returns    \c 0 on success. | 
|  | 592 | * \returns    A negative error code on failure. | 
|  | 593 | * | 
| Jerry Yu | 3ce61ff | 2022-11-21 22:45:58 +0800 | [diff] [blame] | 594 | * \warning    The function does not compute the early master secret. Call | 
|  | 595 | *             mbedtls_ssl_tls13_key_schedule_stage_early() before to | 
|  | 596 | *             call this function to generate the early master secret. | 
|  | 597 | * \note       For a client/server endpoint, the function computes only the | 
|  | 598 | *             encryption/decryption part of the transform as the decryption/ | 
|  | 599 | *             encryption part is not defined by the specification (no early | 
|  | 600 | *             traffic from the server to the client). | 
| Jerry Yu | 91b560f | 2022-11-04 14:10:34 +0800 | [diff] [blame] | 601 | */ | 
|  | 602 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 603 | int mbedtls_ssl_tls13_compute_early_transform(mbedtls_ssl_context *ssl); | 
| Jerry Yu | 91b560f | 2022-11-04 14:10:34 +0800 | [diff] [blame] | 604 | #endif /* MBEDTLS_SSL_EARLY_DATA */ | 
|  | 605 |  | 
| Jerry Yu | e110d25 | 2022-05-05 10:19:22 +0800 | [diff] [blame] | 606 | /** | 
|  | 607 | * \brief Compute TLS 1.3 handshake transform | 
|  | 608 | * | 
| Jerry Yu | f86eb75 | 2022-05-06 11:16:55 +0800 | [diff] [blame] | 609 | * \param ssl  The SSL context to operate on. The early secret must have been | 
| Jerry Yu | e110d25 | 2022-05-05 10:19:22 +0800 | [diff] [blame] | 610 | *             computed. | 
|  | 611 | * | 
|  | 612 | * \returns    \c 0 on success. | 
|  | 613 | * \returns    A negative error code on failure. | 
|  | 614 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 615 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 616 | int mbedtls_ssl_tls13_compute_handshake_transform(mbedtls_ssl_context *ssl); | 
| Jerry Yu | e110d25 | 2022-05-05 10:19:22 +0800 | [diff] [blame] | 617 |  | 
| Jerry Yu | fd5ea04 | 2022-05-19 14:29:48 +0800 | [diff] [blame] | 618 | /** | 
|  | 619 | * \brief Compute TLS 1.3 application transform | 
|  | 620 | * | 
|  | 621 | * \param ssl  The SSL context to operate on. The early secret must have been | 
|  | 622 | *             computed. | 
|  | 623 | * | 
|  | 624 | * \returns    \c 0 on success. | 
|  | 625 | * \returns    A negative error code on failure. | 
|  | 626 | */ | 
| Manuel Pégourié-Gonnard | a82a8b9 | 2022-06-17 10:53:58 +0200 | [diff] [blame] | 627 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 628 | int mbedtls_ssl_tls13_compute_application_transform(mbedtls_ssl_context *ssl); | 
| Jerry Yu | fd5ea04 | 2022-05-19 14:29:48 +0800 | [diff] [blame] | 629 |  | 
| Ronald Cron | 41a443a | 2022-10-04 16:38:25 +0200 | [diff] [blame] | 630 | #if defined(MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_SOME_PSK_ENABLED) | 
| Jerry Yu | 40f3771 | 2022-07-26 16:58:57 +0800 | [diff] [blame] | 631 | /** | 
| Jerry Yu | 6cf6b47 | 2022-08-16 14:50:28 +0800 | [diff] [blame] | 632 | * \brief Export TLS 1.3 PSK from handshake context | 
| Jerry Yu | 40f3771 | 2022-07-26 16:58:57 +0800 | [diff] [blame] | 633 | * | 
| Jerry Yu | 01e42d2 | 2022-08-21 12:55:51 +0800 | [diff] [blame] | 634 | * \param[in]   ssl  The SSL context to operate on. | 
|  | 635 | * \param[out]  psk  PSK output pointer. | 
|  | 636 | * \param[out]  psk_len Length of PSK. | 
| Jerry Yu | 40f3771 | 2022-07-26 16:58:57 +0800 | [diff] [blame] | 637 | * | 
| Jerry Yu | 29d9faa | 2022-08-23 17:52:45 +0800 | [diff] [blame] | 638 | * \returns     \c 0 if there is a configured PSK and it was exported | 
|  | 639 | *              successfully. | 
|  | 640 | * \returns     A negative error code on failure. | 
| Jerry Yu | 40f3771 | 2022-07-26 16:58:57 +0800 | [diff] [blame] | 641 | */ | 
|  | 642 | MBEDTLS_CHECK_RETURN_CRITICAL | 
| Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 643 | int mbedtls_ssl_tls13_export_handshake_psk(mbedtls_ssl_context *ssl, | 
|  | 644 | unsigned char **psk, | 
|  | 645 | size_t *psk_len); | 
| Ronald Cron | 41a443a | 2022-10-04 16:38:25 +0200 | [diff] [blame] | 646 | #endif | 
| Jerry Yu | 40f3771 | 2022-07-26 16:58:57 +0800 | [diff] [blame] | 647 |  | 
| Max Fillinger | bd81c9d | 2024-07-22 14:43:56 +0200 | [diff] [blame] | 648 | /** | 
|  | 649 | * \brief Calculate TLS-Exporter function as defined in RFC 8446, Section 7.5. | 
|  | 650 | * | 
|  | 651 | * \param[in]   hash_alg  The hash algorithm. | 
|  | 652 | * \param[in]   secret  The secret to use. (Should be the exporter master secret.) | 
|  | 653 | * \param[in]   secret_len  Length of secret. | 
|  | 654 | * \param[in]   label  The label of the exported key. | 
|  | 655 | * \param[in]   label_len  The length of label. | 
|  | 656 | * \param[out]  out  The output buffer for the exported key. Must have room for at least out_len bytes. | 
|  | 657 | * \param[in]   out_len  Length of the key to generate. | 
| Max Fillinger | 136fe9e | 2024-08-09 18:54:36 +0200 | [diff] [blame] | 658 | */ | 
| Max Fillinger | 9c9989f | 2024-08-14 16:44:50 +0200 | [diff] [blame] | 659 | int mbedtls_ssl_tls13_exporter(const psa_algorithm_t hash_alg, | 
|  | 660 | const unsigned char *secret, const size_t secret_len, | 
|  | 661 | const unsigned char *label, const size_t label_len, | 
|  | 662 | const unsigned char *context_value, const size_t context_len, | 
|  | 663 | uint8_t *out, const size_t out_len); | 
| Max Fillinger | bd81c9d | 2024-07-22 14:43:56 +0200 | [diff] [blame] | 664 |  | 
| Gabor Mezei | e42d8bf | 2022-03-30 11:33:06 +0200 | [diff] [blame] | 665 | #endif /* MBEDTLS_SSL_PROTO_TLS1_3 */ | 
|  | 666 |  | 
| Hanno Becker | be9d664 | 2020-08-21 13:20:06 +0100 | [diff] [blame] | 667 | #endif /* MBEDTLS_SSL_TLS1_3_KEYS_H */ |