• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /** @file
2   The variable data structures are related to EDK II-specific implementation of UEFI variables.
3   VariableFormat.h defines variable data headers and variable storage region headers.
4 
5 Copyright (c) 2006 - 2011, Intel Corporation. All rights reserved.<BR>
6 This program and the accompanying materials are licensed and made available under
7 the terms and conditions of the BSD License that accompanies this distribution.
8 The full text of the license may be found at
9 http://opensource.org/licenses/bsd-license.php.
10 
11 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
13 
14 **/
15 
16 #ifndef __VARIABLE_INDEX_TABLE_H__
17 #define __VARIABLE_INDEX_TABLE_H__
18 
19 typedef struct {
20   VARIABLE_HEADER *CurrPtr;
21   VARIABLE_HEADER *EndPtr;
22   VARIABLE_HEADER *StartPtr;
23 } VARIABLE_POINTER_TRACK;
24 
25 #define VARIABLE_INDEX_TABLE_VOLUME 122
26 
27 #define EFI_VARIABLE_INDEX_TABLE_GUID \
28   { 0x8cfdb8c8, 0xd6b2, 0x40f3, { 0x8e, 0x97, 0x02, 0x30, 0x7c, 0xc9, 0x8b, 0x7c } }
29 
30 extern EFI_GUID gEfiVariableIndexTableGuid;
31 
32 ///
33 /// Use this data structure to store variable-related info, which can decrease
34 /// the cost of access to NV.
35 ///
36 typedef struct {
37   UINT16          Length;
38   UINT16          GoneThrough;
39   VARIABLE_HEADER *EndPtr;
40   VARIABLE_HEADER *StartPtr;
41   ///
42   /// This field is used to store the distance of two neighbouring VAR_ADDED type variables.
43   /// The meaning of the field is implement-dependent.
44   UINT16          Index[VARIABLE_INDEX_TABLE_VOLUME];
45 } VARIABLE_INDEX_TABLE;
46 
47 #endif // __VARIABLE_INDEX_TABLE_H__
48