123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 |
- /* main.c
- *
- * Copyright (C) 2006-2024 wolfSSL Inc.
- *
- * This file is part of wolfSSL.
- *
- * wolfSSL is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * wolfSSL is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA
- */
- #include <wolfssl/wolfcrypt/settings.h>
- #include <wolfcrypt/test/test.h>
- #include <wolfcrypt/benchmark/benchmark.h>
- /* wolfCrypt_Init/wolfCrypt_Cleanup */
- #include <wolfssl/wolfcrypt/wc_port.h>
- #include <stdio.h>
- #include <stdlib.h>
- #include <stdint.h>
- #ifndef __METAL_MACHINE_HEADER
- #define __METAL_MACHINE_HEADER "../../../../bsp/sifive-hifive1-revb/metal.h"
- #endif
- #include <metal/machine.h>
- #ifndef NO_CRYPT_BENCHMARK
- /*-specs=nano.specs doesn't include support for floating point in printf()*/
- asm (".global _printf_float");
- #ifndef RTC_FREQ
- #define RTC_FREQ 32768UL
- #endif
- /* CLINT Registers (Core Local Interruptor) for time */
- #define CLINT_BASE 0x02000000UL
- #define CLINT_REG_MTIME (*((volatile uint32_t *)(CLINT_BASE + 0xBFF8)))
- #define WOLFSSL_SIFIVE_RISC_V_DEBUG 0
- double current_time(int reset)
- {
- double now = CLINT_REG_MTIME;
- (void)reset;
- return now/RTC_FREQ;
- }
- #endif /* !NO_CRYPT_BENCHMARK */
- #if WOLFSSL_SIFIVE_RISC_V_DEBUG
- void check(int depth) {
- char ch;
- char *ptr = malloc(1);
- printf("stack at %p, heap at %p\n", &ch, ptr);
- if (depth <= 0)
- return;
- check(depth-1);
- free(ptr);
- }
- void mtime_sleep(uint32_t ticks) {
- uint32_t start = CLINT_REG_MTIME;
- while((CLINT_REG_MTIME - start) < ticks) {
- }
- }
- void delay(uint32_t sec) {
- uint32_t ticks = sec * RTC_FREQ;
- mtime_sleep(ticks);
- }
- #endif /* WOLFSSL_SIFIVE_RISC_V_DEBUG */
- /* RNG CODE */
- /* TODO: Implement real RNG */
- static unsigned int gCounter;
- unsigned int hw_rand(void)
- {
- /* #warning Must implement your own random source */
- return ++gCounter;
- }
- unsigned int my_rng_seed_gen(void)
- {
- return hw_rand();
- }
- int my_rng_gen_block(unsigned char* output, unsigned int sz)
- {
- uint32_t i = 0;
- uint32_t randReturnSize = sizeof(CUSTOM_RAND_TYPE);
- while (i < sz)
- {
- /* If not aligned or there is odd/remainder */
- if((i + randReturnSize) > sz ||
- ((uint32_t)&output[i] % randReturnSize) != 0 ) {
- /* Single byte at a time */
- output[i++] = (unsigned char)my_rng_seed_gen();
- }
- else {
- /* Use native 8, 16, 32 or 64 copy instruction */
- *((CUSTOM_RAND_TYPE*)&output[i]) = my_rng_seed_gen();
- i += randReturnSize;
- }
- }
- return 0;
- }
- #if !defined(NO_CLOCK_SPEEDUP) && !defined(USE_CLOCK_HZ)
- /* 320MHz */
- #define USE_CLOCK_HZ 320000000UL
- #endif
- int main(void)
- {
- int ret;
- long clk_Hz = 16000000; /* default */
- #if WOLFSSL_SIFIVE_RISC_V_DEBUG
- printf("check stack and heap addresses\n");
- check(8);
- printf("sleep for 10 seconds to verify timer, measure using a stopwatch\n");
- delay(10);
- printf("awake after sleeping for 10 seconds\n");
- #endif
- #ifdef USE_CLOCK_HZ
- /* Speed up clock */
- printf("SiFive HiFive1 Demo\n");
- printf("Setting clock to %dMHz\n", (int)(USE_CLOCK_HZ/1000000));
- clk_Hz = metal_clock_set_rate_hz(
- &__METAL_DT_SIFIVE_FE310_G000_PLL_HANDLE->clock, USE_CLOCK_HZ
- );
- #endif
- printf("Actual Clock %dMHz\n", (int)(clk_Hz/1000000));
- /* Reconfigure the SPI Bus for dual mode */
- #define QSPI0_CTRL 0x10014000UL
- #define FESPI_REG_FFMT (*((volatile uint32_t *)(QSPI0_CTRL + 0x64)))
- FESPI_REG_FFMT = 0xbb1447;
- #ifdef DEBUG_WOLFSSL
- wolfSSL_Debugging_ON();
- #endif
- if ((ret = wolfCrypt_Init()) != 0) {
- printf("wolfCrypt_Init failed %d\n", ret);
- return -1;
- }
- #ifndef NO_CRYPT_TEST
- printf("\nwolfCrypt Test Started\n");
- wolfcrypt_test(NULL);
- printf("\nwolfCrypt Test Completed\n");
- #endif
- #ifndef NO_CRYPT_BENCHMARK
- printf("\nBenchmark Test Started\n");
- benchmark_test(NULL);
- printf("\nBenchmark Test Completed\n");
- #endif
- if ((ret = wolfCrypt_Cleanup()) != 0) {
- printf("wolfCrypt_Cleanup failed %d\n", ret);
- return -1;
- }
- return 0;
- }
|