blob: a9a0d6c8ce8f0aed70c783a340046f264ddf6078 [file] [log] [blame]
Steven Cooremancd84cb42020-07-16 20:28:36 +02001/*
2 * Function signatures for functionality that can be provided by
3 * cryptographic accelerators.
Steven Cooremancd84cb42020-07-16 20:28:36 +02004 */
Steven Cooreman2c7b2f82020-09-02 13:43:46 +02005/* Copyright The Mbed TLS Contributors
Steven Cooremancd84cb42020-07-16 20:28:36 +02006 * SPDX-License-Identifier: Apache-2.0
7 *
8 * Licensed under the Apache License, Version 2.0 (the "License"); you may
9 * not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
11 *
12 * http://www.apache.org/licenses/LICENSE-2.0
13 *
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
16 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
Steven Cooremancd84cb42020-07-16 20:28:36 +020019 */
20
21#ifndef PSA_CRYPTO_DRIVER_WRAPPERS_H
22#define PSA_CRYPTO_DRIVER_WRAPPERS_H
23
24#include "psa/crypto.h"
25#include "psa/crypto_driver_common.h"
26
Steven Cooreman37941cb2020-07-28 18:49:51 +020027/*
28 * Signature functions
29 */
gabor-mezei-arm50eac352021-04-22 11:32:19 +020030psa_status_t psa_driver_wrapper_sign_message(
31 const psa_key_attributes_t *attributes,
32 const uint8_t *key_buffer,
33 size_t key_buffer_size,
34 psa_algorithm_t alg,
35 const uint8_t *input,
36 size_t input_length,
37 uint8_t *signature,
38 size_t signature_size,
39 size_t *signature_length );
40
41psa_status_t psa_driver_wrapper_verify_message(
42 const psa_key_attributes_t *attributes,
43 const uint8_t *key_buffer,
44 size_t key_buffer_size,
45 psa_algorithm_t alg,
46 const uint8_t *input,
47 size_t input_length,
48 const uint8_t *signature,
49 size_t signature_length );
50
Ronald Cron9f17aa42020-12-08 17:07:25 +010051psa_status_t psa_driver_wrapper_sign_hash(
52 const psa_key_attributes_t *attributes,
53 const uint8_t *key_buffer, size_t key_buffer_size,
54 psa_algorithm_t alg, const uint8_t *hash, size_t hash_length,
55 uint8_t *signature, size_t signature_size, size_t *signature_length );
Steven Cooremancd84cb42020-07-16 20:28:36 +020056
Ronald Cron9f17aa42020-12-08 17:07:25 +010057psa_status_t psa_driver_wrapper_verify_hash(
58 const psa_key_attributes_t *attributes,
59 const uint8_t *key_buffer, size_t key_buffer_size,
60 psa_algorithm_t alg, const uint8_t *hash, size_t hash_length,
61 const uint8_t *signature, size_t signature_length );
Steven Cooreman55ae2172020-07-17 19:46:15 +020062
Steven Cooreman04524762020-10-13 17:43:44 +020063/*
64 * Key handling functions
65 */
66
Ronald Cron83282872020-11-22 14:02:39 +010067psa_status_t psa_driver_wrapper_import_key(
68 const psa_key_attributes_t *attributes,
69 const uint8_t *data, size_t data_length,
70 uint8_t *key_buffer, size_t key_buffer_size,
71 size_t *key_buffer_length, size_t *bits );
Steven Cooreman04524762020-10-13 17:43:44 +020072
Ronald Cron67227982020-11-26 15:16:05 +010073psa_status_t psa_driver_wrapper_export_key(
74 const psa_key_attributes_t *attributes,
75 const uint8_t *key_buffer, size_t key_buffer_size,
76 uint8_t *data, size_t data_size, size_t *data_length );
77
Ronald Cron84cc9942020-11-25 14:30:05 +010078psa_status_t psa_driver_wrapper_export_public_key(
79 const psa_key_attributes_t *attributes,
80 const uint8_t *key_buffer, size_t key_buffer_size,
81 uint8_t *data, size_t data_size, size_t *data_length );
82
Ronald Cron9df74be2020-12-05 19:15:23 +010083psa_status_t psa_driver_wrapper_get_key_buffer_size(
84 const psa_key_attributes_t *attributes,
85 size_t *key_buffer_size );
86
Archanad8a83dc2021-06-14 10:04:16 +053087psa_status_t psa_driver_wrapper_get_key_buffer_size_from_key_data(
88 const psa_key_attributes_t *attributes,
89 const uint8_t *data,
90 size_t data_length,
91 size_t *key_buffer_size );
92
Ronald Cron84cc9942020-11-25 14:30:05 +010093psa_status_t psa_driver_wrapper_generate_key(
94 const psa_key_attributes_t *attributes,
Ronald Cron977c2472020-10-13 08:32:21 +020095 uint8_t *key_buffer, size_t key_buffer_size, size_t *key_buffer_length );
Steven Cooremanb9b84422020-10-14 14:39:20 +020096
Steven Cooreman6801f082021-02-19 17:21:22 +010097psa_status_t psa_driver_wrapper_get_builtin_key(
98 psa_drv_slot_number_t slot_number,
99 psa_key_attributes_t *attributes,
100 uint8_t *key_buffer, size_t key_buffer_size, size_t *key_buffer_length );
101
Archana8a180362021-07-05 02:18:48 +0530102psa_status_t psa_driver_wrapper_copy_key(
103 psa_key_attributes_t *attributes,
Archana9d17bf42021-09-10 06:22:44 +0530104 const uint8_t *source_key, size_t source_key_length,
Archana449608b2021-09-08 15:36:05 +0530105 uint8_t *target_key_buffer, size_t target_key_buffer_size,
106 size_t *target_key_buffer_length );
Steven Cooreman37941cb2020-07-28 18:49:51 +0200107/*
108 * Cipher functions
109 */
110psa_status_t psa_driver_wrapper_cipher_encrypt(
gabor-mezei-arma9449a02021-03-25 11:17:10 +0100111 const psa_key_attributes_t *attributes,
112 const uint8_t *key_buffer,
113 size_t key_buffer_size,
Steven Cooreman37941cb2020-07-28 18:49:51 +0200114 psa_algorithm_t alg,
115 const uint8_t *input,
116 size_t input_length,
117 uint8_t *output,
118 size_t output_size,
119 size_t *output_length );
120
121psa_status_t psa_driver_wrapper_cipher_decrypt(
gabor-mezei-arma9449a02021-03-25 11:17:10 +0100122 const psa_key_attributes_t *attributes,
123 const uint8_t *key_buffer,
124 size_t key_buffer_size,
Steven Cooreman37941cb2020-07-28 18:49:51 +0200125 psa_algorithm_t alg,
126 const uint8_t *input,
127 size_t input_length,
128 uint8_t *output,
129 size_t output_size,
130 size_t *output_length );
131
132psa_status_t psa_driver_wrapper_cipher_encrypt_setup(
Ronald Crona4af55f2020-12-14 14:36:06 +0100133 psa_cipher_operation_t *operation,
134 const psa_key_attributes_t *attributes,
135 const uint8_t *key_buffer, size_t key_buffer_size,
Steven Cooreman37941cb2020-07-28 18:49:51 +0200136 psa_algorithm_t alg );
137
138psa_status_t psa_driver_wrapper_cipher_decrypt_setup(
Ronald Crona4af55f2020-12-14 14:36:06 +0100139 psa_cipher_operation_t *operation,
140 const psa_key_attributes_t *attributes,
141 const uint8_t *key_buffer, size_t key_buffer_size,
Steven Cooreman37941cb2020-07-28 18:49:51 +0200142 psa_algorithm_t alg );
143
Steven Cooreman37941cb2020-07-28 18:49:51 +0200144psa_status_t psa_driver_wrapper_cipher_set_iv(
Ronald Cron6056fe82020-12-15 13:58:07 +0100145 psa_cipher_operation_t *operation,
Steven Cooreman37941cb2020-07-28 18:49:51 +0200146 const uint8_t *iv,
147 size_t iv_length );
148
149psa_status_t psa_driver_wrapper_cipher_update(
Ronald Cron6056fe82020-12-15 13:58:07 +0100150 psa_cipher_operation_t *operation,
Steven Cooreman37941cb2020-07-28 18:49:51 +0200151 const uint8_t *input,
152 size_t input_length,
153 uint8_t *output,
154 size_t output_size,
155 size_t *output_length );
156
157psa_status_t psa_driver_wrapper_cipher_finish(
Ronald Cron6056fe82020-12-15 13:58:07 +0100158 psa_cipher_operation_t *operation,
Steven Cooreman37941cb2020-07-28 18:49:51 +0200159 uint8_t *output,
160 size_t output_size,
161 size_t *output_length );
162
163psa_status_t psa_driver_wrapper_cipher_abort(
Ronald Cron6056fe82020-12-15 13:58:07 +0100164 psa_cipher_operation_t *operation );
Steven Cooreman37941cb2020-07-28 18:49:51 +0200165
Steven Cooreman1e582352021-02-18 17:24:37 +0100166/*
167 * Hashing functions
168 */
169psa_status_t psa_driver_wrapper_hash_compute(
170 psa_algorithm_t alg,
171 const uint8_t *input,
172 size_t input_length,
173 uint8_t *hash,
174 size_t hash_size,
175 size_t *hash_length);
176
177psa_status_t psa_driver_wrapper_hash_setup(
Steven Cooremandbf8ced2021-03-04 13:01:18 +0100178 psa_hash_operation_t *operation,
Steven Cooreman1e582352021-02-18 17:24:37 +0100179 psa_algorithm_t alg );
180
181psa_status_t psa_driver_wrapper_hash_clone(
Steven Cooremandbf8ced2021-03-04 13:01:18 +0100182 const psa_hash_operation_t *source_operation,
183 psa_hash_operation_t *target_operation );
Steven Cooreman1e582352021-02-18 17:24:37 +0100184
185psa_status_t psa_driver_wrapper_hash_update(
Steven Cooremandbf8ced2021-03-04 13:01:18 +0100186 psa_hash_operation_t *operation,
Steven Cooreman1e582352021-02-18 17:24:37 +0100187 const uint8_t *input,
188 size_t input_length );
189
190psa_status_t psa_driver_wrapper_hash_finish(
Steven Cooremandbf8ced2021-03-04 13:01:18 +0100191 psa_hash_operation_t *operation,
Steven Cooreman1e582352021-02-18 17:24:37 +0100192 uint8_t *hash,
193 size_t hash_size,
194 size_t *hash_length );
195
196psa_status_t psa_driver_wrapper_hash_abort(
Steven Cooremandbf8ced2021-03-04 13:01:18 +0100197 psa_hash_operation_t *operation );
Steven Cooreman1e582352021-02-18 17:24:37 +0100198
Ronald Cronde822812021-03-17 16:08:20 +0100199/*
200 * AEAD functions
201 */
202
203psa_status_t psa_driver_wrapper_aead_encrypt(
204 const psa_key_attributes_t *attributes,
205 const uint8_t *key_buffer, size_t key_buffer_size,
206 psa_algorithm_t alg,
207 const uint8_t *nonce, size_t nonce_length,
208 const uint8_t *additional_data, size_t additional_data_length,
209 const uint8_t *plaintext, size_t plaintext_length,
210 uint8_t *ciphertext, size_t ciphertext_size, size_t *ciphertext_length );
211
212psa_status_t psa_driver_wrapper_aead_decrypt(
213 const psa_key_attributes_t *attributes,
214 const uint8_t *key_buffer, size_t key_buffer_size,
215 psa_algorithm_t alg,
216 const uint8_t *nonce, size_t nonce_length,
217 const uint8_t *additional_data, size_t additional_data_length,
218 const uint8_t *ciphertext, size_t ciphertext_length,
219 uint8_t *plaintext, size_t plaintext_size, size_t *plaintext_length );
220
Paul Elliott6504aa62021-04-20 17:09:36 +0100221psa_status_t psa_driver_wrapper_aead_encrypt_setup(
222 psa_aead_operation_t *operation,
223 const psa_key_attributes_t *attributes,
224 const uint8_t *key_buffer, size_t key_buffer_size,
225 psa_algorithm_t alg );
226
227psa_status_t psa_driver_wrapper_aead_decrypt_setup(
228 psa_aead_operation_t *operation,
229 const psa_key_attributes_t *attributes,
230 const uint8_t *key_buffer, size_t key_buffer_size,
231 psa_algorithm_t alg );
232
Paul Elliott6504aa62021-04-20 17:09:36 +0100233psa_status_t psa_driver_wrapper_aead_set_nonce(
234 psa_aead_operation_t *operation,
235 const uint8_t *nonce,
236 size_t nonce_length );
237
238psa_status_t psa_driver_wrapper_aead_set_lengths(
239 psa_aead_operation_t *operation,
240 size_t ad_length,
241 size_t plaintext_length );
242
243psa_status_t psa_driver_wrapper_aead_update_ad(
244 psa_aead_operation_t *operation,
245 const uint8_t *input,
246 size_t input_length );
247
248psa_status_t psa_driver_wrapper_aead_update(
249 psa_aead_operation_t *operation,
250 const uint8_t *input,
251 size_t input_length,
252 uint8_t *output,
253 size_t output_size,
254 size_t *output_length );
255
256psa_status_t psa_driver_wrapper_aead_finish(
257 psa_aead_operation_t *operation,
258 uint8_t *ciphertext,
259 size_t ciphertext_size,
260 size_t *ciphertext_length,
261 uint8_t *tag,
262 size_t tag_size,
263 size_t *tag_length );
264
265psa_status_t psa_driver_wrapper_aead_verify(
266 psa_aead_operation_t *operation,
267 uint8_t *plaintext,
268 size_t plaintext_size,
269 size_t *plaintext_length,
270 const uint8_t *tag,
271 size_t tag_length );
272
273psa_status_t psa_driver_wrapper_aead_abort(
274 psa_aead_operation_t *operation );
275
Steven Cooremand13a70f2021-03-19 15:24:23 +0100276/*
277 * MAC functions
278 */
279psa_status_t psa_driver_wrapper_mac_compute(
280 const psa_key_attributes_t *attributes,
281 const uint8_t *key_buffer,
282 size_t key_buffer_size,
283 psa_algorithm_t alg,
284 const uint8_t *input,
285 size_t input_length,
286 uint8_t *mac,
287 size_t mac_size,
288 size_t *mac_length );
289
290psa_status_t psa_driver_wrapper_mac_sign_setup(
291 psa_mac_operation_t *operation,
292 const psa_key_attributes_t *attributes,
293 const uint8_t *key_buffer,
294 size_t key_buffer_size,
295 psa_algorithm_t alg );
296
297psa_status_t psa_driver_wrapper_mac_verify_setup(
298 psa_mac_operation_t *operation,
299 const psa_key_attributes_t *attributes,
300 const uint8_t *key_buffer,
301 size_t key_buffer_size,
302 psa_algorithm_t alg );
303
304psa_status_t psa_driver_wrapper_mac_update(
305 psa_mac_operation_t *operation,
306 const uint8_t *input,
307 size_t input_length );
308
309psa_status_t psa_driver_wrapper_mac_sign_finish(
310 psa_mac_operation_t *operation,
311 uint8_t *mac,
312 size_t mac_size,
313 size_t *mac_length );
314
315psa_status_t psa_driver_wrapper_mac_verify_finish(
316 psa_mac_operation_t *operation,
317 const uint8_t *mac,
318 size_t mac_length );
319
320psa_status_t psa_driver_wrapper_mac_abort(
321 psa_mac_operation_t *operation );
322
Steven Cooremancd84cb42020-07-16 20:28:36 +0200323#endif /* PSA_CRYPTO_DRIVER_WRAPPERS_H */
324
325/* End of automatically generated file. */