blob: ee13f7898a9e7bc0ae239b11f6e2b008abb36d8c [file] [log] [blame]
Paul Bakker0f90d7d2014-04-30 11:49:44 +02001/*
2 * Version feature information
3 *
Bence Szépkúti44bfbe32020-08-19 16:54:51 +02004 * Copyright The Mbed TLS Contributors
Bence Szépkúti4e9f7122020-06-05 13:02:18 +02005 * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
6 *
7 * This file is provided under the Apache License 2.0, or the
8 * GNU General Public License v2.0 or later.
9 *
10 * **********
11 * Apache License 2.0:
Manuel Pégourié-Gonnard37ff1402015-09-04 14:21:07 +020012 *
13 * Licensed under the Apache License, Version 2.0 (the "License"); you may
14 * not use this file except in compliance with the License.
15 * You may obtain a copy of the License at
16 *
17 * http://www.apache.org/licenses/LICENSE-2.0
18 *
19 * Unless required by applicable law or agreed to in writing, software
20 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
21 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
22 * See the License for the specific language governing permissions and
23 * limitations under the License.
Paul Bakker0f90d7d2014-04-30 11:49:44 +020024 *
Bence Szépkúti4e9f7122020-06-05 13:02:18 +020025 * **********
26 *
27 * **********
28 * GNU General Public License v2.0 or later:
29 *
30 * This program is free software; you can redistribute it and/or modify
31 * it under the terms of the GNU General Public License as published by
32 * the Free Software Foundation; either version 2 of the License, or
33 * (at your option) any later version.
34 *
35 * This program is distributed in the hope that it will be useful,
36 * but WITHOUT ANY WARRANTY; without even the implied warranty of
37 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
38 * GNU General Public License for more details.
39 *
40 * You should have received a copy of the GNU General Public License along
41 * with this program; if not, write to the Free Software Foundation, Inc.,
42 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
43 *
44 * **********
Paul Bakker0f90d7d2014-04-30 11:49:44 +020045 */
46
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020047#if !defined(MBEDTLS_CONFIG_FILE)
Manuel Pégourié-Gonnard7f809972015-03-09 17:05:11 +000048#include "mbedtls/config.h"
Manuel Pégourié-Gonnardcef4ad22014-04-29 12:39:06 +020049#else
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020050#include MBEDTLS_CONFIG_FILE
Manuel Pégourié-Gonnardcef4ad22014-04-29 12:39:06 +020051#endif
Paul Bakker0f90d7d2014-04-30 11:49:44 +020052
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020053#if defined(MBEDTLS_VERSION_C)
Paul Bakker0f90d7d2014-04-30 11:49:44 +020054
Manuel Pégourié-Gonnard7f809972015-03-09 17:05:11 +000055#include "mbedtls/version.h"
Paul Bakker0f90d7d2014-04-30 11:49:44 +020056
57#include <string.h>
58
Manuel Pégourié-Gonnard385069f2015-03-05 15:47:55 +000059static const char *features[] = {
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020060#if defined(MBEDTLS_VERSION_FEATURES)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020061#if defined(MBEDTLS_HAVE_ASM)
62 "MBEDTLS_HAVE_ASM",
63#endif /* MBEDTLS_HAVE_ASM */
Gilles Peskine683ac272017-06-15 18:01:54 +020064#if defined(MBEDTLS_NO_UDBL_DIVISION)
65 "MBEDTLS_NO_UDBL_DIVISION",
66#endif /* MBEDTLS_NO_UDBL_DIVISION */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020067#if defined(MBEDTLS_HAVE_SSE2)
68 "MBEDTLS_HAVE_SSE2",
69#endif /* MBEDTLS_HAVE_SSE2 */
70#if defined(MBEDTLS_HAVE_TIME)
71 "MBEDTLS_HAVE_TIME",
72#endif /* MBEDTLS_HAVE_TIME */
Manuel Pégourié-Gonnardf9cbd732015-06-22 12:06:50 +020073#if defined(MBEDTLS_HAVE_TIME_DATE)
74 "MBEDTLS_HAVE_TIME_DATE",
75#endif /* MBEDTLS_HAVE_TIME_DATE */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020076#if defined(MBEDTLS_PLATFORM_MEMORY)
77 "MBEDTLS_PLATFORM_MEMORY",
78#endif /* MBEDTLS_PLATFORM_MEMORY */
79#if defined(MBEDTLS_PLATFORM_NO_STD_FUNCTIONS)
80 "MBEDTLS_PLATFORM_NO_STD_FUNCTIONS",
81#endif /* MBEDTLS_PLATFORM_NO_STD_FUNCTIONS */
82#if defined(MBEDTLS_PLATFORM_EXIT_ALT)
83 "MBEDTLS_PLATFORM_EXIT_ALT",
84#endif /* MBEDTLS_PLATFORM_EXIT_ALT */
Simon Butcher3fe6cd32016-04-26 19:51:29 +010085#if defined(MBEDTLS_PLATFORM_TIME_ALT)
86 "MBEDTLS_PLATFORM_TIME_ALT",
87#endif /* MBEDTLS_PLATFORM_TIME_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020088#if defined(MBEDTLS_PLATFORM_FPRINTF_ALT)
89 "MBEDTLS_PLATFORM_FPRINTF_ALT",
90#endif /* MBEDTLS_PLATFORM_FPRINTF_ALT */
91#if defined(MBEDTLS_PLATFORM_PRINTF_ALT)
92 "MBEDTLS_PLATFORM_PRINTF_ALT",
93#endif /* MBEDTLS_PLATFORM_PRINTF_ALT */
94#if defined(MBEDTLS_PLATFORM_SNPRINTF_ALT)
95 "MBEDTLS_PLATFORM_SNPRINTF_ALT",
96#endif /* MBEDTLS_PLATFORM_SNPRINTF_ALT */
Paul Bakkerbddf9ab2016-06-01 15:58:12 +010097#if defined(MBEDTLS_PLATFORM_NV_SEED_ALT)
98 "MBEDTLS_PLATFORM_NV_SEED_ALT",
99#endif /* MBEDTLS_PLATFORM_NV_SEED_ALT */
Simon Butchera95d6302017-07-21 23:48:55 +0100100#if defined(MBEDTLS_PLATFORM_SETUP_TEARDOWN_ALT)
101 "MBEDTLS_PLATFORM_SETUP_TEARDOWN_ALT",
102#endif /* MBEDTLS_PLATFORM_SETUP_TEARDOWN_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200103#if defined(MBEDTLS_DEPRECATED_WARNING)
104 "MBEDTLS_DEPRECATED_WARNING",
105#endif /* MBEDTLS_DEPRECATED_WARNING */
106#if defined(MBEDTLS_DEPRECATED_REMOVED)
107 "MBEDTLS_DEPRECATED_REMOVED",
108#endif /* MBEDTLS_DEPRECATED_REMOVED */
109#if defined(MBEDTLS_TIMING_ALT)
110 "MBEDTLS_TIMING_ALT",
111#endif /* MBEDTLS_TIMING_ALT */
112#if defined(MBEDTLS_AES_ALT)
113 "MBEDTLS_AES_ALT",
114#endif /* MBEDTLS_AES_ALT */
115#if defined(MBEDTLS_ARC4_ALT)
116 "MBEDTLS_ARC4_ALT",
117#endif /* MBEDTLS_ARC4_ALT */
118#if defined(MBEDTLS_BLOWFISH_ALT)
119 "MBEDTLS_BLOWFISH_ALT",
120#endif /* MBEDTLS_BLOWFISH_ALT */
121#if defined(MBEDTLS_CAMELLIA_ALT)
122 "MBEDTLS_CAMELLIA_ALT",
123#endif /* MBEDTLS_CAMELLIA_ALT */
Steven Cooreman3a933872017-04-04 12:02:37 +0200124#if defined(MBEDTLS_CCM_ALT)
125 "MBEDTLS_CCM_ALT",
126#endif /* MBEDTLS_CCM_ALT */
Steven Cooreman12d9f3c2017-04-04 12:01:42 +0200127#if defined(MBEDTLS_CMAC_ALT)
128 "MBEDTLS_CMAC_ALT",
129#endif /* MBEDTLS_CMAC_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200130#if defined(MBEDTLS_DES_ALT)
131 "MBEDTLS_DES_ALT",
132#endif /* MBEDTLS_DES_ALT */
nirekh01d569ecf2018-01-09 16:43:21 +0000133#if defined(MBEDTLS_DHM_ALT)
134 "MBEDTLS_DHM_ALT",
135#endif /* MBEDTLS_DHM_ALT */
Hanno Becker616d1ca2018-01-24 10:25:05 +0000136#if defined(MBEDTLS_ECJPAKE_ALT)
137 "MBEDTLS_ECJPAKE_ALT",
138#endif /* MBEDTLS_ECJPAKE_ALT */
Jaeden Amero15263302017-09-21 12:53:48 +0100139#if defined(MBEDTLS_GCM_ALT)
140 "MBEDTLS_GCM_ALT",
141#endif /* MBEDTLS_GCM_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200142#if defined(MBEDTLS_MD2_ALT)
143 "MBEDTLS_MD2_ALT",
144#endif /* MBEDTLS_MD2_ALT */
145#if defined(MBEDTLS_MD4_ALT)
146 "MBEDTLS_MD4_ALT",
147#endif /* MBEDTLS_MD4_ALT */
148#if defined(MBEDTLS_MD5_ALT)
149 "MBEDTLS_MD5_ALT",
150#endif /* MBEDTLS_MD5_ALT */
151#if defined(MBEDTLS_RIPEMD160_ALT)
152 "MBEDTLS_RIPEMD160_ALT",
153#endif /* MBEDTLS_RIPEMD160_ALT */
Hanno Becker88683b22018-01-04 18:26:54 +0000154#if defined(MBEDTLS_RSA_ALT)
155 "MBEDTLS_RSA_ALT",
156#endif /* MBEDTLS_RSA_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200157#if defined(MBEDTLS_SHA1_ALT)
158 "MBEDTLS_SHA1_ALT",
159#endif /* MBEDTLS_SHA1_ALT */
160#if defined(MBEDTLS_SHA256_ALT)
161 "MBEDTLS_SHA256_ALT",
162#endif /* MBEDTLS_SHA256_ALT */
163#if defined(MBEDTLS_SHA512_ALT)
164 "MBEDTLS_SHA512_ALT",
165#endif /* MBEDTLS_SHA512_ALT */
Hanno Becker88683b22018-01-04 18:26:54 +0000166#if defined(MBEDTLS_XTEA_ALT)
167 "MBEDTLS_XTEA_ALT",
168#endif /* MBEDTLS_XTEA_ALT */
Janos Follath69b20512016-11-21 14:53:57 +0000169#if defined(MBEDTLS_ECP_ALT)
170 "MBEDTLS_ECP_ALT",
171#endif /* MBEDTLS_ECP_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200172#if defined(MBEDTLS_MD2_PROCESS_ALT)
173 "MBEDTLS_MD2_PROCESS_ALT",
174#endif /* MBEDTLS_MD2_PROCESS_ALT */
175#if defined(MBEDTLS_MD4_PROCESS_ALT)
176 "MBEDTLS_MD4_PROCESS_ALT",
177#endif /* MBEDTLS_MD4_PROCESS_ALT */
178#if defined(MBEDTLS_MD5_PROCESS_ALT)
179 "MBEDTLS_MD5_PROCESS_ALT",
180#endif /* MBEDTLS_MD5_PROCESS_ALT */
181#if defined(MBEDTLS_RIPEMD160_PROCESS_ALT)
182 "MBEDTLS_RIPEMD160_PROCESS_ALT",
183#endif /* MBEDTLS_RIPEMD160_PROCESS_ALT */
184#if defined(MBEDTLS_SHA1_PROCESS_ALT)
185 "MBEDTLS_SHA1_PROCESS_ALT",
186#endif /* MBEDTLS_SHA1_PROCESS_ALT */
187#if defined(MBEDTLS_SHA256_PROCESS_ALT)
188 "MBEDTLS_SHA256_PROCESS_ALT",
189#endif /* MBEDTLS_SHA256_PROCESS_ALT */
190#if defined(MBEDTLS_SHA512_PROCESS_ALT)
191 "MBEDTLS_SHA512_PROCESS_ALT",
192#endif /* MBEDTLS_SHA512_PROCESS_ALT */
Manuel Pégourié-Gonnarda27b1972015-05-12 16:09:34 +0200193#if defined(MBEDTLS_DES_SETKEY_ALT)
194 "MBEDTLS_DES_SETKEY_ALT",
195#endif /* MBEDTLS_DES_SETKEY_ALT */
196#if defined(MBEDTLS_DES_CRYPT_ECB_ALT)
197 "MBEDTLS_DES_CRYPT_ECB_ALT",
198#endif /* MBEDTLS_DES_CRYPT_ECB_ALT */
199#if defined(MBEDTLS_DES3_CRYPT_ECB_ALT)
200 "MBEDTLS_DES3_CRYPT_ECB_ALT",
201#endif /* MBEDTLS_DES3_CRYPT_ECB_ALT */
202#if defined(MBEDTLS_AES_SETKEY_ENC_ALT)
203 "MBEDTLS_AES_SETKEY_ENC_ALT",
204#endif /* MBEDTLS_AES_SETKEY_ENC_ALT */
205#if defined(MBEDTLS_AES_SETKEY_DEC_ALT)
206 "MBEDTLS_AES_SETKEY_DEC_ALT",
207#endif /* MBEDTLS_AES_SETKEY_DEC_ALT */
208#if defined(MBEDTLS_AES_ENCRYPT_ALT)
209 "MBEDTLS_AES_ENCRYPT_ALT",
210#endif /* MBEDTLS_AES_ENCRYPT_ALT */
211#if defined(MBEDTLS_AES_DECRYPT_ALT)
212 "MBEDTLS_AES_DECRYPT_ALT",
213#endif /* MBEDTLS_AES_DECRYPT_ALT */
Ron Eldora84c1cb2017-10-10 19:04:27 +0300214#if defined(MBEDTLS_ECDH_GEN_PUBLIC_ALT)
215 "MBEDTLS_ECDH_GEN_PUBLIC_ALT",
216#endif /* MBEDTLS_ECDH_GEN_PUBLIC_ALT */
Ron Eldor3226d362017-10-12 14:17:48 +0300217#if defined(MBEDTLS_ECDH_COMPUTE_SHARED_ALT)
218 "MBEDTLS_ECDH_COMPUTE_SHARED_ALT",
219#endif /* MBEDTLS_ECDH_COMPUTE_SHARED_ALT */
Ron Eldor314adb62017-10-10 18:28:25 +0300220#if defined(MBEDTLS_ECDSA_VERIFY_ALT)
221 "MBEDTLS_ECDSA_VERIFY_ALT",
222#endif /* MBEDTLS_ECDSA_VERIFY_ALT */
223#if defined(MBEDTLS_ECDSA_SIGN_ALT)
224 "MBEDTLS_ECDSA_SIGN_ALT",
225#endif /* MBEDTLS_ECDSA_SIGN_ALT */
226#if defined(MBEDTLS_ECDSA_GENKEY_ALT)
227 "MBEDTLS_ECDSA_GENKEY_ALT",
228#endif /* MBEDTLS_ECDSA_GENKEY_ALT */
Janos Follath69b20512016-11-21 14:53:57 +0000229#if defined(MBEDTLS_ECP_INTERNAL_ALT)
230 "MBEDTLS_ECP_INTERNAL_ALT",
231#endif /* MBEDTLS_ECP_INTERNAL_ALT */
232#if defined(MBEDTLS_ECP_RANDOMIZE_JAC_ALT)
233 "MBEDTLS_ECP_RANDOMIZE_JAC_ALT",
234#endif /* MBEDTLS_ECP_RANDOMIZE_JAC_ALT */
235#if defined(MBEDTLS_ECP_ADD_MIXED_ALT)
236 "MBEDTLS_ECP_ADD_MIXED_ALT",
237#endif /* MBEDTLS_ECP_ADD_MIXED_ALT */
238#if defined(MBEDTLS_ECP_DOUBLE_JAC_ALT)
239 "MBEDTLS_ECP_DOUBLE_JAC_ALT",
240#endif /* MBEDTLS_ECP_DOUBLE_JAC_ALT */
241#if defined(MBEDTLS_ECP_NORMALIZE_JAC_MANY_ALT)
242 "MBEDTLS_ECP_NORMALIZE_JAC_MANY_ALT",
243#endif /* MBEDTLS_ECP_NORMALIZE_JAC_MANY_ALT */
244#if defined(MBEDTLS_ECP_NORMALIZE_JAC_ALT)
245 "MBEDTLS_ECP_NORMALIZE_JAC_ALT",
246#endif /* MBEDTLS_ECP_NORMALIZE_JAC_ALT */
247#if defined(MBEDTLS_ECP_DOUBLE_ADD_MXZ_ALT)
248 "MBEDTLS_ECP_DOUBLE_ADD_MXZ_ALT",
249#endif /* MBEDTLS_ECP_DOUBLE_ADD_MXZ_ALT */
250#if defined(MBEDTLS_ECP_RANDOMIZE_MXZ_ALT)
251 "MBEDTLS_ECP_RANDOMIZE_MXZ_ALT",
252#endif /* MBEDTLS_ECP_RANDOMIZE_MXZ_ALT */
253#if defined(MBEDTLS_ECP_NORMALIZE_MXZ_ALT)
254 "MBEDTLS_ECP_NORMALIZE_MXZ_ALT",
255#endif /* MBEDTLS_ECP_NORMALIZE_MXZ_ALT */
Manuel Pégourié-Gonnard40597ce2020-07-28 10:53:06 +0200256#if defined(MBEDTLS_TEST_CONSTANT_FLOW_MEMSAN)
257 "MBEDTLS_TEST_CONSTANT_FLOW_MEMSAN",
258#endif /* MBEDTLS_TEST_CONSTANT_FLOW_MEMSAN */
Manuel Pégourié-Gonnard426c2d42020-08-25 11:26:37 +0200259#if defined(MBEDTLS_TEST_CONSTANT_FLOW_VALGRIND)
260 "MBEDTLS_TEST_CONSTANT_FLOW_VALGRIND",
261#endif /* MBEDTLS_TEST_CONSTANT_FLOW_VALGRIND */
Simon Butcherab5df402016-06-11 02:31:21 +0100262#if defined(MBEDTLS_TEST_NULL_ENTROPY)
263 "MBEDTLS_TEST_NULL_ENTROPY",
264#endif /* MBEDTLS_TEST_NULL_ENTROPY */
Manuel Pégourié-Gonnardf9cbd732015-06-22 12:06:50 +0200265#if defined(MBEDTLS_ENTROPY_HARDWARE_ALT)
266 "MBEDTLS_ENTROPY_HARDWARE_ALT",
267#endif /* MBEDTLS_ENTROPY_HARDWARE_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200268#if defined(MBEDTLS_AES_ROM_TABLES)
269 "MBEDTLS_AES_ROM_TABLES",
270#endif /* MBEDTLS_AES_ROM_TABLES */
271#if defined(MBEDTLS_CAMELLIA_SMALL_MEMORY)
272 "MBEDTLS_CAMELLIA_SMALL_MEMORY",
273#endif /* MBEDTLS_CAMELLIA_SMALL_MEMORY */
274#if defined(MBEDTLS_CIPHER_MODE_CBC)
275 "MBEDTLS_CIPHER_MODE_CBC",
276#endif /* MBEDTLS_CIPHER_MODE_CBC */
277#if defined(MBEDTLS_CIPHER_MODE_CFB)
278 "MBEDTLS_CIPHER_MODE_CFB",
279#endif /* MBEDTLS_CIPHER_MODE_CFB */
280#if defined(MBEDTLS_CIPHER_MODE_CTR)
281 "MBEDTLS_CIPHER_MODE_CTR",
282#endif /* MBEDTLS_CIPHER_MODE_CTR */
283#if defined(MBEDTLS_CIPHER_NULL_CIPHER)
284 "MBEDTLS_CIPHER_NULL_CIPHER",
285#endif /* MBEDTLS_CIPHER_NULL_CIPHER */
286#if defined(MBEDTLS_CIPHER_PADDING_PKCS7)
287 "MBEDTLS_CIPHER_PADDING_PKCS7",
288#endif /* MBEDTLS_CIPHER_PADDING_PKCS7 */
289#if defined(MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS)
290 "MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS",
291#endif /* MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS */
292#if defined(MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN)
293 "MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN",
294#endif /* MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN */
295#if defined(MBEDTLS_CIPHER_PADDING_ZEROS)
296 "MBEDTLS_CIPHER_PADDING_ZEROS",
297#endif /* MBEDTLS_CIPHER_PADDING_ZEROS */
298#if defined(MBEDTLS_ENABLE_WEAK_CIPHERSUITES)
299 "MBEDTLS_ENABLE_WEAK_CIPHERSUITES",
300#endif /* MBEDTLS_ENABLE_WEAK_CIPHERSUITES */
301#if defined(MBEDTLS_REMOVE_ARC4_CIPHERSUITES)
302 "MBEDTLS_REMOVE_ARC4_CIPHERSUITES",
303#endif /* MBEDTLS_REMOVE_ARC4_CIPHERSUITES */
Andres Amaya Garcia21ade062018-10-30 18:21:41 +0000304#if defined(MBEDTLS_REMOVE_3DES_CIPHERSUITES)
305 "MBEDTLS_REMOVE_3DES_CIPHERSUITES",
306#endif /* MBEDTLS_REMOVE_3DES_CIPHERSUITES */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200307#if defined(MBEDTLS_ECP_DP_SECP192R1_ENABLED)
308 "MBEDTLS_ECP_DP_SECP192R1_ENABLED",
309#endif /* MBEDTLS_ECP_DP_SECP192R1_ENABLED */
310#if defined(MBEDTLS_ECP_DP_SECP224R1_ENABLED)
311 "MBEDTLS_ECP_DP_SECP224R1_ENABLED",
312#endif /* MBEDTLS_ECP_DP_SECP224R1_ENABLED */
313#if defined(MBEDTLS_ECP_DP_SECP256R1_ENABLED)
314 "MBEDTLS_ECP_DP_SECP256R1_ENABLED",
315#endif /* MBEDTLS_ECP_DP_SECP256R1_ENABLED */
316#if defined(MBEDTLS_ECP_DP_SECP384R1_ENABLED)
317 "MBEDTLS_ECP_DP_SECP384R1_ENABLED",
318#endif /* MBEDTLS_ECP_DP_SECP384R1_ENABLED */
319#if defined(MBEDTLS_ECP_DP_SECP521R1_ENABLED)
320 "MBEDTLS_ECP_DP_SECP521R1_ENABLED",
321#endif /* MBEDTLS_ECP_DP_SECP521R1_ENABLED */
322#if defined(MBEDTLS_ECP_DP_SECP192K1_ENABLED)
323 "MBEDTLS_ECP_DP_SECP192K1_ENABLED",
324#endif /* MBEDTLS_ECP_DP_SECP192K1_ENABLED */
325#if defined(MBEDTLS_ECP_DP_SECP224K1_ENABLED)
326 "MBEDTLS_ECP_DP_SECP224K1_ENABLED",
327#endif /* MBEDTLS_ECP_DP_SECP224K1_ENABLED */
328#if defined(MBEDTLS_ECP_DP_SECP256K1_ENABLED)
329 "MBEDTLS_ECP_DP_SECP256K1_ENABLED",
330#endif /* MBEDTLS_ECP_DP_SECP256K1_ENABLED */
331#if defined(MBEDTLS_ECP_DP_BP256R1_ENABLED)
332 "MBEDTLS_ECP_DP_BP256R1_ENABLED",
333#endif /* MBEDTLS_ECP_DP_BP256R1_ENABLED */
334#if defined(MBEDTLS_ECP_DP_BP384R1_ENABLED)
335 "MBEDTLS_ECP_DP_BP384R1_ENABLED",
336#endif /* MBEDTLS_ECP_DP_BP384R1_ENABLED */
337#if defined(MBEDTLS_ECP_DP_BP512R1_ENABLED)
338 "MBEDTLS_ECP_DP_BP512R1_ENABLED",
339#endif /* MBEDTLS_ECP_DP_BP512R1_ENABLED */
Manuel Pégourié-Gonnard07894332015-06-23 00:18:41 +0200340#if defined(MBEDTLS_ECP_DP_CURVE25519_ENABLED)
341 "MBEDTLS_ECP_DP_CURVE25519_ENABLED",
342#endif /* MBEDTLS_ECP_DP_CURVE25519_ENABLED */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200343#if defined(MBEDTLS_ECP_NIST_OPTIM)
344 "MBEDTLS_ECP_NIST_OPTIM",
345#endif /* MBEDTLS_ECP_NIST_OPTIM */
Manuel Pégourié-Gonnardd90faf92020-05-19 12:38:31 +0200346#if defined(MBEDTLS_ECP_NO_INTERNAL_RNG)
347 "MBEDTLS_ECP_NO_INTERNAL_RNG",
348#endif /* MBEDTLS_ECP_NO_INTERNAL_RNG */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200349#if defined(MBEDTLS_ECDSA_DETERMINISTIC)
350 "MBEDTLS_ECDSA_DETERMINISTIC",
351#endif /* MBEDTLS_ECDSA_DETERMINISTIC */
352#if defined(MBEDTLS_KEY_EXCHANGE_PSK_ENABLED)
353 "MBEDTLS_KEY_EXCHANGE_PSK_ENABLED",
354#endif /* MBEDTLS_KEY_EXCHANGE_PSK_ENABLED */
355#if defined(MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED)
356 "MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED",
357#endif /* MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED */
358#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED)
359 "MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED",
360#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED */
361#if defined(MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED)
362 "MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED",
363#endif /* MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED */
364#if defined(MBEDTLS_KEY_EXCHANGE_RSA_ENABLED)
365 "MBEDTLS_KEY_EXCHANGE_RSA_ENABLED",
366#endif /* MBEDTLS_KEY_EXCHANGE_RSA_ENABLED */
367#if defined(MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED)
368 "MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED",
369#endif /* MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED */
370#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED)
371 "MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED",
372#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED */
373#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED)
374 "MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED",
375#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED */
376#if defined(MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED)
377 "MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED",
378#endif /* MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED */
379#if defined(MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED)
380 "MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED",
381#endif /* MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED */
Manuel Pégourié-Gonnard557535d2015-09-15 17:53:32 +0200382#if defined(MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED)
383 "MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED",
384#endif /* MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200385#if defined(MBEDTLS_PK_PARSE_EC_EXTENDED)
386 "MBEDTLS_PK_PARSE_EC_EXTENDED",
387#endif /* MBEDTLS_PK_PARSE_EC_EXTENDED */
388#if defined(MBEDTLS_ERROR_STRERROR_DUMMY)
389 "MBEDTLS_ERROR_STRERROR_DUMMY",
390#endif /* MBEDTLS_ERROR_STRERROR_DUMMY */
391#if defined(MBEDTLS_GENPRIME)
392 "MBEDTLS_GENPRIME",
393#endif /* MBEDTLS_GENPRIME */
394#if defined(MBEDTLS_FS_IO)
395 "MBEDTLS_FS_IO",
396#endif /* MBEDTLS_FS_IO */
397#if defined(MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES)
398 "MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES",
399#endif /* MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES */
400#if defined(MBEDTLS_NO_PLATFORM_ENTROPY)
401 "MBEDTLS_NO_PLATFORM_ENTROPY",
402#endif /* MBEDTLS_NO_PLATFORM_ENTROPY */
403#if defined(MBEDTLS_ENTROPY_FORCE_SHA256)
404 "MBEDTLS_ENTROPY_FORCE_SHA256",
405#endif /* MBEDTLS_ENTROPY_FORCE_SHA256 */
Paul Bakkerbddf9ab2016-06-01 15:58:12 +0100406#if defined(MBEDTLS_ENTROPY_NV_SEED)
407 "MBEDTLS_ENTROPY_NV_SEED",
408#endif /* MBEDTLS_ENTROPY_NV_SEED */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200409#if defined(MBEDTLS_MEMORY_DEBUG)
410 "MBEDTLS_MEMORY_DEBUG",
411#endif /* MBEDTLS_MEMORY_DEBUG */
412#if defined(MBEDTLS_MEMORY_BACKTRACE)
413 "MBEDTLS_MEMORY_BACKTRACE",
414#endif /* MBEDTLS_MEMORY_BACKTRACE */
415#if defined(MBEDTLS_PK_RSA_ALT_SUPPORT)
416 "MBEDTLS_PK_RSA_ALT_SUPPORT",
417#endif /* MBEDTLS_PK_RSA_ALT_SUPPORT */
418#if defined(MBEDTLS_PKCS1_V15)
419 "MBEDTLS_PKCS1_V15",
420#endif /* MBEDTLS_PKCS1_V15 */
421#if defined(MBEDTLS_PKCS1_V21)
422 "MBEDTLS_PKCS1_V21",
423#endif /* MBEDTLS_PKCS1_V21 */
424#if defined(MBEDTLS_RSA_NO_CRT)
425 "MBEDTLS_RSA_NO_CRT",
426#endif /* MBEDTLS_RSA_NO_CRT */
427#if defined(MBEDTLS_SELF_TEST)
428 "MBEDTLS_SELF_TEST",
429#endif /* MBEDTLS_SELF_TEST */
Manuel Pégourié-Gonnardeb0d8702015-05-28 12:54:04 +0200430#if defined(MBEDTLS_SHA256_SMALLER)
431 "MBEDTLS_SHA256_SMALLER",
432#endif /* MBEDTLS_SHA256_SMALLER */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200433#if defined(MBEDTLS_SSL_ALL_ALERT_MESSAGES)
434 "MBEDTLS_SSL_ALL_ALERT_MESSAGES",
435#endif /* MBEDTLS_SSL_ALL_ALERT_MESSAGES */
436#if defined(MBEDTLS_SSL_DEBUG_ALL)
437 "MBEDTLS_SSL_DEBUG_ALL",
438#endif /* MBEDTLS_SSL_DEBUG_ALL */
439#if defined(MBEDTLS_SSL_ENCRYPT_THEN_MAC)
440 "MBEDTLS_SSL_ENCRYPT_THEN_MAC",
441#endif /* MBEDTLS_SSL_ENCRYPT_THEN_MAC */
442#if defined(MBEDTLS_SSL_EXTENDED_MASTER_SECRET)
443 "MBEDTLS_SSL_EXTENDED_MASTER_SECRET",
444#endif /* MBEDTLS_SSL_EXTENDED_MASTER_SECRET */
445#if defined(MBEDTLS_SSL_FALLBACK_SCSV)
446 "MBEDTLS_SSL_FALLBACK_SCSV",
447#endif /* MBEDTLS_SSL_FALLBACK_SCSV */
448#if defined(MBEDTLS_SSL_HW_RECORD_ACCEL)
449 "MBEDTLS_SSL_HW_RECORD_ACCEL",
450#endif /* MBEDTLS_SSL_HW_RECORD_ACCEL */
451#if defined(MBEDTLS_SSL_CBC_RECORD_SPLITTING)
452 "MBEDTLS_SSL_CBC_RECORD_SPLITTING",
453#endif /* MBEDTLS_SSL_CBC_RECORD_SPLITTING */
454#if defined(MBEDTLS_SSL_RENEGOTIATION)
455 "MBEDTLS_SSL_RENEGOTIATION",
456#endif /* MBEDTLS_SSL_RENEGOTIATION */
457#if defined(MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO)
458 "MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO",
459#endif /* MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO */
460#if defined(MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE)
461 "MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE",
462#endif /* MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE */
463#if defined(MBEDTLS_SSL_MAX_FRAGMENT_LENGTH)
464 "MBEDTLS_SSL_MAX_FRAGMENT_LENGTH",
465#endif /* MBEDTLS_SSL_MAX_FRAGMENT_LENGTH */
466#if defined(MBEDTLS_SSL_PROTO_SSL3)
467 "MBEDTLS_SSL_PROTO_SSL3",
468#endif /* MBEDTLS_SSL_PROTO_SSL3 */
469#if defined(MBEDTLS_SSL_PROTO_TLS1)
470 "MBEDTLS_SSL_PROTO_TLS1",
471#endif /* MBEDTLS_SSL_PROTO_TLS1 */
472#if defined(MBEDTLS_SSL_PROTO_TLS1_1)
473 "MBEDTLS_SSL_PROTO_TLS1_1",
474#endif /* MBEDTLS_SSL_PROTO_TLS1_1 */
475#if defined(MBEDTLS_SSL_PROTO_TLS1_2)
476 "MBEDTLS_SSL_PROTO_TLS1_2",
477#endif /* MBEDTLS_SSL_PROTO_TLS1_2 */
478#if defined(MBEDTLS_SSL_PROTO_DTLS)
479 "MBEDTLS_SSL_PROTO_DTLS",
480#endif /* MBEDTLS_SSL_PROTO_DTLS */
481#if defined(MBEDTLS_SSL_ALPN)
482 "MBEDTLS_SSL_ALPN",
483#endif /* MBEDTLS_SSL_ALPN */
484#if defined(MBEDTLS_SSL_DTLS_ANTI_REPLAY)
485 "MBEDTLS_SSL_DTLS_ANTI_REPLAY",
486#endif /* MBEDTLS_SSL_DTLS_ANTI_REPLAY */
487#if defined(MBEDTLS_SSL_DTLS_HELLO_VERIFY)
488 "MBEDTLS_SSL_DTLS_HELLO_VERIFY",
489#endif /* MBEDTLS_SSL_DTLS_HELLO_VERIFY */
Manuel Pégourié-Gonnardab05d232015-09-09 11:50:00 +0200490#if defined(MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE)
491 "MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE",
492#endif /* MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200493#if defined(MBEDTLS_SSL_DTLS_BADMAC_LIMIT)
494 "MBEDTLS_SSL_DTLS_BADMAC_LIMIT",
495#endif /* MBEDTLS_SSL_DTLS_BADMAC_LIMIT */
496#if defined(MBEDTLS_SSL_SESSION_TICKETS)
497 "MBEDTLS_SSL_SESSION_TICKETS",
498#endif /* MBEDTLS_SSL_SESSION_TICKETS */
Robert Cragie4d284d22015-10-08 16:56:26 +0100499#if defined(MBEDTLS_SSL_EXPORT_KEYS)
500 "MBEDTLS_SSL_EXPORT_KEYS",
501#endif /* MBEDTLS_SSL_EXPORT_KEYS */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200502#if defined(MBEDTLS_SSL_SERVER_NAME_INDICATION)
503 "MBEDTLS_SSL_SERVER_NAME_INDICATION",
504#endif /* MBEDTLS_SSL_SERVER_NAME_INDICATION */
505#if defined(MBEDTLS_SSL_TRUNCATED_HMAC)
506 "MBEDTLS_SSL_TRUNCATED_HMAC",
507#endif /* MBEDTLS_SSL_TRUNCATED_HMAC */
Hanno Beckere80cd462018-02-22 15:02:47 +0000508#if defined(MBEDTLS_SSL_TRUNCATED_HMAC_COMPAT)
509 "MBEDTLS_SSL_TRUNCATED_HMAC_COMPAT",
510#endif /* MBEDTLS_SSL_TRUNCATED_HMAC_COMPAT */
Gilles Peskine04ea1062019-09-11 13:27:48 +0200511#if defined(MBEDTLS_TEST_HOOKS)
512 "MBEDTLS_TEST_HOOKS",
513#endif /* MBEDTLS_TEST_HOOKS */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200514#if defined(MBEDTLS_THREADING_ALT)
515 "MBEDTLS_THREADING_ALT",
516#endif /* MBEDTLS_THREADING_ALT */
517#if defined(MBEDTLS_THREADING_PTHREAD)
518 "MBEDTLS_THREADING_PTHREAD",
519#endif /* MBEDTLS_THREADING_PTHREAD */
520#if defined(MBEDTLS_VERSION_FEATURES)
521 "MBEDTLS_VERSION_FEATURES",
522#endif /* MBEDTLS_VERSION_FEATURES */
523#if defined(MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3)
524 "MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3",
525#endif /* MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3 */
526#if defined(MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION)
527 "MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION",
528#endif /* MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION */
529#if defined(MBEDTLS_X509_CHECK_KEY_USAGE)
530 "MBEDTLS_X509_CHECK_KEY_USAGE",
531#endif /* MBEDTLS_X509_CHECK_KEY_USAGE */
532#if defined(MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE)
533 "MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE",
534#endif /* MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE */
535#if defined(MBEDTLS_X509_RSASSA_PSS_SUPPORT)
536 "MBEDTLS_X509_RSASSA_PSS_SUPPORT",
537#endif /* MBEDTLS_X509_RSASSA_PSS_SUPPORT */
538#if defined(MBEDTLS_ZLIB_SUPPORT)
539 "MBEDTLS_ZLIB_SUPPORT",
540#endif /* MBEDTLS_ZLIB_SUPPORT */
541#if defined(MBEDTLS_AESNI_C)
542 "MBEDTLS_AESNI_C",
543#endif /* MBEDTLS_AESNI_C */
544#if defined(MBEDTLS_AES_C)
545 "MBEDTLS_AES_C",
546#endif /* MBEDTLS_AES_C */
547#if defined(MBEDTLS_ARC4_C)
548 "MBEDTLS_ARC4_C",
549#endif /* MBEDTLS_ARC4_C */
550#if defined(MBEDTLS_ASN1_PARSE_C)
551 "MBEDTLS_ASN1_PARSE_C",
552#endif /* MBEDTLS_ASN1_PARSE_C */
553#if defined(MBEDTLS_ASN1_WRITE_C)
554 "MBEDTLS_ASN1_WRITE_C",
555#endif /* MBEDTLS_ASN1_WRITE_C */
556#if defined(MBEDTLS_BASE64_C)
557 "MBEDTLS_BASE64_C",
558#endif /* MBEDTLS_BASE64_C */
559#if defined(MBEDTLS_BIGNUM_C)
560 "MBEDTLS_BIGNUM_C",
561#endif /* MBEDTLS_BIGNUM_C */
562#if defined(MBEDTLS_BLOWFISH_C)
563 "MBEDTLS_BLOWFISH_C",
564#endif /* MBEDTLS_BLOWFISH_C */
565#if defined(MBEDTLS_CAMELLIA_C)
566 "MBEDTLS_CAMELLIA_C",
567#endif /* MBEDTLS_CAMELLIA_C */
568#if defined(MBEDTLS_CCM_C)
569 "MBEDTLS_CCM_C",
570#endif /* MBEDTLS_CCM_C */
571#if defined(MBEDTLS_CERTS_C)
572 "MBEDTLS_CERTS_C",
573#endif /* MBEDTLS_CERTS_C */
574#if defined(MBEDTLS_CIPHER_C)
575 "MBEDTLS_CIPHER_C",
576#endif /* MBEDTLS_CIPHER_C */
Robert Cragie48f2ff92015-12-14 17:34:33 +0000577#if defined(MBEDTLS_CMAC_C)
578 "MBEDTLS_CMAC_C",
579#endif /* MBEDTLS_CMAC_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200580#if defined(MBEDTLS_CTR_DRBG_C)
581 "MBEDTLS_CTR_DRBG_C",
582#endif /* MBEDTLS_CTR_DRBG_C */
583#if defined(MBEDTLS_DEBUG_C)
584 "MBEDTLS_DEBUG_C",
585#endif /* MBEDTLS_DEBUG_C */
586#if defined(MBEDTLS_DES_C)
587 "MBEDTLS_DES_C",
588#endif /* MBEDTLS_DES_C */
589#if defined(MBEDTLS_DHM_C)
590 "MBEDTLS_DHM_C",
591#endif /* MBEDTLS_DHM_C */
592#if defined(MBEDTLS_ECDH_C)
593 "MBEDTLS_ECDH_C",
594#endif /* MBEDTLS_ECDH_C */
595#if defined(MBEDTLS_ECDSA_C)
596 "MBEDTLS_ECDSA_C",
597#endif /* MBEDTLS_ECDSA_C */
Manuel Pégourié-Gonnard4d8685b2015-08-05 15:44:42 +0200598#if defined(MBEDTLS_ECJPAKE_C)
599 "MBEDTLS_ECJPAKE_C",
600#endif /* MBEDTLS_ECJPAKE_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200601#if defined(MBEDTLS_ECP_C)
602 "MBEDTLS_ECP_C",
603#endif /* MBEDTLS_ECP_C */
604#if defined(MBEDTLS_ENTROPY_C)
605 "MBEDTLS_ENTROPY_C",
606#endif /* MBEDTLS_ENTROPY_C */
607#if defined(MBEDTLS_ERROR_C)
608 "MBEDTLS_ERROR_C",
609#endif /* MBEDTLS_ERROR_C */
610#if defined(MBEDTLS_GCM_C)
611 "MBEDTLS_GCM_C",
612#endif /* MBEDTLS_GCM_C */
613#if defined(MBEDTLS_HAVEGE_C)
614 "MBEDTLS_HAVEGE_C",
615#endif /* MBEDTLS_HAVEGE_C */
616#if defined(MBEDTLS_HMAC_DRBG_C)
617 "MBEDTLS_HMAC_DRBG_C",
618#endif /* MBEDTLS_HMAC_DRBG_C */
619#if defined(MBEDTLS_MD_C)
620 "MBEDTLS_MD_C",
621#endif /* MBEDTLS_MD_C */
622#if defined(MBEDTLS_MD2_C)
623 "MBEDTLS_MD2_C",
624#endif /* MBEDTLS_MD2_C */
625#if defined(MBEDTLS_MD4_C)
626 "MBEDTLS_MD4_C",
627#endif /* MBEDTLS_MD4_C */
628#if defined(MBEDTLS_MD5_C)
629 "MBEDTLS_MD5_C",
630#endif /* MBEDTLS_MD5_C */
631#if defined(MBEDTLS_MEMORY_BUFFER_ALLOC_C)
632 "MBEDTLS_MEMORY_BUFFER_ALLOC_C",
633#endif /* MBEDTLS_MEMORY_BUFFER_ALLOC_C */
634#if defined(MBEDTLS_NET_C)
635 "MBEDTLS_NET_C",
636#endif /* MBEDTLS_NET_C */
637#if defined(MBEDTLS_OID_C)
638 "MBEDTLS_OID_C",
639#endif /* MBEDTLS_OID_C */
640#if defined(MBEDTLS_PADLOCK_C)
641 "MBEDTLS_PADLOCK_C",
642#endif /* MBEDTLS_PADLOCK_C */
643#if defined(MBEDTLS_PEM_PARSE_C)
644 "MBEDTLS_PEM_PARSE_C",
645#endif /* MBEDTLS_PEM_PARSE_C */
646#if defined(MBEDTLS_PEM_WRITE_C)
647 "MBEDTLS_PEM_WRITE_C",
648#endif /* MBEDTLS_PEM_WRITE_C */
649#if defined(MBEDTLS_PK_C)
650 "MBEDTLS_PK_C",
651#endif /* MBEDTLS_PK_C */
652#if defined(MBEDTLS_PK_PARSE_C)
653 "MBEDTLS_PK_PARSE_C",
654#endif /* MBEDTLS_PK_PARSE_C */
655#if defined(MBEDTLS_PK_WRITE_C)
656 "MBEDTLS_PK_WRITE_C",
657#endif /* MBEDTLS_PK_WRITE_C */
658#if defined(MBEDTLS_PKCS5_C)
659 "MBEDTLS_PKCS5_C",
660#endif /* MBEDTLS_PKCS5_C */
661#if defined(MBEDTLS_PKCS11_C)
662 "MBEDTLS_PKCS11_C",
663#endif /* MBEDTLS_PKCS11_C */
664#if defined(MBEDTLS_PKCS12_C)
665 "MBEDTLS_PKCS12_C",
666#endif /* MBEDTLS_PKCS12_C */
667#if defined(MBEDTLS_PLATFORM_C)
668 "MBEDTLS_PLATFORM_C",
669#endif /* MBEDTLS_PLATFORM_C */
670#if defined(MBEDTLS_RIPEMD160_C)
671 "MBEDTLS_RIPEMD160_C",
672#endif /* MBEDTLS_RIPEMD160_C */
673#if defined(MBEDTLS_RSA_C)
674 "MBEDTLS_RSA_C",
675#endif /* MBEDTLS_RSA_C */
676#if defined(MBEDTLS_SHA1_C)
677 "MBEDTLS_SHA1_C",
678#endif /* MBEDTLS_SHA1_C */
679#if defined(MBEDTLS_SHA256_C)
680 "MBEDTLS_SHA256_C",
681#endif /* MBEDTLS_SHA256_C */
682#if defined(MBEDTLS_SHA512_C)
683 "MBEDTLS_SHA512_C",
684#endif /* MBEDTLS_SHA512_C */
685#if defined(MBEDTLS_SSL_CACHE_C)
686 "MBEDTLS_SSL_CACHE_C",
687#endif /* MBEDTLS_SSL_CACHE_C */
688#if defined(MBEDTLS_SSL_COOKIE_C)
689 "MBEDTLS_SSL_COOKIE_C",
690#endif /* MBEDTLS_SSL_COOKIE_C */
Manuel Pégourié-Gonnardfd6d8972015-05-15 12:09:00 +0200691#if defined(MBEDTLS_SSL_TICKET_C)
692 "MBEDTLS_SSL_TICKET_C",
693#endif /* MBEDTLS_SSL_TICKET_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200694#if defined(MBEDTLS_SSL_CLI_C)
695 "MBEDTLS_SSL_CLI_C",
696#endif /* MBEDTLS_SSL_CLI_C */
697#if defined(MBEDTLS_SSL_SRV_C)
698 "MBEDTLS_SSL_SRV_C",
699#endif /* MBEDTLS_SSL_SRV_C */
700#if defined(MBEDTLS_SSL_TLS_C)
701 "MBEDTLS_SSL_TLS_C",
702#endif /* MBEDTLS_SSL_TLS_C */
703#if defined(MBEDTLS_THREADING_C)
704 "MBEDTLS_THREADING_C",
705#endif /* MBEDTLS_THREADING_C */
706#if defined(MBEDTLS_TIMING_C)
707 "MBEDTLS_TIMING_C",
708#endif /* MBEDTLS_TIMING_C */
709#if defined(MBEDTLS_VERSION_C)
710 "MBEDTLS_VERSION_C",
711#endif /* MBEDTLS_VERSION_C */
712#if defined(MBEDTLS_X509_USE_C)
713 "MBEDTLS_X509_USE_C",
714#endif /* MBEDTLS_X509_USE_C */
715#if defined(MBEDTLS_X509_CRT_PARSE_C)
716 "MBEDTLS_X509_CRT_PARSE_C",
717#endif /* MBEDTLS_X509_CRT_PARSE_C */
718#if defined(MBEDTLS_X509_CRL_PARSE_C)
719 "MBEDTLS_X509_CRL_PARSE_C",
720#endif /* MBEDTLS_X509_CRL_PARSE_C */
721#if defined(MBEDTLS_X509_CSR_PARSE_C)
722 "MBEDTLS_X509_CSR_PARSE_C",
723#endif /* MBEDTLS_X509_CSR_PARSE_C */
724#if defined(MBEDTLS_X509_CREATE_C)
725 "MBEDTLS_X509_CREATE_C",
726#endif /* MBEDTLS_X509_CREATE_C */
727#if defined(MBEDTLS_X509_CRT_WRITE_C)
728 "MBEDTLS_X509_CRT_WRITE_C",
729#endif /* MBEDTLS_X509_CRT_WRITE_C */
730#if defined(MBEDTLS_X509_CSR_WRITE_C)
731 "MBEDTLS_X509_CSR_WRITE_C",
732#endif /* MBEDTLS_X509_CSR_WRITE_C */
733#if defined(MBEDTLS_XTEA_C)
734 "MBEDTLS_XTEA_C",
735#endif /* MBEDTLS_XTEA_C */
736#endif /* MBEDTLS_VERSION_FEATURES */
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200737 NULL
738};
739
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200740int mbedtls_version_check_feature( const char *feature )
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200741{
742 const char **idx = features;
743
Paul Bakker2ca1dc82014-04-30 17:01:25 +0200744 if( *idx == NULL )
745 return( -2 );
746
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200747 if( feature == NULL )
748 return( -1 );
749
750 while( *idx != NULL )
751 {
Manuel Pégourié-Gonnardcb46fd82015-05-28 17:06:07 +0200752 if( !strcmp( *idx, feature ) )
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200753 return( 0 );
754 idx++;
755 }
756 return( -1 );
757}
758
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200759#endif /* MBEDTLS_VERSION_C */