2022-09-07 16:23:54 +05:30
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Unlicense OR CC0-1.0
|
|
|
|
*/
|
2016-11-25 19:15:39 +11:00
|
|
|
/* mbedTLS self-tests as unit tests
|
2016-11-17 16:36:10 +08:00
|
|
|
|
|
|
|
Focus on testing functionality where we use ESP32 hardware
|
|
|
|
accelerated crypto features.
|
|
|
|
|
2016-11-25 19:15:39 +11:00
|
|
|
See also test_hwcrypto.c in esp32 component, which tests hardware crypto without mbedTLS.
|
2016-11-17 16:36:10 +08:00
|
|
|
*/
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
2016-11-25 19:15:39 +11:00
|
|
|
#include <stdbool.h>
|
|
|
|
#include <esp_system.h>
|
2016-11-17 16:36:10 +08:00
|
|
|
#include "mbedtls/sha1.h"
|
|
|
|
#include "mbedtls/sha256.h"
|
|
|
|
#include "mbedtls/sha512.h"
|
|
|
|
#include "mbedtls/aes.h"
|
|
|
|
#include "mbedtls/bignum.h"
|
2016-11-25 19:15:39 +11:00
|
|
|
#include "mbedtls/rsa.h"
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/task.h"
|
|
|
|
#include "freertos/semphr.h"
|
2016-11-17 16:36:10 +08:00
|
|
|
#include "unity.h"
|
2016-11-25 19:15:39 +11:00
|
|
|
#include "sdkconfig.h"
|
2017-08-15 16:45:40 +10:00
|
|
|
#include "test_apb_dport_access.h"
|
2022-05-20 18:16:47 +08:00
|
|
|
#include "test_utils.h"
|
2016-11-17 16:36:10 +08:00
|
|
|
|
|
|
|
TEST_CASE("mbedtls AES self-tests", "[aes]")
|
|
|
|
{
|
2017-08-15 16:45:40 +10:00
|
|
|
start_apb_access_loop();
|
2016-11-17 16:36:10 +08:00
|
|
|
TEST_ASSERT_FALSE_MESSAGE(mbedtls_aes_self_test(1), "AES self-tests should pass.");
|
2017-08-15 16:45:40 +10:00
|
|
|
verify_apb_access_loop();
|
2016-11-17 16:36:10 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("mbedtls MPI self-tests", "[bignum]")
|
|
|
|
{
|
2017-08-15 16:45:40 +10:00
|
|
|
start_apb_access_loop();
|
2016-11-17 16:36:10 +08:00
|
|
|
TEST_ASSERT_FALSE_MESSAGE(mbedtls_mpi_self_test(1), "MPI self-tests should pass.");
|
2017-08-15 16:45:40 +10:00
|
|
|
verify_apb_access_loop();
|
2016-11-17 16:36:10 +08:00
|
|
|
}
|
|
|
|
|
2016-11-25 19:15:39 +11:00
|
|
|
TEST_CASE("mbedtls RSA self-tests", "[bignum]")
|
2016-11-17 16:36:10 +08:00
|
|
|
{
|
2017-08-15 16:45:40 +10:00
|
|
|
start_apb_access_loop();
|
2016-11-25 19:15:39 +11:00
|
|
|
TEST_ASSERT_FALSE_MESSAGE(mbedtls_rsa_self_test(1), "RSA self-tests should pass.");
|
2017-08-15 16:45:40 +10:00
|
|
|
verify_apb_access_loop();
|
2016-11-17 16:36:10 +08:00
|
|
|
}
|