Go to the documentation of this file.
29 #ifndef PSA_CRYPTO_CONFIG_H
30 #define PSA_CRYPTO_CONFIG_H
39 #define TF_PSA_CRYPTO_CONFIG_VERSION 0x01000000
48 #define PSA_WANT_ALG_CBC_NO_PADDING 1
49 #define PSA_WANT_ALG_CBC_PKCS7 1
50 #define PSA_WANT_ALG_CCM 1
51 #define PSA_WANT_ALG_CCM_STAR_NO_TAG 1
52 #define PSA_WANT_ALG_CMAC 1
53 #define PSA_WANT_ALG_CFB 1
54 #define PSA_WANT_ALG_CHACHA20_POLY1305 1
55 #define PSA_WANT_ALG_CTR 1
56 #define PSA_WANT_ALG_DETERMINISTIC_ECDSA 1
57 #define PSA_WANT_ALG_ECB_NO_PADDING 1
58 #define PSA_WANT_ALG_ECDH 1
59 #define PSA_WANT_ALG_FFDH 1
60 #define PSA_WANT_ALG_ECDSA 1
61 #define PSA_WANT_ALG_JPAKE 1
62 #define PSA_WANT_ALG_GCM 1
63 #define PSA_WANT_ALG_HKDF 1
64 #define PSA_WANT_ALG_HKDF_EXTRACT 1
65 #define PSA_WANT_ALG_HKDF_EXPAND 1
66 #define PSA_WANT_ALG_HMAC 1
67 #define PSA_WANT_ALG_MD5 1
68 #define PSA_WANT_ALG_OFB 1
69 #define PSA_WANT_ALG_PBKDF2_HMAC 1
70 #define PSA_WANT_ALG_PBKDF2_AES_CMAC_PRF_128 1
71 #define PSA_WANT_ALG_RIPEMD160 1
72 #define PSA_WANT_ALG_RSA_OAEP 1
73 #define PSA_WANT_ALG_RSA_PKCS1V15_CRYPT 1
74 #define PSA_WANT_ALG_RSA_PKCS1V15_SIGN 1
75 #define PSA_WANT_ALG_RSA_PSS 1
76 #define PSA_WANT_ALG_SHA_1 1
77 #define PSA_WANT_ALG_SHA_224 1
78 #define PSA_WANT_ALG_SHA_256 1
79 #define PSA_WANT_ALG_SHA_384 1
80 #define PSA_WANT_ALG_SHA_512 1
81 #define PSA_WANT_ALG_SHA3_224 1
82 #define PSA_WANT_ALG_SHA3_256 1
83 #define PSA_WANT_ALG_SHA3_384 1
84 #define PSA_WANT_ALG_SHA3_512 1
85 #define PSA_WANT_ALG_STREAM_CIPHER 1
86 #define PSA_WANT_ALG_TLS12_PRF 1
87 #define PSA_WANT_ALG_TLS12_PSK_TO_MS 1
88 #define PSA_WANT_ALG_TLS12_ECJPAKE_TO_PMS 1
90 #define PSA_WANT_ECC_BRAINPOOL_P_R1_256 1
91 #define PSA_WANT_ECC_BRAINPOOL_P_R1_384 1
92 #define PSA_WANT_ECC_BRAINPOOL_P_R1_512 1
93 #define PSA_WANT_ECC_MONTGOMERY_255 1
94 #define PSA_WANT_ECC_MONTGOMERY_448 1
95 #define PSA_WANT_ECC_SECP_K1_256 1
98 #define PSA_WANT_ECC_SECP_R1_256 1
99 #define PSA_WANT_ECC_SECP_R1_384 1
100 #define PSA_WANT_ECC_SECP_R1_521 1
103 #define PSA_WANT_ECC_SECP_K1_192 1
104 #define PSA_WANT_ECC_SECP_R1_192 1
106 #define PSA_WANT_DH_RFC7919_2048 1
107 #define PSA_WANT_DH_RFC7919_3072 1
108 #define PSA_WANT_DH_RFC7919_4096 1
109 #define PSA_WANT_DH_RFC7919_6144 1
110 #define PSA_WANT_DH_RFC7919_8192 1
112 #define PSA_WANT_KEY_TYPE_DERIVE 1
113 #define PSA_WANT_KEY_TYPE_PASSWORD 1
114 #define PSA_WANT_KEY_TYPE_PASSWORD_HASH 1
115 #define PSA_WANT_KEY_TYPE_HMAC 1
116 #define PSA_WANT_KEY_TYPE_AES 1
117 #define PSA_WANT_KEY_TYPE_ARIA 1
118 #define PSA_WANT_KEY_TYPE_CAMELLIA 1
119 #define PSA_WANT_KEY_TYPE_CHACHA20 1
120 #define PSA_WANT_KEY_TYPE_ECC_PUBLIC_KEY 1
121 #define PSA_WANT_KEY_TYPE_DH_PUBLIC_KEY 1
122 #define PSA_WANT_KEY_TYPE_RAW_DATA 1
123 #define PSA_WANT_KEY_TYPE_RSA_PUBLIC_KEY 1
132 #define PSA_WANT_KEY_TYPE_ECC_KEY_PAIR_BASIC 1
133 #define PSA_WANT_KEY_TYPE_ECC_KEY_PAIR_IMPORT 1
134 #define PSA_WANT_KEY_TYPE_ECC_KEY_PAIR_EXPORT 1
135 #define PSA_WANT_KEY_TYPE_ECC_KEY_PAIR_GENERATE 1
136 #define PSA_WANT_KEY_TYPE_ECC_KEY_PAIR_DERIVE 1
138 #define PSA_WANT_KEY_TYPE_RSA_KEY_PAIR_BASIC 1
139 #define PSA_WANT_KEY_TYPE_RSA_KEY_PAIR_IMPORT 1
140 #define PSA_WANT_KEY_TYPE_RSA_KEY_PAIR_EXPORT 1
141 #define PSA_WANT_KEY_TYPE_RSA_KEY_PAIR_GENERATE 1
142 #define PSA_WANT_KEY_TYPE_RSA_KEY_PAIR_DERIVE 1
144 #define PSA_WANT_KEY_TYPE_DH_KEY_PAIR_BASIC 1
145 #define PSA_WANT_KEY_TYPE_DH_KEY_PAIR_IMPORT 1
146 #define PSA_WANT_KEY_TYPE_DH_KEY_PAIR_EXPORT 1
147 #define PSA_WANT_KEY_TYPE_DH_KEY_PAIR_GENERATE 1
148 #define PSA_WANT_KEY_TYPE_DH_KEY_PAIR_DERIVE 1
172 #define MBEDTLS_MEMORY_BUFFER_ALLOC_C
179 #define MBEDTLS_FS_IO
194 #define MBEDTLS_HAVE_TIME
215 #define MBEDTLS_HAVE_TIME_DATE
228 #define MBEDTLS_MEMORY_DEBUG
240 #define MBEDTLS_MEMORY_BACKTRACE
260 #define MBEDTLS_PLATFORM_C
285 #define MBEDTLS_PLATFORM_SETBUF_ALT
286 #define MBEDTLS_PLATFORM_EXIT_ALT
287 #define MBEDTLS_PLATFORM_TIME_ALT
288 #define MBEDTLS_PLATFORM_FPRINTF_ALT
289 #define MBEDTLS_PLATFORM_PRINTF_ALT
290 #define MBEDTLS_PLATFORM_SNPRINTF_ALT
291 #define MBEDTLS_PLATFORM_VSNPRINTF_ALT
292 #define MBEDTLS_PLATFORM_NV_SEED_ALT
293 #define MBEDTLS_PLATFORM_SETUP_TEARDOWN_ALT
294 #define MBEDTLS_PLATFORM_MS_TIME_ALT
313 #define MBEDTLS_PLATFORM_GMTIME_R_ALT
369 #define MBEDTLS_PLATFORM_MEMORY
388 #define MBEDTLS_PLATFORM_NO_STD_FUNCTIONS
411 #define MBEDTLS_PLATFORM_ZEROIZE_ALT
436 #define MBEDTLS_THREADING_ALT
447 #define MBEDTLS_THREADING_PTHREAD
470 #define MBEDTLS_THREADING_C
473 #define MBEDTLS_MEMORY_ALIGN_MULTIPLE 4
477 #define MBEDTLS_PLATFORM_CALLOC_MACRO calloc
478 #define MBEDTLS_PLATFORM_EXIT_MACRO exit
479 #define MBEDTLS_PLATFORM_FREE_MACRO free
480 #define MBEDTLS_PLATFORM_FPRINTF_MACRO fprintf
481 #define MBEDTLS_PLATFORM_MS_TIME_TYPE_MACRO int64_t //#define MBEDTLS_PLATFORM_MS_TIME_TYPE_MACRO int64_t
482 #define MBEDTLS_PLATFORM_NV_SEED_READ_MACRO mbedtls_platform_std_nv_seed_read
483 #define MBEDTLS_PLATFORM_NV_SEED_WRITE_MACRO mbedtls_platform_std_nv_seed_write
484 #define MBEDTLS_PLATFORM_PRINTF_MACRO printf
485 #define MBEDTLS_PLATFORM_SETBUF_MACRO setbuf
487 #define MBEDTLS_PLATFORM_SNPRINTF_MACRO snprintf
500 #define MBEDTLS_PLATFORM_STD_CALLOC calloc
502 #define MBEDTLS_PLATFORM_STD_EXIT exit
503 #define MBEDTLS_PLATFORM_STD_EXIT_FAILURE 1
504 #define MBEDTLS_PLATFORM_STD_EXIT_SUCCESS 0
505 #define MBEDTLS_PLATFORM_STD_FPRINTF fprintf
515 #define MBEDTLS_PLATFORM_STD_FREE free
517 #define MBEDTLS_PLATFORM_STD_MEM_HDR <stdlib.h>
518 #define MBEDTLS_PLATFORM_STD_NV_SEED_FILE "seedfile"
519 #define MBEDTLS_PLATFORM_STD_NV_SEED_READ mbedtls_platform_std_nv_seed_read
520 #define MBEDTLS_PLATFORM_STD_NV_SEED_WRITE mbedtls_platform_std_nv_seed_write
521 #define MBEDTLS_PLATFORM_STD_PRINTF printf
522 #define MBEDTLS_PLATFORM_STD_SETBUF setbuf
524 #define MBEDTLS_PLATFORM_STD_SNPRINTF snprintf
525 #define MBEDTLS_PLATFORM_STD_TIME time
526 #define MBEDTLS_PLATFORM_TIME_MACRO time
527 #define MBEDTLS_PLATFORM_TIME_TYPE_MACRO time_t
528 #define MBEDTLS_PLATFORM_VSNPRINTF_MACRO vsnprintf
529 #define MBEDTLS_PRINTF_MS_TIME PRId64
561 #define MBEDTLS_CHECK_RETURN_WARNING
576 #define MBEDTLS_DEPRECATED_WARNING
588 #define MBEDTLS_DEPRECATED_REMOVED
603 #define MBEDTLS_CHECK_RETURN __attribute__((__warn_unused_result__))
611 #define MBEDTLS_IGNORE_RETURN( result ) ((void) !(result))
628 #define TF_PSA_CRYPTO_CONFIG_FILE "psa/crypto_config.h"
645 #define TF_PSA_CRYPTO_USER_CONFIG_FILE "/dev/null"
652 #define MBEDTLS_SELF_TEST
669 #define MBEDTLS_TEST_CONSTANT_FLOW_MEMSAN
688 #define MBEDTLS_TEST_CONSTANT_FLOW_VALGRIND
708 #define MBEDTLS_TEST_HOOKS
718 #define TF_PSA_CRYPTO_VERSION
741 #define MBEDTLS_LMS_C
753 #define MBEDTLS_LMS_PRIVATE
787 #define MBEDTLS_NIST_KW_C
814 #define MBEDTLS_PKCS5_C
827 #define MBEDTLS_PK_PARSE_C
841 #define MBEDTLS_PK_PARSE_EC_EXTENDED
850 #define MBEDTLS_PK_PARSE_EC_COMPRESSED
863 #define MBEDTLS_PK_WRITE_C
883 #define MBEDTLS_ASN1_PARSE_C
894 #define MBEDTLS_ASN1_WRITE_C
906 #define MBEDTLS_BASE64_C
921 #define MBEDTLS_PEM_PARSE_C
935 #define MBEDTLS_PEM_WRITE_C
963 #define MBEDTLS_CTR_DRBG_C
980 #define MBEDTLS_ENTROPY_NO_SOURCES_OK
1010 #define MBEDTLS_ENTROPY_NV_SEED
1024 #define MBEDTLS_HMAC_DRBG_C
1051 #define MBEDTLS_PSA_CRYPTO_C
1071 #define MBEDTLS_PSA_ASSUME_EXCLUSIVE_BUFFERS
1103 #define MBEDTLS_PSA_BUILTIN_GET_ENTROPY
1119 #define MBEDTLS_PSA_CRYPTO_BUILTIN_KEYS
1135 #define MBEDTLS_PSA_CRYPTO_CLIENT
1173 #define MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG
1185 #define MBEDTLS_PSA_CRYPTO_KEY_ID_ENCODES_OWNER
1206 #define MBEDTLS_PSA_CRYPTO_SPM
1219 #define MBEDTLS_PSA_CRYPTO_STORAGE_C
1247 #define MBEDTLS_PSA_DRIVER_GET_ENTROPY
1259 #define MBEDTLS_PSA_ITS_FILE_C
1276 #define MBEDTLS_PSA_KEY_STORE_DYNAMIC
1296 #define MBEDTLS_PSA_STATIC_KEY_SLOTS
1320 #define MBEDTLS_PSA_CRYPTO_PLATFORM_FILE "psa/crypto_platform_alt.h"
1345 #define MBEDTLS_PSA_CRYPTO_STRUCT_FILE "psa/crypto_struct_alt.h"
1365 #define MBEDTLS_PSA_KEY_SLOT_COUNT 32
1378 #define MBEDTLS_PSA_STATIC_KEY_SLOT_BUFFER_SIZE 256
1387 #define MBEDTLS_PSA_CRYPTO_RNG_STRENGTH 256
1406 #define MBEDTLS_PSA_CRYPTO_RNG_HASH PSA_ALG_SHA_256
1418 #define MBEDTLS_PSA_RNG_RESEED_INTERVAL 1000
1459 #define MBEDTLS_AESNI_C
1485 #define MBEDTLS_AESCE_C
1504 #define MBEDTLS_AES_ROM_TABLES
1525 #define MBEDTLS_AES_FEWER_TABLES
1542 #define MBEDTLS_AES_ONLY_128_BIT_KEY_LENGTH
1556 #define MBEDTLS_AES_USE_HARDWARE_ONLY
1574 #define MBEDTLS_BLOCK_CIPHER_NO_DECRYPT
1583 #define MBEDTLS_CAMELLIA_SMALL_MEMORY
1595 #define MBEDTLS_ECDH_VARIANT_EVEREST_ENABLED
1606 #define MBEDTLS_ECP_NIST_OPTIM
1651 #define MBEDTLS_ECP_RESTARTABLE
1659 #define MBEDTLS_ECP_WITH_MPI_UINT
1675 #define MBEDTLS_GCM_LARGE_TABLE
1696 #define MBEDTLS_HAVE_ASM
1705 #define MBEDTLS_HAVE_SSE2
1733 #define MBEDTLS_NO_UDBL_DIVISION
1755 #define MBEDTLS_NO_64BIT_MULTIPLICATION
1793 #define MBEDTLS_PSA_P256M_DRIVER_ENABLED
1804 #define MBEDTLS_RSA_NO_CRT
1820 #define MBEDTLS_SHA256_SMALLER
1854 #define MBEDTLS_SHA256_USE_ARMV8_A_CRYPTO_IF_PRESENT
1889 #define MBEDTLS_SHA256_USE_ARMV8_A_CRYPTO_ONLY
1899 #define MBEDTLS_SHA512_SMALLER
1933 #define MBEDTLS_SHA512_USE_A64_CRYPTO_IF_PRESENT
1967 #define MBEDTLS_SHA512_USE_A64_CRYPTO_ONLY
1970 #define MBEDTLS_ECP_FIXED_POINT_OPTIM 1
1971 #define MBEDTLS_ECP_WINDOW_SIZE 4
1974 #define MBEDTLS_MPI_MAX_SIZE 1024
1975 #define MBEDTLS_MPI_WINDOW_SIZE 2
1978 #define MBEDTLS_RSA_GEN_KEY_MIN_BITS 1024
1984 #define TF_PSA_CRYPTO_ALLOW_REMOVED_MECHANISMS