blob: 71008a03a063b164497f0d1c1d9264671aacd2f4 [file] [log] [blame]
Steven Cooreman2d9a3f92021-04-29 21:10:11 +02001/*
2 * Test driver for MAC 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
Steven Cooreman2d9a3f92021-04-29 21:10:11 +02006 */
7
8#ifndef PSA_CRYPTO_TEST_DRIVERS_MAC_H
9#define PSA_CRYPTO_TEST_DRIVERS_MAC_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
20typedef 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 MAC driver functions are called. */
25 unsigned long hits;
26 /* Status returned by the last MAC driver function call. */
27 psa_status_t driver_status;
Steven Cooremanbe21dab2021-05-10 11:18:20 +020028} mbedtls_test_driver_mac_hooks_t;
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020029
30#define MBEDTLS_TEST_DRIVER_MAC_INIT { 0, 0, 0 }
Steven Cooremanbe21dab2021-05-10 11:18:20 +020031static inline mbedtls_test_driver_mac_hooks_t
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010032mbedtls_test_driver_mac_hooks_init(void)
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020033{
Steven Cooremanbe21dab2021-05-10 11:18:20 +020034 const mbedtls_test_driver_mac_hooks_t v = MBEDTLS_TEST_DRIVER_MAC_INIT;
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010035 return v;
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020036}
37
Steven Cooremanbe21dab2021-05-10 11:18:20 +020038extern mbedtls_test_driver_mac_hooks_t mbedtls_test_driver_mac_hooks;
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020039
40psa_status_t mbedtls_test_transparent_mac_compute(
41 const psa_key_attributes_t *attributes,
42 const uint8_t *key_buffer,
43 size_t key_buffer_size,
44 psa_algorithm_t alg,
45 const uint8_t *input,
46 size_t input_length,
47 uint8_t *mac,
48 size_t mac_size,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010049 size_t *mac_length);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020050
51psa_status_t mbedtls_test_transparent_mac_sign_setup(
52 mbedtls_transparent_test_driver_mac_operation_t *operation,
53 const psa_key_attributes_t *attributes,
54 const uint8_t *key_buffer,
55 size_t key_buffer_size,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010056 psa_algorithm_t alg);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020057
58psa_status_t mbedtls_test_transparent_mac_verify_setup(
59 mbedtls_transparent_test_driver_mac_operation_t *operation,
60 const psa_key_attributes_t *attributes,
61 const uint8_t *key_buffer,
62 size_t key_buffer_size,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010063 psa_algorithm_t alg);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020064
65psa_status_t mbedtls_test_transparent_mac_update(
66 mbedtls_transparent_test_driver_mac_operation_t *operation,
67 const uint8_t *input,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010068 size_t input_length);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020069
70psa_status_t mbedtls_test_transparent_mac_sign_finish(
71 mbedtls_transparent_test_driver_mac_operation_t *operation,
72 uint8_t *mac,
73 size_t mac_size,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010074 size_t *mac_length);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020075
76psa_status_t mbedtls_test_transparent_mac_verify_finish(
77 mbedtls_transparent_test_driver_mac_operation_t *operation,
78 const uint8_t *mac,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010079 size_t mac_length);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020080
81psa_status_t mbedtls_test_transparent_mac_abort(
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010082 mbedtls_transparent_test_driver_mac_operation_t *operation);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020083
84psa_status_t mbedtls_test_opaque_mac_compute(
85 const psa_key_attributes_t *attributes,
86 const uint8_t *key_buffer,
87 size_t key_buffer_size,
88 psa_algorithm_t alg,
89 const uint8_t *input,
90 size_t input_length,
91 uint8_t *mac,
92 size_t mac_size,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010093 size_t *mac_length);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +020094
95psa_status_t mbedtls_test_opaque_mac_sign_setup(
96 mbedtls_opaque_test_driver_mac_operation_t *operation,
97 const psa_key_attributes_t *attributes,
98 const uint8_t *key_buffer,
99 size_t key_buffer_size,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +0100100 psa_algorithm_t alg);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +0200101
102psa_status_t mbedtls_test_opaque_mac_verify_setup(
103 mbedtls_opaque_test_driver_mac_operation_t *operation,
104 const psa_key_attributes_t *attributes,
105 const uint8_t *key_buffer,
106 size_t key_buffer_size,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +0100107 psa_algorithm_t alg);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +0200108
109psa_status_t mbedtls_test_opaque_mac_update(
110 mbedtls_opaque_test_driver_mac_operation_t *operation,
111 const uint8_t *input,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +0100112 size_t input_length);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +0200113
114psa_status_t mbedtls_test_opaque_mac_sign_finish(
115 mbedtls_opaque_test_driver_mac_operation_t *operation,
116 uint8_t *mac,
117 size_t mac_size,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +0100118 size_t *mac_length);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +0200119
120psa_status_t mbedtls_test_opaque_mac_verify_finish(
121 mbedtls_opaque_test_driver_mac_operation_t *operation,
122 const uint8_t *mac,
Gilles Peskine1b6c09a2023-01-11 14:52:35 +0100123 size_t mac_length);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +0200124
125psa_status_t mbedtls_test_opaque_mac_abort(
Gilles Peskine1b6c09a2023-01-11 14:52:35 +0100126 mbedtls_opaque_test_driver_mac_operation_t *operation);
Steven Cooreman2d9a3f92021-04-29 21:10:11 +0200127
128#endif /* PSA_CRYPTO_DRIVER_TEST */
129#endif /* PSA_CRYPTO_TEST_DRIVERS_MAC_H */