1a8e1175bSopenharmony_ci/* 2a8e1175bSopenharmony_ci * Test driver for signature functions. 3a8e1175bSopenharmony_ci */ 4a8e1175bSopenharmony_ci/* Copyright The Mbed TLS Contributors 5a8e1175bSopenharmony_ci * SPDX-License-Identifier: Apache-2.0 6a8e1175bSopenharmony_ci * 7a8e1175bSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); you may 8a8e1175bSopenharmony_ci * not use this file except in compliance with the License. 9a8e1175bSopenharmony_ci * You may obtain a copy of the License at 10a8e1175bSopenharmony_ci * 11a8e1175bSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 12a8e1175bSopenharmony_ci * 13a8e1175bSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 14a8e1175bSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 15a8e1175bSopenharmony_ci * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 16a8e1175bSopenharmony_ci * See the License for the specific language governing permissions and 17a8e1175bSopenharmony_ci * limitations under the License. 18a8e1175bSopenharmony_ci */ 19a8e1175bSopenharmony_ci 20a8e1175bSopenharmony_ci#ifndef PSA_CRYPTO_TEST_DRIVERS_SIGNATURE_H 21a8e1175bSopenharmony_ci#define PSA_CRYPTO_TEST_DRIVERS_SIGNATURE_H 22a8e1175bSopenharmony_ci 23a8e1175bSopenharmony_ci#include "mbedtls/build_info.h" 24a8e1175bSopenharmony_ci 25a8e1175bSopenharmony_ci#if defined(PSA_CRYPTO_DRIVER_TEST) 26a8e1175bSopenharmony_ci#include <psa/crypto_driver_common.h> 27a8e1175bSopenharmony_ci 28a8e1175bSopenharmony_citypedef struct { 29a8e1175bSopenharmony_ci /* If non-null, on success, copy this to the output. */ 30a8e1175bSopenharmony_ci void *forced_output; 31a8e1175bSopenharmony_ci size_t forced_output_length; 32a8e1175bSopenharmony_ci /* If not PSA_SUCCESS, return this error code instead of processing the 33a8e1175bSopenharmony_ci * function call. */ 34a8e1175bSopenharmony_ci psa_status_t forced_status; 35a8e1175bSopenharmony_ci /* Count the amount of times one of the signature driver functions is called. */ 36a8e1175bSopenharmony_ci unsigned long hits; 37a8e1175bSopenharmony_ci} mbedtls_test_driver_signature_hooks_t; 38a8e1175bSopenharmony_ci 39a8e1175bSopenharmony_ci#define MBEDTLS_TEST_DRIVER_SIGNATURE_INIT { NULL, 0, PSA_SUCCESS, 0 } 40a8e1175bSopenharmony_cistatic inline mbedtls_test_driver_signature_hooks_t 41a8e1175bSopenharmony_cimbedtls_test_driver_signature_hooks_init(void) 42a8e1175bSopenharmony_ci{ 43a8e1175bSopenharmony_ci const mbedtls_test_driver_signature_hooks_t 44a8e1175bSopenharmony_ci v = MBEDTLS_TEST_DRIVER_SIGNATURE_INIT; 45a8e1175bSopenharmony_ci return v; 46a8e1175bSopenharmony_ci} 47a8e1175bSopenharmony_ci 48a8e1175bSopenharmony_ciextern mbedtls_test_driver_signature_hooks_t 49a8e1175bSopenharmony_ci mbedtls_test_driver_signature_sign_hooks; 50a8e1175bSopenharmony_ciextern mbedtls_test_driver_signature_hooks_t 51a8e1175bSopenharmony_ci mbedtls_test_driver_signature_verify_hooks; 52a8e1175bSopenharmony_ci 53a8e1175bSopenharmony_cipsa_status_t mbedtls_test_transparent_signature_sign_message( 54a8e1175bSopenharmony_ci const psa_key_attributes_t *attributes, 55a8e1175bSopenharmony_ci const uint8_t *key, 56a8e1175bSopenharmony_ci size_t key_length, 57a8e1175bSopenharmony_ci psa_algorithm_t alg, 58a8e1175bSopenharmony_ci const uint8_t *input, 59a8e1175bSopenharmony_ci size_t input_length, 60a8e1175bSopenharmony_ci uint8_t *signature, 61a8e1175bSopenharmony_ci size_t signature_size, 62a8e1175bSopenharmony_ci size_t *signature_length); 63a8e1175bSopenharmony_ci 64a8e1175bSopenharmony_cipsa_status_t mbedtls_test_opaque_signature_sign_message( 65a8e1175bSopenharmony_ci const psa_key_attributes_t *attributes, 66a8e1175bSopenharmony_ci const uint8_t *key, 67a8e1175bSopenharmony_ci size_t key_length, 68a8e1175bSopenharmony_ci psa_algorithm_t alg, 69a8e1175bSopenharmony_ci const uint8_t *input, 70a8e1175bSopenharmony_ci size_t input_length, 71a8e1175bSopenharmony_ci uint8_t *signature, 72a8e1175bSopenharmony_ci size_t signature_size, 73a8e1175bSopenharmony_ci size_t *signature_length); 74a8e1175bSopenharmony_ci 75a8e1175bSopenharmony_cipsa_status_t mbedtls_test_transparent_signature_verify_message( 76a8e1175bSopenharmony_ci const psa_key_attributes_t *attributes, 77a8e1175bSopenharmony_ci const uint8_t *key, 78a8e1175bSopenharmony_ci size_t key_length, 79a8e1175bSopenharmony_ci psa_algorithm_t alg, 80a8e1175bSopenharmony_ci const uint8_t *input, 81a8e1175bSopenharmony_ci size_t input_length, 82a8e1175bSopenharmony_ci const uint8_t *signature, 83a8e1175bSopenharmony_ci size_t signature_length); 84a8e1175bSopenharmony_ci 85a8e1175bSopenharmony_cipsa_status_t mbedtls_test_opaque_signature_verify_message( 86a8e1175bSopenharmony_ci const psa_key_attributes_t *attributes, 87a8e1175bSopenharmony_ci const uint8_t *key, 88a8e1175bSopenharmony_ci size_t key_length, 89a8e1175bSopenharmony_ci psa_algorithm_t alg, 90a8e1175bSopenharmony_ci const uint8_t *input, 91a8e1175bSopenharmony_ci size_t input_length, 92a8e1175bSopenharmony_ci const uint8_t *signature, 93a8e1175bSopenharmony_ci size_t signature_length); 94a8e1175bSopenharmony_ci 95a8e1175bSopenharmony_cipsa_status_t mbedtls_test_transparent_signature_sign_hash( 96a8e1175bSopenharmony_ci const psa_key_attributes_t *attributes, 97a8e1175bSopenharmony_ci const uint8_t *key, size_t key_length, 98a8e1175bSopenharmony_ci psa_algorithm_t alg, 99a8e1175bSopenharmony_ci const uint8_t *hash, size_t hash_length, 100a8e1175bSopenharmony_ci uint8_t *signature, size_t signature_size, size_t *signature_length); 101a8e1175bSopenharmony_ci 102a8e1175bSopenharmony_cipsa_status_t mbedtls_test_opaque_signature_sign_hash( 103a8e1175bSopenharmony_ci const psa_key_attributes_t *attributes, 104a8e1175bSopenharmony_ci const uint8_t *key, size_t key_length, 105a8e1175bSopenharmony_ci psa_algorithm_t alg, 106a8e1175bSopenharmony_ci const uint8_t *hash, size_t hash_length, 107a8e1175bSopenharmony_ci uint8_t *signature, size_t signature_size, size_t *signature_length); 108a8e1175bSopenharmony_ci 109a8e1175bSopenharmony_cipsa_status_t mbedtls_test_transparent_signature_verify_hash( 110a8e1175bSopenharmony_ci const psa_key_attributes_t *attributes, 111a8e1175bSopenharmony_ci const uint8_t *key, size_t key_length, 112a8e1175bSopenharmony_ci psa_algorithm_t alg, 113a8e1175bSopenharmony_ci const uint8_t *hash, size_t hash_length, 114a8e1175bSopenharmony_ci const uint8_t *signature, size_t signature_length); 115a8e1175bSopenharmony_ci 116a8e1175bSopenharmony_cipsa_status_t mbedtls_test_opaque_signature_verify_hash( 117a8e1175bSopenharmony_ci const psa_key_attributes_t *attributes, 118a8e1175bSopenharmony_ci const uint8_t *key, size_t key_length, 119a8e1175bSopenharmony_ci psa_algorithm_t alg, 120a8e1175bSopenharmony_ci const uint8_t *hash, size_t hash_length, 121a8e1175bSopenharmony_ci const uint8_t *signature, size_t signature_length); 122a8e1175bSopenharmony_ci 123a8e1175bSopenharmony_ci#endif /* PSA_CRYPTO_DRIVER_TEST */ 124a8e1175bSopenharmony_ci#endif /* PSA_CRYPTO_TEST_DRIVERS_SIGNATURE_H */ 125