mirror of
				https://github.com/yuzu-emu/mbedtls.git
				synced 2025-10-25 18:18:04 +00:00 
			
		
		
		
	Merge pull request #3387 from ronald-cron-arm/tests-common-code
Add support to build and link common code in tests
This commit is contained in:
		
						commit
						b21b1f5e7c
					
				
							
								
								
									
										5
									
								
								ChangeLog.d/tests-common-code.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								ChangeLog.d/tests-common-code.txt
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| Changes | ||||
|    * The unit tests now rely on header files in tests/include/test and source | ||||
|      files in tests/src. When building with make or cmake, the files in | ||||
|      tests/src are compiled and the resulting object linked into each test | ||||
|      executable. | ||||
							
								
								
									
										5
									
								
								tests/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								tests/.gitignore
									
									
									
									
										vendored
									
									
								
							|  | @ -8,4 +8,7 @@ data_files/hmac_drbg_seed | |||
| data_files/ctr_drbg_seed | ||||
| data_files/entropy_seed | ||||
| 
 | ||||
| /instrument_record_status.h | ||||
| include/test/instrument_record_status.h | ||||
| 
 | ||||
| src/*.o | ||||
| src/libmbed* | ||||
|  |  | |||
|  | @ -46,9 +46,9 @@ function(add_test_suite suite_name) | |||
|         DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py mbedtls ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${data_name}.data | ||||
|     ) | ||||
| 
 | ||||
|     include_directories(${CMAKE_CURRENT_SOURCE_DIR}) | ||||
|     add_executable(test_suite_${data_name} test_suite_${data_name}.c) | ||||
|     add_executable(test_suite_${data_name} test_suite_${data_name}.c $<TARGET_OBJECTS:mbedtests>) | ||||
|     target_link_libraries(test_suite_${data_name} ${libs}) | ||||
|     target_include_directories(test_suite_${data_name} PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include) | ||||
|     if(${data_name} MATCHES ${SKIP_TEST_SUITES_REGEX}) | ||||
|         message(STATUS "The test suite ${data_name} will not be executed.") | ||||
|     else() | ||||
|  | @ -66,6 +66,10 @@ if(MSVC) | |||
|     set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX-") | ||||
| endif(MSVC) | ||||
| 
 | ||||
| file(GLOB MBEDTESTS_FILES ${CMAKE_CURRENT_SOURCE_DIR}/src/*.c) | ||||
| add_library(mbedtests OBJECT ${MBEDTESTS_FILES}) | ||||
| target_include_directories(mbedtests PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include) | ||||
| 
 | ||||
| add_test_suite(aes aes.cbc) | ||||
| add_test_suite(aes aes.cfb) | ||||
| add_test_suite(aes aes.ecb) | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ CFLAGS	?= -O2 | |||
| WARNING_CFLAGS ?= -Wall -Wextra | ||||
| LDFLAGS ?= | ||||
| 
 | ||||
| LOCAL_CFLAGS = $(WARNING_CFLAGS) -I../include -I../library -D_FILE_OFFSET_BITS=64 | ||||
| LOCAL_CFLAGS = $(WARNING_CFLAGS) -I./include -I../include -I../library -D_FILE_OFFSET_BITS=64 | ||||
| LOCAL_LDFLAGS = -L../library			\
 | ||||
| 		-lmbedtls$(SHARED_SUFFIX)	\
 | ||||
| 		-lmbedx509$(SHARED_SUFFIX)	\
 | ||||
|  | @ -21,9 +21,9 @@ LOCAL_CFLAGS+=$(THIRDPARTY_INCLUDES) | |||
| LOCAL_CFLAGS += -D_POSIX_C_SOURCE=200809L | ||||
| 
 | ||||
| ifndef SHARED | ||||
| DEP=../library/libmbedcrypto.a ../library/libmbedx509.a ../library/libmbedtls.a | ||||
| MBEDLIBS=../library/libmbedcrypto.a ../library/libmbedx509.a ../library/libmbedtls.a | ||||
| else | ||||
| DEP=../library/libmbedcrypto.$(DLEXT) ../library/libmbedx509.$(DLEXT) ../library/libmbedtls.$(DLEXT) | ||||
| MBEDLIBS=../library/libmbedcrypto.$(DLEXT) ../library/libmbedx509.$(DLEXT) ../library/libmbedtls.$(DLEXT) | ||||
| endif | ||||
| 
 | ||||
| ifdef DEBUG | ||||
|  | @ -74,9 +74,16 @@ BINARIES := $(addsuffix $(EXEXT),$(APPS)) | |||
| 
 | ||||
| all: $(BINARIES) | ||||
| 
 | ||||
| $(DEP): | ||||
| $(MBEDLIBS): | ||||
| 	$(MAKE) -C ../library | ||||
| 
 | ||||
| MBEDTESTS_OBJS=$(patsubst %.c,%.o,$(wildcard src/*.c)) | ||||
| 
 | ||||
| # Rule to compile common test C files in src folder
 | ||||
| src/%.o : src/%.c | ||||
| 	echo "  CC    $<" | ||||
| 	$(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $< | ||||
| 
 | ||||
| C_FILES := $(addsuffix .c,$(APPS)) | ||||
| 
 | ||||
| # Wildcard target for test code generation:
 | ||||
|  | @ -105,23 +112,26 @@ C_FILES := $(addsuffix .c,$(APPS)) | |||
| 		-o . | ||||
| 
 | ||||
| 
 | ||||
| $(BINARIES): %$(EXEXT): %.c $(DEP) | ||||
| $(BINARIES): %$(EXEXT): %.c $(MBEDLIBS) $(MBEDTESTS_OBJS) | ||||
| 	echo "  CC    $<" | ||||
| 	$(CC) $(LOCAL_CFLAGS) $(CFLAGS) $<	$(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ | ||||
| 	$(CC) $(LOCAL_CFLAGS) $(CFLAGS) $< $(MBEDTESTS_OBJS) $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ | ||||
| 
 | ||||
| # Some test suites require additional header files.
 | ||||
| $(filter test_suite_psa_crypto%, $(BINARIES)): psa_crypto_helpers.h | ||||
| $(filter test_suite_psa_crypto%, $(BINARIES)): include/test/psa_crypto_helpers.h | ||||
| $(addprefix embedded_,$(filter test_suite_psa_crypto%, $(APPS))): embedded_%: TESTS/mbedtls/%/psa_crypto_helpers.h | ||||
| $(filter test_suite_psa_%, $(BINARIES)): psa_helpers.h | ||||
| $(filter test_suite_psa_%, $(BINARIES)): include/test/psa_helpers.h | ||||
| $(addprefix embedded_,$(filter test_suite_psa_%, $(APPS))): embedded_%: TESTS/mbedtls/%/psa_helpers.h | ||||
| 
 | ||||
| clean: | ||||
| ifndef WINDOWS | ||||
| 	rm -rf $(BINARIES) *.c *.datax TESTS | ||||
| 	rm -f src/*.o src/libmbed* | ||||
| else | ||||
| 	if exist *.c del /Q /F *.c | ||||
| 	if exist *.exe del /Q /F *.exe | ||||
| 	if exist *.datax del /Q /F *.datax | ||||
| 	if exist src/*.o del /Q /F src/*.o | ||||
| 	if exist src/libmbed* del /Q /F src/libmed* | ||||
| ifneq ($(wildcard TESTS/.*),) | ||||
| 	rmdir /Q /S TESTS | ||||
| endif | ||||
|  | @ -152,7 +162,7 @@ $(EMBEDDED_TESTS): embedded_%: suites/$$(firstword $$(subst ., ,$$*)).function s | |||
| generate-target-tests: $(EMBEDDED_TESTS) | ||||
| 
 | ||||
| define copy_header_to_target | ||||
| TESTS/mbedtls/$(1)/$(2): $(2) | ||||
| TESTS/mbedtls/$(1)/$(2): include/test/$(2) | ||||
| 	echo "  Copy ./$$@" | ||||
| ifndef WINDOWS | ||||
| 	mkdir -p $$(@D) | ||||
|  | @ -163,11 +173,11 @@ else | |||
| endif | ||||
| 
 | ||||
| endef | ||||
| $(foreach app, $(APPS), $(foreach file, $(wildcard *.h), \ | ||||
| $(foreach app, $(APPS), $(foreach file, $(notdir $(wildcard include/test/*.h)), \ | ||||
| 	$(eval $(call copy_header_to_target,$(app),$(file))))) | ||||
| 
 | ||||
| ifdef RECORD_PSA_STATUS_COVERAGE_LOG | ||||
| $(BINARIES): instrument_record_status.h | ||||
| instrument_record_status.h: ../include/psa/crypto.h Makefile | ||||
| $(BINARIES): include/test/instrument_record_status.h | ||||
| include/test/instrument_record_status.h: ../include/psa/crypto.h Makefile | ||||
| 	sed <../include/psa/crypto.h >$@ -n 's/^psa_status_t \([A-Za-z0-9_]*\)(.*/#define \1(...) RECORD_STATUS("\1", \1(__VA_ARGS__))/p' | ||||
| endif | ||||
|  |  | |||
							
								
								
									
										85
									
								
								tests/include/test/helpers.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										85
									
								
								tests/include/test/helpers.h
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,85 @@ | |||
| /**
 | ||||
|  * \file helpers.h | ||||
|  * | ||||
|  * \brief   This file contains the prototypes of helper functions for the | ||||
|  *          purpose of testing. | ||||
|  */ | ||||
| 
 | ||||
| /*  Copyright (C) 2020, ARM Limited, All Rights Reserved
 | ||||
|  *  SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
|  *  Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||
|  *  not use this file except in compliance with the License. | ||||
|  *  You may obtain a copy of the License at | ||||
|  * | ||||
|  *  http://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  *  Unless required by applicable law or agreed to in writing, software | ||||
|  *  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
|  *  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  *  See the License for the specific language governing permissions and | ||||
|  *  limitations under the License. | ||||
|  * | ||||
|  *  This file is part of mbed TLS (https://tls.mbed.org)
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef TEST_HELPERS_H | ||||
| #define TEST_HELPERS_H | ||||
| 
 | ||||
| #if !defined(MBEDTLS_CONFIG_FILE) | ||||
| #include "mbedtls/config.h" | ||||
| #else | ||||
| #include MBEDTLS_CONFIG_FILE | ||||
| #endif | ||||
| 
 | ||||
| #if defined(MBEDTLS_PLATFORM_C) | ||||
| #include "mbedtls/platform.h" | ||||
| #else | ||||
| #include <stdio.h> | ||||
| #define mbedtls_fprintf    fprintf | ||||
| #define mbedtls_snprintf   snprintf | ||||
| #define mbedtls_calloc     calloc | ||||
| #define mbedtls_free       free | ||||
| #define mbedtls_exit       exit | ||||
| #define mbedtls_time       time | ||||
| #define mbedtls_time_t     time_t | ||||
| #define MBEDTLS_EXIT_SUCCESS EXIT_SUCCESS | ||||
| #define MBEDTLS_EXIT_FAILURE EXIT_FAILURE | ||||
| #endif | ||||
| 
 | ||||
| #include <stddef.h> | ||||
| #include <stdint.h> | ||||
| 
 | ||||
| int mbedtls_test_platform_setup( void ); | ||||
| void mbedtls_test_platform_teardown( void ); | ||||
| 
 | ||||
| int mbedtls_test_unhexify( unsigned char *obuf, const char *ibuf ); | ||||
| void mbedtls_test_hexify( unsigned char *obuf, | ||||
|                           const unsigned char *ibuf, | ||||
|                           int len ); | ||||
| 
 | ||||
| /**
 | ||||
|  * Allocate and zeroize a buffer. | ||||
|  * | ||||
|  * If the size if zero, a pointer to a zeroized 1-byte buffer is returned. | ||||
|  * | ||||
|  * For convenience, dies if allocation fails. | ||||
|  */ | ||||
| unsigned char *mbedtls_test_zero_alloc( size_t len ); | ||||
| 
 | ||||
| /**
 | ||||
|  * Allocate and fill a buffer from hex data. | ||||
|  * | ||||
|  * The buffer is sized exactly as needed. This allows to detect buffer | ||||
|  * overruns (including overreads) when running the test suite under valgrind. | ||||
|  * | ||||
|  * If the size if zero, a pointer to a zeroized 1-byte buffer is returned. | ||||
|  * | ||||
|  * For convenience, dies if allocation fails. | ||||
|  */ | ||||
| unsigned char *mbedtls_test_unhexify_alloc( const char *ibuf, size_t *olen ); | ||||
| 
 | ||||
| int mbedtls_test_hexcmp( uint8_t * a, uint8_t * b, | ||||
|                          uint32_t a_len, uint32_t b_len ); | ||||
| 
 | ||||
| #endif /* TEST_HELPERS_H */ | ||||
							
								
								
									
										137
									
								
								tests/include/test/macros.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										137
									
								
								tests/include/test/macros.h
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,137 @@ | |||
| /**
 | ||||
|  * \file macros.h | ||||
|  * | ||||
|  * \brief   This file contains generic macros for the purpose of testing. | ||||
|  */ | ||||
| 
 | ||||
| /*  Copyright (C) 2020, ARM Limited, All Rights Reserved
 | ||||
|  *  SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
|  *  Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||
|  *  not use this file except in compliance with the License. | ||||
|  *  You may obtain a copy of the License at | ||||
|  * | ||||
|  *  http://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  *  Unless required by applicable law or agreed to in writing, software | ||||
|  *  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
|  *  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  *  See the License for the specific language governing permissions and | ||||
|  *  limitations under the License. | ||||
|  * | ||||
|  *  This file is part of mbed TLS (https://tls.mbed.org)
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef TEST_MACROS_H | ||||
| #define TEST_MACROS_H | ||||
| 
 | ||||
| #if !defined(MBEDTLS_CONFIG_FILE) | ||||
| #include "mbedtls/config.h" | ||||
| #else | ||||
| #include MBEDTLS_CONFIG_FILE | ||||
| #endif | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| #if defined(MBEDTLS_PLATFORM_C) | ||||
| #include "mbedtls/platform.h" | ||||
| #else | ||||
| #include <stdio.h> | ||||
| #define mbedtls_fprintf    fprintf | ||||
| #define mbedtls_snprintf   snprintf | ||||
| #define mbedtls_calloc     calloc | ||||
| #define mbedtls_free       free | ||||
| #define mbedtls_exit       exit | ||||
| #define mbedtls_time       time | ||||
| #define mbedtls_time_t     time_t | ||||
| #define MBEDTLS_EXIT_SUCCESS EXIT_SUCCESS | ||||
| #define MBEDTLS_EXIT_FAILURE EXIT_FAILURE | ||||
| #endif | ||||
| 
 | ||||
| #if defined(MBEDTLS_MEMORY_BUFFER_ALLOC_C) | ||||
| #include "mbedtls/memory_buffer_alloc.h" | ||||
| #endif | ||||
| 
 | ||||
| #define TEST_HELPER_ASSERT(a) if( !( a ) )                          \ | ||||
| {                                                                   \ | ||||
|     mbedtls_fprintf( stderr, "Assertion Failed at %s:%d - %s\n",    \ | ||||
|                              __FILE__, __LINE__, #a );              \ | ||||
|     mbedtls_exit( 1 );                                              \ | ||||
| } | ||||
| 
 | ||||
| #if defined(__GNUC__) | ||||
| /* Test if arg and &(arg)[0] have the same type. This is true if arg is
 | ||||
|  * an array but not if it's a pointer. */ | ||||
| #define IS_ARRAY_NOT_POINTER( arg )                                     \ | ||||
|     ( ! __builtin_types_compatible_p( __typeof__( arg ),                \ | ||||
|                                       __typeof__( &( arg )[0] ) ) ) | ||||
| #else | ||||
| /* On platforms where we don't know how to implement this check,
 | ||||
|  * omit it. Oh well, a non-portable check is better than nothing. */ | ||||
| #define IS_ARRAY_NOT_POINTER( arg ) 1 | ||||
| #endif | ||||
| 
 | ||||
| /* A compile-time constant with the value 0. If `const_expr` is not a
 | ||||
|  * compile-time constant with a nonzero value, cause a compile-time error. */ | ||||
| #define STATIC_ASSERT_EXPR( const_expr )                                \ | ||||
|     ( 0 && sizeof( struct { int STATIC_ASSERT : 1 - 2 * ! ( const_expr ); } ) ) | ||||
| /* Return the scalar value `value` (possibly promoted). This is a compile-time
 | ||||
|  * constant if `value` is. `condition` must be a compile-time constant. | ||||
|  * If `condition` is false, arrange to cause a compile-time error. */ | ||||
| #define STATIC_ASSERT_THEN_RETURN( condition, value )   \ | ||||
|     ( STATIC_ASSERT_EXPR( condition ) ? 0 : ( value ) ) | ||||
| 
 | ||||
| #define ARRAY_LENGTH_UNSAFE( array )            \ | ||||
|     ( sizeof( array ) / sizeof( *( array ) ) ) | ||||
| /** Return the number of elements of a static or stack array.
 | ||||
|  * | ||||
|  * \param array         A value of array (not pointer) type. | ||||
|  * | ||||
|  * \return The number of elements of the array. | ||||
|  */ | ||||
| #define ARRAY_LENGTH( array )                                           \ | ||||
|     ( STATIC_ASSERT_THEN_RETURN( IS_ARRAY_NOT_POINTER( array ),         \ | ||||
|                                  ARRAY_LENGTH_UNSAFE( array ) ) ) | ||||
| 
 | ||||
| /** Return the smaller of two values.
 | ||||
|  * | ||||
|  * \param x         An integer-valued expression without side effects. | ||||
|  * \param y         An integer-valued expression without side effects. | ||||
|  * | ||||
|  * \return The smaller of \p x and \p y. | ||||
|  */ | ||||
| #define MIN( x, y ) ( ( x ) < ( y ) ? ( x ) : ( y ) ) | ||||
| 
 | ||||
| /** Return the larger of two values.
 | ||||
|  * | ||||
|  * \param x         An integer-valued expression without side effects. | ||||
|  * \param y         An integer-valued expression without side effects. | ||||
|  * | ||||
|  * \return The larger of \p x and \p y. | ||||
|  */ | ||||
| #define MAX( x, y ) ( ( x ) > ( y ) ? ( x ) : ( y ) ) | ||||
| 
 | ||||
| /*
 | ||||
|  * 32-bit integer manipulation macros (big endian) | ||||
|  */ | ||||
| #ifndef GET_UINT32_BE | ||||
| #define GET_UINT32_BE(n,b,i)                            \ | ||||
| {                                                       \ | ||||
|     (n) = ( (uint32_t) (b)[(i)    ] << 24 )             \ | ||||
|         | ( (uint32_t) (b)[(i) + 1] << 16 )             \ | ||||
|         | ( (uint32_t) (b)[(i) + 2] <<  8 )             \ | ||||
|         | ( (uint32_t) (b)[(i) + 3]       );            \ | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #ifndef PUT_UINT32_BE | ||||
| #define PUT_UINT32_BE(n,b,i)                            \ | ||||
| {                                                       \ | ||||
|     (b)[(i)    ] = (unsigned char) ( (n) >> 24 );       \ | ||||
|     (b)[(i) + 1] = (unsigned char) ( (n) >> 16 );       \ | ||||
|     (b)[(i) + 2] = (unsigned char) ( (n) >>  8 );       \ | ||||
|     (b)[(i) + 3] = (unsigned char) ( (n)       );       \ | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* TEST_MACROS_H */ | ||||
|  | @ -22,7 +22,7 @@ | |||
| #ifndef PSA_CRYPTO_HELPERS_H | ||||
| #define PSA_CRYPTO_HELPERS_H | ||||
| 
 | ||||
| #include "psa_helpers.h" | ||||
| #include "test/psa_helpers.h" | ||||
| 
 | ||||
| #include <psa/crypto.h> | ||||
| 
 | ||||
							
								
								
									
										106
									
								
								tests/include/test/random.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								tests/include/test/random.h
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,106 @@ | |||
| /**
 | ||||
|  * \file random.h | ||||
|  * | ||||
|  * \brief   This file contains the prototypes of helper functions to generate | ||||
|  *          random numbers for the purpose of testing. | ||||
|  */ | ||||
| 
 | ||||
| /*  Copyright (C) 2020, ARM Limited, All Rights Reserved
 | ||||
|  *  SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
|  *  Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||
|  *  not use this file except in compliance with the License. | ||||
|  *  You may obtain a copy of the License at | ||||
|  * | ||||
|  *  http://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  *  Unless required by applicable law or agreed to in writing, software | ||||
|  *  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
|  *  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  *  See the License for the specific language governing permissions and | ||||
|  *  limitations under the License. | ||||
|  * | ||||
|  *  This file is part of mbed TLS (https://tls.mbed.org)
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef TEST_RANDOM_H | ||||
| #define TEST_RANDOM_H | ||||
| 
 | ||||
| #if !defined(MBEDTLS_CONFIG_FILE) | ||||
| #include "mbedtls/config.h" | ||||
| #else | ||||
| #include MBEDTLS_CONFIG_FILE | ||||
| #endif | ||||
| 
 | ||||
| #include <stddef.h> | ||||
| #include <stdint.h> | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
|     unsigned char *buf; | ||||
|     size_t length; | ||||
| } mbedtls_test_rnd_buf_info; | ||||
| 
 | ||||
| /**
 | ||||
|  * Info structure for the pseudo random function | ||||
|  * | ||||
|  * Key should be set at the start to a test-unique value. | ||||
|  * Do not forget endianness! | ||||
|  * State( v0, v1 ) should be set to zero. | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|     uint32_t key[16]; | ||||
|     uint32_t v0, v1; | ||||
| } mbedtls_test_rnd_pseudo_info; | ||||
| 
 | ||||
| /**
 | ||||
|  * This function just returns data from rand(). | ||||
|  * Although predictable and often similar on multiple | ||||
|  * runs, this does not result in identical random on | ||||
|  * each run. So do not use this if the results of a | ||||
|  * test depend on the random data that is generated. | ||||
|  * | ||||
|  * rng_state shall be NULL. | ||||
|  */ | ||||
| int mbedtls_test_rnd_std_rand( void *rng_state, | ||||
|                                unsigned char *output, | ||||
|                                size_t len ); | ||||
| 
 | ||||
| /**
 | ||||
|  * This function only returns zeros | ||||
|  * | ||||
|  * rng_state shall be NULL. | ||||
|  */ | ||||
| int mbedtls_test_rnd_zero_rand( void *rng_state, | ||||
|                                 unsigned char *output, | ||||
|                                 size_t len ); | ||||
| 
 | ||||
| /**
 | ||||
|  * This function returns random based on a buffer it receives. | ||||
|  * | ||||
|  * rng_state shall be a pointer to a rnd_buf_info structure. | ||||
|  * | ||||
|  * The number of bytes released from the buffer on each call to | ||||
|  * the random function is specified by per_call. (Can be between | ||||
|  * 1 and 4) | ||||
|  * | ||||
|  * After the buffer is empty it will return rand(); | ||||
|  */ | ||||
| int mbedtls_test_rnd_buffer_rand( void *rng_state, | ||||
|                                   unsigned char *output, | ||||
|                                   size_t len ); | ||||
| 
 | ||||
| /**
 | ||||
|  * This function returns random based on a pseudo random function. | ||||
|  * This means the results should be identical on all systems. | ||||
|  * Pseudo random is based on the XTEA encryption algorithm to | ||||
|  * generate pseudorandom. | ||||
|  * | ||||
|  * rng_state shall be a pointer to a rnd_pseudo_info structure. | ||||
|  */ | ||||
| int mbedtls_test_rnd_pseudo_rand( void *rng_state, | ||||
|                                   unsigned char *output, | ||||
|                                   size_t len ); | ||||
| 
 | ||||
| #endif /* TEST_RANDOM_H */ | ||||
							
								
								
									
										151
									
								
								tests/src/helpers.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										151
									
								
								tests/src/helpers.c
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,151 @@ | |||
| /*  Copyright (C) 2020, ARM Limited, All Rights Reserved
 | ||||
|  *  SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
|  *  Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||
|  *  not use this file except in compliance with the License. | ||||
|  *  You may obtain a copy of the License at | ||||
|  * | ||||
|  *  http://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  *  Unless required by applicable law or agreed to in writing, software | ||||
|  *  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
|  *  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  *  See the License for the specific language governing permissions and | ||||
|  *  limitations under the License. | ||||
|  * | ||||
|  *  This file is part of mbed TLS (https://tls.mbed.org)
 | ||||
|  */ | ||||
| 
 | ||||
| #include <test/helpers.h> | ||||
| #include <test/macros.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| #if defined(MBEDTLS_PLATFORM_C) | ||||
| static mbedtls_platform_context platform_ctx; | ||||
| #endif | ||||
| 
 | ||||
| int mbedtls_test_platform_setup( void ) | ||||
| { | ||||
|     int ret = 0; | ||||
| #if defined(MBEDTLS_PLATFORM_C) | ||||
|     ret = mbedtls_platform_setup( &platform_ctx ); | ||||
| #endif /* MBEDTLS_PLATFORM_C */ | ||||
|     return( ret ); | ||||
| } | ||||
| 
 | ||||
| void mbedtls_test_platform_teardown( void ) | ||||
| { | ||||
| #if defined(MBEDTLS_PLATFORM_C) | ||||
|     mbedtls_platform_teardown( &platform_ctx ); | ||||
| #endif /* MBEDTLS_PLATFORM_C */ | ||||
| } | ||||
| 
 | ||||
| int mbedtls_test_unhexify( unsigned char *obuf, const char *ibuf ) | ||||
| { | ||||
|     unsigned char c, c2; | ||||
|     int len = strlen( ibuf ) / 2; | ||||
|     TEST_HELPER_ASSERT( strlen( ibuf ) % 2 == 0 ); /* must be even number of bytes */ | ||||
| 
 | ||||
|     while( *ibuf != 0 ) | ||||
|     { | ||||
|         c = *ibuf++; | ||||
|         if( c >= '0' && c <= '9' ) | ||||
|             c -= '0'; | ||||
|         else if( c >= 'a' && c <= 'f' ) | ||||
|             c -= 'a' - 10; | ||||
|         else if( c >= 'A' && c <= 'F' ) | ||||
|             c -= 'A' - 10; | ||||
|         else | ||||
|             TEST_HELPER_ASSERT( 0 ); | ||||
| 
 | ||||
|         c2 = *ibuf++; | ||||
|         if( c2 >= '0' && c2 <= '9' ) | ||||
|             c2 -= '0'; | ||||
|         else if( c2 >= 'a' && c2 <= 'f' ) | ||||
|             c2 -= 'a' - 10; | ||||
|         else if( c2 >= 'A' && c2 <= 'F' ) | ||||
|             c2 -= 'A' - 10; | ||||
|         else | ||||
|             TEST_HELPER_ASSERT( 0 ); | ||||
| 
 | ||||
|         *obuf++ = ( c << 4 ) | c2; | ||||
|     } | ||||
| 
 | ||||
|     return len; | ||||
| } | ||||
| 
 | ||||
| void mbedtls_test_hexify( unsigned char *obuf, | ||||
|                           const unsigned char *ibuf, | ||||
|                           int len ) | ||||
| { | ||||
|     unsigned char l, h; | ||||
| 
 | ||||
|     while( len != 0 ) | ||||
|     { | ||||
|         h = *ibuf / 16; | ||||
|         l = *ibuf % 16; | ||||
| 
 | ||||
|         if( h < 10 ) | ||||
|             *obuf++ = '0' + h; | ||||
|         else | ||||
|             *obuf++ = 'a' + h - 10; | ||||
| 
 | ||||
|         if( l < 10 ) | ||||
|             *obuf++ = '0' + l; | ||||
|         else | ||||
|             *obuf++ = 'a' + l - 10; | ||||
| 
 | ||||
|         ++ibuf; | ||||
|         len--; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| unsigned char *mbedtls_test_zero_alloc( size_t len ) | ||||
| { | ||||
|     void *p; | ||||
|     size_t actual_len = ( len != 0 ) ? len : 1; | ||||
| 
 | ||||
|     p = mbedtls_calloc( 1, actual_len ); | ||||
|     TEST_HELPER_ASSERT( p != NULL ); | ||||
| 
 | ||||
|     memset( p, 0x00, actual_len ); | ||||
| 
 | ||||
|     return( p ); | ||||
| } | ||||
| 
 | ||||
| unsigned char *mbedtls_test_unhexify_alloc( const char *ibuf, size_t *olen ) | ||||
| { | ||||
|     unsigned char *obuf; | ||||
| 
 | ||||
|     *olen = strlen( ibuf ) / 2; | ||||
| 
 | ||||
|     if( *olen == 0 ) | ||||
|         return( mbedtls_test_zero_alloc( *olen ) ); | ||||
| 
 | ||||
|     obuf = mbedtls_calloc( 1, *olen ); | ||||
|     TEST_HELPER_ASSERT( obuf != NULL ); | ||||
| 
 | ||||
|     (void) mbedtls_test_unhexify( obuf, ibuf ); | ||||
| 
 | ||||
|     return( obuf ); | ||||
| } | ||||
| 
 | ||||
| int mbedtls_test_hexcmp( uint8_t * a, uint8_t * b, | ||||
|                          uint32_t a_len, uint32_t b_len ) | ||||
| { | ||||
|     int ret = 0; | ||||
|     uint32_t i = 0; | ||||
| 
 | ||||
|     if( a_len != b_len ) | ||||
|         return( -1 ); | ||||
| 
 | ||||
|     for( i = 0; i < a_len; i++ ) | ||||
|     { | ||||
|         if( a[i] != b[i] ) | ||||
|         { | ||||
|             ret = -1; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
|     return ret; | ||||
| } | ||||
							
								
								
									
										127
									
								
								tests/src/random.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								tests/src/random.c
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,127 @@ | |||
| /**
 | ||||
|  * \file random.c | ||||
|  * | ||||
|  * \brief   This file contains the helper functions to generate random numbers | ||||
|  *          for the purpose of testing. | ||||
|  */ | ||||
| 
 | ||||
| /*  Copyright (C) 2020, ARM Limited, All Rights Reserved
 | ||||
|  *  SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
|  *  Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||
|  *  not use this file except in compliance with the License. | ||||
|  *  You may obtain a copy of the License at | ||||
|  * | ||||
|  *  http://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  *  Unless required by applicable law or agreed to in writing, software | ||||
|  *  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
|  *  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  *  See the License for the specific language governing permissions and | ||||
|  *  limitations under the License. | ||||
|  * | ||||
|  *  This file is part of mbed TLS (https://tls.mbed.org)
 | ||||
|  */ | ||||
| 
 | ||||
| #include <test/macros.h> | ||||
| #include <test/random.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| int mbedtls_test_rnd_std_rand( void *rng_state, | ||||
|                                unsigned char *output, | ||||
|                                size_t len ) | ||||
| { | ||||
| #if !defined(__OpenBSD__) | ||||
|     size_t i; | ||||
| 
 | ||||
|     if( rng_state != NULL ) | ||||
|         rng_state  = NULL; | ||||
| 
 | ||||
|     for( i = 0; i < len; ++i ) | ||||
|         output[i] = rand(); | ||||
| #else | ||||
|     if( rng_state != NULL ) | ||||
|         rng_state = NULL; | ||||
| 
 | ||||
|     arc4random_buf( output, len ); | ||||
| #endif /* !OpenBSD */ | ||||
| 
 | ||||
|     return( 0 ); | ||||
| } | ||||
| 
 | ||||
| int mbedtls_test_rnd_zero_rand( void *rng_state, | ||||
|                                 unsigned char *output, | ||||
|                                 size_t len ) | ||||
| { | ||||
|     if( rng_state != NULL ) | ||||
|         rng_state  = NULL; | ||||
| 
 | ||||
|     memset( output, 0, len ); | ||||
| 
 | ||||
|     return( 0 ); | ||||
| } | ||||
| 
 | ||||
| int mbedtls_test_rnd_buffer_rand( void *rng_state, | ||||
|                                   unsigned char *output, | ||||
|                                   size_t len ) | ||||
| { | ||||
|     mbedtls_test_rnd_buf_info *info = (mbedtls_test_rnd_buf_info *) rng_state; | ||||
|     size_t use_len; | ||||
| 
 | ||||
|     if( rng_state == NULL ) | ||||
|         return( mbedtls_test_rnd_std_rand( NULL, output, len ) ); | ||||
| 
 | ||||
|     use_len = len; | ||||
|     if( len > info->length ) | ||||
|         use_len = info->length; | ||||
| 
 | ||||
|     if( use_len ) | ||||
|     { | ||||
|         memcpy( output, info->buf, use_len ); | ||||
|         info->buf += use_len; | ||||
|         info->length -= use_len; | ||||
|     } | ||||
| 
 | ||||
|     if( len - use_len > 0 ) | ||||
|         return( mbedtls_test_rnd_std_rand( NULL, output + use_len, | ||||
|                                            len - use_len ) ); | ||||
| 
 | ||||
|     return( 0 ); | ||||
| } | ||||
| 
 | ||||
| int mbedtls_test_rnd_pseudo_rand( void *rng_state, | ||||
|                                   unsigned char *output, | ||||
|                                   size_t len ) | ||||
| { | ||||
|     mbedtls_test_rnd_pseudo_info *info = | ||||
|         (mbedtls_test_rnd_pseudo_info *) rng_state; | ||||
|     uint32_t i, *k, sum, delta=0x9E3779B9; | ||||
|     unsigned char result[4], *out = output; | ||||
| 
 | ||||
|     if( rng_state == NULL ) | ||||
|         return( mbedtls_test_rnd_std_rand( NULL, output, len ) ); | ||||
| 
 | ||||
|     k = info->key; | ||||
| 
 | ||||
|     while( len > 0 ) | ||||
|     { | ||||
|         size_t use_len = ( len > 4 ) ? 4 : len; | ||||
|         sum = 0; | ||||
| 
 | ||||
|         for( i = 0; i < 32; i++ ) | ||||
|         { | ||||
|             info->v0 += ( ( ( info->v1 << 4 ) ^ ( info->v1 >> 5 ) ) | ||||
|                             + info->v1 ) ^ ( sum + k[sum & 3] ); | ||||
|             sum += delta; | ||||
|             info->v1 += ( ( ( info->v0 << 4 ) ^ ( info->v0 >> 5 ) ) | ||||
|                             + info->v0 ) ^ ( sum + k[( sum>>11 ) & 3] ); | ||||
|         } | ||||
| 
 | ||||
|         PUT_UINT32_BE( info->v0, result, 0 ); | ||||
|         memcpy( out, result, use_len ); | ||||
|         len -= use_len; | ||||
|         out += 4; | ||||
|     } | ||||
| 
 | ||||
|     return( 0 ); | ||||
| } | ||||
|  | @ -2,6 +2,10 @@ | |||
| /*----------------------------------------------------------------------------*/ | ||||
| /* Headers */ | ||||
| 
 | ||||
| #include <test/macros.h> | ||||
| #include <test/helpers.h> | ||||
| #include <test/random.h> | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| #if defined(MBEDTLS_PLATFORM_C) | ||||
|  | @ -311,65 +315,6 @@ typedef enum | |||
| #define TEST_VALID_PARAM( TEST )                                    \ | ||||
|     TEST_ASSERT( ( TEST, 1 ) ); | ||||
| 
 | ||||
| #define TEST_HELPER_ASSERT(a) if( !( a ) )                          \ | ||||
| {                                                                   \ | ||||
|     mbedtls_fprintf( stderr, "Assertion Failed at %s:%d - %s\n",    \ | ||||
|                              __FILE__, __LINE__, #a );              \ | ||||
|     mbedtls_exit( 1 );                                              \ | ||||
| } | ||||
| 
 | ||||
| #if defined(__GNUC__) | ||||
| /* Test if arg and &(arg)[0] have the same type. This is true if arg is | ||||
|  * an array but not if it's a pointer. */ | ||||
| #define IS_ARRAY_NOT_POINTER( arg )                                     \ | ||||
|     ( ! __builtin_types_compatible_p( __typeof__( arg ),                \ | ||||
|                                       __typeof__( &( arg )[0] ) ) ) | ||||
| #else | ||||
| /* On platforms where we don't know how to implement this check, | ||||
|  * omit it. Oh well, a non-portable check is better than nothing. */ | ||||
| #define IS_ARRAY_NOT_POINTER( arg ) 1 | ||||
| #endif | ||||
| 
 | ||||
| /* A compile-time constant with the value 0. If `const_expr` is not a | ||||
|  * compile-time constant with a nonzero value, cause a compile-time error. */ | ||||
| #define STATIC_ASSERT_EXPR( const_expr )                                \ | ||||
|     ( 0 && sizeof( struct { int STATIC_ASSERT : 1 - 2 * ! ( const_expr ); } ) ) | ||||
| /* Return the scalar value `value` (possibly promoted). This is a compile-time | ||||
|  * constant if `value` is. `condition` must be a compile-time constant. | ||||
|  * If `condition` is false, arrange to cause a compile-time error. */ | ||||
| #define STATIC_ASSERT_THEN_RETURN( condition, value )   \ | ||||
|     ( STATIC_ASSERT_EXPR( condition ) ? 0 : ( value ) ) | ||||
| 
 | ||||
| #define ARRAY_LENGTH_UNSAFE( array )            \ | ||||
|     ( sizeof( array ) / sizeof( *( array ) ) ) | ||||
| /** Return the number of elements of a static or stack array. | ||||
|  * | ||||
|  * \param array         A value of array (not pointer) type. | ||||
|  * | ||||
|  * \return The number of elements of the array. | ||||
|  */ | ||||
| #define ARRAY_LENGTH( array )                                           \ | ||||
|     ( STATIC_ASSERT_THEN_RETURN( IS_ARRAY_NOT_POINTER( array ),         \ | ||||
|                                  ARRAY_LENGTH_UNSAFE( array ) ) ) | ||||
| 
 | ||||
| /** Return the smaller of two values. | ||||
|  * | ||||
|  * \param x         An integer-valued expression without side effects. | ||||
|  * \param y         An integer-valued expression without side effects. | ||||
|  * | ||||
|  * \return The smaller of \p x and \p y. | ||||
|  */ | ||||
| #define MIN( x, y ) ( ( x ) < ( y ) ? ( x ) : ( y ) ) | ||||
| 
 | ||||
| /** Return the larger of two values. | ||||
|  * | ||||
|  * \param x         An integer-valued expression without side effects. | ||||
|  * \param y         An integer-valued expression without side effects. | ||||
|  * | ||||
|  * \return The larger of \p x and \p y. | ||||
|  */ | ||||
| #define MAX( x, y ) ( ( x ) > ( y ) ? ( x ) : ( y ) ) | ||||
| 
 | ||||
| /** Allocate memory dynamically and fail the test case if this fails. | ||||
|  * | ||||
|  * You must set \p pointer to \c NULL before calling this macro and | ||||
|  | @ -402,30 +347,6 @@ typedef enum | |||
|     }                                                             \ | ||||
|     while( 0 ) | ||||
| 
 | ||||
| /* | ||||
|  * 32-bit integer manipulation macros (big endian) | ||||
|  */ | ||||
| #ifndef GET_UINT32_BE | ||||
| #define GET_UINT32_BE(n,b,i)                            \ | ||||
| {                                                       \ | ||||
|     (n) = ( (uint32_t) (b)[(i)    ] << 24 )             \ | ||||
|         | ( (uint32_t) (b)[(i) + 1] << 16 )             \ | ||||
|         | ( (uint32_t) (b)[(i) + 2] <<  8 )             \ | ||||
|         | ( (uint32_t) (b)[(i) + 3]       );            \ | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #ifndef PUT_UINT32_BE | ||||
| #define PUT_UINT32_BE(n,b,i)                            \ | ||||
| {                                                       \ | ||||
|     (b)[(i)    ] = (unsigned char) ( (n) >> 24 );       \ | ||||
|     (b)[(i) + 1] = (unsigned char) ( (n) >> 16 );       \ | ||||
|     (b)[(i) + 2] = (unsigned char) ( (n) >>  8 );       \ | ||||
|     (b)[(i) + 3] = (unsigned char) ( (n)       );       \ | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /*----------------------------------------------------------------------------*/ | ||||
| /* Global variables */ | ||||
| 
 | ||||
|  | @ -448,10 +369,6 @@ typedef struct | |||
| test_info_t; | ||||
| static test_info_t test_info; | ||||
| 
 | ||||
| #if defined(MBEDTLS_PLATFORM_C) | ||||
| mbedtls_platform_context platform_ctx; | ||||
| #endif | ||||
| 
 | ||||
| #if defined(MBEDTLS_CHECK_PARAMS) | ||||
| jmp_buf param_fail_jmp; | ||||
| jmp_buf jmp_tmp; | ||||
|  | @ -504,22 +421,6 @@ void test_skip( const char *test, int line_no, const char* filename ) | |||
|     test_info.filename = filename; | ||||
| } | ||||
| 
 | ||||
| static int platform_setup() | ||||
| { | ||||
|     int ret = 0; | ||||
| #if defined(MBEDTLS_PLATFORM_C) | ||||
|     ret = mbedtls_platform_setup( &platform_ctx ); | ||||
| #endif /* MBEDTLS_PLATFORM_C */ | ||||
|     return( ret ); | ||||
| } | ||||
| 
 | ||||
| static void platform_teardown() | ||||
| { | ||||
| #if defined(MBEDTLS_PLATFORM_C) | ||||
|     mbedtls_platform_teardown( &platform_ctx ); | ||||
| #endif /* MBEDTLS_PLATFORM_C */ | ||||
| } | ||||
| 
 | ||||
| #if defined(MBEDTLS_CHECK_PARAMS) | ||||
| void mbedtls_param_failed( const char *failure_condition, | ||||
|                            const char *file, | ||||
|  | @ -586,268 +487,3 @@ static void close_output( FILE* out_stream ) | |||
|     fclose( out_stream ); | ||||
| } | ||||
| #endif /* __unix__ || __APPLE__ __MACH__ */ | ||||
| 
 | ||||
| int unhexify( unsigned char *obuf, const char *ibuf ) | ||||
| { | ||||
|     unsigned char c, c2; | ||||
|     int len = strlen( ibuf ) / 2; | ||||
|     TEST_HELPER_ASSERT( strlen( ibuf ) % 2 == 0 ); /* must be even number of bytes */ | ||||
| 
 | ||||
|     while( *ibuf != 0 ) | ||||
|     { | ||||
|         c = *ibuf++; | ||||
|         if( c >= '0' && c <= '9' ) | ||||
|             c -= '0'; | ||||
|         else if( c >= 'a' && c <= 'f' ) | ||||
|             c -= 'a' - 10; | ||||
|         else if( c >= 'A' && c <= 'F' ) | ||||
|             c -= 'A' - 10; | ||||
|         else | ||||
|             TEST_HELPER_ASSERT( 0 ); | ||||
| 
 | ||||
|         c2 = *ibuf++; | ||||
|         if( c2 >= '0' && c2 <= '9' ) | ||||
|             c2 -= '0'; | ||||
|         else if( c2 >= 'a' && c2 <= 'f' ) | ||||
|             c2 -= 'a' - 10; | ||||
|         else if( c2 >= 'A' && c2 <= 'F' ) | ||||
|             c2 -= 'A' - 10; | ||||
|         else | ||||
|             TEST_HELPER_ASSERT( 0 ); | ||||
| 
 | ||||
|         *obuf++ = ( c << 4 ) | c2; | ||||
|     } | ||||
| 
 | ||||
|     return len; | ||||
| } | ||||
| 
 | ||||
| void hexify( unsigned char *obuf, const unsigned char *ibuf, int len ) | ||||
| { | ||||
|     unsigned char l, h; | ||||
| 
 | ||||
|     while( len != 0 ) | ||||
|     { | ||||
|         h = *ibuf / 16; | ||||
|         l = *ibuf % 16; | ||||
| 
 | ||||
|         if( h < 10 ) | ||||
|             *obuf++ = '0' + h; | ||||
|         else | ||||
|             *obuf++ = 'a' + h - 10; | ||||
| 
 | ||||
|         if( l < 10 ) | ||||
|             *obuf++ = '0' + l; | ||||
|         else | ||||
|             *obuf++ = 'a' + l - 10; | ||||
| 
 | ||||
|         ++ibuf; | ||||
|         len--; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * Allocate and zeroize a buffer. | ||||
|  * | ||||
|  * If the size if zero, a pointer to a zeroized 1-byte buffer is returned. | ||||
|  * | ||||
|  * For convenience, dies if allocation fails. | ||||
|  */ | ||||
| static unsigned char *zero_alloc( size_t len ) | ||||
| { | ||||
|     void *p; | ||||
|     size_t actual_len = ( len != 0 ) ? len : 1; | ||||
| 
 | ||||
|     p = mbedtls_calloc( 1, actual_len ); | ||||
|     TEST_HELPER_ASSERT( p != NULL ); | ||||
| 
 | ||||
|     memset( p, 0x00, actual_len ); | ||||
| 
 | ||||
|     return( p ); | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * Allocate and fill a buffer from hex data. | ||||
|  * | ||||
|  * The buffer is sized exactly as needed. This allows to detect buffer | ||||
|  * overruns (including overreads) when running the test suite under valgrind. | ||||
|  * | ||||
|  * If the size if zero, a pointer to a zeroized 1-byte buffer is returned. | ||||
|  * | ||||
|  * For convenience, dies if allocation fails. | ||||
|  */ | ||||
| unsigned char *unhexify_alloc( const char *ibuf, size_t *olen ) | ||||
| { | ||||
|     unsigned char *obuf; | ||||
| 
 | ||||
|     *olen = strlen( ibuf ) / 2; | ||||
| 
 | ||||
|     if( *olen == 0 ) | ||||
|         return( zero_alloc( *olen ) ); | ||||
| 
 | ||||
|     obuf = mbedtls_calloc( 1, *olen ); | ||||
|     TEST_HELPER_ASSERT( obuf != NULL ); | ||||
| 
 | ||||
|     (void) unhexify( obuf, ibuf ); | ||||
| 
 | ||||
|     return( obuf ); | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * This function just returns data from rand(). | ||||
|  * Although predictable and often similar on multiple | ||||
|  * runs, this does not result in identical random on | ||||
|  * each run. So do not use this if the results of a | ||||
|  * test depend on the random data that is generated. | ||||
|  * | ||||
|  * rng_state shall be NULL. | ||||
|  */ | ||||
| static int rnd_std_rand( void *rng_state, unsigned char *output, size_t len ) | ||||
| { | ||||
| #if !defined(__OpenBSD__) | ||||
|     size_t i; | ||||
| 
 | ||||
|     if( rng_state != NULL ) | ||||
|         rng_state  = NULL; | ||||
| 
 | ||||
|     for( i = 0; i < len; ++i ) | ||||
|         output[i] = rand(); | ||||
| #else | ||||
|     if( rng_state != NULL ) | ||||
|         rng_state = NULL; | ||||
| 
 | ||||
|     arc4random_buf( output, len ); | ||||
| #endif /* !OpenBSD */ | ||||
| 
 | ||||
|     return( 0 ); | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * This function only returns zeros | ||||
|  * | ||||
|  * rng_state shall be NULL. | ||||
|  */ | ||||
| int rnd_zero_rand( void *rng_state, unsigned char *output, size_t len ) | ||||
| { | ||||
|     if( rng_state != NULL ) | ||||
|         rng_state  = NULL; | ||||
| 
 | ||||
|     memset( output, 0, len ); | ||||
| 
 | ||||
|     return( 0 ); | ||||
| } | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
|     unsigned char *buf; | ||||
|     size_t length; | ||||
| } rnd_buf_info; | ||||
| 
 | ||||
| /** | ||||
|  * This function returns random based on a buffer it receives. | ||||
|  * | ||||
|  * rng_state shall be a pointer to a rnd_buf_info structure. | ||||
|  * | ||||
|  * The number of bytes released from the buffer on each call to | ||||
|  * the random function is specified by per_call. (Can be between | ||||
|  * 1 and 4) | ||||
|  * | ||||
|  * After the buffer is empty it will return rand(); | ||||
|  */ | ||||
| int rnd_buffer_rand( void *rng_state, unsigned char *output, size_t len ) | ||||
| { | ||||
|     rnd_buf_info *info = (rnd_buf_info *) rng_state; | ||||
|     size_t use_len; | ||||
| 
 | ||||
|     if( rng_state == NULL ) | ||||
|         return( rnd_std_rand( NULL, output, len ) ); | ||||
| 
 | ||||
|     use_len = len; | ||||
|     if( len > info->length ) | ||||
|         use_len = info->length; | ||||
| 
 | ||||
|     if( use_len ) | ||||
|     { | ||||
|         memcpy( output, info->buf, use_len ); | ||||
|         info->buf += use_len; | ||||
|         info->length -= use_len; | ||||
|     } | ||||
| 
 | ||||
|     if( len - use_len > 0 ) | ||||
|         return( rnd_std_rand( NULL, output + use_len, len - use_len ) ); | ||||
| 
 | ||||
|     return( 0 ); | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * Info structure for the pseudo random function | ||||
|  * | ||||
|  * Key should be set at the start to a test-unique value. | ||||
|  * Do not forget endianness! | ||||
|  * State( v0, v1 ) should be set to zero. | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|     uint32_t key[16]; | ||||
|     uint32_t v0, v1; | ||||
| } rnd_pseudo_info; | ||||
| 
 | ||||
| /** | ||||
|  * This function returns random based on a pseudo random function. | ||||
|  * This means the results should be identical on all systems. | ||||
|  * Pseudo random is based on the XTEA encryption algorithm to | ||||
|  * generate pseudorandom. | ||||
|  * | ||||
|  * rng_state shall be a pointer to a rnd_pseudo_info structure. | ||||
|  */ | ||||
| int rnd_pseudo_rand( void *rng_state, unsigned char *output, size_t len ) | ||||
| { | ||||
|     rnd_pseudo_info *info = (rnd_pseudo_info *) rng_state; | ||||
|     uint32_t i, *k, sum, delta=0x9E3779B9; | ||||
|     unsigned char result[4], *out = output; | ||||
| 
 | ||||
|     if( rng_state == NULL ) | ||||
|         return( rnd_std_rand( NULL, output, len ) ); | ||||
| 
 | ||||
|     k = info->key; | ||||
| 
 | ||||
|     while( len > 0 ) | ||||
|     { | ||||
|         size_t use_len = ( len > 4 ) ? 4 : len; | ||||
|         sum = 0; | ||||
| 
 | ||||
|         for( i = 0; i < 32; i++ ) | ||||
|         { | ||||
|             info->v0 += ( ( ( info->v1 << 4 ) ^ ( info->v1 >> 5 ) ) | ||||
|                             + info->v1 ) ^ ( sum + k[sum & 3] ); | ||||
|             sum += delta; | ||||
|             info->v1 += ( ( ( info->v0 << 4 ) ^ ( info->v0 >> 5 ) ) | ||||
|                             + info->v0 ) ^ ( sum + k[( sum>>11 ) & 3] ); | ||||
|         } | ||||
| 
 | ||||
|         PUT_UINT32_BE( info->v0, result, 0 ); | ||||
|         memcpy( out, result, use_len ); | ||||
|         len -= use_len; | ||||
|         out += 4; | ||||
|     } | ||||
| 
 | ||||
|     return( 0 ); | ||||
| } | ||||
| 
 | ||||
| int hexcmp( uint8_t * a, uint8_t * b, uint32_t a_len, uint32_t b_len ) | ||||
| { | ||||
|     int ret = 0; | ||||
|     uint32_t i = 0; | ||||
| 
 | ||||
|     if( a_len != b_len ) | ||||
|         return( -1 ); | ||||
| 
 | ||||
|     for( i = 0; i < a_len; i++ ) | ||||
|     { | ||||
|         if( a[i] != b[i] ) | ||||
|         { | ||||
|             ret = -1; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
|     return ret; | ||||
| } | ||||
|  |  | |||
|  | @ -277,7 +277,8 @@ static int convert_params( size_t cnt , char ** params , int * int_params_store | |||
|         { | ||||
|             if ( verify_string( &val ) == 0 ) | ||||
|             { | ||||
|                 *int_params_store = unhexify( (unsigned char *) val, val ); | ||||
|                 *int_params_store = mbedtls_test_unhexify( | ||||
|                                         (unsigned char *) val, val ); | ||||
|                 *out++ = val; | ||||
|                 *out++ = (char *)(int_params_store++); | ||||
|             } | ||||
|  |  | |||
|  | @ -261,7 +261,7 @@ $platform_code | |||
|  */ | ||||
| int main( int argc, const char *argv[] ) | ||||
| { | ||||
|     int ret = platform_setup(); | ||||
|     int ret = mbedtls_test_platform_setup(); | ||||
|     if( ret != 0 ) | ||||
|     { | ||||
|         mbedtls_fprintf( stderr, | ||||
|  | @ -271,6 +271,6 @@ int main( int argc, const char *argv[] ) | |||
|     } | ||||
| 
 | ||||
|     ret = execute_tests( argc, argv ); | ||||
|     platform_teardown(); | ||||
|     mbedtls_test_platform_teardown(); | ||||
|     return( ret ); | ||||
| } | ||||
|  |  | |||
|  | @ -75,7 +75,7 @@ uint8_t receive_byte() | |||
|     c[1] = greentea_getc(); | ||||
|     c[2] = '\0'; | ||||
| 
 | ||||
|     TEST_HELPER_ASSERT( unhexify( &byte, c ) != 2 ); | ||||
|     TEST_HELPER_ASSERT( mbedtls_test_unhexify( &byte, c ) != 2 ); | ||||
|     return( byte ); | ||||
| } | ||||
| 
 | ||||
|  | @ -101,7 +101,7 @@ uint32_t receive_uint32() | |||
|                              }; | ||||
|     const uint8_t c[9] = { c_be[6], c_be[7], c_be[4], c_be[5], c_be[2], | ||||
|                            c_be[3], c_be[0], c_be[1], '\0' }; | ||||
|     TEST_HELPER_ASSERT( unhexify( (uint8_t*)&value, c ) != 8 ); | ||||
|     TEST_HELPER_ASSERT( mbedtls_test_unhexify( (uint8_t*)&value, c ) != 8 ); | ||||
|     return( value ); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -23,7 +23,8 @@ void aes_encrypt_ecb( data_t * key_str, data_t * src_str, | |||
|     { | ||||
|         TEST_ASSERT( mbedtls_aes_crypt_ecb( &ctx, MBEDTLS_AES_ENCRYPT, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, 16, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           16, hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -47,7 +48,8 @@ void aes_decrypt_ecb( data_t * key_str, data_t * src_str, | |||
|     { | ||||
|         TEST_ASSERT( mbedtls_aes_crypt_ecb( &ctx, MBEDTLS_AES_DECRYPT, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, 16, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           16, hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -72,7 +74,9 @@ void aes_encrypt_cbc( data_t * key_str, data_t * iv_str, | |||
|     if( cbc_result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -96,7 +100,9 @@ void aes_decrypt_cbc( data_t * key_str, data_t * iv_str, | |||
|     if( cbc_result == 0) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -119,17 +125,18 @@ void aes_encrypt_xts( char *hex_key_string, char *hex_data_unit_string, | |||
| 
 | ||||
|     mbedtls_aes_xts_init( &ctx ); | ||||
| 
 | ||||
|     data_unit = unhexify_alloc( hex_data_unit_string, &data_unit_len ); | ||||
|     data_unit = mbedtls_test_unhexify_alloc( hex_data_unit_string, | ||||
|                                              &data_unit_len ); | ||||
|     TEST_ASSERT( data_unit_len == AES_BLOCK_SIZE ); | ||||
| 
 | ||||
|     key = unhexify_alloc( hex_key_string, &key_len ); | ||||
|     key = mbedtls_test_unhexify_alloc( hex_key_string, &key_len ); | ||||
|     TEST_ASSERT( key_len % 2 == 0 ); | ||||
| 
 | ||||
|     src = unhexify_alloc( hex_src_string, &src_len ); | ||||
|     dst = unhexify_alloc( hex_dst_string, &dst_len ); | ||||
|     src = mbedtls_test_unhexify_alloc( hex_src_string, &src_len ); | ||||
|     dst = mbedtls_test_unhexify_alloc( hex_dst_string, &dst_len ); | ||||
|     TEST_ASSERT( src_len == dst_len ); | ||||
| 
 | ||||
|     output = zero_alloc( dst_len ); | ||||
|     output = mbedtls_test_zero_alloc( dst_len ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_aes_xts_setkey_enc( &ctx, key, key_len * 8 ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_aes_crypt_xts( &ctx, MBEDTLS_AES_ENCRYPT, src_len, | ||||
|  | @ -162,17 +169,18 @@ void aes_decrypt_xts( char *hex_key_string, char *hex_data_unit_string, | |||
| 
 | ||||
|     mbedtls_aes_xts_init( &ctx ); | ||||
| 
 | ||||
|     data_unit = unhexify_alloc( hex_data_unit_string, &data_unit_len ); | ||||
|     data_unit = mbedtls_test_unhexify_alloc( hex_data_unit_string, | ||||
|                                              &data_unit_len ); | ||||
|     TEST_ASSERT( data_unit_len == AES_BLOCK_SIZE ); | ||||
| 
 | ||||
|     key = unhexify_alloc( hex_key_string, &key_len ); | ||||
|     key = mbedtls_test_unhexify_alloc( hex_key_string, &key_len ); | ||||
|     TEST_ASSERT( key_len % 2 == 0 ); | ||||
| 
 | ||||
|     src = unhexify_alloc( hex_src_string, &src_len ); | ||||
|     dst = unhexify_alloc( hex_dst_string, &dst_len ); | ||||
|     src = mbedtls_test_unhexify_alloc( hex_src_string, &src_len ); | ||||
|     dst = mbedtls_test_unhexify_alloc( hex_dst_string, &dst_len ); | ||||
|     TEST_ASSERT( src_len == dst_len ); | ||||
| 
 | ||||
|     output = zero_alloc( dst_len ); | ||||
|     output = mbedtls_test_zero_alloc( dst_len ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_aes_xts_setkey_dec( &ctx, key, key_len * 8 ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_aes_crypt_xts( &ctx, MBEDTLS_AES_DECRYPT, src_len, | ||||
|  | @ -241,7 +249,8 @@ void aes_encrypt_cfb128( data_t * key_str, data_t * iv_str, | |||
|     mbedtls_aes_setkey_enc( &ctx, key_str->x, key_str->len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_aes_crypt_cfb128( &ctx, MBEDTLS_AES_ENCRYPT, 16, &iv_offset, iv_str->x, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, 16, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       16, hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_aes_free( &ctx ); | ||||
|  | @ -263,7 +272,8 @@ void aes_decrypt_cfb128( data_t * key_str, data_t * iv_str, | |||
|     mbedtls_aes_setkey_enc( &ctx, key_str->x, key_str->len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_aes_crypt_cfb128( &ctx, MBEDTLS_AES_DECRYPT, 16, &iv_offset, iv_str->x, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, 16, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       16, hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_aes_free( &ctx ); | ||||
|  | @ -284,7 +294,9 @@ void aes_encrypt_cfb8( data_t * key_str, data_t * iv_str, | |||
|     mbedtls_aes_setkey_enc( &ctx, key_str->x, key_str->len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_aes_crypt_cfb8( &ctx, MBEDTLS_AES_ENCRYPT, src_str->len, iv_str->x, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       src_str->len, | ||||
|                                       hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_aes_free( &ctx ); | ||||
|  | @ -305,7 +317,9 @@ void aes_decrypt_cfb8( data_t * key_str, data_t * iv_str, | |||
|     mbedtls_aes_setkey_enc( &ctx, key_str->x, key_str->len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_aes_crypt_cfb8( &ctx, MBEDTLS_AES_DECRYPT, src_str->len, iv_str->x, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       src_str->len, | ||||
|                                       hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_aes_free( &ctx ); | ||||
|  | @ -340,9 +354,9 @@ void aes_encrypt_ofb( int fragment_size, char *hex_key_string, | |||
|     TEST_ASSERT( strlen( hex_src_string ) <= ( 64 * 2 ) ); | ||||
|     TEST_ASSERT( strlen( hex_dst_string ) <= ( 64 * 2 ) ); | ||||
| 
 | ||||
|     key_len = unhexify( key_str, hex_key_string ); | ||||
|     unhexify( iv_str, hex_iv_string ); | ||||
|     in_buffer_len = unhexify( src_str, hex_src_string ); | ||||
|     key_len = mbedtls_test_unhexify( key_str, hex_key_string ); | ||||
|     mbedtls_test_unhexify( iv_str, hex_iv_string ); | ||||
|     in_buffer_len = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_aes_setkey_enc( &ctx, key_str, key_len * 8 ) == 0 ); | ||||
|     src_str_next = src_str; | ||||
|  | @ -352,7 +366,7 @@ void aes_encrypt_ofb( int fragment_size, char *hex_key_string, | |||
|         TEST_ASSERT( mbedtls_aes_crypt_ofb( &ctx, fragment_size, &iv_offset, | ||||
|                                             iv_str, src_str_next, output ) == 0 ); | ||||
| 
 | ||||
|         hexify( dst_str, output, fragment_size ); | ||||
|         mbedtls_test_hexify( dst_str, output, fragment_size ); | ||||
|         TEST_ASSERT( strncmp( (char *) dst_str, hex_dst_string, | ||||
|                               ( 2 * fragment_size ) ) == 0 ); | ||||
| 
 | ||||
|  |  | |||
|  | @ -21,7 +21,9 @@ void mbedtls_arc4_crypt( data_t * src_str, data_t * key_str, | |||
|     mbedtls_arc4_setup(&ctx, key_str->x, key_str->len); | ||||
|     TEST_ASSERT( mbedtls_arc4_crypt(&ctx, src_str->len, src_str->x, dst_str ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( dst_str, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( dst_str, hex_dst_string->x, | ||||
|                                       src_str->len, | ||||
|                                       hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_arc4_free( &ctx ); | ||||
|  |  | |||
|  | @ -222,8 +222,8 @@ void aria_encrypt_ecb( char *hex_key_string, char *hex_src_string, | |||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     mbedtls_aria_init( &ctx ); | ||||
| 
 | ||||
|     key_len = unhexify( key_str, hex_key_string ); | ||||
|     data_len = unhexify( src_str, hex_src_string ); | ||||
|     key_len = mbedtls_test_unhexify( key_str, hex_key_string ); | ||||
|     data_len = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_aria_setkey_enc( &ctx, key_str, key_len * 8 ) | ||||
|                  == setkey_result ); | ||||
|  | @ -234,7 +234,7 @@ void aria_encrypt_ecb( char *hex_key_string, char *hex_src_string, | |||
|             TEST_ASSERT( mbedtls_aria_crypt_ecb( &ctx, src_str + i, output + i ) | ||||
|                                                  == 0 ); | ||||
|         } | ||||
|         hexify( dst_str, output, data_len ); | ||||
|         mbedtls_test_hexify( dst_str, output, data_len ); | ||||
| 
 | ||||
|         TEST_ASSERT( strcasecmp( (char *) dst_str, hex_dst_string ) == 0 ); | ||||
|     } | ||||
|  | @ -261,8 +261,8 @@ void aria_decrypt_ecb( char *hex_key_string, char *hex_src_string, | |||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     mbedtls_aria_init( &ctx ); | ||||
| 
 | ||||
|     key_len = unhexify( key_str, hex_key_string ); | ||||
|     data_len = unhexify( src_str, hex_src_string ); | ||||
|     key_len = mbedtls_test_unhexify( key_str, hex_key_string ); | ||||
|     data_len = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_aria_setkey_dec( &ctx, key_str, key_len * 8 ) | ||||
|                  == setkey_result ); | ||||
|  | @ -273,7 +273,7 @@ void aria_decrypt_ecb( char *hex_key_string, char *hex_src_string, | |||
|             TEST_ASSERT( mbedtls_aria_crypt_ecb( &ctx, src_str + i, output + i ) | ||||
|                          == 0 ); | ||||
|         } | ||||
|         hexify( dst_str, output, data_len ); | ||||
|         mbedtls_test_hexify( dst_str, output, data_len ); | ||||
| 
 | ||||
|         TEST_ASSERT( strcasecmp( (char *) dst_str, hex_dst_string ) == 0 ); | ||||
|     } | ||||
|  | @ -303,9 +303,9 @@ void aria_encrypt_cbc( char *hex_key_string, char *hex_iv_string, | |||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     mbedtls_aria_init( &ctx ); | ||||
| 
 | ||||
|     key_len = unhexify( key_str, hex_key_string ); | ||||
|     unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = unhexify( src_str, hex_src_string ); | ||||
|     key_len = mbedtls_test_unhexify( key_str, hex_key_string ); | ||||
|     mbedtls_test_unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
| 
 | ||||
|     mbedtls_aria_setkey_enc( &ctx, key_str, key_len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_aria_crypt_cbc( &ctx, MBEDTLS_ARIA_ENCRYPT, data_len, | ||||
|  | @ -313,7 +313,7 @@ void aria_encrypt_cbc( char *hex_key_string, char *hex_iv_string, | |||
|                  == cbc_result ); | ||||
|     if( cbc_result == 0 ) | ||||
|     { | ||||
|         hexify( dst_str, output, data_len ); | ||||
|         mbedtls_test_hexify( dst_str, output, data_len ); | ||||
| 
 | ||||
|         TEST_ASSERT( strcasecmp( (char *) dst_str, hex_dst_string ) == 0 ); | ||||
|     } | ||||
|  | @ -343,9 +343,9 @@ void aria_decrypt_cbc( char *hex_key_string, char *hex_iv_string, | |||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     mbedtls_aria_init( &ctx ); | ||||
| 
 | ||||
|     key_len = unhexify( key_str, hex_key_string ); | ||||
|     unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = unhexify( src_str, hex_src_string ); | ||||
|     key_len = mbedtls_test_unhexify( key_str, hex_key_string ); | ||||
|     mbedtls_test_unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
| 
 | ||||
|     mbedtls_aria_setkey_dec( &ctx, key_str, key_len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_aria_crypt_cbc( &ctx, MBEDTLS_ARIA_DECRYPT, data_len, | ||||
|  | @ -353,7 +353,7 @@ void aria_decrypt_cbc( char *hex_key_string, char *hex_iv_string, | |||
|                  == cbc_result ); | ||||
|     if( cbc_result == 0 ) | ||||
|     { | ||||
|         hexify( dst_str, output, data_len ); | ||||
|         mbedtls_test_hexify( dst_str, output, data_len ); | ||||
| 
 | ||||
|         TEST_ASSERT( strcasecmp( (char *) dst_str, hex_dst_string ) == 0 ); | ||||
|     } | ||||
|  | @ -384,16 +384,16 @@ void aria_encrypt_cfb128( char *hex_key_string, char *hex_iv_string, | |||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     mbedtls_aria_init( &ctx ); | ||||
| 
 | ||||
|     key_len = unhexify( key_str, hex_key_string ); | ||||
|     unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = unhexify( src_str, hex_src_string ); | ||||
|     key_len = mbedtls_test_unhexify( key_str, hex_key_string ); | ||||
|     mbedtls_test_unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
| 
 | ||||
|     mbedtls_aria_setkey_enc( &ctx, key_str, key_len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_aria_crypt_cfb128( &ctx, MBEDTLS_ARIA_ENCRYPT, | ||||
|                                             data_len, &iv_offset, iv_str, | ||||
|                                             src_str, output ) | ||||
|                  == result ); | ||||
|     hexify( dst_str, output, data_len ); | ||||
|     mbedtls_test_hexify( dst_str, output, data_len ); | ||||
| 
 | ||||
|     TEST_ASSERT( strcasecmp( (char *) dst_str, hex_dst_string ) == 0 ); | ||||
| 
 | ||||
|  | @ -423,16 +423,16 @@ void aria_decrypt_cfb128( char *hex_key_string, char *hex_iv_string, | |||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     mbedtls_aria_init( &ctx ); | ||||
| 
 | ||||
|     key_len = unhexify( key_str, hex_key_string ); | ||||
|     unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = unhexify( src_str, hex_src_string ); | ||||
|     key_len = mbedtls_test_unhexify( key_str, hex_key_string ); | ||||
|     mbedtls_test_unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
| 
 | ||||
|     mbedtls_aria_setkey_enc( &ctx, key_str, key_len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_aria_crypt_cfb128( &ctx, MBEDTLS_ARIA_DECRYPT, | ||||
|                                             data_len, &iv_offset, iv_str, | ||||
|                                             src_str, output ) | ||||
|                  == result ); | ||||
|     hexify( dst_str, output, data_len ); | ||||
|     mbedtls_test_hexify( dst_str, output, data_len ); | ||||
| 
 | ||||
|     TEST_ASSERT( strcasecmp( (char *) dst_str, hex_dst_string ) == 0 ); | ||||
| 
 | ||||
|  | @ -463,15 +463,15 @@ void aria_encrypt_ctr( char *hex_key_string, char *hex_iv_string, | |||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     mbedtls_aria_init( &ctx ); | ||||
| 
 | ||||
|     key_len = unhexify( key_str, hex_key_string ); | ||||
|     unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = unhexify( src_str, hex_src_string ); | ||||
|     key_len = mbedtls_test_unhexify( key_str, hex_key_string ); | ||||
|     mbedtls_test_unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
| 
 | ||||
|     mbedtls_aria_setkey_enc( &ctx, key_str, key_len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_aria_crypt_ctr( &ctx, data_len, &iv_offset, iv_str, | ||||
|                                          blk, src_str, output ) | ||||
|                  == result ); | ||||
|     hexify( dst_str, output, data_len ); | ||||
|     mbedtls_test_hexify( dst_str, output, data_len ); | ||||
| 
 | ||||
|     TEST_ASSERT( strcasecmp( (char *) dst_str, hex_dst_string ) == 0 ); | ||||
| 
 | ||||
|  | @ -502,15 +502,15 @@ void aria_decrypt_ctr( char *hex_key_string, char *hex_iv_string, | |||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     mbedtls_aria_init( &ctx ); | ||||
| 
 | ||||
|     key_len = unhexify( key_str, hex_key_string ); | ||||
|     unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = unhexify( src_str, hex_src_string ); | ||||
|     key_len = mbedtls_test_unhexify( key_str, hex_key_string ); | ||||
|     mbedtls_test_unhexify( iv_str, hex_iv_string ); | ||||
|     data_len = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
| 
 | ||||
|     mbedtls_aria_setkey_enc( &ctx, key_str, key_len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_aria_crypt_ctr( &ctx, data_len, &iv_offset, iv_str, | ||||
|                                          blk, src_str, output ) | ||||
|                  == result ); | ||||
|     hexify( dst_str, output, data_len ); | ||||
|     mbedtls_test_hexify( dst_str, output, data_len ); | ||||
| 
 | ||||
|     TEST_ASSERT( strcasecmp( (char *) dst_str, hex_dst_string ) == 0 ); | ||||
| 
 | ||||
|  |  | |||
|  | @ -55,7 +55,7 @@ void base64_encode_hex( data_t * src, char * dst, int dst_buf_size, | |||
|     unsigned char *res = NULL; | ||||
|     size_t len; | ||||
| 
 | ||||
|     res = zero_alloc( dst_buf_size ); | ||||
|     res = mbedtls_test_zero_alloc( dst_buf_size ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_base64_encode( res, dst_buf_size, &len, src->x, src->len ) == result ); | ||||
|     if( result == 0 ) | ||||
|  | @ -76,7 +76,7 @@ void base64_decode_hex( char * src, data_t * dst, int dst_buf_size, | |||
|     unsigned char *res = NULL; | ||||
|     size_t len; | ||||
| 
 | ||||
|     res = zero_alloc( dst_buf_size ); | ||||
|     res = mbedtls_test_zero_alloc( dst_buf_size ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_base64_decode( res, dst_buf_size, &len, (unsigned char *) src, | ||||
|                                 strlen( src ) ) == result ); | ||||
|  |  | |||
|  | @ -181,7 +181,8 @@ void blowfish_encrypt_ecb( data_t * key_str, data_t * src_str, | |||
|     { | ||||
|         TEST_ASSERT( mbedtls_blowfish_crypt_ecb( &ctx, MBEDTLS_BLOWFISH_ENCRYPT, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, 8, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           8, hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -205,7 +206,8 @@ void blowfish_decrypt_ecb( data_t * key_str, data_t * src_str, | |||
|     { | ||||
|         TEST_ASSERT( mbedtls_blowfish_crypt_ecb( &ctx, MBEDTLS_BLOWFISH_DECRYPT, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, 8, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           8, hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -231,7 +233,9 @@ void blowfish_encrypt_cbc( data_t * key_str, data_t * iv_str, | |||
|     if( cbc_result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -256,7 +260,9 @@ void blowfish_decrypt_cbc( data_t * key_str, data_t * iv_str, | |||
|     if( cbc_result == 0) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -280,7 +286,9 @@ void blowfish_encrypt_cfb64( data_t * key_str, data_t * iv_str, | |||
|     mbedtls_blowfish_setkey( &ctx, key_str->x, key_str->len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_blowfish_crypt_cfb64( &ctx, MBEDTLS_BLOWFISH_ENCRYPT, src_str->len, &iv_offset, iv_str->x, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       src_str->len, | ||||
|                                       hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_blowfish_free( &ctx ); | ||||
|  | @ -303,7 +311,9 @@ void blowfish_decrypt_cfb64( data_t * key_str, data_t * iv_str, | |||
|     mbedtls_blowfish_setkey( &ctx, key_str->x, key_str->len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_blowfish_crypt_cfb64( &ctx, MBEDTLS_BLOWFISH_DECRYPT, src_str->len, &iv_offset, iv_str->x, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       src_str->len, | ||||
|                                       hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_blowfish_free( &ctx ); | ||||
|  | @ -327,7 +337,9 @@ void blowfish_encrypt_ctr( data_t * key_str, data_t * iv_str, | |||
|     mbedtls_blowfish_setkey( &ctx, key_str->x, key_str->len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_blowfish_crypt_ctr( &ctx, src_str->len, &iv_offset, iv_str->x, stream_str, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       src_str->len, | ||||
|                                       hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_blowfish_free( &ctx ); | ||||
|  |  | |||
|  | @ -189,7 +189,8 @@ void camellia_encrypt_ecb( data_t * key_str, data_t * src_str, | |||
|     { | ||||
|         TEST_ASSERT( mbedtls_camellia_crypt_ecb( &ctx, MBEDTLS_CAMELLIA_ENCRYPT, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, 16, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           16, hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -213,7 +214,8 @@ void camellia_decrypt_ecb( data_t * key_str, data_t * src_str, | |||
|     { | ||||
|         TEST_ASSERT( mbedtls_camellia_crypt_ecb( &ctx, MBEDTLS_CAMELLIA_DECRYPT, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, 16, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           16, hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -238,7 +240,9 @@ void camellia_encrypt_cbc( data_t * key_str, data_t * iv_str, | |||
|     if( cbc_result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -263,7 +267,9 @@ void camellia_decrypt_cbc( data_t * key_str, data_t * iv_str, | |||
|     if( cbc_result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -287,7 +293,8 @@ void camellia_encrypt_cfb128( data_t * key_str, data_t * iv_str, | |||
|     mbedtls_camellia_setkey_enc( &ctx, key_str->x, key_str->len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_camellia_crypt_cfb128( &ctx, MBEDTLS_CAMELLIA_ENCRYPT, 16, &iv_offset, iv_str->x, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, 16, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       16, hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_camellia_free( &ctx ); | ||||
|  | @ -310,7 +317,8 @@ void camellia_decrypt_cfb128( data_t * key_str, data_t * iv_str, | |||
|     mbedtls_camellia_setkey_enc( &ctx, key_str->x, key_str->len * 8 ); | ||||
|     TEST_ASSERT( mbedtls_camellia_crypt_cfb128( &ctx, MBEDTLS_CAMELLIA_DECRYPT, 16, &iv_offset, iv_str->x, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, 16, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       16, hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_camellia_free( &ctx ); | ||||
|  |  | |||
|  | @ -218,12 +218,14 @@ void mbedtls_ccm_star_encrypt_and_tag( int cipher_id, | |||
|     memset( source_address, 0x00, sizeof( source_address ) ); | ||||
|     memset( frame_counter, 0x00, sizeof( frame_counter ) ); | ||||
| 
 | ||||
|     key_len = unhexify( key, key_hex ); | ||||
|     msg_len = unhexify( msg, msg_hex ); | ||||
|     add_len = unhexify( add, add_hex ); | ||||
|     result_len = unhexify( result, result_hex ); | ||||
|     source_address_len = unhexify( source_address, source_address_hex ); | ||||
|     frame_counter_len = unhexify( frame_counter, frame_counter_hex ); | ||||
|     key_len = mbedtls_test_unhexify( key, key_hex ); | ||||
|     msg_len = mbedtls_test_unhexify( msg, msg_hex ); | ||||
|     add_len = mbedtls_test_unhexify( add, add_hex ); | ||||
|     result_len = mbedtls_test_unhexify( result, result_hex ); | ||||
|     source_address_len = mbedtls_test_unhexify( source_address, | ||||
|                                                 source_address_hex ); | ||||
|     frame_counter_len = mbedtls_test_unhexify( frame_counter, | ||||
|                                                frame_counter_hex ); | ||||
| 
 | ||||
|     if( sec_level % 4 == 0) | ||||
|         tag_len = 0; | ||||
|  | @ -286,12 +288,14 @@ void mbedtls_ccm_star_auth_decrypt( int cipher_id, | |||
|     memset( frame_counter, 0x00, sizeof( frame_counter ) ); | ||||
|     memset( tag, 0x00, sizeof( tag ) ); | ||||
| 
 | ||||
|     key_len = unhexify( key, key_hex ); | ||||
|     msg_len = unhexify( msg, msg_hex ); | ||||
|     add_len = unhexify( add, add_hex ); | ||||
|     result_len = unhexify( result, result_hex ); | ||||
|     source_address_len = unhexify( source_address, source_address_hex ); | ||||
|     frame_counter_len = unhexify( frame_counter, frame_counter_hex ); | ||||
|     key_len = mbedtls_test_unhexify( key, key_hex ); | ||||
|     msg_len = mbedtls_test_unhexify( msg, msg_hex ); | ||||
|     add_len = mbedtls_test_unhexify( add, add_hex ); | ||||
|     result_len = mbedtls_test_unhexify( result, result_hex ); | ||||
|     source_address_len = mbedtls_test_unhexify( source_address, | ||||
|                                                 source_address_hex ); | ||||
|     frame_counter_len = mbedtls_test_unhexify( frame_counter, | ||||
|                                                frame_counter_hex ); | ||||
| 
 | ||||
|     if( sec_level % 4 == 0) | ||||
|         tag_len = 0; | ||||
|  |  | |||
|  | @ -31,10 +31,10 @@ void chacha20_crypt( char *hex_key_string, | |||
|     memset( dst_str,    0x00, sizeof( dst_str ) ); | ||||
|     memset( output,     0x00, sizeof( output ) ); | ||||
| 
 | ||||
|     key_len   = unhexify( key_str, hex_key_string ); | ||||
|     nonce_len = unhexify( nonce_str, hex_nonce_string ); | ||||
|     src_len   = unhexify( src_str, hex_src_string ); | ||||
|     dst_len   = unhexify( dst_str, hex_dst_string ); | ||||
|     key_len   = mbedtls_test_unhexify( key_str, hex_key_string ); | ||||
|     nonce_len = mbedtls_test_unhexify( nonce_str, hex_nonce_string ); | ||||
|     src_len   = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
|     dst_len   = mbedtls_test_unhexify( dst_str, hex_dst_string ); | ||||
| 
 | ||||
|     TEST_ASSERT( src_len   == dst_len ); | ||||
|     TEST_ASSERT( key_len   == 32U ); | ||||
|  | @ -45,7 +45,7 @@ void chacha20_crypt( char *hex_key_string, | |||
|      */ | ||||
|     TEST_ASSERT( mbedtls_chacha20_crypt( key_str, nonce_str, counter, src_len, src_str, output ) == 0 ); | ||||
| 
 | ||||
|     hexify( dst_str, output, src_len ); | ||||
|     mbedtls_test_hexify( dst_str, output, src_len ); | ||||
|     TEST_ASSERT( strcmp( (char*) dst_str, hex_dst_string ) == 0 ); | ||||
| 
 | ||||
|     /* | ||||
|  | @ -60,7 +60,7 @@ void chacha20_crypt( char *hex_key_string, | |||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     TEST_ASSERT( mbedtls_chacha20_update( &ctx, src_len, src_str, output ) == 0 ); | ||||
| 
 | ||||
|     hexify( dst_str, output, src_len ); | ||||
|     mbedtls_test_hexify( dst_str, output, src_len ); | ||||
|     TEST_ASSERT( strcmp( (char*) dst_str, hex_dst_string ) == 0 ); | ||||
| 
 | ||||
|     /* | ||||
|  | @ -75,7 +75,7 @@ void chacha20_crypt( char *hex_key_string, | |||
|     TEST_ASSERT( mbedtls_chacha20_update( &ctx, 1, src_str, output ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_chacha20_update( &ctx, src_len - 1, src_str + 1, output + 1 ) == 0 ); | ||||
| 
 | ||||
|     hexify( dst_str, output, src_len ); | ||||
|     mbedtls_test_hexify( dst_str, output, src_len ); | ||||
|     TEST_ASSERT( strcmp( (char*) dst_str, hex_dst_string ) == 0 ); | ||||
| 
 | ||||
|     mbedtls_chacha20_free( &ctx ); | ||||
|  |  | |||
|  | @ -33,12 +33,12 @@ void mbedtls_chachapoly_enc( char *hex_key_string, char *hex_nonce_string, char | |||
|     memset( output_str, 0x00, sizeof( output_str ) ); | ||||
|     memset( mac_str,    0x00, sizeof( mac_str ) ); | ||||
| 
 | ||||
|     aad_len    = unhexify( aad_str,    hex_aad_string    ); | ||||
|     input_len  = unhexify( input_str,  hex_input_string  ); | ||||
|     output_len = unhexify( output_str, hex_output_string ); | ||||
|     key_len    = unhexify( key_str,    hex_key_string    ); | ||||
|     nonce_len  = unhexify( nonce_str,  hex_nonce_string  ); | ||||
|     mac_len    = unhexify( mac_str,    hex_mac_string    ); | ||||
|     aad_len    = mbedtls_test_unhexify( aad_str,    hex_aad_string    ); | ||||
|     input_len  = mbedtls_test_unhexify( input_str,  hex_input_string  ); | ||||
|     output_len = mbedtls_test_unhexify( output_str, hex_output_string ); | ||||
|     key_len    = mbedtls_test_unhexify( key_str,    hex_key_string    ); | ||||
|     nonce_len  = mbedtls_test_unhexify( nonce_str,  hex_nonce_string  ); | ||||
|     mac_len    = mbedtls_test_unhexify( mac_str,    hex_mac_string    ); | ||||
| 
 | ||||
|     TEST_ASSERT( key_len   == 32 ); | ||||
|     TEST_ASSERT( nonce_len == 12 ); | ||||
|  | @ -87,12 +87,12 @@ void mbedtls_chachapoly_dec( char *hex_key_string, char *hex_nonce_string, char | |||
|     memset( output_str, 0x00, sizeof( output_str ) ); | ||||
|     memset( mac_str,    0x00, sizeof( mac_str ) ); | ||||
| 
 | ||||
|     aad_len    = unhexify( aad_str,    hex_aad_string    ); | ||||
|     input_len  = unhexify( input_str,  hex_input_string  ); | ||||
|     output_len = unhexify( output_str, hex_output_string ); | ||||
|     key_len    = unhexify( key_str,    hex_key_string    ); | ||||
|     nonce_len  = unhexify( nonce_str,  hex_nonce_string  ); | ||||
|     mac_len    = unhexify( mac_str,    hex_mac_string    ); | ||||
|     aad_len    = mbedtls_test_unhexify( aad_str,    hex_aad_string    ); | ||||
|     input_len  = mbedtls_test_unhexify( input_str,  hex_input_string  ); | ||||
|     output_len = mbedtls_test_unhexify( output_str, hex_output_string ); | ||||
|     key_len    = mbedtls_test_unhexify( key_str,    hex_key_string    ); | ||||
|     nonce_len  = mbedtls_test_unhexify( nonce_str,  hex_nonce_string  ); | ||||
|     mac_len    = mbedtls_test_unhexify( mac_str,    hex_mac_string    ); | ||||
| 
 | ||||
|     TEST_ASSERT( key_len   == 32 ); | ||||
|     TEST_ASSERT( nonce_len == 12 ); | ||||
|  |  | |||
|  | @ -10,7 +10,7 @@ | |||
| #endif | ||||
| 
 | ||||
| #if defined(MBEDTLS_USE_PSA_CRYPTO) | ||||
| #include "psa_crypto_helpers.h" | ||||
| #include "test/psa_crypto_helpers.h" | ||||
| #endif | ||||
| 
 | ||||
| /* END_HEADER */ | ||||
|  | @ -1161,15 +1161,15 @@ void test_vec_crypt( int cipher_id, int operation, char *hex_key, | |||
|     TEST_ASSERT( 0 == mbedtls_cipher_setup( &ctx, | ||||
|                               mbedtls_cipher_info_from_type( cipher_id ) ) ); | ||||
| 
 | ||||
|     key_len = unhexify( key, hex_key ); | ||||
|     inputlen =  unhexify( input, hex_input ); | ||||
|     resultlen = unhexify( result, hex_result ); | ||||
|     key_len = mbedtls_test_unhexify( key, hex_key ); | ||||
|     inputlen =  mbedtls_test_unhexify( input, hex_input ); | ||||
|     resultlen = mbedtls_test_unhexify( result, hex_result ); | ||||
| 
 | ||||
|     TEST_ASSERT( 0 == mbedtls_cipher_setkey( &ctx, key, 8 * key_len, operation ) ); | ||||
|     if( MBEDTLS_MODE_CBC == ctx.cipher_info->mode ) | ||||
|         TEST_ASSERT( 0 == mbedtls_cipher_set_padding_mode( &ctx, MBEDTLS_PADDING_NONE ) ); | ||||
| 
 | ||||
|     iv_len = unhexify( iv, hex_iv ); | ||||
|     iv_len = mbedtls_test_unhexify( iv, hex_iv ); | ||||
| 
 | ||||
|     TEST_ASSERT( finish_result == mbedtls_cipher_crypt( &ctx, iv_len ? iv : NULL, | ||||
|                                                         iv_len, input, inputlen, | ||||
|  |  | |||
|  | @ -316,7 +316,8 @@ void ctr_drbg_seed_file( char * path, int ret ) | |||
| 
 | ||||
|     mbedtls_ctr_drbg_init( &ctx ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ctr_drbg_seed( &ctx, rnd_std_rand, NULL, NULL, 0 ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ctr_drbg_seed( &ctx, mbedtls_test_rnd_std_rand, | ||||
|                                         NULL, NULL, 0 ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ctr_drbg_write_seed_file( &ctx, path ) == ret ); | ||||
|     TEST_ASSERT( mbedtls_ctr_drbg_update_seed_file( &ctx, path ) == ret ); | ||||
| 
 | ||||
|  |  | |||
|  | @ -28,7 +28,8 @@ void des_encrypt_ecb( data_t * key_str, data_t * src_str, | |||
|     mbedtls_des_setkey_enc( &ctx, key_str->x ); | ||||
|     TEST_ASSERT( mbedtls_des_crypt_ecb( &ctx, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, 8, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       8, hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_des_free( &ctx ); | ||||
|  | @ -49,7 +50,8 @@ void des_decrypt_ecb( data_t * key_str, data_t * src_str, | |||
|     mbedtls_des_setkey_dec( &ctx, key_str->x ); | ||||
|     TEST_ASSERT( mbedtls_des_crypt_ecb( &ctx, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, 8, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       8, hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_des_free( &ctx ); | ||||
|  | @ -73,7 +75,9 @@ void des_encrypt_cbc( data_t * key_str, data_t * iv_str, | |||
|     if( cbc_result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -98,7 +102,9 @@ void des_decrypt_cbc( data_t * key_str, data_t * iv_str, | |||
|     if( cbc_result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -126,7 +132,8 @@ void des3_encrypt_ecb( int key_count, data_t * key_str, | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_des3_crypt_ecb( &ctx, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, 8, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       8, hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_des3_free( &ctx ); | ||||
|  | @ -153,7 +160,8 @@ void des3_decrypt_ecb( int key_count, data_t * key_str, | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_des3_crypt_ecb( &ctx, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, 8, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       8, hex_dst_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_des3_free( &ctx ); | ||||
|  | @ -184,7 +192,9 @@ void des3_encrypt_cbc( int key_count, data_t * key_str, | |||
|     if( cbc_result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -216,7 +226,9 @@ void des3_decrypt_cbc( int key_count, data_t * key_str, | |||
|     if( cbc_result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  |  | |||
|  | @ -36,17 +36,17 @@ void dhm_invalid_params( ) | |||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_DHM_BAD_INPUT_DATA, | ||||
|                             mbedtls_dhm_make_params( NULL, buflen, | ||||
|                                                      buf, &len, | ||||
|                                                      rnd_std_rand, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_DHM_BAD_INPUT_DATA, | ||||
|                             mbedtls_dhm_make_params( &ctx, buflen, | ||||
|                                                      NULL, &len, | ||||
|                                                      rnd_std_rand, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_DHM_BAD_INPUT_DATA, | ||||
|                             mbedtls_dhm_make_params( &ctx, buflen, | ||||
|                                                      buf, NULL, | ||||
|                                                      rnd_std_rand, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_DHM_BAD_INPUT_DATA, | ||||
|                             mbedtls_dhm_make_params( &ctx, buflen, | ||||
|  | @ -69,12 +69,12 @@ void dhm_invalid_params( ) | |||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_DHM_BAD_INPUT_DATA, | ||||
|                             mbedtls_dhm_make_public( NULL, buflen, | ||||
|                                                      buf, buflen, | ||||
|                                                      rnd_std_rand, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_DHM_BAD_INPUT_DATA, | ||||
|                             mbedtls_dhm_make_public( &ctx, buflen, | ||||
|                                                      NULL, buflen, | ||||
|                                                      rnd_std_rand, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_DHM_BAD_INPUT_DATA, | ||||
|                             mbedtls_dhm_make_public( &ctx, buflen, | ||||
|  | @ -83,16 +83,16 @@ void dhm_invalid_params( ) | |||
|                                                      NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_DHM_BAD_INPUT_DATA, | ||||
|                             mbedtls_dhm_calc_secret( NULL, buf, buflen, | ||||
|                                                      &len, rnd_std_rand, | ||||
|                             mbedtls_dhm_calc_secret( NULL, buf, buflen, &len, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_DHM_BAD_INPUT_DATA, | ||||
|                             mbedtls_dhm_calc_secret( &ctx, NULL, buflen, | ||||
|                                                      &len, rnd_std_rand, | ||||
|                             mbedtls_dhm_calc_secret( &ctx, NULL, buflen, &len, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_DHM_BAD_INPUT_DATA, | ||||
|                             mbedtls_dhm_calc_secret( &ctx, buf, buflen, | ||||
|                                                      NULL, rnd_std_rand, | ||||
|                             mbedtls_dhm_calc_secret( &ctx, buf, buflen, NULL, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
| 
 | ||||
| #if defined(MBEDTLS_ASN1_PARSE_C) | ||||
|  | @ -130,7 +130,7 @@ void dhm_do_dhm( int radix_P, char *input_P, | |||
|     size_t sec_srv_len; | ||||
|     size_t sec_cli_len; | ||||
|     int x_size, i; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_dhm_init( &ctx_srv ); | ||||
|     mbedtls_dhm_init( &ctx_cli ); | ||||
|  | @ -138,7 +138,7 @@ void dhm_do_dhm( int radix_P, char *input_P, | |||
|     memset( pub_cli, 0x00, 1000 ); | ||||
|     memset( sec_srv, 0x00, 1000 ); | ||||
|     memset( sec_cli, 0x00, 1000 ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     /* | ||||
|      * Set params | ||||
|  | @ -151,7 +151,9 @@ void dhm_do_dhm( int radix_P, char *input_P, | |||
|     /* | ||||
|      * First key exchange | ||||
|      */ | ||||
|     TEST_ASSERT( mbedtls_dhm_make_params( &ctx_srv, x_size, ske, &ske_len, &rnd_pseudo_rand, &rnd_info ) == result ); | ||||
|     TEST_ASSERT( mbedtls_dhm_make_params( &ctx_srv, x_size, ske, &ske_len, | ||||
|                                           &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info ) == result ); | ||||
|     if ( result != 0 ) | ||||
|         goto exit; | ||||
| 
 | ||||
|  | @ -159,10 +161,15 @@ void dhm_do_dhm( int radix_P, char *input_P, | |||
|     ske[ske_len++] = 0; | ||||
|     TEST_ASSERT( mbedtls_dhm_read_params( &ctx_cli, &p, ske + ske_len ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_dhm_make_public( &ctx_cli, x_size, pub_cli, pub_cli_len, &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_dhm_make_public( &ctx_cli, x_size, pub_cli, pub_cli_len, | ||||
|                                           &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_dhm_read_public( &ctx_srv, pub_cli, pub_cli_len ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_dhm_calc_secret( &ctx_srv, sec_srv, sizeof( sec_srv ), &sec_srv_len, &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_dhm_calc_secret( &ctx_srv, sec_srv, sizeof( sec_srv ), | ||||
|                                           &sec_srv_len, | ||||
|                                           &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_dhm_calc_secret( &ctx_cli, sec_cli, sizeof( sec_cli ), &sec_cli_len, NULL, NULL ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( sec_srv_len == sec_cli_len ); | ||||
|  | @ -173,7 +180,10 @@ void dhm_do_dhm( int radix_P, char *input_P, | |||
|     for( i = 0; i < 3; i++ ) | ||||
|     { | ||||
|         sec_srv_len = 1000; | ||||
|         TEST_ASSERT( mbedtls_dhm_calc_secret( &ctx_srv, sec_srv, sizeof( sec_srv ), &sec_srv_len, &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_dhm_calc_secret( &ctx_srv, sec_srv, | ||||
|                                               sizeof( sec_srv ), &sec_srv_len, | ||||
|                                               &mbedtls_test_rnd_pseudo_rand, | ||||
|                                               &rnd_info ) == 0 ); | ||||
| 
 | ||||
|         TEST_ASSERT( sec_srv_len == sec_cli_len ); | ||||
|         TEST_ASSERT( sec_srv_len != 0 ); | ||||
|  | @ -185,15 +195,22 @@ void dhm_do_dhm( int radix_P, char *input_P, | |||
|      */ | ||||
|     p = ske; | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_dhm_make_params( &ctx_srv, x_size, ske, &ske_len, &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_dhm_make_params( &ctx_srv, x_size, ske, &ske_len, | ||||
|                                           &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info ) == 0 ); | ||||
|     ske[ske_len++] = 0; | ||||
|     ske[ske_len++] = 0; | ||||
|     TEST_ASSERT( mbedtls_dhm_read_params( &ctx_cli, &p, ske + ske_len ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_dhm_make_public( &ctx_cli, x_size, pub_cli, pub_cli_len, &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_dhm_make_public( &ctx_cli, x_size, pub_cli, pub_cli_len, | ||||
|                                           &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_dhm_read_public( &ctx_srv, pub_cli, pub_cli_len ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_dhm_calc_secret( &ctx_srv, sec_srv, sizeof( sec_srv ), &sec_srv_len, &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_dhm_calc_secret( &ctx_srv, sec_srv, sizeof( sec_srv ), | ||||
|                                           &sec_srv_len, | ||||
|                                           &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_dhm_calc_secret( &ctx_cli, sec_cli, sizeof( sec_cli ), &sec_cli_len, NULL, NULL ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( sec_srv_len == sec_cli_len ); | ||||
|  |  | |||
|  | @ -19,7 +19,7 @@ exit: | |||
| 
 | ||||
| static int load_private_key( int grp_id, data_t *private_key, | ||||
|                              mbedtls_ecp_keypair *ecp, | ||||
|                              rnd_pseudo_info *rnd_info ) | ||||
|                              mbedtls_test_rnd_pseudo_info *rnd_info ) | ||||
| { | ||||
|     int ok = 0; | ||||
|     TEST_ASSERT( mbedtls_ecp_read_key( grp_id, ecp, | ||||
|  | @ -29,7 +29,8 @@ static int load_private_key( int grp_id, data_t *private_key, | |||
|     /* Calculate the public key from the private key. */ | ||||
|     TEST_ASSERT( mbedtls_ecp_mul( &ecp->grp, &ecp->Q, &ecp->d, | ||||
|                                   &ecp->grp.G, | ||||
|                                   &rnd_pseudo_rand, rnd_info ) == 0 ); | ||||
|                                   &mbedtls_test_rnd_pseudo_rand, | ||||
|                                   rnd_info ) == 0 ); | ||||
|     ok = 1; | ||||
| exit: | ||||
|     return( ok ); | ||||
|  | @ -72,49 +73,54 @@ void ecdh_invalid_param( ) | |||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_gen_public( NULL, &m, &P, | ||||
|                                                      rnd_std_rand, NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_gen_public( &grp, NULL, &P, | ||||
|                                                      rnd_std_rand, NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_gen_public( &grp, &m, NULL, | ||||
|                                                      rnd_std_rand, NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_gen_public( &grp, &m, &P, | ||||
|                                                      NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_compute_shared( NULL, &m, &P, &m, | ||||
|                                                          rnd_std_rand, NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_compute_shared( &grp, NULL, &P, &m, | ||||
|                                                          rnd_std_rand, NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_compute_shared( &grp, &m, NULL, &m, | ||||
|                                                          rnd_std_rand, NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_compute_shared( &grp, &m, &P, NULL, | ||||
|                                                          rnd_std_rand, NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_setup( NULL, valid_grp ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_make_params( NULL, &olen, | ||||
|                                                       buf, buflen, | ||||
|                                                       rnd_std_rand, NULL ) ); | ||||
|          mbedtls_ecdh_make_params( NULL, &olen, buf, buflen, | ||||
|                                    mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_make_params( &ctx, NULL, | ||||
|                                                       buf, buflen, | ||||
|                                                       rnd_std_rand, NULL ) ); | ||||
|          mbedtls_ecdh_make_params( &ctx, NULL, buf, buflen, | ||||
|                                    mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_make_params( &ctx, &olen, | ||||
|                                                       NULL, buflen, | ||||
|                                                       rnd_std_rand, NULL ) ); | ||||
|          mbedtls_ecdh_make_params( &ctx, &olen, NULL, buflen, | ||||
|                                    mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_make_params( &ctx, &olen, | ||||
|                                                       buf, buflen, | ||||
|                                                       NULL, NULL ) ); | ||||
|          mbedtls_ecdh_make_params( &ctx, &olen, buf, buflen, NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_read_params( NULL, | ||||
|  | @ -141,25 +147,19 @@ void ecdh_invalid_param( ) | |||
|                                                      invalid_side ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_make_public( NULL, &olen, | ||||
|                                                       buf, buflen, | ||||
|                                                       rnd_std_rand, | ||||
|                                                       NULL ) ); | ||||
|          mbedtls_ecdh_make_public( NULL, &olen, buf, buflen, | ||||
|                                    mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_make_public( &ctx, NULL, | ||||
|                                                       buf, buflen, | ||||
|                                                       rnd_std_rand, | ||||
|                                                       NULL ) ); | ||||
|          mbedtls_ecdh_make_public( &ctx, NULL, buf, buflen, | ||||
|                                    mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_make_public( &ctx, &olen, | ||||
|                                                       NULL, buflen, | ||||
|                                                       rnd_std_rand, | ||||
|                                                       NULL ) ); | ||||
|          mbedtls_ecdh_make_public( &ctx, &olen, NULL, buflen, | ||||
|                                    mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_make_public( &ctx, &olen, | ||||
|                                                       buf, buflen, | ||||
|                                                       NULL, | ||||
|                                                       NULL ) ); | ||||
|          mbedtls_ecdh_make_public( &ctx, &olen, buf, buflen, NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_read_public( NULL, buf, buflen ) ); | ||||
|  | @ -167,17 +167,16 @@ void ecdh_invalid_param( ) | |||
|                             mbedtls_ecdh_read_public( &ctx, NULL, buflen ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_calc_secret( NULL, &olen, buf, buflen, | ||||
|                                                       rnd_std_rand, | ||||
|                                                       NULL ) ); | ||||
|          mbedtls_ecdh_calc_secret( NULL, &olen, buf, buflen, | ||||
|                                    mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_calc_secret( &ctx, NULL, buf, buflen, | ||||
|                                                       rnd_std_rand, | ||||
|                                                       NULL ) ); | ||||
|          mbedtls_ecdh_calc_secret( &ctx, NULL, buf, buflen, | ||||
|                                    mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdh_calc_secret( &ctx, &olen, NULL, buflen, | ||||
|                                                       rnd_std_rand, | ||||
|                                                       NULL ) ); | ||||
|          mbedtls_ecdh_calc_secret( &ctx, &olen, NULL, buflen, | ||||
|                                    mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
| exit: | ||||
|     return; | ||||
|  | @ -190,22 +189,25 @@ void ecdh_primitive_random( int id ) | |||
|     mbedtls_ecp_group grp; | ||||
|     mbedtls_ecp_point qA, qB; | ||||
|     mbedtls_mpi dA, dB, zA, zB; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_ecp_group_init( &grp ); | ||||
|     mbedtls_ecp_point_init( &qA ); mbedtls_ecp_point_init( &qB ); | ||||
|     mbedtls_mpi_init( &dA ); mbedtls_mpi_init( &dB ); | ||||
|     mbedtls_mpi_init( &zA ); mbedtls_mpi_init( &zB ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_group_load( &grp, id ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecdh_gen_public( &grp, &dA, &qA, &rnd_pseudo_rand, &rnd_info ) | ||||
|                  == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_gen_public( &grp, &dB, &qB, &rnd_pseudo_rand, &rnd_info ) | ||||
|                  == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_gen_public( &grp, &dA, &qA, | ||||
|                                           &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_gen_public( &grp, &dB, &qB, | ||||
|                                           &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_compute_shared( &grp, &zA, &qB, &dA, | ||||
|                                       &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                                               &mbedtls_test_rnd_pseudo_rand, | ||||
|                                               &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_compute_shared( &grp, &zB, &qA, &dB, | ||||
|                                       NULL, NULL ) == 0 ); | ||||
| 
 | ||||
|  | @ -227,7 +229,7 @@ void ecdh_primitive_testvec( int id, data_t * rnd_buf_A, char * xA_str, | |||
|     mbedtls_ecp_group grp; | ||||
|     mbedtls_ecp_point qA, qB; | ||||
|     mbedtls_mpi dA, dB, zA, zB, check; | ||||
|     rnd_buf_info rnd_info_A, rnd_info_B; | ||||
|     mbedtls_test_rnd_buf_info rnd_info_A, rnd_info_B; | ||||
| 
 | ||||
|     mbedtls_ecp_group_init( &grp ); | ||||
|     mbedtls_ecp_point_init( &qA ); mbedtls_ecp_point_init( &qB ); | ||||
|  | @ -269,7 +271,8 @@ void ecdh_primitive_testvec( int id, data_t * rnd_buf_A, char * xA_str, | |||
|     } | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecdh_gen_public( &grp, &dA, &qA, | ||||
|                                   rnd_buffer_rand, &rnd_info_A ) == 0 ); | ||||
|                                           mbedtls_test_rnd_buffer_rand, | ||||
|                                           &rnd_info_A ) == 0 ); | ||||
|     TEST_ASSERT( ! mbedtls_ecp_is_zero( &qA ) ); | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &check, 16, xA_str ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &qA.X, &check ) == 0 ); | ||||
|  | @ -277,7 +280,8 @@ void ecdh_primitive_testvec( int id, data_t * rnd_buf_A, char * xA_str, | |||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &qA.Y, &check ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecdh_gen_public( &grp, &dB, &qB, | ||||
|                                   rnd_buffer_rand, &rnd_info_B ) == 0 ); | ||||
|                                           mbedtls_test_rnd_buffer_rand, | ||||
|                                           &rnd_info_B ) == 0 ); | ||||
|     TEST_ASSERT( ! mbedtls_ecp_is_zero( &qB ) ); | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &check, 16, xB_str ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &qB.X, &check ) == 0 ); | ||||
|  | @ -305,28 +309,31 @@ void ecdh_exchange( int id ) | |||
|     unsigned char buf[1000]; | ||||
|     const unsigned char *vbuf; | ||||
|     size_t len; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     unsigned char res_buf[1000]; | ||||
|     size_t res_len; | ||||
| 
 | ||||
|     mbedtls_ecdh_init( &srv ); | ||||
|     mbedtls_ecdh_init( &cli ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecdh_setup( &srv, id ) == 0 ); | ||||
| 
 | ||||
|     memset( buf, 0x00, sizeof( buf ) ); vbuf = buf; | ||||
|     TEST_ASSERT( mbedtls_ecdh_make_params( &srv, &len, buf, 1000, | ||||
|                                            &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                                            &mbedtls_test_rnd_pseudo_rand, | ||||
|                                            &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_read_params( &cli, &vbuf, buf + len ) == 0 ); | ||||
| 
 | ||||
|     memset( buf, 0x00, sizeof( buf ) ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_make_public( &cli, &len, buf, 1000, | ||||
|                                            &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                                            &mbedtls_test_rnd_pseudo_rand, | ||||
|                                            &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_read_public( &srv, buf, len ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecdh_calc_secret( &srv, &len, buf, 1000, | ||||
|                                            &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                                            &mbedtls_test_rnd_pseudo_rand, | ||||
|                                            &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_calc_secret( &cli, &res_len, res_buf, 1000, | ||||
|                                            NULL, NULL ) == 0 ); | ||||
|     TEST_ASSERT( len == res_len ); | ||||
|  | @ -351,7 +358,7 @@ void ecdh_restart( int id, char *dA_str, char *dB_str, char *z_str, | |||
|     size_t z_len; | ||||
|     unsigned char rnd_buf_A[MBEDTLS_ECP_MAX_BYTES]; | ||||
|     unsigned char rnd_buf_B[MBEDTLS_ECP_MAX_BYTES]; | ||||
|     rnd_buf_info rnd_info_A, rnd_info_B; | ||||
|     mbedtls_test_rnd_buf_info rnd_info_A, rnd_info_B; | ||||
|     int cnt_restart; | ||||
|     mbedtls_ecp_group grp; | ||||
| 
 | ||||
|  | @ -359,13 +366,13 @@ void ecdh_restart( int id, char *dA_str, char *dB_str, char *z_str, | |||
|     mbedtls_ecdh_init( &srv ); | ||||
|     mbedtls_ecdh_init( &cli ); | ||||
| 
 | ||||
|     z_len = unhexify( z, z_str ); | ||||
|     z_len = mbedtls_test_unhexify( z, z_str ); | ||||
| 
 | ||||
|     rnd_info_A.buf = rnd_buf_A; | ||||
|     rnd_info_A.length = unhexify( rnd_buf_A, dA_str ); | ||||
|     rnd_info_A.length = mbedtls_test_unhexify( rnd_buf_A, dA_str ); | ||||
| 
 | ||||
|     rnd_info_B.buf = rnd_buf_B; | ||||
|     rnd_info_B.length = unhexify( rnd_buf_B, dB_str ); | ||||
|     rnd_info_B.length = mbedtls_test_unhexify( rnd_buf_B, dB_str ); | ||||
| 
 | ||||
|     /* The ECDH context is not guaranteed ot have an mbedtls_ecp_group structure | ||||
|      * in every configuration, therefore we load it separately. */ | ||||
|  | @ -393,7 +400,8 @@ void ecdh_restart( int id, char *dA_str, char *dB_str, char *z_str, | |||
|     cnt_restart = 0; | ||||
|     do { | ||||
|         ret = mbedtls_ecdh_make_params( &srv, &len, buf, sizeof( buf ), | ||||
|                                         rnd_buffer_rand, &rnd_info_A ); | ||||
|                                         mbedtls_test_rnd_buffer_rand, | ||||
|                                         &rnd_info_A ); | ||||
|     } while( ret == MBEDTLS_ERR_ECP_IN_PROGRESS && ++cnt_restart ); | ||||
| 
 | ||||
|     TEST_ASSERT( ret == 0 ); | ||||
|  | @ -411,7 +419,8 @@ void ecdh_restart( int id, char *dA_str, char *dB_str, char *z_str, | |||
|     cnt_restart = 0; | ||||
|     do { | ||||
|         ret = mbedtls_ecdh_make_public( &cli, &len, buf, sizeof( buf ), | ||||
|                                         rnd_buffer_rand, &rnd_info_B ); | ||||
|                                         mbedtls_test_rnd_buffer_rand, | ||||
|                                         &rnd_info_B ); | ||||
|     } while( ret == MBEDTLS_ERR_ECP_IN_PROGRESS && ++cnt_restart ); | ||||
| 
 | ||||
|     TEST_ASSERT( ret == 0 ); | ||||
|  | @ -470,26 +479,29 @@ void ecdh_exchange_legacy( int id ) | |||
|     const unsigned char *vbuf; | ||||
|     size_t len; | ||||
| 
 | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_ecdh_init( &srv ); | ||||
|     mbedtls_ecdh_init( &cli ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_group_load( &srv.grp, id ) == 0 ); | ||||
| 
 | ||||
|     memset( buf, 0x00, sizeof( buf ) ); vbuf = buf; | ||||
|     TEST_ASSERT( mbedtls_ecdh_make_params( &srv, &len, buf, 1000, | ||||
|                                    &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                                            &mbedtls_test_rnd_pseudo_rand, | ||||
|                                            &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_read_params( &cli, &vbuf, buf + len ) == 0 ); | ||||
| 
 | ||||
|     memset( buf, 0x00, sizeof( buf ) ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_make_public( &cli, &len, buf, 1000, | ||||
|                                            &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                                            &mbedtls_test_rnd_pseudo_rand, | ||||
|                                            &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_read_public( &srv, buf, len ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecdh_calc_secret( &srv, &len, buf, 1000, | ||||
|                                            &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                                            &mbedtls_test_rnd_pseudo_rand, | ||||
|                                            &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdh_calc_secret( &cli, &len, buf, 1000, NULL, | ||||
|                                            NULL ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &srv.z, &cli.z ) == 0 ); | ||||
|  | @ -507,14 +519,14 @@ void ecdh_exchange_calc_secret( int grp_id, | |||
|                                 int ours_first, | ||||
|                                 data_t *expected ) | ||||
| { | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     mbedtls_ecp_keypair our_key; | ||||
|     mbedtls_ecp_keypair their_key; | ||||
|     mbedtls_ecdh_context ecdh; | ||||
|     unsigned char shared_secret[MBEDTLS_ECP_MAX_BYTES]; | ||||
|     size_t shared_secret_length = 0; | ||||
| 
 | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
|     mbedtls_ecdh_init( &ecdh ); | ||||
|     mbedtls_ecp_keypair_init( &our_key ); | ||||
|     mbedtls_ecp_keypair_init( &their_key ); | ||||
|  | @ -545,7 +557,7 @@ void ecdh_exchange_calc_secret( int grp_id, | |||
|                      &ecdh, | ||||
|                      &shared_secret_length, | ||||
|                      shared_secret, sizeof( shared_secret ), | ||||
|                      &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                      &mbedtls_test_rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( shared_secret_length == expected->len ); | ||||
|     TEST_ASSERT( memcmp( expected->x, shared_secret, | ||||
|                          shared_secret_length ) == 0 ); | ||||
|  | @ -565,12 +577,12 @@ void ecdh_exchange_get_params_fail( int our_grp_id, | |||
|                                     int ours_first, | ||||
|                                     int expected_ret ) | ||||
| { | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     mbedtls_ecp_keypair our_key; | ||||
|     mbedtls_ecp_keypair their_key; | ||||
|     mbedtls_ecdh_context ecdh; | ||||
| 
 | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
|     mbedtls_ecdh_init( &ecdh ); | ||||
|     mbedtls_ecp_keypair_init( &our_key ); | ||||
|     mbedtls_ecp_keypair_init( &their_key ); | ||||
|  |  | |||
|  | @ -31,23 +31,28 @@ void ecdsa_invalid_param( ) | |||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdsa_sign( NULL, &m, &m, &m, | ||||
|                                                 buf, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|                                                 mbedtls_test_rnd_std_rand, | ||||
|                                                 NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecdsa_sign( &grp, NULL, &m, &m, | ||||
|                                                 buf, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|                                                 mbedtls_test_rnd_std_rand, | ||||
|                                                 NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_sign( &grp, &m, NULL, &m, | ||||
|                                                 buf, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|                                                 mbedtls_test_rnd_std_rand, | ||||
|                                                 NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_sign( &grp, &m, &m, NULL, | ||||
|                                                 buf, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|                                                 mbedtls_test_rnd_std_rand, | ||||
|                                                 NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_sign( &grp, &m, &m, &m, | ||||
|                                                 NULL, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|                                                 mbedtls_test_rnd_std_rand, | ||||
|                                                 NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_sign( &grp, &m, &m, &m, | ||||
|                                                 buf, sizeof( buf ), | ||||
|  | @ -58,27 +63,32 @@ void ecdsa_invalid_param( ) | |||
|                        mbedtls_ecdsa_sign_det_ext( NULL, &m, &m, &m, | ||||
|                                                    buf, sizeof( buf ), | ||||
|                                                    valid_md, | ||||
|                                                    rnd_std_rand, NULL ) ); | ||||
|                                                    mbedtls_test_rnd_std_rand, | ||||
|                                                    NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_sign_det_ext( &grp, NULL, &m, &m, | ||||
|                                                    buf, sizeof( buf ), | ||||
|                                                    valid_md, | ||||
|                                                    rnd_std_rand, NULL ) ); | ||||
|                                                    mbedtls_test_rnd_std_rand, | ||||
|                                                    NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_sign_det_ext( &grp, &m, NULL, &m, | ||||
|                                                    buf, sizeof( buf ), | ||||
|                                                    valid_md, | ||||
|                                                    rnd_std_rand, NULL ) ); | ||||
|                                                    mbedtls_test_rnd_std_rand, | ||||
|                                                    NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_sign_det_ext( &grp, &m, &m, NULL, | ||||
|                                                    buf, sizeof( buf ), | ||||
|                                                    valid_md, | ||||
|                                                    rnd_std_rand, NULL ) ); | ||||
|                                                    mbedtls_test_rnd_std_rand, | ||||
|                                                    NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_sign_det_ext( &grp, &m, &m, &m, | ||||
|                                                    NULL, sizeof( buf ), | ||||
|                                                    valid_md, | ||||
|                                                    rnd_std_rand, NULL ) ); | ||||
|                                                    mbedtls_test_rnd_std_rand, | ||||
|                                                    NULL ) ); | ||||
| #endif /* MBEDTLS_ECDSA_DETERMINISTIC */ | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|  | @ -103,62 +113,48 @@ void ecdsa_invalid_param( ) | |||
|                                                   &P, &m, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_write_signature( NULL, | ||||
|                                                            valid_md, | ||||
|                                                            buf, sizeof( buf ), | ||||
|                                                            buf, &slen, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_write_signature( &ctx, | ||||
|                                                            valid_md, | ||||
|                                                            NULL, sizeof( buf ), | ||||
|                                                            buf, &slen, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_write_signature( &ctx, | ||||
|                                                            valid_md, | ||||
|                                                            buf, sizeof( buf ), | ||||
|                                                            NULL, &slen, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_write_signature( &ctx, | ||||
|                                                            valid_md, | ||||
|                                                            buf, sizeof( buf ), | ||||
|                                                            buf, NULL, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL ) ); | ||||
|          mbedtls_ecdsa_write_signature( NULL, valid_md, buf, sizeof( buf ), | ||||
|                                         buf, &slen, mbedtls_test_rnd_std_rand, | ||||
|                                         NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_write_signature_restartable( NULL, | ||||
|                                                            valid_md, | ||||
|                                                            buf, sizeof( buf ), | ||||
|                                                            buf, &slen, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL, NULL ) ); | ||||
|          mbedtls_ecdsa_write_signature( &ctx, valid_md, NULL, sizeof( buf ), | ||||
|                                         buf, &slen, mbedtls_test_rnd_std_rand, | ||||
|                                         NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_write_signature_restartable( &ctx, | ||||
|                                                            valid_md, | ||||
|                                                            NULL, sizeof( buf ), | ||||
|                                                            buf, &slen, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL, NULL ) ); | ||||
|          mbedtls_ecdsa_write_signature( &ctx, valid_md, buf, sizeof( buf ), | ||||
|                                         NULL, &slen, mbedtls_test_rnd_std_rand, | ||||
|                                         NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_write_signature_restartable( &ctx, | ||||
|                                                            valid_md, | ||||
|                                                            buf, sizeof( buf ), | ||||
|                                                            NULL, &slen, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL, NULL ) ); | ||||
|          mbedtls_ecdsa_write_signature( &ctx, valid_md, buf, sizeof( buf ), | ||||
|                                         buf, NULL, mbedtls_test_rnd_std_rand, | ||||
|                                         NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_write_signature_restartable( &ctx, | ||||
|                                                            valid_md, | ||||
|                                                            buf, sizeof( buf ), | ||||
|                                                            buf, NULL, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL, NULL ) ); | ||||
|          mbedtls_ecdsa_write_signature_restartable( NULL, valid_md, buf, | ||||
|                                                     sizeof( buf ), buf, &slen, | ||||
|                                                     mbedtls_test_rnd_std_rand, | ||||
|                                                     NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|          mbedtls_ecdsa_write_signature_restartable( &ctx, valid_md, NULL, | ||||
|                                                     sizeof( buf ), buf, &slen, | ||||
|                                                     mbedtls_test_rnd_std_rand, | ||||
|                                                     NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|          mbedtls_ecdsa_write_signature_restartable( &ctx, valid_md, buf, | ||||
|                                                     sizeof( buf ), NULL, &slen, | ||||
|                                                     mbedtls_test_rnd_std_rand, | ||||
|                                                     NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|          mbedtls_ecdsa_write_signature_restartable( &ctx, valid_md, buf, | ||||
|                                                     sizeof( buf ), buf, NULL, | ||||
|                                                     mbedtls_test_rnd_std_rand, | ||||
|                                                     NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_read_signature( NULL, | ||||
|  | @ -191,7 +187,8 @@ void ecdsa_invalid_param( ) | |||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_genkey( NULL, valid_group, | ||||
|                                                   rnd_std_rand, NULL ) ); | ||||
|                                              mbedtls_test_rnd_std_rand, | ||||
|                                              NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                        mbedtls_ecdsa_genkey( &ctx, valid_group, | ||||
|                                                   NULL, NULL ) ); | ||||
|  | @ -213,23 +210,26 @@ void ecdsa_prim_random( int id ) | |||
|     mbedtls_ecp_group grp; | ||||
|     mbedtls_ecp_point Q; | ||||
|     mbedtls_mpi d, r, s; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     unsigned char buf[MBEDTLS_MD_MAX_SIZE]; | ||||
| 
 | ||||
|     mbedtls_ecp_group_init( &grp ); | ||||
|     mbedtls_ecp_point_init( &Q ); | ||||
|     mbedtls_mpi_init( &d ); mbedtls_mpi_init( &r ); mbedtls_mpi_init( &s ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
|     memset( buf, 0, sizeof( buf ) ); | ||||
| 
 | ||||
|     /* prepare material for signature */ | ||||
|     TEST_ASSERT( rnd_pseudo_rand( &rnd_info, buf, sizeof( buf ) ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_rnd_pseudo_rand( &rnd_info, | ||||
|                                                buf, sizeof( buf ) ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_group_load( &grp, id ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_gen_keypair( &grp, &d, &Q, &rnd_pseudo_rand, &rnd_info ) | ||||
|                  == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_gen_keypair( &grp, &d, &Q, | ||||
|                                           &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecdsa_sign( &grp, &r, &s, &d, buf, sizeof( buf ), | ||||
|                              &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                                      &mbedtls_test_rnd_pseudo_rand, | ||||
|                                      &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdsa_verify( &grp, buf, sizeof( buf ), &Q, &r, &s ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|  | @ -248,7 +248,7 @@ void ecdsa_prim_test_vectors( int id, char * d_str, char * xQ_str, | |||
|     mbedtls_ecp_group grp; | ||||
|     mbedtls_ecp_point Q; | ||||
|     mbedtls_mpi d, r, s, r_check, s_check; | ||||
|     rnd_buf_info rnd_info; | ||||
|     mbedtls_test_rnd_buf_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_ecp_group_init( &grp ); | ||||
|     mbedtls_ecp_point_init( &Q ); | ||||
|  | @ -276,7 +276,7 @@ void ecdsa_prim_test_vectors( int id, char * d_str, char * xQ_str, | |||
|     } | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecdsa_sign( &grp, &r, &s, &d, hash->x, hash->len, | ||||
|                  rnd_buffer_rand, &rnd_info ) == result ); | ||||
|                  mbedtls_test_rnd_buffer_rand, &rnd_info ) == result ); | ||||
| 
 | ||||
|     if ( result == 0) | ||||
|     { | ||||
|  | @ -332,7 +332,8 @@ void ecdsa_det_test_vectors( int id, char * d_str, int md_alg, char * msg, | |||
| 
 | ||||
|     TEST_ASSERT( | ||||
|                 mbedtls_ecdsa_sign_det_ext( &grp, &r, &s, &d, hash, hlen, | ||||
|                                             md_alg, rnd_std_rand, NULL ) | ||||
|                                             md_alg, mbedtls_test_rnd_std_rand, | ||||
|                                             NULL ) | ||||
|                 == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &r, &r_check ) == 0 ); | ||||
|  | @ -349,26 +350,30 @@ exit: | |||
| void ecdsa_write_read_random( int id ) | ||||
| { | ||||
|     mbedtls_ecdsa_context ctx; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     unsigned char hash[32]; | ||||
|     unsigned char sig[200]; | ||||
|     size_t sig_len, i; | ||||
| 
 | ||||
|     mbedtls_ecdsa_init( &ctx ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
|     memset( hash, 0, sizeof( hash ) ); | ||||
|     memset( sig, 0x2a, sizeof( sig ) ); | ||||
| 
 | ||||
|     /* prepare material for signature */ | ||||
|     TEST_ASSERT( rnd_pseudo_rand( &rnd_info, hash, sizeof( hash ) ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_rnd_pseudo_rand( &rnd_info, | ||||
|                                                hash, sizeof( hash ) ) == 0 ); | ||||
| 
 | ||||
|     /* generate signing key */ | ||||
|     TEST_ASSERT( mbedtls_ecdsa_genkey( &ctx, id, &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdsa_genkey( &ctx, id, | ||||
|                                        &mbedtls_test_rnd_pseudo_rand, | ||||
|                                        &rnd_info ) == 0 ); | ||||
| 
 | ||||
|     /* generate and write signature, then read and verify it */ | ||||
|     TEST_ASSERT( mbedtls_ecdsa_write_signature( &ctx, MBEDTLS_MD_SHA256, | ||||
|                  hash, sizeof( hash ), | ||||
|                  sig, &sig_len, &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                  sig, &sig_len, &mbedtls_test_rnd_pseudo_rand, | ||||
|                  &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecdsa_read_signature( &ctx, hash, sizeof( hash ), | ||||
|                  sig, sig_len ) == 0 ); | ||||
| 
 | ||||
|  | @ -420,9 +425,9 @@ void ecdsa_read_restart( int id, char *k_str, char *h_str, char *s_str, | |||
|     mbedtls_ecdsa_init( &ctx ); | ||||
|     mbedtls_ecdsa_restart_init( &rs_ctx ); | ||||
| 
 | ||||
|     hash_len = unhexify(hash, h_str); | ||||
|     sig_len = unhexify(sig, s_str); | ||||
|     pk_len = unhexify(pk, k_str); | ||||
|     hash_len = mbedtls_test_unhexify(hash, h_str); | ||||
|     sig_len = mbedtls_test_unhexify(sig, s_str); | ||||
|     pk_len = mbedtls_test_unhexify(pk, k_str); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_group_load( &ctx.grp, id ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_point_read_binary( &ctx.grp, &ctx.Q, pk, pk_len ) == 0 ); | ||||
|  | @ -494,7 +499,7 @@ void ecdsa_write_restart( int id, char *d_str, int md_alg, | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_group_load( &ctx.grp, id ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &ctx.d, 16, d_str ) == 0 ); | ||||
|     slen_check = unhexify( sig_check, sig_str ); | ||||
|     slen_check = mbedtls_test_unhexify( sig_check, sig_str ); | ||||
| 
 | ||||
|     md_info = mbedtls_md_info_from_type( md_alg ); | ||||
|     TEST_ASSERT( md_info != NULL ); | ||||
|  |  | |||
|  | @ -136,54 +136,33 @@ void ecjpake_invalid_param( ) | |||
|                             mbedtls_ecjpake_check( NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_write_round_one( NULL, | ||||
|                                                              buf, len, | ||||
|                                                              &olen, | ||||
|                                                              rnd_std_rand, | ||||
|                                                              NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_write_round_one( &ctx, | ||||
|                                                              NULL, len, | ||||
|                                                              &olen, | ||||
|                                                              rnd_std_rand, | ||||
|                                                              NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_write_round_one( &ctx, | ||||
|                                                              buf, len, | ||||
|                                                              NULL, | ||||
|                                                              rnd_std_rand, | ||||
|                                                              NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_write_round_one( &ctx, | ||||
|                                                              buf, len, | ||||
|                                                              &olen, | ||||
|                                                              NULL, | ||||
|                                                              NULL ) ); | ||||
|         mbedtls_ecjpake_write_round_one( NULL, buf, len, &olen, | ||||
|                                          mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_write_round_two( NULL, | ||||
|                                                              buf, len, | ||||
|                                                              &olen, | ||||
|                                                              rnd_std_rand, | ||||
|                                                              NULL ) ); | ||||
|         mbedtls_ecjpake_write_round_one( &ctx, NULL, len, &olen, | ||||
|                                          mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_write_round_two( &ctx, | ||||
|                                                              NULL, len, | ||||
|                                                              &olen, | ||||
|                                                              rnd_std_rand, | ||||
|                                                              NULL ) ); | ||||
|         mbedtls_ecjpake_write_round_one( &ctx, buf, len, NULL, | ||||
|                                          mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_write_round_two( &ctx, | ||||
|                                                              buf, len, | ||||
|                                                              NULL, | ||||
|                                                              rnd_std_rand, | ||||
|                                                              NULL ) ); | ||||
|         mbedtls_ecjpake_write_round_one( &ctx, buf, len, &olen, NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_write_round_two( &ctx, | ||||
|                                                              buf, len, | ||||
|                                                              &olen, | ||||
|                                                              NULL, | ||||
|                                                              NULL ) ); | ||||
|         mbedtls_ecjpake_write_round_two( NULL, buf, len, &olen, | ||||
|                                          mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|         mbedtls_ecjpake_write_round_two( &ctx, NULL, len, &olen, | ||||
|                                          mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|         mbedtls_ecjpake_write_round_two( &ctx, buf, len, NULL, | ||||
|                                          mbedtls_test_rnd_std_rand, NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|         mbedtls_ecjpake_write_round_two( &ctx, buf, len, &olen, NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_read_round_one( NULL, | ||||
|  | @ -200,29 +179,19 @@ void ecjpake_invalid_param( ) | |||
|                                                             NULL, len ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_derive_secret( NULL, | ||||
|                                                            buf, len, | ||||
|                                                            &olen, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL ) ); | ||||
|         mbedtls_ecjpake_derive_secret( NULL, buf, len, &olen, | ||||
|                                        mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_derive_secret( &ctx, | ||||
|                                                            NULL, len, | ||||
|                                                            &olen, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL ) ); | ||||
|         mbedtls_ecjpake_derive_secret( &ctx, NULL, len, &olen, | ||||
|                                        mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_derive_secret( &ctx, | ||||
|                                                            buf, len, | ||||
|                                                            NULL, | ||||
|                                                            rnd_std_rand, | ||||
|                                                            NULL ) ); | ||||
|         mbedtls_ecjpake_derive_secret( &ctx, buf, len, NULL, | ||||
|                                        mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecjpake_derive_secret( &ctx, | ||||
|                                                            buf, len, | ||||
|                                                            &olen, | ||||
|                                                            NULL, | ||||
|                                                            NULL ) ); | ||||
|         mbedtls_ecjpake_derive_secret( &ctx, buf, len, &olen, NULL, NULL ) ); | ||||
| 
 | ||||
| exit: | ||||
|     return; | ||||
|  |  | |||
|  | @ -69,12 +69,12 @@ void ecp_invalid_param( ) | |||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_privkey( NULL, | ||||
|                                                      &m, | ||||
|                                                      rnd_std_rand, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_privkey( &grp, | ||||
|                                                      NULL, | ||||
|                                                      rnd_std_rand, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_privkey( &grp, | ||||
|  | @ -222,29 +222,37 @@ void ecp_invalid_param( ) | |||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_mul( NULL, &P, &m, &P, | ||||
|                                              rnd_std_rand, NULL ) ); | ||||
|                                              mbedtls_test_rnd_std_rand, | ||||
|                                              NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_mul( &grp, NULL, &m, &P, | ||||
|                                              rnd_std_rand, NULL ) ); | ||||
|                                              mbedtls_test_rnd_std_rand, | ||||
|                                              NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_mul( &grp, &P, NULL, &P, | ||||
|                                              rnd_std_rand, NULL ) ); | ||||
|                                              mbedtls_test_rnd_std_rand, | ||||
|                                              NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_mul( &grp, &P, &m, NULL, | ||||
|                                              rnd_std_rand, NULL ) ); | ||||
|                                              mbedtls_test_rnd_std_rand, | ||||
|                                              NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_mul_restartable( NULL, &P, &m, &P, | ||||
|                                                  rnd_std_rand, NULL , NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL , NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_mul_restartable( &grp, NULL, &m, &P, | ||||
|                                                  rnd_std_rand, NULL , NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL , NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_mul_restartable( &grp, &P, NULL, &P, | ||||
|                                                  rnd_std_rand, NULL , NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL , NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_mul_restartable( &grp, &P, &m, NULL, | ||||
|                                                  rnd_std_rand, NULL , NULL ) ); | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL , NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_muladd( NULL, &P, &m, &P, | ||||
|  | @ -300,45 +308,38 @@ void ecp_invalid_param( ) | |||
|                             mbedtls_ecp_check_privkey( &grp, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_keypair_base( NULL, &P, | ||||
|                                                           &m, &P, | ||||
|                                                           rnd_std_rand, | ||||
|                                                           NULL ) ); | ||||
|         mbedtls_ecp_gen_keypair_base( NULL, &P, &m, &P, | ||||
|                                       mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_keypair_base( &grp, NULL, | ||||
|                                                           &m, &P, | ||||
|                                                           rnd_std_rand, | ||||
|                                                           NULL ) ); | ||||
|         mbedtls_ecp_gen_keypair_base( &grp, NULL, &m, &P, | ||||
|                                       mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_keypair_base( &grp, &P, | ||||
|                                                           NULL, &P, | ||||
|                                                           rnd_std_rand, | ||||
|                                                           NULL ) ); | ||||
|         mbedtls_ecp_gen_keypair_base( &grp, &P, NULL, &P, | ||||
|                                       mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_keypair_base( &grp, &P, | ||||
|                                                           &m, NULL, | ||||
|                                                           rnd_std_rand, | ||||
|                                                           NULL ) ); | ||||
|         mbedtls_ecp_gen_keypair_base( &grp, &P, &m, NULL, | ||||
|                                       mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_keypair_base( &grp, &P, | ||||
|                                                           &m, &P, | ||||
|                                                           NULL, | ||||
|                                                           NULL ) ); | ||||
|         mbedtls_ecp_gen_keypair_base( &grp, &P, &m, &P, NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_keypair( NULL, | ||||
|                                                      &m, &P, | ||||
|                                                      rnd_std_rand, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_keypair( &grp, | ||||
|                                                      NULL, &P, | ||||
|                                                      rnd_std_rand, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_keypair( &grp, | ||||
|                                                      &m, NULL, | ||||
|                                                      rnd_std_rand, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_keypair( &grp, | ||||
|  | @ -348,7 +349,8 @@ void ecp_invalid_param( ) | |||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_key( valid_group, NULL, | ||||
|                                                  rnd_std_rand, NULL ) ); | ||||
|                                                  mbedtls_test_rnd_std_rand, | ||||
|                                                  NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_ECP_BAD_INPUT_DATA, | ||||
|                             mbedtls_ecp_gen_key( valid_group, &kp, | ||||
|                                                  NULL, NULL ) ); | ||||
|  | @ -576,12 +578,12 @@ void ecp_test_vect( int id, char * dA_str, char * xA_str, char * yA_str, | |||
|     mbedtls_ecp_group grp; | ||||
|     mbedtls_ecp_point R; | ||||
|     mbedtls_mpi dA, xA, yA, dB, xB, yB, xZ, yZ; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_ecp_group_init( &grp ); mbedtls_ecp_point_init( &R ); | ||||
|     mbedtls_mpi_init( &dA ); mbedtls_mpi_init( &xA ); mbedtls_mpi_init( &yA ); mbedtls_mpi_init( &dB ); | ||||
|     mbedtls_mpi_init( &xB ); mbedtls_mpi_init( &yB ); mbedtls_mpi_init( &xZ ); mbedtls_mpi_init( &yZ ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_group_load( &grp, id ) == 0 ); | ||||
| 
 | ||||
|  | @ -597,7 +599,7 @@ void ecp_test_vect( int id, char * dA_str, char * xA_str, char * yA_str, | |||
|     TEST_ASSERT( mbedtls_mpi_read_string( &yZ, 16, yZ_str ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_mul( &grp, &R, &dA, &grp.G, | ||||
|                           &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                           &mbedtls_test_rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &R.X, &xA ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &R.Y, &yA ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_check_pubkey( &grp, &R ) == 0 ); | ||||
|  | @ -611,7 +613,7 @@ void ecp_test_vect( int id, char * dA_str, char * xA_str, char * yA_str, | |||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &R.Y, &yB ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_check_pubkey( &grp, &R ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_mul( &grp, &R, &dA, &R, | ||||
|                           &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                           &mbedtls_test_rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &R.X, &xZ ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &R.Y, &yZ ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_check_pubkey( &grp, &R ) == 0 ); | ||||
|  | @ -630,13 +632,13 @@ void ecp_test_vec_x( int id, char * dA_hex, char * xA_hex, char * dB_hex, | |||
|     mbedtls_ecp_group grp; | ||||
|     mbedtls_ecp_point R; | ||||
|     mbedtls_mpi dA, xA, dB, xB, xS; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_ecp_group_init( &grp ); mbedtls_ecp_point_init( &R ); | ||||
|     mbedtls_mpi_init( &dA ); mbedtls_mpi_init( &xA ); | ||||
|     mbedtls_mpi_init( &dB ); mbedtls_mpi_init( &xB ); | ||||
|     mbedtls_mpi_init( &xS ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_group_load( &grp, id ) == 0 ); | ||||
| 
 | ||||
|  | @ -649,12 +651,12 @@ void ecp_test_vec_x( int id, char * dA_hex, char * xA_hex, char * dB_hex, | |||
|     TEST_ASSERT( mbedtls_mpi_read_string( &xS, 16, xS_hex ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_mul( &grp, &R, &dA, &grp.G, | ||||
|                           &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                           &mbedtls_test_rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_check_pubkey( &grp, &R ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &R.X, &xA ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_mul( &grp, &R, &dB, &R, | ||||
|                           &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|                           &mbedtls_test_rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_check_pubkey( &grp, &R ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_cmp_mpi( &R.X, &xS ) == 0 ); | ||||
| 
 | ||||
|  | @ -683,12 +685,12 @@ void ecp_test_mul( int id, data_t * n_hex, | |||
|     mbedtls_ecp_group grp; | ||||
|     mbedtls_ecp_point P, nP, R; | ||||
|     mbedtls_mpi n; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_ecp_group_init( &grp ); mbedtls_ecp_point_init( &R ); | ||||
|     mbedtls_ecp_point_init( &P ); mbedtls_ecp_point_init( &nP ); | ||||
|     mbedtls_mpi_init( &n ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_group_load( &grp, id ) == 0 ); | ||||
| 
 | ||||
|  | @ -707,7 +709,7 @@ void ecp_test_mul( int id, data_t * n_hex, | |||
|                  == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_mul( &grp, &R, &n, &P, | ||||
|                                   &rnd_pseudo_rand, &rnd_info ) | ||||
|                                   &mbedtls_test_rnd_pseudo_rand, &rnd_info ) | ||||
|                  == expected_ret ); | ||||
| 
 | ||||
|     if( expected_ret == 0 ) | ||||
|  | @ -740,7 +742,8 @@ void ecp_test_mul_rng( int id, data_t * d_hex) | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_mpi_read_binary( &d, d_hex->x, d_hex->len ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_mul( &grp, &Q, &d, &grp.G, &rnd_zero_rand, NULL ) | ||||
|     TEST_ASSERT( mbedtls_ecp_mul( &grp, &Q, &d, &grp.G, | ||||
|                                   &mbedtls_test_rnd_zero_rand, NULL ) | ||||
|                  == MBEDTLS_ERR_ECP_RANDOM_FAILED ); | ||||
| 
 | ||||
| exit: | ||||
|  | @ -806,7 +809,7 @@ void ecp_write_binary( int id, char * x, char * y, char * z, int format, | |||
| 
 | ||||
|     if( ret == 0 ) | ||||
|     { | ||||
|         TEST_ASSERT( hexcmp( buf, out->x, olen, out->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( buf, out->x, olen, out->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -1052,17 +1055,18 @@ void mbedtls_ecp_gen_keypair( int id ) | |||
|     mbedtls_ecp_group grp; | ||||
|     mbedtls_ecp_point Q; | ||||
|     mbedtls_mpi d; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_ecp_group_init( &grp ); | ||||
|     mbedtls_ecp_point_init( &Q ); | ||||
|     mbedtls_mpi_init( &d ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_group_load( &grp, id ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_gen_keypair( &grp, &d, &Q, &rnd_pseudo_rand, &rnd_info ) | ||||
|                  == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_gen_keypair( &grp, &d, &Q, | ||||
|                                           &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_check_pubkey( &grp, &Q ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_check_privkey( &grp, &d ) == 0 ); | ||||
|  | @ -1078,12 +1082,14 @@ exit: | |||
| void mbedtls_ecp_gen_key( int id ) | ||||
| { | ||||
|     mbedtls_ecp_keypair key; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_ecp_keypair_init( &key ); | ||||
|     memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x00, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_gen_key( id, &key, &rnd_pseudo_rand, &rnd_info ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_gen_key( id, &key, | ||||
|                                       &mbedtls_test_rnd_pseudo_rand, | ||||
|                                       &rnd_info ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_ecp_check_pubkey( &key.grp, &key.Q ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_check_privkey( &key.grp, &key.d ) == 0 ); | ||||
|  |  | |||
|  | @ -55,8 +55,11 @@ void gcm_encrypt_and_tag( int cipher_id, data_t * key_str, | |||
|     { | ||||
|         TEST_ASSERT( mbedtls_gcm_crypt_and_tag( &ctx, MBEDTLS_GCM_ENCRYPT, src_str->len, iv_str->x, iv_str->len, add_str->x, add_str->len, src_str->x, output, tag_len, tag_output ) == 0 ); | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( hexcmp( tag_output, hex_tag_string->x, tag_len, hex_tag_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                           src_str->len, | ||||
|                                           hex_dst_string->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( tag_output, hex_tag_string->x, | ||||
|                                           tag_len, hex_tag_string->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -94,7 +97,9 @@ void gcm_decrypt_and_verify( int cipher_id, data_t * key_str, | |||
|         { | ||||
|             TEST_ASSERT( ret == 0 ); | ||||
| 
 | ||||
|             TEST_ASSERT( hexcmp( output, pt_result->x, src_str->len, pt_result->len ) == 0 ); | ||||
|             TEST_ASSERT( mbedtls_test_hexcmp( output, pt_result->x, | ||||
|                                               src_str->len, | ||||
|                                               pt_result->len ) == 0 ); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -28,17 +28,20 @@ void test_hkdf( int md_alg, char *hex_ikm_string, char *hex_salt_string, | |||
|     const mbedtls_md_info_t *md = mbedtls_md_info_from_type( md_alg ); | ||||
|     TEST_ASSERT( md != NULL ); | ||||
| 
 | ||||
|     ikm_len = unhexify( ikm, hex_ikm_string ); | ||||
|     salt_len = unhexify( salt, hex_salt_string ); | ||||
|     info_len = unhexify( info, hex_info_string ); | ||||
|     okm_len = unhexify( expected_okm, hex_okm_string ); | ||||
|     ikm_len = mbedtls_test_unhexify( ikm, hex_ikm_string ); | ||||
|     salt_len = mbedtls_test_unhexify( salt, hex_salt_string ); | ||||
|     info_len = mbedtls_test_unhexify( info, hex_info_string ); | ||||
|     okm_len = mbedtls_test_unhexify( expected_okm, hex_okm_string ); | ||||
| 
 | ||||
|     ret = mbedtls_hkdf( md, salt, salt_len, ikm, ikm_len, info, info_len, okm, | ||||
|                         okm_len); | ||||
|     TEST_ASSERT( ret == 0 ); | ||||
| 
 | ||||
|     // Run hexify on it so that it looks nicer if the assertion fails | ||||
|     hexify( okm_hex, okm, okm_len ); | ||||
|     /* | ||||
|      * Run mbedtls_test_hexify on it so that it looks nicer if the assertion | ||||
|      * fails. | ||||
|      */ | ||||
|     mbedtls_test_hexify( okm_hex, okm, okm_len ); | ||||
|     TEST_ASSERT( !strcmp( (char *)okm_hex, hex_okm_string ) ); | ||||
| } | ||||
| /* END_CASE */ | ||||
|  | @ -60,9 +63,9 @@ void test_hkdf_extract( int md_alg, char *hex_ikm_string, | |||
|     output_prk_len = mbedtls_md_get_size( md ); | ||||
|     output_prk = mbedtls_calloc( 1, output_prk_len ); | ||||
| 
 | ||||
|     ikm = unhexify_alloc( hex_ikm_string, &ikm_len ); | ||||
|     salt = unhexify_alloc( hex_salt_string, &salt_len ); | ||||
|     prk = unhexify_alloc( hex_prk_string, &prk_len ); | ||||
|     ikm = mbedtls_test_unhexify_alloc( hex_ikm_string, &ikm_len ); | ||||
|     salt = mbedtls_test_unhexify_alloc( hex_salt_string, &salt_len ); | ||||
|     prk = mbedtls_test_unhexify_alloc( hex_prk_string, &prk_len ); | ||||
|     TEST_ASSERT( prk_len == output_prk_len ); | ||||
| 
 | ||||
|     ret = mbedtls_hkdf_extract( md, salt, salt_len, ikm, ikm_len, output_prk ); | ||||
|  | @ -95,9 +98,9 @@ void test_hkdf_expand( int md_alg, char *hex_info_string, | |||
| 
 | ||||
|     output_okm = mbedtls_calloc( OKM_LEN, 1 ); | ||||
| 
 | ||||
|     prk = unhexify_alloc( hex_prk_string, &prk_len ); | ||||
|     info = unhexify_alloc( hex_info_string, &info_len ); | ||||
|     okm = unhexify_alloc( hex_okm_string, &okm_len ); | ||||
|     prk = mbedtls_test_unhexify_alloc( hex_prk_string, &prk_len ); | ||||
|     info = mbedtls_test_unhexify_alloc( hex_info_string, &info_len ); | ||||
|     okm = mbedtls_test_unhexify_alloc( hex_okm_string, &okm_len ); | ||||
|     TEST_ASSERT( prk_len == mbedtls_md_get_size( md ) ); | ||||
|     TEST_ASSERT( okm_len < OKM_LEN ); | ||||
| 
 | ||||
|  |  | |||
|  | @ -129,8 +129,9 @@ void hmac_drbg_seed_file( int md_alg, char * path, int ret ) | |||
|     md_info = mbedtls_md_info_from_type( md_alg ); | ||||
|     TEST_ASSERT( md_info != NULL ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_hmac_drbg_seed( &ctx, md_info, rnd_std_rand, NULL, | ||||
|                                  NULL, 0 ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_hmac_drbg_seed( &ctx, md_info, | ||||
|                                          mbedtls_test_rnd_std_rand, NULL, | ||||
|                                          NULL, 0 ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_hmac_drbg_write_seed_file( &ctx, path ) == ret ); | ||||
|     TEST_ASSERT( mbedtls_hmac_drbg_update_seed_file( &ctx, path ) == ret ); | ||||
|  |  | |||
|  | @ -145,7 +145,9 @@ void md_text( char * text_md_name, char * text_src_string, | |||
| 
 | ||||
|     TEST_ASSERT ( 0 == mbedtls_md( md_info, src_str, strlen( (char *) src_str ), output ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, mbedtls_md_get_size( md_info ), hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       mbedtls_md_get_size( md_info ), | ||||
|                                       hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -167,8 +169,9 @@ void md_hex( char * text_md_name, data_t * src_str, | |||
|     TEST_ASSERT ( 0 == mbedtls_md( md_info, src_str->x, src_str->len, output ) ); | ||||
| 
 | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, | ||||
|                  mbedtls_md_get_size( md_info ), hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       mbedtls_md_get_size( md_info ), | ||||
|                                       hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -208,15 +211,18 @@ void md_text_multi( char * text_md_name, char * text_src_string, | |||
| 
 | ||||
|     TEST_ASSERT ( 0 == mbedtls_md_update( &ctx, src_str + halfway, len - halfway ) ); | ||||
|     TEST_ASSERT ( 0 == mbedtls_md_finish( &ctx, output ) ); | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, | ||||
|                  mbedtls_md_get_size( md_info ), hex_hash_string->len) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       mbedtls_md_get_size( md_info ), | ||||
|                                       hex_hash_string->len) == 0 ); | ||||
| 
 | ||||
|     /* Test clone */ | ||||
|     memset( output, 0x00, 100 ); | ||||
| 
 | ||||
|     TEST_ASSERT ( 0 == mbedtls_md_update( &ctx_copy, src_str + halfway, len - halfway ) ); | ||||
|     TEST_ASSERT ( 0 == mbedtls_md_finish( &ctx_copy, output ) ); | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, mbedtls_md_get_size( md_info ), hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       mbedtls_md_get_size( md_info ), | ||||
|                                       hex_hash_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_md_free( &ctx ); | ||||
|  | @ -255,14 +261,18 @@ void md_hex_multi( char * text_md_name, data_t * src_str, | |||
| 
 | ||||
|     TEST_ASSERT ( 0 == mbedtls_md_update( &ctx, src_str->x + halfway, src_str->len - halfway) ); | ||||
|     TEST_ASSERT ( 0 == mbedtls_md_finish( &ctx, output ) ); | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, mbedtls_md_get_size( md_info ), hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       mbedtls_md_get_size( md_info ), | ||||
|                                       hex_hash_string->len ) == 0 ); | ||||
| 
 | ||||
|     /* Test clone */ | ||||
|     memset( output, 0x00, 100 ); | ||||
| 
 | ||||
|     TEST_ASSERT ( 0 == mbedtls_md_update( &ctx_copy, src_str->x + halfway, src_str->len - halfway ) ); | ||||
|     TEST_ASSERT ( 0 == mbedtls_md_finish( &ctx_copy, output ) ); | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, mbedtls_md_get_size( md_info ), hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       mbedtls_md_get_size( md_info ), | ||||
|                                       hex_hash_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_md_free( &ctx ); | ||||
|  | @ -289,7 +299,8 @@ void mbedtls_md_hmac( char * text_md_name, int trunc_size, | |||
| 
 | ||||
|     TEST_ASSERT ( mbedtls_md_hmac( md_info, key_str->x, key_str->len, src_str->x, src_str->len, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, trunc_size, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       trunc_size, hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -321,7 +332,8 @@ void md_hmac_multi( char * text_md_name, int trunc_size, data_t * key_str, | |||
|     TEST_ASSERT ( 0 == mbedtls_md_hmac_update( &ctx, src_str->x + halfway, src_str->len - halfway ) ); | ||||
|     TEST_ASSERT ( 0 == mbedtls_md_hmac_finish( &ctx, output ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, trunc_size, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       trunc_size, hex_hash_string->len ) == 0 ); | ||||
| 
 | ||||
|     /* Test again, for reset() */ | ||||
|     memset( output, 0x00, 100 ); | ||||
|  | @ -331,7 +343,8 @@ void md_hmac_multi( char * text_md_name, int trunc_size, data_t * key_str, | |||
|     TEST_ASSERT ( 0 == mbedtls_md_hmac_update( &ctx, src_str->x + halfway, src_str->len - halfway ) ); | ||||
|     TEST_ASSERT ( 0 == mbedtls_md_hmac_finish( &ctx, output ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, trunc_size, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       trunc_size, hex_hash_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_md_free( &ctx ); | ||||
|  | @ -355,6 +368,8 @@ void mbedtls_md_file( char * text_md_name, char * filename, | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_md_file( md_info, filename, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, mbedtls_md_get_size( md_info ), hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       mbedtls_md_get_size( md_info ), | ||||
|                                       hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
|  |  | |||
|  | @ -20,7 +20,9 @@ void md2_text( char * text_src_string, data_t * hex_hash_string ) | |||
|     ret = mbedtls_md2_ret( src_str, strlen( (char *) src_str ), output ); | ||||
|     TEST_ASSERT( ret == 0 ) ; | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, sizeof  output, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       sizeof  output, | ||||
|                                       hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -39,7 +41,9 @@ void md4_text( char * text_src_string, data_t * hex_hash_string ) | |||
|     ret = mbedtls_md4_ret( src_str, strlen( (char *) src_str ), output ); | ||||
|     TEST_ASSERT( ret == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, sizeof  output, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       sizeof  output, | ||||
|                                       hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -58,7 +62,9 @@ void md5_text( char * text_src_string, data_t * hex_hash_string ) | |||
|     ret = mbedtls_md5_ret( src_str, strlen( (char *) src_str ), output ); | ||||
|     TEST_ASSERT( ret == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, sizeof  output, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       sizeof  output, | ||||
|                                       hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -77,7 +83,9 @@ void ripemd160_text( char * text_src_string, data_t * hex_hash_string ) | |||
|     ret = mbedtls_ripemd160_ret( src_str, strlen( (char *) src_str ), output ); | ||||
|     TEST_ASSERT( ret == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, sizeof output, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       sizeof output, | ||||
|                                       hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  |  | |||
|  | @ -240,7 +240,8 @@ void mpi_invalid_param( ) | |||
|                             mbedtls_mpi_exp_mod( &X, &X, &X, NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_MPI_BAD_INPUT_DATA, | ||||
|                             mbedtls_mpi_fill_random( NULL, 42, rnd_std_rand, | ||||
|                             mbedtls_mpi_fill_random( NULL, 42, | ||||
|                                                      mbedtls_test_rnd_std_rand, | ||||
|                                                      NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_MPI_BAD_INPUT_DATA, | ||||
|                             mbedtls_mpi_fill_random( &X, 42, NULL, NULL ) ); | ||||
|  | @ -373,7 +374,8 @@ void mbedtls_mpi_write_binary( int radix_X, char * input_X, | |||
|     if( result == 0) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( buf, input_A->x, buflen, input_A->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( buf, input_A->x, | ||||
|                                           buflen, input_A->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -404,7 +406,8 @@ void mbedtls_mpi_write_binary_le( int radix_X, char * input_X, | |||
|     if( result == 0) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( buf, input_A->x, buflen, input_A->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( buf, input_A->x, | ||||
|                                           buflen, input_A->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -438,7 +441,8 @@ void mbedtls_mpi_read_file( int radix_X, char * input_file, | |||
|         TEST_ASSERT( mbedtls_mpi_write_binary( &X, buf, buflen ) == 0 ); | ||||
| 
 | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( buf, input_A->x, buflen, input_A->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( buf, input_A->x, | ||||
|                                           buflen, input_A->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -1192,7 +1196,7 @@ void mbedtls_mpi_is_prime( int radix_X, char * input_X, int div_result ) | |||
|     mbedtls_mpi_init( &X ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &X, radix_X, input_X ) == 0 ); | ||||
|     res = mbedtls_mpi_is_prime_ext( &X, 40, rnd_std_rand, NULL ); | ||||
|     res = mbedtls_mpi_is_prime_ext( &X, 40, mbedtls_test_rnd_std_rand, NULL ); | ||||
|     TEST_ASSERT( res == div_result ); | ||||
| 
 | ||||
| exit: | ||||
|  | @ -1241,7 +1245,8 @@ void mbedtls_mpi_gen_prime( int bits, int flags, int ref_ret ) | |||
| 
 | ||||
|     mbedtls_mpi_init( &X ); | ||||
| 
 | ||||
|     my_ret = mbedtls_mpi_gen_prime( &X, bits, flags, rnd_std_rand, NULL ); | ||||
|     my_ret = mbedtls_mpi_gen_prime( &X, bits, flags, | ||||
|                                     mbedtls_test_rnd_std_rand, NULL ); | ||||
|     TEST_ASSERT( my_ret == ref_ret ); | ||||
| 
 | ||||
|     if( ref_ret == 0 ) | ||||
|  | @ -1251,14 +1256,16 @@ void mbedtls_mpi_gen_prime( int bits, int flags, int ref_ret ) | |||
|         TEST_ASSERT( actual_bits >= (size_t) bits ); | ||||
|         TEST_ASSERT( actual_bits <= (size_t) bits + 1 ); | ||||
| 
 | ||||
|         TEST_ASSERT( mbedtls_mpi_is_prime_ext( &X, 40, rnd_std_rand, NULL ) | ||||
|                      == 0 ); | ||||
|         TEST_ASSERT( mbedtls_mpi_is_prime_ext( &X, 40, | ||||
|                                                mbedtls_test_rnd_std_rand, | ||||
|                                                NULL ) == 0 ); | ||||
|         if( flags & MBEDTLS_MPI_GEN_PRIME_FLAG_DH ) | ||||
|         { | ||||
|             /* X = ( X - 1 ) / 2 */ | ||||
|             TEST_ASSERT( mbedtls_mpi_shift_r( &X, 1 ) == 0 ); | ||||
|             TEST_ASSERT( mbedtls_mpi_is_prime_ext( &X, 40, rnd_std_rand, NULL ) | ||||
|                          == 0 ); | ||||
|             TEST_ASSERT( mbedtls_mpi_is_prime_ext( &X, 40, | ||||
|                                                    mbedtls_test_rnd_std_rand, | ||||
|                                                    NULL ) == 0 ); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -259,9 +259,9 @@ void mbedtls_nist_kw_wrap( int cipher_id, int mode, | |||
|     memset( msg, 0x00, sizeof( msg ) ); | ||||
|     memset( result, '+', sizeof( result ) ); | ||||
| 
 | ||||
|     key_len = unhexify( key, key_hex ); | ||||
|     msg_len = unhexify( msg, msg_hex ); | ||||
|     result_len = unhexify( expected_result, result_hex ); | ||||
|     key_len = mbedtls_test_unhexify( key, key_hex ); | ||||
|     msg_len = mbedtls_test_unhexify( msg, msg_hex ); | ||||
|     result_len = mbedtls_test_unhexify( expected_result, result_hex ); | ||||
|     output_len = sizeof( result ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_nist_kw_setkey( &ctx, cipher_id, key, key_len * 8, 1 ) | ||||
|  | @ -306,9 +306,9 @@ void mbedtls_nist_kw_unwrap( int cipher_id, int mode, | |||
|     memset( result, '+', sizeof( result ) ); | ||||
|     memset( expected_result, 0x00, sizeof( expected_result ) ); | ||||
| 
 | ||||
|     key_len = unhexify( key, key_hex ); | ||||
|     msg_len = unhexify( msg, msg_hex ); | ||||
|     result_len = unhexify( expected_result, result_hex ); | ||||
|     key_len = mbedtls_test_unhexify( key, key_hex ); | ||||
|     msg_len = mbedtls_test_unhexify( msg, msg_hex ); | ||||
|     result_len = mbedtls_test_unhexify( expected_result, result_hex ); | ||||
|     output_len = sizeof( result ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_nist_kw_setkey( &ctx, cipher_id, key, key_len * 8, 0 ) | ||||
|  |  | |||
|  | @ -17,7 +17,7 @@ | |||
| 
 | ||||
| #if defined(MBEDTLS_USE_PSA_CRYPTO) | ||||
| #include "mbedtls/psa_util.h" | ||||
| #include "psa_crypto_helpers.h" | ||||
| #include "test/psa_crypto_helpers.h" | ||||
| #define PSA_INIT( ) PSA_ASSERT( psa_crypto_init( ) ) | ||||
| #else | ||||
| /* Define empty macros so that we can use them in the preamble and teardown | ||||
|  | @ -27,8 +27,6 @@ | |||
| #define PSA_DONE( ) ( (void) 0 ) | ||||
| #endif | ||||
| 
 | ||||
| static int rnd_std_rand( void *rng_state, unsigned char *output, size_t len ); | ||||
| 
 | ||||
| #define RSA_KEY_SIZE 512 | ||||
| #define RSA_KEY_LEN   64 | ||||
| 
 | ||||
|  | @ -51,7 +49,7 @@ static int pk_genkey( mbedtls_pk_context *pk, int parameter ) | |||
| #if defined(MBEDTLS_RSA_C) && defined(MBEDTLS_GENPRIME) | ||||
|     if( mbedtls_pk_get_type( pk ) == MBEDTLS_PK_RSA ) | ||||
|         return mbedtls_rsa_gen_key( mbedtls_pk_rsa( *pk ), | ||||
|                                     rnd_std_rand, NULL, | ||||
|                                     mbedtls_test_rnd_std_rand, NULL, | ||||
|                                     parameter, 3 ); | ||||
| #endif | ||||
| #if defined(MBEDTLS_ECP_C) | ||||
|  | @ -64,8 +62,10 @@ static int pk_genkey( mbedtls_pk_context *pk, int parameter ) | |||
|                                             parameter ) ) != 0 ) | ||||
|             return( ret ); | ||||
| 
 | ||||
|         return mbedtls_ecp_gen_keypair( &mbedtls_pk_ec( *pk )->grp, &mbedtls_pk_ec( *pk )->d, | ||||
|                                 &mbedtls_pk_ec( *pk )->Q, rnd_std_rand, NULL ); | ||||
|         return mbedtls_ecp_gen_keypair( &mbedtls_pk_ec( *pk )->grp, | ||||
|                                         &mbedtls_pk_ec( *pk )->d, | ||||
|                                         &mbedtls_pk_ec( *pk )->Q, | ||||
|                                         mbedtls_test_rnd_std_rand, NULL ); | ||||
|     } | ||||
| #endif | ||||
|     return( -1 ); | ||||
|  | @ -77,8 +77,8 @@ int mbedtls_rsa_decrypt_func( void *ctx, int mode, size_t *olen, | |||
|                        size_t output_max_len ) | ||||
| { | ||||
|     return( mbedtls_rsa_pkcs1_decrypt( (mbedtls_rsa_context *) ctx, | ||||
|                                        rnd_std_rand, NULL, mode, olen, | ||||
|                                        input, output, output_max_len ) ); | ||||
|                                        mbedtls_test_rnd_std_rand, NULL, mode, | ||||
|                                        olen, input, output, output_max_len ) ); | ||||
| } | ||||
| int mbedtls_rsa_sign_func( void *ctx, | ||||
|                    int (*f_rng)(void *, unsigned char *, size_t), void *p_rng, | ||||
|  | @ -87,8 +87,9 @@ int mbedtls_rsa_sign_func( void *ctx, | |||
| { | ||||
|     ((void) f_rng); | ||||
|     ((void) p_rng); | ||||
|     return( mbedtls_rsa_pkcs1_sign( (mbedtls_rsa_context *) ctx, rnd_std_rand, NULL, mode, | ||||
|                             md_alg, hashlen, hash, sig ) ); | ||||
|     return( mbedtls_rsa_pkcs1_sign( (mbedtls_rsa_context *) ctx, | ||||
|                                     mbedtls_test_rnd_std_rand, NULL, mode, | ||||
|                                     md_alg, hashlen, hash, sig ) ); | ||||
| } | ||||
| size_t mbedtls_rsa_key_len_func( void *ctx ) | ||||
| { | ||||
|  | @ -237,7 +238,7 @@ void valid_parameters( ) | |||
|                                               MBEDTLS_MD_NONE, | ||||
|                                               NULL, 0, | ||||
|                                               buf, &len, | ||||
|                                               rnd_std_rand, NULL, | ||||
|                                               mbedtls_test_rnd_std_rand, NULL, | ||||
|                                               NULL ) == | ||||
|                  MBEDTLS_ERR_PK_BAD_INPUT_DATA ); | ||||
| 
 | ||||
|  | @ -245,7 +246,7 @@ void valid_parameters( ) | |||
|                                               MBEDTLS_MD_NONE, | ||||
|                                               NULL, 0, | ||||
|                                               buf, &len, | ||||
|                                               rnd_std_rand, NULL, | ||||
|                                               mbedtls_test_rnd_std_rand, NULL, | ||||
|                                               NULL ) == | ||||
|                  MBEDTLS_ERR_PK_BAD_INPUT_DATA ); | ||||
| 
 | ||||
|  | @ -253,7 +254,7 @@ void valid_parameters( ) | |||
|                                   MBEDTLS_MD_NONE, | ||||
|                                   NULL, 0, | ||||
|                                   buf, &len, | ||||
|                                   rnd_std_rand, NULL ) == | ||||
|                                   mbedtls_test_rnd_std_rand, NULL ) == | ||||
|                  MBEDTLS_ERR_PK_BAD_INPUT_DATA ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_pk_verify_restartable( &pk, | ||||
|  | @ -279,13 +280,13 @@ void valid_parameters( ) | |||
|     TEST_ASSERT( mbedtls_pk_encrypt( &pk, | ||||
|                                      NULL, 0, | ||||
|                                      NULL, &len, 0, | ||||
|                                      rnd_std_rand, NULL ) == | ||||
|                                      mbedtls_test_rnd_std_rand, NULL ) == | ||||
|                  MBEDTLS_ERR_PK_BAD_INPUT_DATA ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_pk_decrypt( &pk, | ||||
|                                      NULL, 0, | ||||
|                                      NULL, &len, 0, | ||||
|                                      rnd_std_rand, NULL ) == | ||||
|                                      mbedtls_test_rnd_std_rand, NULL ) == | ||||
|                  MBEDTLS_ERR_PK_BAD_INPUT_DATA ); | ||||
| 
 | ||||
| #if defined(MBEDTLS_PK_PARSE_C) | ||||
|  | @ -433,100 +434,71 @@ void invalid_parameters( ) | |||
|                                                    NULL, sizeof( buf ) ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_sign_restartable( NULL, | ||||
|                                                          MBEDTLS_MD_NONE, | ||||
|                                                          buf, sizeof( buf ), | ||||
|                                                          buf, &len, | ||||
|                                                          rnd_std_rand, NULL, | ||||
|                                                          NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_sign_restartable( &pk, | ||||
|                                                          MBEDTLS_MD_NONE, | ||||
|                                                          NULL, sizeof( buf ), | ||||
|                                                          buf, &len, | ||||
|                                                          rnd_std_rand, NULL, | ||||
|                                                          NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_sign_restartable( &pk, | ||||
|                                                          valid_md, | ||||
|                                                          NULL, 0, | ||||
|                                                          buf, &len, | ||||
|                                                          rnd_std_rand, NULL, | ||||
|                                                          NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_sign_restartable( &pk, | ||||
|                                                          MBEDTLS_MD_NONE, | ||||
|                                                          buf, sizeof( buf ), | ||||
|                                                          NULL, &len, | ||||
|                                                          rnd_std_rand, NULL, | ||||
|                                                          NULL ) ); | ||||
|         mbedtls_pk_sign_restartable( NULL, MBEDTLS_MD_NONE, buf, sizeof( buf ), | ||||
|                                      buf, &len, mbedtls_test_rnd_std_rand, | ||||
|                                      NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_sign( NULL, | ||||
|                                              MBEDTLS_MD_NONE, | ||||
|                                              buf, sizeof( buf ), | ||||
|                                              buf, &len, | ||||
|                                              rnd_std_rand, NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_sign( &pk, | ||||
|                                              MBEDTLS_MD_NONE, | ||||
|                                              NULL, sizeof( buf ), | ||||
|                                              buf, &len, | ||||
|                                              rnd_std_rand, NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_sign( &pk, | ||||
|                                              valid_md, | ||||
|                                              NULL, 0, | ||||
|                                              buf, &len, | ||||
|                                              rnd_std_rand, NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_sign( &pk, | ||||
|                                              MBEDTLS_MD_NONE, | ||||
|                                              buf, sizeof( buf ), | ||||
|                                              NULL, &len, | ||||
|                                              rnd_std_rand, NULL ) ); | ||||
|         mbedtls_pk_sign_restartable( &pk, MBEDTLS_MD_NONE, NULL, sizeof( buf ), | ||||
|                                      buf, &len, mbedtls_test_rnd_std_rand, | ||||
|                                      NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_decrypt( NULL, | ||||
|                                                 buf, sizeof( buf ), | ||||
|                                                 buf, &len, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_decrypt( &pk, | ||||
|                                                 NULL, sizeof( buf ), | ||||
|                                                 buf, &len, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_decrypt( &pk, | ||||
|                                                 buf, sizeof( buf ), | ||||
|                                                 NULL, &len, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_decrypt( &pk, | ||||
|                                                 buf, sizeof( buf ), | ||||
|                                                 buf, NULL, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|         mbedtls_pk_sign_restartable( &pk, valid_md, NULL, 0, buf, &len, | ||||
|                                      mbedtls_test_rnd_std_rand, NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_encrypt( NULL, | ||||
|                                                 buf, sizeof( buf ), | ||||
|                                                 buf, &len, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|         mbedtls_pk_sign_restartable( &pk, MBEDTLS_MD_NONE, buf, sizeof( buf ), | ||||
|                                      NULL, &len, mbedtls_test_rnd_std_rand, | ||||
|                                      NULL, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_encrypt( &pk, | ||||
|                                                 NULL, sizeof( buf ), | ||||
|                                                 buf, &len, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|         mbedtls_pk_sign( NULL, MBEDTLS_MD_NONE, buf, sizeof( buf ), | ||||
|                          buf, &len, mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_encrypt( &pk, | ||||
|                                                 buf, sizeof( buf ), | ||||
|                                                 NULL, &len, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|         mbedtls_pk_sign( &pk, MBEDTLS_MD_NONE, NULL, sizeof( buf ), | ||||
|                          buf, &len, mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_encrypt( &pk, | ||||
|                                                 buf, sizeof( buf ), | ||||
|                                                 buf, NULL, sizeof( buf ), | ||||
|                                                 rnd_std_rand, NULL ) ); | ||||
|         mbedtls_pk_sign( &pk, valid_md, NULL, 0, buf, &len, | ||||
|                          mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|         mbedtls_pk_sign( &pk, MBEDTLS_MD_NONE, buf, sizeof( buf ), NULL, &len, | ||||
|                          mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|         mbedtls_pk_decrypt( NULL, buf, sizeof( buf ), buf, &len, sizeof( buf ), | ||||
|                             mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|         mbedtls_pk_decrypt( &pk, NULL, sizeof( buf ), buf, &len, sizeof( buf ), | ||||
|                             mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|         mbedtls_pk_decrypt( &pk, buf, sizeof( buf ), NULL, &len, sizeof( buf ), | ||||
|                             mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|         mbedtls_pk_decrypt( &pk, buf, sizeof( buf ), buf, NULL, sizeof( buf ), | ||||
|                             mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|         mbedtls_pk_encrypt( NULL, buf, sizeof( buf ), buf, &len, sizeof( buf ), | ||||
|                             mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|         mbedtls_pk_encrypt( &pk, NULL, sizeof( buf ), buf, &len, sizeof( buf ), | ||||
|                             mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|         mbedtls_pk_encrypt( &pk, buf, sizeof( buf ), NULL, &len, sizeof( buf ), | ||||
|                             mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|         mbedtls_pk_encrypt( &pk, buf, sizeof( buf ), buf, NULL, sizeof( buf ), | ||||
|                             mbedtls_test_rnd_std_rand, NULL ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_PK_BAD_INPUT_DATA, | ||||
|                             mbedtls_pk_check_pair( NULL, &pk ) ); | ||||
|  | @ -843,7 +815,7 @@ void pk_sign_verify_restart( int pk_type, int grp_id, char *d_str, | |||
|     TEST_ASSERT( mbedtls_ecp_group_load( &mbedtls_pk_ec( pub )->grp, grp_id ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_point_read_string( &mbedtls_pk_ec( pub )->Q, 16, QX_str, QY_str ) == 0 ); | ||||
| 
 | ||||
|     slen_check = unhexify( sig_check, sig_str ); | ||||
|     slen_check = mbedtls_test_unhexify( sig_check, sig_str ); | ||||
| 
 | ||||
|     md_info = mbedtls_md_info_from_type( md_alg ); | ||||
|     TEST_ASSERT( md_info != NULL ); | ||||
|  | @ -947,7 +919,7 @@ void pk_sign_verify( int type, int parameter, int sign_ret, int verify_ret ) | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_pk_sign_restartable( &pk, MBEDTLS_MD_SHA256, | ||||
|                  hash, sizeof hash, sig, &sig_len, | ||||
|                  rnd_std_rand, NULL, rs_ctx ) == sign_ret ); | ||||
|                  mbedtls_test_rnd_std_rand, NULL, rs_ctx ) == sign_ret ); | ||||
|     if( sign_ret == 0 ) | ||||
|         TEST_ASSERT( sig_len <= MBEDTLS_PK_SIGNATURE_MAX_SIZE ); | ||||
|     else | ||||
|  | @ -970,7 +942,9 @@ void pk_sign_verify( int type, int parameter, int sign_ret, int verify_ret ) | |||
|     } | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_pk_sign( &pk, MBEDTLS_MD_SHA256, hash, sizeof hash, | ||||
|                           sig, &sig_len, rnd_std_rand, NULL ) == sign_ret ); | ||||
|                                   sig, &sig_len, | ||||
|                                   mbedtls_test_rnd_std_rand, | ||||
|                                   NULL ) == sign_ret ); | ||||
|     if( sign_ret == 0 ) | ||||
|         TEST_ASSERT( sig_len <= MBEDTLS_PK_SIGNATURE_MAX_SIZE ); | ||||
|     else | ||||
|  | @ -1007,12 +981,12 @@ void pk_rsa_encrypt_test_vec( data_t * message, int mod, int radix_N, | |||
|                               data_t * result, int ret ) | ||||
| { | ||||
|     unsigned char output[300]; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     mbedtls_rsa_context *rsa; | ||||
|     mbedtls_pk_context pk; | ||||
|     size_t olen; | ||||
| 
 | ||||
|     memset( &rnd_info,  0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info,  0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
|     memset( output,     0, sizeof( output ) ); | ||||
| 
 | ||||
| 
 | ||||
|  | @ -1025,8 +999,8 @@ void pk_rsa_encrypt_test_vec( data_t * message, int mod, int radix_N, | |||
|     TEST_ASSERT( mbedtls_mpi_read_string( &rsa->E, radix_E, input_E ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_pk_encrypt( &pk, message->x, message->len, | ||||
|                              output, &olen, sizeof( output ), | ||||
|                              rnd_pseudo_rand, &rnd_info ) == ret ); | ||||
|                             output, &olen, sizeof( output ), | ||||
|                             mbedtls_test_rnd_pseudo_rand, &rnd_info ) == ret ); | ||||
|     TEST_ASSERT( olen == result->len ); | ||||
|     TEST_ASSERT( memcmp( output, result->x, olen ) == 0 ); | ||||
| 
 | ||||
|  | @ -1042,7 +1016,7 @@ void pk_rsa_decrypt_test_vec( data_t * cipher, int mod, int radix_P, | |||
|                               char * input_E, data_t * clear, int ret ) | ||||
| { | ||||
|     unsigned char output[256]; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     mbedtls_mpi N, P, Q, E; | ||||
|     mbedtls_rsa_context *rsa; | ||||
|     mbedtls_pk_context pk; | ||||
|  | @ -1052,7 +1026,7 @@ void pk_rsa_decrypt_test_vec( data_t * cipher, int mod, int radix_P, | |||
|     mbedtls_mpi_init( &N ); mbedtls_mpi_init( &P ); | ||||
|     mbedtls_mpi_init( &Q ); mbedtls_mpi_init( &E ); | ||||
| 
 | ||||
|     memset( &rnd_info,  0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info,  0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
| 
 | ||||
|     /* init pk-rsa context */ | ||||
|  | @ -1074,8 +1048,8 @@ void pk_rsa_decrypt_test_vec( data_t * cipher, int mod, int radix_P, | |||
|     memset( output, 0, sizeof( output ) ); | ||||
|     olen = 0; | ||||
|     TEST_ASSERT( mbedtls_pk_decrypt( &pk, cipher->x, cipher->len, | ||||
|                              output, &olen, sizeof( output ), | ||||
|                              rnd_pseudo_rand, &rnd_info ) == ret ); | ||||
|                             output, &olen, sizeof( output ), | ||||
|                             mbedtls_test_rnd_pseudo_rand, &rnd_info ) == ret ); | ||||
|     if( ret == 0 ) | ||||
|     { | ||||
|         TEST_ASSERT( olen == clear->len ); | ||||
|  | @ -1095,25 +1069,25 @@ void pk_ec_nocrypt( int type ) | |||
|     mbedtls_pk_context pk; | ||||
|     unsigned char output[100]; | ||||
|     unsigned char input[100]; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     size_t olen = 0; | ||||
|     int ret = MBEDTLS_ERR_PK_TYPE_MISMATCH; | ||||
| 
 | ||||
|     mbedtls_pk_init( &pk ); | ||||
| 
 | ||||
|     memset( &rnd_info,  0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info,  0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
|     memset( output,     0, sizeof( output ) ); | ||||
|     memset( input,      0, sizeof( input ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_pk_setup( &pk, mbedtls_pk_info_from_type( type ) ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_pk_encrypt( &pk, input, sizeof( input ), | ||||
|                              output, &olen, sizeof( output ), | ||||
|                              rnd_pseudo_rand, &rnd_info ) == ret ); | ||||
|                             output, &olen, sizeof( output ), | ||||
|                             mbedtls_test_rnd_pseudo_rand, &rnd_info ) == ret ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_pk_decrypt( &pk, input, sizeof( input ), | ||||
|                              output, &olen, sizeof( output ), | ||||
|                              rnd_pseudo_rand, &rnd_info ) == ret ); | ||||
|                             output, &olen, sizeof( output ), | ||||
|                             mbedtls_test_rnd_pseudo_rand, &rnd_info ) == ret ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_pk_free( &pk ); | ||||
|  | @ -1147,8 +1121,9 @@ void pk_rsa_overflow( ) | |||
|     TEST_ASSERT( mbedtls_pk_verify( &pk, MBEDTLS_MD_NONE, hash, hash_len, | ||||
|                     sig, sig_len ) == MBEDTLS_ERR_PK_BAD_INPUT_DATA ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_pk_sign( &pk, MBEDTLS_MD_NONE, hash, hash_len, sig, &sig_len, | ||||
|                     rnd_std_rand, NULL ) == MBEDTLS_ERR_PK_BAD_INPUT_DATA ); | ||||
|     TEST_ASSERT( mbedtls_pk_sign( &pk, MBEDTLS_MD_NONE, hash, hash_len, sig, | ||||
|                                   &sig_len, mbedtls_test_rnd_std_rand, NULL ) | ||||
|                  == MBEDTLS_ERR_PK_BAD_INPUT_DATA ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_pk_free( &pk ); | ||||
|  | @ -1201,12 +1176,13 @@ void pk_rsa_alt(  ) | |||
| 
 | ||||
|     /* Test signature */ | ||||
| #if SIZE_MAX > UINT_MAX | ||||
|     TEST_ASSERT( mbedtls_pk_sign( &alt, MBEDTLS_MD_NONE, hash, SIZE_MAX, | ||||
|                                   sig, &sig_len, rnd_std_rand, NULL ) == | ||||
|                  MBEDTLS_ERR_PK_BAD_INPUT_DATA ); | ||||
|     TEST_ASSERT( mbedtls_pk_sign( &alt, MBEDTLS_MD_NONE, hash, SIZE_MAX, sig, | ||||
|                                   &sig_len, mbedtls_test_rnd_std_rand, NULL ) | ||||
|                  == MBEDTLS_ERR_PK_BAD_INPUT_DATA ); | ||||
| #endif /* SIZE_MAX > UINT_MAX */ | ||||
|     TEST_ASSERT( mbedtls_pk_sign( &alt, MBEDTLS_MD_NONE, hash, sizeof hash, | ||||
|                                   sig, &sig_len, rnd_std_rand, NULL ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_pk_sign( &alt, MBEDTLS_MD_NONE, hash, sizeof hash, sig, | ||||
|                                   &sig_len, mbedtls_test_rnd_std_rand, NULL ) | ||||
|                  == 0 ); | ||||
|     TEST_ASSERT( sig_len == RSA_KEY_LEN ); | ||||
|     TEST_ASSERT( mbedtls_pk_verify( &rsa, MBEDTLS_MD_NONE, | ||||
|                             hash, sizeof hash, sig, sig_len ) == 0 ); | ||||
|  | @ -1214,17 +1190,17 @@ void pk_rsa_alt(  ) | |||
|     /* Test decrypt */ | ||||
|     TEST_ASSERT( mbedtls_pk_encrypt( &rsa, msg, sizeof msg, | ||||
|                              ciph, &ciph_len, sizeof ciph, | ||||
|                              rnd_std_rand, NULL ) == 0 ); | ||||
|                              mbedtls_test_rnd_std_rand, NULL ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_pk_decrypt( &alt, ciph, ciph_len, | ||||
|                              test, &test_len, sizeof test, | ||||
|                              rnd_std_rand, NULL ) == 0 ); | ||||
|                              mbedtls_test_rnd_std_rand, NULL ) == 0 ); | ||||
|     TEST_ASSERT( test_len == sizeof msg ); | ||||
|     TEST_ASSERT( memcmp( test, msg, test_len ) == 0 ); | ||||
| 
 | ||||
|     /* Test forbidden operations */ | ||||
|     TEST_ASSERT( mbedtls_pk_encrypt( &alt, msg, sizeof msg, | ||||
|                              ciph, &ciph_len, sizeof ciph, | ||||
|                              rnd_std_rand, NULL ) == ret ); | ||||
|                              mbedtls_test_rnd_std_rand, NULL ) == ret ); | ||||
|     TEST_ASSERT( mbedtls_pk_verify( &alt, MBEDTLS_MD_NONE, | ||||
|                             hash, sizeof hash, sig, sig_len ) == ret ); | ||||
|     TEST_ASSERT( mbedtls_pk_debug( &alt, dbg_items ) == ret ); | ||||
|  | @ -1269,7 +1245,7 @@ void pk_psa_sign( int grpid_arg, | |||
|                       mbedtls_pk_info_from_type( MBEDTLS_PK_ECKEY ) ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_ecp_gen_key( grpid, | ||||
|                                       (mbedtls_ecp_keypair*) pk.pk_ctx, | ||||
|                                       rnd_std_rand, NULL ) == 0 ); | ||||
|                                       mbedtls_test_rnd_std_rand, NULL ) == 0 ); | ||||
| 
 | ||||
|     /* Export underlying public key for re-importing in a legacy context. */ | ||||
|     ret = mbedtls_pk_write_pubkey_der( &pk, pkey_legacy, | ||||
|  |  | |||
|  | @ -16,7 +16,7 @@ void pkcs1_rsaes_v15_encrypt( int mod, int radix_N, char * input_N, | |||
| { | ||||
|     unsigned char output[128]; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     rnd_buf_info info; | ||||
|     mbedtls_test_rnd_buf_info info; | ||||
|     mbedtls_mpi N, E; | ||||
| 
 | ||||
|     info.buf = rnd_buf->x; | ||||
|  | @ -34,10 +34,16 @@ void pkcs1_rsaes_v15_encrypt( int mod, int radix_N, char * input_N, | |||
| 
 | ||||
|     if( message_str->len == 0 ) | ||||
|         message_str->x = NULL; | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_encrypt( &ctx, &rnd_buffer_rand, &info, MBEDTLS_RSA_PUBLIC, message_str->len, message_str->x, output ) == result ); | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_encrypt( &ctx, | ||||
|                                             &mbedtls_test_rnd_buffer_rand, | ||||
|                                             &info, MBEDTLS_RSA_PUBLIC, | ||||
|                                             message_str->len, message_str->x, | ||||
|                                             output ) == result ); | ||||
| 
 | ||||
|     if( result == 0 ) | ||||
|     { | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           ctx.len, result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -57,7 +63,7 @@ void pkcs1_rsaes_v15_decrypt( int mod, int radix_P, char * input_P, | |||
|     unsigned char output[128]; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     size_t output_len; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     mbedtls_mpi N, P, Q, E; | ||||
|     ((void) seed); | ||||
| 
 | ||||
|  | @ -66,7 +72,7 @@ void pkcs1_rsaes_v15_decrypt( int mod, int radix_P, char * input_P, | |||
|     mbedtls_rsa_init( &ctx, MBEDTLS_RSA_PKCS_V15, hash ); | ||||
| 
 | ||||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     memset( &rnd_info, 0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &P, radix_P, input_P ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &Q, radix_Q, input_Q ) == 0 ); | ||||
|  | @ -80,14 +86,25 @@ void pkcs1_rsaes_v15_decrypt( int mod, int radix_P, char * input_P, | |||
| 
 | ||||
|     if( result_hex_str->len == 0 ) | ||||
|     { | ||||
|         TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, &rnd_pseudo_rand, &rnd_info, MBEDTLS_RSA_PRIVATE, &output_len, message_str->x, NULL, 0 ) == result ); | ||||
|         TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, | ||||
|                                                 &mbedtls_test_rnd_pseudo_rand, | ||||
|                                                 &rnd_info, | ||||
|                                                 MBEDTLS_RSA_PRIVATE, | ||||
|                                                 &output_len, message_str->x, | ||||
|                                                 NULL, 0 ) == result ); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, &rnd_pseudo_rand, &rnd_info, MBEDTLS_RSA_PRIVATE, &output_len, message_str->x, output, 1000 ) == result ); | ||||
|         TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, | ||||
|                                                 &mbedtls_test_rnd_pseudo_rand, | ||||
|                                                 &rnd_info, MBEDTLS_RSA_PRIVATE, | ||||
|                                                 &output_len, message_str->x, | ||||
|                                                 output, 1000 ) == result ); | ||||
|         if( result == 0 ) | ||||
|         { | ||||
|             TEST_ASSERT( hexcmp( output, result_hex_str->x, output_len, result_hex_str->len) == 0 ); | ||||
|             TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                               output_len, | ||||
|                                               result_hex_str->len) == 0 ); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  | @ -107,7 +124,7 @@ void pkcs1_v15_decode( int mode, | |||
| { | ||||
|     size_t expected_plaintext_length = expected_plaintext_length_arg; | ||||
|     size_t output_size = output_size_arg; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     mbedtls_mpi Nmpi, Empi, Pmpi, Qmpi; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     static unsigned char N[128] = { | ||||
|  | @ -173,7 +190,7 @@ void pkcs1_v15_decode( int mode, | |||
|     unsigned char final[128]; | ||||
|     size_t output_length = 0x7EA0; | ||||
| 
 | ||||
|     memset( &rnd_info, 0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
|     mbedtls_mpi_init( &Nmpi ); mbedtls_mpi_init( &Empi ); | ||||
|     mbedtls_mpi_init( &Pmpi ); mbedtls_mpi_init( &Qmpi ); | ||||
|     mbedtls_rsa_init( &ctx, MBEDTLS_RSA_PKCS_V15, 0 ); | ||||
|  | @ -193,16 +210,15 @@ void pkcs1_v15_decode( int mode, | |||
|     if( mode == MBEDTLS_RSA_PRIVATE ) | ||||
|         TEST_ASSERT( mbedtls_rsa_public( &ctx, original, intermediate ) == 0 ); | ||||
|     else | ||||
|         TEST_ASSERT( mbedtls_rsa_private( &ctx, &rnd_pseudo_rand, &rnd_info, | ||||
|                                           original, intermediate ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_rsa_private( &ctx, &mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info, original, | ||||
|                                           intermediate ) == 0 ); | ||||
| 
 | ||||
|     memcpy( final, default_content, sizeof( final ) ); | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, | ||||
|                                             &rnd_pseudo_rand, &rnd_info, | ||||
|                                             mode, | ||||
|                                             &output_length, | ||||
|                                             intermediate, | ||||
|                                             final, | ||||
|                                             &mbedtls_test_rnd_pseudo_rand, | ||||
|                                             &rnd_info, mode, &output_length, | ||||
|                                             intermediate, final, | ||||
|                                             output_size ) == expected_result ); | ||||
|     if( expected_result == 0 ) | ||||
|     { | ||||
|  | @ -257,7 +273,7 @@ void pkcs1_rsassa_v15_sign( int mod, int radix_P, char * input_P, int radix_Q, | |||
|     unsigned char output[128]; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     mbedtls_mpi N, P, Q, E; | ||||
|     rnd_buf_info info; | ||||
|     mbedtls_test_rnd_buf_info info; | ||||
| 
 | ||||
|     info.buf = rnd_buf->x; | ||||
|     info.length = rnd_buf->len; | ||||
|  | @ -283,11 +299,14 @@ void pkcs1_rsassa_v15_sign( int mod, int radix_P, char * input_P, int radix_Q, | |||
|     if( mbedtls_md_info_from_type( digest ) != NULL ) | ||||
|         TEST_ASSERT( mbedtls_md( mbedtls_md_info_from_type( digest ), message_str->x, message_str->len, hash_result ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_sign( &ctx, &rnd_buffer_rand, &info, MBEDTLS_RSA_PRIVATE, digest, 0, hash_result, output ) == result ); | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_sign( &ctx, &mbedtls_test_rnd_buffer_rand, | ||||
|                                          &info, MBEDTLS_RSA_PRIVATE, digest, | ||||
|                                          0, hash_result, output ) == result ); | ||||
|     if( result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           ctx.len, result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  |  | |||
|  | @ -16,7 +16,7 @@ void pkcs1_rsaes_oaep_encrypt( int mod, int radix_N, char * input_N, | |||
| { | ||||
|     unsigned char output[256]; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     rnd_buf_info info; | ||||
|     mbedtls_test_rnd_buf_info info; | ||||
|     mbedtls_mpi N, E; | ||||
| 
 | ||||
|     info.buf = rnd_buf->x; | ||||
|  | @ -34,10 +34,15 @@ void pkcs1_rsaes_oaep_encrypt( int mod, int radix_N, char * input_N, | |||
| 
 | ||||
|     if( message_str->len == 0 ) | ||||
|         message_str->x = NULL; | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_encrypt( &ctx, &rnd_buffer_rand, &info, MBEDTLS_RSA_PUBLIC, message_str->len, message_str->x, output ) == result ); | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_encrypt( &ctx, | ||||
|                                             &mbedtls_test_rnd_buffer_rand, | ||||
|                                             &info, MBEDTLS_RSA_PUBLIC, | ||||
|                                             message_str->len, message_str->x, | ||||
|                                             output ) == result ); | ||||
|     if( result == 0 ) | ||||
|     { | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           ctx.len, result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -57,7 +62,7 @@ void pkcs1_rsaes_oaep_decrypt( int mod, int radix_P, char * input_P, | |||
|     unsigned char output[64]; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     size_t output_len; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     mbedtls_mpi N, P, Q, E; | ||||
|     ((void) seed); | ||||
| 
 | ||||
|  | @ -67,7 +72,7 @@ void pkcs1_rsaes_oaep_decrypt( int mod, int radix_P, char * input_P, | |||
|     mbedtls_rsa_init( &ctx, MBEDTLS_RSA_PKCS_V21, hash ); | ||||
| 
 | ||||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     memset( &rnd_info, 0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &P, radix_P, input_P ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &Q, radix_Q, input_Q ) == 0 ); | ||||
|  | @ -81,19 +86,27 @@ void pkcs1_rsaes_oaep_decrypt( int mod, int radix_P, char * input_P, | |||
| 
 | ||||
|     if( result_hex_str->len == 0 ) | ||||
|     { | ||||
|         TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, &rnd_pseudo_rand, &rnd_info, | ||||
|                                                 MBEDTLS_RSA_PRIVATE, &output_len, | ||||
|                                                 message_str->x, NULL, 0 ) == result ); | ||||
|         TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, | ||||
|                                                 &mbedtls_test_rnd_pseudo_rand, | ||||
|                                                 &rnd_info, | ||||
|                                                 MBEDTLS_RSA_PRIVATE, | ||||
|                                                 &output_len, message_str->x, | ||||
|                                                 NULL, 0 ) == result ); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, &rnd_pseudo_rand, &rnd_info, | ||||
|                                                 MBEDTLS_RSA_PRIVATE, &output_len, | ||||
|                                                 message_str->x, output, | ||||
|         TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, | ||||
|                                                 &mbedtls_test_rnd_pseudo_rand, | ||||
|                                                 &rnd_info, | ||||
|                                                 MBEDTLS_RSA_PRIVATE, | ||||
|                                                 &output_len, message_str->x, | ||||
|                                                 output, | ||||
|                                                 sizeof( output ) ) == result ); | ||||
|         if( result == 0 ) | ||||
|         { | ||||
|             TEST_ASSERT( hexcmp( output, result_hex_str->x, output_len, result_hex_str->len ) == 0 ); | ||||
|             TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                               output_len, | ||||
|                                               result_hex_str->len ) == 0 ); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  | @ -114,7 +127,7 @@ void pkcs1_rsassa_pss_sign( int mod, int radix_P, char * input_P, int radix_Q, | |||
|     unsigned char hash_result[MBEDTLS_MD_MAX_SIZE]; | ||||
|     unsigned char output[256]; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     rnd_buf_info info; | ||||
|     mbedtls_test_rnd_buf_info info; | ||||
|     mbedtls_mpi N, P, Q, E; | ||||
| 
 | ||||
|     info.buf = rnd_buf->x; | ||||
|  | @ -141,12 +154,14 @@ void pkcs1_rsassa_pss_sign( int mod, int radix_P, char * input_P, int radix_Q, | |||
|     if( mbedtls_md_info_from_type( digest ) != NULL ) | ||||
|         TEST_ASSERT( mbedtls_md( mbedtls_md_info_from_type( digest ), message_str->x, message_str->len, hash_result ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_sign( &ctx, &rnd_buffer_rand, &info, MBEDTLS_RSA_PRIVATE, | ||||
|                                          digest, 0, hash_result, output ) == result ); | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_sign( &ctx, &mbedtls_test_rnd_buffer_rand, | ||||
|                                          &info, MBEDTLS_RSA_PRIVATE, digest, 0, | ||||
|                                          hash_result, output ) == result ); | ||||
|     if( result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           ctx.len, result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  |  | |||
|  | @ -24,7 +24,8 @@ void pbkdf2_hmac( int hash, data_t * pw_str, data_t * salt_str, | |||
|     TEST_ASSERT( mbedtls_pkcs5_pbkdf2_hmac( &ctx, pw_str->x, pw_str->len, salt_str->x, salt_str->len, | ||||
|                                      it_cnt, key_len, key ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( key, result_key_string->x, key_len, result_key_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( key, result_key_string->x, | ||||
|                                       key_len, result_key_string->len ) == 0 ); | ||||
| 
 | ||||
| exit: | ||||
|     mbedtls_md_free( &ctx ); | ||||
|  | @ -43,7 +44,7 @@ void mbedtls_pkcs5_pbes2( int params_tag, data_t *params_hex, data_t *pw, | |||
|     params.p = params_hex->x; | ||||
|     params.len = params_hex->len; | ||||
| 
 | ||||
|     my_out = zero_alloc( ref_out->len ); | ||||
|     my_out = mbedtls_test_zero_alloc( ref_out->len ); | ||||
| 
 | ||||
|     my_ret = mbedtls_pkcs5_pbes2( ¶ms, MBEDTLS_PKCS5_DECRYPT, | ||||
|                           pw->x, pw->len, data->x, data->len, my_out ); | ||||
|  |  | |||
|  | @ -23,15 +23,15 @@ void mbedtls_poly1305( char *hex_key_string, char *hex_mac_string, char *hex_src | |||
|     memset( key,     0x00, sizeof( key ) ); | ||||
|     memset( mac,     0x00, sizeof( mac ) ); | ||||
| 
 | ||||
|     src_len = unhexify( src_str, hex_src_string ); | ||||
|     unhexify( key, hex_key_string ); | ||||
|     src_len = mbedtls_test_unhexify( src_str, hex_src_string ); | ||||
|     mbedtls_test_unhexify( key, hex_key_string ); | ||||
| 
 | ||||
|     /* | ||||
|      * Test the integrated API | ||||
|      */ | ||||
|     TEST_ASSERT( mbedtls_poly1305_mac( key, src_str, src_len, mac ) == 0 ); | ||||
| 
 | ||||
|     hexify( mac_str, mac, 16 ); | ||||
|     mbedtls_test_hexify( mac_str, mac, 16 ); | ||||
|     TEST_ASSERT( strcmp( (char *) mac_str, hex_mac_string ) == 0 ); | ||||
| 
 | ||||
|     /* | ||||
|  | @ -45,7 +45,7 @@ void mbedtls_poly1305( char *hex_key_string, char *hex_mac_string, char *hex_src | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_poly1305_finish( &ctx, mac ) == 0 ); | ||||
| 
 | ||||
|     hexify( mac_str, mac, 16 ); | ||||
|     mbedtls_test_hexify( mac_str, mac, 16 ); | ||||
|     TEST_ASSERT( strcmp( (char *) mac_str, hex_mac_string ) == 0 ); | ||||
| 
 | ||||
|     /* | ||||
|  | @ -63,7 +63,7 @@ void mbedtls_poly1305( char *hex_key_string, char *hex_mac_string, char *hex_src | |||
| 
 | ||||
|         TEST_ASSERT( mbedtls_poly1305_finish( &ctx, mac ) == 0 ); | ||||
| 
 | ||||
|         hexify( mac_str, mac, 16 ); | ||||
|         mbedtls_test_hexify( mac_str, mac, 16 ); | ||||
|         TEST_ASSERT( strcmp( (char *) mac_str, hex_mac_string ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
|  | @ -80,7 +80,7 @@ void mbedtls_poly1305( char *hex_key_string, char *hex_mac_string, char *hex_src | |||
| 
 | ||||
|         TEST_ASSERT( mbedtls_poly1305_finish( &ctx, mac ) == 0 ); | ||||
| 
 | ||||
|         hexify( mac_str, mac, 16 ); | ||||
|         mbedtls_test_hexify( mac_str, mac, 16 ); | ||||
|         TEST_ASSERT( strcmp( (char *) mac_str, hex_mac_string ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -9,7 +9,7 @@ | |||
|  * uses mbedtls_ctr_drbg internally. */ | ||||
| #include "mbedtls/ctr_drbg.h" | ||||
| 
 | ||||
| #include "psa_crypto_helpers.h" | ||||
| #include "test/psa_crypto_helpers.h" | ||||
| 
 | ||||
| /* Tests that require more than 128kB of RAM plus change have this symbol | ||||
|  * as a dependency. Currently we always define this symbol, so the tests | ||||
|  |  | |||
|  | @ -4,7 +4,7 @@ | |||
| #include "mbedtls/entropy.h" | ||||
| #include "mbedtls/entropy_poll.h" | ||||
| 
 | ||||
| #include "psa_crypto_helpers.h" | ||||
| #include "test/psa_crypto_helpers.h" | ||||
| #if defined(MBEDTLS_PSA_ITS_FILE_C) | ||||
| #include <stdio.h> | ||||
| #else | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ | |||
| 
 | ||||
| #include <stdint.h> | ||||
| 
 | ||||
| #include "psa_crypto_helpers.h" | ||||
| #include "test/psa_crypto_helpers.h" | ||||
| 
 | ||||
| /* END_HEADER */ | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| /* BEGIN_HEADER */ | ||||
| #include <stdint.h> | ||||
| 
 | ||||
| #include "psa_crypto_helpers.h" | ||||
| #include "test/psa_crypto_helpers.h" | ||||
| /* Some tests in this module configure entropy sources. */ | ||||
| #include "psa_crypto_invasive.h" | ||||
| 
 | ||||
|  |  | |||
|  | @ -9,7 +9,7 @@ | |||
| 
 | ||||
| #include <stdint.h> | ||||
| 
 | ||||
| #include "psa_crypto_helpers.h" | ||||
| #include "test/psa_crypto_helpers.h" | ||||
| #include "psa_crypto_storage.h" | ||||
| 
 | ||||
| #include "mbedtls/md.h" | ||||
|  |  | |||
|  | @ -1,5 +1,5 @@ | |||
| /* BEGIN_HEADER */ | ||||
| #include "psa_crypto_helpers.h" | ||||
| #include "test/psa_crypto_helpers.h" | ||||
| #include "psa/crypto_se_driver.h" | ||||
| 
 | ||||
| #include "psa_crypto_se.h" | ||||
|  |  | |||
|  | @ -1,5 +1,5 @@ | |||
| /* BEGIN_HEADER */ | ||||
| #include "psa_crypto_helpers.h" | ||||
| #include "test/psa_crypto_helpers.h" | ||||
| #include "psa/crypto_se_driver.h" | ||||
| 
 | ||||
| #include "psa_crypto_se.h" | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| /* BEGIN_HEADER */ | ||||
| #include <stdint.h> | ||||
| 
 | ||||
| #include "psa_crypto_helpers.h" | ||||
| #include "test/psa_crypto_helpers.h" | ||||
| #include "psa_crypto_storage.h" | ||||
| 
 | ||||
| typedef enum | ||||
|  |  | |||
|  | @ -7,7 +7,7 @@ | |||
| 
 | ||||
| #include "../library/psa_crypto_its.h" | ||||
| 
 | ||||
| #include "psa_helpers.h" | ||||
| #include "test/psa_helpers.h" | ||||
| 
 | ||||
| /* Internal definitions of the implementation, copied for the sake of | ||||
|  * some of the tests and of the cleanup code. */ | ||||
|  |  | |||
|  | @ -67,7 +67,8 @@ void rsa_invalid_param( ) | |||
|                                                  invalid_padding, 0 ) ); | ||||
| 
 | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_RSA_BAD_INPUT_DATA, | ||||
|                             mbedtls_rsa_gen_key( NULL, rnd_std_rand, | ||||
|                             mbedtls_rsa_gen_key( NULL, | ||||
|                                                  mbedtls_test_rnd_std_rand, | ||||
|                                                  NULL, 0, 0 ) ); | ||||
|     TEST_INVALID_PARAM_RET( MBEDTLS_ERR_RSA_BAD_INPUT_DATA, | ||||
|                             mbedtls_rsa_gen_key( &ctx, NULL, | ||||
|  | @ -476,7 +477,7 @@ void mbedtls_rsa_pkcs1_sign( data_t * message_str, int padding_mode, | |||
|     unsigned char output[256]; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     mbedtls_mpi N, P, Q, E; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_mpi_init( &N ); mbedtls_mpi_init( &P ); | ||||
|     mbedtls_mpi_init( &Q ); mbedtls_mpi_init( &E ); | ||||
|  | @ -484,7 +485,7 @@ void mbedtls_rsa_pkcs1_sign( data_t * message_str, int padding_mode, | |||
| 
 | ||||
|     memset( hash_result, 0x00, sizeof( hash_result ) ); | ||||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     memset( &rnd_info, 0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &P, radix_P, input_P ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &Q, radix_Q, input_Q ) == 0 ); | ||||
|  | @ -500,13 +501,14 @@ void mbedtls_rsa_pkcs1_sign( data_t * message_str, int padding_mode, | |||
|     if( mbedtls_md_info_from_type( digest ) != NULL ) | ||||
|         TEST_ASSERT( mbedtls_md( mbedtls_md_info_from_type( digest ), message_str->x, message_str->len, hash_result ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_sign( &ctx, &rnd_pseudo_rand, &rnd_info, | ||||
|                                          MBEDTLS_RSA_PRIVATE, digest, 0, | ||||
|                                          hash_result, output ) == result ); | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_sign( &ctx, &mbedtls_test_rnd_pseudo_rand, | ||||
|                                          &rnd_info, MBEDTLS_RSA_PRIVATE, digest, | ||||
|                                          0, hash_result, output ) == result ); | ||||
|     if( result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           ctx.len, result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -560,14 +562,14 @@ void rsa_pkcs1_sign_raw( data_t * hash_result, | |||
|     unsigned char output[256]; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     mbedtls_mpi N, P, Q, E; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_rsa_init( &ctx, padding_mode, 0 ); | ||||
|     mbedtls_mpi_init( &N ); mbedtls_mpi_init( &P ); | ||||
|     mbedtls_mpi_init( &Q ); mbedtls_mpi_init( &E ); | ||||
| 
 | ||||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     memset( &rnd_info, 0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &P, radix_P, input_P ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &Q, radix_Q, input_Q ) == 0 ); | ||||
|  | @ -580,13 +582,14 @@ void rsa_pkcs1_sign_raw( data_t * hash_result, | |||
|     TEST_ASSERT( mbedtls_rsa_check_privkey( &ctx ) == 0 ); | ||||
| 
 | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_sign( &ctx, &rnd_pseudo_rand, &rnd_info, | ||||
|                                          MBEDTLS_RSA_PRIVATE, MBEDTLS_MD_NONE, | ||||
|                                          hash_result->len, hash_result->x, | ||||
|                                          output ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_sign( &ctx, &mbedtls_test_rnd_pseudo_rand, | ||||
|                                          &rnd_info, MBEDTLS_RSA_PRIVATE, | ||||
|                                          MBEDTLS_MD_NONE, hash_result->len, | ||||
|                                          hash_result->x, output ) == 0 ); | ||||
| 
 | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                       ctx.len, result_hex_str->len ) == 0 ); | ||||
| 
 | ||||
| #if defined(MBEDTLS_PKCS1_V15) | ||||
|     /* For PKCS#1 v1.5, there is an alternative way to generate signatures */ | ||||
|  | @ -596,8 +599,9 @@ void rsa_pkcs1_sign_raw( data_t * hash_result, | |||
|         memset( output, 0x00, sizeof( output) ); | ||||
| 
 | ||||
|         res = mbedtls_rsa_rsaes_pkcs1_v15_encrypt( &ctx, | ||||
|                     &rnd_pseudo_rand, &rnd_info, MBEDTLS_RSA_PRIVATE, | ||||
|                     hash_result->len, hash_result->x, output ); | ||||
|                   &mbedtls_test_rnd_pseudo_rand, &rnd_info, | ||||
|                   MBEDTLS_RSA_PRIVATE, hash_result->len, | ||||
|                   hash_result->x, output ); | ||||
| 
 | ||||
| #if !defined(MBEDTLS_RSA_ALT) | ||||
|         TEST_ASSERT( res == 0 ); | ||||
|  | @ -608,7 +612,9 @@ void rsa_pkcs1_sign_raw( data_t * hash_result, | |||
| 
 | ||||
|         if( res == 0 ) | ||||
|         { | ||||
|             TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|             TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                               ctx.len, | ||||
|                                               result_hex_str->len ) == 0 ); | ||||
|         } | ||||
|     } | ||||
| #endif /* MBEDTLS_PKCS1_V15 */ | ||||
|  | @ -690,12 +696,12 @@ void mbedtls_rsa_pkcs1_encrypt( data_t * message_str, int padding_mode, | |||
| { | ||||
|     unsigned char output[256]; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     mbedtls_mpi N, E; | ||||
|     mbedtls_mpi_init( &N ); mbedtls_mpi_init( &E ); | ||||
| 
 | ||||
|     memset( &rnd_info, 0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     mbedtls_rsa_init( &ctx, padding_mode, 0 ); | ||||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|  | @ -708,13 +714,16 @@ void mbedtls_rsa_pkcs1_encrypt( data_t * message_str, int padding_mode, | |||
|     TEST_ASSERT( mbedtls_rsa_check_pubkey( &ctx ) == 0 ); | ||||
| 
 | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_encrypt( &ctx, &rnd_pseudo_rand, &rnd_info, | ||||
|                                             MBEDTLS_RSA_PUBLIC, message_str->len, | ||||
|                                             message_str->x, output ) == result ); | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_encrypt( &ctx, | ||||
|                                             &mbedtls_test_rnd_pseudo_rand, | ||||
|                                             &rnd_info, MBEDTLS_RSA_PUBLIC, | ||||
|                                             message_str->len, message_str->x, | ||||
|                                             output ) == result ); | ||||
|     if( result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           ctx.len, result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -746,13 +755,15 @@ void rsa_pkcs1_encrypt_bad_rng( data_t * message_str, int padding_mode, | |||
|     TEST_ASSERT( mbedtls_rsa_check_pubkey( &ctx ) == 0 ); | ||||
| 
 | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_encrypt( &ctx, &rnd_zero_rand, NULL, | ||||
|                                             MBEDTLS_RSA_PUBLIC, message_str->len, | ||||
|                                             message_str->x, output ) == result ); | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_encrypt( &ctx, &mbedtls_test_rnd_zero_rand, | ||||
|                                             NULL, MBEDTLS_RSA_PUBLIC, | ||||
|                                             message_str->len, message_str->x, | ||||
|                                             output ) == result ); | ||||
|     if( result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           ctx.len, result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -772,7 +783,7 @@ void mbedtls_rsa_pkcs1_decrypt( data_t * message_str, int padding_mode, | |||
|     unsigned char output[32]; | ||||
|     mbedtls_rsa_context ctx; | ||||
|     size_t output_len; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     mbedtls_mpi N, P, Q, E; | ||||
| 
 | ||||
|     mbedtls_mpi_init( &N ); mbedtls_mpi_init( &P ); | ||||
|  | @ -781,7 +792,7 @@ void mbedtls_rsa_pkcs1_decrypt( data_t * message_str, int padding_mode, | |||
|     mbedtls_rsa_init( &ctx, padding_mode, 0 ); | ||||
| 
 | ||||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     memset( &rnd_info, 0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &P, radix_P, input_P ) == 0 ); | ||||
|  | @ -796,11 +807,16 @@ void mbedtls_rsa_pkcs1_decrypt( data_t * message_str, int padding_mode, | |||
| 
 | ||||
|     output_len = 0; | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, rnd_pseudo_rand, &rnd_info, MBEDTLS_RSA_PRIVATE, &output_len, message_str->x, output, max_output ) == result ); | ||||
|     TEST_ASSERT( mbedtls_rsa_pkcs1_decrypt( &ctx, mbedtls_test_rnd_pseudo_rand, | ||||
|                                             &rnd_info, MBEDTLS_RSA_PRIVATE, | ||||
|                                             &output_len, message_str->x, output, | ||||
|                                             max_output ) == result ); | ||||
|     if( result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, output_len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           output_len, | ||||
|                                           result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -837,7 +853,8 @@ void mbedtls_rsa_public( data_t * message_str, int mod, int radix_N, | |||
|     if( result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           ctx.len, result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
|     /* And now with the copy */ | ||||
|  | @ -852,7 +869,8 @@ void mbedtls_rsa_public( data_t * message_str, int mod, int radix_N, | |||
|     if( result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           ctx.len, result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  | @ -872,7 +890,7 @@ void mbedtls_rsa_private( data_t * message_str, int mod, int radix_P, | |||
|     unsigned char output[256]; | ||||
|     mbedtls_rsa_context ctx, ctx2; /* Also test mbedtls_rsa_copy() while at it */ | ||||
|     mbedtls_mpi N, P, Q, E; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
|     int i; | ||||
| 
 | ||||
|     mbedtls_mpi_init( &N ); mbedtls_mpi_init( &P ); | ||||
|  | @ -880,7 +898,7 @@ void mbedtls_rsa_private( data_t * message_str, int mod, int radix_P, | |||
|     mbedtls_rsa_init( &ctx, MBEDTLS_RSA_PKCS_V15, 0 ); | ||||
|     mbedtls_rsa_init( &ctx2, MBEDTLS_RSA_PKCS_V15, 0 ); | ||||
| 
 | ||||
|     memset( &rnd_info, 0, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &P, radix_P, input_P ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_mpi_read_string( &Q, radix_Q, input_Q ) == 0 ); | ||||
|  | @ -897,12 +915,15 @@ void mbedtls_rsa_private( data_t * message_str, int mod, int radix_P, | |||
|     for( i = 0; i < 3; i++ ) | ||||
|     { | ||||
|         memset( output, 0x00, sizeof( output ) ); | ||||
|         TEST_ASSERT( mbedtls_rsa_private( &ctx, rnd_pseudo_rand, &rnd_info, | ||||
|                                   message_str->x, output ) == result ); | ||||
|         TEST_ASSERT( mbedtls_rsa_private( &ctx, mbedtls_test_rnd_pseudo_rand, | ||||
|                                           &rnd_info, message_str->x, | ||||
|                                           output ) == result ); | ||||
|         if( result == 0 ) | ||||
|         { | ||||
| 
 | ||||
|             TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx.len, result_hex_str->len ) == 0 ); | ||||
|             TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                               ctx.len, | ||||
|                                               result_hex_str->len ) == 0 ); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  | @ -914,12 +935,15 @@ void mbedtls_rsa_private( data_t * message_str, int mod, int radix_P, | |||
|     TEST_ASSERT( mbedtls_rsa_check_privkey( &ctx2 ) == 0 ); | ||||
| 
 | ||||
|     memset( output, 0x00, sizeof( output ) ); | ||||
|     TEST_ASSERT( mbedtls_rsa_private( &ctx2, rnd_pseudo_rand, &rnd_info, | ||||
|                               message_str->x, output ) == result ); | ||||
|     TEST_ASSERT( mbedtls_rsa_private( &ctx2, mbedtls_test_rnd_pseudo_rand, | ||||
|                                       &rnd_info, message_str->x, | ||||
|                                       output ) == result ); | ||||
|     if( result == 0 ) | ||||
|     { | ||||
| 
 | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, ctx2.len, result_hex_str->len ) == 0 ); | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                                           ctx2.len, | ||||
|                                           result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| 
 | ||||
| exit: | ||||
|  |  | |||
|  | @ -61,7 +61,8 @@ void mbedtls_sha1( data_t * src_str, data_t * hex_hash_string ) | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_sha1_ret( src_str->x, src_str->len, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, 20, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       20, hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -131,7 +132,8 @@ void sha224( data_t * src_str, data_t * hex_hash_string ) | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_sha256_ret( src_str->x, src_str->len, output, 1 ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, 28, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       28, hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -145,7 +147,8 @@ void mbedtls_sha256( data_t * src_str, data_t * hex_hash_string ) | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_sha256_ret( src_str->x, src_str->len, output, 0 ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, 32, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       32, hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -215,7 +218,8 @@ void sha384( data_t * src_str, data_t * hex_hash_string ) | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_sha512_ret( src_str->x, src_str->len, output, 1 ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, 48, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       48, hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -229,7 +233,8 @@ void mbedtls_sha512( data_t * src_str, data_t * hex_hash_string ) | |||
| 
 | ||||
|     TEST_ASSERT( mbedtls_sha512_ret( src_str->x, src_str->len, output, 0 ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_hash_string->x, 64, hex_hash_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_hash_string->x, | ||||
|                                       64, hex_hash_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  |  | |||
|  | @ -1185,8 +1185,8 @@ static int build_transforms( mbedtls_ssl_transform *t_in, | |||
|     unsigned char cid0[ SSL_CID_LEN_MIN ]; | ||||
|     unsigned char cid1[ SSL_CID_LEN_MIN ]; | ||||
| 
 | ||||
|     rnd_std_rand( NULL, cid0, sizeof( cid0 ) ); | ||||
|     rnd_std_rand( NULL, cid1, sizeof( cid1 ) ); | ||||
|     mbedtls_test_rnd_std_rand( NULL, cid0, sizeof( cid0 ) ); | ||||
|     mbedtls_test_rnd_std_rand( NULL, cid1, sizeof( cid1 ) ); | ||||
| #else | ||||
|     ((void) cid0_len); | ||||
|     ((void) cid1_len); | ||||
|  | @ -3232,7 +3232,7 @@ void ssl_crypt_record( int cipher_type, int hash_id, | |||
| 
 | ||||
|         /* Encrypt record */ | ||||
|         ret = mbedtls_ssl_encrypt_buf( &ssl, t_enc, &rec, | ||||
|                                        rnd_std_rand, NULL ); | ||||
|                                        mbedtls_test_rnd_std_rand, NULL ); | ||||
|         TEST_ASSERT( ret == 0 || ret == MBEDTLS_ERR_SSL_BUFFER_TOO_SMALL ); | ||||
|         if( ret != 0 ) | ||||
|         { | ||||
|  | @ -3386,7 +3386,8 @@ void ssl_crypt_record_small( int cipher_type, int hash_id, | |||
|             rec_backup = rec; | ||||
| 
 | ||||
|             /* Encrypt record */ | ||||
|             ret = mbedtls_ssl_encrypt_buf( &ssl, t_enc, &rec, rnd_std_rand, NULL ); | ||||
|             ret = mbedtls_ssl_encrypt_buf( &ssl, t_enc, &rec, | ||||
|                                            mbedtls_test_rnd_std_rand, NULL ); | ||||
| 
 | ||||
|             if( ( mode == 1 || mode == 2 ) && seen_success ) | ||||
|             { | ||||
|  | @ -3471,7 +3472,7 @@ void ssl_tls_prf( int type, data_t * secret, data_t * random, | |||
| 
 | ||||
|     if( exp_ret == 0 ) | ||||
|     { | ||||
|         TEST_ASSERT( hexcmp( output, result_hex_str->x, | ||||
|         TEST_ASSERT( mbedtls_test_hexcmp( output, result_hex_str->x, | ||||
|                      result_hex_str->len, result_hex_str->len ) == 0 ); | ||||
|     } | ||||
| exit: | ||||
|  |  | |||
|  | @ -94,9 +94,9 @@ void x509_csr_check( char * key_file, char * cert_req_check_file, int md_type, | |||
|     int der_len = -1; | ||||
|     FILE *f; | ||||
|     const char *subject_name = "C=NL,O=PolarSSL,CN=PolarSSL Server 1"; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     memset( &rnd_info, 0x2a, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x2a, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     mbedtls_pk_init( &key ); | ||||
|     TEST_ASSERT( mbedtls_pk_parse_keyfile( &key, key_file, NULL ) == 0 ); | ||||
|  | @ -111,7 +111,7 @@ void x509_csr_check( char * key_file, char * cert_req_check_file, int md_type, | |||
|         TEST_ASSERT( mbedtls_x509write_csr_set_ns_cert_type( &req, cert_type ) == 0 ); | ||||
| 
 | ||||
|     ret = mbedtls_x509write_csr_pem( &req, buf, sizeof( buf ), | ||||
|                              rnd_pseudo_rand, &rnd_info ); | ||||
|                                      mbedtls_test_rnd_pseudo_rand, &rnd_info ); | ||||
|     TEST_ASSERT( ret == 0 ); | ||||
| 
 | ||||
|     pem_len = strlen( (char *) buf ); | ||||
|  | @ -125,14 +125,15 @@ void x509_csr_check( char * key_file, char * cert_req_check_file, int md_type, | |||
|     TEST_ASSERT( memcmp( buf, check_buf, pem_len - 1 ) == 0 ); | ||||
| 
 | ||||
|     der_len = mbedtls_x509write_csr_der( &req, buf, sizeof( buf ), | ||||
|                             rnd_pseudo_rand, &rnd_info ); | ||||
|                                          mbedtls_test_rnd_pseudo_rand, | ||||
|                                          &rnd_info ); | ||||
|     TEST_ASSERT( der_len >= 0 ); | ||||
| 
 | ||||
|     if( der_len == 0 ) | ||||
|         goto exit; | ||||
| 
 | ||||
|     ret = mbedtls_x509write_csr_der( &req, buf, (size_t)( der_len - 1 ), | ||||
|                             rnd_pseudo_rand, &rnd_info ); | ||||
|                                      mbedtls_test_rnd_pseudo_rand, &rnd_info ); | ||||
|     TEST_ASSERT( ret == MBEDTLS_ERR_ASN1_BUF_TOO_SMALL ); | ||||
| 
 | ||||
| exit: | ||||
|  | @ -153,10 +154,10 @@ void x509_csr_check_opaque( char *key_file, int md_type, int key_usage, | |||
|     int ret; | ||||
|     size_t pem_len = 0; | ||||
|     const char *subject_name = "C=NL,O=PolarSSL,CN=PolarSSL Server 1"; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     psa_crypto_init(); | ||||
|     memset( &rnd_info, 0x2a, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x2a, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
| 
 | ||||
|     md_alg_psa = mbedtls_psa_translate_md( (mbedtls_md_type_t) md_type ); | ||||
|     TEST_ASSERT( md_alg_psa != MBEDTLS_MD_NONE ); | ||||
|  | @ -175,7 +176,8 @@ void x509_csr_check_opaque( char *key_file, int md_type, int key_usage, | |||
|         TEST_ASSERT( mbedtls_x509write_csr_set_ns_cert_type( &req, cert_type ) == 0 ); | ||||
| 
 | ||||
|     ret = mbedtls_x509write_csr_pem( &req, buf, sizeof( buf ) - 1, | ||||
|                              rnd_pseudo_rand, &rnd_info ); | ||||
|                                      mbedtls_test_rnd_pseudo_rand, &rnd_info ); | ||||
| 
 | ||||
|     TEST_ASSERT( ret == 0 ); | ||||
| 
 | ||||
|     pem_len = strlen( (char *) buf ); | ||||
|  | @ -208,9 +210,9 @@ void x509_crt_check( char *subject_key_file, char *subject_pwd, | |||
|     size_t olen = 0, pem_len = 0; | ||||
|     int der_len = -1; | ||||
|     FILE *f; | ||||
|     rnd_pseudo_info rnd_info; | ||||
|     mbedtls_test_rnd_pseudo_info rnd_info; | ||||
| 
 | ||||
|     memset( &rnd_info, 0x2a, sizeof( rnd_pseudo_info ) ); | ||||
|     memset( &rnd_info, 0x2a, sizeof( mbedtls_test_rnd_pseudo_info ) ); | ||||
|     mbedtls_mpi_init( &serial ); | ||||
| 
 | ||||
|     mbedtls_pk_init( &subject_key ); | ||||
|  | @ -269,7 +271,7 @@ void x509_crt_check( char *subject_key_file, char *subject_pwd, | |||
|     } | ||||
| 
 | ||||
|     ret = mbedtls_x509write_crt_pem( &crt, buf, sizeof( buf ), | ||||
|                                      rnd_pseudo_rand, &rnd_info ); | ||||
|                                      mbedtls_test_rnd_pseudo_rand, &rnd_info ); | ||||
|     TEST_ASSERT( ret == 0 ); | ||||
| 
 | ||||
|     pem_len = strlen( (char *) buf ); | ||||
|  | @ -284,14 +286,15 @@ void x509_crt_check( char *subject_key_file, char *subject_pwd, | |||
|     TEST_ASSERT( memcmp( buf, check_buf, pem_len - 1 ) == 0 ); | ||||
| 
 | ||||
|     der_len = mbedtls_x509write_crt_der( &crt, buf, sizeof( buf ), | ||||
|                                          rnd_pseudo_rand, &rnd_info ); | ||||
|                                          mbedtls_test_rnd_pseudo_rand, | ||||
|                                          &rnd_info ); | ||||
|     TEST_ASSERT( der_len >= 0 ); | ||||
| 
 | ||||
|     if( der_len == 0 ) | ||||
|         goto exit; | ||||
| 
 | ||||
|     ret = mbedtls_x509write_crt_der( &crt, buf, (size_t)( der_len - 1 ), | ||||
|                                      rnd_pseudo_rand, &rnd_info ); | ||||
|                                      mbedtls_test_rnd_pseudo_rand, &rnd_info ); | ||||
|     TEST_ASSERT( ret == MBEDTLS_ERR_ASN1_BUF_TOO_SMALL ); | ||||
| 
 | ||||
| exit: | ||||
|  |  | |||
|  | @ -20,7 +20,8 @@ void xtea_encrypt_ecb( data_t * key_str, data_t * src_str, | |||
|     mbedtls_xtea_setup( &ctx, key_str->x ); | ||||
|     TEST_ASSERT( mbedtls_xtea_crypt_ecb( &ctx, MBEDTLS_XTEA_ENCRYPT, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, 8, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       8, hex_dst_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -37,7 +38,8 @@ void xtea_decrypt_ecb( data_t * key_str, data_t * src_str, | |||
|     mbedtls_xtea_setup( &ctx, key_str->x ); | ||||
|     TEST_ASSERT( mbedtls_xtea_crypt_ecb( &ctx, MBEDTLS_XTEA_DECRYPT, src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, 8, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       8, hex_dst_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -55,7 +57,9 @@ void xtea_encrypt_cbc( data_t * key_str, data_t * iv_str, | |||
|     TEST_ASSERT( mbedtls_xtea_crypt_cbc( &ctx, MBEDTLS_XTEA_ENCRYPT, src_str->len, iv_str->x, | ||||
|                                  src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       src_str->len, | ||||
|                                       hex_dst_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  | @ -73,7 +77,9 @@ void xtea_decrypt_cbc( data_t * key_str, data_t * iv_str, | |||
|     TEST_ASSERT( mbedtls_xtea_crypt_cbc( &ctx, MBEDTLS_XTEA_DECRYPT, src_str->len, iv_str->x, | ||||
|                                  src_str->x, output ) == 0 ); | ||||
| 
 | ||||
|     TEST_ASSERT( hexcmp( output, hex_dst_string->x, src_str->len, hex_dst_string->len ) == 0 ); | ||||
|     TEST_ASSERT( mbedtls_test_hexcmp( output, hex_dst_string->x, | ||||
|                                       src_str->len, | ||||
|                                       hex_dst_string->len ) == 0 ); | ||||
| } | ||||
| /* END_CASE */ | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue