1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 23:12:45 +01:00
RIOT/examples/psa_crypto/main.c

157 lines
4.5 KiB
C
Raw Normal View History

2023-08-29 19:27:27 +02:00
/*
* Copyright (C) 2022 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 examples
* @{
*
* @brief Example application for PSA Crypto
*
* @author Lena Boeckmann <lena.boeckmann@haw-hamburg.de>
*
* @}
*/
#include <stdio.h>
#include "psa/crypto.h"
#include "ztimer.h"
#if IS_USED(MODULE_PSA_CIPHER)
2023-08-29 19:27:27 +02:00
extern psa_status_t example_cipher_aes_128(void);
#endif
#if IS_USED(MODULE_PSA_MAC)
2023-08-29 19:27:27 +02:00
extern psa_status_t example_hmac_sha256(void);
#endif
#if IS_USED(MODULE_PSA_ASYMMETRIC_ECC_P256R1) || \
IS_USED(MODULE_PSA_SECURE_ELEMENT_ATECCX08A_ECC_P256)
2023-08-29 19:27:27 +02:00
extern psa_status_t example_ecdsa_p256(void);
#endif
#if IS_USED(MODULE_PSA_ASYMMETRIC_ECC_ED25519)
#ifndef SECURE_ELEMENT
extern psa_status_t example_eddsa(void);
#endif
#endif
2023-08-29 19:27:27 +02:00
2024-01-02 13:53:54 +01:00
extern psa_status_t example_hash(void);
2023-08-29 19:27:27 +02:00
#ifdef MULTIPLE_SE
#if IS_USED(MODULE_PSA_CIPHER)
2023-08-29 19:27:27 +02:00
extern psa_status_t example_cipher_aes_128_sec_se(void);
#endif /* MODULE_PSA_CIPHER */
#if IS_USED(MODULE_PSA_MAC)
2023-08-29 19:27:27 +02:00
extern psa_status_t example_hmac_sha256_sec_se(void);
#endif /* MODULE_PSA_MAC */
#if IS_USED(MODULE_PSA_SECURE_ELEMENT_ATECCX08A_ECC_P256)
2023-08-29 19:27:27 +02:00
extern psa_status_t example_ecdsa_p256_sec_se(void);
#endif /* MODULE_PSA_ASYMMETRIC_ECC_P256R1 */
#endif /* MULTIPLE_SE */
2023-08-29 19:27:27 +02:00
int main(void)
{
bool failed = false;
2023-08-29 19:27:27 +02:00
psa_status_t status;
psa_crypto_init();
ztimer_acquire(ZTIMER_USEC);
ztimer_now_t start = ztimer_now(ZTIMER_USEC);
/* Needed in case only hashes are tested */
(void)status;
(void)start;
2024-01-02 13:53:54 +01:00
status = example_hash();
printf("Hash took %d us\n", (int)(ztimer_now(ZTIMER_USEC) - start));
if (status != PSA_SUCCESS) {
failed = true;
printf("Hash failed: %s\n", psa_status_to_humanly_readable(status));
}
#if IS_USED(MODULE_PSA_MAC)
2023-08-29 19:27:27 +02:00
status = example_hmac_sha256();
printf("HMAC SHA256 took %d us\n", (int)(ztimer_now(ZTIMER_USEC) - start));
if (status != PSA_SUCCESS) {
failed = true;
2023-08-29 19:27:27 +02:00
printf("HMAC SHA256 failed: %s\n", psa_status_to_humanly_readable(status));
}
#endif
2023-08-29 19:27:27 +02:00
#if IS_USED(MODULE_PSA_CIPHER)
2023-08-29 19:27:27 +02:00
start = ztimer_now(ZTIMER_USEC);
status = example_cipher_aes_128();
printf("Cipher AES 128 took %d us\n", (int)(ztimer_now(ZTIMER_USEC) - start));
if (status != PSA_SUCCESS) {
failed = true;
2023-08-29 19:27:27 +02:00
printf("Cipher AES 128 failed: %s\n", psa_status_to_humanly_readable(status));
}
#endif
2023-08-29 19:27:27 +02:00
#if IS_USED(MODULE_PSA_ASYMMETRIC_ECC_P256R1) || \
IS_USED(MODULE_PSA_SECURE_ELEMENT_ATECCX08A_ECC_P256)
2023-08-29 19:27:27 +02:00
start = ztimer_now(ZTIMER_USEC);
status = example_ecdsa_p256();
printf("ECDSA took %d us\n", (int)(ztimer_now(ZTIMER_USEC) - start));
if (status != PSA_SUCCESS) {
failed = true;
2023-08-29 19:27:27 +02:00
printf("ECDSA failed: %s\n", psa_status_to_humanly_readable(status));
}
#endif
#if IS_USED(MODULE_PSA_ASYMMETRIC_ECC_ED25519)
start = ztimer_now(ZTIMER_USEC);
status = example_eddsa();
printf("EdDSA took %d us\n", (int)(ztimer_now(ZTIMER_USEC) - start));
if (status != PSA_SUCCESS) {
failed = true;
printf("EdDSA failed: %s\n", psa_status_to_humanly_readable(status));
2023-08-29 19:27:27 +02:00
}
#endif
2023-08-29 19:27:27 +02:00
#ifdef MULTIPLE_SE
#if IS_USED(MODULE_PSA_MAC)
2023-08-29 19:27:27 +02:00
puts("Running Examples with secondary SE:");
status = example_hmac_sha256_sec_se();
printf("HMAC SHA256 took %d us\n", (int)(ztimer_now(ZTIMER_USEC) - start));
if (status != PSA_SUCCESS) {
failed = true;
2023-08-29 19:27:27 +02:00
printf("HMAC SHA256 failed: %s\n", psa_status_to_humanly_readable(status));
}
#endif /* MODULE_PSA_MAC */
2023-08-29 19:27:27 +02:00
#if IS_USED(MODULE_PSA_CIPHER)
2023-08-29 19:27:27 +02:00
start = ztimer_now(ZTIMER_USEC);
status = example_cipher_aes_128_sec_se();
printf("Cipher AES 128 took %d us\n", (int)(ztimer_now(ZTIMER_USEC) - start));
if (status != PSA_SUCCESS) {
failed = true;
2023-08-29 19:27:27 +02:00
printf("Cipher AES 128 failed: %s\n", psa_status_to_humanly_readable(status));
}
#endif /* MODULE_PSA_CIPHER */
2023-08-29 19:27:27 +02:00
#if IS_USED(MODULE_PSA_SECURE_ELEMENT_ATECCX08A_ECC_P256)
2023-08-29 19:27:27 +02:00
start = ztimer_now(ZTIMER_USEC);
status = example_ecdsa_p256_sec_se();
printf("ECDSA took %d us\n", (int)(ztimer_now(ZTIMER_USEC) - start));
if (status != PSA_SUCCESS) {
failed = true;
2023-08-29 19:27:27 +02:00
printf("ECDSA failed: %s\n", psa_status_to_humanly_readable(status));
}
#endif /* MODULE_PSA_SECURE_ELEMENT_ATECCX08A_ECC_P256 */
#endif /* MULTIPLE_SE */
2023-08-29 19:27:27 +02:00
ztimer_release(ZTIMER_USEC);
if (failed) {
puts("Tests failed...");
}
else {
puts("All Done");
}
2023-08-29 19:27:27 +02:00
return 0;
}