2020-11-30 21:28:19 +01:00
|
|
|
/** @file
|
2020-12-16 00:20:56 +01:00
|
|
|
Confidential Computing Secret configuration table constructor
|
2020-11-30 21:28:19 +01:00
|
|
|
|
|
|
|
Copyright (C) 2020 James Bottomley, IBM Corporation.
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
#include <PiDxe.h>
|
|
|
|
#include <Library/UefiBootServicesTableLib.h>
|
2020-12-16 02:41:46 +01:00
|
|
|
#include <Guid/ConfidentialComputingSecret.h>
|
2020-11-30 21:28:19 +01:00
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
2021-12-05 23:54:09 +01:00
|
|
|
InitializeSecretDxe (
|
|
|
|
IN EFI_HANDLE ImageHandle,
|
|
|
|
IN EFI_SYSTEM_TABLE *SystemTable
|
2020-11-30 21:28:19 +01:00
|
|
|
)
|
|
|
|
{
|
2022-12-15 14:11:51 +01:00
|
|
|
EFI_STATUS Status;
|
|
|
|
CONFIDENTIAL_COMPUTING_SECRET_LOCATION *SecretDxeTable;
|
|
|
|
|
|
|
|
Status = gBS->AllocatePool (
|
|
|
|
EfiACPIReclaimMemory,
|
|
|
|
sizeof (CONFIDENTIAL_COMPUTING_SECRET_LOCATION),
|
|
|
|
(VOID **)&SecretDxeTable
|
|
|
|
);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
return Status;
|
|
|
|
}
|
|
|
|
|
|
|
|
SecretDxeTable->Base = FixedPcdGet32 (PcdSevLaunchSecretBase);
|
|
|
|
SecretDxeTable->Size = FixedPcdGet32 (PcdSevLaunchSecretSize);
|
|
|
|
|
2020-11-30 21:28:19 +01:00
|
|
|
return gBS->InstallConfigurationTable (
|
2020-12-16 02:41:46 +01:00
|
|
|
&gConfidentialComputingSecretGuid,
|
2022-12-15 14:11:51 +01:00
|
|
|
SecretDxeTable
|
2020-11-30 21:28:19 +01:00
|
|
|
);
|
|
|
|
}
|