123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650 |
- /*
- * Version feature information
- *
- * Copyright (C) 2006-2015, ARM Limited, All Rights Reserved
- * SPDX-License-Identifier: GPL-2.0
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- *
- * This file is part of mbed TLS (https://tls.mbed.org)
- */
- #if !defined(MBEDTLS_CONFIG_FILE)
- #include "mbedtls/config.h"
- #else
- #include MBEDTLS_CONFIG_FILE
- #endif
- #if defined(MBEDTLS_VERSION_C)
- #include "mbedtls/version.h"
- #include <string.h>
- static const char *features[] = {
- #if defined(MBEDTLS_VERSION_FEATURES)
- #if defined(MBEDTLS_HAVE_ASM)
- "MBEDTLS_HAVE_ASM",
- #endif /* MBEDTLS_HAVE_ASM */
- #if defined(MBEDTLS_HAVE_SSE2)
- "MBEDTLS_HAVE_SSE2",
- #endif /* MBEDTLS_HAVE_SSE2 */
- #if defined(MBEDTLS_HAVE_TIME)
- "MBEDTLS_HAVE_TIME",
- #endif /* MBEDTLS_HAVE_TIME */
- #if defined(MBEDTLS_HAVE_TIME_DATE)
- "MBEDTLS_HAVE_TIME_DATE",
- #endif /* MBEDTLS_HAVE_TIME_DATE */
- #if defined(MBEDTLS_PLATFORM_MEMORY)
- "MBEDTLS_PLATFORM_MEMORY",
- #endif /* MBEDTLS_PLATFORM_MEMORY */
- #if defined(MBEDTLS_PLATFORM_NO_STD_FUNCTIONS)
- "MBEDTLS_PLATFORM_NO_STD_FUNCTIONS",
- #endif /* MBEDTLS_PLATFORM_NO_STD_FUNCTIONS */
- #if defined(MBEDTLS_PLATFORM_EXIT_ALT)
- "MBEDTLS_PLATFORM_EXIT_ALT",
- #endif /* MBEDTLS_PLATFORM_EXIT_ALT */
- #if defined(MBEDTLS_PLATFORM_TIME_ALT)
- "MBEDTLS_PLATFORM_TIME_ALT",
- #endif /* MBEDTLS_PLATFORM_TIME_ALT */
- #if defined(MBEDTLS_PLATFORM_FPRINTF_ALT)
- "MBEDTLS_PLATFORM_FPRINTF_ALT",
- #endif /* MBEDTLS_PLATFORM_FPRINTF_ALT */
- #if defined(MBEDTLS_PLATFORM_PRINTF_ALT)
- "MBEDTLS_PLATFORM_PRINTF_ALT",
- #endif /* MBEDTLS_PLATFORM_PRINTF_ALT */
- #if defined(MBEDTLS_PLATFORM_SNPRINTF_ALT)
- "MBEDTLS_PLATFORM_SNPRINTF_ALT",
- #endif /* MBEDTLS_PLATFORM_SNPRINTF_ALT */
- #if defined(MBEDTLS_PLATFORM_NV_SEED_ALT)
- "MBEDTLS_PLATFORM_NV_SEED_ALT",
- #endif /* MBEDTLS_PLATFORM_NV_SEED_ALT */
- #if defined(MBEDTLS_DEPRECATED_WARNING)
- "MBEDTLS_DEPRECATED_WARNING",
- #endif /* MBEDTLS_DEPRECATED_WARNING */
- #if defined(MBEDTLS_DEPRECATED_REMOVED)
- "MBEDTLS_DEPRECATED_REMOVED",
- #endif /* MBEDTLS_DEPRECATED_REMOVED */
- #if defined(MBEDTLS_TIMING_ALT)
- "MBEDTLS_TIMING_ALT",
- #endif /* MBEDTLS_TIMING_ALT */
- #if defined(MBEDTLS_AES_ALT)
- "MBEDTLS_AES_ALT",
- #endif /* MBEDTLS_AES_ALT */
- #if defined(MBEDTLS_ARC4_ALT)
- "MBEDTLS_ARC4_ALT",
- #endif /* MBEDTLS_ARC4_ALT */
- #if defined(MBEDTLS_BLOWFISH_ALT)
- "MBEDTLS_BLOWFISH_ALT",
- #endif /* MBEDTLS_BLOWFISH_ALT */
- #if defined(MBEDTLS_CAMELLIA_ALT)
- "MBEDTLS_CAMELLIA_ALT",
- #endif /* MBEDTLS_CAMELLIA_ALT */
- #if defined(MBEDTLS_DES_ALT)
- "MBEDTLS_DES_ALT",
- #endif /* MBEDTLS_DES_ALT */
- #if defined(MBEDTLS_XTEA_ALT)
- "MBEDTLS_XTEA_ALT",
- #endif /* MBEDTLS_XTEA_ALT */
- #if defined(MBEDTLS_MD2_ALT)
- "MBEDTLS_MD2_ALT",
- #endif /* MBEDTLS_MD2_ALT */
- #if defined(MBEDTLS_MD4_ALT)
- "MBEDTLS_MD4_ALT",
- #endif /* MBEDTLS_MD4_ALT */
- #if defined(MBEDTLS_MD5_ALT)
- "MBEDTLS_MD5_ALT",
- #endif /* MBEDTLS_MD5_ALT */
- #if defined(MBEDTLS_RIPEMD160_ALT)
- "MBEDTLS_RIPEMD160_ALT",
- #endif /* MBEDTLS_RIPEMD160_ALT */
- #if defined(MBEDTLS_SHA1_ALT)
- "MBEDTLS_SHA1_ALT",
- #endif /* MBEDTLS_SHA1_ALT */
- #if defined(MBEDTLS_SHA256_ALT)
- "MBEDTLS_SHA256_ALT",
- #endif /* MBEDTLS_SHA256_ALT */
- #if defined(MBEDTLS_SHA512_ALT)
- "MBEDTLS_SHA512_ALT",
- #endif /* MBEDTLS_SHA512_ALT */
- #if defined(MBEDTLS_MD2_PROCESS_ALT)
- "MBEDTLS_MD2_PROCESS_ALT",
- #endif /* MBEDTLS_MD2_PROCESS_ALT */
- #if defined(MBEDTLS_MD4_PROCESS_ALT)
- "MBEDTLS_MD4_PROCESS_ALT",
- #endif /* MBEDTLS_MD4_PROCESS_ALT */
- #if defined(MBEDTLS_MD5_PROCESS_ALT)
- "MBEDTLS_MD5_PROCESS_ALT",
- #endif /* MBEDTLS_MD5_PROCESS_ALT */
- #if defined(MBEDTLS_RIPEMD160_PROCESS_ALT)
- "MBEDTLS_RIPEMD160_PROCESS_ALT",
- #endif /* MBEDTLS_RIPEMD160_PROCESS_ALT */
- #if defined(MBEDTLS_SHA1_PROCESS_ALT)
- "MBEDTLS_SHA1_PROCESS_ALT",
- #endif /* MBEDTLS_SHA1_PROCESS_ALT */
- #if defined(MBEDTLS_SHA256_PROCESS_ALT)
- "MBEDTLS_SHA256_PROCESS_ALT",
- #endif /* MBEDTLS_SHA256_PROCESS_ALT */
- #if defined(MBEDTLS_SHA512_PROCESS_ALT)
- "MBEDTLS_SHA512_PROCESS_ALT",
- #endif /* MBEDTLS_SHA512_PROCESS_ALT */
- #if defined(MBEDTLS_DES_SETKEY_ALT)
- "MBEDTLS_DES_SETKEY_ALT",
- #endif /* MBEDTLS_DES_SETKEY_ALT */
- #if defined(MBEDTLS_DES_CRYPT_ECB_ALT)
- "MBEDTLS_DES_CRYPT_ECB_ALT",
- #endif /* MBEDTLS_DES_CRYPT_ECB_ALT */
- #if defined(MBEDTLS_DES3_CRYPT_ECB_ALT)
- "MBEDTLS_DES3_CRYPT_ECB_ALT",
- #endif /* MBEDTLS_DES3_CRYPT_ECB_ALT */
- #if defined(MBEDTLS_AES_SETKEY_ENC_ALT)
- "MBEDTLS_AES_SETKEY_ENC_ALT",
- #endif /* MBEDTLS_AES_SETKEY_ENC_ALT */
- #if defined(MBEDTLS_AES_SETKEY_DEC_ALT)
- "MBEDTLS_AES_SETKEY_DEC_ALT",
- #endif /* MBEDTLS_AES_SETKEY_DEC_ALT */
- #if defined(MBEDTLS_AES_ENCRYPT_ALT)
- "MBEDTLS_AES_ENCRYPT_ALT",
- #endif /* MBEDTLS_AES_ENCRYPT_ALT */
- #if defined(MBEDTLS_AES_DECRYPT_ALT)
- "MBEDTLS_AES_DECRYPT_ALT",
- #endif /* MBEDTLS_AES_DECRYPT_ALT */
- #if defined(MBEDTLS_TEST_NULL_ENTROPY)
- "MBEDTLS_TEST_NULL_ENTROPY",
- #endif /* MBEDTLS_TEST_NULL_ENTROPY */
- #if defined(MBEDTLS_ENTROPY_HARDWARE_ALT)
- "MBEDTLS_ENTROPY_HARDWARE_ALT",
- #endif /* MBEDTLS_ENTROPY_HARDWARE_ALT */
- #if defined(MBEDTLS_AES_ROM_TABLES)
- "MBEDTLS_AES_ROM_TABLES",
- #endif /* MBEDTLS_AES_ROM_TABLES */
- #if defined(MBEDTLS_CAMELLIA_SMALL_MEMORY)
- "MBEDTLS_CAMELLIA_SMALL_MEMORY",
- #endif /* MBEDTLS_CAMELLIA_SMALL_MEMORY */
- #if defined(MBEDTLS_CIPHER_MODE_CBC)
- "MBEDTLS_CIPHER_MODE_CBC",
- #endif /* MBEDTLS_CIPHER_MODE_CBC */
- #if defined(MBEDTLS_CIPHER_MODE_CFB)
- "MBEDTLS_CIPHER_MODE_CFB",
- #endif /* MBEDTLS_CIPHER_MODE_CFB */
- #if defined(MBEDTLS_CIPHER_MODE_CTR)
- "MBEDTLS_CIPHER_MODE_CTR",
- #endif /* MBEDTLS_CIPHER_MODE_CTR */
- #if defined(MBEDTLS_CIPHER_NULL_CIPHER)
- "MBEDTLS_CIPHER_NULL_CIPHER",
- #endif /* MBEDTLS_CIPHER_NULL_CIPHER */
- #if defined(MBEDTLS_CIPHER_PADDING_PKCS7)
- "MBEDTLS_CIPHER_PADDING_PKCS7",
- #endif /* MBEDTLS_CIPHER_PADDING_PKCS7 */
- #if defined(MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS)
- "MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS",
- #endif /* MBEDTLS_CIPHER_PADDING_ONE_AND_ZEROS */
- #if defined(MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN)
- "MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN",
- #endif /* MBEDTLS_CIPHER_PADDING_ZEROS_AND_LEN */
- #if defined(MBEDTLS_CIPHER_PADDING_ZEROS)
- "MBEDTLS_CIPHER_PADDING_ZEROS",
- #endif /* MBEDTLS_CIPHER_PADDING_ZEROS */
- #if defined(MBEDTLS_ENABLE_WEAK_CIPHERSUITES)
- "MBEDTLS_ENABLE_WEAK_CIPHERSUITES",
- #endif /* MBEDTLS_ENABLE_WEAK_CIPHERSUITES */
- #if defined(MBEDTLS_REMOVE_ARC4_CIPHERSUITES)
- "MBEDTLS_REMOVE_ARC4_CIPHERSUITES",
- #endif /* MBEDTLS_REMOVE_ARC4_CIPHERSUITES */
- #if defined(MBEDTLS_ECP_DP_SECP192R1_ENABLED)
- "MBEDTLS_ECP_DP_SECP192R1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_SECP192R1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_SECP224R1_ENABLED)
- "MBEDTLS_ECP_DP_SECP224R1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_SECP224R1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_SECP256R1_ENABLED)
- "MBEDTLS_ECP_DP_SECP256R1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_SECP256R1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_SECP384R1_ENABLED)
- "MBEDTLS_ECP_DP_SECP384R1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_SECP384R1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_SECP521R1_ENABLED)
- "MBEDTLS_ECP_DP_SECP521R1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_SECP521R1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_SECP192K1_ENABLED)
- "MBEDTLS_ECP_DP_SECP192K1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_SECP192K1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_SECP224K1_ENABLED)
- "MBEDTLS_ECP_DP_SECP224K1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_SECP224K1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_SECP256K1_ENABLED)
- "MBEDTLS_ECP_DP_SECP256K1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_SECP256K1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_BP256R1_ENABLED)
- "MBEDTLS_ECP_DP_BP256R1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_BP256R1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_BP384R1_ENABLED)
- "MBEDTLS_ECP_DP_BP384R1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_BP384R1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_BP512R1_ENABLED)
- "MBEDTLS_ECP_DP_BP512R1_ENABLED",
- #endif /* MBEDTLS_ECP_DP_BP512R1_ENABLED */
- #if defined(MBEDTLS_ECP_DP_CURVE25519_ENABLED)
- "MBEDTLS_ECP_DP_CURVE25519_ENABLED",
- #endif /* MBEDTLS_ECP_DP_CURVE25519_ENABLED */
- #if defined(MBEDTLS_ECP_NIST_OPTIM)
- "MBEDTLS_ECP_NIST_OPTIM",
- #endif /* MBEDTLS_ECP_NIST_OPTIM */
- #if defined(MBEDTLS_ECDSA_DETERMINISTIC)
- "MBEDTLS_ECDSA_DETERMINISTIC",
- #endif /* MBEDTLS_ECDSA_DETERMINISTIC */
- #if defined(MBEDTLS_KEY_EXCHANGE_PSK_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_PSK_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_PSK_ENABLED */
- #if defined(MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED */
- #if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED */
- #if defined(MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED */
- #if defined(MBEDTLS_KEY_EXCHANGE_RSA_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_RSA_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_RSA_ENABLED */
- #if defined(MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED */
- #if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED */
- #if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED */
- #if defined(MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED */
- #if defined(MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED */
- #if defined(MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED)
- "MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED",
- #endif /* MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED */
- #if defined(MBEDTLS_PK_PARSE_EC_EXTENDED)
- "MBEDTLS_PK_PARSE_EC_EXTENDED",
- #endif /* MBEDTLS_PK_PARSE_EC_EXTENDED */
- #if defined(MBEDTLS_ERROR_STRERROR_DUMMY)
- "MBEDTLS_ERROR_STRERROR_DUMMY",
- #endif /* MBEDTLS_ERROR_STRERROR_DUMMY */
- #if defined(MBEDTLS_GENPRIME)
- "MBEDTLS_GENPRIME",
- #endif /* MBEDTLS_GENPRIME */
- #if defined(MBEDTLS_FS_IO)
- "MBEDTLS_FS_IO",
- #endif /* MBEDTLS_FS_IO */
- #if defined(MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES)
- "MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES",
- #endif /* MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES */
- #if defined(MBEDTLS_NO_PLATFORM_ENTROPY)
- "MBEDTLS_NO_PLATFORM_ENTROPY",
- #endif /* MBEDTLS_NO_PLATFORM_ENTROPY */
- #if defined(MBEDTLS_ENTROPY_FORCE_SHA256)
- "MBEDTLS_ENTROPY_FORCE_SHA256",
- #endif /* MBEDTLS_ENTROPY_FORCE_SHA256 */
- #if defined(MBEDTLS_ENTROPY_NV_SEED)
- "MBEDTLS_ENTROPY_NV_SEED",
- #endif /* MBEDTLS_ENTROPY_NV_SEED */
- #if defined(MBEDTLS_MEMORY_DEBUG)
- "MBEDTLS_MEMORY_DEBUG",
- #endif /* MBEDTLS_MEMORY_DEBUG */
- #if defined(MBEDTLS_MEMORY_BACKTRACE)
- "MBEDTLS_MEMORY_BACKTRACE",
- #endif /* MBEDTLS_MEMORY_BACKTRACE */
- #if defined(MBEDTLS_PK_RSA_ALT_SUPPORT)
- "MBEDTLS_PK_RSA_ALT_SUPPORT",
- #endif /* MBEDTLS_PK_RSA_ALT_SUPPORT */
- #if defined(MBEDTLS_PKCS1_V15)
- "MBEDTLS_PKCS1_V15",
- #endif /* MBEDTLS_PKCS1_V15 */
- #if defined(MBEDTLS_PKCS1_V21)
- "MBEDTLS_PKCS1_V21",
- #endif /* MBEDTLS_PKCS1_V21 */
- #if defined(MBEDTLS_RSA_NO_CRT)
- "MBEDTLS_RSA_NO_CRT",
- #endif /* MBEDTLS_RSA_NO_CRT */
- #if defined(MBEDTLS_SELF_TEST)
- "MBEDTLS_SELF_TEST",
- #endif /* MBEDTLS_SELF_TEST */
- #if defined(MBEDTLS_SHA256_SMALLER)
- "MBEDTLS_SHA256_SMALLER",
- #endif /* MBEDTLS_SHA256_SMALLER */
- #if defined(MBEDTLS_SSL_ALL_ALERT_MESSAGES)
- "MBEDTLS_SSL_ALL_ALERT_MESSAGES",
- #endif /* MBEDTLS_SSL_ALL_ALERT_MESSAGES */
- #if defined(MBEDTLS_SSL_DEBUG_ALL)
- "MBEDTLS_SSL_DEBUG_ALL",
- #endif /* MBEDTLS_SSL_DEBUG_ALL */
- #if defined(MBEDTLS_SSL_ENCRYPT_THEN_MAC)
- "MBEDTLS_SSL_ENCRYPT_THEN_MAC",
- #endif /* MBEDTLS_SSL_ENCRYPT_THEN_MAC */
- #if defined(MBEDTLS_SSL_EXTENDED_MASTER_SECRET)
- "MBEDTLS_SSL_EXTENDED_MASTER_SECRET",
- #endif /* MBEDTLS_SSL_EXTENDED_MASTER_SECRET */
- #if defined(MBEDTLS_SSL_FALLBACK_SCSV)
- "MBEDTLS_SSL_FALLBACK_SCSV",
- #endif /* MBEDTLS_SSL_FALLBACK_SCSV */
- #if defined(MBEDTLS_SSL_HW_RECORD_ACCEL)
- "MBEDTLS_SSL_HW_RECORD_ACCEL",
- #endif /* MBEDTLS_SSL_HW_RECORD_ACCEL */
- #if defined(MBEDTLS_SSL_CBC_RECORD_SPLITTING)
- "MBEDTLS_SSL_CBC_RECORD_SPLITTING",
- #endif /* MBEDTLS_SSL_CBC_RECORD_SPLITTING */
- #if defined(MBEDTLS_SSL_RENEGOTIATION)
- "MBEDTLS_SSL_RENEGOTIATION",
- #endif /* MBEDTLS_SSL_RENEGOTIATION */
- #if defined(MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO)
- "MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO",
- #endif /* MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO */
- #if defined(MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE)
- "MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE",
- #endif /* MBEDTLS_SSL_SRV_RESPECT_CLIENT_PREFERENCE */
- #if defined(MBEDTLS_SSL_MAX_FRAGMENT_LENGTH)
- "MBEDTLS_SSL_MAX_FRAGMENT_LENGTH",
- #endif /* MBEDTLS_SSL_MAX_FRAGMENT_LENGTH */
- #if defined(MBEDTLS_SSL_PROTO_SSL3)
- "MBEDTLS_SSL_PROTO_SSL3",
- #endif /* MBEDTLS_SSL_PROTO_SSL3 */
- #if defined(MBEDTLS_SSL_PROTO_TLS1)
- "MBEDTLS_SSL_PROTO_TLS1",
- #endif /* MBEDTLS_SSL_PROTO_TLS1 */
- #if defined(MBEDTLS_SSL_PROTO_TLS1_1)
- "MBEDTLS_SSL_PROTO_TLS1_1",
- #endif /* MBEDTLS_SSL_PROTO_TLS1_1 */
- #if defined(MBEDTLS_SSL_PROTO_TLS1_2)
- "MBEDTLS_SSL_PROTO_TLS1_2",
- #endif /* MBEDTLS_SSL_PROTO_TLS1_2 */
- #if defined(MBEDTLS_SSL_PROTO_DTLS)
- "MBEDTLS_SSL_PROTO_DTLS",
- #endif /* MBEDTLS_SSL_PROTO_DTLS */
- #if defined(MBEDTLS_SSL_ALPN)
- "MBEDTLS_SSL_ALPN",
- #endif /* MBEDTLS_SSL_ALPN */
- #if defined(MBEDTLS_SSL_DTLS_ANTI_REPLAY)
- "MBEDTLS_SSL_DTLS_ANTI_REPLAY",
- #endif /* MBEDTLS_SSL_DTLS_ANTI_REPLAY */
- #if defined(MBEDTLS_SSL_DTLS_HELLO_VERIFY)
- "MBEDTLS_SSL_DTLS_HELLO_VERIFY",
- #endif /* MBEDTLS_SSL_DTLS_HELLO_VERIFY */
- #if defined(MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE)
- "MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE",
- #endif /* MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE */
- #if defined(MBEDTLS_SSL_DTLS_BADMAC_LIMIT)
- "MBEDTLS_SSL_DTLS_BADMAC_LIMIT",
- #endif /* MBEDTLS_SSL_DTLS_BADMAC_LIMIT */
- #if defined(MBEDTLS_SSL_SESSION_TICKETS)
- "MBEDTLS_SSL_SESSION_TICKETS",
- #endif /* MBEDTLS_SSL_SESSION_TICKETS */
- #if defined(MBEDTLS_SSL_EXPORT_KEYS)
- "MBEDTLS_SSL_EXPORT_KEYS",
- #endif /* MBEDTLS_SSL_EXPORT_KEYS */
- #if defined(MBEDTLS_SSL_SERVER_NAME_INDICATION)
- "MBEDTLS_SSL_SERVER_NAME_INDICATION",
- #endif /* MBEDTLS_SSL_SERVER_NAME_INDICATION */
- #if defined(MBEDTLS_SSL_TRUNCATED_HMAC)
- "MBEDTLS_SSL_TRUNCATED_HMAC",
- #endif /* MBEDTLS_SSL_TRUNCATED_HMAC */
- #if defined(MBEDTLS_THREADING_ALT)
- "MBEDTLS_THREADING_ALT",
- #endif /* MBEDTLS_THREADING_ALT */
- #if defined(MBEDTLS_THREADING_PTHREAD)
- "MBEDTLS_THREADING_PTHREAD",
- #endif /* MBEDTLS_THREADING_PTHREAD */
- #if defined(MBEDTLS_VERSION_FEATURES)
- "MBEDTLS_VERSION_FEATURES",
- #endif /* MBEDTLS_VERSION_FEATURES */
- #if defined(MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3)
- "MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3",
- #endif /* MBEDTLS_X509_ALLOW_EXTENSIONS_NON_V3 */
- #if defined(MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION)
- "MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION",
- #endif /* MBEDTLS_X509_ALLOW_UNSUPPORTED_CRITICAL_EXTENSION */
- #if defined(MBEDTLS_X509_CHECK_KEY_USAGE)
- "MBEDTLS_X509_CHECK_KEY_USAGE",
- #endif /* MBEDTLS_X509_CHECK_KEY_USAGE */
- #if defined(MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE)
- "MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE",
- #endif /* MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE */
- #if defined(MBEDTLS_X509_RSASSA_PSS_SUPPORT)
- "MBEDTLS_X509_RSASSA_PSS_SUPPORT",
- #endif /* MBEDTLS_X509_RSASSA_PSS_SUPPORT */
- #if defined(MBEDTLS_ZLIB_SUPPORT)
- "MBEDTLS_ZLIB_SUPPORT",
- #endif /* MBEDTLS_ZLIB_SUPPORT */
- #if defined(MBEDTLS_AESNI_C)
- "MBEDTLS_AESNI_C",
- #endif /* MBEDTLS_AESNI_C */
- #if defined(MBEDTLS_AES_C)
- "MBEDTLS_AES_C",
- #endif /* MBEDTLS_AES_C */
- #if defined(MBEDTLS_ARC4_C)
- "MBEDTLS_ARC4_C",
- #endif /* MBEDTLS_ARC4_C */
- #if defined(MBEDTLS_ASN1_PARSE_C)
- "MBEDTLS_ASN1_PARSE_C",
- #endif /* MBEDTLS_ASN1_PARSE_C */
- #if defined(MBEDTLS_ASN1_WRITE_C)
- "MBEDTLS_ASN1_WRITE_C",
- #endif /* MBEDTLS_ASN1_WRITE_C */
- #if defined(MBEDTLS_BASE64_C)
- "MBEDTLS_BASE64_C",
- #endif /* MBEDTLS_BASE64_C */
- #if defined(MBEDTLS_BIGNUM_C)
- "MBEDTLS_BIGNUM_C",
- #endif /* MBEDTLS_BIGNUM_C */
- #if defined(MBEDTLS_BLOWFISH_C)
- "MBEDTLS_BLOWFISH_C",
- #endif /* MBEDTLS_BLOWFISH_C */
- #if defined(MBEDTLS_CAMELLIA_C)
- "MBEDTLS_CAMELLIA_C",
- #endif /* MBEDTLS_CAMELLIA_C */
- #if defined(MBEDTLS_CCM_C)
- "MBEDTLS_CCM_C",
- #endif /* MBEDTLS_CCM_C */
- #if defined(MBEDTLS_CERTS_C)
- "MBEDTLS_CERTS_C",
- #endif /* MBEDTLS_CERTS_C */
- #if defined(MBEDTLS_CIPHER_C)
- "MBEDTLS_CIPHER_C",
- #endif /* MBEDTLS_CIPHER_C */
- #if defined(MBEDTLS_CMAC_C)
- "MBEDTLS_CMAC_C",
- #endif /* MBEDTLS_CMAC_C */
- #if defined(MBEDTLS_CTR_DRBG_C)
- "MBEDTLS_CTR_DRBG_C",
- #endif /* MBEDTLS_CTR_DRBG_C */
- #if defined(MBEDTLS_DEBUG_C)
- "MBEDTLS_DEBUG_C",
- #endif /* MBEDTLS_DEBUG_C */
- #if defined(MBEDTLS_DES_C)
- "MBEDTLS_DES_C",
- #endif /* MBEDTLS_DES_C */
- #if defined(MBEDTLS_DHM_C)
- "MBEDTLS_DHM_C",
- #endif /* MBEDTLS_DHM_C */
- #if defined(MBEDTLS_ECDH_C)
- "MBEDTLS_ECDH_C",
- #endif /* MBEDTLS_ECDH_C */
- #if defined(MBEDTLS_ECDSA_C)
- "MBEDTLS_ECDSA_C",
- #endif /* MBEDTLS_ECDSA_C */
- #if defined(MBEDTLS_ECJPAKE_C)
- "MBEDTLS_ECJPAKE_C",
- #endif /* MBEDTLS_ECJPAKE_C */
- #if defined(MBEDTLS_ECP_C)
- "MBEDTLS_ECP_C",
- #endif /* MBEDTLS_ECP_C */
- #if defined(MBEDTLS_ENTROPY_C)
- "MBEDTLS_ENTROPY_C",
- #endif /* MBEDTLS_ENTROPY_C */
- #if defined(MBEDTLS_ERROR_C)
- "MBEDTLS_ERROR_C",
- #endif /* MBEDTLS_ERROR_C */
- #if defined(MBEDTLS_GCM_C)
- "MBEDTLS_GCM_C",
- #endif /* MBEDTLS_GCM_C */
- #if defined(MBEDTLS_HAVEGE_C)
- "MBEDTLS_HAVEGE_C",
- #endif /* MBEDTLS_HAVEGE_C */
- #if defined(MBEDTLS_HMAC_DRBG_C)
- "MBEDTLS_HMAC_DRBG_C",
- #endif /* MBEDTLS_HMAC_DRBG_C */
- #if defined(MBEDTLS_MD_C)
- "MBEDTLS_MD_C",
- #endif /* MBEDTLS_MD_C */
- #if defined(MBEDTLS_MD2_C)
- "MBEDTLS_MD2_C",
- #endif /* MBEDTLS_MD2_C */
- #if defined(MBEDTLS_MD4_C)
- "MBEDTLS_MD4_C",
- #endif /* MBEDTLS_MD4_C */
- #if defined(MBEDTLS_MD5_C)
- "MBEDTLS_MD5_C",
- #endif /* MBEDTLS_MD5_C */
- #if defined(MBEDTLS_MEMORY_BUFFER_ALLOC_C)
- "MBEDTLS_MEMORY_BUFFER_ALLOC_C",
- #endif /* MBEDTLS_MEMORY_BUFFER_ALLOC_C */
- #if defined(MBEDTLS_NET_C)
- "MBEDTLS_NET_C",
- #endif /* MBEDTLS_NET_C */
- #if defined(MBEDTLS_OID_C)
- "MBEDTLS_OID_C",
- #endif /* MBEDTLS_OID_C */
- #if defined(MBEDTLS_PADLOCK_C)
- "MBEDTLS_PADLOCK_C",
- #endif /* MBEDTLS_PADLOCK_C */
- #if defined(MBEDTLS_PEM_PARSE_C)
- "MBEDTLS_PEM_PARSE_C",
- #endif /* MBEDTLS_PEM_PARSE_C */
- #if defined(MBEDTLS_PEM_WRITE_C)
- "MBEDTLS_PEM_WRITE_C",
- #endif /* MBEDTLS_PEM_WRITE_C */
- #if defined(MBEDTLS_PK_C)
- "MBEDTLS_PK_C",
- #endif /* MBEDTLS_PK_C */
- #if defined(MBEDTLS_PK_PARSE_C)
- "MBEDTLS_PK_PARSE_C",
- #endif /* MBEDTLS_PK_PARSE_C */
- #if defined(MBEDTLS_PK_WRITE_C)
- "MBEDTLS_PK_WRITE_C",
- #endif /* MBEDTLS_PK_WRITE_C */
- #if defined(MBEDTLS_PKCS5_C)
- "MBEDTLS_PKCS5_C",
- #endif /* MBEDTLS_PKCS5_C */
- #if defined(MBEDTLS_PKCS11_C)
- "MBEDTLS_PKCS11_C",
- #endif /* MBEDTLS_PKCS11_C */
- #if defined(MBEDTLS_PKCS12_C)
- "MBEDTLS_PKCS12_C",
- #endif /* MBEDTLS_PKCS12_C */
- #if defined(MBEDTLS_PLATFORM_C)
- "MBEDTLS_PLATFORM_C",
- #endif /* MBEDTLS_PLATFORM_C */
- #if defined(MBEDTLS_RIPEMD160_C)
- "MBEDTLS_RIPEMD160_C",
- #endif /* MBEDTLS_RIPEMD160_C */
- #if defined(MBEDTLS_RSA_C)
- "MBEDTLS_RSA_C",
- #endif /* MBEDTLS_RSA_C */
- #if defined(MBEDTLS_SHA1_C)
- "MBEDTLS_SHA1_C",
- #endif /* MBEDTLS_SHA1_C */
- #if defined(MBEDTLS_SHA256_C)
- "MBEDTLS_SHA256_C",
- #endif /* MBEDTLS_SHA256_C */
- #if defined(MBEDTLS_SHA512_C)
- "MBEDTLS_SHA512_C",
- #endif /* MBEDTLS_SHA512_C */
- #if defined(MBEDTLS_SSL_CACHE_C)
- "MBEDTLS_SSL_CACHE_C",
- #endif /* MBEDTLS_SSL_CACHE_C */
- #if defined(MBEDTLS_SSL_COOKIE_C)
- "MBEDTLS_SSL_COOKIE_C",
- #endif /* MBEDTLS_SSL_COOKIE_C */
- #if defined(MBEDTLS_SSL_TICKET_C)
- "MBEDTLS_SSL_TICKET_C",
- #endif /* MBEDTLS_SSL_TICKET_C */
- #if defined(MBEDTLS_SSL_CLI_C)
- "MBEDTLS_SSL_CLI_C",
- #endif /* MBEDTLS_SSL_CLI_C */
- #if defined(MBEDTLS_SSL_SRV_C)
- "MBEDTLS_SSL_SRV_C",
- #endif /* MBEDTLS_SSL_SRV_C */
- #if defined(MBEDTLS_SSL_TLS_C)
- "MBEDTLS_SSL_TLS_C",
- #endif /* MBEDTLS_SSL_TLS_C */
- #if defined(MBEDTLS_THREADING_C)
- "MBEDTLS_THREADING_C",
- #endif /* MBEDTLS_THREADING_C */
- #if defined(MBEDTLS_TIMING_C)
- "MBEDTLS_TIMING_C",
- #endif /* MBEDTLS_TIMING_C */
- #if defined(MBEDTLS_VERSION_C)
- "MBEDTLS_VERSION_C",
- #endif /* MBEDTLS_VERSION_C */
- #if defined(MBEDTLS_X509_USE_C)
- "MBEDTLS_X509_USE_C",
- #endif /* MBEDTLS_X509_USE_C */
- #if defined(MBEDTLS_X509_CRT_PARSE_C)
- "MBEDTLS_X509_CRT_PARSE_C",
- #endif /* MBEDTLS_X509_CRT_PARSE_C */
- #if defined(MBEDTLS_X509_CRL_PARSE_C)
- "MBEDTLS_X509_CRL_PARSE_C",
- #endif /* MBEDTLS_X509_CRL_PARSE_C */
- #if defined(MBEDTLS_X509_CSR_PARSE_C)
- "MBEDTLS_X509_CSR_PARSE_C",
- #endif /* MBEDTLS_X509_CSR_PARSE_C */
- #if defined(MBEDTLS_X509_CREATE_C)
- "MBEDTLS_X509_CREATE_C",
- #endif /* MBEDTLS_X509_CREATE_C */
- #if defined(MBEDTLS_X509_CRT_WRITE_C)
- "MBEDTLS_X509_CRT_WRITE_C",
- #endif /* MBEDTLS_X509_CRT_WRITE_C */
- #if defined(MBEDTLS_X509_CSR_WRITE_C)
- "MBEDTLS_X509_CSR_WRITE_C",
- #endif /* MBEDTLS_X509_CSR_WRITE_C */
- #if defined(MBEDTLS_XTEA_C)
- "MBEDTLS_XTEA_C",
- #endif /* MBEDTLS_XTEA_C */
- #endif /* MBEDTLS_VERSION_FEATURES */
- NULL
- };
- int mbedtls_version_check_feature( const char *feature )
- {
- const char **idx = features;
- if( *idx == NULL )
- return( -2 );
- if( feature == NULL )
- return( -1 );
- while( *idx != NULL )
- {
- if( !strcmp( *idx, feature ) )
- return( 0 );
- idx++;
- }
- return( -1 );
- }
- #endif /* MBEDTLS_VERSION_C */
|