blob: a620178f616f68c42f0f7abf132bb689044fd249 [file] [log] [blame]
Azim Khanec024482017-05-09 17:20:21 +01001#line 2 "suites/helpers.function"
SimonB0269dad2016-02-17 23:34:30 +00002/*----------------------------------------------------------------------------*/
3/* Headers */
4
Ronald Cronb6d6d4c2020-06-03 10:11:18 +02005#include <test/helpers.h>
Mateusz Starzyk3911e702021-05-27 14:44:31 +02006#include <test/macros.h>
Ronald Cronb7eb67f2020-06-09 16:57:42 +02007#include <test/random.h>
Gilles Peskinef6be5902020-11-24 18:33:13 +01008#include <test/psa_crypto_helpers.h>
Ronald Cron4b8b1992020-06-09 13:52:23 +02009
Simon Butcheredb7fd92016-05-17 13:35:51 +010010#include <stdlib.h>
11
Mateusz Starzyk28c8cce2021-05-21 09:48:03 +020012#if defined (MBEDTLS_ERROR_C)
13#include "mbedtls/error.h"
14#endif
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020015#if defined(MBEDTLS_PLATFORM_C)
Manuel Pégourié-Gonnard7f809972015-03-09 17:05:11 +000016#include "mbedtls/platform.h"
Manuel Pégourié-Gonnard3d49b9d2014-06-06 14:48:09 +020017#else
Rich Evans00ab4702015-02-06 13:43:58 +000018#include <stdio.h>
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020019#define mbedtls_fprintf fprintf
Simon Butcher25731362016-09-30 13:11:29 +010020#define mbedtls_snprintf snprintf
21#define mbedtls_calloc calloc
Manuel Pégourié-Gonnard2cf5a7c2015-04-08 12:49:31 +020022#define mbedtls_free free
23#define mbedtls_exit exit
Simon Butcherb2d5dd12016-04-27 13:35:37 +010024#define mbedtls_time time
25#define mbedtls_time_t time_t
Janos Follath55abc212016-04-18 18:18:48 +010026#define MBEDTLS_EXIT_SUCCESS EXIT_SUCCESS
27#define MBEDTLS_EXIT_FAILURE EXIT_FAILURE
Manuel Pégourié-Gonnard3d49b9d2014-06-06 14:48:09 +020028#endif
29
SimonB0269dad2016-02-17 23:34:30 +000030#if defined(MBEDTLS_MEMORY_BUFFER_ALLOC_C)
31#include "mbedtls/memory_buffer_alloc.h"
32#endif
33
Paul Bakkerb3dcbc12011-03-13 16:57:25 +000034#ifdef _MSC_VER
35#include <basetsd.h>
Azim Khan0fa35042018-06-22 11:34:33 +010036typedef UINT8 uint8_t;
37typedef INT32 int32_t;
Paul Bakkerb3dcbc12011-03-13 16:57:25 +000038typedef UINT32 uint32_t;
Nicholas Wilson733676b2015-11-14 13:09:01 +000039#define strncasecmp _strnicmp
40#define strcasecmp _stricmp
Paul Bakkerb3dcbc12011-03-13 16:57:25 +000041#else
Manuel Pégourié-Gonnard93866642015-06-22 19:21:23 +020042#include <stdint.h>
Paul Bakkerb3dcbc12011-03-13 16:57:25 +000043#endif
44
Paul Bakker19343182013-08-16 13:31:10 +020045#include <string.h>
46
Cameron Cawleyea5496c2021-03-08 23:29:26 +000047#if defined(__unix__) || (defined(__APPLE__) && defined(__MACH__)) || defined(__MINGW32__)
48#include <strings.h>
49#endif
50
Janos Follath8ca53b52016-10-05 10:57:49 +010051#if defined(__unix__) || (defined(__APPLE__) && defined(__MACH__))
52#include <unistd.h>
53#endif
SimonB0269dad2016-02-17 23:34:30 +000054
Azim Khand30ca132017-06-09 04:32:58 +010055/* Type for Hex parameters */
Azim Khan5fcca462018-06-29 11:05:32 +010056typedef struct data_tag
Azim Khand30ca132017-06-09 04:32:58 +010057{
58 uint8_t * x;
59 uint32_t len;
Azim Khan5fcca462018-06-29 11:05:32 +010060} data_t;
Azim Khand30ca132017-06-09 04:32:58 +010061
SimonB0269dad2016-02-17 23:34:30 +000062/*----------------------------------------------------------------------------*/
Azim Khan62a5d7d2018-06-29 10:02:54 +010063/* Status and error constants */
SimonB0269dad2016-02-17 23:34:30 +000064
Azim Khan62a5d7d2018-06-29 10:02:54 +010065#define DEPENDENCY_SUPPORTED 0 /* Dependency supported by build */
66#define KEY_VALUE_MAPPING_FOUND 0 /* Integer expression found */
67#define DISPATCH_TEST_SUCCESS 0 /* Test dispatch successful */
SimonB8ca7bc42016-04-17 23:24:50 +010068
Azim Khan62a5d7d2018-06-29 10:02:54 +010069#define KEY_VALUE_MAPPING_NOT_FOUND -1 /* Integer expression not found */
70#define DEPENDENCY_NOT_SUPPORTED -2 /* Dependency not supported */
71#define DISPATCH_TEST_FN_NOT_FOUND -3 /* Test function not found */
72#define DISPATCH_INVALID_TEST_DATA -4 /* Invalid test parameter type.
73 Only int, string, binary data
74 and integer expressions are
75 allowed */
76#define DISPATCH_UNSUPPORTED_SUITE -5 /* Test suite not supported by the
77 build */
SimonB0269dad2016-02-17 23:34:30 +000078
SimonB0269dad2016-02-17 23:34:30 +000079/*----------------------------------------------------------------------------*/
SimonB8ca7bc42016-04-17 23:24:50 +010080/* Global variables */
81
SimonB8ca7bc42016-04-17 23:24:50 +010082/*----------------------------------------------------------------------------*/
Hanno Becker47deec42017-07-24 12:27:09 +010083/* Helper flags for complex dependencies */
84
85/* Indicates whether we expect mbedtls_entropy_init
86 * to initialize some strong entropy source. */
Mateusz Starzyk72f60df2021-04-30 13:28:22 +020087#if !defined(MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES) && \
88 ( !defined(MBEDTLS_NO_PLATFORM_ENTROPY) || \
89 defined(MBEDTLS_ENTROPY_HARDWARE_ALT) || \
90 defined(ENTROPY_NV_SEED) )
Hanno Beckerd4a872e2017-09-07 08:09:33 +010091#define ENTROPY_HAVE_STRONG
Hanno Becker47deec42017-07-24 12:27:09 +010092#endif
93
94
95/*----------------------------------------------------------------------------*/
SimonB0269dad2016-02-17 23:34:30 +000096/* Helper Functions */
Andrzej Kurekc470b6b2019-01-31 08:20:20 -050097
Gilles Peskinec85c2012021-01-06 20:47:16 +010098#if defined(MBEDTLS_PSA_CRYPTO_C)
99/** Check that no PSA Crypto key slots are in use.
100 *
101 * If any slots are in use, mark the current test as failed.
102 *
103 * \return 0 if the key store is empty, 1 otherwise.
104 */
105int test_fail_if_psa_leaking( int line_no, const char *filename )
106{
107 const char *msg = mbedtls_test_helper_is_psa_leaking( );
108 if( msg == NULL )
109 return 0;
110 else
111 {
Chris Jones9634bb12021-01-20 15:56:42 +0000112 mbedtls_test_fail( msg, line_no, filename );
Gilles Peskinec85c2012021-01-06 20:47:16 +0100113 return 1;
114 }
115}
116#endif /* defined(MBEDTLS_PSA_CRYPTO_C) */
117
Janos Follath8ca53b52016-10-05 10:57:49 +0100118#if defined(__unix__) || (defined(__APPLE__) && defined(__MACH__))
gufe44067f6e02020-07-30 09:02:27 +0200119static int redirect_output( FILE* out_stream, const char* path )
Janos Follath8ca53b52016-10-05 10:57:49 +0100120{
gufe44067f6e02020-07-30 09:02:27 +0200121 int out_fd, dup_fd;
122 FILE* path_stream;
Janos Follath8ca53b52016-10-05 10:57:49 +0100123
gufe44067f6e02020-07-30 09:02:27 +0200124 out_fd = fileno( out_stream );
125 dup_fd = dup( out_fd );
126
127 if( dup_fd == -1 )
Janos Follath8ca53b52016-10-05 10:57:49 +0100128 {
gufe44067f6e02020-07-30 09:02:27 +0200129 return( -1 );
Janos Follath8ca53b52016-10-05 10:57:49 +0100130 }
131
gufe44067f6e02020-07-30 09:02:27 +0200132 path_stream = fopen( path, "w" );
133 if( path_stream == NULL )
Janos Follath8ca53b52016-10-05 10:57:49 +0100134 {
gufe44067f6e02020-07-30 09:02:27 +0200135 close( dup_fd );
136 return( -1 );
Janos Follath8ca53b52016-10-05 10:57:49 +0100137 }
138
gufe44067f6e02020-07-30 09:02:27 +0200139 fflush( out_stream );
140 if( dup2( fileno( path_stream ), out_fd ) == -1 )
141 {
142 close( dup_fd );
143 fclose( path_stream );
144 return( -1 );
145 }
146
147 fclose( path_stream );
148 return( dup_fd );
Janos Follath8ca53b52016-10-05 10:57:49 +0100149}
150
gufe44067f6e02020-07-30 09:02:27 +0200151static int restore_output( FILE* out_stream, int dup_fd )
Janos Follath8ca53b52016-10-05 10:57:49 +0100152{
gufe44067f6e02020-07-30 09:02:27 +0200153 int out_fd = fileno( out_stream );
Janos Follath8ca53b52016-10-05 10:57:49 +0100154
gufe44067f6e02020-07-30 09:02:27 +0200155 fflush( out_stream );
156 if( dup2( dup_fd, out_fd ) == -1 )
Janos Follath8ca53b52016-10-05 10:57:49 +0100157 {
gufe44067f6e02020-07-30 09:02:27 +0200158 close( out_fd );
159 close( dup_fd );
160 return( -1 );
Janos Follath8ca53b52016-10-05 10:57:49 +0100161 }
162
gufe44067f6e02020-07-30 09:02:27 +0200163 close( dup_fd );
164 return( 0 );
Simon Butchere0192962016-10-12 23:07:30 +0100165}
Janos Follath8ca53b52016-10-05 10:57:49 +0100166#endif /* __unix__ || __APPLE__ __MACH__ */