185 lines
4.6 KiB
C
185 lines
4.6 KiB
C
|
/* main.c
|
|||
|
*
|
|||
|
* Copyright (C) 2020 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;
|
|||
|
}
|