blob: 7481c5b4ad83b4d4a0a744e49e0ab9b68d703d4c [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
Janos Follath8ca53b52016-10-05 10:57:49 +010047#if defined(__unix__) || (defined(__APPLE__) && defined(__MACH__))
48#include <unistd.h>
Nicholas Wilson2682edf2017-12-05 12:08:15 +000049#include <strings.h>
Janos Follath8ca53b52016-10-05 10:57:49 +010050#endif
SimonB0269dad2016-02-17 23:34:30 +000051
Azim Khand30ca132017-06-09 04:32:58 +010052/* Type for Hex parameters */
Azim Khan5fcca462018-06-29 11:05:32 +010053typedef struct data_tag
Azim Khand30ca132017-06-09 04:32:58 +010054{
55 uint8_t * x;
56 uint32_t len;
Azim Khan5fcca462018-06-29 11:05:32 +010057} data_t;
Azim Khand30ca132017-06-09 04:32:58 +010058
SimonB0269dad2016-02-17 23:34:30 +000059/*----------------------------------------------------------------------------*/
Azim Khan62a5d7d2018-06-29 10:02:54 +010060/* Status and error constants */
SimonB0269dad2016-02-17 23:34:30 +000061
Azim Khan62a5d7d2018-06-29 10:02:54 +010062#define DEPENDENCY_SUPPORTED 0 /* Dependency supported by build */
63#define KEY_VALUE_MAPPING_FOUND 0 /* Integer expression found */
64#define DISPATCH_TEST_SUCCESS 0 /* Test dispatch successful */
SimonB8ca7bc42016-04-17 23:24:50 +010065
Azim Khan62a5d7d2018-06-29 10:02:54 +010066#define KEY_VALUE_MAPPING_NOT_FOUND -1 /* Integer expression not found */
67#define DEPENDENCY_NOT_SUPPORTED -2 /* Dependency not supported */
68#define DISPATCH_TEST_FN_NOT_FOUND -3 /* Test function not found */
69#define DISPATCH_INVALID_TEST_DATA -4 /* Invalid test parameter type.
70 Only int, string, binary data
71 and integer expressions are
72 allowed */
73#define DISPATCH_UNSUPPORTED_SUITE -5 /* Test suite not supported by the
74 build */
SimonB0269dad2016-02-17 23:34:30 +000075
SimonB0269dad2016-02-17 23:34:30 +000076/*----------------------------------------------------------------------------*/
SimonB8ca7bc42016-04-17 23:24:50 +010077/* Global variables */
78
SimonB8ca7bc42016-04-17 23:24:50 +010079/*----------------------------------------------------------------------------*/
Hanno Becker47deec42017-07-24 12:27:09 +010080/* Helper flags for complex dependencies */
81
82/* Indicates whether we expect mbedtls_entropy_init
83 * to initialize some strong entropy source. */
Mateusz Starzyk72f60df2021-04-30 13:28:22 +020084#if !defined(MBEDTLS_NO_DEFAULT_ENTROPY_SOURCES) && \
85 ( !defined(MBEDTLS_NO_PLATFORM_ENTROPY) || \
86 defined(MBEDTLS_ENTROPY_HARDWARE_ALT) || \
87 defined(ENTROPY_NV_SEED) )
Hanno Beckerd4a872e2017-09-07 08:09:33 +010088#define ENTROPY_HAVE_STRONG
Hanno Becker47deec42017-07-24 12:27:09 +010089#endif
90
91
92/*----------------------------------------------------------------------------*/
SimonB0269dad2016-02-17 23:34:30 +000093/* Helper Functions */
Andrzej Kurekc470b6b2019-01-31 08:20:20 -050094
Gilles Peskinec85c2012021-01-06 20:47:16 +010095#if defined(MBEDTLS_PSA_CRYPTO_C)
96/** Check that no PSA Crypto key slots are in use.
97 *
98 * If any slots are in use, mark the current test as failed.
99 *
100 * \return 0 if the key store is empty, 1 otherwise.
101 */
102int test_fail_if_psa_leaking( int line_no, const char *filename )
103{
104 const char *msg = mbedtls_test_helper_is_psa_leaking( );
105 if( msg == NULL )
106 return 0;
107 else
108 {
Chris Jones9634bb12021-01-20 15:56:42 +0000109 mbedtls_test_fail( msg, line_no, filename );
Gilles Peskinec85c2012021-01-06 20:47:16 +0100110 return 1;
111 }
112}
113#endif /* defined(MBEDTLS_PSA_CRYPTO_C) */
114
Janos Follath8ca53b52016-10-05 10:57:49 +0100115#if defined(__unix__) || (defined(__APPLE__) && defined(__MACH__))
gufe44067f6e02020-07-30 09:02:27 +0200116static int redirect_output( FILE* out_stream, const char* path )
Janos Follath8ca53b52016-10-05 10:57:49 +0100117{
gufe44067f6e02020-07-30 09:02:27 +0200118 int out_fd, dup_fd;
119 FILE* path_stream;
Janos Follath8ca53b52016-10-05 10:57:49 +0100120
gufe44067f6e02020-07-30 09:02:27 +0200121 out_fd = fileno( out_stream );
122 dup_fd = dup( out_fd );
123
124 if( dup_fd == -1 )
Janos Follath8ca53b52016-10-05 10:57:49 +0100125 {
gufe44067f6e02020-07-30 09:02:27 +0200126 return( -1 );
Janos Follath8ca53b52016-10-05 10:57:49 +0100127 }
128
gufe44067f6e02020-07-30 09:02:27 +0200129 path_stream = fopen( path, "w" );
130 if( path_stream == NULL )
Janos Follath8ca53b52016-10-05 10:57:49 +0100131 {
gufe44067f6e02020-07-30 09:02:27 +0200132 close( dup_fd );
133 return( -1 );
Janos Follath8ca53b52016-10-05 10:57:49 +0100134 }
135
gufe44067f6e02020-07-30 09:02:27 +0200136 fflush( out_stream );
137 if( dup2( fileno( path_stream ), out_fd ) == -1 )
138 {
139 close( dup_fd );
140 fclose( path_stream );
141 return( -1 );
142 }
143
144 fclose( path_stream );
145 return( dup_fd );
Janos Follath8ca53b52016-10-05 10:57:49 +0100146}
147
gufe44067f6e02020-07-30 09:02:27 +0200148static int restore_output( FILE* out_stream, int dup_fd )
Janos Follath8ca53b52016-10-05 10:57:49 +0100149{
gufe44067f6e02020-07-30 09:02:27 +0200150 int out_fd = fileno( out_stream );
Janos Follath8ca53b52016-10-05 10:57:49 +0100151
gufe44067f6e02020-07-30 09:02:27 +0200152 fflush( out_stream );
153 if( dup2( dup_fd, out_fd ) == -1 )
Janos Follath8ca53b52016-10-05 10:57:49 +0100154 {
gufe44067f6e02020-07-30 09:02:27 +0200155 close( out_fd );
156 close( dup_fd );
157 return( -1 );
Janos Follath8ca53b52016-10-05 10:57:49 +0100158 }
159
gufe44067f6e02020-07-30 09:02:27 +0200160 close( dup_fd );
161 return( 0 );
Simon Butchere0192962016-10-12 23:07:30 +0100162}
Janos Follath8ca53b52016-10-05 10:57:49 +0100163#endif /* __unix__ || __APPLE__ __MACH__ */