summaryrefslogtreecommitdiff
path: root/MdeModulePkg/Include/Guid/VariableInfo.h
blob: 27a4dafea020b3bbbb6844f472ad445ae399f358 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/** @file
  This file defines variable info guid and variable info entry.
  This guid is used to specify the variable list put in the EFI system table.

Copyright (c) 2006 - 2009, Intel Corporation
All rights reserved. This program and the accompanying materials
are licensed and made available under the terms and conditions of the BSD License
which accompanies this distribution.  The full text of the license may be found at
http://opensource.org/licenses/bsd-license.php

THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.

**/

#ifndef __VARIABLE_INFO_GUID_H__
#define __VARIABLE_INFO_GUID_H__

#define EFI_VARIABLE_INFO_GUID \
  { 0xddcf3616, 0x3275, 0x4164, { 0x98, 0xb6, 0xfe, 0x85, 0x70, 0x7f, 0xfe, 0x7d } }

extern EFI_GUID gEfiVariableInfoGuid;


typedef struct _VARIABLE_INFO_ENTRY  VARIABLE_INFO_ENTRY;

///
/// This structure contains the variable list that is put in EFI system table.
/// The variable driver collects all used variables at boot service time and produce this list.
/// This is an optional feature to dump all used variables in shell environment. 
///
struct _VARIABLE_INFO_ENTRY {
  VARIABLE_INFO_ENTRY *Next;       ///> Pointer to next entry
  EFI_GUID            VendorGuid;  ///> Guid of Variable 
  CHAR16              *Name;       ///> Name of Variable 
  UINT32              Attributes;  ///> Attributes of variable defined in UEFI spec
  UINT32              ReadCount;   ///> Times to read this variable
  UINT32              WriteCount;  ///> Times to write this variable
  UINT32              DeleteCount; ///> Times to delete this variable
  UINT32              CacheCount;  ///> Times that cache hits this variable
  BOOLEAN             Volatile;    ///> TRUE if volatile FALSE if non-volatile
};

#endif