1 /*
2  *  Declaration of context structures for use with the PSA driver wrapper
3  *  interface. This file contains the context structures for 'composite'
4  *  operations, i.e. those operations which need to make use of other operations
5  *  from the primitives (crypto_driver_contexts_primitives.h)
6  *
7  *  Warning: This file will be auto-generated in the future.
8  *
9  * \note This file may not be included directly. Applications must
10  * include psa/crypto.h.
11  *
12  * \note This header and its content is not part of the Mbed TLS API and
13  * applications must not depend on it. Its main purpose is to define the
14  * multi-part state objects of the PSA drivers included in the cryptographic
15  * library. The definition of these objects are then used by crypto_struct.h
16  * to define the implementation-defined types of PSA multi-part state objects.
17  */
18 /*  Copyright The Mbed TLS Contributors
19  *  SPDX-License-Identifier: Apache-2.0
20  *
21  *  Licensed under the Apache License, Version 2.0 (the "License"); you may
22  *  not use this file except in compliance with the License.
23  *  You may obtain a copy of the License at
24  *
25  *  http://www.apache.org/licenses/LICENSE-2.0
26  *
27  *  Unless required by applicable law or agreed to in writing, software
28  *  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
29  *  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
30  *  See the License for the specific language governing permissions and
31  *  limitations under the License.
32  */
33 
34 #ifndef PSA_CRYPTO_DRIVER_CONTEXTS_COMPOSITES_H
35 #define PSA_CRYPTO_DRIVER_CONTEXTS_COMPOSITES_H
36 
37 #include "psa/crypto_driver_common.h"
38 
39 /* Include the context structure definitions for the Mbed TLS software drivers */
40 #include "psa/crypto_builtin_composites.h"
41 
42 /* Include the context structure definitions for those drivers that were
43  * declared during the autogeneration process. */
44 #if defined(PSA_CRYPTO_DRIVER_CC3XX)
45 #include "cc3xx_crypto_primitives_private.h"
46 #endif
47 
48 #if defined(MBEDTLS_TEST_LIBTESTDRIVER1)
49 #include <libtestdriver1/include/psa/crypto.h>
50 #endif
51 
52 #if defined(PSA_CRYPTO_DRIVER_TEST)
53 #if defined(MBEDTLS_TEST_LIBTESTDRIVER1) && \
54     defined(LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_MAC)
55 typedef libtestdriver1_mbedtls_psa_mac_operation_t
56         mbedtls_transparent_test_driver_mac_operation_t;
57 typedef libtestdriver1_mbedtls_psa_mac_operation_t
58         mbedtls_opaque_test_driver_mac_operation_t;
59 
60 #define MBEDTLS_TRANSPARENT_TEST_DRIVER_MAC_OPERATION_INIT \
61         LIBTESTDRIVER1_MBEDTLS_PSA_MAC_OPERATION_INIT
62 #define MBEDTLS_OPAQUE_TEST_DRIVER_MAC_OPERATION_INIT \
63         LIBTESTDRIVER1_MBEDTLS_PSA_MAC_OPERATION_INIT
64 
65 #else
66 typedef mbedtls_psa_mac_operation_t
67         mbedtls_transparent_test_driver_mac_operation_t;
68 typedef mbedtls_psa_mac_operation_t
69         mbedtls_opaque_test_driver_mac_operation_t;
70 
71 #define MBEDTLS_TRANSPARENT_TEST_DRIVER_MAC_OPERATION_INIT \
72         MBEDTLS_PSA_MAC_OPERATION_INIT
73 #define MBEDTLS_OPAQUE_TEST_DRIVER_MAC_OPERATION_INIT \
74         MBEDTLS_PSA_MAC_OPERATION_INIT
75 
76 #endif /* MBEDTLS_TEST_LIBTESTDRIVER1 && LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_MAC */
77 
78 #if defined(MBEDTLS_TEST_LIBTESTDRIVER1) && \
79     defined(LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_AEAD)
80 typedef libtestdriver1_mbedtls_psa_aead_operation_t
81         mbedtls_transparent_test_driver_aead_operation_t;
82 
83 #define MBEDTLS_TRANSPARENT_TEST_DRIVER_AEAD_OPERATION_INIT \
84         LIBTESTDRIVER1_MBEDTLS_PSA_AEAD_OPERATION_INIT
85 #else
86 typedef mbedtls_psa_aead_operation_t
87         mbedtls_transparent_test_driver_aead_operation_t;
88 
89 #define MBEDTLS_TRANSPARENT_TEST_DRIVER_AEAD_OPERATION_INIT \
90         MBEDTLS_PSA_AEAD_OPERATION_INIT
91 
92 #endif /* MBEDTLS_TEST_LIBTESTDRIVER1 && LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_AEAD */
93 
94 #endif /* PSA_CRYPTO_DRIVER_TEST */
95 
96 /* Define the context to be used for an operation that is executed through the
97  * PSA Driver wrapper layer as the union of all possible driver's contexts.
98  *
99  * The union members are the driver's context structures, and the member names
100  * are formatted as `'drivername'_ctx`. This allows for procedural generation
101  * of both this file and the content of psa_crypto_driver_wrappers.c */
102 
103 typedef union {
104     unsigned dummy; /* Make sure this union is always non-empty */
105     mbedtls_psa_mac_operation_t mbedtls_ctx;
106 #if defined(PSA_CRYPTO_DRIVER_TEST)
107     mbedtls_transparent_test_driver_mac_operation_t transparent_test_driver_ctx;
108     mbedtls_opaque_test_driver_mac_operation_t opaque_test_driver_ctx;
109 #endif
110 #if defined(PSA_CRYPTO_DRIVER_CC3XX)
111     cc3xx_mac_operation_t cc3xx_driver_ctx;
112 #endif
113 } psa_driver_mac_context_t;
114 
115 typedef union {
116     unsigned dummy; /* Make sure this union is always non-empty */
117     mbedtls_psa_aead_operation_t mbedtls_ctx;
118 #if defined(PSA_CRYPTO_DRIVER_TEST)
119     mbedtls_transparent_test_driver_aead_operation_t transparent_test_driver_ctx;
120 #endif
121 #if defined(PSA_CRYPTO_DRIVER_CC3XX)
122     cc3xx_aead_operation_t cc3xx_driver_ctx;
123 #endif /* PSA_CRYPTO_DRIVER_CC3XX */
124 } psa_driver_aead_context_t;
125 
126 #endif /* PSA_CRYPTO_DRIVER_CONTEXTS_COMPOSITES_H */
127 /* End of automatically generated file. */
128