1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

sys/random: make sha1prng sha256 compatible

This commit is contained in:
PeterKietzmann 2020-07-09 11:46:12 +02:00
parent ad28752e4e
commit 5a13d00b65
3 changed files with 66 additions and 19 deletions

View File

@ -782,7 +782,8 @@ ifneq (,$(filter random,$(USEMODULE)))
USEMODULE += tinymt32 USEMODULE += tinymt32
endif endif
ifneq (,$(filter prng_sha1prng,$(USEMODULE))) ifneq (,$(filter prng_sha%prng,$(USEMODULE)))
USEMODULE += prng_shaxprng
USEMODULE += hashes USEMODULE += hashes
endif endif

View File

@ -14,7 +14,9 @@
* @{ * @{
* @file * @file
* *
* @brief SHA1PRNG random number generator implementation * @brief SHA based PRNG random number generator implementation
*
* BLABLA
* *
* @author Peter Kietzmann <peter.kietzmann@haw-hamburg.de> * @author Peter Kietzmann <peter.kietzmann@haw-hamburg.de>
* @} * @}
@ -24,10 +26,52 @@
#include <string.h> #include <string.h>
#include "hashes/sha1.h" #include "hashes/sha1.h"
#include "hashes/sha256.h"
#include "kernel_defines.h"
#define STATE_SIZE (SHA1_DIGEST_LENGTH) #if IS_USED(MODULE_PRNG_SHA1PRNG)
/* state size is digset length of SHA-1 */
#define STATE_SIZE (SHA1_DIGEST_LENGTH)
typedef sha1_context shax_context_t;
#elif IS_USED(MODULE_PRNG_SHA256PRNG)
/* state size is digest length of SHA-256 */
#define STATE_SIZE (SHA256_DIGEST_LENGTH)
typedef sha256_context_t shax_context_t;
#endif
static inline void _shax_init(shax_context_t *ctx)
{
if (IS_USED(MODULE_PRNG_SHA1PRNG)) {
sha1_init((sha1_context *)ctx);
}
else if (IS_USED(MODULE_PRNG_SHA256PRNG)) {
sha256_init((sha256_context_t *)ctx);
}
}
static inline void _shax_update(shax_context_t *ctx, const void *data, size_t len)
{
if (IS_USED(MODULE_PRNG_SHA1PRNG)) {
sha1_update((sha1_context *)ctx, data, len);
}
else if (IS_USED(MODULE_PRNG_SHA256PRNG)) {
sha256_update((sha256_context_t *)ctx, data, len);
}
}
static inline void _shax_final(shax_context_t *ctx, void *digest)
{
if (IS_USED(MODULE_PRNG_SHA1PRNG)) {
sha1_final((sha1_context *)ctx, digest);
}
else if (IS_USED(MODULE_PRNG_SHA256PRNG)) {
sha256_final((sha256_context_t *)ctx, digest);
}
}
/* allocate SHA context */
static shax_context_t ctx;
static sha1_context ctx;
static uint32_t datapos = STATE_SIZE; static uint32_t datapos = STATE_SIZE;
static int8_t digestdata[STATE_SIZE]; static int8_t digestdata[STATE_SIZE];
static int8_t prng_state[STATE_SIZE]; static int8_t prng_state[STATE_SIZE];
@ -62,7 +106,7 @@ void _updatestate(int8_t *state)
} }
} }
void _random_bytes(uint8_t *bytes, size_t size) /* TODO: use with global API */ void _random_bytes(uint8_t *bytes, size_t size)
{ {
uint32_t loc = 0; uint32_t loc = 0;
while (loc < size) while (loc < size)
@ -88,14 +132,14 @@ void _random_bytes(uint8_t *bytes, size_t size) /* TODO: use with global API */
/* no out data ready, (re)fill internal buffer */ /* no out data ready, (re)fill internal buffer */
else else
{ {
/* reset SHA1 internal state */ /* reset SHA internal state */
sha1_init(&ctx); _shax_init(&ctx);
/* update SHA1 internal state with PRNG state */ /* update SHA internal state with PRNG state */
sha1_update(&ctx, (void *)prng_state, sizeof(prng_state)); _shax_update(&ctx, prng_state, sizeof(prng_state));
/* get the digest */ /* get the digest */
sha1_final(&ctx, digestdata); _shax_final(&ctx, digestdata);
/* update PRNG state for next round */ /* update PRNG state for next round */
_updatestate(prng_state); _updatestate(prng_state);
@ -108,9 +152,9 @@ void _random_bytes(uint8_t *bytes, size_t size) /* TODO: use with global API */
void random_init_by_array(uint32_t init_key[], int key_length) void random_init_by_array(uint32_t init_key[], int key_length)
{ {
sha1_init(&ctx); _shax_init(&ctx);
sha1_update(&ctx, (void *)init_key, key_length); _shax_update(&ctx, init_key, key_length);
sha1_final(&ctx, digestdata); _shax_final(&ctx, digestdata);
/* copy seeded SHA1 state to PRNG state */ /* copy seeded SHA1 state to PRNG state */
memcpy(prng_state, &ctx.state, STATE_SIZE); memcpy(prng_state, &ctx.state, STATE_SIZE);
@ -124,13 +168,13 @@ void random_init(uint32_t seed)
uint32_t random_uint32(void) uint32_t random_uint32(void)
{ {
uint32_t ret; uint32_t ret;
int8_t bytes[sizeof(uint32_t)]; uint8_t bytes[sizeof(uint32_t)];
_random_bytes((uint8_t *)bytes, sizeof(uint32_t)); _random_bytes(bytes, sizeof(bytes));
ret = ((bytes[0] & 0xff) << 24) ret = ((uint32_t)(bytes[0] & 0xff) << 24)
| ((bytes[1] & 0xff) << 16) | ((uint32_t)(bytes[1] & 0xff) << 16)
| ((bytes[2] & 0xff) << 8) | ((uint32_t)(bytes[2] & 0xff) << 8)
| (bytes[3] & 0xff); | ((uint32_t)(bytes[3] & 0xff));
return ret; return ret;
} }

View File

@ -61,6 +61,8 @@ static void test_init(char *name)
puts("Musl C PRNG.\n"); puts("Musl C PRNG.\n");
#elif MODULE_PRNG_SHA1PRNG #elif MODULE_PRNG_SHA1PRNG
puts("SHA1 PRNG.\n"); puts("SHA1 PRNG.\n");
#elif MODULE_PRNG_SHA256PRNG
puts("SHA256 PRNG.\n");
#elif MODULE_PRNG_TINYMT32 #elif MODULE_PRNG_TINYMT32
puts("Tiny Mersenne Twister PRNG.\n"); puts("Tiny Mersenne Twister PRNG.\n");
#elif MODULE_PRNG_XORSHIFT #elif MODULE_PRNG_XORSHIFT