mirror of
https://github.com/CloverHackyColor/CloverBootloader.git
synced 2025-01-03 18:07:41 +01:00
150 lines
5.8 KiB
C
150 lines
5.8 KiB
C
|
/** @file
|
||
|
Implementation functions and structures for var check protocol
|
||
|
and variable lock protocol based on VarCheckLib.
|
||
|
|
||
|
Copyright (c) 2015, Intel Corporation. All rights reserved.<BR>
|
||
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
||
|
|
||
|
**/
|
||
|
|
||
|
#include "Variable.h"
|
||
|
|
||
|
/**
|
||
|
Mark a variable that will become read-only after leaving the DXE phase of execution.
|
||
|
Write request coming from SMM environment through EFI_SMM_VARIABLE_PROTOCOL is allowed.
|
||
|
|
||
|
@param[in] This The VARIABLE_LOCK_PROTOCOL instance.
|
||
|
@param[in] VariableName A pointer to the variable name that will be made read-only subsequently.
|
||
|
@param[in] VendorGuid A pointer to the vendor GUID that will be made read-only subsequently.
|
||
|
|
||
|
@retval EFI_SUCCESS The variable specified by the VariableName and the VendorGuid was marked
|
||
|
as pending to be read-only.
|
||
|
@retval EFI_INVALID_PARAMETER VariableName or VendorGuid is NULL.
|
||
|
Or VariableName is an empty string.
|
||
|
@retval EFI_ACCESS_DENIED EFI_END_OF_DXE_EVENT_GROUP_GUID or EFI_EVENT_GROUP_READY_TO_BOOT has
|
||
|
already been signaled.
|
||
|
@retval EFI_OUT_OF_RESOURCES There is not enough resource to hold the lock request.
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
VariableLockRequestToLock (
|
||
|
IN CONST EDKII_VARIABLE_LOCK_PROTOCOL *This,
|
||
|
IN CHAR16 *VariableName,
|
||
|
IN EFI_GUID *VendorGuid
|
||
|
)
|
||
|
{
|
||
|
EFI_STATUS Status;
|
||
|
VAR_CHECK_VARIABLE_PROPERTY Property;
|
||
|
|
||
|
AcquireLockOnlyAtBootTime (&mVariableModuleGlobal->VariableGlobal.VariableServicesLock);
|
||
|
|
||
|
Status = VarCheckLibVariablePropertyGet (VariableName, VendorGuid, &Property);
|
||
|
if (!EFI_ERROR (Status)) {
|
||
|
Property.Property |= VAR_CHECK_VARIABLE_PROPERTY_READ_ONLY;
|
||
|
} else {
|
||
|
Property.Revision = VAR_CHECK_VARIABLE_PROPERTY_REVISION;
|
||
|
Property.Property = VAR_CHECK_VARIABLE_PROPERTY_READ_ONLY;
|
||
|
Property.Attributes = 0;
|
||
|
Property.MinSize = 1;
|
||
|
Property.MaxSize = MAX_UINTN;
|
||
|
}
|
||
|
Status = VarCheckLibVariablePropertySet (VariableName, VendorGuid, &Property);
|
||
|
|
||
|
DEBUG ((EFI_D_INFO, "[Variable] Lock: %g:%s %r\n", VendorGuid, VariableName, Status));
|
||
|
|
||
|
ReleaseLockOnlyAtBootTime (&mVariableModuleGlobal->VariableGlobal.VariableServicesLock);
|
||
|
|
||
|
return Status;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
Register SetVariable check handler.
|
||
|
|
||
|
@param[in] Handler Pointer to check handler.
|
||
|
|
||
|
@retval EFI_SUCCESS The SetVariable check handler was registered successfully.
|
||
|
@retval EFI_INVALID_PARAMETER Handler is NULL.
|
||
|
@retval EFI_ACCESS_DENIED EFI_END_OF_DXE_EVENT_GROUP_GUID or EFI_EVENT_GROUP_READY_TO_BOOT has
|
||
|
already been signaled.
|
||
|
@retval EFI_OUT_OF_RESOURCES There is not enough resource for the SetVariable check handler register request.
|
||
|
@retval EFI_UNSUPPORTED This interface is not implemented.
|
||
|
For example, it is unsupported in VarCheck protocol if both VarCheck and SmmVarCheck protocols are present.
|
||
|
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
VarCheckRegisterSetVariableCheckHandler (
|
||
|
IN VAR_CHECK_SET_VARIABLE_CHECK_HANDLER Handler
|
||
|
)
|
||
|
{
|
||
|
EFI_STATUS Status;
|
||
|
|
||
|
AcquireLockOnlyAtBootTime (&mVariableModuleGlobal->VariableGlobal.VariableServicesLock);
|
||
|
Status = VarCheckLibRegisterSetVariableCheckHandler (Handler);
|
||
|
ReleaseLockOnlyAtBootTime (&mVariableModuleGlobal->VariableGlobal.VariableServicesLock);
|
||
|
|
||
|
return Status;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
Variable property set.
|
||
|
|
||
|
@param[in] Name Pointer to the variable name.
|
||
|
@param[in] Guid Pointer to the vendor GUID.
|
||
|
@param[in] VariableProperty Pointer to the input variable property.
|
||
|
|
||
|
@retval EFI_SUCCESS The property of variable specified by the Name and Guid was set successfully.
|
||
|
@retval EFI_INVALID_PARAMETER Name, Guid or VariableProperty is NULL, or Name is an empty string,
|
||
|
or the fields of VariableProperty are not valid.
|
||
|
@retval EFI_ACCESS_DENIED EFI_END_OF_DXE_EVENT_GROUP_GUID or EFI_EVENT_GROUP_READY_TO_BOOT has
|
||
|
already been signaled.
|
||
|
@retval EFI_OUT_OF_RESOURCES There is not enough resource for the variable property set request.
|
||
|
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
VarCheckVariablePropertySet (
|
||
|
IN CHAR16 *Name,
|
||
|
IN EFI_GUID *Guid,
|
||
|
IN VAR_CHECK_VARIABLE_PROPERTY *VariableProperty
|
||
|
)
|
||
|
{
|
||
|
EFI_STATUS Status;
|
||
|
|
||
|
AcquireLockOnlyAtBootTime (&mVariableModuleGlobal->VariableGlobal.VariableServicesLock);
|
||
|
Status = VarCheckLibVariablePropertySet (Name, Guid, VariableProperty);
|
||
|
ReleaseLockOnlyAtBootTime (&mVariableModuleGlobal->VariableGlobal.VariableServicesLock);
|
||
|
|
||
|
return Status;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
Variable property get.
|
||
|
|
||
|
@param[in] Name Pointer to the variable name.
|
||
|
@param[in] Guid Pointer to the vendor GUID.
|
||
|
@param[out] VariableProperty Pointer to the output variable property.
|
||
|
|
||
|
@retval EFI_SUCCESS The property of variable specified by the Name and Guid was got successfully.
|
||
|
@retval EFI_INVALID_PARAMETER Name, Guid or VariableProperty is NULL, or Name is an empty string.
|
||
|
@retval EFI_NOT_FOUND The property of variable specified by the Name and Guid was not found.
|
||
|
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
VarCheckVariablePropertyGet (
|
||
|
IN CHAR16 *Name,
|
||
|
IN EFI_GUID *Guid,
|
||
|
OUT VAR_CHECK_VARIABLE_PROPERTY *VariableProperty
|
||
|
)
|
||
|
{
|
||
|
EFI_STATUS Status;
|
||
|
|
||
|
AcquireLockOnlyAtBootTime (&mVariableModuleGlobal->VariableGlobal.VariableServicesLock);
|
||
|
Status = VarCheckLibVariablePropertyGet (Name, Guid, VariableProperty);
|
||
|
ReleaseLockOnlyAtBootTime (&mVariableModuleGlobal->VariableGlobal.VariableServicesLock);
|
||
|
|
||
|
return Status;
|
||
|
}
|
||
|
|