23 #ifndef PSA_CRYPTO_BUILTIN_PRIMITIVES_H
24 #define PSA_CRYPTO_BUILTIN_PRIMITIVES_H
25 #include "mbedtls/private_access.h"
33 #include "mbedtls/private/md5.h"
34 #include "mbedtls/private/ripemd160.h"
35 #include "mbedtls/private/sha1.h"
36 #include "mbedtls/private/sha256.h"
37 #include "mbedtls/private/sha512.h"
38 #include "mbedtls/private/sha3.h"
40 #if defined(MBEDTLS_PSA_BUILTIN_ALG_MD5) || \
41 defined(MBEDTLS_PSA_BUILTIN_ALG_RIPEMD160) || \
42 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA_1) || \
43 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA_224) || \
44 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA_256) || \
45 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA_384) || \
46 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA_512) || \
47 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA3_224) || \
48 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA3_256) || \
49 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA3_384) || \
50 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA3_512)
51 #define MBEDTLS_PSA_BUILTIN_HASH
58 #if defined(MBEDTLS_PSA_BUILTIN_ALG_MD5)
59 mbedtls_md5_context
md5;
61 #if defined(MBEDTLS_PSA_BUILTIN_ALG_RIPEMD160)
64 #if defined(MBEDTLS_PSA_BUILTIN_ALG_SHA_1)
67 #if defined(MBEDTLS_PSA_BUILTIN_ALG_SHA_256) || \
68 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA_224)
71 #if defined(MBEDTLS_PSA_BUILTIN_ALG_SHA_512) || \
72 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA_384)
75 #if defined(MBEDTLS_PSA_BUILTIN_ALG_SHA3_224) || \
76 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA3_256) || \
77 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA3_384) || \
78 defined(MBEDTLS_PSA_BUILTIN_ALG_SHA3_512)
81 } MBEDTLS_PRIVATE(ctx);
84 #define MBEDTLS_PSA_HASH_OPERATION_INIT { 0, { 0 } }
90 #include "mbedtls/private/cipher.h"
92 #if defined(MBEDTLS_PSA_BUILTIN_ALG_STREAM_CIPHER) || \
93 defined(MBEDTLS_PSA_BUILTIN_ALG_CTR) || \
94 defined(MBEDTLS_PSA_BUILTIN_ALG_CFB) || \
95 defined(MBEDTLS_PSA_BUILTIN_ALG_OFB) || \
96 defined(MBEDTLS_PSA_BUILTIN_ALG_ECB_NO_PADDING) || \
97 defined(MBEDTLS_PSA_BUILTIN_ALG_CBC_NO_PADDING) || \
98 defined(MBEDTLS_PSA_BUILTIN_ALG_CBC_PKCS7) || \
99 defined(MBEDTLS_PSA_BUILTIN_ALG_CCM_STAR_NO_TAG)
100 #define MBEDTLS_PSA_BUILTIN_CIPHER 1
106 uint8_t MBEDTLS_PRIVATE(iv_length);
107 uint8_t MBEDTLS_PRIVATE(block_length);
109 unsigned int MBEDTLS_PRIVATE(dummy);
110 mbedtls_cipher_context_t MBEDTLS_PRIVATE(cipher);
111 } MBEDTLS_PRIVATE(ctx);
114 #define MBEDTLS_PSA_CIPHER_OPERATION_INIT { 0, 0, 0, { 0 } }
mbedtls_sha512_context sha512
uint32_t psa_algorithm_t
Encoding of a cryptographic algorithm.
mbedtls_ripemd160_context ripemd160
mbedtls_sha3_context sha3
Definitions for all PSA crypto drivers.
mbedtls_sha256_context sha256
mbedtls_sha1_context sha1