From 4e2c7b2b070699b9f0a9cfe75de8316866cc5ed1 Mon Sep 17 00:00:00 2001 From: Uros Majstorovic Date: Thu, 31 Mar 2022 13:17:48 +0200 Subject: random numbers for fe310 --- fw/esp32/components/eos/include/rng.h | 1 + fw/esp32/components/eos/rng.c | 31 +++++++++++++++++++++++++++++++ fw/fe310/eos/rng.c | 27 +++++++++++++++++++++++++++ fw/fe310/eos/rng.h | 5 +++++ 4 files changed, 64 insertions(+) create mode 100644 fw/esp32/components/eos/include/rng.h create mode 100644 fw/esp32/components/eos/rng.c create mode 100644 fw/fe310/eos/rng.c create mode 100644 fw/fe310/eos/rng.h (limited to 'fw') diff --git a/fw/esp32/components/eos/include/rng.h b/fw/esp32/components/eos/include/rng.h new file mode 100644 index 0000000..0690973 --- /dev/null +++ b/fw/esp32/components/eos/include/rng.h @@ -0,0 +1 @@ +void eos_rng_init(void); diff --git a/fw/esp32/components/eos/rng.c b/fw/esp32/components/eos/rng.c new file mode 100644 index 0000000..79eca21 --- /dev/null +++ b/fw/esp32/components/eos/rng.c @@ -0,0 +1,31 @@ +#include +#include +#include + +#include "net.h" +#include "rng.h" + +static const char *TAG = "EOS RNG"; + +static void rng_handler(unsigned char type, unsigned char *buffer, uint16_t buf_len) { + uint16_t rng_len = 0; + + if (buf_len < sizeof(uint16_t)) goto rng_handler_fin; + + rng_len = (uint16_t)buffer[0] << 8; + rng_len |= (uint16_t)buffer[1]; + if (rng_len > EOS_NET_MTU) { + rng_len = 0; + goto rng_handler_fin; + } + esp_fill_random(buffer, rng_len); + +rng_handler_fin: + eos_net_reply(EOS_NET_MTYPE_RNG, buffer, rng_len); +} + +void eos_rng_init(void) { + eos_net_set_handler(EOS_NET_MTYPE_RNG, rng_handler); + ESP_LOGI(TAG, "INIT"); +} + diff --git a/fw/fe310/eos/rng.c b/fw/fe310/eos/rng.c new file mode 100644 index 0000000..317941d --- /dev/null +++ b/fw/fe310/eos/rng.c @@ -0,0 +1,27 @@ +#include +#include +#include + +#include "net.h" + +int getentropy(unsigned char *b, size_t sz) { + unsigned char type; + unsigned char *buffer; + uint16_t len; + int rv; + + buffer = eos_net_alloc(); + + type = EOS_NET_MTYPE_RNG; + len = sizeof(uint16_t); + buffer[0] = sz >> 8; + buffer[1] = sz; + + rv = eos_net_xchg(&type, buffer, &len); + if (rv || (len != sz)) rv = -1; + + if (!rv) memcpy(b, buffer, sz); + eos_net_free(buffer, 1); + + return rv; +} diff --git a/fw/fe310/eos/rng.h b/fw/fe310/eos/rng.h new file mode 100644 index 0000000..27bbf74 --- /dev/null +++ b/fw/fe310/eos/rng.h @@ -0,0 +1,5 @@ +#include + +int getentropy(unsigned char *b, size_t sz); +int arc4random_alloc(void **rsp, size_t rsp_size, void **rsxp, size_t rsxp_size); +void arc4random_close(void **rsp, void **rsxp); \ No newline at end of file -- cgit v1.2.3