blob: 868289ce1b2a5dc97aa5edc07c824cbf3c0c28f0 [file] [log] [blame]
Paul Bakker0f90d7d2014-04-30 11:49:44 +02001/*
2 * Version feature information
3 *
Manuel Pégourié-Gonnarda658a402015-01-23 09:45:19 +00004 * Copyright (C) 2006-2014, ARM Limited, All Rights Reserved
Paul Bakker0f90d7d2014-04-30 11:49:44 +02005 *
Manuel Pégourié-Gonnardfe446432015-03-06 13:17:10 +00006 * This file is part of mbed TLS (https://tls.mbed.org)
Paul Bakker0f90d7d2014-04-30 11:49:44 +02007 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License along
19 * with this program; if not, write to the Free Software Foundation, Inc.,
20 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
21 */
22
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020023#if !defined(MBEDTLS_CONFIG_FILE)
Manuel Pégourié-Gonnard7f809972015-03-09 17:05:11 +000024#include "mbedtls/config.h"
Manuel Pégourié-Gonnardcef4ad22014-04-29 12:39:06 +020025#else
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020026#include MBEDTLS_CONFIG_FILE
Manuel Pégourié-Gonnardcef4ad22014-04-29 12:39:06 +020027#endif
Paul Bakker0f90d7d2014-04-30 11:49:44 +020028
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020029#if defined(MBEDTLS_VERSION_C)
Paul Bakker0f90d7d2014-04-30 11:49:44 +020030
Manuel Pégourié-Gonnard7f809972015-03-09 17:05:11 +000031#include "mbedtls/version.h"
Paul Bakker0f90d7d2014-04-30 11:49:44 +020032
33#include <string.h>
34
Manuel Pégourié-Gonnard385069f2015-03-05 15:47:55 +000035static const char *features[] = {
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020036#if defined(MBEDTLS_VERSION_FEATURES)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020037#if defined(MBEDTLS_HAVE_ASM)
38 "MBEDTLS_HAVE_ASM",
39#endif /* MBEDTLS_HAVE_ASM */
40#if defined(MBEDTLS_HAVE_SSE2)
41 "MBEDTLS_HAVE_SSE2",
42#endif /* MBEDTLS_HAVE_SSE2 */
43#if defined(MBEDTLS_HAVE_TIME)
44 "MBEDTLS_HAVE_TIME",
45#endif /* MBEDTLS_HAVE_TIME */
Manuel Pégourié-Gonnardf9cbd732015-06-22 12:06:50 +020046#if defined(MBEDTLS_HAVE_TIME_DATE)
47 "MBEDTLS_HAVE_TIME_DATE",
48#endif /* MBEDTLS_HAVE_TIME_DATE */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020049#if defined(MBEDTLS_PLATFORM_MEMORY)
50 "MBEDTLS_PLATFORM_MEMORY",
51#endif /* MBEDTLS_PLATFORM_MEMORY */
52#if defined(MBEDTLS_PLATFORM_NO_STD_FUNCTIONS)
53 "MBEDTLS_PLATFORM_NO_STD_FUNCTIONS",
54#endif /* MBEDTLS_PLATFORM_NO_STD_FUNCTIONS */
55#if defined(MBEDTLS_PLATFORM_EXIT_ALT)
56 "MBEDTLS_PLATFORM_EXIT_ALT",
57#endif /* MBEDTLS_PLATFORM_EXIT_ALT */
58#if defined(MBEDTLS_PLATFORM_FPRINTF_ALT)
59 "MBEDTLS_PLATFORM_FPRINTF_ALT",
60#endif /* MBEDTLS_PLATFORM_FPRINTF_ALT */
61#if defined(MBEDTLS_PLATFORM_PRINTF_ALT)
62 "MBEDTLS_PLATFORM_PRINTF_ALT",
63#endif /* MBEDTLS_PLATFORM_PRINTF_ALT */
64#if defined(MBEDTLS_PLATFORM_SNPRINTF_ALT)
65 "MBEDTLS_PLATFORM_SNPRINTF_ALT",
66#endif /* MBEDTLS_PLATFORM_SNPRINTF_ALT */
67#if defined(MBEDTLS_DEPRECATED_WARNING)
68 "MBEDTLS_DEPRECATED_WARNING",
69#endif /* MBEDTLS_DEPRECATED_WARNING */
70#if defined(MBEDTLS_DEPRECATED_REMOVED)
71 "MBEDTLS_DEPRECATED_REMOVED",
72#endif /* MBEDTLS_DEPRECATED_REMOVED */
73#if defined(MBEDTLS_TIMING_ALT)
74 "MBEDTLS_TIMING_ALT",
75#endif /* MBEDTLS_TIMING_ALT */
76#if defined(MBEDTLS_AES_ALT)
77 "MBEDTLS_AES_ALT",
78#endif /* MBEDTLS_AES_ALT */
79#if defined(MBEDTLS_ARC4_ALT)
80 "MBEDTLS_ARC4_ALT",
81#endif /* MBEDTLS_ARC4_ALT */
82#if defined(MBEDTLS_BLOWFISH_ALT)
83 "MBEDTLS_BLOWFISH_ALT",
84#endif /* MBEDTLS_BLOWFISH_ALT */
85#if defined(MBEDTLS_CAMELLIA_ALT)
86 "MBEDTLS_CAMELLIA_ALT",
87#endif /* MBEDTLS_CAMELLIA_ALT */
88#if defined(MBEDTLS_DES_ALT)
89 "MBEDTLS_DES_ALT",
90#endif /* MBEDTLS_DES_ALT */
91#if defined(MBEDTLS_XTEA_ALT)
92 "MBEDTLS_XTEA_ALT",
93#endif /* MBEDTLS_XTEA_ALT */
94#if defined(MBEDTLS_MD2_ALT)
95 "MBEDTLS_MD2_ALT",
96#endif /* MBEDTLS_MD2_ALT */
97#if defined(MBEDTLS_MD4_ALT)
98 "MBEDTLS_MD4_ALT",
99#endif /* MBEDTLS_MD4_ALT */
100#if defined(MBEDTLS_MD5_ALT)
101 "MBEDTLS_MD5_ALT",
102#endif /* MBEDTLS_MD5_ALT */
103#if defined(MBEDTLS_RIPEMD160_ALT)
104 "MBEDTLS_RIPEMD160_ALT",
105#endif /* MBEDTLS_RIPEMD160_ALT */
106#if defined(MBEDTLS_SHA1_ALT)
107 "MBEDTLS_SHA1_ALT",
108#endif /* MBEDTLS_SHA1_ALT */
109#if defined(MBEDTLS_SHA256_ALT)
110 "MBEDTLS_SHA256_ALT",
111#endif /* MBEDTLS_SHA256_ALT */
112#if defined(MBEDTLS_SHA512_ALT)
113 "MBEDTLS_SHA512_ALT",
114#endif /* MBEDTLS_SHA512_ALT */
115#if defined(MBEDTLS_MD2_PROCESS_ALT)
116 "MBEDTLS_MD2_PROCESS_ALT",
117#endif /* MBEDTLS_MD2_PROCESS_ALT */
118#if defined(MBEDTLS_MD4_PROCESS_ALT)
119 "MBEDTLS_MD4_PROCESS_ALT",
120#endif /* MBEDTLS_MD4_PROCESS_ALT */
121#if defined(MBEDTLS_MD5_PROCESS_ALT)
122 "MBEDTLS_MD5_PROCESS_ALT",
123#endif /* MBEDTLS_MD5_PROCESS_ALT */
124#if defined(MBEDTLS_RIPEMD160_PROCESS_ALT)
125 "MBEDTLS_RIPEMD160_PROCESS_ALT",
126#endif /* MBEDTLS_RIPEMD160_PROCESS_ALT */
127#if defined(MBEDTLS_SHA1_PROCESS_ALT)
128 "MBEDTLS_SHA1_PROCESS_ALT",
129#endif /* MBEDTLS_SHA1_PROCESS_ALT */
130#if defined(MBEDTLS_SHA256_PROCESS_ALT)
131 "MBEDTLS_SHA256_PROCESS_ALT",
132#endif /* MBEDTLS_SHA256_PROCESS_ALT */
133#if defined(MBEDTLS_SHA512_PROCESS_ALT)
134 "MBEDTLS_SHA512_PROCESS_ALT",
135#endif /* MBEDTLS_SHA512_PROCESS_ALT */
Manuel Pégourié-Gonnarda27b1972015-05-12 16:09:34 +0200136#if defined(MBEDTLS_DES_SETKEY_ALT)
137 "MBEDTLS_DES_SETKEY_ALT",
138#endif /* MBEDTLS_DES_SETKEY_ALT */
139#if defined(MBEDTLS_DES_CRYPT_ECB_ALT)
140 "MBEDTLS_DES_CRYPT_ECB_ALT",
141#endif /* MBEDTLS_DES_CRYPT_ECB_ALT */
142#if defined(MBEDTLS_DES3_CRYPT_ECB_ALT)
143 "MBEDTLS_DES3_CRYPT_ECB_ALT",
144#endif /* MBEDTLS_DES3_CRYPT_ECB_ALT */
145#if defined(MBEDTLS_AES_SETKEY_ENC_ALT)
146 "MBEDTLS_AES_SETKEY_ENC_ALT",
147#endif /* MBEDTLS_AES_SETKEY_ENC_ALT */
148#if defined(MBEDTLS_AES_SETKEY_DEC_ALT)
149 "MBEDTLS_AES_SETKEY_DEC_ALT",
150#endif /* MBEDTLS_AES_SETKEY_DEC_ALT */
151#if defined(MBEDTLS_AES_ENCRYPT_ALT)
152 "MBEDTLS_AES_ENCRYPT_ALT",
153#endif /* MBEDTLS_AES_ENCRYPT_ALT */
154#if defined(MBEDTLS_AES_DECRYPT_ALT)
155 "MBEDTLS_AES_DECRYPT_ALT",
156#endif /* MBEDTLS_AES_DECRYPT_ALT */
Manuel Pégourié-Gonnardf9cbd732015-06-22 12:06:50 +0200157#if defined(MBEDTLS_ENTROPY_HARDWARE_ALT)
158 "MBEDTLS_ENTROPY_HARDWARE_ALT",
159#endif /* MBEDTLS_ENTROPY_HARDWARE_ALT */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200160#if defined(MBEDTLS_AES_ROM_TABLES)
161 "MBEDTLS_AES_ROM_TABLES",
162#endif /* MBEDTLS_AES_ROM_TABLES */
163#if defined(MBEDTLS_CAMELLIA_SMALL_MEMORY)
164 "MBEDTLS_CAMELLIA_SMALL_MEMORY",
165#endif /* MBEDTLS_CAMELLIA_SMALL_MEMORY */
166#if defined(MBEDTLS_CIPHER_MODE_CBC)
167 "MBEDTLS_CIPHER_MODE_CBC",
168#endif /* MBEDTLS_CIPHER_MODE_CBC */
169#if defined(MBEDTLS_CIPHER_MODE_CFB)
170 "MBEDTLS_CIPHER_MODE_CFB",
171#endif /* MBEDTLS_CIPHER_MODE_CFB */
172#if defined(MBEDTLS_CIPHER_MODE_CTR)
173 "MBEDTLS_CIPHER_MODE_CTR",
174#endif /* MBEDTLS_CIPHER_MODE_CTR */
175#if defined(MBEDTLS_CIPHER_NULL_CIPHER)
176 "MBEDTLS_CIPHER_NULL_CIPHER",
177#endif /* MBEDTLS_CIPHER_NULL_CIPHER */
178#if defined(MBEDTLS_CIPHER_PADDING_PKCS7)
179 "MBEDTLS_CIPHER_PADDING_PKCS7",
180#endif /* MBEDTLS_CIPHER_PADDING_PKCS7 */
181#if defined(MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS)
182 "MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS",
183#endif /* MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS */
184#if defined(MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN)
185 "MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN",
186#endif /* MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN */
187#if defined(MBEDTLS_CIPHER_PADDING_ZEROS)
188 "MBEDTLS_CIPHER_PADDING_ZEROS",
189#endif /* MBEDTLS_CIPHER_PADDING_ZEROS */
190#if defined(MBEDTLS_ENABLE_WEAK_CIPHERSUITES)
191 "MBEDTLS_ENABLE_WEAK_CIPHERSUITES",
192#endif /* MBEDTLS_ENABLE_WEAK_CIPHERSUITES */
193#if defined(MBEDTLS_REMOVE_ARC4_CIPHERSUITES)
194 "MBEDTLS_REMOVE_ARC4_CIPHERSUITES",
195#endif /* MBEDTLS_REMOVE_ARC4_CIPHERSUITES */
196#if defined(MBEDTLS_ECP_DP_SECP192R1_ENABLED)
197 "MBEDTLS_ECP_DP_SECP192R1_ENABLED",
198#endif /* MBEDTLS_ECP_DP_SECP192R1_ENABLED */
199#if defined(MBEDTLS_ECP_DP_SECP224R1_ENABLED)
200 "MBEDTLS_ECP_DP_SECP224R1_ENABLED",
201#endif /* MBEDTLS_ECP_DP_SECP224R1_ENABLED */
202#if defined(MBEDTLS_ECP_DP_SECP256R1_ENABLED)
203 "MBEDTLS_ECP_DP_SECP256R1_ENABLED",
204#endif /* MBEDTLS_ECP_DP_SECP256R1_ENABLED */
205#if defined(MBEDTLS_ECP_DP_SECP384R1_ENABLED)
206 "MBEDTLS_ECP_DP_SECP384R1_ENABLED",
207#endif /* MBEDTLS_ECP_DP_SECP384R1_ENABLED */
208#if defined(MBEDTLS_ECP_DP_SECP521R1_ENABLED)
209 "MBEDTLS_ECP_DP_SECP521R1_ENABLED",
210#endif /* MBEDTLS_ECP_DP_SECP521R1_ENABLED */
211#if defined(MBEDTLS_ECP_DP_SECP192K1_ENABLED)
212 "MBEDTLS_ECP_DP_SECP192K1_ENABLED",
213#endif /* MBEDTLS_ECP_DP_SECP192K1_ENABLED */
214#if defined(MBEDTLS_ECP_DP_SECP224K1_ENABLED)
215 "MBEDTLS_ECP_DP_SECP224K1_ENABLED",
216#endif /* MBEDTLS_ECP_DP_SECP224K1_ENABLED */
217#if defined(MBEDTLS_ECP_DP_SECP256K1_ENABLED)
218 "MBEDTLS_ECP_DP_SECP256K1_ENABLED",
219#endif /* MBEDTLS_ECP_DP_SECP256K1_ENABLED */
220#if defined(MBEDTLS_ECP_DP_BP256R1_ENABLED)
221 "MBEDTLS_ECP_DP_BP256R1_ENABLED",
222#endif /* MBEDTLS_ECP_DP_BP256R1_ENABLED */
223#if defined(MBEDTLS_ECP_DP_BP384R1_ENABLED)
224 "MBEDTLS_ECP_DP_BP384R1_ENABLED",
225#endif /* MBEDTLS_ECP_DP_BP384R1_ENABLED */
226#if defined(MBEDTLS_ECP_DP_BP512R1_ENABLED)
227 "MBEDTLS_ECP_DP_BP512R1_ENABLED",
228#endif /* MBEDTLS_ECP_DP_BP512R1_ENABLED */
Manuel Pégourié-Gonnard07894332015-06-23 00:18:41 +0200229#if defined(MBEDTLS_ECP_DP_CURVE25519_ENABLED)
230 "MBEDTLS_ECP_DP_CURVE25519_ENABLED",
231#endif /* MBEDTLS_ECP_DP_CURVE25519_ENABLED */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200232#if defined(MBEDTLS_ECP_NIST_OPTIM)
233 "MBEDTLS_ECP_NIST_OPTIM",
234#endif /* MBEDTLS_ECP_NIST_OPTIM */
235#if defined(MBEDTLS_ECDSA_DETERMINISTIC)
236 "MBEDTLS_ECDSA_DETERMINISTIC",
237#endif /* MBEDTLS_ECDSA_DETERMINISTIC */
238#if defined(MBEDTLS_KEY_EXCHANGE_PSK_ENABLED)
239 "MBEDTLS_KEY_EXCHANGE_PSK_ENABLED",
240#endif /* MBEDTLS_KEY_EXCHANGE_PSK_ENABLED */
241#if defined(MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED)
242 "MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED",
243#endif /* MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED */
244#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED)
245 "MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED",
246#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED */
247#if defined(MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED)
248 "MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED",
249#endif /* MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED */
250#if defined(MBEDTLS_KEY_EXCHANGE_RSA_ENABLED)
251 "MBEDTLS_KEY_EXCHANGE_RSA_ENABLED",
252#endif /* MBEDTLS_KEY_EXCHANGE_RSA_ENABLED */
253#if defined(MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED)
254 "MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED",
255#endif /* MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED */
256#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED)
257 "MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED",
258#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED */
259#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED)
260 "MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED",
261#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED */
262#if defined(MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED)
263 "MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED",
264#endif /* MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED */
265#if defined(MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED)
266 "MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED",
267#endif /* MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED */
268#if defined(MBEDTLS_PK_PARSE_EC_EXTENDED)
269 "MBEDTLS_PK_PARSE_EC_EXTENDED",
270#endif /* MBEDTLS_PK_PARSE_EC_EXTENDED */
271#if defined(MBEDTLS_ERROR_STRERROR_DUMMY)
272 "MBEDTLS_ERROR_STRERROR_DUMMY",
273#endif /* MBEDTLS_ERROR_STRERROR_DUMMY */
274#if defined(MBEDTLS_GENPRIME)
275 "MBEDTLS_GENPRIME",
276#endif /* MBEDTLS_GENPRIME */
277#if defined(MBEDTLS_FS_IO)
278 "MBEDTLS_FS_IO",
279#endif /* MBEDTLS_FS_IO */
280#if defined(MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES)
281 "MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES",
282#endif /* MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES */
283#if defined(MBEDTLS_NO_PLATFORM_ENTROPY)
284 "MBEDTLS_NO_PLATFORM_ENTROPY",
285#endif /* MBEDTLS_NO_PLATFORM_ENTROPY */
286#if defined(MBEDTLS_ENTROPY_FORCE_SHA256)
287 "MBEDTLS_ENTROPY_FORCE_SHA256",
288#endif /* MBEDTLS_ENTROPY_FORCE_SHA256 */
289#if defined(MBEDTLS_MEMORY_DEBUG)
290 "MBEDTLS_MEMORY_DEBUG",
291#endif /* MBEDTLS_MEMORY_DEBUG */
292#if defined(MBEDTLS_MEMORY_BACKTRACE)
293 "MBEDTLS_MEMORY_BACKTRACE",
294#endif /* MBEDTLS_MEMORY_BACKTRACE */
295#if defined(MBEDTLS_PK_RSA_ALT_SUPPORT)
296 "MBEDTLS_PK_RSA_ALT_SUPPORT",
297#endif /* MBEDTLS_PK_RSA_ALT_SUPPORT */
298#if defined(MBEDTLS_PKCS1_V15)
299 "MBEDTLS_PKCS1_V15",
300#endif /* MBEDTLS_PKCS1_V15 */
301#if defined(MBEDTLS_PKCS1_V21)
302 "MBEDTLS_PKCS1_V21",
303#endif /* MBEDTLS_PKCS1_V21 */
304#if defined(MBEDTLS_RSA_NO_CRT)
305 "MBEDTLS_RSA_NO_CRT",
306#endif /* MBEDTLS_RSA_NO_CRT */
307#if defined(MBEDTLS_SELF_TEST)
308 "MBEDTLS_SELF_TEST",
309#endif /* MBEDTLS_SELF_TEST */
Manuel Pégourié-Gonnardeb0d8702015-05-28 12:54:04 +0200310#if defined(MBEDTLS_SHA256_SMALLER)
311 "MBEDTLS_SHA256_SMALLER",
312#endif /* MBEDTLS_SHA256_SMALLER */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200313#if defined(MBEDTLS_SSL_AEAD_RANDOM_IV)
314 "MBEDTLS_SSL_AEAD_RANDOM_IV",
315#endif /* MBEDTLS_SSL_AEAD_RANDOM_IV */
316#if defined(MBEDTLS_SSL_ALL_ALERT_MESSAGES)
317 "MBEDTLS_SSL_ALL_ALERT_MESSAGES",
318#endif /* MBEDTLS_SSL_ALL_ALERT_MESSAGES */
319#if defined(MBEDTLS_SSL_DEBUG_ALL)
320 "MBEDTLS_SSL_DEBUG_ALL",
321#endif /* MBEDTLS_SSL_DEBUG_ALL */
322#if defined(MBEDTLS_SSL_ENCRYPT_THEN_MAC)
323 "MBEDTLS_SSL_ENCRYPT_THEN_MAC",
324#endif /* MBEDTLS_SSL_ENCRYPT_THEN_MAC */
325#if defined(MBEDTLS_SSL_EXTENDED_MASTER_SECRET)
326 "MBEDTLS_SSL_EXTENDED_MASTER_SECRET",
327#endif /* MBEDTLS_SSL_EXTENDED_MASTER_SECRET */
328#if defined(MBEDTLS_SSL_FALLBACK_SCSV)
329 "MBEDTLS_SSL_FALLBACK_SCSV",
330#endif /* MBEDTLS_SSL_FALLBACK_SCSV */
331#if defined(MBEDTLS_SSL_HW_RECORD_ACCEL)
332 "MBEDTLS_SSL_HW_RECORD_ACCEL",
333#endif /* MBEDTLS_SSL_HW_RECORD_ACCEL */
334#if defined(MBEDTLS_SSL_CBC_RECORD_SPLITTING)
335 "MBEDTLS_SSL_CBC_RECORD_SPLITTING",
336#endif /* MBEDTLS_SSL_CBC_RECORD_SPLITTING */
337#if defined(MBEDTLS_SSL_RENEGOTIATION)
338 "MBEDTLS_SSL_RENEGOTIATION",
339#endif /* MBEDTLS_SSL_RENEGOTIATION */
340#if defined(MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO)
341 "MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO",
342#endif /* MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO */
343#if defined(MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE)
344 "MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE",
345#endif /* MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE */
346#if defined(MBEDTLS_SSL_MAX_FRAGMENT_LENGTH)
347 "MBEDTLS_SSL_MAX_FRAGMENT_LENGTH",
348#endif /* MBEDTLS_SSL_MAX_FRAGMENT_LENGTH */
349#if defined(MBEDTLS_SSL_PROTO_SSL3)
350 "MBEDTLS_SSL_PROTO_SSL3",
351#endif /* MBEDTLS_SSL_PROTO_SSL3 */
352#if defined(MBEDTLS_SSL_PROTO_TLS1)
353 "MBEDTLS_SSL_PROTO_TLS1",
354#endif /* MBEDTLS_SSL_PROTO_TLS1 */
355#if defined(MBEDTLS_SSL_PROTO_TLS1_1)
356 "MBEDTLS_SSL_PROTO_TLS1_1",
357#endif /* MBEDTLS_SSL_PROTO_TLS1_1 */
358#if defined(MBEDTLS_SSL_PROTO_TLS1_2)
359 "MBEDTLS_SSL_PROTO_TLS1_2",
360#endif /* MBEDTLS_SSL_PROTO_TLS1_2 */
361#if defined(MBEDTLS_SSL_PROTO_DTLS)
362 "MBEDTLS_SSL_PROTO_DTLS",
363#endif /* MBEDTLS_SSL_PROTO_DTLS */
364#if defined(MBEDTLS_SSL_ALPN)
365 "MBEDTLS_SSL_ALPN",
366#endif /* MBEDTLS_SSL_ALPN */
367#if defined(MBEDTLS_SSL_DTLS_ANTI_REPLAY)
368 "MBEDTLS_SSL_DTLS_ANTI_REPLAY",
369#endif /* MBEDTLS_SSL_DTLS_ANTI_REPLAY */
370#if defined(MBEDTLS_SSL_DTLS_HELLO_VERIFY)
371 "MBEDTLS_SSL_DTLS_HELLO_VERIFY",
372#endif /* MBEDTLS_SSL_DTLS_HELLO_VERIFY */
373#if defined(MBEDTLS_SSL_DTLS_BADMAC_LIMIT)
374 "MBEDTLS_SSL_DTLS_BADMAC_LIMIT",
375#endif /* MBEDTLS_SSL_DTLS_BADMAC_LIMIT */
376#if defined(MBEDTLS_SSL_SESSION_TICKETS)
377 "MBEDTLS_SSL_SESSION_TICKETS",
378#endif /* MBEDTLS_SSL_SESSION_TICKETS */
379#if defined(MBEDTLS_SSL_SERVER_NAME_INDICATION)
380 "MBEDTLS_SSL_SERVER_NAME_INDICATION",
381#endif /* MBEDTLS_SSL_SERVER_NAME_INDICATION */
382#if defined(MBEDTLS_SSL_TRUNCATED_HMAC)
383 "MBEDTLS_SSL_TRUNCATED_HMAC",
384#endif /* MBEDTLS_SSL_TRUNCATED_HMAC */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200385#if defined(MBEDTLS_THREADING_ALT)
386 "MBEDTLS_THREADING_ALT",
387#endif /* MBEDTLS_THREADING_ALT */
388#if defined(MBEDTLS_THREADING_PTHREAD)
389 "MBEDTLS_THREADING_PTHREAD",
390#endif /* MBEDTLS_THREADING_PTHREAD */
391#if defined(MBEDTLS_VERSION_FEATURES)
392 "MBEDTLS_VERSION_FEATURES",
393#endif /* MBEDTLS_VERSION_FEATURES */
394#if defined(MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3)
395 "MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3",
396#endif /* MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3 */
397#if defined(MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION)
398 "MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION",
399#endif /* MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION */
400#if defined(MBEDTLS_X509_CHECK_KEY_USAGE)
401 "MBEDTLS_X509_CHECK_KEY_USAGE",
402#endif /* MBEDTLS_X509_CHECK_KEY_USAGE */
403#if defined(MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE)
404 "MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE",
405#endif /* MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE */
406#if defined(MBEDTLS_X509_RSASSA_PSS_SUPPORT)
407 "MBEDTLS_X509_RSASSA_PSS_SUPPORT",
408#endif /* MBEDTLS_X509_RSASSA_PSS_SUPPORT */
409#if defined(MBEDTLS_ZLIB_SUPPORT)
410 "MBEDTLS_ZLIB_SUPPORT",
411#endif /* MBEDTLS_ZLIB_SUPPORT */
412#if defined(MBEDTLS_AESNI_C)
413 "MBEDTLS_AESNI_C",
414#endif /* MBEDTLS_AESNI_C */
415#if defined(MBEDTLS_AES_C)
416 "MBEDTLS_AES_C",
417#endif /* MBEDTLS_AES_C */
418#if defined(MBEDTLS_ARC4_C)
419 "MBEDTLS_ARC4_C",
420#endif /* MBEDTLS_ARC4_C */
421#if defined(MBEDTLS_ASN1_PARSE_C)
422 "MBEDTLS_ASN1_PARSE_C",
423#endif /* MBEDTLS_ASN1_PARSE_C */
424#if defined(MBEDTLS_ASN1_WRITE_C)
425 "MBEDTLS_ASN1_WRITE_C",
426#endif /* MBEDTLS_ASN1_WRITE_C */
427#if defined(MBEDTLS_BASE64_C)
428 "MBEDTLS_BASE64_C",
429#endif /* MBEDTLS_BASE64_C */
430#if defined(MBEDTLS_BIGNUM_C)
431 "MBEDTLS_BIGNUM_C",
432#endif /* MBEDTLS_BIGNUM_C */
433#if defined(MBEDTLS_BLOWFISH_C)
434 "MBEDTLS_BLOWFISH_C",
435#endif /* MBEDTLS_BLOWFISH_C */
436#if defined(MBEDTLS_CAMELLIA_C)
437 "MBEDTLS_CAMELLIA_C",
438#endif /* MBEDTLS_CAMELLIA_C */
439#if defined(MBEDTLS_CCM_C)
440 "MBEDTLS_CCM_C",
441#endif /* MBEDTLS_CCM_C */
442#if defined(MBEDTLS_CERTS_C)
443 "MBEDTLS_CERTS_C",
444#endif /* MBEDTLS_CERTS_C */
445#if defined(MBEDTLS_CIPHER_C)
446 "MBEDTLS_CIPHER_C",
447#endif /* MBEDTLS_CIPHER_C */
448#if defined(MBEDTLS_CTR_DRBG_C)
449 "MBEDTLS_CTR_DRBG_C",
450#endif /* MBEDTLS_CTR_DRBG_C */
451#if defined(MBEDTLS_DEBUG_C)
452 "MBEDTLS_DEBUG_C",
453#endif /* MBEDTLS_DEBUG_C */
454#if defined(MBEDTLS_DES_C)
455 "MBEDTLS_DES_C",
456#endif /* MBEDTLS_DES_C */
457#if defined(MBEDTLS_DHM_C)
458 "MBEDTLS_DHM_C",
459#endif /* MBEDTLS_DHM_C */
460#if defined(MBEDTLS_ECDH_C)
461 "MBEDTLS_ECDH_C",
462#endif /* MBEDTLS_ECDH_C */
463#if defined(MBEDTLS_ECDSA_C)
464 "MBEDTLS_ECDSA_C",
465#endif /* MBEDTLS_ECDSA_C */
466#if defined(MBEDTLS_ECP_C)
467 "MBEDTLS_ECP_C",
468#endif /* MBEDTLS_ECP_C */
469#if defined(MBEDTLS_ENTROPY_C)
470 "MBEDTLS_ENTROPY_C",
471#endif /* MBEDTLS_ENTROPY_C */
472#if defined(MBEDTLS_ERROR_C)
473 "MBEDTLS_ERROR_C",
474#endif /* MBEDTLS_ERROR_C */
475#if defined(MBEDTLS_GCM_C)
476 "MBEDTLS_GCM_C",
477#endif /* MBEDTLS_GCM_C */
478#if defined(MBEDTLS_HAVEGE_C)
479 "MBEDTLS_HAVEGE_C",
480#endif /* MBEDTLS_HAVEGE_C */
481#if defined(MBEDTLS_HMAC_DRBG_C)
482 "MBEDTLS_HMAC_DRBG_C",
483#endif /* MBEDTLS_HMAC_DRBG_C */
484#if defined(MBEDTLS_MD_C)
485 "MBEDTLS_MD_C",
486#endif /* MBEDTLS_MD_C */
487#if defined(MBEDTLS_MD2_C)
488 "MBEDTLS_MD2_C",
489#endif /* MBEDTLS_MD2_C */
490#if defined(MBEDTLS_MD4_C)
491 "MBEDTLS_MD4_C",
492#endif /* MBEDTLS_MD4_C */
493#if defined(MBEDTLS_MD5_C)
494 "MBEDTLS_MD5_C",
495#endif /* MBEDTLS_MD5_C */
496#if defined(MBEDTLS_MEMORY_BUFFER_ALLOC_C)
497 "MBEDTLS_MEMORY_BUFFER_ALLOC_C",
498#endif /* MBEDTLS_MEMORY_BUFFER_ALLOC_C */
499#if defined(MBEDTLS_NET_C)
500 "MBEDTLS_NET_C",
501#endif /* MBEDTLS_NET_C */
502#if defined(MBEDTLS_OID_C)
503 "MBEDTLS_OID_C",
504#endif /* MBEDTLS_OID_C */
505#if defined(MBEDTLS_PADLOCK_C)
506 "MBEDTLS_PADLOCK_C",
507#endif /* MBEDTLS_PADLOCK_C */
508#if defined(MBEDTLS_PEM_PARSE_C)
509 "MBEDTLS_PEM_PARSE_C",
510#endif /* MBEDTLS_PEM_PARSE_C */
511#if defined(MBEDTLS_PEM_WRITE_C)
512 "MBEDTLS_PEM_WRITE_C",
513#endif /* MBEDTLS_PEM_WRITE_C */
514#if defined(MBEDTLS_PK_C)
515 "MBEDTLS_PK_C",
516#endif /* MBEDTLS_PK_C */
517#if defined(MBEDTLS_PK_PARSE_C)
518 "MBEDTLS_PK_PARSE_C",
519#endif /* MBEDTLS_PK_PARSE_C */
520#if defined(MBEDTLS_PK_WRITE_C)
521 "MBEDTLS_PK_WRITE_C",
522#endif /* MBEDTLS_PK_WRITE_C */
523#if defined(MBEDTLS_PKCS5_C)
524 "MBEDTLS_PKCS5_C",
525#endif /* MBEDTLS_PKCS5_C */
526#if defined(MBEDTLS_PKCS11_C)
527 "MBEDTLS_PKCS11_C",
528#endif /* MBEDTLS_PKCS11_C */
529#if defined(MBEDTLS_PKCS12_C)
530 "MBEDTLS_PKCS12_C",
531#endif /* MBEDTLS_PKCS12_C */
532#if defined(MBEDTLS_PLATFORM_C)
533 "MBEDTLS_PLATFORM_C",
534#endif /* MBEDTLS_PLATFORM_C */
535#if defined(MBEDTLS_RIPEMD160_C)
536 "MBEDTLS_RIPEMD160_C",
537#endif /* MBEDTLS_RIPEMD160_C */
538#if defined(MBEDTLS_RSA_C)
539 "MBEDTLS_RSA_C",
540#endif /* MBEDTLS_RSA_C */
541#if defined(MBEDTLS_SHA1_C)
542 "MBEDTLS_SHA1_C",
543#endif /* MBEDTLS_SHA1_C */
544#if defined(MBEDTLS_SHA256_C)
545 "MBEDTLS_SHA256_C",
546#endif /* MBEDTLS_SHA256_C */
547#if defined(MBEDTLS_SHA512_C)
548 "MBEDTLS_SHA512_C",
549#endif /* MBEDTLS_SHA512_C */
550#if defined(MBEDTLS_SSL_CACHE_C)
551 "MBEDTLS_SSL_CACHE_C",
552#endif /* MBEDTLS_SSL_CACHE_C */
553#if defined(MBEDTLS_SSL_COOKIE_C)
554 "MBEDTLS_SSL_COOKIE_C",
555#endif /* MBEDTLS_SSL_COOKIE_C */
Manuel Pégourié-Gonnardfd6d8972015-05-15 12:09:00 +0200556#if defined(MBEDTLS_SSL_TICKET_C)
557 "MBEDTLS_SSL_TICKET_C",
558#endif /* MBEDTLS_SSL_TICKET_C */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200559#if defined(MBEDTLS_SSL_CLI_C)
560 "MBEDTLS_SSL_CLI_C",
561#endif /* MBEDTLS_SSL_CLI_C */
562#if defined(MBEDTLS_SSL_SRV_C)
563 "MBEDTLS_SSL_SRV_C",
564#endif /* MBEDTLS_SSL_SRV_C */
565#if defined(MBEDTLS_SSL_TLS_C)
566 "MBEDTLS_SSL_TLS_C",
567#endif /* MBEDTLS_SSL_TLS_C */
568#if defined(MBEDTLS_THREADING_C)
569 "MBEDTLS_THREADING_C",
570#endif /* MBEDTLS_THREADING_C */
571#if defined(MBEDTLS_TIMING_C)
572 "MBEDTLS_TIMING_C",
573#endif /* MBEDTLS_TIMING_C */
574#if defined(MBEDTLS_VERSION_C)
575 "MBEDTLS_VERSION_C",
576#endif /* MBEDTLS_VERSION_C */
577#if defined(MBEDTLS_X509_USE_C)
578 "MBEDTLS_X509_USE_C",
579#endif /* MBEDTLS_X509_USE_C */
580#if defined(MBEDTLS_X509_CRT_PARSE_C)
581 "MBEDTLS_X509_CRT_PARSE_C",
582#endif /* MBEDTLS_X509_CRT_PARSE_C */
583#if defined(MBEDTLS_X509_CRL_PARSE_C)
584 "MBEDTLS_X509_CRL_PARSE_C",
585#endif /* MBEDTLS_X509_CRL_PARSE_C */
586#if defined(MBEDTLS_X509_CSR_PARSE_C)
587 "MBEDTLS_X509_CSR_PARSE_C",
588#endif /* MBEDTLS_X509_CSR_PARSE_C */
589#if defined(MBEDTLS_X509_CREATE_C)
590 "MBEDTLS_X509_CREATE_C",
591#endif /* MBEDTLS_X509_CREATE_C */
592#if defined(MBEDTLS_X509_CRT_WRITE_C)
593 "MBEDTLS_X509_CRT_WRITE_C",
594#endif /* MBEDTLS_X509_CRT_WRITE_C */
595#if defined(MBEDTLS_X509_CSR_WRITE_C)
596 "MBEDTLS_X509_CSR_WRITE_C",
597#endif /* MBEDTLS_X509_CSR_WRITE_C */
598#if defined(MBEDTLS_XTEA_C)
599 "MBEDTLS_XTEA_C",
600#endif /* MBEDTLS_XTEA_C */
601#endif /* MBEDTLS_VERSION_FEATURES */
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200602 NULL
603};
604
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200605int mbedtls_version_check_feature( const char *feature )
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200606{
607 const char **idx = features;
608
Paul Bakker2ca1dc82014-04-30 17:01:25 +0200609 if( *idx == NULL )
610 return( -2 );
611
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200612 if( feature == NULL )
613 return( -1 );
614
615 while( *idx != NULL )
616 {
Manuel Pégourié-Gonnardcb46fd82015-05-28 17:06:07 +0200617 if( !strcmp( *idx, feature ) )
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200618 return( 0 );
619 idx++;
620 }
621 return( -1 );
622}
623
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200624#endif /* MBEDTLS_VERSION_C */