mirror of https://github.com/acidanthera/audk.git
69 lines
1.3 KiB
C
69 lines
1.3 KiB
C
|
/** @file
|
||
|
|
||
|
CcProbeLib is used to probe the Confidential computing guest type.
|
||
|
|
||
|
Copyright (c) 2022, Intel Corporation. All rights reserved.<BR>
|
||
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
||
|
|
||
|
**/
|
||
|
|
||
|
#include <Uefi/UefiBaseType.h>
|
||
|
#include <Library/CcProbeLib.h>
|
||
|
#include <WorkArea.h>
|
||
|
|
||
|
STATIC UINT8 mCcProbeGuestType = 0;
|
||
|
STATIC BOOLEAN mCcProbed = FALSE;
|
||
|
|
||
|
/**
|
||
|
* Read the the ConfidentialComputing Guest type from Ovmf work-area.
|
||
|
*
|
||
|
* @return The ConfidentialComputing Guest type
|
||
|
*/
|
||
|
STATIC
|
||
|
UINT8
|
||
|
ReadCcGuestType (
|
||
|
VOID
|
||
|
)
|
||
|
{
|
||
|
OVMF_WORK_AREA *WorkArea;
|
||
|
|
||
|
if (!mCcProbed) {
|
||
|
WorkArea = (OVMF_WORK_AREA *)FixedPcdGet32 (PcdOvmfWorkAreaBase);
|
||
|
mCcProbeGuestType = WorkArea != NULL ? WorkArea->Header.GuestType : CcGuestTypeNonEncrypted;
|
||
|
mCcProbed = TRUE;
|
||
|
}
|
||
|
|
||
|
return mCcProbeGuestType;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
Probe the ConfidentialComputing Guest type. See defition of
|
||
|
CC_GUEST_TYPE in <ConfidentialComputingGuestAttr.h>.
|
||
|
|
||
|
@return The guest type
|
||
|
|
||
|
**/
|
||
|
UINT8
|
||
|
EFIAPI
|
||
|
CcProbe (
|
||
|
VOID
|
||
|
)
|
||
|
{
|
||
|
return ReadCcGuestType ();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Constructor of DxeCcProbeLib
|
||
|
*
|
||
|
* @return EFI_SUCCESS Successfully called of constructor
|
||
|
*/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
DxeCcProbeLibConstructor (
|
||
|
VOID
|
||
|
)
|
||
|
{
|
||
|
ReadCcGuestType ();
|
||
|
return EFI_SUCCESS;
|
||
|
}
|