/* * 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 tests * @{ * * @brief Tests the PSA cipher configurations * * @author Mikolai Gütschow * @author Lena Boeckmann * * @} */ #include #include "psa/crypto.h" #include "ztimer.h" extern psa_status_t example_cipher_aes_128(void); extern psa_status_t example_cipher_chacha20(void); int main(void) { bool failed = false; psa_status_t status; psa_crypto_init(); ztimer_acquire(ZTIMER_USEC); ztimer_now_t start = ztimer_now(ZTIMER_USEC); 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; printf("Cipher AES 128 failed: %s\n", psa_status_to_humanly_readable(status)); } start = ztimer_now(ZTIMER_USEC); status = example_cipher_chacha20(); printf("Cipher CHACHA20 took %d us\n", (int)(ztimer_now(ZTIMER_USEC) - start)); if (status != PSA_SUCCESS) { failed = true; printf("Cipher CHACHA20 failed: %s\n", psa_status_to_humanly_readable(status)); } ztimer_release(ZTIMER_USEC); if (failed) { puts("Tests failed..."); } else { puts("All Done"); } return 0; }