2013-11-19 02:49:49 +01:00
|
|
|
## @file
|
2014-08-28 07:31:09 +02:00
|
|
|
# Produces the UEFI Random Number Generator protocol
|
2013-11-19 02:49:49 +01:00
|
|
|
#
|
|
|
|
# This module will leverage Intel Secure Key technology to produce the Random
|
|
|
|
# Number Generator protocol, which is used to provide high-quality random numbers
|
|
|
|
# for use in applications, or entropy for seeding other random number generators.
|
|
|
|
# Refer to http://software.intel.com/en-us/articles/intel-digital-random-number
|
|
|
|
# -generator-drng-software-implementation-guide/ for more information about Intel
|
|
|
|
# Secure Key technology.
|
|
|
|
#
|
2018-06-27 15:13:09 +02:00
|
|
|
# Copyright (c) 2013 - 2018, Intel Corporation. All rights reserved.<BR>
|
2015-10-09 08:03:26 +02:00
|
|
|
# (C) Copyright 2015 Hewlett Packard Enterprise Development LP<BR>
|
2022-10-28 17:32:50 +02:00
|
|
|
# Copyright (c) 2021 - 2022, Arm Limited. All rights reserved.<BR>
|
2019-04-04 01:06:56 +02:00
|
|
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
2013-11-19 02:49:49 +01:00
|
|
|
#
|
|
|
|
##
|
|
|
|
|
|
|
|
[Defines]
|
|
|
|
INF_VERSION = 0x00010005
|
|
|
|
BASE_NAME = RngDxe
|
|
|
|
FILE_GUID = B981A835-6EE8-4f4c-AE0B-210AA0BFBF01
|
|
|
|
MODULE_TYPE = DXE_DRIVER
|
|
|
|
VERSION_STRING = 1.0
|
|
|
|
ENTRY_POINT = RngDriverEntry
|
2022-10-28 17:32:54 +02:00
|
|
|
UNLOAD_IMAGE = RngDriverUnLoad
|
2014-08-28 07:31:09 +02:00
|
|
|
MODULE_UNI_FILE = RngDxe.uni
|
2013-11-19 02:49:49 +01:00
|
|
|
|
|
|
|
#
|
|
|
|
# The following information is for reference only and not required by the build tools.
|
|
|
|
#
|
2021-05-10 23:53:08 +02:00
|
|
|
# VALID_ARCHITECTURES = IA32 X64 AARCH64
|
2013-11-19 02:49:49 +01:00
|
|
|
#
|
|
|
|
|
|
|
|
[Sources.common]
|
|
|
|
RngDxe.c
|
2021-05-10 23:53:08 +02:00
|
|
|
RngDxeInternals.h
|
|
|
|
|
|
|
|
[Sources.IA32, Sources.X64]
|
|
|
|
Rand/RngDxe.c
|
|
|
|
Rand/RdRand.c
|
|
|
|
Rand/AesCore.c
|
|
|
|
Rand/AesCore.h
|
|
|
|
|
|
|
|
[Sources.AARCH64]
|
|
|
|
AArch64/RngDxe.c
|
2022-10-28 17:32:55 +02:00
|
|
|
ArmTrng.c
|
2013-11-19 02:49:49 +01:00
|
|
|
|
|
|
|
[Packages]
|
2022-10-28 17:32:55 +02:00
|
|
|
MdeModulePkg/MdeModulePkg.dec
|
2013-11-19 02:49:49 +01:00
|
|
|
MdePkg/MdePkg.dec
|
|
|
|
SecurityPkg/SecurityPkg.dec
|
|
|
|
|
|
|
|
[LibraryClasses]
|
|
|
|
UefiLib
|
|
|
|
UefiBootServicesTableLib
|
|
|
|
BaseLib
|
2018-06-27 15:13:09 +02:00
|
|
|
DebugLib
|
2013-11-19 02:49:49 +01:00
|
|
|
UefiDriverEntryPoint
|
|
|
|
TimerLib
|
2015-10-09 08:03:26 +02:00
|
|
|
RngLib
|
2013-11-19 02:49:49 +01:00
|
|
|
|
2022-10-28 17:32:55 +02:00
|
|
|
[LibraryClasses.AARCH64]
|
|
|
|
ArmTrngLib
|
|
|
|
|
2013-11-19 02:49:49 +01:00
|
|
|
[Guids]
|
2021-05-10 23:53:08 +02:00
|
|
|
gEfiRngAlgorithmSp80090Hash256Guid ## SOMETIMES_PRODUCES ## GUID # Unique ID of the algorithm for RNG
|
|
|
|
gEfiRngAlgorithmSp80090Hmac256Guid ## SOMETIMES_PRODUCES ## GUID # Unique ID of the algorithm for RNG
|
2014-08-28 07:31:09 +02:00
|
|
|
gEfiRngAlgorithmSp80090Ctr256Guid ## SOMETIMES_PRODUCES ## GUID # Unique ID of the algorithm for RNG
|
2021-05-10 23:53:08 +02:00
|
|
|
gEfiRngAlgorithmX9313DesGuid ## SOMETIMES_PRODUCES ## GUID # Unique ID of the algorithm for RNG
|
|
|
|
gEfiRngAlgorithmX931AesGuid ## SOMETIMES_PRODUCES ## GUID # Unique ID of the algorithm for RNG
|
2014-08-28 07:31:09 +02:00
|
|
|
gEfiRngAlgorithmRaw ## SOMETIMES_PRODUCES ## GUID # Unique ID of the algorithm for RNG
|
2013-11-19 02:49:49 +01:00
|
|
|
|
|
|
|
[Protocols]
|
2014-08-28 07:31:09 +02:00
|
|
|
gEfiRngProtocolGuid ## PRODUCES
|
2013-11-19 02:49:49 +01:00
|
|
|
|
2021-05-10 23:53:08 +02:00
|
|
|
[Pcd]
|
|
|
|
gEfiSecurityPkgTokenSpaceGuid.PcdCpuRngSupportedAlgorithm ## CONSUMES
|
|
|
|
|
2013-11-19 02:49:49 +01:00
|
|
|
[Depex]
|
|
|
|
TRUE
|
2014-06-16 10:31:41 +02:00
|
|
|
|
|
|
|
[BuildOptions]
|
|
|
|
XCODE:*_*_*_CC_FLAGS = -mmmx -msse
|
2014-08-28 07:31:09 +02:00
|
|
|
|
|
|
|
[UserExtensions.TianoCore."ExtraFiles"]
|
2015-10-09 08:03:26 +02:00
|
|
|
RngDxeExtra.uni
|