8e51a8153a
- edk2-MdeModulePkg-Change-use-of-EFI_D_-to-DEBUG_.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-MdeModulePkg-Potential-UINT32-overflow-in-S3-ResumeC.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-MdePkg-Apply-uncrustify-changes.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-NetworkPkg-Apply-uncrustify-changes.p2.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Rename-RdRandGenerateEntropy-to-g.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Remove-ArchGetSupportedRngAlgorit.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Documentation-include-parameter-c.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Check-before-advertising-Cpu-Rng-.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Add-AArch64-RawAlgorithm-support-.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Add-debug-warning-for-NULL-PcdCpu.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Rename-AArch64-RngDxe.c.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Add-Arm-support-of-RngDxe.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Correctly-update-mAvailableAlgoAr.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Conditionally-install-EFI_RNG_PRO.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-MdeModulePkg-Duplicate-BaseRngLibTimerLib-to-MdeModu.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-MdePkg-Add-deprecated-warning-to-BaseRngLibTimer.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-SecurityPkg.dec-Move-PcdCpuRngSupportedA.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-MdePkg-DxeRngLib-Request-raw-algorithm-instead-of-de.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-MdePkg-Rng-Add-GUID-to-describe-Arm-Rndr-Rng-algorit.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-MdeModulePkg-Rng-Add-GUID-to-describe-unsafe-Rng-alg.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-MdePkg-Rng-Add-GetRngGuid-to-RngLib.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Use-GetRngGuid-when-probing-RngLi.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-Simplify-Rng-algorithm-selection-.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-NetworkPkg-SECURITY-PATCH-CVE-2023-45237.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-MdePkg-BaseRngLib-Add-a-smoketest-for-RDRAND-and-che.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-SecurityPkg-RngDxe-add-rng-test.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-OvmfPkg-wire-up-RngDxe.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-CryptoPkg-Test-call-ProcessLibraryConstructorList.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-MdePkg-X86UnitTestHost-set-rdrand-cpuid-bit.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-NetworkPkg-TcpDxe-SECURITY-PATCH-CVE-2023-45236.patch [RHEL-21854 RHEL-21856 RHEL-40099] - edk2-NetworkPkg-TcpDxe-Fixed-system-stuck-on-PXE-boot-flo.patch [RHEL-21854 RHEL-21856 RHEL-40099] - Resolves: RHEL-21854 (CVE-2023-45236 edk2: Predictable TCP Initial Sequence Numbers [rhel-8]) - Resolves: RHEL-21856 (CVE-2023-45237 edk2: Use of a Weak PseudoRandom Number Generator [rhel-8]) - Resolves: RHEL-40099 (CVE-2024-1298 edk2: Temporary DoS vulnerability [rhel-8.10.z])
196 lines
6.8 KiB
Diff
196 lines
6.8 KiB
Diff
From 6b3795dcecf31b0d8aa7edabeffccf37b7259ff0 Mon Sep 17 00:00:00 2001
|
|
From: Jon Maloy <jmaloy@redhat.com>
|
|
Date: Thu, 20 Jun 2024 16:09:46 -0400
|
|
Subject: [PATCH 22/31] SecurityPkg/RngDxe: Use GetRngGuid() when probing
|
|
RngLib
|
|
|
|
RH-Author: Jon Maloy <jmaloy@redhat.com>
|
|
RH-MergeRequest: 77: UINT32 overflow in S3 ResumeCount and Pixiefail fixes
|
|
RH-Jira: RHEL-21854 RHEL-21856 RHEL-40099
|
|
RH-Acked-by: Gerd Hoffmann <None>
|
|
RH-Commit: [22/31] 17b40bc3daeba2ba8407826e17f3096c4a5151c6
|
|
|
|
JIRA: https://issues.redhat.com/browse/RHEL-21856
|
|
Upstream: Merged
|
|
CVE: CVE-2023-45237
|
|
|
|
commit 19438cff973bfb35a1ef12fab45fabb28b63fe64
|
|
Author: Pierre Gondois <pierre.gondois@arm.com>
|
|
Date: Fri Aug 11 16:33:09 2023 +0200
|
|
|
|
SecurityPkg/RngDxe: Use GetRngGuid() when probing RngLib
|
|
|
|
BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=4151
|
|
|
|
The EFI_RNG_PROTOCOL can rely on the RngLib. The RngLib has multiple
|
|
implementations, some of them are unsafe (e.g. BaseRngLibTimerLib).
|
|
To allow the RngDxe to detect when such implementation is used,
|
|
a GetRngGuid() function was added in a previous patch.
|
|
|
|
The EFI_RNG_PROTOCOL can advertise multiple algorithms through
|
|
Guids. The PcdCpuRngSupportedAlgorithm is currently used to
|
|
advertise the RngLib in the Arm implementation.
|
|
|
|
The issues of doing that are:
|
|
- the RngLib implementation might not use CPU instructions,
|
|
cf. the BaseRngLibTimerLib
|
|
- most platforms don't set PcdCpuRngSupportedAlgorithm
|
|
|
|
A GetRngGuid() was added to the RngLib in a previous patch,
|
|
allowing to identify the algorithm implemented by the RngLib.
|
|
Make use of this function and place the unsage algorithm
|
|
at the last position in the mAvailableAlgoArray.
|
|
|
|
Signed-off-by: Pierre Gondois <pierre.gondois@arm.com>
|
|
Reviewed-by: Sami Mujawar <sami.mujawar@arm.com>
|
|
Acked-by: Ard Biesheuvel <ardb@kernel.org>
|
|
Acked-by: Jiewen Yao <Jiewen.yao@intel.com>
|
|
Tested-by: Kun Qin <kun.qin@microsoft.com>
|
|
|
|
Signed-off-by: Jon Maloy <jmaloy@redhat.com>
|
|
---
|
|
.../RngDxe/AArch64/AArch64Algo.c | 55 +++++++++++++------
|
|
.../RandomNumberGenerator/RngDxe/ArmRngDxe.c | 8 ++-
|
|
.../RandomNumberGenerator/RngDxe/RngDxe.inf | 4 +-
|
|
3 files changed, 45 insertions(+), 22 deletions(-)
|
|
|
|
diff --git a/SecurityPkg/RandomNumberGenerator/RngDxe/AArch64/AArch64Algo.c b/SecurityPkg/RandomNumberGenerator/RngDxe/AArch64/AArch64Algo.c
|
|
index e8be217f8a..a270441ebb 100644
|
|
--- a/SecurityPkg/RandomNumberGenerator/RngDxe/AArch64/AArch64Algo.c
|
|
+++ b/SecurityPkg/RandomNumberGenerator/RngDxe/AArch64/AArch64Algo.c
|
|
@@ -10,6 +10,8 @@
|
|
#include <Library/DebugLib.h>
|
|
#include <Library/MemoryAllocationLib.h>
|
|
#include <Library/ArmTrngLib.h>
|
|
+#include <Library/RngLib.h>
|
|
+#include <Guid/RngAlgorithm.h>
|
|
|
|
#include "RngDxeInternals.h"
|
|
|
|
@@ -28,9 +30,13 @@ GetAvailableAlgorithms (
|
|
VOID
|
|
)
|
|
{
|
|
- UINT64 DummyRand;
|
|
- UINT16 MajorRevision;
|
|
- UINT16 MinorRevision;
|
|
+ EFI_STATUS Status;
|
|
+ UINT16 MajorRevision;
|
|
+ UINT16 MinorRevision;
|
|
+ GUID RngGuid;
|
|
+ BOOLEAN UnSafeAlgo;
|
|
+
|
|
+ UnSafeAlgo = FALSE;
|
|
|
|
// Rng algorithms 2 times, one for the allocation, one to populate.
|
|
mAvailableAlgoArray = AllocateZeroPool (RNG_AVAILABLE_ALGO_MAX);
|
|
@@ -38,24 +44,29 @@ GetAvailableAlgorithms (
|
|
return EFI_OUT_OF_RESOURCES;
|
|
}
|
|
|
|
- // Check RngGetBytes() before advertising PcdCpuRngSupportedAlgorithm.
|
|
- if (!EFI_ERROR (RngGetBytes (sizeof (DummyRand), (UINT8 *)&DummyRand))) {
|
|
- CopyMem (
|
|
- &mAvailableAlgoArray[mAvailableAlgoArrayCount],
|
|
- PcdGetPtr (PcdCpuRngSupportedAlgorithm),
|
|
- sizeof (EFI_RNG_ALGORITHM)
|
|
- );
|
|
- mAvailableAlgoArrayCount++;
|
|
-
|
|
- DEBUG_CODE_BEGIN ();
|
|
- if (IsZeroGuid (PcdGetPtr (PcdCpuRngSupportedAlgorithm))) {
|
|
+ // Identify RngLib algorithm.
|
|
+ Status = GetRngGuid (&RngGuid);
|
|
+ if (!EFI_ERROR (Status)) {
|
|
+ if (IsZeroGuid (&RngGuid) ||
|
|
+ CompareGuid (&RngGuid, &gEdkiiRngAlgorithmUnSafe))
|
|
+ {
|
|
+ // Treat zero GUID as an unsafe algorithm
|
|
DEBUG ((
|
|
DEBUG_WARN,
|
|
- "PcdCpuRngSupportedAlgorithm should be a non-zero GUID\n"
|
|
+ "RngLib uses an Unsafe algorithm and "
|
|
+ "must not be used for production builds.\n"
|
|
));
|
|
+ // Set the UnSafeAlgo flag to indicate an unsafe algorithm was found
|
|
+ // so that it can be added at the end of the algorithm list.
|
|
+ UnSafeAlgo = TRUE;
|
|
+ } else {
|
|
+ CopyMem (
|
|
+ &mAvailableAlgoArray[mAvailableAlgoArrayCount],
|
|
+ &RngGuid,
|
|
+ sizeof (RngGuid)
|
|
+ );
|
|
+ mAvailableAlgoArrayCount++;
|
|
}
|
|
-
|
|
- DEBUG_CODE_END ();
|
|
}
|
|
|
|
// Raw algorithm (Trng)
|
|
@@ -68,5 +79,15 @@ GetAvailableAlgorithms (
|
|
mAvailableAlgoArrayCount++;
|
|
}
|
|
|
|
+ // Add unsafe algorithm at the end of the list.
|
|
+ if (UnSafeAlgo) {
|
|
+ CopyMem (
|
|
+ &mAvailableAlgoArray[mAvailableAlgoArrayCount],
|
|
+ &gEdkiiRngAlgorithmUnSafe,
|
|
+ sizeof (EFI_RNG_ALGORITHM)
|
|
+ );
|
|
+ mAvailableAlgoArrayCount++;
|
|
+ }
|
|
+
|
|
return EFI_SUCCESS;
|
|
}
|
|
diff --git a/SecurityPkg/RandomNumberGenerator/RngDxe/ArmRngDxe.c b/SecurityPkg/RandomNumberGenerator/RngDxe/ArmRngDxe.c
|
|
index 0e44d0c931..2fc36fc186 100644
|
|
--- a/SecurityPkg/RandomNumberGenerator/RngDxe/ArmRngDxe.c
|
|
+++ b/SecurityPkg/RandomNumberGenerator/RngDxe/ArmRngDxe.c
|
|
@@ -76,8 +76,9 @@ RngGetRNG (
|
|
OUT UINT8 *RNGValue
|
|
)
|
|
{
|
|
- EFI_STATUS Status;
|
|
+ EFI_STATUS Status;
|
|
UINTN Index;
|
|
+ GUID RngGuid;
|
|
|
|
if ((This == NULL) || (RNGValueLength == 0) || (RNGValue == NULL)) {
|
|
return EFI_INVALID_PARAMETER;
|
|
@@ -102,7 +103,10 @@ RngGetRNG (
|
|
}
|
|
|
|
FoundAlgo:
|
|
- if (CompareGuid (RNGAlgorithm, PcdGetPtr (PcdCpuRngSupportedAlgorithm))) {
|
|
+ Status = GetRngGuid (&RngGuid);
|
|
+ if (!EFI_ERROR (Status) &&
|
|
+ CompareGuid (RNGAlgorithm, &RngGuid))
|
|
+ {
|
|
Status = RngGetBytes (RNGValueLength, RNGValue);
|
|
return Status;
|
|
}
|
|
diff --git a/SecurityPkg/RandomNumberGenerator/RngDxe/RngDxe.inf b/SecurityPkg/RandomNumberGenerator/RngDxe/RngDxe.inf
|
|
index d6c2d30195..8704a64441 100644
|
|
--- a/SecurityPkg/RandomNumberGenerator/RngDxe/RngDxe.inf
|
|
+++ b/SecurityPkg/RandomNumberGenerator/RngDxe/RngDxe.inf
|
|
@@ -75,13 +75,11 @@
|
|
gEfiRngAlgorithmX9313DesGuid ## SOMETIMES_PRODUCES ## GUID # Unique ID of the algorithm for RNG
|
|
gEfiRngAlgorithmX931AesGuid ## SOMETIMES_PRODUCES ## GUID # Unique ID of the algorithm for RNG
|
|
gEfiRngAlgorithmRaw ## SOMETIMES_PRODUCES ## GUID # Unique ID of the algorithm for RNG
|
|
+ gEdkiiRngAlgorithmUnSafe ## SOMETIMES_PRODUCES ## GUID # Unique ID of the algorithm for RNG
|
|
|
|
[Protocols]
|
|
gEfiRngProtocolGuid ## PRODUCES
|
|
|
|
-[Pcd.AARCH64]
|
|
- gEfiMdePkgTokenSpaceGuid.PcdCpuRngSupportedAlgorithm ## CONSUMES
|
|
-
|
|
[Depex]
|
|
TRUE
|
|
|
|
--
|
|
2.39.3
|
|
|