Use arc4random_buf instead of rand on NetBSD

Avoid old implementation of rand returning numbers with cyclical lower bits. Allow tests to pass.

Signed-off-by: gufe44 <gu981@protonmail.com>
This commit is contained in:
gufe44 2020-08-03 17:56:50 +02:00
parent a586099fd3
commit 3fa7c64edf
2 changed files with 5 additions and 5 deletions

View file

@ -83,7 +83,7 @@
#include "mbedtls/md.h" #include "mbedtls/md.h"
#endif #endif
#if defined(MBEDTLS_PKCS1_V15) && !defined(__OpenBSD__) #if defined(MBEDTLS_PKCS1_V15) && !defined(__OpenBSD__) && !defined(__NetBSD__)
#include <stdlib.h> #include <stdlib.h>
#endif #endif
@ -2590,7 +2590,7 @@ void mbedtls_rsa_free( mbedtls_rsa_context *ctx )
#if defined(MBEDTLS_PKCS1_V15) #if defined(MBEDTLS_PKCS1_V15)
static int myrand( void *rng_state, unsigned char *output, size_t len ) static int myrand( void *rng_state, unsigned char *output, size_t len )
{ {
#if !defined(__OpenBSD__) #if !defined(__OpenBSD__) && !defined(__NetBSD__)
size_t i; size_t i;
if( rng_state != NULL ) if( rng_state != NULL )
@ -2603,7 +2603,7 @@ static int myrand( void *rng_state, unsigned char *output, size_t len )
rng_state = NULL; rng_state = NULL;
arc4random_buf( output, len ); arc4random_buf( output, len );
#endif /* !OpenBSD */ #endif /* !OpenBSD && !NetBSD */
return( 0 ); return( 0 );
} }

View file

@ -549,7 +549,7 @@ unsigned char *unhexify_alloc( const char *ibuf, size_t *olen )
*/ */
static int rnd_std_rand( void *rng_state, unsigned char *output, size_t len ) static int rnd_std_rand( void *rng_state, unsigned char *output, size_t len )
{ {
#if !defined(__OpenBSD__) #if !defined(__OpenBSD__) && !defined(__NetBSD__)
size_t i; size_t i;
if( rng_state != NULL ) if( rng_state != NULL )
@ -562,7 +562,7 @@ static int rnd_std_rand( void *rng_state, unsigned char *output, size_t len )
rng_state = NULL; rng_state = NULL;
arc4random_buf( output, len ); arc4random_buf( output, len );
#endif /* !OpenBSD */ #endif /* !OpenBSD && !NetBSD */
return( 0 ); return( 0 );
} }