blob: cfcf162e90240f1d225a2ad9d91ac9a1ea086cf1 [file] [log] [blame]
Steven Cooremanc7f0a572021-04-29 21:10:11 +02001/*
2 * Test driver for MAC entry points.
3 */
4/* Copyright The Mbed TLS Contributors
5 * SPDX-License-Identifier: Apache-2.0
6 *
7 * Licensed under the Apache License, Version 2.0 (the "License"); you may
8 * not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
10 *
11 * http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
15 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 */
19
Mateusz Starzykb4a01292021-05-27 14:49:25 +020020#include <test/helpers.h>
Steven Cooremanc7f0a572021-04-29 21:10:11 +020021
22#if defined(MBEDTLS_PSA_CRYPTO_DRIVERS) && defined(PSA_CRYPTO_DRIVER_TEST)
23#include "psa_crypto_mac.h"
24
25#include "test/drivers/mac.h"
26
Steven Cooremanae3ec522021-05-10 11:18:20 +020027mbedtls_test_driver_mac_hooks_t mbedtls_test_driver_mac_hooks =
28 MBEDTLS_TEST_DRIVER_MAC_INIT;
Steven Cooremanc7f0a572021-04-29 21:10:11 +020029
30psa_status_t mbedtls_test_transparent_mac_compute(
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 *mac,
38 size_t mac_size,
39 size_t *mac_length )
40{
Steven Cooremanae3ec522021-05-10 11:18:20 +020041 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +020042
Steven Cooremanae3ec522021-05-10 11:18:20 +020043 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +020044 {
Steven Cooremanae3ec522021-05-10 11:18:20 +020045 mbedtls_test_driver_mac_hooks.driver_status =
46 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +020047 }
48 else
49 {
Steven Cooremanae3ec522021-05-10 11:18:20 +020050 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +020051 mbedtls_transparent_test_driver_mac_compute(
52 attributes, key_buffer, key_buffer_size, alg,
53 input, input_length,
54 mac, mac_size, mac_length );
55 }
56
Mateusz Starzyke36f5b12021-07-22 16:43:35 +020057 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +020058}
59
60psa_status_t mbedtls_test_transparent_mac_sign_setup(
61 mbedtls_transparent_test_driver_mac_operation_t *operation,
62 const psa_key_attributes_t *attributes,
63 const uint8_t *key_buffer,
64 size_t key_buffer_size,
65 psa_algorithm_t alg )
66{
Steven Cooremanae3ec522021-05-10 11:18:20 +020067 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +020068
Steven Cooremanae3ec522021-05-10 11:18:20 +020069 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +020070 {
Steven Cooremanae3ec522021-05-10 11:18:20 +020071 mbedtls_test_driver_mac_hooks.driver_status =
72 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +020073 }
74 else
75 {
Steven Cooremanae3ec522021-05-10 11:18:20 +020076 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +020077 mbedtls_transparent_test_driver_mac_sign_setup(
78 operation, attributes, key_buffer, key_buffer_size, alg );
79 }
80
Mateusz Starzyke36f5b12021-07-22 16:43:35 +020081 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +020082}
83
84psa_status_t mbedtls_test_transparent_mac_verify_setup(
85 mbedtls_transparent_test_driver_mac_operation_t *operation,
86 const psa_key_attributes_t *attributes,
87 const uint8_t *key_buffer,
88 size_t key_buffer_size,
89 psa_algorithm_t alg )
90{
Steven Cooremanae3ec522021-05-10 11:18:20 +020091 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +020092
Steven Cooremanae3ec522021-05-10 11:18:20 +020093 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +020094 {
Steven Cooremanae3ec522021-05-10 11:18:20 +020095 mbedtls_test_driver_mac_hooks.driver_status =
96 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +020097 }
98 else
99 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200100 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200101 mbedtls_transparent_test_driver_mac_verify_setup(
102 operation, attributes, key_buffer, key_buffer_size, alg );
103 }
104
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200105 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200106}
107
108psa_status_t mbedtls_test_transparent_mac_update(
109 mbedtls_transparent_test_driver_mac_operation_t *operation,
110 const uint8_t *input,
111 size_t input_length )
112{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200113 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200114
Steven Cooremanae3ec522021-05-10 11:18:20 +0200115 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200116 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200117 mbedtls_test_driver_mac_hooks.driver_status =
118 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200119 }
120 else
121 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200122 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200123 mbedtls_transparent_test_driver_mac_update(
124 operation, input, input_length );
125 }
126
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200127 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200128}
129
130psa_status_t mbedtls_test_transparent_mac_sign_finish(
131 mbedtls_transparent_test_driver_mac_operation_t *operation,
132 uint8_t *mac,
133 size_t mac_size,
134 size_t *mac_length )
135{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200136 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200137
Steven Cooremanae3ec522021-05-10 11:18:20 +0200138 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200139 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200140 mbedtls_test_driver_mac_hooks.driver_status =
141 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200142 }
143 else
144 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200145 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200146 mbedtls_transparent_test_driver_mac_sign_finish(
147 operation, mac, mac_size, mac_length );
148 }
149
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200150 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200151}
152
153psa_status_t mbedtls_test_transparent_mac_verify_finish(
154 mbedtls_transparent_test_driver_mac_operation_t *operation,
155 const uint8_t *mac,
156 size_t mac_length )
157{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200158 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200159
Steven Cooremanae3ec522021-05-10 11:18:20 +0200160 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200161 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200162 mbedtls_test_driver_mac_hooks.driver_status =
163 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200164 }
165 else
166 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200167 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200168 mbedtls_transparent_test_driver_mac_verify_finish(
169 operation, mac, mac_length );
170 }
171
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200172 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200173}
174
175psa_status_t mbedtls_test_transparent_mac_abort(
176 mbedtls_transparent_test_driver_mac_operation_t *operation )
177{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200178 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200179
Steven Cooremanae3ec522021-05-10 11:18:20 +0200180 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200181 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200182 mbedtls_test_driver_mac_hooks.driver_status =
183 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200184 }
185 else
186 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200187 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200188 mbedtls_transparent_test_driver_mac_abort( operation );
189 }
190
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200191 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200192}
193
194psa_status_t mbedtls_test_opaque_mac_compute(
195 const psa_key_attributes_t *attributes,
196 const uint8_t *key_buffer,
197 size_t key_buffer_size,
198 psa_algorithm_t alg,
199 const uint8_t *input,
200 size_t input_length,
201 uint8_t *mac,
202 size_t mac_size,
203 size_t *mac_length )
204{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200205 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200206
Steven Cooremanae3ec522021-05-10 11:18:20 +0200207 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200208 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200209 mbedtls_test_driver_mac_hooks.driver_status =
210 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200211 }
212 else
213 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200214 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200215 mbedtls_opaque_test_driver_mac_compute(
216 attributes, key_buffer, key_buffer_size, alg,
217 input, input_length,
218 mac, mac_size, mac_length );
219 }
220
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200221 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200222}
223
224psa_status_t mbedtls_test_opaque_mac_sign_setup(
225 mbedtls_opaque_test_driver_mac_operation_t *operation,
226 const psa_key_attributes_t *attributes,
227 const uint8_t *key_buffer,
228 size_t key_buffer_size,
229 psa_algorithm_t alg )
230{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200231 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200232
Steven Cooremanae3ec522021-05-10 11:18:20 +0200233 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200234 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200235 mbedtls_test_driver_mac_hooks.driver_status =
236 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200237 }
238 else
239 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200240 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200241 mbedtls_opaque_test_driver_mac_sign_setup(
242 operation, attributes, key_buffer, key_buffer_size, alg );
243 }
244
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200245 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200246}
247
248psa_status_t mbedtls_test_opaque_mac_verify_setup(
249 mbedtls_opaque_test_driver_mac_operation_t *operation,
250 const psa_key_attributes_t *attributes,
251 const uint8_t *key_buffer,
252 size_t key_buffer_size,
253 psa_algorithm_t alg )
254{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200255 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200256
Steven Cooremanae3ec522021-05-10 11:18:20 +0200257 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200258 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200259 mbedtls_test_driver_mac_hooks.driver_status =
260 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200261 }
262 else
263 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200264 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200265 mbedtls_opaque_test_driver_mac_verify_setup(
266 operation, attributes, key_buffer, key_buffer_size, alg );
267 }
268
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200269 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200270}
271
272psa_status_t mbedtls_test_opaque_mac_update(
273 mbedtls_opaque_test_driver_mac_operation_t *operation,
274 const uint8_t *input,
275 size_t input_length )
276{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200277 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200278
Steven Cooremanae3ec522021-05-10 11:18:20 +0200279 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200280 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200281 mbedtls_test_driver_mac_hooks.driver_status =
282 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200283 }
284 else
285 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200286 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200287 mbedtls_opaque_test_driver_mac_update(
288 operation, input, input_length );
289 }
290
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200291 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200292}
293
294psa_status_t mbedtls_test_opaque_mac_sign_finish(
295 mbedtls_opaque_test_driver_mac_operation_t *operation,
296 uint8_t *mac,
297 size_t mac_size,
298 size_t *mac_length )
299{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200300 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200301
Steven Cooremanae3ec522021-05-10 11:18:20 +0200302 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200303 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200304 mbedtls_test_driver_mac_hooks.driver_status =
305 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200306 }
307 else
308 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200309 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200310 mbedtls_opaque_test_driver_mac_sign_finish(
311 operation, mac, mac_size, mac_length );
312 }
313
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200314 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200315}
316
317psa_status_t mbedtls_test_opaque_mac_verify_finish(
318 mbedtls_opaque_test_driver_mac_operation_t *operation,
319 const uint8_t *mac,
320 size_t mac_length )
321{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200322 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200323
Steven Cooremanae3ec522021-05-10 11:18:20 +0200324 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200325 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200326 mbedtls_test_driver_mac_hooks.driver_status =
327 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200328 }
329 else
330 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200331 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200332 mbedtls_opaque_test_driver_mac_verify_finish(
333 operation, mac, mac_length );
334 }
335
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200336 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200337}
338
339psa_status_t mbedtls_test_opaque_mac_abort(
340 mbedtls_opaque_test_driver_mac_operation_t *operation )
341{
Steven Cooremanae3ec522021-05-10 11:18:20 +0200342 mbedtls_test_driver_mac_hooks.hits++;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200343
Steven Cooremanae3ec522021-05-10 11:18:20 +0200344 if( mbedtls_test_driver_mac_hooks.forced_status != PSA_SUCCESS )
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200345 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200346 mbedtls_test_driver_mac_hooks.driver_status =
347 mbedtls_test_driver_mac_hooks.forced_status;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200348 }
349 else
350 {
Steven Cooremanae3ec522021-05-10 11:18:20 +0200351 mbedtls_test_driver_mac_hooks.driver_status =
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200352 mbedtls_opaque_test_driver_mac_abort( operation );
353 }
354
Mateusz Starzyke36f5b12021-07-22 16:43:35 +0200355 return mbedtls_test_driver_mac_hooks.driver_status ;
Steven Cooremanc7f0a572021-04-29 21:10:11 +0200356}
357
358#endif /* MBEDTLS_PSA_CRYPTO_DRIVERS && PSA_CRYPTO_DRIVER_TEST */