Home | History | Annotate | Download | only in Guid
      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