blob: a033e399d0699ed2d31053a31dc073d2216f72a0 [file] [log] [blame]
Ronald Cronde822812021-03-17 16:08:20 +01001/*
2 * Test driver for AEAD driver entry points.
3 */
4/* Copyright The Mbed TLS Contributors
Dave Rodgman16799db2023-11-02 19:47:20 +00005 * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
Ronald Cronde822812021-03-17 16:08:20 +01006 */
7
8#ifndef PSA_CRYPTO_TEST_DRIVERS_AEAD_H
9#define PSA_CRYPTO_TEST_DRIVERS_AEAD_H
10
Bence Szépkútic662b362021-05-27 11:25:03 +020011#include "mbedtls/build_info.h"
Ronald Cronde822812021-03-17 16:08:20 +010012
13#if defined(PSA_CRYPTO_DRIVER_TEST)
14#include <psa/crypto_driver_common.h>
15
Ronald Cronbfe551d2021-03-23 09:33:25 +010016typedef struct {
17 /* If not PSA_SUCCESS, return this error code instead of processing the
18 * function call. */
19 psa_status_t forced_status;
20 /* Count the amount of times AEAD driver functions are called. */
Paul Elliottfcb5cdc2021-06-23 09:40:12 +010021 unsigned long hits_encrypt;
22 unsigned long hits_decrypt;
23 unsigned long hits_encrypt_setup;
24 unsigned long hits_decrypt_setup;
25 unsigned long hits_set_nonce;
26 unsigned long hits_set_lengths;
27 unsigned long hits_update_ad;
28 unsigned long hits_update;
29 unsigned long hits_finish;
30 unsigned long hits_verify;
31 unsigned long hits_abort;
32
Ronald Cronbfe551d2021-03-23 09:33:25 +010033 /* Status returned by the last AEAD driver function call. */
34 psa_status_t driver_status;
Ronald Cron7f13fa22021-04-13 12:41:34 +020035} mbedtls_test_driver_aead_hooks_t;
Ronald Cronbfe551d2021-03-23 09:33:25 +010036
Paul Elliottfcb5cdc2021-06-23 09:40:12 +010037#define MBEDTLS_TEST_DRIVER_AEAD_INIT { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }
Ronald Cron7f13fa22021-04-13 12:41:34 +020038static inline mbedtls_test_driver_aead_hooks_t
Gilles Peskine449bd832023-01-11 14:50:10 +010039mbedtls_test_driver_aead_hooks_init(void)
Ronald Cronbfe551d2021-03-23 09:33:25 +010040{
Ronald Cron7f13fa22021-04-13 12:41:34 +020041 const mbedtls_test_driver_aead_hooks_t v = MBEDTLS_TEST_DRIVER_AEAD_INIT;
Gilles Peskine449bd832023-01-11 14:50:10 +010042 return v;
Ronald Cronbfe551d2021-03-23 09:33:25 +010043}
44
Ronald Cron7f13fa22021-04-13 12:41:34 +020045extern mbedtls_test_driver_aead_hooks_t mbedtls_test_driver_aead_hooks;
Ronald Cronbfe551d2021-03-23 09:33:25 +010046
Ronald Cron7f13fa22021-04-13 12:41:34 +020047psa_status_t mbedtls_test_transparent_aead_encrypt(
Ronald Cronde822812021-03-17 16:08:20 +010048 const psa_key_attributes_t *attributes,
49 const uint8_t *key_buffer, size_t key_buffer_size,
50 psa_algorithm_t alg,
51 const uint8_t *nonce, size_t nonce_length,
52 const uint8_t *additional_data, size_t additional_data_length,
53 const uint8_t *plaintext, size_t plaintext_length,
Gilles Peskine449bd832023-01-11 14:50:10 +010054 uint8_t *ciphertext, size_t ciphertext_size, size_t *ciphertext_length);
Ronald Cronde822812021-03-17 16:08:20 +010055
Ronald Cron7f13fa22021-04-13 12:41:34 +020056psa_status_t mbedtls_test_transparent_aead_decrypt(
Ronald Cronde822812021-03-17 16:08:20 +010057 const psa_key_attributes_t *attributes,
58 const uint8_t *key_buffer, size_t key_buffer_size,
59 psa_algorithm_t alg,
60 const uint8_t *nonce, size_t nonce_length,
61 const uint8_t *additional_data, size_t additional_data_length,
62 const uint8_t *ciphertext, size_t ciphertext_length,
Gilles Peskine449bd832023-01-11 14:50:10 +010063 uint8_t *plaintext, size_t plaintext_size, size_t *plaintext_length);
Ronald Cronde822812021-03-17 16:08:20 +010064
Paul Elliotta218ceb2021-05-07 15:10:31 +010065psa_status_t mbedtls_test_transparent_aead_encrypt_setup(
Ronald Cron9a37ff62021-12-02 17:50:50 +010066 mbedtls_transparent_test_driver_aead_operation_t *operation,
Paul Elliott4bbe82b2021-04-27 12:11:56 +010067 const psa_key_attributes_t *attributes,
68 const uint8_t *key_buffer, size_t key_buffer_size,
Gilles Peskine449bd832023-01-11 14:50:10 +010069 psa_algorithm_t alg);
Paul Elliott4bbe82b2021-04-27 12:11:56 +010070
Paul Elliotta218ceb2021-05-07 15:10:31 +010071psa_status_t mbedtls_test_transparent_aead_decrypt_setup(
Ronald Cron9a37ff62021-12-02 17:50:50 +010072 mbedtls_transparent_test_driver_aead_operation_t *operation,
Paul Elliott4bbe82b2021-04-27 12:11:56 +010073 const psa_key_attributes_t *attributes,
74 const uint8_t *key_buffer, size_t key_buffer_size,
Gilles Peskine449bd832023-01-11 14:50:10 +010075 psa_algorithm_t alg);
Paul Elliott4bbe82b2021-04-27 12:11:56 +010076
Paul Elliotta218ceb2021-05-07 15:10:31 +010077psa_status_t mbedtls_test_transparent_aead_set_nonce(
Ronald Cron9a37ff62021-12-02 17:50:50 +010078 mbedtls_transparent_test_driver_aead_operation_t *operation,
Paul Elliott4bbe82b2021-04-27 12:11:56 +010079 const uint8_t *nonce,
Gilles Peskine449bd832023-01-11 14:50:10 +010080 size_t nonce_length);
Paul Elliott4bbe82b2021-04-27 12:11:56 +010081
Paul Elliotta218ceb2021-05-07 15:10:31 +010082psa_status_t mbedtls_test_transparent_aead_set_lengths(
Ronald Cron9a37ff62021-12-02 17:50:50 +010083 mbedtls_transparent_test_driver_aead_operation_t *operation,
Paul Elliott4bbe82b2021-04-27 12:11:56 +010084 size_t ad_length,
Gilles Peskine449bd832023-01-11 14:50:10 +010085 size_t plaintext_length);
Paul Elliott4bbe82b2021-04-27 12:11:56 +010086
Paul Elliotta218ceb2021-05-07 15:10:31 +010087psa_status_t mbedtls_test_transparent_aead_update_ad(
Ronald Cron9a37ff62021-12-02 17:50:50 +010088 mbedtls_transparent_test_driver_aead_operation_t *operation,
Paul Elliott4bbe82b2021-04-27 12:11:56 +010089 const uint8_t *input,
Gilles Peskine449bd832023-01-11 14:50:10 +010090 size_t input_length);
Paul Elliott4bbe82b2021-04-27 12:11:56 +010091
Paul Elliotta218ceb2021-05-07 15:10:31 +010092psa_status_t mbedtls_test_transparent_aead_update(
Gilles Peskine449bd832023-01-11 14:50:10 +010093 mbedtls_transparent_test_driver_aead_operation_t *operation,
94 const uint8_t *input,
95 size_t input_length,
96 uint8_t *output,
97 size_t output_size,
98 size_t *output_length);
Paul Elliott4bbe82b2021-04-27 12:11:56 +010099
Paul Elliotta218ceb2021-05-07 15:10:31 +0100100psa_status_t mbedtls_test_transparent_aead_finish(
Gilles Peskine449bd832023-01-11 14:50:10 +0100101 mbedtls_transparent_test_driver_aead_operation_t *operation,
102 uint8_t *ciphertext,
103 size_t ciphertext_size,
104 size_t *ciphertext_length,
105 uint8_t *tag,
106 size_t tag_size,
107 size_t *tag_length);
Paul Elliott4bbe82b2021-04-27 12:11:56 +0100108
Paul Elliotta218ceb2021-05-07 15:10:31 +0100109psa_status_t mbedtls_test_transparent_aead_verify(
Gilles Peskine449bd832023-01-11 14:50:10 +0100110 mbedtls_transparent_test_driver_aead_operation_t *operation,
111 uint8_t *plaintext,
112 size_t plaintext_size,
113 size_t *plaintext_length,
114 const uint8_t *tag,
115 size_t tag_length);
Paul Elliott4bbe82b2021-04-27 12:11:56 +0100116
Paul Elliotta218ceb2021-05-07 15:10:31 +0100117psa_status_t mbedtls_test_transparent_aead_abort(
Gilles Peskine449bd832023-01-11 14:50:10 +0100118 mbedtls_transparent_test_driver_aead_operation_t *operation);
Paul Elliott4bbe82b2021-04-27 12:11:56 +0100119
Ronald Cronde822812021-03-17 16:08:20 +0100120#endif /* PSA_CRYPTO_DRIVER_TEST */
121#endif /* PSA_CRYPTO_TEST_DRIVERS_AEAD_H */