Steven Cooreman | 3c8dd63 | 2021-04-26 12:16:27 +0200 | [diff] [blame] | 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 | * |
Ronald Cron | 789cef8 | 2023-03-27 16:31:19 +0200 | [diff] [blame^] | 12 | * \note This header and its content are not part of the Mbed TLS API and |
Steven Cooreman | 3c8dd63 | 2021-04-26 12:16:27 +0200 | [diff] [blame] | 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 |
Ronald Cron | 789cef8 | 2023-03-27 16:31:19 +0200 | [diff] [blame^] | 15 | * library. The definitions of these objects are then used by crypto_struct.h |
Steven Cooreman | 3c8dd63 | 2021-04-26 12:16:27 +0200 | [diff] [blame] | 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 | |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 39 | /* Include the context structure definitions for the Mbed TLS software drivers */ |
| 40 | #include "psa/crypto_builtin_composites.h" |
| 41 | |
Steven Cooreman | 3c8dd63 | 2021-04-26 12:16:27 +0200 | [diff] [blame] | 42 | /* Include the context structure definitions for those drivers that were |
| 43 | * declared during the autogeneration process. */ |
| 44 | |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 45 | #if defined(MBEDTLS_TEST_LIBTESTDRIVER1) |
| 46 | #include <libtestdriver1/include/psa/crypto.h> |
| 47 | #endif |
| 48 | |
| 49 | #if defined(PSA_CRYPTO_DRIVER_TEST) |
| 50 | #if defined(MBEDTLS_TEST_LIBTESTDRIVER1) && \ |
| 51 | defined(LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_MAC) |
| 52 | typedef libtestdriver1_mbedtls_psa_mac_operation_t |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 53 | mbedtls_transparent_test_driver_mac_operation_t; |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 54 | typedef libtestdriver1_mbedtls_psa_mac_operation_t |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 55 | mbedtls_opaque_test_driver_mac_operation_t; |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 56 | |
| 57 | #define MBEDTLS_TRANSPARENT_TEST_DRIVER_MAC_OPERATION_INIT \ |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 58 | LIBTESTDRIVER1_MBEDTLS_PSA_MAC_OPERATION_INIT |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 59 | #define MBEDTLS_OPAQUE_TEST_DRIVER_MAC_OPERATION_INIT \ |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 60 | LIBTESTDRIVER1_MBEDTLS_PSA_MAC_OPERATION_INIT |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 61 | |
| 62 | #else |
| 63 | typedef mbedtls_psa_mac_operation_t |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 64 | mbedtls_transparent_test_driver_mac_operation_t; |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 65 | typedef mbedtls_psa_mac_operation_t |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 66 | mbedtls_opaque_test_driver_mac_operation_t; |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 67 | |
| 68 | #define MBEDTLS_TRANSPARENT_TEST_DRIVER_MAC_OPERATION_INIT \ |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 69 | MBEDTLS_PSA_MAC_OPERATION_INIT |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 70 | #define MBEDTLS_OPAQUE_TEST_DRIVER_MAC_OPERATION_INIT \ |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 71 | MBEDTLS_PSA_MAC_OPERATION_INIT |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 72 | |
| 73 | #endif /* MBEDTLS_TEST_LIBTESTDRIVER1 && LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_MAC */ |
| 74 | |
| 75 | #if defined(MBEDTLS_TEST_LIBTESTDRIVER1) && \ |
| 76 | defined(LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_AEAD) |
| 77 | typedef libtestdriver1_mbedtls_psa_aead_operation_t |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 78 | mbedtls_transparent_test_driver_aead_operation_t; |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 79 | |
| 80 | #define MBEDTLS_TRANSPARENT_TEST_DRIVER_AEAD_OPERATION_INIT \ |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 81 | LIBTESTDRIVER1_MBEDTLS_PSA_AEAD_OPERATION_INIT |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 82 | #else |
| 83 | typedef mbedtls_psa_aead_operation_t |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 84 | mbedtls_transparent_test_driver_aead_operation_t; |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 85 | |
| 86 | #define MBEDTLS_TRANSPARENT_TEST_DRIVER_AEAD_OPERATION_INIT \ |
Gilles Peskine | 449bd83 | 2023-01-11 14:50:10 +0100 | [diff] [blame] | 87 | MBEDTLS_PSA_AEAD_OPERATION_INIT |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 88 | |
| 89 | #endif /* MBEDTLS_TEST_LIBTESTDRIVER1 && LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_AEAD */ |
| 90 | |
Przemek Stekiel | 96ae8b9 | 2022-12-07 11:52:08 +0100 | [diff] [blame] | 91 | #if defined(MBEDTLS_TEST_LIBTESTDRIVER1) && \ |
| 92 | defined(LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_PAKE) |
| 93 | |
| 94 | typedef libtestdriver1_mbedtls_psa_pake_operation_t |
| 95 | mbedtls_transparent_test_driver_pake_operation_t; |
Przemek Stekiel | 251e86a | 2023-02-17 14:30:50 +0100 | [diff] [blame] | 96 | typedef libtestdriver1_mbedtls_psa_pake_operation_t |
Przemek Stekiel | 96ae8b9 | 2022-12-07 11:52:08 +0100 | [diff] [blame] | 97 | mbedtls_opaque_test_driver_pake_operation_t; |
| 98 | |
| 99 | #define MBEDTLS_TRANSPARENT_TEST_DRIVER_PAKE_OPERATION_INIT \ |
| 100 | LIBTESTDRIVER1_MBEDTLS_PSA_PAKE_OPERATION_INIT |
| 101 | #define MBEDTLS_OPAQUE_TEST_DRIVER_PAKE_OPERATION_INIT \ |
| 102 | LIBTESTDRIVER1_MBEDTLS_PSA_PAKE_OPERATION_INIT |
| 103 | |
| 104 | #else |
| 105 | typedef mbedtls_psa_pake_operation_t |
| 106 | mbedtls_transparent_test_driver_pake_operation_t; |
| 107 | typedef mbedtls_psa_pake_operation_t |
| 108 | mbedtls_opaque_test_driver_pake_operation_t; |
| 109 | |
| 110 | #define MBEDTLS_TRANSPARENT_TEST_DRIVER_PAKE_OPERATION_INIT \ |
| 111 | MBEDTLS_PSA_PAKE_OPERATION_INIT |
| 112 | #define MBEDTLS_OPAQUE_TEST_DRIVER_PAKE_OPERATION_INIT \ |
| 113 | MBEDTLS_PSA_PAKE_OPERATION_INIT |
| 114 | |
| 115 | #endif /* MBEDTLS_TEST_LIBTESTDRIVER1 && LIBTESTDRIVER1_MBEDTLS_PSA_BUILTIN_PAKE */ |
| 116 | |
Ronald Cron | 7975fae | 2021-09-13 14:50:42 +0200 | [diff] [blame] | 117 | #endif /* PSA_CRYPTO_DRIVER_TEST */ |
Steven Cooreman | 3c8dd63 | 2021-04-26 12:16:27 +0200 | [diff] [blame] | 118 | |
| 119 | /* Define the context to be used for an operation that is executed through the |
| 120 | * PSA Driver wrapper layer as the union of all possible driver's contexts. |
| 121 | * |
| 122 | * The union members are the driver's context structures, and the member names |
| 123 | * are formatted as `'drivername'_ctx`. This allows for procedural generation |
| 124 | * of both this file and the content of psa_crypto_driver_wrappers.c */ |
| 125 | |
Steven Cooreman | d13a70f | 2021-03-19 15:24:23 +0100 | [diff] [blame] | 126 | typedef union { |
| 127 | unsigned dummy; /* Make sure this union is always non-empty */ |
| 128 | mbedtls_psa_mac_operation_t mbedtls_ctx; |
| 129 | #if defined(PSA_CRYPTO_DRIVER_TEST) |
| 130 | mbedtls_transparent_test_driver_mac_operation_t transparent_test_driver_ctx; |
| 131 | mbedtls_opaque_test_driver_mac_operation_t opaque_test_driver_ctx; |
| 132 | #endif |
| 133 | } psa_driver_mac_context_t; |
| 134 | |
Paul Elliott | 3dc1c24 | 2021-05-20 18:32:57 +0100 | [diff] [blame] | 135 | typedef union { |
| 136 | unsigned dummy; /* Make sure this union is always non-empty */ |
| 137 | mbedtls_psa_aead_operation_t mbedtls_ctx; |
| 138 | #if defined(PSA_CRYPTO_DRIVER_TEST) |
| 139 | mbedtls_transparent_test_driver_aead_operation_t transparent_test_driver_ctx; |
| 140 | #endif |
| 141 | } psa_driver_aead_context_t; |
| 142 | |
Paul Elliott | 588f8ed | 2022-12-02 18:10:26 +0000 | [diff] [blame] | 143 | typedef union { |
| 144 | unsigned dummy; /* Make sure this union is always non-empty */ |
| 145 | mbedtls_psa_sign_hash_interruptible_operation_t mbedtls_ctx; |
| 146 | } psa_driver_sign_hash_interruptible_context_t; |
| 147 | |
| 148 | typedef union { |
| 149 | unsigned dummy; /* Make sure this union is always non-empty */ |
| 150 | mbedtls_psa_verify_hash_interruptible_operation_t mbedtls_ctx; |
| 151 | } psa_driver_verify_hash_interruptible_context_t; |
| 152 | |
Przemek Stekiel | 96ae8b9 | 2022-12-07 11:52:08 +0100 | [diff] [blame] | 153 | typedef union { |
| 154 | unsigned dummy; /* Make sure this union is always non-empty */ |
| 155 | mbedtls_psa_pake_operation_t mbedtls_ctx; |
| 156 | #if defined(PSA_CRYPTO_DRIVER_TEST) |
| 157 | mbedtls_transparent_test_driver_pake_operation_t transparent_test_driver_ctx; |
| 158 | mbedtls_opaque_test_driver_pake_operation_t opaque_test_driver_ctx; |
| 159 | #endif |
| 160 | } psa_driver_pake_context_t; |
| 161 | |
Steven Cooreman | 3c8dd63 | 2021-04-26 12:16:27 +0200 | [diff] [blame] | 162 | #endif /* PSA_CRYPTO_DRIVER_CONTEXTS_COMPOSITES_H */ |
| 163 | /* End of automatically generated file. */ |