mac.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. /*
  2. * Test driver for MAC driver 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. #ifndef PSA_CRYPTO_TEST_DRIVERS_MAC_H
  20. #define PSA_CRYPTO_TEST_DRIVERS_MAC_H
  21. #if !defined(MBEDTLS_CONFIG_FILE)
  22. #include "mbedtls/config.h"
  23. #else
  24. #include MBEDTLS_CONFIG_FILE
  25. #endif
  26. #if defined(PSA_CRYPTO_DRIVER_TEST)
  27. #include <psa/crypto_driver_common.h>
  28. typedef struct {
  29. /* If not PSA_SUCCESS, return this error code instead of processing the
  30. * function call. */
  31. psa_status_t forced_status;
  32. /* Count the amount of times MAC driver functions are called. */
  33. unsigned long hits;
  34. /* Status returned by the last MAC driver function call. */
  35. psa_status_t driver_status;
  36. } mbedtls_test_driver_mac_hooks_t;
  37. #define MBEDTLS_TEST_DRIVER_MAC_INIT { 0, 0, 0 }
  38. static inline mbedtls_test_driver_mac_hooks_t
  39. mbedtls_test_driver_mac_hooks_init( void )
  40. {
  41. const mbedtls_test_driver_mac_hooks_t v = MBEDTLS_TEST_DRIVER_MAC_INIT;
  42. return( v );
  43. }
  44. extern mbedtls_test_driver_mac_hooks_t mbedtls_test_driver_mac_hooks;
  45. psa_status_t mbedtls_test_transparent_mac_compute(
  46. const psa_key_attributes_t *attributes,
  47. const uint8_t *key_buffer,
  48. size_t key_buffer_size,
  49. psa_algorithm_t alg,
  50. const uint8_t *input,
  51. size_t input_length,
  52. uint8_t *mac,
  53. size_t mac_size,
  54. size_t *mac_length );
  55. psa_status_t mbedtls_test_transparent_mac_sign_setup(
  56. mbedtls_transparent_test_driver_mac_operation_t *operation,
  57. const psa_key_attributes_t *attributes,
  58. const uint8_t *key_buffer,
  59. size_t key_buffer_size,
  60. psa_algorithm_t alg );
  61. psa_status_t mbedtls_test_transparent_mac_verify_setup(
  62. mbedtls_transparent_test_driver_mac_operation_t *operation,
  63. const psa_key_attributes_t *attributes,
  64. const uint8_t *key_buffer,
  65. size_t key_buffer_size,
  66. psa_algorithm_t alg );
  67. psa_status_t mbedtls_test_transparent_mac_update(
  68. mbedtls_transparent_test_driver_mac_operation_t *operation,
  69. const uint8_t *input,
  70. size_t input_length );
  71. psa_status_t mbedtls_test_transparent_mac_sign_finish(
  72. mbedtls_transparent_test_driver_mac_operation_t *operation,
  73. uint8_t *mac,
  74. size_t mac_size,
  75. size_t *mac_length );
  76. psa_status_t mbedtls_test_transparent_mac_verify_finish(
  77. mbedtls_transparent_test_driver_mac_operation_t *operation,
  78. const uint8_t *mac,
  79. size_t mac_length );
  80. psa_status_t mbedtls_test_transparent_mac_abort(
  81. mbedtls_transparent_test_driver_mac_operation_t *operation );
  82. psa_status_t mbedtls_test_opaque_mac_compute(
  83. const psa_key_attributes_t *attributes,
  84. const uint8_t *key_buffer,
  85. size_t key_buffer_size,
  86. psa_algorithm_t alg,
  87. const uint8_t *input,
  88. size_t input_length,
  89. uint8_t *mac,
  90. size_t mac_size,
  91. size_t *mac_length );
  92. psa_status_t mbedtls_test_opaque_mac_sign_setup(
  93. mbedtls_opaque_test_driver_mac_operation_t *operation,
  94. const psa_key_attributes_t *attributes,
  95. const uint8_t *key_buffer,
  96. size_t key_buffer_size,
  97. psa_algorithm_t alg );
  98. psa_status_t mbedtls_test_opaque_mac_verify_setup(
  99. mbedtls_opaque_test_driver_mac_operation_t *operation,
  100. const psa_key_attributes_t *attributes,
  101. const uint8_t *key_buffer,
  102. size_t key_buffer_size,
  103. psa_algorithm_t alg );
  104. psa_status_t mbedtls_test_opaque_mac_update(
  105. mbedtls_opaque_test_driver_mac_operation_t *operation,
  106. const uint8_t *input,
  107. size_t input_length );
  108. psa_status_t mbedtls_test_opaque_mac_sign_finish(
  109. mbedtls_opaque_test_driver_mac_operation_t *operation,
  110. uint8_t *mac,
  111. size_t mac_size,
  112. size_t *mac_length );
  113. psa_status_t mbedtls_test_opaque_mac_verify_finish(
  114. mbedtls_opaque_test_driver_mac_operation_t *operation,
  115. const uint8_t *mac,
  116. size_t mac_length );
  117. psa_status_t mbedtls_test_opaque_mac_abort(
  118. mbedtls_opaque_test_driver_mac_operation_t *operation );
  119. #endif /* PSA_CRYPTO_DRIVER_TEST */
  120. #endif /* PSA_CRYPTO_TEST_DRIVERS_MAC_H */