mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2025-01-09 22:55:27 +00:00
Use HMAC_DRBG by default for ECP internal DRBG
It results in smaller code than using CTR_DRBG (64 bytes smaller on ARMv6-M with arm-none-eabi-gcc 7.3.1), so let's use this by default when both are available. Signed-off-by: Manuel Pégourié-Gonnard <manuel.pegourie-gonnard@arm.com>
This commit is contained in:
parent
c334f41bf9
commit
c7295f5416
|
@ -105,10 +105,10 @@
|
||||||
#include "mbedtls/ecp_internal.h"
|
#include "mbedtls/ecp_internal.h"
|
||||||
|
|
||||||
#if !defined(MBEDTLS_ECP_NO_INTERNAL_RNG)
|
#if !defined(MBEDTLS_ECP_NO_INTERNAL_RNG)
|
||||||
#if defined(MBEDTLS_CTR_DRBG_C)
|
#if defined(MBEDTLS_HMAC_DRBG_C)
|
||||||
#include "mbedtls/ctr_drbg.h"
|
|
||||||
#elif defined(MBEDTLS_HMAC_DRBG_C)
|
|
||||||
#include "mbedtls/hmac_drbg.h"
|
#include "mbedtls/hmac_drbg.h"
|
||||||
|
#elif defined(MBEDTLS_CTR_DRBG_C)
|
||||||
|
#include "mbedtls/ctr_drbg.h"
|
||||||
#else
|
#else
|
||||||
#error "Invalid configuration detected. Include check_config.h to ensure that the configuration is valid."
|
#error "Invalid configuration detected. Include check_config.h to ensure that the configuration is valid."
|
||||||
#endif
|
#endif
|
||||||
|
@ -143,10 +143,48 @@ static unsigned long add_count, dbl_count, mul_count;
|
||||||
* have our own internal DRBG instance, seeded from the secret scalar.
|
* have our own internal DRBG instance, seeded from the secret scalar.
|
||||||
*
|
*
|
||||||
* The following is a light-weight abstraction layer for doing that with
|
* The following is a light-weight abstraction layer for doing that with
|
||||||
* CTR_DRBG or HMAC_DRBG.
|
* HMAC_DRBG (first choice) or CTR_DRBG.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if defined(MBEDTLS_CTR_DRBG_C)
|
#if defined(MBEDTLS_HMAC_DRBG_C)
|
||||||
|
|
||||||
|
/* DRBG context type */
|
||||||
|
typedef mbedtls_hmac_drbg_context ecp_drbg_context;
|
||||||
|
|
||||||
|
/* DRBG context init */
|
||||||
|
static inline void ecp_drbg_init( ecp_drbg_context *ctx )
|
||||||
|
{
|
||||||
|
mbedtls_hmac_drbg_init( ctx );
|
||||||
|
}
|
||||||
|
|
||||||
|
/* DRBG context free */
|
||||||
|
static inline void ecp_drbg_free( ecp_drbg_context *ctx )
|
||||||
|
{
|
||||||
|
mbedtls_hmac_drbg_free( ctx );
|
||||||
|
}
|
||||||
|
|
||||||
|
/* DRBG function */
|
||||||
|
static inline int ecp_drbg_random( void *p_rng,
|
||||||
|
unsigned char *output, size_t output_len )
|
||||||
|
{
|
||||||
|
return( mbedtls_hmac_drbg_random( p_rng, output, output_len ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
/* DRBG context seeding */
|
||||||
|
static int ecp_drbg_seed( ecp_drbg_context *ctx, const mbedtls_mpi *secret )
|
||||||
|
{
|
||||||
|
const unsigned char *secret_p = (const unsigned char *) secret->p;
|
||||||
|
const size_t secret_size = secret->n * sizeof( mbedtls_mpi_uint );
|
||||||
|
|
||||||
|
/* The list starts with strong hashes */
|
||||||
|
const mbedtls_md_type_t md_type = mbedtls_md_list()[0];
|
||||||
|
const mbedtls_md_info_t *md_info = mbedtls_md_info_from_type( md_type );
|
||||||
|
|
||||||
|
return( mbedtls_hmac_drbg_seed_buf( ctx, md_info, secret_p, secret_size ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif defined(MBEDTLS_CTR_DRBG_C)
|
||||||
|
|
||||||
/* DRBG context type */
|
/* DRBG context type */
|
||||||
typedef mbedtls_ctr_drbg_context ecp_drbg_context;
|
typedef mbedtls_ctr_drbg_context ecp_drbg_context;
|
||||||
|
|
||||||
|
@ -193,42 +231,6 @@ static int ecp_drbg_seed( ecp_drbg_context *ctx, const mbedtls_mpi *secret )
|
||||||
secret_p, secret_size ) );
|
secret_p, secret_size ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif defined(MBEDTLS_HMAC_DRBG_C)
|
|
||||||
/* DRBG context type */
|
|
||||||
typedef mbedtls_hmac_drbg_context ecp_drbg_context;
|
|
||||||
|
|
||||||
/* DRBG context init */
|
|
||||||
static inline void ecp_drbg_init( ecp_drbg_context *ctx )
|
|
||||||
{
|
|
||||||
mbedtls_hmac_drbg_init( ctx );
|
|
||||||
}
|
|
||||||
|
|
||||||
/* DRBG context free */
|
|
||||||
static inline void ecp_drbg_free( ecp_drbg_context *ctx )
|
|
||||||
{
|
|
||||||
mbedtls_hmac_drbg_free( ctx );
|
|
||||||
}
|
|
||||||
|
|
||||||
/* DRBG function */
|
|
||||||
static inline int ecp_drbg_random( void *p_rng,
|
|
||||||
unsigned char *output, size_t output_len )
|
|
||||||
{
|
|
||||||
return( mbedtls_hmac_drbg_random( p_rng, output, output_len ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
/* DRBG context seeding */
|
|
||||||
static int ecp_drbg_seed( ecp_drbg_context *ctx, const mbedtls_mpi *secret )
|
|
||||||
{
|
|
||||||
const unsigned char *secret_p = (const unsigned char *) secret->p;
|
|
||||||
const size_t secret_size = secret->n * sizeof( mbedtls_mpi_uint );
|
|
||||||
|
|
||||||
/* The list starts with strong hashes */
|
|
||||||
const mbedtls_md_type_t md_type = mbedtls_md_list()[0];
|
|
||||||
const mbedtls_md_info_t *md_info = mbedtls_md_info_from_type( md_type );
|
|
||||||
|
|
||||||
return( mbedtls_hmac_drbg_seed_buf( ctx, md_info, secret_p, secret_size ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
#error "Invalid configuration detected. Include check_config.h to ensure that the configuration is valid."
|
#error "Invalid configuration detected. Include check_config.h to ensure that the configuration is valid."
|
||||||
#endif /* DRBG modules */
|
#endif /* DRBG modules */
|
||||||
|
|
Loading…
Reference in a new issue