2020-10-09 00:37:46 +02:00
|
|
|
/** @file
|
|
|
|
Application for Pseudorandom Number Generator Validation.
|
|
|
|
|
|
|
|
Copyright (c) 2010, Intel Corporation. All rights reserved.<BR>
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "TestBaseCryptLib.h"
|
|
|
|
|
|
|
|
#define RANDOM_NUMBER_SIZE 256
|
|
|
|
|
|
|
|
CONST UINT8 SeedString[] = "This is the random seed for PRNG verification.";
|
|
|
|
|
|
|
|
UINT8 PreviousRandomBuffer[RANDOM_NUMBER_SIZE] = { 0x0 };
|
|
|
|
|
|
|
|
UINT8 RandomBuffer[RANDOM_NUMBER_SIZE] = { 0x0 };
|
|
|
|
|
|
|
|
UNIT_TEST_STATUS
|
|
|
|
EFIAPI
|
|
|
|
TestVerifyPrngGeneration (
|
2021-12-05 23:53:54 +01:00
|
|
|
UNIT_TEST_CONTEXT Context
|
2020-10-09 00:37:46 +02:00
|
|
|
)
|
|
|
|
{
|
|
|
|
UINTN Index;
|
|
|
|
BOOLEAN Status;
|
|
|
|
|
|
|
|
Status = RandomSeed (SeedString, sizeof (SeedString));
|
|
|
|
UT_ASSERT_TRUE (Status);
|
|
|
|
|
2021-12-05 23:53:54 +01:00
|
|
|
for (Index = 0; Index < 10; Index++) {
|
2020-10-09 00:37:46 +02:00
|
|
|
Status = RandomBytes (RandomBuffer, RANDOM_NUMBER_SIZE);
|
|
|
|
UT_ASSERT_TRUE (Status);
|
|
|
|
|
|
|
|
Status = (CompareMem (PreviousRandomBuffer, RandomBuffer, RANDOM_NUMBER_SIZE) == 0);
|
|
|
|
UT_ASSERT_FALSE (Status);
|
|
|
|
|
|
|
|
CopyMem (PreviousRandomBuffer, RandomBuffer, RANDOM_NUMBER_SIZE);
|
|
|
|
}
|
|
|
|
|
|
|
|
return UNIT_TEST_PASSED;
|
|
|
|
}
|
|
|
|
|
2021-12-05 23:53:54 +01:00
|
|
|
TEST_DESC mPrngTest[] = {
|
|
|
|
//
|
|
|
|
// -----Description--------------------------------Class--------------------Function----------------Pre---Post--Context
|
|
|
|
//
|
|
|
|
{ "TestVerifyPrngGeneration()", "CryptoPkg.BaseCryptLib.Prng", TestVerifyPrngGeneration, NULL, NULL, NULL },
|
2020-10-09 00:37:46 +02:00
|
|
|
};
|
|
|
|
|
2021-12-05 23:53:54 +01:00
|
|
|
UINTN mPrngTestNum = ARRAY_SIZE (mPrngTest);
|