mirror of
https://github.com/polhenarejos/pico-keys-sdk
synced 2026-06-10 11:59:05 +02:00
Adding functions for calling random in core0.
Signed-off-by: Pol Henarejos <pol.henarejos@cttc.es>
This commit is contained in:
@@ -176,6 +176,17 @@ void neug_wait_full(void) { //should be called only on core1
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void neug_wait_full_ext(bool blocking) {
|
||||||
|
struct rng_rb *rb = &the_ring_buffer;
|
||||||
|
|
||||||
|
while (!rb->full) {
|
||||||
|
if (blocking == true)
|
||||||
|
sleep_ms(1);
|
||||||
|
else
|
||||||
|
neug_task();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void neug_fini(void) {
|
void neug_fini(void) {
|
||||||
neug_get();
|
neug_get();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -20,10 +20,14 @@
|
|||||||
|
|
||||||
#define NEUG_PRE_LOOP 32
|
#define NEUG_PRE_LOOP 32
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include "pico/stdlib.h"
|
||||||
|
|
||||||
void neug_init(uint32_t *buf, uint8_t size);
|
void neug_init(uint32_t *buf, uint8_t size);
|
||||||
uint32_t neug_get();
|
uint32_t neug_get();
|
||||||
void neug_flush(void);
|
void neug_flush(void);
|
||||||
void neug_wait_full(void);
|
void neug_wait_full(void);
|
||||||
|
void neug_wait_full_ext(bool);
|
||||||
void neug_fini(void);
|
void neug_fini(void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
@@ -79,13 +79,13 @@ void random_get_salt(uint8_t *p) {
|
|||||||
/*
|
/*
|
||||||
* Random byte iterator
|
* Random byte iterator
|
||||||
*/
|
*/
|
||||||
int random_gen(void *arg, unsigned char *out, size_t out_len) {
|
int random_gen_ext(void *arg, unsigned char *out, size_t out_len, bool blocking) {
|
||||||
uint8_t *index_p = (uint8_t *)arg;
|
uint8_t *index_p = (uint8_t *)arg;
|
||||||
uint8_t index = index_p ? *index_p : 0;
|
uint8_t index = index_p ? *index_p : 0;
|
||||||
size_t n;
|
size_t n;
|
||||||
|
|
||||||
while (out_len) {
|
while (out_len) {
|
||||||
neug_wait_full();
|
neug_wait_full_ext(blocking);
|
||||||
|
|
||||||
n = RANDOM_BYTES_LENGTH - index;
|
n = RANDOM_BYTES_LENGTH - index;
|
||||||
if (n > out_len)
|
if (n > out_len)
|
||||||
@@ -107,3 +107,11 @@ int random_gen(void *arg, unsigned char *out, size_t out_len) {
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int random_gen(void *arg, unsigned char *out, size_t out_len) {
|
||||||
|
return random_gen_ext(arg, out, out_len, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
int random_gen_core0(void *arg, unsigned char *out, size_t out_len) {
|
||||||
|
return random_gen_ext(arg, out, out_len, false);
|
||||||
|
}
|
||||||
|
|||||||
@@ -34,5 +34,6 @@ void random_get_salt (uint8_t *p);
|
|||||||
|
|
||||||
/* iterator returning a byta at a time */
|
/* iterator returning a byta at a time */
|
||||||
extern int random_gen (void *arg, unsigned char *output, size_t output_len);
|
extern int random_gen (void *arg, unsigned char *output, size_t output_len);
|
||||||
|
extern int random_gen_core0(void *arg, unsigned char *out, size_t out_len);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
Reference in New Issue
Block a user