blob: f5734c45774084d12fbfbe07f8604dfcba15d38b [file] [log] [blame]
Paul Bakker0f90d7d2014-04-30 11:49:44 +02001/*
2 * Version feature information
3 *
Bence Szépkúti1e148272020-08-07 13:07:28 +02004 * Copyright The Mbed TLS Contributors
Dave Rodgman7ff79652023-11-03 12:04:52 +00005 * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
Paul Bakker0f90d7d2014-04-30 11:49:44 +02006 */
7
Gilles Peskinedb09ef62020-06-03 01:43:33 +02008#include "common.h"
Paul Bakker0f90d7d2014-04-30 11:49:44 +02009
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020010#if defined(MBEDTLS_VERSION_C)
Paul Bakker0f90d7d2014-04-30 11:49:44 +020011
Manuel Pégourié-Gonnard7f809972015-03-09 17:05:11 +000012#include "mbedtls/version.h"
Paul Bakker0f90d7d2014-04-30 11:49:44 +020013
14#include <string.h>
15
Máté Vargac5de4622019-06-12 12:26:37 +020016static const char * const features[] = {
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020017#if defined(MBEDTLS_VERSION_FEATURES)
Gilles Peskineec03b042023-01-11 14:52:37 +010018 #if defined(MBEDTLS_HAVE_ASM)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020019 "MBEDTLS_HAVE_ASM",
20#endif /* MBEDTLS_HAVE_ASM */
Gilles Peskine683ac272017-06-15 18:01:54 +020021#if defined(MBEDTLS_NO_UDBL_DIVISION)
22 "MBEDTLS_NO_UDBL_DIVISION",
23#endif /* MBEDTLS_NO_UDBL_DIVISION */
Manuel Pégourié-Gonnard2adb3752018-06-07 10:51:44 +020024#if defined(MBEDTLS_NO_64BIT_MULTIPLICATION)
25 "MBEDTLS_NO_64BIT_MULTIPLICATION",
26#endif /* MBEDTLS_NO_64BIT_MULTIPLICATION */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020027#if defined(MBEDTLS_HAVE_SSE2)
28 "MBEDTLS_HAVE_SSE2",
29#endif /* MBEDTLS_HAVE_SSE2 */
30#if defined(MBEDTLS_HAVE_TIME)
31 "MBEDTLS_HAVE_TIME",
32#endif /* MBEDTLS_HAVE_TIME */
Manuel Pégourié-Gonnardf9cbd732015-06-22 12:06:50 +020033#if defined(MBEDTLS_HAVE_TIME_DATE)
34 "MBEDTLS_HAVE_TIME_DATE",
35#endif /* MBEDTLS_HAVE_TIME_DATE */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020036#if defined(MBEDTLS_PLATFORM_MEMORY)
37 "MBEDTLS_PLATFORM_MEMORY",
38#endif /* MBEDTLS_PLATFORM_MEMORY */
39#if defined(MBEDTLS_PLATFORM_NO_STD_FUNCTIONS)
40 "MBEDTLS_PLATFORM_NO_STD_FUNCTIONS",
41#endif /* MBEDTLS_PLATFORM_NO_STD_FUNCTIONS */
42#if defined(MBEDTLS_PLATFORM_EXIT_ALT)
43 "MBEDTLS_PLATFORM_EXIT_ALT",
44#endif /* MBEDTLS_PLATFORM_EXIT_ALT */
Simon Butcher3fe6cd32016-04-26 19:51:29 +010045#if defined(MBEDTLS_PLATFORM_TIME_ALT)
46 "MBEDTLS_PLATFORM_TIME_ALT",
47#endif /* MBEDTLS_PLATFORM_TIME_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020048#if defined(MBEDTLS_PLATFORM_FPRINTF_ALT)
49 "MBEDTLS_PLATFORM_FPRINTF_ALT",
50#endif /* MBEDTLS_PLATFORM_FPRINTF_ALT */
51#if defined(MBEDTLS_PLATFORM_PRINTF_ALT)
52 "MBEDTLS_PLATFORM_PRINTF_ALT",
53#endif /* MBEDTLS_PLATFORM_PRINTF_ALT */
54#if defined(MBEDTLS_PLATFORM_SNPRINTF_ALT)
55 "MBEDTLS_PLATFORM_SNPRINTF_ALT",
56#endif /* MBEDTLS_PLATFORM_SNPRINTF_ALT */
k-stachowiak723f8672018-07-16 14:27:07 +020057#if defined(MBEDTLS_PLATFORM_VSNPRINTF_ALT)
58 "MBEDTLS_PLATFORM_VSNPRINTF_ALT",
59#endif /* MBEDTLS_PLATFORM_VSNPRINTF_ALT */
Paul Bakkerbddf9ab2016-06-01 15:58:12 +010060#if defined(MBEDTLS_PLATFORM_NV_SEED_ALT)
61 "MBEDTLS_PLATFORM_NV_SEED_ALT",
62#endif /* MBEDTLS_PLATFORM_NV_SEED_ALT */
Simon Butchera95d6302017-07-21 23:48:55 +010063#if defined(MBEDTLS_PLATFORM_SETUP_TEARDOWN_ALT)
64 "MBEDTLS_PLATFORM_SETUP_TEARDOWN_ALT",
65#endif /* MBEDTLS_PLATFORM_SETUP_TEARDOWN_ALT */
Gilles Peskinee0088902023-09-07 19:20:34 +020066#if defined(MBEDTLS_PLATFORM_GMTIME_R_ALT)
67 "MBEDTLS_PLATFORM_GMTIME_R_ALT",
68#endif /* MBEDTLS_PLATFORM_GMTIME_R_ALT */
69#if defined(MBEDTLS_PLATFORM_ZEROIZE_ALT)
70 "MBEDTLS_PLATFORM_ZEROIZE_ALT",
71#endif /* MBEDTLS_PLATFORM_ZEROIZE_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020072#if defined(MBEDTLS_DEPRECATED_WARNING)
73 "MBEDTLS_DEPRECATED_WARNING",
74#endif /* MBEDTLS_DEPRECATED_WARNING */
75#if defined(MBEDTLS_DEPRECATED_REMOVED)
76 "MBEDTLS_DEPRECATED_REMOVED",
77#endif /* MBEDTLS_DEPRECATED_REMOVED */
Andrzej Kurekc470b6b2019-01-31 08:20:20 -050078#if defined(MBEDTLS_CHECK_PARAMS)
79 "MBEDTLS_CHECK_PARAMS",
80#endif /* MBEDTLS_CHECK_PARAMS */
Gilles Peskinec7ad1222019-06-13 16:44:19 +020081#if defined(MBEDTLS_CHECK_PARAMS_ASSERT)
82 "MBEDTLS_CHECK_PARAMS_ASSERT",
83#endif /* MBEDTLS_CHECK_PARAMS_ASSERT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020084#if defined(MBEDTLS_TIMING_ALT)
85 "MBEDTLS_TIMING_ALT",
86#endif /* MBEDTLS_TIMING_ALT */
87#if defined(MBEDTLS_AES_ALT)
88 "MBEDTLS_AES_ALT",
89#endif /* MBEDTLS_AES_ALT */
90#if defined(MBEDTLS_ARC4_ALT)
91 "MBEDTLS_ARC4_ALT",
92#endif /* MBEDTLS_ARC4_ALT */
Markku-Juhani O. Saarinen0fb47fe2017-12-01 15:41:38 +000093#if defined(MBEDTLS_ARIA_ALT)
94 "MBEDTLS_ARIA_ALT",
95#endif /* MBEDTLS_ARIA_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020096#if defined(MBEDTLS_BLOWFISH_ALT)
97 "MBEDTLS_BLOWFISH_ALT",
98#endif /* MBEDTLS_BLOWFISH_ALT */
99#if defined(MBEDTLS_CAMELLIA_ALT)
100 "MBEDTLS_CAMELLIA_ALT",
101#endif /* MBEDTLS_CAMELLIA_ALT */
Steven Cooreman3a933872017-04-04 12:02:37 +0200102#if defined(MBEDTLS_CCM_ALT)
103 "MBEDTLS_CCM_ALT",
104#endif /* MBEDTLS_CCM_ALT */
Daniel King34b822c2016-05-15 17:28:08 -0300105#if defined(MBEDTLS_CHACHA20_ALT)
106 "MBEDTLS_CHACHA20_ALT",
107#endif /* MBEDTLS_CHACHA20_ALT */
Manuel Pégourié-Gonnard94175a52018-06-04 12:42:17 +0200108#if defined(MBEDTLS_CHACHAPOLY_ALT)
109 "MBEDTLS_CHACHAPOLY_ALT",
110#endif /* MBEDTLS_CHACHAPOLY_ALT */
Steven Cooreman12d9f3c2017-04-04 12:01:42 +0200111#if defined(MBEDTLS_CMAC_ALT)
112 "MBEDTLS_CMAC_ALT",
113#endif /* MBEDTLS_CMAC_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200114#if defined(MBEDTLS_DES_ALT)
115 "MBEDTLS_DES_ALT",
116#endif /* MBEDTLS_DES_ALT */
nirekh01d569ecf2018-01-09 16:43:21 +0000117#if defined(MBEDTLS_DHM_ALT)
118 "MBEDTLS_DHM_ALT",
119#endif /* MBEDTLS_DHM_ALT */
Hanno Becker616d1ca2018-01-24 10:25:05 +0000120#if defined(MBEDTLS_ECJPAKE_ALT)
121 "MBEDTLS_ECJPAKE_ALT",
122#endif /* MBEDTLS_ECJPAKE_ALT */
Jaeden Amero15263302017-09-21 12:53:48 +0100123#if defined(MBEDTLS_GCM_ALT)
124 "MBEDTLS_GCM_ALT",
125#endif /* MBEDTLS_GCM_ALT */
Ron Eldor466a57f2018-05-03 16:54:28 +0300126#if defined(MBEDTLS_NIST_KW_ALT)
127 "MBEDTLS_NIST_KW_ALT",
128#endif /* MBEDTLS_NIST_KW_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200129#if defined(MBEDTLS_MD2_ALT)
130 "MBEDTLS_MD2_ALT",
131#endif /* MBEDTLS_MD2_ALT */
132#if defined(MBEDTLS_MD4_ALT)
133 "MBEDTLS_MD4_ALT",
134#endif /* MBEDTLS_MD4_ALT */
135#if defined(MBEDTLS_MD5_ALT)
136 "MBEDTLS_MD5_ALT",
137#endif /* MBEDTLS_MD5_ALT */
Daniel King8fe47012016-05-17 20:33:28 -0300138#if defined(MBEDTLS_POLY1305_ALT)
139 "MBEDTLS_POLY1305_ALT",
140#endif /* MBEDTLS_POLY1305_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200141#if defined(MBEDTLS_RIPEMD160_ALT)
142 "MBEDTLS_RIPEMD160_ALT",
143#endif /* MBEDTLS_RIPEMD160_ALT */
Hanno Becker88683b22018-01-04 18:26:54 +0000144#if defined(MBEDTLS_RSA_ALT)
145 "MBEDTLS_RSA_ALT",
146#endif /* MBEDTLS_RSA_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200147#if defined(MBEDTLS_SHA1_ALT)
148 "MBEDTLS_SHA1_ALT",
149#endif /* MBEDTLS_SHA1_ALT */
150#if defined(MBEDTLS_SHA256_ALT)
151 "MBEDTLS_SHA256_ALT",
152#endif /* MBEDTLS_SHA256_ALT */
153#if defined(MBEDTLS_SHA512_ALT)
154 "MBEDTLS_SHA512_ALT",
155#endif /* MBEDTLS_SHA512_ALT */
Hanno Becker88683b22018-01-04 18:26:54 +0000156#if defined(MBEDTLS_XTEA_ALT)
157 "MBEDTLS_XTEA_ALT",
158#endif /* MBEDTLS_XTEA_ALT */
Janos Follath69b20512016-11-21 14:53:57 +0000159#if defined(MBEDTLS_ECP_ALT)
160 "MBEDTLS_ECP_ALT",
161#endif /* MBEDTLS_ECP_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200162#if defined(MBEDTLS_MD2_PROCESS_ALT)
163 "MBEDTLS_MD2_PROCESS_ALT",
164#endif /* MBEDTLS_MD2_PROCESS_ALT */
165#if defined(MBEDTLS_MD4_PROCESS_ALT)
166 "MBEDTLS_MD4_PROCESS_ALT",
167#endif /* MBEDTLS_MD4_PROCESS_ALT */
168#if defined(MBEDTLS_MD5_PROCESS_ALT)
169 "MBEDTLS_MD5_PROCESS_ALT",
170#endif /* MBEDTLS_MD5_PROCESS_ALT */
171#if defined(MBEDTLS_RIPEMD160_PROCESS_ALT)
172 "MBEDTLS_RIPEMD160_PROCESS_ALT",
173#endif /* MBEDTLS_RIPEMD160_PROCESS_ALT */
174#if defined(MBEDTLS_SHA1_PROCESS_ALT)
175 "MBEDTLS_SHA1_PROCESS_ALT",
176#endif /* MBEDTLS_SHA1_PROCESS_ALT */
177#if defined(MBEDTLS_SHA256_PROCESS_ALT)
178 "MBEDTLS_SHA256_PROCESS_ALT",
179#endif /* MBEDTLS_SHA256_PROCESS_ALT */
180#if defined(MBEDTLS_SHA512_PROCESS_ALT)
181 "MBEDTLS_SHA512_PROCESS_ALT",
182#endif /* MBEDTLS_SHA512_PROCESS_ALT */
Manuel Pégourié-Gonnarda27b1972015-05-12 16:09:34 +0200183#if defined(MBEDTLS_DES_SETKEY_ALT)
184 "MBEDTLS_DES_SETKEY_ALT",
185#endif /* MBEDTLS_DES_SETKEY_ALT */
186#if defined(MBEDTLS_DES_CRYPT_ECB_ALT)
187 "MBEDTLS_DES_CRYPT_ECB_ALT",
188#endif /* MBEDTLS_DES_CRYPT_ECB_ALT */
189#if defined(MBEDTLS_DES3_CRYPT_ECB_ALT)
190 "MBEDTLS_DES3_CRYPT_ECB_ALT",
191#endif /* MBEDTLS_DES3_CRYPT_ECB_ALT */
192#if defined(MBEDTLS_AES_SETKEY_ENC_ALT)
193 "MBEDTLS_AES_SETKEY_ENC_ALT",
194#endif /* MBEDTLS_AES_SETKEY_ENC_ALT */
195#if defined(MBEDTLS_AES_SETKEY_DEC_ALT)
196 "MBEDTLS_AES_SETKEY_DEC_ALT",
197#endif /* MBEDTLS_AES_SETKEY_DEC_ALT */
198#if defined(MBEDTLS_AES_ENCRYPT_ALT)
199 "MBEDTLS_AES_ENCRYPT_ALT",
200#endif /* MBEDTLS_AES_ENCRYPT_ALT */
201#if defined(MBEDTLS_AES_DECRYPT_ALT)
202 "MBEDTLS_AES_DECRYPT_ALT",
203#endif /* MBEDTLS_AES_DECRYPT_ALT */
Ron Eldora84c1cb2017-10-10 19:04:27 +0300204#if defined(MBEDTLS_ECDH_GEN_PUBLIC_ALT)
205 "MBEDTLS_ECDH_GEN_PUBLIC_ALT",
206#endif /* MBEDTLS_ECDH_GEN_PUBLIC_ALT */
Ron Eldor3226d362017-10-12 14:17:48 +0300207#if defined(MBEDTLS_ECDH_COMPUTE_SHARED_ALT)
208 "MBEDTLS_ECDH_COMPUTE_SHARED_ALT",
209#endif /* MBEDTLS_ECDH_COMPUTE_SHARED_ALT */
Ron Eldor314adb62017-10-10 18:28:25 +0300210#if defined(MBEDTLS_ECDSA_VERIFY_ALT)
211 "MBEDTLS_ECDSA_VERIFY_ALT",
212#endif /* MBEDTLS_ECDSA_VERIFY_ALT */
213#if defined(MBEDTLS_ECDSA_SIGN_ALT)
214 "MBEDTLS_ECDSA_SIGN_ALT",
215#endif /* MBEDTLS_ECDSA_SIGN_ALT */
216#if defined(MBEDTLS_ECDSA_GENKEY_ALT)
217 "MBEDTLS_ECDSA_GENKEY_ALT",
218#endif /* MBEDTLS_ECDSA_GENKEY_ALT */
Janos Follath69b20512016-11-21 14:53:57 +0000219#if defined(MBEDTLS_ECP_INTERNAL_ALT)
220 "MBEDTLS_ECP_INTERNAL_ALT",
221#endif /* MBEDTLS_ECP_INTERNAL_ALT */
Steven Cooreman97b49842021-01-08 16:32:20 +0100222#if defined(MBEDTLS_ECP_NO_FALLBACK)
223 "MBEDTLS_ECP_NO_FALLBACK",
224#endif /* MBEDTLS_ECP_NO_FALLBACK */
Janos Follath69b20512016-11-21 14:53:57 +0000225#if defined(MBEDTLS_ECP_RANDOMIZE_JAC_ALT)
226 "MBEDTLS_ECP_RANDOMIZE_JAC_ALT",
227#endif /* MBEDTLS_ECP_RANDOMIZE_JAC_ALT */
228#if defined(MBEDTLS_ECP_ADD_MIXED_ALT)
229 "MBEDTLS_ECP_ADD_MIXED_ALT",
230#endif /* MBEDTLS_ECP_ADD_MIXED_ALT */
231#if defined(MBEDTLS_ECP_DOUBLE_JAC_ALT)
232 "MBEDTLS_ECP_DOUBLE_JAC_ALT",
233#endif /* MBEDTLS_ECP_DOUBLE_JAC_ALT */
234#if defined(MBEDTLS_ECP_NORMALIZE_JAC_MANY_ALT)
235 "MBEDTLS_ECP_NORMALIZE_JAC_MANY_ALT",
236#endif /* MBEDTLS_ECP_NORMALIZE_JAC_MANY_ALT */
237#if defined(MBEDTLS_ECP_NORMALIZE_JAC_ALT)
238 "MBEDTLS_ECP_NORMALIZE_JAC_ALT",
239#endif /* MBEDTLS_ECP_NORMALIZE_JAC_ALT */
240#if defined(MBEDTLS_ECP_DOUBLE_ADD_MXZ_ALT)
241 "MBEDTLS_ECP_DOUBLE_ADD_MXZ_ALT",
242#endif /* MBEDTLS_ECP_DOUBLE_ADD_MXZ_ALT */
243#if defined(MBEDTLS_ECP_RANDOMIZE_MXZ_ALT)
244 "MBEDTLS_ECP_RANDOMIZE_MXZ_ALT",
245#endif /* MBEDTLS_ECP_RANDOMIZE_MXZ_ALT */
246#if defined(MBEDTLS_ECP_NORMALIZE_MXZ_ALT)
247 "MBEDTLS_ECP_NORMALIZE_MXZ_ALT",
248#endif /* MBEDTLS_ECP_NORMALIZE_MXZ_ALT */
Simon Butcherab5df402016-06-11 02:31:21 +0100249#if defined(MBEDTLS_TEST_NULL_ENTROPY)
250 "MBEDTLS_TEST_NULL_ENTROPY",
251#endif /* MBEDTLS_TEST_NULL_ENTROPY */
Manuel Pégourié-Gonnardf9cbd732015-06-22 12:06:50 +0200252#if defined(MBEDTLS_ENTROPY_HARDWARE_ALT)
253 "MBEDTLS_ENTROPY_HARDWARE_ALT",
254#endif /* MBEDTLS_ENTROPY_HARDWARE_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200255#if defined(MBEDTLS_AES_ROM_TABLES)
256 "MBEDTLS_AES_ROM_TABLES",
257#endif /* MBEDTLS_AES_ROM_TABLES */
Hanno Becker177d3cf2017-06-07 15:52:48 +0100258#if defined(MBEDTLS_AES_FEWER_TABLES)
259 "MBEDTLS_AES_FEWER_TABLES",
260#endif /* MBEDTLS_AES_FEWER_TABLES */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200261#if defined(MBEDTLS_CAMELLIA_SMALL_MEMORY)
262 "MBEDTLS_CAMELLIA_SMALL_MEMORY",
263#endif /* MBEDTLS_CAMELLIA_SMALL_MEMORY */
Gilles Peskine8ad54fa2021-09-30 19:22:48 +0200264#if defined(MBEDTLS_CHECK_RETURN_WARNING)
265 "MBEDTLS_CHECK_RETURN_WARNING",
266#endif /* MBEDTLS_CHECK_RETURN_WARNING */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200267#if defined(MBEDTLS_CIPHER_MODE_CBC)
268 "MBEDTLS_CIPHER_MODE_CBC",
269#endif /* MBEDTLS_CIPHER_MODE_CBC */
270#if defined(MBEDTLS_CIPHER_MODE_CFB)
271 "MBEDTLS_CIPHER_MODE_CFB",
272#endif /* MBEDTLS_CIPHER_MODE_CFB */
273#if defined(MBEDTLS_CIPHER_MODE_CTR)
274 "MBEDTLS_CIPHER_MODE_CTR",
275#endif /* MBEDTLS_CIPHER_MODE_CTR */
Jaeden Ameroff2f4932018-06-14 11:38:50 +0100276#if defined(MBEDTLS_CIPHER_MODE_OFB)
277 "MBEDTLS_CIPHER_MODE_OFB",
278#endif /* MBEDTLS_CIPHER_MODE_OFB */
279#if defined(MBEDTLS_CIPHER_MODE_XTS)
280 "MBEDTLS_CIPHER_MODE_XTS",
281#endif /* MBEDTLS_CIPHER_MODE_XTS */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200282#if defined(MBEDTLS_CIPHER_NULL_CIPHER)
283 "MBEDTLS_CIPHER_NULL_CIPHER",
284#endif /* MBEDTLS_CIPHER_NULL_CIPHER */
285#if defined(MBEDTLS_CIPHER_PADDING_PKCS7)
286 "MBEDTLS_CIPHER_PADDING_PKCS7",
287#endif /* MBEDTLS_CIPHER_PADDING_PKCS7 */
288#if defined(MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS)
289 "MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS",
290#endif /* MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS */
291#if defined(MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN)
292 "MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN",
293#endif /* MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN */
294#if defined(MBEDTLS_CIPHER_PADDING_ZEROS)
295 "MBEDTLS_CIPHER_PADDING_ZEROS",
296#endif /* MBEDTLS_CIPHER_PADDING_ZEROS */
Gilles Peskine1540e5b2019-10-03 14:21:14 +0200297#if defined(MBEDTLS_CTR_DRBG_USE_128_BIT_KEY)
298 "MBEDTLS_CTR_DRBG_USE_128_BIT_KEY",
299#endif /* MBEDTLS_CTR_DRBG_USE_128_BIT_KEY */
Gilles Peskine4e117492020-02-26 18:56:08 +0100300#if defined(MBEDTLS_ENABLE_WEAK_CIPHERSUITES)
301 "MBEDTLS_ENABLE_WEAK_CIPHERSUITES",
302#endif /* MBEDTLS_ENABLE_WEAK_CIPHERSUITES */
303#if defined(MBEDTLS_REMOVE_ARC4_CIPHERSUITES)
304 "MBEDTLS_REMOVE_ARC4_CIPHERSUITES",
305#endif /* MBEDTLS_REMOVE_ARC4_CIPHERSUITES */
306#if defined(MBEDTLS_REMOVE_3DES_CIPHERSUITES)
307 "MBEDTLS_REMOVE_3DES_CIPHERSUITES",
308#endif /* MBEDTLS_REMOVE_3DES_CIPHERSUITES */
Gilles Peskinee0088902023-09-07 19:20:34 +0200309#if defined(MBEDTLS_ECDH_VARIANT_EVEREST_ENABLED)
310 "MBEDTLS_ECDH_VARIANT_EVEREST_ENABLED",
311#endif /* MBEDTLS_ECDH_VARIANT_EVEREST_ENABLED */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200312#if defined(MBEDTLS_ECP_DP_SECP192R1_ENABLED)
313 "MBEDTLS_ECP_DP_SECP192R1_ENABLED",
314#endif /* MBEDTLS_ECP_DP_SECP192R1_ENABLED */
315#if defined(MBEDTLS_ECP_DP_SECP224R1_ENABLED)
316 "MBEDTLS_ECP_DP_SECP224R1_ENABLED",
317#endif /* MBEDTLS_ECP_DP_SECP224R1_ENABLED */
318#if defined(MBEDTLS_ECP_DP_SECP256R1_ENABLED)
319 "MBEDTLS_ECP_DP_SECP256R1_ENABLED",
320#endif /* MBEDTLS_ECP_DP_SECP256R1_ENABLED */
321#if defined(MBEDTLS_ECP_DP_SECP384R1_ENABLED)
322 "MBEDTLS_ECP_DP_SECP384R1_ENABLED",
323#endif /* MBEDTLS_ECP_DP_SECP384R1_ENABLED */
324#if defined(MBEDTLS_ECP_DP_SECP521R1_ENABLED)
325 "MBEDTLS_ECP_DP_SECP521R1_ENABLED",
326#endif /* MBEDTLS_ECP_DP_SECP521R1_ENABLED */
327#if defined(MBEDTLS_ECP_DP_SECP192K1_ENABLED)
328 "MBEDTLS_ECP_DP_SECP192K1_ENABLED",
329#endif /* MBEDTLS_ECP_DP_SECP192K1_ENABLED */
330#if defined(MBEDTLS_ECP_DP_SECP224K1_ENABLED)
331 "MBEDTLS_ECP_DP_SECP224K1_ENABLED",
332#endif /* MBEDTLS_ECP_DP_SECP224K1_ENABLED */
333#if defined(MBEDTLS_ECP_DP_SECP256K1_ENABLED)
334 "MBEDTLS_ECP_DP_SECP256K1_ENABLED",
335#endif /* MBEDTLS_ECP_DP_SECP256K1_ENABLED */
336#if defined(MBEDTLS_ECP_DP_BP256R1_ENABLED)
337 "MBEDTLS_ECP_DP_BP256R1_ENABLED",
338#endif /* MBEDTLS_ECP_DP_BP256R1_ENABLED */
339#if defined(MBEDTLS_ECP_DP_BP384R1_ENABLED)
340 "MBEDTLS_ECP_DP_BP384R1_ENABLED",
341#endif /* MBEDTLS_ECP_DP_BP384R1_ENABLED */
342#if defined(MBEDTLS_ECP_DP_BP512R1_ENABLED)
343 "MBEDTLS_ECP_DP_BP512R1_ENABLED",
344#endif /* MBEDTLS_ECP_DP_BP512R1_ENABLED */
Manuel Pégourié-Gonnard07894332015-06-23 00:18:41 +0200345#if defined(MBEDTLS_ECP_DP_CURVE25519_ENABLED)
346 "MBEDTLS_ECP_DP_CURVE25519_ENABLED",
347#endif /* MBEDTLS_ECP_DP_CURVE25519_ENABLED */
Nicholas Wilson08f3ef12015-11-10 13:10:01 +0000348#if defined(MBEDTLS_ECP_DP_CURVE448_ENABLED)
349 "MBEDTLS_ECP_DP_CURVE448_ENABLED",
350#endif /* MBEDTLS_ECP_DP_CURVE448_ENABLED */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200351#if defined(MBEDTLS_ECP_NIST_OPTIM)
352 "MBEDTLS_ECP_NIST_OPTIM",
353#endif /* MBEDTLS_ECP_NIST_OPTIM */
Manuel Pégourié-Gonnard1a3f9ed2020-05-19 12:38:31 +0200354#if defined(MBEDTLS_ECP_NO_INTERNAL_RNG)
355 "MBEDTLS_ECP_NO_INTERNAL_RNG",
356#endif /* MBEDTLS_ECP_NO_INTERNAL_RNG */
Manuel Pégourié-Gonnard4b9c51e2017-04-20 15:50:26 +0200357#if defined(MBEDTLS_ECP_RESTARTABLE)
358 "MBEDTLS_ECP_RESTARTABLE",
359#endif /* MBEDTLS_ECP_RESTARTABLE */
Gilles Peskine43f564f2019-02-22 12:14:02 +0100360#if defined(MBEDTLS_ECDH_LEGACY_CONTEXT)
361 "MBEDTLS_ECDH_LEGACY_CONTEXT",
362#endif /* MBEDTLS_ECDH_LEGACY_CONTEXT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200363#if defined(MBEDTLS_ECDSA_DETERMINISTIC)
364 "MBEDTLS_ECDSA_DETERMINISTIC",
365#endif /* MBEDTLS_ECDSA_DETERMINISTIC */
Gilles Peskine4e117492020-02-26 18:56:08 +0100366#if defined(MBEDTLS_KEY_EXCHANGE_PSK_ENABLED)
367 "MBEDTLS_KEY_EXCHANGE_PSK_ENABLED",
368#endif /* MBEDTLS_KEY_EXCHANGE_PSK_ENABLED */
369#if defined(MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED)
370 "MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED",
371#endif /* MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED */
372#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED)
373 "MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED",
374#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED */
375#if defined(MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED)
376 "MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED",
377#endif /* MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED */
378#if defined(MBEDTLS_KEY_EXCHANGE_RSA_ENABLED)
379 "MBEDTLS_KEY_EXCHANGE_RSA_ENABLED",
380#endif /* MBEDTLS_KEY_EXCHANGE_RSA_ENABLED */
381#if defined(MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED)
382 "MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED",
383#endif /* MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED */
384#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED)
385 "MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED",
386#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED */
387#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED)
388 "MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED",
389#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED */
390#if defined(MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED)
391 "MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED",
392#endif /* MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED */
393#if defined(MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED)
394 "MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED",
395#endif /* MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED */
396#if defined(MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED)
397 "MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED",
398#endif /* MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200399#if defined(MBEDTLS_PK_PARSE_EC_EXTENDED)
400 "MBEDTLS_PK_PARSE_EC_EXTENDED",
401#endif /* MBEDTLS_PK_PARSE_EC_EXTENDED */
402#if defined(MBEDTLS_ERROR_STRERROR_DUMMY)
403 "MBEDTLS_ERROR_STRERROR_DUMMY",
404#endif /* MBEDTLS_ERROR_STRERROR_DUMMY */
405#if defined(MBEDTLS_GENPRIME)
406 "MBEDTLS_GENPRIME",
407#endif /* MBEDTLS_GENPRIME */
408#if defined(MBEDTLS_FS_IO)
409 "MBEDTLS_FS_IO",
410#endif /* MBEDTLS_FS_IO */
411#if defined(MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES)
412 "MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES",
413#endif /* MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES */
414#if defined(MBEDTLS_NO_PLATFORM_ENTROPY)
415 "MBEDTLS_NO_PLATFORM_ENTROPY",
416#endif /* MBEDTLS_NO_PLATFORM_ENTROPY */
417#if defined(MBEDTLS_ENTROPY_FORCE_SHA256)
418 "MBEDTLS_ENTROPY_FORCE_SHA256",
419#endif /* MBEDTLS_ENTROPY_FORCE_SHA256 */
Paul Bakkerbddf9ab2016-06-01 15:58:12 +0100420#if defined(MBEDTLS_ENTROPY_NV_SEED)
421 "MBEDTLS_ENTROPY_NV_SEED",
422#endif /* MBEDTLS_ENTROPY_NV_SEED */
Ronald Cron71016a92020-08-28 19:01:50 +0200423#if defined(MBEDTLS_PSA_CRYPTO_KEY_ID_ENCODES_OWNER)
424 "MBEDTLS_PSA_CRYPTO_KEY_ID_ENCODES_OWNER",
425#endif /* MBEDTLS_PSA_CRYPTO_KEY_ID_ENCODES_OWNER */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200426#if defined(MBEDTLS_MEMORY_DEBUG)
427 "MBEDTLS_MEMORY_DEBUG",
428#endif /* MBEDTLS_MEMORY_DEBUG */
429#if defined(MBEDTLS_MEMORY_BACKTRACE)
430 "MBEDTLS_MEMORY_BACKTRACE",
431#endif /* MBEDTLS_MEMORY_BACKTRACE */
432#if defined(MBEDTLS_PK_RSA_ALT_SUPPORT)
433 "MBEDTLS_PK_RSA_ALT_SUPPORT",
434#endif /* MBEDTLS_PK_RSA_ALT_SUPPORT */
435#if defined(MBEDTLS_PKCS1_V15)
436 "MBEDTLS_PKCS1_V15",
437#endif /* MBEDTLS_PKCS1_V15 */
438#if defined(MBEDTLS_PKCS1_V21)
439 "MBEDTLS_PKCS1_V21",
440#endif /* MBEDTLS_PKCS1_V21 */
Steven Cooreman6801f082021-02-19 17:21:22 +0100441#if defined(MBEDTLS_PSA_CRYPTO_BUILTIN_KEYS)
442 "MBEDTLS_PSA_CRYPTO_BUILTIN_KEYS",
443#endif /* MBEDTLS_PSA_CRYPTO_BUILTIN_KEYS */
Ronald Cron3768ac12021-01-26 16:58:00 +0100444#if defined(MBEDTLS_PSA_CRYPTO_CLIENT)
445 "MBEDTLS_PSA_CRYPTO_CLIENT",
446#endif /* MBEDTLS_PSA_CRYPTO_CLIENT */
Steven Cooreman0d59f7b02020-07-16 20:27:57 +0200447#if defined(MBEDTLS_PSA_CRYPTO_DRIVERS)
448 "MBEDTLS_PSA_CRYPTO_DRIVERS",
449#endif /* MBEDTLS_PSA_CRYPTO_DRIVERS */
Gilles Peskinef08b3f82020-11-13 17:36:48 +0100450#if defined(MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG)
451 "MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG",
452#endif /* MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG */
Jaeden Amero67a93512018-07-11 16:07:40 +0100453#if defined(MBEDTLS_PSA_CRYPTO_SPM)
454 "MBEDTLS_PSA_CRYPTO_SPM",
455#endif /* MBEDTLS_PSA_CRYPTO_SPM */
Gilles Peskinee3dbdd82019-02-25 11:04:06 +0100456#if defined(MBEDTLS_PSA_INJECT_ENTROPY)
457 "MBEDTLS_PSA_INJECT_ENTROPY",
458#endif /* MBEDTLS_PSA_INJECT_ENTROPY */
David Horstmann5bada222024-03-14 11:20:47 +0000459#if defined(MBEDTLS_PSA_ASSUME_EXCLUSIVE_BUFFERS)
460 "MBEDTLS_PSA_ASSUME_EXCLUSIVE_BUFFERS",
461#endif /* MBEDTLS_PSA_ASSUME_EXCLUSIVE_BUFFERS */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200462#if defined(MBEDTLS_RSA_NO_CRT)
463 "MBEDTLS_RSA_NO_CRT",
464#endif /* MBEDTLS_RSA_NO_CRT */
465#if defined(MBEDTLS_SELF_TEST)
466 "MBEDTLS_SELF_TEST",
467#endif /* MBEDTLS_SELF_TEST */
Manuel Pégourié-Gonnardeb0d8702015-05-28 12:54:04 +0200468#if defined(MBEDTLS_SHA256_SMALLER)
469 "MBEDTLS_SHA256_SMALLER",
470#endif /* MBEDTLS_SHA256_SMALLER */
Manuel Pégourié-Gonnard2306d152019-07-17 12:36:53 +0200471#if defined(MBEDTLS_SHA512_SMALLER)
472 "MBEDTLS_SHA512_SMALLER",
473#endif /* MBEDTLS_SHA512_SMALLER */
Manuel Pégourié-Gonnardad6cb112019-07-17 14:58:03 +0200474#if defined(MBEDTLS_SHA512_NO_SHA384)
475 "MBEDTLS_SHA512_NO_SHA384",
476#endif /* MBEDTLS_SHA512_NO_SHA384 */
Gilles Peskine4e117492020-02-26 18:56:08 +0100477#if defined(MBEDTLS_SSL_ALL_ALERT_MESSAGES)
478 "MBEDTLS_SSL_ALL_ALERT_MESSAGES",
479#endif /* MBEDTLS_SSL_ALL_ALERT_MESSAGES */
Gilles Peskineb22d0cf2020-03-09 16:48:21 +0100480#if defined(MBEDTLS_SSL_RECORD_CHECKING)
481 "MBEDTLS_SSL_RECORD_CHECKING",
482#endif /* MBEDTLS_SSL_RECORD_CHECKING */
483#if defined(MBEDTLS_SSL_DTLS_CONNECTION_ID)
484 "MBEDTLS_SSL_DTLS_CONNECTION_ID",
485#endif /* MBEDTLS_SSL_DTLS_CONNECTION_ID */
Gilles Peskine4e117492020-02-26 18:56:08 +0100486#if defined(MBEDTLS_SSL_ASYNC_PRIVATE)
487 "MBEDTLS_SSL_ASYNC_PRIVATE",
488#endif /* MBEDTLS_SSL_ASYNC_PRIVATE */
Gilles Peskineae59c522025-02-13 13:46:58 +0100489#if defined(MBEDTLS_SSL_CLI_ALLOW_WEAK_CERTIFICATE_VERIFICATION_WITHOUT_HOSTNAME)
490 "MBEDTLS_SSL_CLI_ALLOW_WEAK_CERTIFICATE_VERIFICATION_WITHOUT_HOSTNAME",
491#endif /* MBEDTLS_SSL_CLI_ALLOW_WEAK_CERTIFICATE_VERIFICATION_WITHOUT_HOSTNAME */
Gilles Peskineb22d0cf2020-03-09 16:48:21 +0100492#if defined(MBEDTLS_SSL_CONTEXT_SERIALIZATION)
493 "MBEDTLS_SSL_CONTEXT_SERIALIZATION",
494#endif /* MBEDTLS_SSL_CONTEXT_SERIALIZATION */
Gilles Peskine4e117492020-02-26 18:56:08 +0100495#if defined(MBEDTLS_SSL_DEBUG_ALL)
496 "MBEDTLS_SSL_DEBUG_ALL",
497#endif /* MBEDTLS_SSL_DEBUG_ALL */
498#if defined(MBEDTLS_SSL_ENCRYPT_THEN_MAC)
499 "MBEDTLS_SSL_ENCRYPT_THEN_MAC",
500#endif /* MBEDTLS_SSL_ENCRYPT_THEN_MAC */
501#if defined(MBEDTLS_SSL_EXTENDED_MASTER_SECRET)
502 "MBEDTLS_SSL_EXTENDED_MASTER_SECRET",
503#endif /* MBEDTLS_SSL_EXTENDED_MASTER_SECRET */
504#if defined(MBEDTLS_SSL_FALLBACK_SCSV)
505 "MBEDTLS_SSL_FALLBACK_SCSV",
506#endif /* MBEDTLS_SSL_FALLBACK_SCSV */
507#if defined(MBEDTLS_SSL_KEEP_PEER_CERTIFICATE)
508 "MBEDTLS_SSL_KEEP_PEER_CERTIFICATE",
509#endif /* MBEDTLS_SSL_KEEP_PEER_CERTIFICATE */
510#if defined(MBEDTLS_SSL_HW_RECORD_ACCEL)
511 "MBEDTLS_SSL_HW_RECORD_ACCEL",
512#endif /* MBEDTLS_SSL_HW_RECORD_ACCEL */
513#if defined(MBEDTLS_SSL_CBC_RECORD_SPLITTING)
514 "MBEDTLS_SSL_CBC_RECORD_SPLITTING",
515#endif /* MBEDTLS_SSL_CBC_RECORD_SPLITTING */
516#if defined(MBEDTLS_SSL_RENEGOTIATION)
517 "MBEDTLS_SSL_RENEGOTIATION",
518#endif /* MBEDTLS_SSL_RENEGOTIATION */
519#if defined(MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO)
520 "MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO",
521#endif /* MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO */
522#if defined(MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE)
523 "MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE",
524#endif /* MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE */
525#if defined(MBEDTLS_SSL_MAX_FRAGMENT_LENGTH)
526 "MBEDTLS_SSL_MAX_FRAGMENT_LENGTH",
527#endif /* MBEDTLS_SSL_MAX_FRAGMENT_LENGTH */
528#if defined(MBEDTLS_SSL_PROTO_SSL3)
529 "MBEDTLS_SSL_PROTO_SSL3",
530#endif /* MBEDTLS_SSL_PROTO_SSL3 */
531#if defined(MBEDTLS_SSL_PROTO_TLS1)
532 "MBEDTLS_SSL_PROTO_TLS1",
533#endif /* MBEDTLS_SSL_PROTO_TLS1 */
534#if defined(MBEDTLS_SSL_PROTO_TLS1_1)
535 "MBEDTLS_SSL_PROTO_TLS1_1",
536#endif /* MBEDTLS_SSL_PROTO_TLS1_1 */
537#if defined(MBEDTLS_SSL_PROTO_TLS1_2)
538 "MBEDTLS_SSL_PROTO_TLS1_2",
539#endif /* MBEDTLS_SSL_PROTO_TLS1_2 */
Hanno Beckera0c65d82020-05-28 08:59:39 +0100540#if defined(MBEDTLS_SSL_PROTO_TLS1_3_EXPERIMENTAL)
541 "MBEDTLS_SSL_PROTO_TLS1_3_EXPERIMENTAL",
542#endif /* MBEDTLS_SSL_PROTO_TLS1_3_EXPERIMENTAL */
Gilles Peskine4e117492020-02-26 18:56:08 +0100543#if defined(MBEDTLS_SSL_PROTO_DTLS)
544 "MBEDTLS_SSL_PROTO_DTLS",
545#endif /* MBEDTLS_SSL_PROTO_DTLS */
546#if defined(MBEDTLS_SSL_ALPN)
547 "MBEDTLS_SSL_ALPN",
548#endif /* MBEDTLS_SSL_ALPN */
549#if defined(MBEDTLS_SSL_DTLS_ANTI_REPLAY)
550 "MBEDTLS_SSL_DTLS_ANTI_REPLAY",
551#endif /* MBEDTLS_SSL_DTLS_ANTI_REPLAY */
552#if defined(MBEDTLS_SSL_DTLS_HELLO_VERIFY)
553 "MBEDTLS_SSL_DTLS_HELLO_VERIFY",
554#endif /* MBEDTLS_SSL_DTLS_HELLO_VERIFY */
Johan Pascal701984d2017-02-09 09:56:05 +0700555#if defined(MBEDTLS_SSL_DTLS_SRTP)
556 "MBEDTLS_SSL_DTLS_SRTP",
557#endif /* MBEDTLS_SSL_DTLS_SRTP */
Gilles Peskine4e117492020-02-26 18:56:08 +0100558#if defined(MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE)
559 "MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE",
560#endif /* MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE */
561#if defined(MBEDTLS_SSL_DTLS_BADMAC_LIMIT)
562 "MBEDTLS_SSL_DTLS_BADMAC_LIMIT",
563#endif /* MBEDTLS_SSL_DTLS_BADMAC_LIMIT */
564#if defined(MBEDTLS_SSL_SESSION_TICKETS)
565 "MBEDTLS_SSL_SESSION_TICKETS",
566#endif /* MBEDTLS_SSL_SESSION_TICKETS */
567#if defined(MBEDTLS_SSL_EXPORT_KEYS)
568 "MBEDTLS_SSL_EXPORT_KEYS",
569#endif /* MBEDTLS_SSL_EXPORT_KEYS */
570#if defined(MBEDTLS_SSL_SERVER_NAME_INDICATION)
571 "MBEDTLS_SSL_SERVER_NAME_INDICATION",
572#endif /* MBEDTLS_SSL_SERVER_NAME_INDICATION */
573#if defined(MBEDTLS_SSL_TRUNCATED_HMAC)
574 "MBEDTLS_SSL_TRUNCATED_HMAC",
575#endif /* MBEDTLS_SSL_TRUNCATED_HMAC */
576#if defined(MBEDTLS_SSL_TRUNCATED_HMAC_COMPAT)
577 "MBEDTLS_SSL_TRUNCATED_HMAC_COMPAT",
578#endif /* MBEDTLS_SSL_TRUNCATED_HMAC_COMPAT */
Gilles Peskine3ed2de92020-03-23 20:45:07 +0100579#if defined(MBEDTLS_SSL_VARIABLE_BUFFER_LENGTH)
580 "MBEDTLS_SSL_VARIABLE_BUFFER_LENGTH",
581#endif /* MBEDTLS_SSL_VARIABLE_BUFFER_LENGTH */
Gilles Peskinee0088902023-09-07 19:20:34 +0200582#if defined(MBEDTLS_TLS_DEFAULT_ALLOW_SHA1_IN_KEY_EXCHANGE)
583 "MBEDTLS_TLS_DEFAULT_ALLOW_SHA1_IN_KEY_EXCHANGE",
584#endif /* MBEDTLS_TLS_DEFAULT_ALLOW_SHA1_IN_KEY_EXCHANGE */
Manuel Pégourié-Gonnard6240def2020-07-10 09:35:54 +0200585#if defined(MBEDTLS_TEST_CONSTANT_FLOW_MEMSAN)
586 "MBEDTLS_TEST_CONSTANT_FLOW_MEMSAN",
587#endif /* MBEDTLS_TEST_CONSTANT_FLOW_MEMSAN */
Manuel Pégourié-Gonnard73afa372020-08-19 10:27:38 +0200588#if defined(MBEDTLS_TEST_CONSTANT_FLOW_VALGRIND)
589 "MBEDTLS_TEST_CONSTANT_FLOW_VALGRIND",
590#endif /* MBEDTLS_TEST_CONSTANT_FLOW_VALGRIND */
Gilles Peskinefea6eaf2019-09-11 13:27:48 +0200591#if defined(MBEDTLS_TEST_HOOKS)
592 "MBEDTLS_TEST_HOOKS",
593#endif /* MBEDTLS_TEST_HOOKS */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200594#if defined(MBEDTLS_THREADING_ALT)
595 "MBEDTLS_THREADING_ALT",
596#endif /* MBEDTLS_THREADING_ALT */
597#if defined(MBEDTLS_THREADING_PTHREAD)
598 "MBEDTLS_THREADING_PTHREAD",
599#endif /* MBEDTLS_THREADING_PTHREAD */
Manuel Pégourié-Gonnard26fd7302018-10-22 12:14:52 +0200600#if defined(MBEDTLS_USE_PSA_CRYPTO)
601 "MBEDTLS_USE_PSA_CRYPTO",
602#endif /* MBEDTLS_USE_PSA_CRYPTO */
John Durkop39e09672020-09-24 21:09:25 -0700603#if defined(MBEDTLS_PSA_CRYPTO_CONFIG)
604 "MBEDTLS_PSA_CRYPTO_CONFIG",
605#endif /* MBEDTLS_PSA_CRYPTO_CONFIG */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200606#if defined(MBEDTLS_VERSION_FEATURES)
607 "MBEDTLS_VERSION_FEATURES",
608#endif /* MBEDTLS_VERSION_FEATURES */
Gilles Peskine252e3912020-02-26 18:33:58 +0100609#if defined(MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3)
610 "MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3",
611#endif /* MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3 */
612#if defined(MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION)
613 "MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION",
614#endif /* MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION */
615#if defined(MBEDTLS_X509_TRUSTED_CERTIFICATE_CALLBACK)
616 "MBEDTLS_X509_TRUSTED_CERTIFICATE_CALLBACK",
617#endif /* MBEDTLS_X509_TRUSTED_CERTIFICATE_CALLBACK */
618#if defined(MBEDTLS_X509_CHECK_KEY_USAGE)
619 "MBEDTLS_X509_CHECK_KEY_USAGE",
620#endif /* MBEDTLS_X509_CHECK_KEY_USAGE */
621#if defined(MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE)
622 "MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE",
623#endif /* MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE */
624#if defined(MBEDTLS_X509_RSASSA_PSS_SUPPORT)
625 "MBEDTLS_X509_RSASSA_PSS_SUPPORT",
626#endif /* MBEDTLS_X509_RSASSA_PSS_SUPPORT */
Gilles Peskine4e117492020-02-26 18:56:08 +0100627#if defined(MBEDTLS_ZLIB_SUPPORT)
628 "MBEDTLS_ZLIB_SUPPORT",
629#endif /* MBEDTLS_ZLIB_SUPPORT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200630#if defined(MBEDTLS_AESNI_C)
631 "MBEDTLS_AESNI_C",
632#endif /* MBEDTLS_AESNI_C */
633#if defined(MBEDTLS_AES_C)
634 "MBEDTLS_AES_C",
635#endif /* MBEDTLS_AES_C */
636#if defined(MBEDTLS_ARC4_C)
637 "MBEDTLS_ARC4_C",
638#endif /* MBEDTLS_ARC4_C */
639#if defined(MBEDTLS_ASN1_PARSE_C)
640 "MBEDTLS_ASN1_PARSE_C",
641#endif /* MBEDTLS_ASN1_PARSE_C */
642#if defined(MBEDTLS_ASN1_WRITE_C)
643 "MBEDTLS_ASN1_WRITE_C",
644#endif /* MBEDTLS_ASN1_WRITE_C */
645#if defined(MBEDTLS_BASE64_C)
646 "MBEDTLS_BASE64_C",
647#endif /* MBEDTLS_BASE64_C */
648#if defined(MBEDTLS_BIGNUM_C)
649 "MBEDTLS_BIGNUM_C",
650#endif /* MBEDTLS_BIGNUM_C */
651#if defined(MBEDTLS_BLOWFISH_C)
652 "MBEDTLS_BLOWFISH_C",
653#endif /* MBEDTLS_BLOWFISH_C */
654#if defined(MBEDTLS_CAMELLIA_C)
655 "MBEDTLS_CAMELLIA_C",
656#endif /* MBEDTLS_CAMELLIA_C */
Markku-Juhani O. Saarinen3c0b53b2017-11-30 16:00:34 +0000657#if defined(MBEDTLS_ARIA_C)
658 "MBEDTLS_ARIA_C",
659#endif /* MBEDTLS_ARIA_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200660#if defined(MBEDTLS_CCM_C)
661 "MBEDTLS_CCM_C",
662#endif /* MBEDTLS_CCM_C */
Gilles Peskine252e3912020-02-26 18:33:58 +0100663#if defined(MBEDTLS_CERTS_C)
664 "MBEDTLS_CERTS_C",
665#endif /* MBEDTLS_CERTS_C */
Daniel King34b822c2016-05-15 17:28:08 -0300666#if defined(MBEDTLS_CHACHA20_C)
667 "MBEDTLS_CHACHA20_C",
668#endif /* MBEDTLS_CHACHA20_C */
Manuel Pégourié-Gonnard94175a52018-06-04 12:42:17 +0200669#if defined(MBEDTLS_CHACHAPOLY_C)
670 "MBEDTLS_CHACHAPOLY_C",
671#endif /* MBEDTLS_CHACHAPOLY_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200672#if defined(MBEDTLS_CIPHER_C)
673 "MBEDTLS_CIPHER_C",
674#endif /* MBEDTLS_CIPHER_C */
Robert Cragie48f2ff92015-12-14 17:34:33 +0000675#if defined(MBEDTLS_CMAC_C)
676 "MBEDTLS_CMAC_C",
677#endif /* MBEDTLS_CMAC_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200678#if defined(MBEDTLS_CTR_DRBG_C)
679 "MBEDTLS_CTR_DRBG_C",
680#endif /* MBEDTLS_CTR_DRBG_C */
Gilles Peskine4e117492020-02-26 18:56:08 +0100681#if defined(MBEDTLS_DEBUG_C)
682 "MBEDTLS_DEBUG_C",
683#endif /* MBEDTLS_DEBUG_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200684#if defined(MBEDTLS_DES_C)
685 "MBEDTLS_DES_C",
686#endif /* MBEDTLS_DES_C */
687#if defined(MBEDTLS_DHM_C)
688 "MBEDTLS_DHM_C",
689#endif /* MBEDTLS_DHM_C */
690#if defined(MBEDTLS_ECDH_C)
691 "MBEDTLS_ECDH_C",
692#endif /* MBEDTLS_ECDH_C */
693#if defined(MBEDTLS_ECDSA_C)
694 "MBEDTLS_ECDSA_C",
695#endif /* MBEDTLS_ECDSA_C */
Manuel Pégourié-Gonnard4d8685b2015-08-05 15:44:42 +0200696#if defined(MBEDTLS_ECJPAKE_C)
697 "MBEDTLS_ECJPAKE_C",
698#endif /* MBEDTLS_ECJPAKE_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200699#if defined(MBEDTLS_ECP_C)
700 "MBEDTLS_ECP_C",
701#endif /* MBEDTLS_ECP_C */
702#if defined(MBEDTLS_ENTROPY_C)
703 "MBEDTLS_ENTROPY_C",
704#endif /* MBEDTLS_ENTROPY_C */
705#if defined(MBEDTLS_ERROR_C)
706 "MBEDTLS_ERROR_C",
707#endif /* MBEDTLS_ERROR_C */
708#if defined(MBEDTLS_GCM_C)
709 "MBEDTLS_GCM_C",
710#endif /* MBEDTLS_GCM_C */
711#if defined(MBEDTLS_HAVEGE_C)
712 "MBEDTLS_HAVEGE_C",
713#endif /* MBEDTLS_HAVEGE_C */
Thomas Fossati656864b2016-07-17 08:51:22 +0100714#if defined(MBEDTLS_HKDF_C)
715 "MBEDTLS_HKDF_C",
716#endif /* MBEDTLS_HKDF_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200717#if defined(MBEDTLS_HMAC_DRBG_C)
718 "MBEDTLS_HMAC_DRBG_C",
719#endif /* MBEDTLS_HMAC_DRBG_C */
Ron Eldor466a57f2018-05-03 16:54:28 +0300720#if defined(MBEDTLS_NIST_KW_C)
721 "MBEDTLS_NIST_KW_C",
722#endif /* MBEDTLS_NIST_KW_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200723#if defined(MBEDTLS_MD_C)
724 "MBEDTLS_MD_C",
725#endif /* MBEDTLS_MD_C */
726#if defined(MBEDTLS_MD2_C)
727 "MBEDTLS_MD2_C",
728#endif /* MBEDTLS_MD2_C */
729#if defined(MBEDTLS_MD4_C)
730 "MBEDTLS_MD4_C",
731#endif /* MBEDTLS_MD4_C */
732#if defined(MBEDTLS_MD5_C)
733 "MBEDTLS_MD5_C",
734#endif /* MBEDTLS_MD5_C */
735#if defined(MBEDTLS_MEMORY_BUFFER_ALLOC_C)
736 "MBEDTLS_MEMORY_BUFFER_ALLOC_C",
737#endif /* MBEDTLS_MEMORY_BUFFER_ALLOC_C */
Gilles Peskine4e117492020-02-26 18:56:08 +0100738#if defined(MBEDTLS_NET_C)
739 "MBEDTLS_NET_C",
740#endif /* MBEDTLS_NET_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200741#if defined(MBEDTLS_OID_C)
742 "MBEDTLS_OID_C",
743#endif /* MBEDTLS_OID_C */
744#if defined(MBEDTLS_PADLOCK_C)
745 "MBEDTLS_PADLOCK_C",
746#endif /* MBEDTLS_PADLOCK_C */
747#if defined(MBEDTLS_PEM_PARSE_C)
748 "MBEDTLS_PEM_PARSE_C",
749#endif /* MBEDTLS_PEM_PARSE_C */
750#if defined(MBEDTLS_PEM_WRITE_C)
751 "MBEDTLS_PEM_WRITE_C",
752#endif /* MBEDTLS_PEM_WRITE_C */
753#if defined(MBEDTLS_PK_C)
754 "MBEDTLS_PK_C",
755#endif /* MBEDTLS_PK_C */
756#if defined(MBEDTLS_PK_PARSE_C)
757 "MBEDTLS_PK_PARSE_C",
758#endif /* MBEDTLS_PK_PARSE_C */
759#if defined(MBEDTLS_PK_WRITE_C)
760 "MBEDTLS_PK_WRITE_C",
761#endif /* MBEDTLS_PK_WRITE_C */
762#if defined(MBEDTLS_PKCS5_C)
763 "MBEDTLS_PKCS5_C",
764#endif /* MBEDTLS_PKCS5_C */
Gilles Peskine252e3912020-02-26 18:33:58 +0100765#if defined(MBEDTLS_PKCS11_C)
766 "MBEDTLS_PKCS11_C",
767#endif /* MBEDTLS_PKCS11_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200768#if defined(MBEDTLS_PKCS12_C)
769 "MBEDTLS_PKCS12_C",
770#endif /* MBEDTLS_PKCS12_C */
771#if defined(MBEDTLS_PLATFORM_C)
772 "MBEDTLS_PLATFORM_C",
773#endif /* MBEDTLS_PLATFORM_C */
Daniel Kingadc32c02016-05-16 18:25:45 -0300774#if defined(MBEDTLS_POLY1305_C)
775 "MBEDTLS_POLY1305_C",
776#endif /* MBEDTLS_POLY1305_C */
Gilles Peskinee59236f2018-01-27 23:32:46 +0100777#if defined(MBEDTLS_PSA_CRYPTO_C)
778 "MBEDTLS_PSA_CRYPTO_C",
779#endif /* MBEDTLS_PSA_CRYPTO_C */
Gilles Peskinea8ade162019-06-26 11:24:49 +0200780#if defined(MBEDTLS_PSA_CRYPTO_SE_C)
781 "MBEDTLS_PSA_CRYPTO_SE_C",
782#endif /* MBEDTLS_PSA_CRYPTO_SE_C */
Darryl Greendb2b8db2018-06-15 13:06:04 +0100783#if defined(MBEDTLS_PSA_CRYPTO_STORAGE_C)
784 "MBEDTLS_PSA_CRYPTO_STORAGE_C",
785#endif /* MBEDTLS_PSA_CRYPTO_STORAGE_C */
Gilles Peskine6194dc22018-11-16 22:24:15 +0100786#if defined(MBEDTLS_PSA_ITS_FILE_C)
787 "MBEDTLS_PSA_ITS_FILE_C",
788#endif /* MBEDTLS_PSA_ITS_FILE_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200789#if defined(MBEDTLS_RIPEMD160_C)
790 "MBEDTLS_RIPEMD160_C",
791#endif /* MBEDTLS_RIPEMD160_C */
792#if defined(MBEDTLS_RSA_C)
793 "MBEDTLS_RSA_C",
794#endif /* MBEDTLS_RSA_C */
795#if defined(MBEDTLS_SHA1_C)
796 "MBEDTLS_SHA1_C",
797#endif /* MBEDTLS_SHA1_C */
798#if defined(MBEDTLS_SHA256_C)
799 "MBEDTLS_SHA256_C",
800#endif /* MBEDTLS_SHA256_C */
801#if defined(MBEDTLS_SHA512_C)
802 "MBEDTLS_SHA512_C",
803#endif /* MBEDTLS_SHA512_C */
Gilles Peskine4e117492020-02-26 18:56:08 +0100804#if defined(MBEDTLS_SSL_CACHE_C)
805 "MBEDTLS_SSL_CACHE_C",
806#endif /* MBEDTLS_SSL_CACHE_C */
807#if defined(MBEDTLS_SSL_COOKIE_C)
808 "MBEDTLS_SSL_COOKIE_C",
809#endif /* MBEDTLS_SSL_COOKIE_C */
810#if defined(MBEDTLS_SSL_TICKET_C)
811 "MBEDTLS_SSL_TICKET_C",
812#endif /* MBEDTLS_SSL_TICKET_C */
813#if defined(MBEDTLS_SSL_CLI_C)
814 "MBEDTLS_SSL_CLI_C",
815#endif /* MBEDTLS_SSL_CLI_C */
816#if defined(MBEDTLS_SSL_SRV_C)
817 "MBEDTLS_SSL_SRV_C",
818#endif /* MBEDTLS_SSL_SRV_C */
819#if defined(MBEDTLS_SSL_TLS_C)
820 "MBEDTLS_SSL_TLS_C",
821#endif /* MBEDTLS_SSL_TLS_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200822#if defined(MBEDTLS_THREADING_C)
823 "MBEDTLS_THREADING_C",
824#endif /* MBEDTLS_THREADING_C */
825#if defined(MBEDTLS_TIMING_C)
826 "MBEDTLS_TIMING_C",
827#endif /* MBEDTLS_TIMING_C */
828#if defined(MBEDTLS_VERSION_C)
829 "MBEDTLS_VERSION_C",
830#endif /* MBEDTLS_VERSION_C */
Gilles Peskine252e3912020-02-26 18:33:58 +0100831#if defined(MBEDTLS_X509_USE_C)
832 "MBEDTLS_X509_USE_C",
833#endif /* MBEDTLS_X509_USE_C */
834#if defined(MBEDTLS_X509_CRT_PARSE_C)
835 "MBEDTLS_X509_CRT_PARSE_C",
836#endif /* MBEDTLS_X509_CRT_PARSE_C */
837#if defined(MBEDTLS_X509_CRL_PARSE_C)
838 "MBEDTLS_X509_CRL_PARSE_C",
839#endif /* MBEDTLS_X509_CRL_PARSE_C */
840#if defined(MBEDTLS_X509_CSR_PARSE_C)
841 "MBEDTLS_X509_CSR_PARSE_C",
842#endif /* MBEDTLS_X509_CSR_PARSE_C */
843#if defined(MBEDTLS_X509_CREATE_C)
844 "MBEDTLS_X509_CREATE_C",
845#endif /* MBEDTLS_X509_CREATE_C */
846#if defined(MBEDTLS_X509_CRT_WRITE_C)
847 "MBEDTLS_X509_CRT_WRITE_C",
848#endif /* MBEDTLS_X509_CRT_WRITE_C */
849#if defined(MBEDTLS_X509_CSR_WRITE_C)
850 "MBEDTLS_X509_CSR_WRITE_C",
851#endif /* MBEDTLS_X509_CSR_WRITE_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200852#if defined(MBEDTLS_XTEA_C)
853 "MBEDTLS_XTEA_C",
854#endif /* MBEDTLS_XTEA_C */
855#endif /* MBEDTLS_VERSION_FEATURES */
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200856 NULL
857};
858
Gilles Peskineec03b042023-01-11 14:52:37 +0100859int mbedtls_version_check_feature(const char *feature)
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200860{
Máté Vargac5de4622019-06-12 12:26:37 +0200861 const char * const *idx = features;
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200862
Gilles Peskineec03b042023-01-11 14:52:37 +0100863 if (*idx == NULL) {
864 return -2;
865 }
Paul Bakker2ca1dc82014-04-30 17:01:25 +0200866
Gilles Peskineec03b042023-01-11 14:52:37 +0100867 if (feature == NULL) {
868 return -1;
869 }
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200870
Gilles Peskineec03b042023-01-11 14:52:37 +0100871 while (*idx != NULL) {
872 if (!strcmp(*idx, feature)) {
873 return 0;
874 }
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200875 idx++;
876 }
Gilles Peskineec03b042023-01-11 14:52:37 +0100877 return -1;
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200878}
879
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200880#endif /* MBEDTLS_VERSION_C */