2016-11-04 08:31:28 +01:00
|
|
|
/** @file
|
|
|
|
IA-32/x64 AsmRdRandxx()
|
|
|
|
Generates random number through CPU RdRand instruction.
|
|
|
|
|
|
|
|
Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:00 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2016-11-04 08:31:28 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "BaseLibInternals.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
Generates a 16-bit random number through RDRAND instruction.
|
|
|
|
|
|
|
|
if Rand is NULL, then ASSERT().
|
|
|
|
|
|
|
|
@param[out] Rand Buffer pointer to store the random result.
|
|
|
|
|
|
|
|
@retval TRUE RDRAND call was successful.
|
|
|
|
@retval FALSE Failed attempts to call RDRAND.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
AsmRdRand16 (
|
|
|
|
OUT UINT16 *Rand
|
|
|
|
)
|
|
|
|
{
|
|
|
|
ASSERT (Rand != NULL);
|
|
|
|
return InternalX86RdRand16 (Rand);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Generates a 32-bit random number through RDRAND instruction.
|
|
|
|
|
|
|
|
if Rand is NULL, then ASSERT().
|
|
|
|
|
|
|
|
@param[out] Rand Buffer pointer to store the random result.
|
|
|
|
|
|
|
|
@retval TRUE RDRAND call was successful.
|
|
|
|
@retval FALSE Failed attempts to call RDRAND.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
AsmRdRand32 (
|
|
|
|
OUT UINT32 *Rand
|
|
|
|
)
|
|
|
|
{
|
|
|
|
ASSERT (Rand != NULL);
|
|
|
|
return InternalX86RdRand32 (Rand);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Generates a 64-bit random number through RDRAND instruction.
|
|
|
|
|
|
|
|
if Rand is NULL, then ASSERT().
|
|
|
|
|
|
|
|
@param[out] Rand Buffer pointer to store the random result.
|
|
|
|
|
|
|
|
@retval TRUE RDRAND call was successful.
|
|
|
|
@retval FALSE Failed attempts to call RDRAND.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
AsmRdRand64 (
|
|
|
|
OUT UINT64 *Rand
|
|
|
|
)
|
|
|
|
{
|
|
|
|
ASSERT (Rand != NULL);
|
|
|
|
return InternalX86RdRand64 (Rand);
|
|
|
|
}
|