2020-11-09 07:45:10 +01:00
|
|
|
/** @file -- VariablePolicy.h
|
|
|
|
|
|
|
|
This protocol allows communication with Variable Policy Engine.
|
|
|
|
|
|
|
|
Copyright (c) Microsoft Corporation.
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __EDKII_VARIABLE_POLICY_PROTOCOL__
|
|
|
|
#define __EDKII_VARIABLE_POLICY_PROTOCOL__
|
|
|
|
|
2021-12-05 23:54:02 +01:00
|
|
|
#define EDKII_VARIABLE_POLICY_PROTOCOL_REVISION 0x0000000000010000
|
2020-11-09 07:45:10 +01:00
|
|
|
|
|
|
|
#define EDKII_VARIABLE_POLICY_PROTOCOL_GUID \
|
|
|
|
{ \
|
|
|
|
0x81D1675C, 0x86F6, 0x48DF, { 0xBD, 0x95, 0x9A, 0x6E, 0x4F, 0x09, 0x25, 0xC3 } \
|
|
|
|
}
|
|
|
|
|
2021-12-05 23:54:02 +01:00
|
|
|
#define VARIABLE_POLICY_ENTRY_REVISION 0x00010000
|
2020-11-09 07:45:10 +01:00
|
|
|
|
|
|
|
#pragma pack(push, 1)
|
|
|
|
typedef struct {
|
2021-12-05 23:54:02 +01:00
|
|
|
UINT32 Version;
|
|
|
|
UINT16 Size;
|
|
|
|
UINT16 OffsetToName;
|
|
|
|
EFI_GUID Namespace;
|
|
|
|
UINT32 MinSize;
|
|
|
|
UINT32 MaxSize;
|
|
|
|
UINT32 AttributesMustHave;
|
|
|
|
UINT32 AttributesCantHave;
|
|
|
|
UINT8 LockPolicyType;
|
|
|
|
UINT8 Padding[3];
|
2020-11-09 07:45:10 +01:00
|
|
|
// UINT8 LockPolicy[]; // Variable Length Field
|
|
|
|
// CHAR16 Name[] // Variable Length Field
|
|
|
|
} VARIABLE_POLICY_ENTRY;
|
|
|
|
|
2021-12-05 23:54:02 +01:00
|
|
|
#define VARIABLE_POLICY_NO_MIN_SIZE 0
|
|
|
|
#define VARIABLE_POLICY_NO_MAX_SIZE MAX_UINT32
|
|
|
|
#define VARIABLE_POLICY_NO_MUST_ATTR 0
|
|
|
|
#define VARIABLE_POLICY_NO_CANT_ATTR 0
|
2020-11-09 07:45:10 +01:00
|
|
|
|
|
|
|
#define VARIABLE_POLICY_TYPE_NO_LOCK 0
|
|
|
|
#define VARIABLE_POLICY_TYPE_LOCK_NOW 1
|
|
|
|
#define VARIABLE_POLICY_TYPE_LOCK_ON_CREATE 2
|
|
|
|
#define VARIABLE_POLICY_TYPE_LOCK_ON_VAR_STATE 3
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:02 +01:00
|
|
|
EFI_GUID Namespace;
|
|
|
|
UINT8 Value;
|
|
|
|
UINT8 Padding;
|
2020-11-09 07:45:10 +01:00
|
|
|
// CHAR16 Name[]; // Variable Length Field
|
|
|
|
} VARIABLE_LOCK_ON_VAR_STATE_POLICY;
|
|
|
|
#pragma pack(pop)
|
|
|
|
|
|
|
|
/**
|
|
|
|
This API function disables the variable policy enforcement. If it's
|
|
|
|
already been called once, will return EFI_ALREADY_STARTED.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS
|
|
|
|
@retval EFI_ALREADY_STARTED Has already been called once this boot.
|
|
|
|
@retval EFI_WRITE_PROTECTED Interface has been locked until reboot.
|
|
|
|
@retval EFI_WRITE_PROTECTED Interface option is disabled by platform PCD.
|
|
|
|
|
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *DISABLE_VARIABLE_POLICY)(
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
This API function returns whether or not the policy engine is
|
|
|
|
currently being enforced.
|
|
|
|
|
|
|
|
@param[out] State Pointer to a return value for whether the policy enforcement
|
|
|
|
is currently enabled.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS
|
|
|
|
@retval Others An error has prevented this command from completing.
|
|
|
|
|
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *IS_VARIABLE_POLICY_ENABLED)(
|
|
|
|
OUT BOOLEAN *State
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
This API function validates and registers a new policy with
|
|
|
|
the policy enforcement engine.
|
|
|
|
|
|
|
|
@param[in] NewPolicy Pointer to the incoming policy structure.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS
|
|
|
|
@retval EFI_INVALID_PARAMETER NewPolicy is NULL or is internally inconsistent.
|
|
|
|
@retval EFI_ALREADY_STARTED An identical matching policy already exists.
|
|
|
|
@retval EFI_WRITE_PROTECTED The interface has been locked until the next reboot.
|
|
|
|
@retval EFI_ABORTED A calculation error has prevented this function from completing.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Cannot grow the table to hold any more policies.
|
|
|
|
|
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *REGISTER_VARIABLE_POLICY)(
|
|
|
|
IN CONST VARIABLE_POLICY_ENTRY *PolicyEntry
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
This API function will dump the entire contents of the variable policy table.
|
|
|
|
|
|
|
|
Similar to GetVariable, the first call can be made with a 0 size and it will return
|
|
|
|
the size of the buffer required to hold the entire table.
|
|
|
|
|
|
|
|
@param[out] Policy Pointer to the policy buffer. Can be NULL if Size is 0.
|
|
|
|
@param[in,out] Size On input, the size of the output buffer. On output, the size
|
|
|
|
of the data returned.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Policy data is in the output buffer and Size has been updated.
|
|
|
|
@retval EFI_INVALID_PARAMETER Size is NULL, or Size is non-zero and Policy is NULL.
|
|
|
|
@retval EFI_BUFFER_TOO_SMALL Size is insufficient to hold policy. Size updated with required size.
|
|
|
|
|
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *DUMP_VARIABLE_POLICY)(
|
|
|
|
IN OUT UINT8 *Policy,
|
|
|
|
IN OUT UINT32 *Size
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
This API function locks the interface so that no more policy updates
|
|
|
|
can be performed or changes made to the enforcement until the next boot.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS
|
|
|
|
@retval Others An error has prevented this command from completing.
|
|
|
|
|
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *LOCK_VARIABLE_POLICY)(
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:02 +01:00
|
|
|
UINT64 Revision;
|
|
|
|
DISABLE_VARIABLE_POLICY DisableVariablePolicy;
|
|
|
|
IS_VARIABLE_POLICY_ENABLED IsVariablePolicyEnabled;
|
|
|
|
REGISTER_VARIABLE_POLICY RegisterVariablePolicy;
|
|
|
|
DUMP_VARIABLE_POLICY DumpVariablePolicy;
|
|
|
|
LOCK_VARIABLE_POLICY LockVariablePolicy;
|
2020-11-09 07:45:10 +01:00
|
|
|
} _EDKII_VARIABLE_POLICY_PROTOCOL;
|
|
|
|
|
|
|
|
typedef _EDKII_VARIABLE_POLICY_PROTOCOL EDKII_VARIABLE_POLICY_PROTOCOL;
|
|
|
|
|
2021-12-05 23:54:02 +01:00
|
|
|
extern EFI_GUID gEdkiiVariablePolicyProtocolGuid;
|
2020-11-09 07:45:10 +01:00
|
|
|
|
|
|
|
#endif
|