23 #ifndef MBEDTLS_CHECK_CONFIG_H
24 #define MBEDTLS_CHECK_CONFIG_H
33 #error "mbed TLS requires a platform with 8-bit chars"
39 #if !defined(MBEDTLS_PLATFORM_C)
40 #error "MBEDTLS_PLATFORM_C is required on Windows"
45 #if !defined(MBEDTLS_PLATFORM_SNPRINTF_ALT) && \
46 !defined(MBEDTLS_PLATFORM_SNPRINTF_MACRO)
47 #define MBEDTLS_PLATFORM_SNPRINTF_ALT
50 #if !defined(MBEDTLS_PLATFORM_VSNPRINTF_ALT) && \
51 !defined(MBEDTLS_PLATFORM_VSNPRINTF_MACRO)
52 #define MBEDTLS_PLATFORM_VSNPRINTF_ALT
56 #if defined(TARGET_LIKE_MBED) && defined(MBEDTLS_NET_C)
57 #error "The NET module is not available for mbed OS - please use the network functions provided by Mbed OS"
60 #if defined(MBEDTLS_DEPRECATED_WARNING) && \
61 !defined(__GNUC__) && !defined(__clang__)
62 #error "MBEDTLS_DEPRECATED_WARNING only works with GCC and Clang"
65 #if defined(MBEDTLS_HAVE_TIME_DATE) && !defined(MBEDTLS_HAVE_TIME)
66 #error "MBEDTLS_HAVE_TIME_DATE without MBEDTLS_HAVE_TIME does not make sense"
69 #if defined(__aarch64__) && defined(__GNUC__)
71 #if defined(MBEDTLS_AESCE_C) && !defined(MBEDTLS_HAVE_ASM)
72 #error "MBEDTLS_AESCE_C defined, but not all prerequisites"
76 #if defined(MBEDTLS_CTR_DRBG_C) && !defined(MBEDTLS_AES_C)
77 #error "MBEDTLS_CTR_DRBG_C defined, but not all prerequisites"
80 #if defined(MBEDTLS_DHM_C) && !defined(MBEDTLS_BIGNUM_C)
81 #error "MBEDTLS_DHM_C defined, but not all prerequisites"
84 #if defined(MBEDTLS_CMAC_C) && \
85 ( !defined(MBEDTLS_CIPHER_C ) || ( !defined(MBEDTLS_AES_C) && !defined(MBEDTLS_DES_C) ) )
86 #error "MBEDTLS_CMAC_C defined, but not all prerequisites"
89 #if defined(MBEDTLS_NIST_KW_C) && \
90 ( !defined(MBEDTLS_AES_C) || !defined(MBEDTLS_CIPHER_C) )
91 #error "MBEDTLS_NIST_KW_C defined, but not all prerequisites"
94 #if defined(MBEDTLS_ECDH_C) && !defined(MBEDTLS_ECP_C)
95 #error "MBEDTLS_ECDH_C defined, but not all prerequisites"
98 #if defined(MBEDTLS_ECDSA_C) && \
99 ( !defined(MBEDTLS_ECP_C) || \
100 !( defined(MBEDTLS_ECP_DP_SECP192R1_ENABLED) || \
101 defined(MBEDTLS_ECP_DP_SECP224R1_ENABLED) || \
102 defined(MBEDTLS_ECP_DP_SECP256R1_ENABLED) || \
103 defined(MBEDTLS_ECP_DP_SECP384R1_ENABLED) || \
104 defined(MBEDTLS_ECP_DP_SECP521R1_ENABLED) || \
105 defined(MBEDTLS_ECP_DP_SECP192K1_ENABLED) || \
106 defined(MBEDTLS_ECP_DP_SECP224K1_ENABLED) || \
107 defined(MBEDTLS_ECP_DP_SECP256K1_ENABLED) || \
108 defined(MBEDTLS_ECP_DP_BP256R1_ENABLED) || \
109 defined(MBEDTLS_ECP_DP_BP384R1_ENABLED) || \
110 defined(MBEDTLS_ECP_DP_BP512R1_ENABLED) ) || \
111 !defined(MBEDTLS_ASN1_PARSE_C) || \
112 !defined(MBEDTLS_ASN1_WRITE_C) )
113 #error "MBEDTLS_ECDSA_C defined, but not all prerequisites"
116 #if defined(MBEDTLS_ECJPAKE_C) && \
117 ( !defined(MBEDTLS_ECP_C) || \
118 !( defined(MBEDTLS_MD_C) || defined(MBEDTLS_PSA_CRYPTO_C) ) )
119 #error "MBEDTLS_ECJPAKE_C defined, but not all prerequisites"
122 #if defined(MBEDTLS_ECP_RESTARTABLE) && \
123 ( defined(MBEDTLS_ECDH_COMPUTE_SHARED_ALT) || \
124 defined(MBEDTLS_ECDH_GEN_PUBLIC_ALT) || \
125 defined(MBEDTLS_ECDSA_SIGN_ALT) || \
126 defined(MBEDTLS_ECDSA_VERIFY_ALT) || \
127 defined(MBEDTLS_ECDSA_GENKEY_ALT) || \
128 defined(MBEDTLS_ECP_INTERNAL_ALT) || \
129 defined(MBEDTLS_ECP_ALT) )
130 #error "MBEDTLS_ECP_RESTARTABLE defined, but it cannot coexist with an alternative ECP implementation"
133 #if defined(MBEDTLS_ECP_RESTARTABLE) && \
134 !defined(MBEDTLS_ECP_C)
135 #error "MBEDTLS_ECP_RESTARTABLE defined, but not all prerequisites"
138 #if defined(MBEDTLS_ECDSA_DETERMINISTIC) && !defined(MBEDTLS_HMAC_DRBG_C)
139 #error "MBEDTLS_ECDSA_DETERMINISTIC defined, but not all prerequisites"
142 #if defined(MBEDTLS_ECP_C) && ( !defined(MBEDTLS_BIGNUM_C) || ( \
143 !defined(MBEDTLS_ECP_DP_SECP192R1_ENABLED) && \
144 !defined(MBEDTLS_ECP_DP_SECP224R1_ENABLED) && \
145 !defined(MBEDTLS_ECP_DP_SECP256R1_ENABLED) && \
146 !defined(MBEDTLS_ECP_DP_SECP384R1_ENABLED) && \
147 !defined(MBEDTLS_ECP_DP_SECP521R1_ENABLED) && \
148 !defined(MBEDTLS_ECP_DP_BP256R1_ENABLED) && \
149 !defined(MBEDTLS_ECP_DP_BP384R1_ENABLED) && \
150 !defined(MBEDTLS_ECP_DP_BP512R1_ENABLED) && \
151 !defined(MBEDTLS_ECP_DP_SECP192K1_ENABLED) && \
152 !defined(MBEDTLS_ECP_DP_SECP224K1_ENABLED) && \
153 !defined(MBEDTLS_ECP_DP_SECP256K1_ENABLED) && \
154 !defined(MBEDTLS_ECP_DP_CURVE25519_ENABLED) && \
155 !defined(MBEDTLS_ECP_DP_CURVE448_ENABLED) ) )
156 #error "MBEDTLS_ECP_C defined, but not all prerequisites"
159 #if defined(MBEDTLS_PK_PARSE_C) && !defined(MBEDTLS_ASN1_PARSE_C)
160 #error "MBEDTLS_PK_PARSE_C defined, but not all prerequisites"
163 #if defined(MBEDTLS_PKCS12_C) && !defined(MBEDTLS_CIPHER_C)
164 #error "MBEDTLS_PKCS12_C defined, but not all prerequisites"
167 #if defined(MBEDTLS_PKCS5_C) && \
168 ( !( defined(MBEDTLS_MD_C) || defined(MBEDTLS_PSA_CRYPTO_C) ) || \
169 !defined(MBEDTLS_CIPHER_C) )
170 #error "MBEDTLS_PKCS5_C defined, but not all prerequisites"
173 #if defined(MBEDTLS_PKCS12_C) && \
174 !( defined(MBEDTLS_MD_C) || defined(MBEDTLS_PSA_CRYPTO_C) )
175 #error "MBEDTLS_PKCS12_C defined, but not all prerequisites"
178 #if defined(MBEDTLS_PKCS1_V21) && \
179 !( defined(MBEDTLS_MD_C) || defined(MBEDTLS_PSA_CRYPTO_C) )
180 #error "MBEDTLS_PKCS1_V21 defined, but not all prerequisites"
183 #if defined(MBEDTLS_ENTROPY_C) && (!defined(MBEDTLS_SHA512_C) && \
184 !defined(MBEDTLS_SHA256_C))
185 #error "MBEDTLS_ENTROPY_C defined, but not all prerequisites"
187 #if defined(MBEDTLS_ENTROPY_C) && defined(MBEDTLS_SHA512_C) && \
188 defined(MBEDTLS_CTR_DRBG_ENTROPY_LEN) && (MBEDTLS_CTR_DRBG_ENTROPY_LEN > 64)
189 #error "MBEDTLS_CTR_DRBG_ENTROPY_LEN value too high"
191 #if defined(MBEDTLS_ENTROPY_C) && \
192 ( !defined(MBEDTLS_SHA512_C) || defined(MBEDTLS_ENTROPY_FORCE_SHA256) ) \
193 && defined(MBEDTLS_CTR_DRBG_ENTROPY_LEN) && (MBEDTLS_CTR_DRBG_ENTROPY_LEN > 32)
194 #error "MBEDTLS_CTR_DRBG_ENTROPY_LEN value too high"
196 #if defined(MBEDTLS_ENTROPY_C) && \
197 defined(MBEDTLS_ENTROPY_FORCE_SHA256) && !defined(MBEDTLS_SHA256_C)
198 #error "MBEDTLS_ENTROPY_FORCE_SHA256 defined, but not all prerequisites"
201 #if defined(__has_feature)
202 #if __has_feature(memory_sanitizer)
203 #define MBEDTLS_HAS_MEMSAN
206 #if defined(MBEDTLS_TEST_CONSTANT_FLOW_MEMSAN) && !defined(MBEDTLS_HAS_MEMSAN)
207 #error "MBEDTLS_TEST_CONSTANT_FLOW_MEMSAN requires building with MemorySanitizer"
209 #undef MBEDTLS_HAS_MEMSAN
211 #if defined(MBEDTLS_CCM_C) && ( \
212 !defined(MBEDTLS_AES_C) && !defined(MBEDTLS_CAMELLIA_C) && !defined(MBEDTLS_ARIA_C) )
213 #error "MBEDTLS_CCM_C defined, but not all prerequisites"
216 #if defined(MBEDTLS_CCM_C) && !defined(MBEDTLS_CIPHER_C)
217 #error "MBEDTLS_CCM_C defined, but not all prerequisites"
220 #if defined(MBEDTLS_GCM_C) && ( \
221 !defined(MBEDTLS_AES_C) && !defined(MBEDTLS_CAMELLIA_C) && !defined(MBEDTLS_ARIA_C) )
222 #error "MBEDTLS_GCM_C defined, but not all prerequisites"
225 #if defined(MBEDTLS_GCM_C) && !defined(MBEDTLS_CIPHER_C)
226 #error "MBEDTLS_GCM_C defined, but not all prerequisites"
229 #if defined(MBEDTLS_CHACHAPOLY_C) && !defined(MBEDTLS_CHACHA20_C)
230 #error "MBEDTLS_CHACHAPOLY_C defined, but not all prerequisites"
233 #if defined(MBEDTLS_CHACHAPOLY_C) && !defined(MBEDTLS_POLY1305_C)
234 #error "MBEDTLS_CHACHAPOLY_C defined, but not all prerequisites"
237 #if defined(MBEDTLS_ECP_RANDOMIZE_JAC_ALT) && !defined(MBEDTLS_ECP_INTERNAL_ALT)
238 #error "MBEDTLS_ECP_RANDOMIZE_JAC_ALT defined, but not all prerequisites"
241 #if defined(MBEDTLS_ECP_ADD_MIXED_ALT) && !defined(MBEDTLS_ECP_INTERNAL_ALT)
242 #error "MBEDTLS_ECP_ADD_MIXED_ALT defined, but not all prerequisites"
245 #if defined(MBEDTLS_ECP_DOUBLE_JAC_ALT) && !defined(MBEDTLS_ECP_INTERNAL_ALT)
246 #error "MBEDTLS_ECP_DOUBLE_JAC_ALT defined, but not all prerequisites"
249 #if defined(MBEDTLS_ECP_NORMALIZE_JAC_MANY_ALT) && !defined(MBEDTLS_ECP_INTERNAL_ALT)
250 #error "MBEDTLS_ECP_NORMALIZE_JAC_MANY_ALT defined, but not all prerequisites"
253 #if defined(MBEDTLS_ECP_NORMALIZE_JAC_ALT) && !defined(MBEDTLS_ECP_INTERNAL_ALT)
254 #error "MBEDTLS_ECP_NORMALIZE_JAC_ALT defined, but not all prerequisites"
257 #if defined(MBEDTLS_ECP_DOUBLE_ADD_MXZ_ALT) && !defined(MBEDTLS_ECP_INTERNAL_ALT)
258 #error "MBEDTLS_ECP_DOUBLE_ADD_MXZ_ALT defined, but not all prerequisites"
261 #if defined(MBEDTLS_ECP_RANDOMIZE_MXZ_ALT) && !defined(MBEDTLS_ECP_INTERNAL_ALT)
262 #error "MBEDTLS_ECP_RANDOMIZE_MXZ_ALT defined, but not all prerequisites"
265 #if defined(MBEDTLS_ECP_NORMALIZE_MXZ_ALT) && !defined(MBEDTLS_ECP_INTERNAL_ALT)
266 #error "MBEDTLS_ECP_NORMALIZE_MXZ_ALT defined, but not all prerequisites"
269 #if defined(MBEDTLS_ECP_NO_FALLBACK) && !defined(MBEDTLS_ECP_INTERNAL_ALT)
270 #error "MBEDTLS_ECP_NO_FALLBACK defined, but no alternative implementation enabled"
273 #if defined(MBEDTLS_HKDF_C) && !defined(MBEDTLS_MD_C)
274 #error "MBEDTLS_HKDF_C defined, but not all prerequisites"
277 #if defined(MBEDTLS_HMAC_DRBG_C) && !defined(MBEDTLS_MD_C)
278 #error "MBEDTLS_HMAC_DRBG_C defined, but not all prerequisites"
282 #if defined(MBEDTLS_USE_PSA_CRYPTO)
283 #if defined(PSA_HAVE_FULL_ECDSA)
284 #define MBEDTLS_PK_HAVE_ECDSA
287 #if defined(MBEDTLS_ECDSA_C)
288 #define MBEDTLS_PK_HAVE_ECDSA
293 #if defined(MBEDTLS_USE_PSA_CRYPTO)
294 #if defined(PSA_HAVE_FULL_JPAKE)
295 #define MBEDTLS_PK_HAVE_JPAKE
298 #if defined(MBEDTLS_ECJPAKE_C)
299 #define MBEDTLS_PK_HAVE_JPAKE
303 #if defined(MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED) && \
304 ( !defined(MBEDTLS_ECDH_C) || \
305 !defined(MBEDTLS_PK_HAVE_ECDSA) || \
306 !defined(MBEDTLS_X509_CRT_PARSE_C) )
307 #error "MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED defined, but not all prerequisites"
310 #if defined(MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED) && \
311 ( !defined(MBEDTLS_ECDH_C) || !defined(MBEDTLS_RSA_C) || \
312 !defined(MBEDTLS_X509_CRT_PARSE_C) )
313 #error "MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED defined, but not all prerequisites"
316 #if defined(MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED) && !defined(MBEDTLS_DHM_C)
317 #error "MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED defined, but not all prerequisites"
320 #if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED) && \
321 !defined(MBEDTLS_ECDH_C)
322 #error "MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED defined, but not all prerequisites"
325 #if defined(MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED) && \
326 ( !defined(MBEDTLS_DHM_C) || !defined(MBEDTLS_RSA_C) || \
327 !defined(MBEDTLS_X509_CRT_PARSE_C) || !defined(MBEDTLS_PKCS1_V15) )
328 #error "MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED defined, but not all prerequisites"
331 #if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED) && \
332 ( !defined(MBEDTLS_ECDH_C) || !defined(MBEDTLS_RSA_C) || \
333 !defined(MBEDTLS_X509_CRT_PARSE_C) || !defined(MBEDTLS_PKCS1_V15) )
334 #error "MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED defined, but not all prerequisites"
337 #if defined(MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED) && \
338 ( !defined(MBEDTLS_ECDH_C) || \
339 !defined(MBEDTLS_PK_HAVE_ECDSA) || \
340 !defined(MBEDTLS_X509_CRT_PARSE_C) )
341 #error "MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED defined, but not all prerequisites"
344 #if defined(MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED) && \
345 ( !defined(MBEDTLS_RSA_C) || !defined(MBEDTLS_X509_CRT_PARSE_C) || \
346 !defined(MBEDTLS_PKCS1_V15) )
347 #error "MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED defined, but not all prerequisites"
350 #if defined(MBEDTLS_KEY_EXCHANGE_RSA_ENABLED) && \
351 ( !defined(MBEDTLS_RSA_C) || !defined(MBEDTLS_X509_CRT_PARSE_C) || \
352 !defined(MBEDTLS_PKCS1_V15) )
353 #error "MBEDTLS_KEY_EXCHANGE_RSA_ENABLED defined, but not all prerequisites"
356 #if defined(MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED) && \
357 ( !defined(MBEDTLS_PK_HAVE_JPAKE) || \
358 !defined(MBEDTLS_ECP_DP_SECP256R1_ENABLED) )
359 #error "MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED defined, but not all prerequisites"
365 #if defined(MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED) && \
366 !( defined(MBEDTLS_MD_C) && defined(MBEDTLS_SHA256_C) ) && \
367 !( !defined(MBEDTLS_MD_C) && defined(PSA_WANT_ALG_SHA_256) )
368 #error "MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED defined, but not all prerequisites"
371 #if defined(MBEDTLS_KEY_EXCHANGE_WITH_CERT_ENABLED) && \
372 !defined(MBEDTLS_SSL_KEEP_PEER_CERTIFICATE) && \
373 ( !defined(MBEDTLS_SHA256_C) && \
374 !defined(MBEDTLS_SHA512_C) && \
375 !defined(MBEDTLS_SHA1_C) )
376 #error "!MBEDTLS_SSL_KEEP_PEER_CERTIFICATE requires MBEDTLS_SHA512_C, MBEDTLS_SHA256_C or MBEDTLS_SHA1_C"
379 #if defined(MBEDTLS_MD_C) && !( \
380 defined(MBEDTLS_MD5_C) || \
381 defined(MBEDTLS_RIPEMD160_C) || \
382 defined(MBEDTLS_SHA1_C) || \
383 defined(MBEDTLS_SHA224_C) || \
384 defined(MBEDTLS_SHA256_C) || \
385 defined(MBEDTLS_SHA384_C) || \
386 defined(MBEDTLS_SHA512_C) )
387 #error "MBEDTLS_MD_C defined, but not all prerequisites"
390 #if defined(MBEDTLS_LMS_C) && \
391 ! ( defined(MBEDTLS_PSA_CRYPTO_C) && defined(PSA_WANT_ALG_SHA_256) )
392 #error "MBEDTLS_LMS_C requires MBEDTLS_PSA_CRYPTO_C and PSA_WANT_ALG_SHA_256"
395 #if defined(MBEDTLS_LMS_PRIVATE) && \
396 ( !defined(MBEDTLS_LMS_C) )
397 #error "MBEDTLS_LMS_PRIVATE requires MBEDTLS_LMS_C"
400 #if defined(MBEDTLS_MEMORY_BUFFER_ALLOC_C) && \
401 ( !defined(MBEDTLS_PLATFORM_C) || !defined(MBEDTLS_PLATFORM_MEMORY) )
402 #error "MBEDTLS_MEMORY_BUFFER_ALLOC_C defined, but not all prerequisites"
405 #if defined(MBEDTLS_MEMORY_BACKTRACE) && !defined(MBEDTLS_MEMORY_BUFFER_ALLOC_C)
406 #error "MBEDTLS_MEMORY_BACKTRACE defined, but not all prerequisites"
409 #if defined(MBEDTLS_MEMORY_DEBUG) && !defined(MBEDTLS_MEMORY_BUFFER_ALLOC_C)
410 #error "MBEDTLS_MEMORY_DEBUG defined, but not all prerequisites"
413 #if defined(MBEDTLS_PADLOCK_C) && !defined(MBEDTLS_HAVE_ASM)
414 #error "MBEDTLS_PADLOCK_C defined, but not all prerequisites"
417 #if defined(MBEDTLS_PEM_PARSE_C) && !defined(MBEDTLS_BASE64_C)
418 #error "MBEDTLS_PEM_PARSE_C defined, but not all prerequisites"
421 #if defined(MBEDTLS_PEM_WRITE_C) && !defined(MBEDTLS_BASE64_C)
422 #error "MBEDTLS_PEM_WRITE_C defined, but not all prerequisites"
425 #if defined(MBEDTLS_PK_C) && \
426 !defined(MBEDTLS_RSA_C) && !defined(MBEDTLS_ECP_C)
427 #error "MBEDTLS_PK_C defined, but not all prerequisites"
430 #if defined(MBEDTLS_PK_PARSE_C) && !defined(MBEDTLS_PK_C)
431 #error "MBEDTLS_PK_PARSE_C defined, but not all prerequisites"
434 #if defined(MBEDTLS_PK_WRITE_C) && !defined(MBEDTLS_PK_C)
435 #error "MBEDTLS_PK_WRITE_C defined, but not all prerequisites"
438 #if defined(MBEDTLS_PLATFORM_EXIT_ALT) && !defined(MBEDTLS_PLATFORM_C)
439 #error "MBEDTLS_PLATFORM_EXIT_ALT defined, but not all prerequisites"
442 #if defined(MBEDTLS_PLATFORM_EXIT_MACRO) && !defined(MBEDTLS_PLATFORM_C)
443 #error "MBEDTLS_PLATFORM_EXIT_MACRO defined, but not all prerequisites"
446 #if defined(MBEDTLS_PLATFORM_EXIT_MACRO) &&\
447 ( defined(MBEDTLS_PLATFORM_STD_EXIT) ||\
448 defined(MBEDTLS_PLATFORM_EXIT_ALT) )
449 #error "MBEDTLS_PLATFORM_EXIT_MACRO and MBEDTLS_PLATFORM_STD_EXIT/MBEDTLS_PLATFORM_EXIT_ALT cannot be defined simultaneously"
452 #if defined(MBEDTLS_PLATFORM_SETBUF_ALT) && !defined(MBEDTLS_PLATFORM_C)
453 #error "MBEDTLS_PLATFORM_SETBUF_ALT defined, but not all prerequisites"
456 #if defined(MBEDTLS_PLATFORM_SETBUF_MACRO) && !defined(MBEDTLS_PLATFORM_C)
457 #error "MBEDTLS_PLATFORM_SETBUF_MACRO defined, but not all prerequisites"
460 #if defined(MBEDTLS_PLATFORM_SETBUF_MACRO) &&\
461 ( defined(MBEDTLS_PLATFORM_STD_SETBUF) ||\
462 defined(MBEDTLS_PLATFORM_SETBUF_ALT) )
463 #error "MBEDTLS_PLATFORM_SETBUF_MACRO and MBEDTLS_PLATFORM_STD_SETBUF/MBEDTLS_PLATFORM_SETBUF_ALT cannot be defined simultaneously"
466 #if defined(MBEDTLS_PLATFORM_TIME_ALT) &&\
467 ( !defined(MBEDTLS_PLATFORM_C) ||\
468 !defined(MBEDTLS_HAVE_TIME) )
469 #error "MBEDTLS_PLATFORM_TIME_ALT defined, but not all prerequisites"
472 #if defined(MBEDTLS_PLATFORM_TIME_MACRO) &&\
473 ( !defined(MBEDTLS_PLATFORM_C) ||\
474 !defined(MBEDTLS_HAVE_TIME) )
475 #error "MBEDTLS_PLATFORM_TIME_MACRO defined, but not all prerequisites"
478 #if defined(MBEDTLS_PLATFORM_TIME_TYPE_MACRO) &&\
479 ( !defined(MBEDTLS_PLATFORM_C) ||\
480 !defined(MBEDTLS_HAVE_TIME) )
481 #error "MBEDTLS_PLATFORM_TIME_TYPE_MACRO defined, but not all prerequisites"
484 #if defined(MBEDTLS_PLATFORM_TIME_MACRO) &&\
485 ( defined(MBEDTLS_PLATFORM_STD_TIME) ||\
486 defined(MBEDTLS_PLATFORM_TIME_ALT) )
487 #error "MBEDTLS_PLATFORM_TIME_MACRO and MBEDTLS_PLATFORM_STD_TIME/MBEDTLS_PLATFORM_TIME_ALT cannot be defined simultaneously"
490 #if defined(MBEDTLS_PLATFORM_TIME_TYPE_MACRO) &&\
491 ( defined(MBEDTLS_PLATFORM_STD_TIME) ||\
492 defined(MBEDTLS_PLATFORM_TIME_ALT) )
493 #error "MBEDTLS_PLATFORM_TIME_TYPE_MACRO and MBEDTLS_PLATFORM_STD_TIME/MBEDTLS_PLATFORM_TIME_ALT cannot be defined simultaneously"
496 #if defined(MBEDTLS_PLATFORM_FPRINTF_ALT) && !defined(MBEDTLS_PLATFORM_C)
497 #error "MBEDTLS_PLATFORM_FPRINTF_ALT defined, but not all prerequisites"
500 #if defined(MBEDTLS_PLATFORM_FPRINTF_MACRO) && !defined(MBEDTLS_PLATFORM_C)
501 #error "MBEDTLS_PLATFORM_FPRINTF_MACRO defined, but not all prerequisites"
504 #if defined(MBEDTLS_PLATFORM_FPRINTF_MACRO) &&\
505 ( defined(MBEDTLS_PLATFORM_STD_FPRINTF) ||\
506 defined(MBEDTLS_PLATFORM_FPRINTF_ALT) )
507 #error "MBEDTLS_PLATFORM_FPRINTF_MACRO and MBEDTLS_PLATFORM_STD_FPRINTF/MBEDTLS_PLATFORM_FPRINTF_ALT cannot be defined simultaneously"
510 #if defined(MBEDTLS_PLATFORM_FREE_MACRO) &&\
511 ( !defined(MBEDTLS_PLATFORM_C) || !defined(MBEDTLS_PLATFORM_MEMORY) )
512 #error "MBEDTLS_PLATFORM_FREE_MACRO defined, but not all prerequisites"
515 #if defined(MBEDTLS_PLATFORM_FREE_MACRO) &&\
516 defined(MBEDTLS_PLATFORM_STD_FREE)
517 #error "MBEDTLS_PLATFORM_FREE_MACRO and MBEDTLS_PLATFORM_STD_FREE cannot be defined simultaneously"
520 #if defined(MBEDTLS_PLATFORM_FREE_MACRO) && !defined(MBEDTLS_PLATFORM_CALLOC_MACRO)
521 #error "MBEDTLS_PLATFORM_CALLOC_MACRO must be defined if MBEDTLS_PLATFORM_FREE_MACRO is"
524 #if defined(MBEDTLS_PLATFORM_CALLOC_MACRO) &&\
525 ( !defined(MBEDTLS_PLATFORM_C) || !defined(MBEDTLS_PLATFORM_MEMORY) )
526 #error "MBEDTLS_PLATFORM_CALLOC_MACRO defined, but not all prerequisites"
529 #if defined(MBEDTLS_PLATFORM_CALLOC_MACRO) &&\
530 defined(MBEDTLS_PLATFORM_STD_CALLOC)
531 #error "MBEDTLS_PLATFORM_CALLOC_MACRO and MBEDTLS_PLATFORM_STD_CALLOC cannot be defined simultaneously"
534 #if defined(MBEDTLS_PLATFORM_CALLOC_MACRO) && !defined(MBEDTLS_PLATFORM_FREE_MACRO)
535 #error "MBEDTLS_PLATFORM_FREE_MACRO must be defined if MBEDTLS_PLATFORM_CALLOC_MACRO is"
538 #if defined(MBEDTLS_PLATFORM_MEMORY) && !defined(MBEDTLS_PLATFORM_C)
539 #error "MBEDTLS_PLATFORM_MEMORY defined, but not all prerequisites"
542 #if defined(MBEDTLS_PLATFORM_PRINTF_ALT) && !defined(MBEDTLS_PLATFORM_C)
543 #error "MBEDTLS_PLATFORM_PRINTF_ALT defined, but not all prerequisites"
546 #if defined(MBEDTLS_PLATFORM_PRINTF_MACRO) && !defined(MBEDTLS_PLATFORM_C)
547 #error "MBEDTLS_PLATFORM_PRINTF_MACRO defined, but not all prerequisites"
550 #if defined(MBEDTLS_PLATFORM_PRINTF_MACRO) &&\
551 ( defined(MBEDTLS_PLATFORM_STD_PRINTF) ||\
552 defined(MBEDTLS_PLATFORM_PRINTF_ALT) )
553 #error "MBEDTLS_PLATFORM_PRINTF_MACRO and MBEDTLS_PLATFORM_STD_PRINTF/MBEDTLS_PLATFORM_PRINTF_ALT cannot be defined simultaneously"
556 #if defined(MBEDTLS_PLATFORM_SNPRINTF_ALT) && !defined(MBEDTLS_PLATFORM_C)
557 #error "MBEDTLS_PLATFORM_SNPRINTF_ALT defined, but not all prerequisites"
560 #if defined(MBEDTLS_PLATFORM_SNPRINTF_MACRO) && !defined(MBEDTLS_PLATFORM_C)
561 #error "MBEDTLS_PLATFORM_SNPRINTF_MACRO defined, but not all prerequisites"
564 #if defined(MBEDTLS_PLATFORM_SNPRINTF_MACRO) &&\
565 ( defined(MBEDTLS_PLATFORM_STD_SNPRINTF) ||\
566 defined(MBEDTLS_PLATFORM_SNPRINTF_ALT) )
567 #error "MBEDTLS_PLATFORM_SNPRINTF_MACRO and MBEDTLS_PLATFORM_STD_SNPRINTF/MBEDTLS_PLATFORM_SNPRINTF_ALT cannot be defined simultaneously"
570 #if defined(MBEDTLS_PLATFORM_VSNPRINTF_ALT) && !defined(MBEDTLS_PLATFORM_C)
571 #error "MBEDTLS_PLATFORM_VSNPRINTF_ALT defined, but not all prerequisites"
574 #if defined(MBEDTLS_PLATFORM_VSNPRINTF_MACRO) && !defined(MBEDTLS_PLATFORM_C)
575 #error "MBEDTLS_PLATFORM_VSNPRINTF_MACRO defined, but not all prerequisites"
578 #if defined(MBEDTLS_PLATFORM_VSNPRINTF_MACRO) &&\
579 ( defined(MBEDTLS_PLATFORM_STD_VSNPRINTF) ||\
580 defined(MBEDTLS_PLATFORM_VSNPRINTF_ALT) )
581 #error "MBEDTLS_PLATFORM_VSNPRINTF_MACRO and MBEDTLS_PLATFORM_STD_VSNPRINTF/MBEDTLS_PLATFORM_VSNPRINTF_ALT cannot be defined simultaneously"
584 #if defined(MBEDTLS_PLATFORM_STD_MEM_HDR) &&\
585 !defined(MBEDTLS_PLATFORM_NO_STD_FUNCTIONS)
586 #error "MBEDTLS_PLATFORM_STD_MEM_HDR defined, but not all prerequisites"
589 #if defined(MBEDTLS_PLATFORM_STD_CALLOC) && !defined(MBEDTLS_PLATFORM_MEMORY)
590 #error "MBEDTLS_PLATFORM_STD_CALLOC defined, but not all prerequisites"
593 #if defined(MBEDTLS_PLATFORM_STD_FREE) && !defined(MBEDTLS_PLATFORM_MEMORY)
594 #error "MBEDTLS_PLATFORM_STD_FREE defined, but not all prerequisites"
597 #if defined(MBEDTLS_PLATFORM_STD_EXIT) &&\
598 !defined(MBEDTLS_PLATFORM_EXIT_ALT)
599 #error "MBEDTLS_PLATFORM_STD_EXIT defined, but not all prerequisites"
602 #if defined(MBEDTLS_PLATFORM_STD_TIME) &&\
603 ( !defined(MBEDTLS_PLATFORM_TIME_ALT) ||\
604 !defined(MBEDTLS_HAVE_TIME) )
605 #error "MBEDTLS_PLATFORM_STD_TIME defined, but not all prerequisites"
608 #if defined(MBEDTLS_PLATFORM_STD_FPRINTF) &&\
609 !defined(MBEDTLS_PLATFORM_FPRINTF_ALT)
610 #error "MBEDTLS_PLATFORM_STD_FPRINTF defined, but not all prerequisites"
613 #if defined(MBEDTLS_PLATFORM_STD_PRINTF) &&\
614 !defined(MBEDTLS_PLATFORM_PRINTF_ALT)
615 #error "MBEDTLS_PLATFORM_STD_PRINTF defined, but not all prerequisites"
618 #if defined(MBEDTLS_PLATFORM_STD_SNPRINTF) &&\
619 !defined(MBEDTLS_PLATFORM_SNPRINTF_ALT)
620 #error "MBEDTLS_PLATFORM_STD_SNPRINTF defined, but not all prerequisites"
623 #if defined(MBEDTLS_ENTROPY_NV_SEED) &&\
624 ( !defined(MBEDTLS_PLATFORM_C) || !defined(MBEDTLS_ENTROPY_C) )
625 #error "MBEDTLS_ENTROPY_NV_SEED defined, but not all prerequisites"
628 #if defined(MBEDTLS_PLATFORM_NV_SEED_ALT) &&\
629 !defined(MBEDTLS_ENTROPY_NV_SEED)
630 #error "MBEDTLS_PLATFORM_NV_SEED_ALT defined, but not all prerequisites"
633 #if defined(MBEDTLS_PLATFORM_STD_NV_SEED_READ) &&\
634 !defined(MBEDTLS_PLATFORM_NV_SEED_ALT)
635 #error "MBEDTLS_PLATFORM_STD_NV_SEED_READ defined, but not all prerequisites"
638 #if defined(MBEDTLS_PLATFORM_STD_NV_SEED_WRITE) &&\
639 !defined(MBEDTLS_PLATFORM_NV_SEED_ALT)
640 #error "MBEDTLS_PLATFORM_STD_NV_SEED_WRITE defined, but not all prerequisites"
643 #if defined(MBEDTLS_PLATFORM_NV_SEED_READ_MACRO) &&\
644 ( defined(MBEDTLS_PLATFORM_STD_NV_SEED_READ) ||\
645 defined(MBEDTLS_PLATFORM_NV_SEED_ALT) )
646 #error "MBEDTLS_PLATFORM_NV_SEED_READ_MACRO and MBEDTLS_PLATFORM_STD_NV_SEED_READ cannot be defined simultaneously"
649 #if defined(MBEDTLS_PLATFORM_NV_SEED_WRITE_MACRO) &&\
650 ( defined(MBEDTLS_PLATFORM_STD_NV_SEED_WRITE) ||\
651 defined(MBEDTLS_PLATFORM_NV_SEED_ALT) )
652 #error "MBEDTLS_PLATFORM_NV_SEED_WRITE_MACRO and MBEDTLS_PLATFORM_STD_NV_SEED_WRITE cannot be defined simultaneously"
655 #if defined(MBEDTLS_PSA_CRYPTO_C) && \
656 !( ( ( defined(MBEDTLS_CTR_DRBG_C) || defined(MBEDTLS_HMAC_DRBG_C) ) && \
657 defined(MBEDTLS_ENTROPY_C) ) || \
658 defined(MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG) )
659 #error "MBEDTLS_PSA_CRYPTO_C defined, but not all prerequisites (missing RNG)"
662 #if defined(MBEDTLS_PSA_CRYPTO_C) && !defined(MBEDTLS_CIPHER_C )
663 #error "MBEDTLS_PSA_CRYPTO_C defined, but not all prerequisites"
666 #if defined(MBEDTLS_PSA_CRYPTO_SPM) && !defined(MBEDTLS_PSA_CRYPTO_C)
667 #error "MBEDTLS_PSA_CRYPTO_SPM defined, but not all prerequisites"
670 #if defined(MBEDTLS_PSA_CRYPTO_SE_C) && \
671 ! ( defined(MBEDTLS_PSA_CRYPTO_C) && \
672 defined(MBEDTLS_PSA_CRYPTO_STORAGE_C) )
673 #error "MBEDTLS_PSA_CRYPTO_SE_C defined, but not all prerequisites"
676 #if defined(MBEDTLS_PSA_CRYPTO_SE_C)
677 #if defined(MBEDTLS_DEPRECATED_REMOVED)
678 #error "MBEDTLS_PSA_CRYPTO_SE_C is deprecated and will be removed in a future version of Mbed TLS"
679 #elif defined(MBEDTLS_DEPRECATED_WARNING)
680 #warning "MBEDTLS_PSA_CRYPTO_SE_C is deprecated and will be removed in a future version of Mbed TLS"
684 #if defined(MBEDTLS_PSA_CRYPTO_STORAGE_C) && \
685 ! defined(MBEDTLS_PSA_CRYPTO_C)
686 #error "MBEDTLS_PSA_CRYPTO_STORAGE_C defined, but not all prerequisites"
689 #if defined(MBEDTLS_PSA_INJECT_ENTROPY) && \
690 !( defined(MBEDTLS_PSA_CRYPTO_STORAGE_C) && \
691 defined(MBEDTLS_ENTROPY_NV_SEED) )
692 #error "MBEDTLS_PSA_INJECT_ENTROPY defined, but not all prerequisites"
695 #if defined(MBEDTLS_PSA_INJECT_ENTROPY) && \
696 !defined(MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES)
697 #error "MBEDTLS_PSA_INJECT_ENTROPY is not compatible with actual entropy sources"
700 #if defined(MBEDTLS_PSA_INJECT_ENTROPY) && \
701 defined(MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG)
702 #error "MBEDTLS_PSA_INJECT_ENTROPY is not compatible with MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG"
705 #if defined(MBEDTLS_PSA_ITS_FILE_C) && \
706 !defined(MBEDTLS_FS_IO)
707 #error "MBEDTLS_PSA_ITS_FILE_C defined, but not all prerequisites"
710 #if defined(MBEDTLS_RSA_C) && ( !defined(MBEDTLS_BIGNUM_C) || \
711 !defined(MBEDTLS_OID_C) )
712 #error "MBEDTLS_RSA_C defined, but not all prerequisites"
715 #if defined(MBEDTLS_RSA_C) && ( !defined(MBEDTLS_PKCS1_V21) && \
716 !defined(MBEDTLS_PKCS1_V15) )
717 #error "MBEDTLS_RSA_C defined, but none of the PKCS1 versions enabled"
720 #if defined(MBEDTLS_X509_RSASSA_PSS_SUPPORT) && \
721 ( !defined(MBEDTLS_RSA_C) || !defined(MBEDTLS_PKCS1_V21) )
722 #error "MBEDTLS_X509_RSASSA_PSS_SUPPORT defined, but not all prerequisites"
725 #if defined(MBEDTLS_SHA512_USE_A64_CRYPTO_IF_PRESENT) && \
726 defined(MBEDTLS_SHA512_USE_A64_CRYPTO_ONLY)
727 #error "Must only define one of MBEDTLS_SHA512_USE_A64_CRYPTO_*"
730 #if defined(MBEDTLS_SHA512_USE_A64_CRYPTO_IF_PRESENT) || \
731 defined(MBEDTLS_SHA512_USE_A64_CRYPTO_ONLY)
732 #if !defined(MBEDTLS_SHA512_C)
733 #error "MBEDTLS_SHA512_USE_A64_CRYPTO_* defined without MBEDTLS_SHA512_C"
735 #if defined(MBEDTLS_SHA512_ALT) || defined(MBEDTLS_SHA512_PROCESS_ALT)
736 #error "MBEDTLS_SHA512_*ALT can't be used with MBEDTLS_SHA512_USE_A64_CRYPTO_*"
741 #if defined(MBEDTLS_SHA512_USE_A64_CRYPTO_ONLY) && !defined(__aarch64__)
742 #error "MBEDTLS_SHA512_USE_A64_CRYPTO_ONLY defined on non-Aarch64 system"
745 #if defined(MBEDTLS_SHA256_USE_A64_CRYPTO_IF_PRESENT) && \
746 defined(MBEDTLS_SHA256_USE_A64_CRYPTO_ONLY)
747 #error "Must only define one of MBEDTLS_SHA256_USE_A64_CRYPTO_*"
750 #if defined(MBEDTLS_SHA256_USE_A64_CRYPTO_IF_PRESENT) || \
751 defined(MBEDTLS_SHA256_USE_A64_CRYPTO_ONLY)
752 #if !defined(MBEDTLS_SHA256_C)
753 #error "MBEDTLS_SHA256_USE_A64_CRYPTO_* defined without MBEDTLS_SHA256_C"
755 #if defined(MBEDTLS_SHA256_ALT) || defined(MBEDTLS_SHA256_PROCESS_ALT)
756 #error "MBEDTLS_SHA256_*ALT can't be used with MBEDTLS_SHA256_USE_A64_CRYPTO_*"
761 #if defined(MBEDTLS_SHA256_USE_A64_CRYPTO_ONLY) && \
762 !defined(__aarch64__) && !defined(_M_ARM64)
763 #error "MBEDTLS_SHA256_USE_A64_CRYPTO_ONLY defined on non-Aarch64 system"
766 #if defined(MBEDTLS_SSL_PROTO_TLS1_2) && !defined(MBEDTLS_USE_PSA_CRYPTO) && \
767 !( defined(MBEDTLS_SHA1_C) || defined(MBEDTLS_SHA256_C) || defined(MBEDTLS_SHA512_C) )
768 #error "MBEDTLS_SSL_PROTO_TLS1_2 defined, but not all prerequisites"
772 #if defined(MBEDTLS_SSL_PROTO_TLS1_3) && \
773 !( defined(MBEDTLS_PSA_CRYPTO_C) && defined(PSA_WANT_ALG_HKDF_EXTRACT) && defined(PSA_WANT_ALG_HKDF_EXPAND) )
774 #error "MBEDTLS_SSL_PROTO_TLS1_3 defined, but not all prerequisites"
778 #if defined(MBEDTLS_SSL_PROTO_TLS1_3)
780 #if !( defined(PSA_WANT_ALG_SHA_256) || defined(PSA_WANT_ALG_SHA_384) )
781 #error "MBEDTLS_SSL_PROTO_TLS1_3 defined, but not all prerequisites"
783 #if !defined(MBEDTLS_USE_PSA_CRYPTO)
787 #if !defined(MBEDTLS_MD_C) || \
788 !( defined(MBEDTLS_SHA256_C) || defined(MBEDTLS_SHA384_C) )
789 #error "MBEDTLS_SSL_PROTO_TLS1_3 defined, but not all prerequisites"
794 #if defined(MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED)
795 #if !( defined(MBEDTLS_ECDH_C) && defined(MBEDTLS_X509_CRT_PARSE_C) && \
796 ( defined(MBEDTLS_PK_HAVE_ECDSA) || defined(MBEDTLS_PKCS1_V21) ) )
797 #error "MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED defined, but not all prerequisites"
801 #if defined(MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED)
802 #if !( defined(MBEDTLS_ECDH_C) )
803 #error "MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED defined, but not all prerequisites"
810 #if defined(MBEDTLS_SSL_PROTO_TLS1_3) && !defined(MBEDTLS_SSL_KEEP_PEER_CERTIFICATE)
811 #error "MBEDTLS_SSL_PROTO_TLS1_3 defined without MBEDTLS_SSL_KEEP_PEER_CERTIFICATE"
814 #if defined(MBEDTLS_SSL_PROTO_TLS1_2) && \
815 !(defined(MBEDTLS_KEY_EXCHANGE_RSA_ENABLED) || \
816 defined(MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED) || \
817 defined(MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED) || \
818 defined(MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED) || \
819 defined(MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED) || \
820 defined(MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED) || \
821 defined(MBEDTLS_KEY_EXCHANGE_PSK_ENABLED) || \
822 defined(MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED) || \
823 defined(MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED) || \
824 defined(MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED) || \
825 defined(MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED) )
826 #error "One or more versions of the TLS protocol are enabled " \
827 "but no key exchange methods defined with MBEDTLS_KEY_EXCHANGE_xxxx"
830 #if defined(MBEDTLS_SSL_EARLY_DATA) && \
831 ( !defined(MBEDTLS_SSL_SESSION_TICKETS) || \
832 ( !defined(MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED) && \
833 !defined(MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED) ) )
834 #error "MBEDTLS_SSL_EARLY_DATA defined, but not all prerequisites"
837 #if defined(MBEDTLS_SSL_EARLY_DATA) && defined(MBEDTLS_SSL_SRV_C) && \
838 ( !defined(MBEDTLS_SSL_MAX_EARLY_DATA_SIZE) || \
839 ( MBEDTLS_SSL_MAX_EARLY_DATA_SIZE < 0 ) || \
840 ( MBEDTLS_SSL_MAX_EARLY_DATA_SIZE > UINT32_MAX ) )
841 #error "MBEDTLS_SSL_MAX_EARLY_DATA_SIZE MUST be defined and in range(0..UINT32_MAX)"
844 #if defined(MBEDTLS_SSL_PROTO_DTLS) && \
845 !defined(MBEDTLS_SSL_PROTO_TLS1_2)
846 #error "MBEDTLS_SSL_PROTO_DTLS defined, but not all prerequisites"
849 #if defined(MBEDTLS_SSL_CLI_C) && !defined(MBEDTLS_SSL_TLS_C)
850 #error "MBEDTLS_SSL_CLI_C defined, but not all prerequisites"
853 #if defined(MBEDTLS_SSL_ASYNC_PRIVATE) && !defined(MBEDTLS_X509_CRT_PARSE_C)
854 #error "MBEDTLS_SSL_ASYNC_PRIVATE defined, but not all prerequisites"
857 #if defined(MBEDTLS_SSL_TLS_C) && ( !defined(MBEDTLS_CIPHER_C) || \
858 ( !defined(MBEDTLS_MD_C) && !defined(MBEDTLS_USE_PSA_CRYPTO) ) )
859 #error "MBEDTLS_SSL_TLS_C defined, but not all prerequisites"
862 #if defined(MBEDTLS_SSL_SRV_C) && !defined(MBEDTLS_SSL_TLS_C)
863 #error "MBEDTLS_SSL_SRV_C defined, but not all prerequisites"
866 #if defined(MBEDTLS_SSL_TLS_C) && \
867 !( defined(MBEDTLS_SSL_PROTO_TLS1_2) || defined(MBEDTLS_SSL_PROTO_TLS1_3) )
868 #error "MBEDTLS_SSL_TLS_C defined, but no protocols are active"
871 #if defined(MBEDTLS_SSL_DTLS_HELLO_VERIFY) && !defined(MBEDTLS_SSL_PROTO_DTLS)
872 #error "MBEDTLS_SSL_DTLS_HELLO_VERIFY defined, but not all prerequisites"
875 #if defined(MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE) && \
876 !defined(MBEDTLS_SSL_DTLS_HELLO_VERIFY)
877 #error "MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE defined, but not all prerequisites"
880 #if defined(MBEDTLS_SSL_DTLS_ANTI_REPLAY) && \
881 ( !defined(MBEDTLS_SSL_TLS_C) || !defined(MBEDTLS_SSL_PROTO_DTLS) )
882 #error "MBEDTLS_SSL_DTLS_ANTI_REPLAY defined, but not all prerequisites"
885 #if defined(MBEDTLS_SSL_DTLS_CONNECTION_ID) && \
886 ( !defined(MBEDTLS_SSL_TLS_C) || !defined(MBEDTLS_SSL_PROTO_DTLS) )
887 #error "MBEDTLS_SSL_DTLS_CONNECTION_ID defined, but not all prerequisites"
890 #if defined(MBEDTLS_SSL_DTLS_CONNECTION_ID) && \
891 defined(MBEDTLS_SSL_CID_IN_LEN_MAX) && \
892 MBEDTLS_SSL_CID_IN_LEN_MAX > 255
893 #error "MBEDTLS_SSL_CID_IN_LEN_MAX too large (max 255)"
896 #if defined(MBEDTLS_SSL_DTLS_CONNECTION_ID) && \
897 defined(MBEDTLS_SSL_CID_OUT_LEN_MAX) && \
898 MBEDTLS_SSL_CID_OUT_LEN_MAX > 255
899 #error "MBEDTLS_SSL_CID_OUT_LEN_MAX too large (max 255)"
902 #if defined(MBEDTLS_SSL_DTLS_CONNECTION_ID_COMPAT) && \
903 !defined(MBEDTLS_SSL_DTLS_CONNECTION_ID)
904 #error "MBEDTLS_SSL_DTLS_CONNECTION_ID_COMPAT defined, but not all prerequisites"
907 #if defined(MBEDTLS_SSL_DTLS_CONNECTION_ID_COMPAT) && MBEDTLS_SSL_DTLS_CONNECTION_ID_COMPAT != 0
908 #if defined(MBEDTLS_DEPRECATED_REMOVED)
909 #error "MBEDTLS_SSL_DTLS_CONNECTION_ID_COMPAT is deprecated and will be removed in a future version of Mbed TLS"
910 #elif defined(MBEDTLS_DEPRECATED_WARNING)
911 #warning "MBEDTLS_SSL_DTLS_CONNECTION_ID_COMPAT is deprecated and will be removed in a future version of Mbed TLS"
915 #if defined(MBEDTLS_SSL_ENCRYPT_THEN_MAC) && \
916 !defined(MBEDTLS_SSL_PROTO_TLS1_2)
917 #error "MBEDTLS_SSL_ENCRYPT_THEN_MAC defined, but not all prerequisites"
920 #if defined(MBEDTLS_SSL_EXTENDED_MASTER_SECRET) && \
921 !defined(MBEDTLS_SSL_PROTO_TLS1_2)
922 #error "MBEDTLS_SSL_EXTENDED_MASTER_SECRET defined, but not all prerequisites"
925 #if defined(MBEDTLS_SSL_RENEGOTIATION) && \
926 !defined(MBEDTLS_SSL_PROTO_TLS1_2)
927 #error "MBEDTLS_SSL_RENEGOTIATION defined, but not all prerequisites"
930 #if defined(MBEDTLS_SSL_TICKET_C) && ( !defined(MBEDTLS_CIPHER_C) && \
931 !defined(MBEDTLS_USE_PSA_CRYPTO) )
932 #error "MBEDTLS_SSL_TICKET_C defined, but not all prerequisites"
935 #if defined(MBEDTLS_SSL_TICKET_C) && \
936 !( defined(MBEDTLS_GCM_C) || defined(MBEDTLS_CCM_C) || defined(MBEDTLS_CHACHAPOLY_C) )
937 #error "MBEDTLS_SSL_TICKET_C defined, but not all prerequisites"
940 #if defined(MBEDTLS_SSL_TLS1_3_TICKET_NONCE_LENGTH) && \
941 MBEDTLS_SSL_TLS1_3_TICKET_NONCE_LENGTH >= 256
942 #error "MBEDTLS_SSL_TLS1_3_TICKET_NONCE_LENGTH must be less than 256"
945 #if defined(MBEDTLS_SSL_SERVER_NAME_INDICATION) && \
946 !defined(MBEDTLS_X509_CRT_PARSE_C)
947 #error "MBEDTLS_SSL_SERVER_NAME_INDICATION defined, but not all prerequisites"
950 #if defined(MBEDTLS_THREADING_PTHREAD)
951 #if !defined(MBEDTLS_THREADING_C) || defined(MBEDTLS_THREADING_IMPL)
952 #error "MBEDTLS_THREADING_PTHREAD defined, but not all prerequisites"
954 #define MBEDTLS_THREADING_IMPL
957 #if defined(MBEDTLS_THREADING_ALT)
958 #if !defined(MBEDTLS_THREADING_C) || defined(MBEDTLS_THREADING_IMPL)
959 #error "MBEDTLS_THREADING_ALT defined, but not all prerequisites"
961 #define MBEDTLS_THREADING_IMPL
964 #if defined(MBEDTLS_THREADING_C) && !defined(MBEDTLS_THREADING_IMPL)
965 #error "MBEDTLS_THREADING_C defined, single threading implementation required"
967 #undef MBEDTLS_THREADING_IMPL
969 #if defined(MBEDTLS_USE_PSA_CRYPTO) && !defined(MBEDTLS_PSA_CRYPTO_C)
970 #error "MBEDTLS_USE_PSA_CRYPTO defined, but not all prerequisites"
973 #if defined(MBEDTLS_VERSION_FEATURES) && !defined(MBEDTLS_VERSION_C)
974 #error "MBEDTLS_VERSION_FEATURES defined, but not all prerequisites"
977 #if defined(MBEDTLS_X509_USE_C) && ( !defined(MBEDTLS_BIGNUM_C) || \
978 !defined(MBEDTLS_OID_C) || !defined(MBEDTLS_ASN1_PARSE_C) || \
979 !defined(MBEDTLS_PK_PARSE_C) || \
980 ( !defined(MBEDTLS_MD_C) && !defined(MBEDTLS_USE_PSA_CRYPTO) ) )
981 #error "MBEDTLS_X509_USE_C defined, but not all prerequisites"
984 #if defined(MBEDTLS_X509_CREATE_C) && ( !defined(MBEDTLS_BIGNUM_C) || \
985 !defined(MBEDTLS_OID_C) || !defined(MBEDTLS_ASN1_WRITE_C) || \
986 !defined(MBEDTLS_PK_PARSE_C) || \
987 ( !defined(MBEDTLS_MD_C) && !defined(MBEDTLS_USE_PSA_CRYPTO) ) )
988 #error "MBEDTLS_X509_CREATE_C defined, but not all prerequisites"
991 #if defined(MBEDTLS_X509_CRT_PARSE_C) && ( !defined(MBEDTLS_X509_USE_C) )
992 #error "MBEDTLS_X509_CRT_PARSE_C defined, but not all prerequisites"
995 #if defined(MBEDTLS_X509_CRL_PARSE_C) && ( !defined(MBEDTLS_X509_USE_C) )
996 #error "MBEDTLS_X509_CRL_PARSE_C defined, but not all prerequisites"
999 #if defined(MBEDTLS_X509_CSR_PARSE_C) && ( !defined(MBEDTLS_X509_USE_C) )
1000 #error "MBEDTLS_X509_CSR_PARSE_C defined, but not all prerequisites"
1003 #if defined(MBEDTLS_X509_CRT_WRITE_C) && ( !defined(MBEDTLS_X509_CREATE_C) )
1004 #error "MBEDTLS_X509_CRT_WRITE_C defined, but not all prerequisites"
1007 #if defined(MBEDTLS_X509_CSR_WRITE_C) && ( !defined(MBEDTLS_X509_CREATE_C) )
1008 #error "MBEDTLS_X509_CSR_WRITE_C defined, but not all prerequisites"
1011 #if defined(MBEDTLS_X509_TRUSTED_CERTIFICATE_CALLBACK) && \
1012 ( !defined(MBEDTLS_X509_CRT_PARSE_C) )
1013 #error "MBEDTLS_X509_TRUSTED_CERTIFICATE_CALLBACK defined, but not all prerequisites"
1016 #if defined(MBEDTLS_HAVE_INT32) && defined(MBEDTLS_HAVE_INT64)
1017 #error "MBEDTLS_HAVE_INT32 and MBEDTLS_HAVE_INT64 cannot be defined simultaneously"
1020 #if ( defined(MBEDTLS_HAVE_INT32) || defined(MBEDTLS_HAVE_INT64) ) && \
1021 defined(MBEDTLS_HAVE_ASM)
1022 #error "MBEDTLS_HAVE_INT32/MBEDTLS_HAVE_INT64 and MBEDTLS_HAVE_ASM cannot be defined simultaneously"
1025 #if defined(MBEDTLS_SSL_DTLS_SRTP) && ( !defined(MBEDTLS_SSL_PROTO_DTLS) )
1026 #error "MBEDTLS_SSL_DTLS_SRTP defined, but not all prerequisites"
1029 #if defined(MBEDTLS_SSL_VARIABLE_BUFFER_LENGTH) && ( !defined(MBEDTLS_SSL_MAX_FRAGMENT_LENGTH) )
1030 #error "MBEDTLS_SSL_VARIABLE_BUFFER_LENGTH defined, but not all prerequisites"
1033 #if defined(MBEDTLS_SSL_RECORD_SIZE_LIMIT) && ( !defined(MBEDTLS_SSL_PROTO_TLS1_3) )
1034 #error "MBEDTLS_SSL_RECORD_SIZE_LIMIT defined, but not all prerequisites"
1037 #if defined(MBEDTLS_SSL_CONTEXT_SERIALIZATION) && !( defined(MBEDTLS_GCM_C) || defined(MBEDTLS_CCM_C) || defined(MBEDTLS_CHACHAPOLY_C) )
1038 #error "MBEDTLS_SSL_CONTEXT_SERIALIZATION defined, but not all prerequisites"
1044 #if defined(MBEDTLS_HAVEGE_C) //no-check-names
1045 #error "MBEDTLS_HAVEGE_C was removed in Mbed TLS 3.0. See https://github.com/Mbed-TLS/mbedtls/issues/2599"
1048 #if defined(MBEDTLS_SSL_HW_RECORD_ACCEL) //no-check-names
1049 #error "MBEDTLS_SSL_HW_RECORD_ACCEL was removed in Mbed TLS 3.0. See https://github.com/Mbed-TLS/mbedtls/issues/4031"
1052 #if defined(MBEDTLS_SSL_PROTO_SSL3) //no-check-names
1053 #error "MBEDTLS_SSL_PROTO_SSL3 (SSL v3.0 support) was removed in Mbed TLS 3.0. See https://github.com/Mbed-TLS/mbedtls/issues/4031"
1056 #if defined(MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO) //no-check-names
1057 #error "MBEDTLS_SSL_SRV_SUPPORT_SSLV2_CLIENT_HELLO (SSL v2 ClientHello support) was removed in Mbed TLS 3.0. See https://github.com/Mbed-TLS/mbedtls/issues/4031"
1060 #if defined(MBEDTLS_SSL_TRUNCATED_HMAC_COMPAT) //no-check-names
1061 #error "MBEDTLS_SSL_TRUNCATED_HMAC_COMPAT (compatibility with the buggy implementation of truncated HMAC in Mbed TLS up to 2.7) was removed in Mbed TLS 3.0. See https://github.com/Mbed-TLS/mbedtls/issues/4031"
1064 #if defined(MBEDTLS_TLS_DEFAULT_ALLOW_SHA1_IN_CERTIFICATES) //no-check-names
1065 #error "MBEDTLS_TLS_DEFAULT_ALLOW_SHA1_IN_CERTIFICATES was removed in Mbed TLS 3.0. See the ChangeLog entry if you really need SHA-1-signed certificates."
1068 #if defined(MBEDTLS_ZLIB_SUPPORT) //no-check-names
1069 #error "MBEDTLS_ZLIB_SUPPORT was removed in Mbed TLS 3.0. See https://github.com/Mbed-TLS/mbedtls/issues/4031"
1072 #if defined(MBEDTLS_CHECK_PARAMS) //no-check-names
1073 #error "MBEDTLS_CHECK_PARAMS was removed in Mbed TLS 3.0. See https://github.com/Mbed-TLS/mbedtls/issues/4313"
1076 #if defined(MBEDTLS_SSL_CID_PADDING_GRANULARITY) //no-check-names
1077 #error "MBEDTLS_SSL_CID_PADDING_GRANULARITY was removed in Mbed TLS 3.0. See https://github.com/Mbed-TLS/mbedtls/issues/4335"
1080 #if defined(MBEDTLS_SSL_TLS1_3_PADDING_GRANULARITY) //no-check-names
1081 #error "MBEDTLS_SSL_TLS1_3_PADDING_GRANULARITY was removed in Mbed TLS 3.0. See https://github.com/Mbed-TLS/mbedtls/issues/4335"
1084 #if defined(MBEDTLS_SSL_TRUNCATED_HMAC) //no-check-names
1085 #error "MBEDTLS_SSL_TRUNCATED_HMAC was removed in Mbed TLS 3.0. See https://github.com/Mbed-TLS/mbedtls/issues/4341"
1088 #if defined(MBEDTLS_PKCS7_C) && ( ( !defined(MBEDTLS_ASN1_PARSE_C) ) || \
1089 ( !defined(MBEDTLS_OID_C) ) || ( !defined(MBEDTLS_PK_PARSE_C) ) || \
1090 ( !defined(MBEDTLS_X509_CRT_PARSE_C) ) ||\
1091 ( !defined(MBEDTLS_X509_CRL_PARSE_C) ) || ( !defined(MBEDTLS_BIGNUM_C) ) || \
1092 ( !defined(MBEDTLS_MD_C) ) )
1093 #error "MBEDTLS_PKCS7_C is defined, but not all prerequisites"
1097 #undef MBEDTLS_PK_HAVE_ECDSA
1098 #undef MBEDTLS_PK_HAVE_JPAKE
int mbedtls_iso_c_forbids_empty_translation_units