xref: /aosp_15_r20/external/openthread/third_party/mbedtls/repo/configs/config-tfm.h (revision cfb92d1480a9e65faed56933e9c12405f45898b4)
1 /**
2  * \file config-tfm.h
3  *
4  * \brief TF-M medium profile, adapted to work on other platforms.
5  */
6 /*
7  *  Copyright The Mbed TLS Contributors
8  *  SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
9  */
10 
11 /* TF-M medium profile: mbedtls legacy configuration */
12 #include "../configs/ext/tfm_mbedcrypto_config_profile_medium.h"
13 
14 /* TF-M medium profile: PSA crypto configuration */
15 #define MBEDTLS_PSA_CRYPTO_CONFIG_FILE "../configs/ext/crypto_config_profile_medium.h"
16 
17 /***********************************************************/
18 /* Tweak the configuration to remove dependencies on TF-M. */
19 /***********************************************************/
20 
21 /* MBEDTLS_PSA_CRYPTO_SPM needs third-party files, so disable it. */
22 #undef MBEDTLS_PSA_CRYPTO_SPM
23 
24 /* Disable buffer-based memory allocator. This isn't strictly required,
25  * but using the native allocator is faster and works better with
26  * memory management analysis frameworks such as ASan. */
27 #undef MBEDTLS_MEMORY_BUFFER_ALLOC_C
28 
29 // This macro is enabled in TFM Medium but is disabled here because it is
30 // incompatible with baremetal builds in Mbed TLS.
31 #undef MBEDTLS_PSA_CRYPTO_STORAGE_C
32 
33 // This macro is enabled in TFM Medium but is disabled here because it is
34 // incompatible with baremetal builds in Mbed TLS.
35 #undef MBEDTLS_ENTROPY_NV_SEED
36 
37 // These platform-related TF-M settings are not useful here.
38 #undef MBEDTLS_PLATFORM_NO_STD_FUNCTIONS
39 #undef MBEDTLS_PLATFORM_STD_MEM_HDR
40 #undef MBEDTLS_PLATFORM_SNPRINTF_MACRO
41 #undef MBEDTLS_PLATFORM_PRINTF_ALT
42 #undef MBEDTLS_PLATFORM_STD_EXIT_SUCCESS
43 #undef MBEDTLS_PLATFORM_STD_EXIT_FAILURE
44 
45 /*
46  * In order to get an example config that works cleanly out-of-the-box
47  * for both baremetal and non-baremetal builds, we detect baremetal builds
48  * (either IAR, Arm compiler or __ARM_EABI__ defined), and adjust some
49  * variables accordingly.
50  */
51 #if defined(__IAR_SYSTEMS_ICC__) || defined(__ARMCC_VERSION) || defined(__ARM_EABI__)
52 #define MBEDTLS_NO_PLATFORM_ENTROPY
53 #else
54 /* Use built-in platform entropy functions (TF-M provides its own). */
55 #undef MBEDTLS_NO_PLATFORM_ENTROPY
56 #endif
57 
58 /***********************************************************************
59  * Local changes to crypto config below this delimiter
60  **********************************************************************/
61 
62 // We expect TF-M to pick this up soon
63 #define MBEDTLS_BLOCK_CIPHER_NO_DECRYPT
64 
65 /* CCM is the only cipher/AEAD enabled in TF-M configuration files, but it
66  * does not need CIPHER_C to be enabled, so we can disable it in order
67  * to reduce code size further. */
68 #undef MBEDTLS_CIPHER_C
69