2020-06-19 17:17:50 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2020 HAW Hamburg
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup tests
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Test the correct loading and linking of the mbedtls package and
|
|
|
|
execute built-in selftests.
|
|
|
|
*
|
|
|
|
* @author Peter Kietzmann <peter.kietzmann@haw-hamburg.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#include "mbedtls/sha256.h"
|
|
|
|
#include "mbedtls/entropy.h"
|
|
|
|
|
|
|
|
#include "entropy_mbedtls_riot.h"
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
puts("mbedtls test\n");
|
|
|
|
|
2022-02-02 16:55:23 +01:00
|
|
|
/* Execute built-in tests SHA-2xx tests */
|
2020-06-19 17:17:50 +02:00
|
|
|
mbedtls_sha256_self_test(1);
|
2022-02-02 16:55:23 +01:00
|
|
|
|
|
|
|
bool adc_noise_single_entropy = false;
|
|
|
|
/* NOTE, the following express needs adjustment when further entropy
|
|
|
|
sources added by RIOT */
|
|
|
|
#if IS_USED(MODULE_MBEDTLS_ENTROPY_SOURCE_ADC) && !IS_USED(MODULE_MBEDTLS_ENTROPY_SOURCE_HWRNG)
|
|
|
|
/* If the adc noise entropy source is compiled and is the only source
|
|
|
|
utilized with the mbedtls entropy module, indicate it */
|
|
|
|
adc_noise_single_entropy = true;
|
|
|
|
#endif
|
|
|
|
/* Used by the testrunner to ignore potential test failures it the case of
|
|
|
|
a single adc noise entropy source */
|
|
|
|
printf("adc_noise_single_entropy: %d\n", adc_noise_single_entropy);
|
|
|
|
|
|
|
|
/* Initializes available entropy sources */
|
|
|
|
entropy_mbedtls_riot_init();
|
|
|
|
|
|
|
|
/* Execute mbedtls built-in entropy tests*/
|
2020-06-19 17:17:50 +02:00
|
|
|
mbedtls_entropy_self_test(1);
|
|
|
|
|
2022-02-02 16:55:23 +01:00
|
|
|
/* Execute convenience entropy functions */
|
2020-06-19 17:17:50 +02:00
|
|
|
unsigned char out[4];
|
2022-02-02 16:55:23 +01:00
|
|
|
/* This function requires entropy_mbedtls_riot_init() beforehand */
|
2020-06-19 17:17:50 +02:00
|
|
|
entropy_mbedtls_riot_retrieve(out, sizeof(out));
|
2022-02-02 16:55:23 +01:00
|
|
|
/* Clears the internal context again */
|
2020-06-19 17:17:50 +02:00
|
|
|
entropy_mbedtls_riot_uninit();
|
|
|
|
|
2022-02-02 16:55:23 +01:00
|
|
|
/* This function does not require initialization */
|
2020-06-19 17:17:50 +02:00
|
|
|
entropy_mbedtls_riot_get(out, sizeof(out));
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|