File hmac_drbg.h

The HMAC_DRBG pseudorandom generator.

This module implements the HMAC_DRBG pseudorandom generator described in NIST SP 800-90A: Recommendation for Random Number Generation Using Deterministic Random Bit Generators.

SECTION: Module settings

The configuration options you can set for this module are in this section. Either change them in mbedtls_config.h or define them on the compiler command line.

MBEDTLS_HMAC_DRBG_RESEED_INTERVAL

Interval before reseed is performed by default

MBEDTLS_HMAC_DRBG_MAX_INPUT

Maximum number of additional input bytes

MBEDTLS_HMAC_DRBG_MAX_REQUEST

Maximum number of requested bytes per call

MBEDTLS_HMAC_DRBG_MAX_SEED_INPUT

Maximum size of (re)seed buffer

Defines

MBEDTLS_ERR_HMAC_DRBG_REQUEST_TOO_BIG

Too many random requested in single call.

MBEDTLS_ERR_HMAC_DRBG_INPUT_TOO_BIG

Input too large (Entropy + additional).

MBEDTLS_ERR_HMAC_DRBG_FILE_IO_ERROR

Read/write error in file.

MBEDTLS_ERR_HMAC_DRBG_ENTROPY_SOURCE_FAILED

The entropy source failed.

MBEDTLS_HMAC_DRBG_PR_OFF

No prediction resistance

MBEDTLS_HMAC_DRBG_PR_ON

Prediction resistance enabled

Typedefs

typedef struct mbedtls_hmac_drbg_context mbedtls_hmac_drbg_context

HMAC_DRBG context.

Functions

void mbedtls_hmac_drbg_init(mbedtls_hmac_drbg_context *ctx)

HMAC_DRBG context initialization.

This function makes the context ready for mbedtls_hmac_drbg_seed(), mbedtls_hmac_drbg_seed_buf() or mbedtls_hmac_drbg_free().

Note

The reseed interval is MBEDTLS_HMAC_DRBG_RESEED_INTERVAL by default. Override this value by calling mbedtls_hmac_drbg_set_reseed_interval().

Parameters

ctx – HMAC_DRBG context to be initialized.

int mbedtls_hmac_drbg_seed(mbedtls_hmac_drbg_context *ctx, const mbedtls_md_info_t *md_info, int (*f_entropy)(void*, unsigned char*, size_t), void *p_entropy, const unsigned char *custom, size_t len)

HMAC_DRBG initial seeding.

Set the initial seed and set up the entropy source for future reseeds.

A typical choice for the f_entropy and p_entropy parameters is to use the entropy module:

You can provide a personalization string in addition to the entropy source, to make this instantiation as unique as possible.

Note

By default, the security strength as defined by NIST is:

  • 128 bits if md_info is SHA-1;

  • 192 bits if md_info is SHA-224;

  • 256 bits if md_info is SHA-256, SHA-384 or SHA-512. Note that SHA-256 is just as efficient as SHA-224. The security strength can be reduced if a smaller entropy length is set with mbedtls_hmac_drbg_set_entropy_len().

Note

The default entropy length is the security strength (converted from bits to bytes). You can override it by calling mbedtls_hmac_drbg_set_entropy_len().

Note

During the initial seeding, this function calls the entropy source to obtain a nonce whose length is half the entropy length.

Note

When Mbed TLS is built with threading support, after this function returns successfully, it is safe to call mbedtls_hmac_drbg_random() from multiple threads. Other operations, including reseeding, are not thread-safe.

Parameters
  • ctx – HMAC_DRBG context to be seeded.

  • md_info – MD algorithm to use for HMAC_DRBG.

  • f_entropy – The entropy callback, taking as arguments the p_entropy context, the buffer to fill, and the length of the buffer. f_entropy is always called with a length that is less than or equal to the entropy length.

  • p_entropy – The entropy context to pass to f_entropy.

  • custom – The personalization string. This can be NULL, in which case the personalization string is empty regardless of the value of len.

  • len – The length of the personalization string. This must be at most MBEDTLS_HMAC_DRBG_MAX_INPUT and also at most MBEDTLS_HMAC_DRBG_MAX_SEED_INPUT - entropy_len * 3 / 2 where entropy_len is the entropy length described above.

Returns

0 if successful.

Returns

MBEDTLS_ERR_MD_BAD_INPUT_DATA if md_info is invalid.

Returns

MBEDTLS_ERR_MD_ALLOC_FAILED if there was not enough memory to allocate context data.

Returns

MBEDTLS_ERR_HMAC_DRBG_ENTROPY_SOURCE_FAILED if the call to f_entropy failed.

int mbedtls_hmac_drbg_seed_buf(mbedtls_hmac_drbg_context *ctx, const mbedtls_md_info_t *md_info, const unsigned char *data, size_t data_len)

Initialisation of simplified HMAC_DRBG (never reseeds).

This function is meant for use in algorithms that need a pseudorandom input such as deterministic ECDSA.

Note

When Mbed TLS is built with threading support, after this function returns successfully, it is safe to call mbedtls_hmac_drbg_random() from multiple threads. Other operations, including reseeding, are not thread-safe.

Parameters
  • ctx – HMAC_DRBG context to be initialised.

  • md_info – MD algorithm to use for HMAC_DRBG.

  • data – Concatenation of the initial entropy string and the additional data.

  • data_len – Length of data in bytes.

Returns

0 if successful. or

Returns

MBEDTLS_ERR_MD_BAD_INPUT_DATA if md_info is invalid.

Returns

MBEDTLS_ERR_MD_ALLOC_FAILED if there was not enough memory to allocate context data.

void mbedtls_hmac_drbg_set_prediction_resistance(mbedtls_hmac_drbg_context *ctx, int resistance)

This function turns prediction resistance on or off. The default value is off.

Note

If enabled, entropy is gathered at the beginning of every call to mbedtls_hmac_drbg_random_with_add() or mbedtls_hmac_drbg_random(). Only use this if your entropy source has sufficient throughput.

Parameters
void mbedtls_hmac_drbg_set_entropy_len(mbedtls_hmac_drbg_context *ctx, size_t len)

This function sets the amount of entropy grabbed on each seed or reseed.

See the documentation of mbedtls_hmac_drbg_seed() for the default value.

Parameters
  • ctx – The HMAC_DRBG context.

  • len – The amount of entropy to grab, in bytes.

void mbedtls_hmac_drbg_set_reseed_interval(mbedtls_hmac_drbg_context *ctx, int interval)

Set the reseed interval.

The reseed interval is the number of calls to mbedtls_hmac_drbg_random() or mbedtls_hmac_drbg_random_with_add() after which the entropy function is called again.

The default value is MBEDTLS_HMAC_DRBG_RESEED_INTERVAL.

Parameters
  • ctx – The HMAC_DRBG context.

  • interval – The reseed interval.

int mbedtls_hmac_drbg_update(mbedtls_hmac_drbg_context *ctx, const unsigned char *additional, size_t add_len)

This function updates the state of the HMAC_DRBG context.

Note

This function is not thread-safe. It is not safe to call this function if another thread might be concurrently obtaining random numbers from the same context or updating or reseeding the same context.

Parameters
  • ctx – The HMAC_DRBG context.

  • additional – The data to update the state with. If this is NULL, there is no additional data.

  • add_len – Length of additional in bytes. Unused if additional is NULL.

Returns

0 on success, or an error from the underlying hash calculation.

int mbedtls_hmac_drbg_reseed(mbedtls_hmac_drbg_context *ctx, const unsigned char *additional, size_t len)

This function reseeds the HMAC_DRBG context, that is extracts data from the entropy source.

Note

This function is not thread-safe. It is not safe to call this function if another thread might be concurrently obtaining random numbers from the same context or updating or reseeding the same context.

Parameters
Returns

0 if successful.

Returns

MBEDTLS_ERR_HMAC_DRBG_ENTROPY_SOURCE_FAILED if a call to the entropy function failed.

int mbedtls_hmac_drbg_random_with_add(void *p_rng, unsigned char *output, size_t output_len, const unsigned char *additional, size_t add_len)

This function updates an HMAC_DRBG instance with additional data and uses it to generate random data.

This function automatically reseeds if the reseed counter is exceeded or prediction resistance is enabled.

Note

This function is not thread-safe. It is not safe to call this function if another thread might be concurrently obtaining random numbers from the same context or updating or reseeding the same context.

Parameters
  • p_rng – The HMAC_DRBG context. This must be a pointer to a mbedtls_hmac_drbg_context structure.

  • output – The buffer to fill.

  • output_len – The length of the buffer in bytes. This must be at most MBEDTLS_HMAC_DRBG_MAX_REQUEST.

  • additional – Additional data to update with. If this is NULL, there is no additional data and add_len should be 0.

  • add_len – The length of the additional data. This must be at most MBEDTLS_HMAC_DRBG_MAX_INPUT.

Returns

0 if successful.

Returns

MBEDTLS_ERR_HMAC_DRBG_ENTROPY_SOURCE_FAILED if a call to the entropy source failed.

Returns

MBEDTLS_ERR_HMAC_DRBG_REQUEST_TOO_BIG if output_len > MBEDTLS_HMAC_DRBG_MAX_REQUEST.

Returns

MBEDTLS_ERR_HMAC_DRBG_INPUT_TOO_BIG if add_len > MBEDTLS_HMAC_DRBG_MAX_INPUT.

int mbedtls_hmac_drbg_random(void *p_rng, unsigned char *output, size_t out_len)

This function uses HMAC_DRBG to generate random data.

This function automatically reseeds if the reseed counter is exceeded or prediction resistance is enabled.

Note

When Mbed TLS is built with threading support, it is safe to call mbedtls_ctr_drbg_random() from multiple threads. Other operations, including reseeding, are not thread-safe.

Parameters
Returns

0 if successful.

Returns

MBEDTLS_ERR_HMAC_DRBG_ENTROPY_SOURCE_FAILED if a call to the entropy source failed.

Returns

MBEDTLS_ERR_HMAC_DRBG_REQUEST_TOO_BIG if out_len > MBEDTLS_HMAC_DRBG_MAX_REQUEST.

void mbedtls_hmac_drbg_free(mbedtls_hmac_drbg_context *ctx)

This function resets HMAC_DRBG context to the state immediately after initial call of mbedtls_hmac_drbg_init().

Parameters

ctx – The HMAC_DRBG context to free.

int mbedtls_hmac_drbg_write_seed_file(mbedtls_hmac_drbg_context *ctx, const char *path)

This function writes a seed file.

Parameters
  • ctx – The HMAC_DRBG context.

  • path – The name of the file.

Returns

0 on success.

Returns

MBEDTLS_ERR_HMAC_DRBG_FILE_IO_ERROR on file error.

Returns

MBEDTLS_ERR_HMAC_DRBG_ENTROPY_SOURCE_FAILED on reseed failure.

int mbedtls_hmac_drbg_update_seed_file(mbedtls_hmac_drbg_context *ctx, const char *path)

This function reads and updates a seed file. The seed is added to this instance.

Parameters
  • ctx – The HMAC_DRBG context.

  • path – The name of the file.

Returns

0 on success.

Returns

MBEDTLS_ERR_HMAC_DRBG_FILE_IO_ERROR on file error.

Returns

MBEDTLS_ERR_HMAC_DRBG_ENTROPY_SOURCE_FAILED on reseed failure.

Returns

MBEDTLS_ERR_HMAC_DRBG_INPUT_TOO_BIG if the existing seed file is too large.

int mbedtls_hmac_drbg_self_test(int verbose)

The HMAC_DRBG Checkup routine.

Returns

0 if successful.

Returns

1 if the test failed.

struct mbedtls_hmac_drbg_context
#include <hmac_drbg.h>

HMAC_DRBG context.

Public Members

mbedtls_md_context_t private_md_ctx

HMAC context (inc. K)

unsigned char private_V[MBEDTLS_MD_MAX_SIZE]

V in the spec

int private_reseed_counter

reseed counter

size_t private_entropy_len

entropy bytes grabbed on each (re)seed

int private_prediction_resistance

enable prediction resistance (Automatic reseed before every random generation)

int private_reseed_interval

reseed interval

int (*private_f_entropy)(void*, unsigned char*, size_t)

entropy function

void *private_p_entropy

context for the entropy function

mbedtls_threading_mutex_t private_mutex