blob: 4001ae6c9cc723b22e8451f712fd61f8745e1936 [file] [log] [blame]
/** @file
Internal structure for Var Check Pcd.
Copyright (c) 2015 - 2018, Intel Corporation. All rights reserved.<BR>
SPDX-License-Identifier: BSD-2-Clause-Patent
**/
#ifndef _VAR_CHECK_STRUCTURE_H_
#define _VAR_CHECK_STRUCTURE_H_
//
// Alignment for PCD Variable and check data header.
//
#define HEADER_ALIGNMENT 4
#define HEADER_ALIGN(Header) (((UINTN) (Header) + HEADER_ALIGNMENT - 1) & (~(HEADER_ALIGNMENT - 1)))
#pragma pack (1)
#define VAR_CHECK_PCD_REVISION 0x0001
typedef enum {
VarCheckPcdVariableHeader,
VarCheckPcdValidList,
VarCheckPcdValidRange,
VarCheckPcdCheckTypeMax,
} VAR_CHECK_PCD_CHECK_TYPE;
typedef struct {
UINT16 Revision;
UINT16 HeaderLength;
UINT32 Length; // Length include this header
UINT8 Type;
UINT8 Reserved[3];
UINT32 Attributes;
EFI_GUID Guid;
// CHAR16 Name[];
} VAR_CHECK_PCD_VARIABLE_HEADER;
typedef struct {
UINT8 Type;
UINT8 Length; // Length include this header
UINT16 VarOffset;
UINT8 StorageWidth;
} VAR_CHECK_PCD_VALID_DATA_HEADER;
typedef struct {
UINT8 Type;
UINT8 Length; // Length include this header
UINT16 VarOffset;
UINT8 StorageWidth;
// UINTx Data[]; // x = UINT8/UINT16/UINT32/UINT64;
} VAR_CHECK_PCD_VALID_LIST;
// typedef struct {
// UINTx Minimum; // x = UINT8/UINT16/UINT32/UINT64
// UINTx Maximum; // x = UINT8/UINT16/UINT32/UINT64
// } VAR_CHECK_PCD_VALID_RANGE_DATA;
typedef struct {
UINT8 Type;
UINT8 Length; // Length include this header
UINT16 VarOffset;
UINT8 StorageWidth;
// VAR_CHECK_PCD_VALID_RANGE_DATA ValidRange[];
} VAR_CHECK_PCD_VALID_RANGE;
#pragma pack ()
#endif