blob: de9c1bb8f2f8ecbe4a28aa9b0f6cea17c2c2c2b8 [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
Paul Bakker2ca1dc82014-04-30 17:01:25 +020035#if defined(_MSC_VER) && !defined strcasecmp && !defined(EFIX64) && \
Paul Bakker0f90d7d2014-04-30 11:49:44 +020036 !defined(EFI32)
Paul Bakker2ca1dc82014-04-30 17:01:25 +020037#define strcasecmp _stricmp
Paul Bakker0f90d7d2014-04-30 11:49:44 +020038#endif
39
Manuel Pégourié-Gonnard385069f2015-03-05 15:47:55 +000040static const char *features[] = {
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020041#if defined(MBEDTLS_VERSION_FEATURES)
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020042#if defined(MBEDTLS_HAVE_ASM)
43 "MBEDTLS_HAVE_ASM",
44#endif /* MBEDTLS_HAVE_ASM */
45#if defined(MBEDTLS_HAVE_SSE2)
46 "MBEDTLS_HAVE_SSE2",
47#endif /* MBEDTLS_HAVE_SSE2 */
48#if defined(MBEDTLS_HAVE_TIME)
49 "MBEDTLS_HAVE_TIME",
50#endif /* MBEDTLS_HAVE_TIME */
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020051#if defined(MBEDTLS_PLATFORM_MEMORY)
52 "MBEDTLS_PLATFORM_MEMORY",
53#endif /* MBEDTLS_PLATFORM_MEMORY */
54#if defined(MBEDTLS_PLATFORM_NO_STD_FUNCTIONS)
55 "MBEDTLS_PLATFORM_NO_STD_FUNCTIONS",
56#endif /* MBEDTLS_PLATFORM_NO_STD_FUNCTIONS */
57#if defined(MBEDTLS_PLATFORM_EXIT_ALT)
58 "MBEDTLS_PLATFORM_EXIT_ALT",
59#endif /* MBEDTLS_PLATFORM_EXIT_ALT */
60#if defined(MBEDTLS_PLATFORM_FPRINTF_ALT)
61 "MBEDTLS_PLATFORM_FPRINTF_ALT",
62#endif /* MBEDTLS_PLATFORM_FPRINTF_ALT */
63#if defined(MBEDTLS_PLATFORM_PRINTF_ALT)
64 "MBEDTLS_PLATFORM_PRINTF_ALT",
65#endif /* MBEDTLS_PLATFORM_PRINTF_ALT */
66#if defined(MBEDTLS_PLATFORM_SNPRINTF_ALT)
67 "MBEDTLS_PLATFORM_SNPRINTF_ALT",
68#endif /* MBEDTLS_PLATFORM_SNPRINTF_ALT */
69#if defined(MBEDTLS_DEPRECATED_WARNING)
70 "MBEDTLS_DEPRECATED_WARNING",
71#endif /* MBEDTLS_DEPRECATED_WARNING */
72#if defined(MBEDTLS_DEPRECATED_REMOVED)
73 "MBEDTLS_DEPRECATED_REMOVED",
74#endif /* MBEDTLS_DEPRECATED_REMOVED */
75#if defined(MBEDTLS_TIMING_ALT)
76 "MBEDTLS_TIMING_ALT",
77#endif /* MBEDTLS_TIMING_ALT */
78#if defined(MBEDTLS_AES_ALT)
79 "MBEDTLS_AES_ALT",
80#endif /* MBEDTLS_AES_ALT */
81#if defined(MBEDTLS_ARC4_ALT)
82 "MBEDTLS_ARC4_ALT",
83#endif /* MBEDTLS_ARC4_ALT */
84#if defined(MBEDTLS_BLOWFISH_ALT)
85 "MBEDTLS_BLOWFISH_ALT",
86#endif /* MBEDTLS_BLOWFISH_ALT */
87#if defined(MBEDTLS_CAMELLIA_ALT)
88 "MBEDTLS_CAMELLIA_ALT",
89#endif /* MBEDTLS_CAMELLIA_ALT */
90#if defined(MBEDTLS_DES_ALT)
91 "MBEDTLS_DES_ALT",
92#endif /* MBEDTLS_DES_ALT */
93#if defined(MBEDTLS_XTEA_ALT)
94 "MBEDTLS_XTEA_ALT",
95#endif /* MBEDTLS_XTEA_ALT */
96#if defined(MBEDTLS_MD2_ALT)
97 "MBEDTLS_MD2_ALT",
98#endif /* MBEDTLS_MD2_ALT */
99#if defined(MBEDTLS_MD4_ALT)
100 "MBEDTLS_MD4_ALT",
101#endif /* MBEDTLS_MD4_ALT */
102#if defined(MBEDTLS_MD5_ALT)
103 "MBEDTLS_MD5_ALT",
104#endif /* MBEDTLS_MD5_ALT */
105#if defined(MBEDTLS_RIPEMD160_ALT)
106 "MBEDTLS_RIPEMD160_ALT",
107#endif /* MBEDTLS_RIPEMD160_ALT */
108#if defined(MBEDTLS_SHA1_ALT)
109 "MBEDTLS_SHA1_ALT",
110#endif /* MBEDTLS_SHA1_ALT */
111#if defined(MBEDTLS_SHA256_ALT)
112 "MBEDTLS_SHA256_ALT",
113#endif /* MBEDTLS_SHA256_ALT */
114#if defined(MBEDTLS_SHA512_ALT)
115 "MBEDTLS_SHA512_ALT",
116#endif /* MBEDTLS_SHA512_ALT */
117#if defined(MBEDTLS_MD2_PROCESS_ALT)
118 "MBEDTLS_MD2_PROCESS_ALT",
119#endif /* MBEDTLS_MD2_PROCESS_ALT */
120#if defined(MBEDTLS_MD4_PROCESS_ALT)
121 "MBEDTLS_MD4_PROCESS_ALT",
122#endif /* MBEDTLS_MD4_PROCESS_ALT */
123#if defined(MBEDTLS_MD5_PROCESS_ALT)
124 "MBEDTLS_MD5_PROCESS_ALT",
125#endif /* MBEDTLS_MD5_PROCESS_ALT */
126#if defined(MBEDTLS_RIPEMD160_PROCESS_ALT)
127 "MBEDTLS_RIPEMD160_PROCESS_ALT",
128#endif /* MBEDTLS_RIPEMD160_PROCESS_ALT */
129#if defined(MBEDTLS_SHA1_PROCESS_ALT)
130 "MBEDTLS_SHA1_PROCESS_ALT",
131#endif /* MBEDTLS_SHA1_PROCESS_ALT */
132#if defined(MBEDTLS_SHA256_PROCESS_ALT)
133 "MBEDTLS_SHA256_PROCESS_ALT",
134#endif /* MBEDTLS_SHA256_PROCESS_ALT */
135#if defined(MBEDTLS_SHA512_PROCESS_ALT)
136 "MBEDTLS_SHA512_PROCESS_ALT",
137#endif /* MBEDTLS_SHA512_PROCESS_ALT */
138#if defined(MBEDTLS_AES_ROM_TABLES)
139 "MBEDTLS_AES_ROM_TABLES",
140#endif /* MBEDTLS_AES_ROM_TABLES */
141#if defined(MBEDTLS_CAMELLIA_SMALL_MEMORY)
142 "MBEDTLS_CAMELLIA_SMALL_MEMORY",
143#endif /* MBEDTLS_CAMELLIA_SMALL_MEMORY */
144#if defined(MBEDTLS_CIPHER_MODE_CBC)
145 "MBEDTLS_CIPHER_MODE_CBC",
146#endif /* MBEDTLS_CIPHER_MODE_CBC */
147#if defined(MBEDTLS_CIPHER_MODE_CFB)
148 "MBEDTLS_CIPHER_MODE_CFB",
149#endif /* MBEDTLS_CIPHER_MODE_CFB */
150#if defined(MBEDTLS_CIPHER_MODE_CTR)
151 "MBEDTLS_CIPHER_MODE_CTR",
152#endif /* MBEDTLS_CIPHER_MODE_CTR */
153#if defined(MBEDTLS_CIPHER_NULL_CIPHER)
154 "MBEDTLS_CIPHER_NULL_CIPHER",
155#endif /* MBEDTLS_CIPHER_NULL_CIPHER */
156#if defined(MBEDTLS_CIPHER_PADDING_PKCS7)
157 "MBEDTLS_CIPHER_PADDING_PKCS7",
158#endif /* MBEDTLS_CIPHER_PADDING_PKCS7 */
159#if defined(MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS)
160 "MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS",
161#endif /* MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS */
162#if defined(MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN)
163 "MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN",
164#endif /* MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN */
165#if defined(MBEDTLS_CIPHER_PADDING_ZEROS)
166 "MBEDTLS_CIPHER_PADDING_ZEROS",
167#endif /* MBEDTLS_CIPHER_PADDING_ZEROS */
168#if defined(MBEDTLS_ENABLE_WEAK_CIPHERSUITES)
169 "MBEDTLS_ENABLE_WEAK_CIPHERSUITES",
170#endif /* MBEDTLS_ENABLE_WEAK_CIPHERSUITES */
171#if defined(MBEDTLS_REMOVE_ARC4_CIPHERSUITES)
172 "MBEDTLS_REMOVE_ARC4_CIPHERSUITES",
173#endif /* MBEDTLS_REMOVE_ARC4_CIPHERSUITES */
174#if defined(MBEDTLS_ECP_DP_SECP192R1_ENABLED)
175 "MBEDTLS_ECP_DP_SECP192R1_ENABLED",
176#endif /* MBEDTLS_ECP_DP_SECP192R1_ENABLED */
177#if defined(MBEDTLS_ECP_DP_SECP224R1_ENABLED)
178 "MBEDTLS_ECP_DP_SECP224R1_ENABLED",
179#endif /* MBEDTLS_ECP_DP_SECP224R1_ENABLED */
180#if defined(MBEDTLS_ECP_DP_SECP256R1_ENABLED)
181 "MBEDTLS_ECP_DP_SECP256R1_ENABLED",
182#endif /* MBEDTLS_ECP_DP_SECP256R1_ENABLED */
183#if defined(MBEDTLS_ECP_DP_SECP384R1_ENABLED)
184 "MBEDTLS_ECP_DP_SECP384R1_ENABLED",
185#endif /* MBEDTLS_ECP_DP_SECP384R1_ENABLED */
186#if defined(MBEDTLS_ECP_DP_SECP521R1_ENABLED)
187 "MBEDTLS_ECP_DP_SECP521R1_ENABLED",
188#endif /* MBEDTLS_ECP_DP_SECP521R1_ENABLED */
189#if defined(MBEDTLS_ECP_DP_SECP192K1_ENABLED)
190 "MBEDTLS_ECP_DP_SECP192K1_ENABLED",
191#endif /* MBEDTLS_ECP_DP_SECP192K1_ENABLED */
192#if defined(MBEDTLS_ECP_DP_SECP224K1_ENABLED)
193 "MBEDTLS_ECP_DP_SECP224K1_ENABLED",
194#endif /* MBEDTLS_ECP_DP_SECP224K1_ENABLED */
195#if defined(MBEDTLS_ECP_DP_SECP256K1_ENABLED)
196 "MBEDTLS_ECP_DP_SECP256K1_ENABLED",
197#endif /* MBEDTLS_ECP_DP_SECP256K1_ENABLED */
198#if defined(MBEDTLS_ECP_DP_BP256R1_ENABLED)
199 "MBEDTLS_ECP_DP_BP256R1_ENABLED",
200#endif /* MBEDTLS_ECP_DP_BP256R1_ENABLED */
201#if defined(MBEDTLS_ECP_DP_BP384R1_ENABLED)
202 "MBEDTLS_ECP_DP_BP384R1_ENABLED",
203#endif /* MBEDTLS_ECP_DP_BP384R1_ENABLED */
204#if defined(MBEDTLS_ECP_DP_BP512R1_ENABLED)
205 "MBEDTLS_ECP_DP_BP512R1_ENABLED",
206#endif /* MBEDTLS_ECP_DP_BP512R1_ENABLED */
207#if defined(MBEDTLS_ECP_DP_M221_ENABLED)
208 "MBEDTLS_ECP_DP_M221_ENABLED",
209#endif /* MBEDTLS_ECP_DP_M221_ENABLED */
210#if defined(MBEDTLS_ECP_DP_M255_ENABLED)
211 "MBEDTLS_ECP_DP_M255_ENABLED",
212#endif /* MBEDTLS_ECP_DP_M255_ENABLED */
213#if defined(MBEDTLS_ECP_DP_M383_ENABLED)
214 "MBEDTLS_ECP_DP_M383_ENABLED",
215#endif /* MBEDTLS_ECP_DP_M383_ENABLED */
216#if defined(MBEDTLS_ECP_DP_M511_ENABLED)
217 "MBEDTLS_ECP_DP_M511_ENABLED",
218#endif /* MBEDTLS_ECP_DP_M511_ENABLED */
219#if defined(MBEDTLS_ECP_NIST_OPTIM)
220 "MBEDTLS_ECP_NIST_OPTIM",
221#endif /* MBEDTLS_ECP_NIST_OPTIM */
222#if defined(MBEDTLS_ECDSA_DETERMINISTIC)
223 "MBEDTLS_ECDSA_DETERMINISTIC",
224#endif /* MBEDTLS_ECDSA_DETERMINISTIC */
225#if defined(MBEDTLS_KEY_EXCHANGE_PSK_ENABLED)
226 "MBEDTLS_KEY_EXCHANGE_PSK_ENABLED",
227#endif /* MBEDTLS_KEY_EXCHANGE_PSK_ENABLED */
228#if defined(MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED)
229 "MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED",
230#endif /* MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED */
231#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED)
232 "MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED",
233#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED */
234#if defined(MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED)
235 "MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED",
236#endif /* MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED */
237#if defined(MBEDTLS_KEY_EXCHANGE_RSA_ENABLED)
238 "MBEDTLS_KEY_EXCHANGE_RSA_ENABLED",
239#endif /* MBEDTLS_KEY_EXCHANGE_RSA_ENABLED */
240#if defined(MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED)
241 "MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED",
242#endif /* MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED */
243#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED)
244 "MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED",
245#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED */
246#if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED)
247 "MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED",
248#endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED */
249#if defined(MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED)
250 "MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED",
251#endif /* MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED */
252#if defined(MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED)
253 "MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED",
254#endif /* MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED */
255#if defined(MBEDTLS_PK_PARSE_EC_EXTENDED)
256 "MBEDTLS_PK_PARSE_EC_EXTENDED",
257#endif /* MBEDTLS_PK_PARSE_EC_EXTENDED */
258#if defined(MBEDTLS_ERROR_STRERROR_DUMMY)
259 "MBEDTLS_ERROR_STRERROR_DUMMY",
260#endif /* MBEDTLS_ERROR_STRERROR_DUMMY */
261#if defined(MBEDTLS_GENPRIME)
262 "MBEDTLS_GENPRIME",
263#endif /* MBEDTLS_GENPRIME */
264#if defined(MBEDTLS_FS_IO)
265 "MBEDTLS_FS_IO",
266#endif /* MBEDTLS_FS_IO */
267#if defined(MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES)
268 "MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES",
269#endif /* MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES */
270#if defined(MBEDTLS_NO_PLATFORM_ENTROPY)
271 "MBEDTLS_NO_PLATFORM_ENTROPY",
272#endif /* MBEDTLS_NO_PLATFORM_ENTROPY */
273#if defined(MBEDTLS_ENTROPY_FORCE_SHA256)
274 "MBEDTLS_ENTROPY_FORCE_SHA256",
275#endif /* MBEDTLS_ENTROPY_FORCE_SHA256 */
276#if defined(MBEDTLS_MEMORY_DEBUG)
277 "MBEDTLS_MEMORY_DEBUG",
278#endif /* MBEDTLS_MEMORY_DEBUG */
279#if defined(MBEDTLS_MEMORY_BACKTRACE)
280 "MBEDTLS_MEMORY_BACKTRACE",
281#endif /* MBEDTLS_MEMORY_BACKTRACE */
282#if defined(MBEDTLS_PK_RSA_ALT_SUPPORT)
283 "MBEDTLS_PK_RSA_ALT_SUPPORT",
284#endif /* MBEDTLS_PK_RSA_ALT_SUPPORT */
285#if defined(MBEDTLS_PKCS1_V15)
286 "MBEDTLS_PKCS1_V15",
287#endif /* MBEDTLS_PKCS1_V15 */
288#if defined(MBEDTLS_PKCS1_V21)
289 "MBEDTLS_PKCS1_V21",
290#endif /* MBEDTLS_PKCS1_V21 */
291#if defined(MBEDTLS_RSA_NO_CRT)
292 "MBEDTLS_RSA_NO_CRT",
293#endif /* MBEDTLS_RSA_NO_CRT */
294#if defined(MBEDTLS_SELF_TEST)
295 "MBEDTLS_SELF_TEST",
296#endif /* MBEDTLS_SELF_TEST */
297#if defined(MBEDTLS_SSL_AEAD_RANDOM_IV)
298 "MBEDTLS_SSL_AEAD_RANDOM_IV",
299#endif /* MBEDTLS_SSL_AEAD_RANDOM_IV */
300#if defined(MBEDTLS_SSL_ALL_ALERT_MESSAGES)
301 "MBEDTLS_SSL_ALL_ALERT_MESSAGES",
302#endif /* MBEDTLS_SSL_ALL_ALERT_MESSAGES */
303#if defined(MBEDTLS_SSL_DEBUG_ALL)
304 "MBEDTLS_SSL_DEBUG_ALL",
305#endif /* MBEDTLS_SSL_DEBUG_ALL */
306#if defined(MBEDTLS_SSL_ENCRYPT_THEN_MAC)
307 "MBEDTLS_SSL_ENCRYPT_THEN_MAC",
308#endif /* MBEDTLS_SSL_ENCRYPT_THEN_MAC */
309#if defined(MBEDTLS_SSL_EXTENDED_MASTER_SECRET)
310 "MBEDTLS_SSL_EXTENDED_MASTER_SECRET",
311#endif /* MBEDTLS_SSL_EXTENDED_MASTER_SECRET */
312#if defined(MBEDTLS_SSL_FALLBACK_SCSV)
313 "MBEDTLS_SSL_FALLBACK_SCSV",
314#endif /* MBEDTLS_SSL_FALLBACK_SCSV */
315#if defined(MBEDTLS_SSL_HW_RECORD_ACCEL)
316 "MBEDTLS_SSL_HW_RECORD_ACCEL",
317#endif /* MBEDTLS_SSL_HW_RECORD_ACCEL */
318#if defined(MBEDTLS_SSL_CBC_RECORD_SPLITTING)
319 "MBEDTLS_SSL_CBC_RECORD_SPLITTING",
320#endif /* MBEDTLS_SSL_CBC_RECORD_SPLITTING */
321#if defined(MBEDTLS_SSL_RENEGOTIATION)
322 "MBEDTLS_SSL_RENEGOTIATION",
323#endif /* MBEDTLS_SSL_RENEGOTIATION */
324#if defined(MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO)
325 "MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO",
326#endif /* MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO */
327#if defined(MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE)
328 "MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE",
329#endif /* MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE */
330#if defined(MBEDTLS_SSL_MAX_FRAGMENT_LENGTH)
331 "MBEDTLS_SSL_MAX_FRAGMENT_LENGTH",
332#endif /* MBEDTLS_SSL_MAX_FRAGMENT_LENGTH */
333#if defined(MBEDTLS_SSL_PROTO_SSL3)
334 "MBEDTLS_SSL_PROTO_SSL3",
335#endif /* MBEDTLS_SSL_PROTO_SSL3 */
336#if defined(MBEDTLS_SSL_PROTO_TLS1)
337 "MBEDTLS_SSL_PROTO_TLS1",
338#endif /* MBEDTLS_SSL_PROTO_TLS1 */
339#if defined(MBEDTLS_SSL_PROTO_TLS1_1)
340 "MBEDTLS_SSL_PROTO_TLS1_1",
341#endif /* MBEDTLS_SSL_PROTO_TLS1_1 */
342#if defined(MBEDTLS_SSL_PROTO_TLS1_2)
343 "MBEDTLS_SSL_PROTO_TLS1_2",
344#endif /* MBEDTLS_SSL_PROTO_TLS1_2 */
345#if defined(MBEDTLS_SSL_PROTO_DTLS)
346 "MBEDTLS_SSL_PROTO_DTLS",
347#endif /* MBEDTLS_SSL_PROTO_DTLS */
348#if defined(MBEDTLS_SSL_ALPN)
349 "MBEDTLS_SSL_ALPN",
350#endif /* MBEDTLS_SSL_ALPN */
351#if defined(MBEDTLS_SSL_DTLS_ANTI_REPLAY)
352 "MBEDTLS_SSL_DTLS_ANTI_REPLAY",
353#endif /* MBEDTLS_SSL_DTLS_ANTI_REPLAY */
354#if defined(MBEDTLS_SSL_DTLS_HELLO_VERIFY)
355 "MBEDTLS_SSL_DTLS_HELLO_VERIFY",
356#endif /* MBEDTLS_SSL_DTLS_HELLO_VERIFY */
357#if defined(MBEDTLS_SSL_DTLS_BADMAC_LIMIT)
358 "MBEDTLS_SSL_DTLS_BADMAC_LIMIT",
359#endif /* MBEDTLS_SSL_DTLS_BADMAC_LIMIT */
360#if defined(MBEDTLS_SSL_SESSION_TICKETS)
361 "MBEDTLS_SSL_SESSION_TICKETS",
362#endif /* MBEDTLS_SSL_SESSION_TICKETS */
363#if defined(MBEDTLS_SSL_SERVER_NAME_INDICATION)
364 "MBEDTLS_SSL_SERVER_NAME_INDICATION",
365#endif /* MBEDTLS_SSL_SERVER_NAME_INDICATION */
366#if defined(MBEDTLS_SSL_TRUNCATED_HMAC)
367 "MBEDTLS_SSL_TRUNCATED_HMAC",
368#endif /* MBEDTLS_SSL_TRUNCATED_HMAC */
369#if defined(MBEDTLS_SSL_SET_CURVES)
370 "MBEDTLS_SSL_SET_CURVES",
371#endif /* MBEDTLS_SSL_SET_CURVES */
372#if defined(MBEDTLS_THREADING_ALT)
373 "MBEDTLS_THREADING_ALT",
374#endif /* MBEDTLS_THREADING_ALT */
375#if defined(MBEDTLS_THREADING_PTHREAD)
376 "MBEDTLS_THREADING_PTHREAD",
377#endif /* MBEDTLS_THREADING_PTHREAD */
378#if defined(MBEDTLS_VERSION_FEATURES)
379 "MBEDTLS_VERSION_FEATURES",
380#endif /* MBEDTLS_VERSION_FEATURES */
381#if defined(MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3)
382 "MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3",
383#endif /* MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3 */
384#if defined(MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION)
385 "MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION",
386#endif /* MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION */
387#if defined(MBEDTLS_X509_CHECK_KEY_USAGE)
388 "MBEDTLS_X509_CHECK_KEY_USAGE",
389#endif /* MBEDTLS_X509_CHECK_KEY_USAGE */
390#if defined(MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE)
391 "MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE",
392#endif /* MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE */
393#if defined(MBEDTLS_X509_RSASSA_PSS_SUPPORT)
394 "MBEDTLS_X509_RSASSA_PSS_SUPPORT",
395#endif /* MBEDTLS_X509_RSASSA_PSS_SUPPORT */
396#if defined(MBEDTLS_ZLIB_SUPPORT)
397 "MBEDTLS_ZLIB_SUPPORT",
398#endif /* MBEDTLS_ZLIB_SUPPORT */
399#if defined(MBEDTLS_AESNI_C)
400 "MBEDTLS_AESNI_C",
401#endif /* MBEDTLS_AESNI_C */
402#if defined(MBEDTLS_AES_C)
403 "MBEDTLS_AES_C",
404#endif /* MBEDTLS_AES_C */
405#if defined(MBEDTLS_ARC4_C)
406 "MBEDTLS_ARC4_C",
407#endif /* MBEDTLS_ARC4_C */
408#if defined(MBEDTLS_ASN1_PARSE_C)
409 "MBEDTLS_ASN1_PARSE_C",
410#endif /* MBEDTLS_ASN1_PARSE_C */
411#if defined(MBEDTLS_ASN1_WRITE_C)
412 "MBEDTLS_ASN1_WRITE_C",
413#endif /* MBEDTLS_ASN1_WRITE_C */
414#if defined(MBEDTLS_BASE64_C)
415 "MBEDTLS_BASE64_C",
416#endif /* MBEDTLS_BASE64_C */
417#if defined(MBEDTLS_BIGNUM_C)
418 "MBEDTLS_BIGNUM_C",
419#endif /* MBEDTLS_BIGNUM_C */
420#if defined(MBEDTLS_BLOWFISH_C)
421 "MBEDTLS_BLOWFISH_C",
422#endif /* MBEDTLS_BLOWFISH_C */
423#if defined(MBEDTLS_CAMELLIA_C)
424 "MBEDTLS_CAMELLIA_C",
425#endif /* MBEDTLS_CAMELLIA_C */
426#if defined(MBEDTLS_CCM_C)
427 "MBEDTLS_CCM_C",
428#endif /* MBEDTLS_CCM_C */
429#if defined(MBEDTLS_CERTS_C)
430 "MBEDTLS_CERTS_C",
431#endif /* MBEDTLS_CERTS_C */
432#if defined(MBEDTLS_CIPHER_C)
433 "MBEDTLS_CIPHER_C",
434#endif /* MBEDTLS_CIPHER_C */
435#if defined(MBEDTLS_CTR_DRBG_C)
436 "MBEDTLS_CTR_DRBG_C",
437#endif /* MBEDTLS_CTR_DRBG_C */
438#if defined(MBEDTLS_DEBUG_C)
439 "MBEDTLS_DEBUG_C",
440#endif /* MBEDTLS_DEBUG_C */
441#if defined(MBEDTLS_DES_C)
442 "MBEDTLS_DES_C",
443#endif /* MBEDTLS_DES_C */
444#if defined(MBEDTLS_DHM_C)
445 "MBEDTLS_DHM_C",
446#endif /* MBEDTLS_DHM_C */
447#if defined(MBEDTLS_ECDH_C)
448 "MBEDTLS_ECDH_C",
449#endif /* MBEDTLS_ECDH_C */
450#if defined(MBEDTLS_ECDSA_C)
451 "MBEDTLS_ECDSA_C",
452#endif /* MBEDTLS_ECDSA_C */
453#if defined(MBEDTLS_ECP_C)
454 "MBEDTLS_ECP_C",
455#endif /* MBEDTLS_ECP_C */
456#if defined(MBEDTLS_ENTROPY_C)
457 "MBEDTLS_ENTROPY_C",
458#endif /* MBEDTLS_ENTROPY_C */
459#if defined(MBEDTLS_ERROR_C)
460 "MBEDTLS_ERROR_C",
461#endif /* MBEDTLS_ERROR_C */
462#if defined(MBEDTLS_GCM_C)
463 "MBEDTLS_GCM_C",
464#endif /* MBEDTLS_GCM_C */
465#if defined(MBEDTLS_HAVEGE_C)
466 "MBEDTLS_HAVEGE_C",
467#endif /* MBEDTLS_HAVEGE_C */
468#if defined(MBEDTLS_HMAC_DRBG_C)
469 "MBEDTLS_HMAC_DRBG_C",
470#endif /* MBEDTLS_HMAC_DRBG_C */
471#if defined(MBEDTLS_MD_C)
472 "MBEDTLS_MD_C",
473#endif /* MBEDTLS_MD_C */
474#if defined(MBEDTLS_MD2_C)
475 "MBEDTLS_MD2_C",
476#endif /* MBEDTLS_MD2_C */
477#if defined(MBEDTLS_MD4_C)
478 "MBEDTLS_MD4_C",
479#endif /* MBEDTLS_MD4_C */
480#if defined(MBEDTLS_MD5_C)
481 "MBEDTLS_MD5_C",
482#endif /* MBEDTLS_MD5_C */
483#if defined(MBEDTLS_MEMORY_BUFFER_ALLOC_C)
484 "MBEDTLS_MEMORY_BUFFER_ALLOC_C",
485#endif /* MBEDTLS_MEMORY_BUFFER_ALLOC_C */
486#if defined(MBEDTLS_NET_C)
487 "MBEDTLS_NET_C",
488#endif /* MBEDTLS_NET_C */
489#if defined(MBEDTLS_OID_C)
490 "MBEDTLS_OID_C",
491#endif /* MBEDTLS_OID_C */
492#if defined(MBEDTLS_PADLOCK_C)
493 "MBEDTLS_PADLOCK_C",
494#endif /* MBEDTLS_PADLOCK_C */
495#if defined(MBEDTLS_PEM_PARSE_C)
496 "MBEDTLS_PEM_PARSE_C",
497#endif /* MBEDTLS_PEM_PARSE_C */
498#if defined(MBEDTLS_PEM_WRITE_C)
499 "MBEDTLS_PEM_WRITE_C",
500#endif /* MBEDTLS_PEM_WRITE_C */
501#if defined(MBEDTLS_PK_C)
502 "MBEDTLS_PK_C",
503#endif /* MBEDTLS_PK_C */
504#if defined(MBEDTLS_PK_PARSE_C)
505 "MBEDTLS_PK_PARSE_C",
506#endif /* MBEDTLS_PK_PARSE_C */
507#if defined(MBEDTLS_PK_WRITE_C)
508 "MBEDTLS_PK_WRITE_C",
509#endif /* MBEDTLS_PK_WRITE_C */
510#if defined(MBEDTLS_PKCS5_C)
511 "MBEDTLS_PKCS5_C",
512#endif /* MBEDTLS_PKCS5_C */
513#if defined(MBEDTLS_PKCS11_C)
514 "MBEDTLS_PKCS11_C",
515#endif /* MBEDTLS_PKCS11_C */
516#if defined(MBEDTLS_PKCS12_C)
517 "MBEDTLS_PKCS12_C",
518#endif /* MBEDTLS_PKCS12_C */
519#if defined(MBEDTLS_PLATFORM_C)
520 "MBEDTLS_PLATFORM_C",
521#endif /* MBEDTLS_PLATFORM_C */
522#if defined(MBEDTLS_RIPEMD160_C)
523 "MBEDTLS_RIPEMD160_C",
524#endif /* MBEDTLS_RIPEMD160_C */
525#if defined(MBEDTLS_RSA_C)
526 "MBEDTLS_RSA_C",
527#endif /* MBEDTLS_RSA_C */
528#if defined(MBEDTLS_SHA1_C)
529 "MBEDTLS_SHA1_C",
530#endif /* MBEDTLS_SHA1_C */
531#if defined(MBEDTLS_SHA256_C)
532 "MBEDTLS_SHA256_C",
533#endif /* MBEDTLS_SHA256_C */
534#if defined(MBEDTLS_SHA512_C)
535 "MBEDTLS_SHA512_C",
536#endif /* MBEDTLS_SHA512_C */
537#if defined(MBEDTLS_SSL_CACHE_C)
538 "MBEDTLS_SSL_CACHE_C",
539#endif /* MBEDTLS_SSL_CACHE_C */
540#if defined(MBEDTLS_SSL_COOKIE_C)
541 "MBEDTLS_SSL_COOKIE_C",
542#endif /* MBEDTLS_SSL_COOKIE_C */
543#if defined(MBEDTLS_SSL_CLI_C)
544 "MBEDTLS_SSL_CLI_C",
545#endif /* MBEDTLS_SSL_CLI_C */
546#if defined(MBEDTLS_SSL_SRV_C)
547 "MBEDTLS_SSL_SRV_C",
548#endif /* MBEDTLS_SSL_SRV_C */
549#if defined(MBEDTLS_SSL_TLS_C)
550 "MBEDTLS_SSL_TLS_C",
551#endif /* MBEDTLS_SSL_TLS_C */
552#if defined(MBEDTLS_THREADING_C)
553 "MBEDTLS_THREADING_C",
554#endif /* MBEDTLS_THREADING_C */
555#if defined(MBEDTLS_TIMING_C)
556 "MBEDTLS_TIMING_C",
557#endif /* MBEDTLS_TIMING_C */
558#if defined(MBEDTLS_VERSION_C)
559 "MBEDTLS_VERSION_C",
560#endif /* MBEDTLS_VERSION_C */
561#if defined(MBEDTLS_X509_USE_C)
562 "MBEDTLS_X509_USE_C",
563#endif /* MBEDTLS_X509_USE_C */
564#if defined(MBEDTLS_X509_CRT_PARSE_C)
565 "MBEDTLS_X509_CRT_PARSE_C",
566#endif /* MBEDTLS_X509_CRT_PARSE_C */
567#if defined(MBEDTLS_X509_CRL_PARSE_C)
568 "MBEDTLS_X509_CRL_PARSE_C",
569#endif /* MBEDTLS_X509_CRL_PARSE_C */
570#if defined(MBEDTLS_X509_CSR_PARSE_C)
571 "MBEDTLS_X509_CSR_PARSE_C",
572#endif /* MBEDTLS_X509_CSR_PARSE_C */
573#if defined(MBEDTLS_X509_CREATE_C)
574 "MBEDTLS_X509_CREATE_C",
575#endif /* MBEDTLS_X509_CREATE_C */
576#if defined(MBEDTLS_X509_CRT_WRITE_C)
577 "MBEDTLS_X509_CRT_WRITE_C",
578#endif /* MBEDTLS_X509_CRT_WRITE_C */
579#if defined(MBEDTLS_X509_CSR_WRITE_C)
580 "MBEDTLS_X509_CSR_WRITE_C",
581#endif /* MBEDTLS_X509_CSR_WRITE_C */
582#if defined(MBEDTLS_XTEA_C)
583 "MBEDTLS_XTEA_C",
584#endif /* MBEDTLS_XTEA_C */
585#endif /* MBEDTLS_VERSION_FEATURES */
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200586 NULL
587};
588
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200589int mbedtls_version_check_feature( const char *feature )
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200590{
591 const char **idx = features;
592
Paul Bakker2ca1dc82014-04-30 17:01:25 +0200593 if( *idx == NULL )
594 return( -2 );
595
Paul Bakker0f90d7d2014-04-30 11:49:44 +0200596 if( feature == NULL )
597 return( -1 );
598
599 while( *idx != NULL )
600 {
601 if( !strcasecmp( *idx, feature ) )
602 return( 0 );
603 idx++;
604 }
605 return( -1 );
606}
607
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +0200608#endif /* MBEDTLS_VERSION_C */