Introduces two new APIs to EDKII_VARIABLE_POLICY_PROTOCOL: 1. GetVariablePolicyInfo() 2. GetLockOnVariableStateVariablePolicyInfo() These allow a caller to retrieve policy information associated with a UEFI variable given the variable name and vendor GUID. GetVariablePolicyInfo() - Returns the variable policy applied to the UEFI variable. If the variable policy is applied toward an individual UEFI variable, that name can optionally be returned. GetLockOnVariableStateVariablePolicyInfo() - Returns the Lock on Variable State policy applied to the UEFI variable. If the Lock on Variable State policy is applied to a specific variable name, that name can optionally be returned. These functions can be useful for a variety of purposes such as auditing, testing, and functional flows. Also fixed some variable name typos in code touched by the changes. Cc: Dandan Bi <dandan.bi@intel.com> Cc: Hao A Wu <hao.a.wu@intel.com> Cc: Jian J Wang <jian.j.wang@intel.com> Cc: Liming Gao <gaoliming@byosoft.com.cn> Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com> Reviewed-by: Ard Biesheuvel <ardb@kernel.org> Reviewed-by: Liming Gao <gaoliming@byosoft.com.cn> Message-Id: <20231030203112.736-2-mikuback@linux.microsoft.com>
		
			
				
	
	
		
			84 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file -- VarCheckPolicyMmiCommon.h
 | |
| This header contains communication definitions that are shared between DXE
 | |
| and the MM component of VarCheckPolicy.
 | |
| 
 | |
| Copyright (c) Microsoft Corporation.
 | |
| SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| **/
 | |
| 
 | |
| #ifndef _VAR_CHECK_POLICY_MMI_COMMON_H_
 | |
| #define _VAR_CHECK_POLICY_MMI_COMMON_H_
 | |
| 
 | |
| #define   VAR_CHECK_POLICY_COMM_SIG       SIGNATURE_32('V', 'C', 'P', 'C')
 | |
| #define   VAR_CHECK_POLICY_COMM_REVISION  1
 | |
| 
 | |
| #pragma pack(push, 1)
 | |
| 
 | |
| typedef struct _VAR_CHECK_POLICY_COMM_HEADER {
 | |
|   UINT32        Signature;
 | |
|   UINT32        Revision;
 | |
|   UINT32        Command;
 | |
|   EFI_STATUS    Result;
 | |
| } VAR_CHECK_POLICY_COMM_HEADER;
 | |
| 
 | |
| typedef struct _VAR_CHECK_POLICY_COMM_IS_ENABLED_PARAMS {
 | |
|   BOOLEAN    State;
 | |
| } VAR_CHECK_POLICY_COMM_IS_ENABLED_PARAMS;
 | |
| 
 | |
| typedef struct _VAR_CHECK_POLICY_COMM_DUMP_PARAMS {
 | |
|   UINT32     PageRequested;
 | |
|   UINT32     TotalSize;
 | |
|   UINT32     PageSize;
 | |
|   BOOLEAN    HasMore;
 | |
| } VAR_CHECK_POLICY_COMM_DUMP_PARAMS;
 | |
| 
 | |
| typedef union {
 | |
|   VARIABLE_POLICY_ENTRY                VariablePolicy;
 | |
|   VARIABLE_LOCK_ON_VAR_STATE_POLICY    LockOnVarStatePolicy;
 | |
| } VAR_CHECK_POLICY_OUTPUT_POLICY_ENTRY;
 | |
| 
 | |
| typedef struct _VAR_CHECK_POLICY_COMM_GET_INFO_PARAMS {
 | |
|   EFI_GUID                                InputVendorGuid;
 | |
|   UINT32                                  InputVariableNameSize;
 | |
|   UINT32                                  OutputVariableNameSize;
 | |
|   VAR_CHECK_POLICY_OUTPUT_POLICY_ENTRY    OutputPolicyEntry;
 | |
|   CHAR16                                  InputVariableName[1];
 | |
| } VAR_CHECK_POLICY_COMM_GET_INFO_PARAMS;
 | |
| 
 | |
| #pragma pack(pop)
 | |
| 
 | |
| #define   VAR_CHECK_POLICY_COMM_GET_INFO_PARAMS_END \
 | |
|             (OFFSET_OF(VAR_CHECK_POLICY_COMM_GET_INFO_PARAMS, InputVariableName))
 | |
| 
 | |
| // Make sure that we will hold at least the headers.
 | |
| #define   VAR_CHECK_POLICY_MM_COMM_BUFFER_SIZE  MAX((OFFSET_OF(EFI_MM_COMMUNICATE_HEADER, Data) + sizeof (VAR_CHECK_POLICY_COMM_HEADER) + EFI_PAGES_TO_SIZE(1)), EFI_PAGES_TO_SIZE(4))
 | |
| #define   VAR_CHECK_POLICY_MM_DUMP_BUFFER_SIZE  (VAR_CHECK_POLICY_MM_COMM_BUFFER_SIZE - \
 | |
|                                                     (OFFSET_OF(EFI_MM_COMMUNICATE_HEADER, Data) + \
 | |
|                                                       sizeof(VAR_CHECK_POLICY_COMM_HEADER) + \
 | |
|                                                       sizeof(VAR_CHECK_POLICY_COMM_DUMP_PARAMS)))
 | |
| 
 | |
| #define   VAR_CHECK_POLICY_MM_GET_INFO_BUFFER_SIZE  (VAR_CHECK_POLICY_MM_COMM_BUFFER_SIZE - \
 | |
|                                                       (OFFSET_OF(EFI_MM_COMMUNICATE_HEADER, Data) + \
 | |
|                                                         sizeof(VAR_CHECK_POLICY_COMM_HEADER) + \
 | |
|                                                         OFFSET_OF(VAR_CHECK_POLICY_COMM_GET_INFO_PARAMS, InputVariableName)))
 | |
| 
 | |
| STATIC_ASSERT (
 | |
|   VAR_CHECK_POLICY_MM_DUMP_BUFFER_SIZE < VAR_CHECK_POLICY_MM_COMM_BUFFER_SIZE,
 | |
|   "an integer underflow may have occurred calculating VAR_CHECK_POLICY_MM_DUMP_BUFFER_SIZE"
 | |
|   );
 | |
| 
 | |
| STATIC_ASSERT (
 | |
|   VAR_CHECK_POLICY_MM_GET_INFO_BUFFER_SIZE < VAR_CHECK_POLICY_MM_COMM_BUFFER_SIZE,
 | |
|   "an integer underflow may have occurred calculating VAR_CHECK_POLICY_MM_GET_INFO_BUFFER_SIZE"
 | |
|   );
 | |
| 
 | |
| #define   VAR_CHECK_POLICY_COMMAND_DISABLE                  0x0001
 | |
| #define   VAR_CHECK_POLICY_COMMAND_IS_ENABLED               0x0002
 | |
| #define   VAR_CHECK_POLICY_COMMAND_REGISTER                 0x0003
 | |
| #define   VAR_CHECK_POLICY_COMMAND_DUMP                     0x0004
 | |
| #define   VAR_CHECK_POLICY_COMMAND_LOCK                     0x0005
 | |
| #define   VAR_CHECK_POLICY_COMMAND_GET_INFO                 0x0006
 | |
| #define   VAR_CHECK_POLICY_COMMAND_GET_LOCK_VAR_STATE_INFO  0x0007
 | |
| 
 | |
| #endif // _VAR_CHECK_POLICY_MMI_COMMON_H_
 |