blob: 4c01214dc7cdca2186a4e90ece66aeaad62b593d [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 Rodgman7ff79652023-11-03 12:04:52 +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
11#if !defined(MBEDTLS_CONFIG_FILE)
12#include "mbedtls/config.h"
13#else
14#include MBEDTLS_CONFIG_FILE
15#endif
16
17#if defined(PSA_CRYPTO_DRIVER_TEST)
18#include <psa/crypto_driver_common.h>
19
Ronald Cronbfe551d2021-03-23 09:33:25 +010020typedef struct {
21 /* If not PSA_SUCCESS, return this error code instead of processing the
22 * function call. */
23 psa_status_t forced_status;
24 /* Count the amount of times AEAD driver functions are called. */
25 unsigned long hits;
26 /* Status returned by the last AEAD driver function call. */
27 psa_status_t driver_status;
Ronald Cronc4bc12e2021-04-13 12:41:34 +020028} mbedtls_test_driver_aead_hooks_t;
Ronald Cronbfe551d2021-03-23 09:33:25 +010029
Ronald Cronc4bc12e2021-04-13 12:41:34 +020030#define MBEDTLS_TEST_DRIVER_AEAD_INIT { 0, 0, 0 }
31static inline mbedtls_test_driver_aead_hooks_t
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010032mbedtls_test_driver_aead_hooks_init(void)
Ronald Cronbfe551d2021-03-23 09:33:25 +010033{
Ronald Cronc4bc12e2021-04-13 12:41:34 +020034 const mbedtls_test_driver_aead_hooks_t v = MBEDTLS_TEST_DRIVER_AEAD_INIT;
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010035 return v;
Ronald Cronbfe551d2021-03-23 09:33:25 +010036}
37
Ronald Cronc4bc12e2021-04-13 12:41:34 +020038extern mbedtls_test_driver_aead_hooks_t mbedtls_test_driver_aead_hooks;
Ronald Cronbfe551d2021-03-23 09:33:25 +010039
Ronald Cronc4bc12e2021-04-13 12:41:34 +020040psa_status_t mbedtls_test_transparent_aead_encrypt(
Ronald Cronde822812021-03-17 16:08:20 +010041 const psa_key_attributes_t *attributes,
42 const uint8_t *key_buffer, size_t key_buffer_size,
43 psa_algorithm_t alg,
44 const uint8_t *nonce, size_t nonce_length,
45 const uint8_t *additional_data, size_t additional_data_length,
46 const uint8_t *plaintext, size_t plaintext_length,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010047 uint8_t *ciphertext, size_t ciphertext_size, size_t *ciphertext_length);
Ronald Cronde822812021-03-17 16:08:20 +010048
Ronald Cronc4bc12e2021-04-13 12:41:34 +020049psa_status_t mbedtls_test_transparent_aead_decrypt(
Ronald Cronde822812021-03-17 16:08:20 +010050 const psa_key_attributes_t *attributes,
51 const uint8_t *key_buffer, size_t key_buffer_size,
52 psa_algorithm_t alg,
53 const uint8_t *nonce, size_t nonce_length,
54 const uint8_t *additional_data, size_t additional_data_length,
55 const uint8_t *ciphertext, size_t ciphertext_length,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010056 uint8_t *plaintext, size_t plaintext_size, size_t *plaintext_length);
Ronald Cronde822812021-03-17 16:08:20 +010057
58#endif /* PSA_CRYPTO_DRIVER_TEST */
59#endif /* PSA_CRYPTO_TEST_DRIVERS_AEAD_H */