2 * Copyright (c) 2020, The OpenThread Authors.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met:
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 * 3. Neither the name of the copyright holder nor the
13 * names of its contributors may be used to endorse or promote products
14 * derived from this software without specific prior written permission.
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26 * POSSIBILITY OF SUCH DAMAGE.
35 #include "em_device.h"
37 #include "sl_malloc.h"
40 * Enable FreeRTOS threading support
42 #define MBEDTLS_FREERTOS
43 #define MBEDTLS_THREADING_C
44 #define MBEDTLS_THREADING_ALT
46 #define SL_CATALOG_FREERTOS_KERNEL_PRESENT
49 * Enable H Crypto and Entropy modules
53 #define MBEDTLS_ECDH_C
54 #define MBEDTLS_ENTROPY_C
55 #define MBEDTLS_SHA256_C
56 #define MBEDTLS_CIPHER_MODE_CTR
57 #define MBEDTLS_TRNG_C
59 #if defined(MBEDTLS_ECP_ALT) && !defined(MBEDTLS_ECP_RESTARTABLE)
60 typedef void mbedtls_ecp_restart_ctx;
63 #define MBEDTLS_PLATFORM_SNPRINTF_MACRO snprintf
65 #define MBEDTLS_AES_ROM_TABLES
66 #define MBEDTLS_ASN1_PARSE_C
67 #define MBEDTLS_ASN1_WRITE_C
68 #define MBEDTLS_BASE64_C
69 #define MBEDTLS_BIGNUM_C
71 #define MBEDTLS_CIPHER_C
72 #define MBEDTLS_CIPHER_MODE_CBC
73 #define MBEDTLS_CIPHER_MODE_CFB
74 #define MBEDTLS_CMAC_C
75 #define MBEDTLS_CTR_DRBG_C
76 #define MBEDTLS_ECDH_LEGACY_CONTEXT
77 #define MBEDTLS_ECDSA_C
78 #define MBEDTLS_ECJPAKE_C
79 #define MBEDTLS_ECP_DP_SECP256R1_ENABLED
80 #define MBEDTLS_ECP_NIST_OPTIM
81 #define MBEDTLS_ENTROPY_FORCE_SHA256
82 #define MBEDTLS_ENTROPY_HARDWARE_ALT
83 #define MBEDTLS_ERROR_STRERROR_DUMMY
84 #define MBEDTLS_HAVE_ASM
85 #define MBEDTLS_HKDF_C
86 #define MBEDTLS_HMAC_DRBG_C
87 #define MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED
88 #define MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED
89 #define MBEDTLS_KEY_EXCHANGE_PSK_ENABLED
91 #define MBEDTLS_NO_PLATFORM_ENTROPY
93 #define MBEDTLS_PEM_PARSE_C
94 #define MBEDTLS_PEM_WRITE_C
96 #define MBEDTLS_PK_PARSE_C
97 #define MBEDTLS_PK_WRITE_C
98 #define MBEDTLS_PKCS5_C
99 #define MBEDTLS_PLATFORM_C
100 #define MBEDTLS_PLATFORM_MEMORY
101 #define MBEDTLS_PLATFORM_NO_STD_FUNCTIONS
102 #define MBEDTLS_PSA_CRYPTO_C
103 #define MBEDTLS_PSA_CRYPTO_CONFIG
104 #define MBEDTLS_PSA_CRYPTO_DRIVERS
105 #define MBEDTLS_PSA_CRYPTO_BUILTIN_KEYS
106 #define MBEDTLS_PSA_CRYPTO_STORAGE_C
107 #define MBEDTLS_SHA256_SMALLER
108 #define MBEDTLS_SHA512_C
109 #define MBEDTLS_SSL_CLI_C
110 #define MBEDTLS_SSL_COOKIE_C
111 #define MBEDTLS_SSL_DTLS_ANTI_REPLAY
112 #define MBEDTLS_SSL_DTLS_HELLO_VERIFY
113 #define MBEDTLS_SSL_EXPORT_KEYS
114 #define MBEDTLS_SSL_KEEP_PEER_CERTIFICATE
115 #define MBEDTLS_SSL_MAX_FRAGMENT_LENGTH
116 #define MBEDTLS_SSL_PROTO_TLS1_2
117 #define MBEDTLS_SSL_PROTO_DTLS
118 #define MBEDTLS_SSL_SRV_C
119 #define MBEDTLS_SSL_TLS_C
120 #define MBEDTLS_X509_CREATE_C
121 #define MBEDTLS_X509_CSR_WRITE_C
122 #define MBEDTLS_X509_CRL_PARSE_C
123 #define MBEDTLS_X509_CRT_PARSE_C
124 #define MBEDTLS_X509_CSR_PARSE_C
125 #define MBEDTLS_X509_USE_C
127 #define MBEDTLS_MPI_WINDOW_SIZE 1 /**< Maximum windows size used. */
128 #define MBEDTLS_MPI_MAX_SIZE 32 /**< Maximum number of bytes for usable MPIs. */
129 #define MBEDTLS_ECP_MAX_BITS 256 /**< Maximum bit size of groups */
130 #define MBEDTLS_ECP_WINDOW_SIZE 2 /**< Maximum window size used */
131 #define MBEDTLS_ECP_FIXED_POINT_OPTIM 0 /**< Enable fixed-point speed-up */
132 #define MBEDTLS_ENTROPY_MAX_SOURCES 2 /**< Maximum number of sources supported */
134 #define MBEDTLS_PLATFORM_STD_CALLOC sl_calloc /**< Default allocator to use, can be undefined */
135 #define MBEDTLS_PLATFORM_STD_FREE sl_free /**< Default free to use, can be undefined */
137 #if OPENTHREAD_CONFIG_COAP_SECURE_API_ENABLE
138 #define MBEDTLS_SSL_MAX_CONTENT_LEN 900 /**< Maxium fragment length in bytes */
140 #define MBEDTLS_SSL_MAX_CONTENT_LEN 768 /**< Maxium fragment length in bytes */
143 #define MBEDTLS_SSL_CIPHERSUITES MBEDTLS_TLS_ECJPAKE_WITH_AES_128_CCM_8
145 #include "config-device-acceleration.h"
146 #include "mbedtls/check_config.h"