2012-05-10 09:58:02 +02:00
|
|
|
/** @file
|
|
|
|
Pseudorandom Number Generator Wrapper Implementation over OpenSSL.
|
|
|
|
|
2018-06-27 11:32:13 +02:00
|
|
|
Copyright (c) 2012 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:03:30 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2012-05-10 09:58:02 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "InternalCryptLib.h"
|
|
|
|
#include <openssl/rand.h>
|
2013-11-19 03:57:19 +01:00
|
|
|
#include <openssl/evp.h>
|
2012-05-10 09:58:02 +02:00
|
|
|
#include <Library/PrintLib.h>
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets up the seed value for the pseudorandom number generator.
|
|
|
|
|
|
|
|
This function sets up the seed value for the pseudorandom number generator.
|
|
|
|
If Seed is not NULL, then the seed passed in is used.
|
|
|
|
If Seed is NULL, then default seed is used.
|
|
|
|
|
|
|
|
@param[in] Seed Pointer to seed value.
|
|
|
|
If NULL, default seed is used.
|
|
|
|
@param[in] SeedSize Size of seed value.
|
|
|
|
If Seed is NULL, this parameter is ignored.
|
|
|
|
|
|
|
|
@retval TRUE Pseudorandom number generator has enough entropy for random generation.
|
|
|
|
@retval FALSE Pseudorandom number generator does not have enough entropy for random generation.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
RandomSeed (
|
|
|
|
IN CONST UINT8 *Seed OPTIONAL,
|
|
|
|
IN UINTN SeedSize
|
|
|
|
)
|
|
|
|
{
|
|
|
|
CHAR8 DefaultSeed[128];
|
|
|
|
|
2012-08-02 04:49:24 +02:00
|
|
|
if (SeedSize > INT_MAX) {
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2013-11-19 03:57:19 +01:00
|
|
|
//
|
|
|
|
// The software PRNG implementation built in OpenSSL depends on message digest algorithm.
|
|
|
|
// Make sure SHA-1 digest algorithm is available here.
|
|
|
|
//
|
|
|
|
if (EVP_add_digest (EVP_sha1 ()) == 0) {
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2012-05-10 09:58:02 +02:00
|
|
|
//
|
|
|
|
// Seed the pseudorandom number generator with user-supplied value.
|
|
|
|
// NOTE: A cryptographic PRNG must be seeded with unpredictable data.
|
|
|
|
//
|
|
|
|
if (Seed != NULL) {
|
2021-12-05 23:53:54 +01:00
|
|
|
RAND_seed (Seed, (UINT32)SeedSize);
|
2012-05-10 09:58:02 +02:00
|
|
|
} else {
|
|
|
|
//
|
|
|
|
// Retrieve current time.
|
|
|
|
//
|
|
|
|
AsciiSPrint (
|
|
|
|
DefaultSeed,
|
|
|
|
sizeof (DefaultSeed),
|
|
|
|
"UEFI Crypto Library default seed (%ld)",
|
|
|
|
AsmReadTsc ()
|
2018-06-27 11:32:13 +02:00
|
|
|
);
|
2012-05-10 09:58:02 +02:00
|
|
|
|
|
|
|
RAND_seed (DefaultSeed, sizeof (DefaultSeed));
|
|
|
|
}
|
|
|
|
|
2013-05-29 07:30:13 +02:00
|
|
|
if (RAND_status () == 1) {
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return FALSE;
|
2012-05-10 09:58:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Generates a pseudorandom byte stream of the specified size.
|
|
|
|
|
|
|
|
If Output is NULL, then return FALSE.
|
|
|
|
|
|
|
|
@param[out] Output Pointer to buffer to receive random value.
|
2016-10-19 09:01:10 +02:00
|
|
|
@param[in] Size Size of random bytes to generate.
|
2012-05-10 09:58:02 +02:00
|
|
|
|
|
|
|
@retval TRUE Pseudorandom byte stream generated successfully.
|
|
|
|
@retval FALSE Pseudorandom number generator fails to generate due to lack of entropy.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
RandomBytes (
|
|
|
|
OUT UINT8 *Output,
|
|
|
|
IN UINTN Size
|
|
|
|
)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
// Check input parameters.
|
|
|
|
//
|
2021-12-05 23:53:54 +01:00
|
|
|
if ((Output == NULL) || (Size > INT_MAX)) {
|
2012-05-10 09:58:02 +02:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Generate random data.
|
|
|
|
//
|
2021-12-05 23:53:54 +01:00
|
|
|
if (RAND_bytes (Output, (UINT32)Size) != 1) {
|
2012-05-10 09:58:02 +02:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|