2) Add HEADER_VALID_ONLY state of variable, which represents only the header is valid and the data/name is stale. This may be caused by incomplete data updating. Adding the state helps to check whether the header is valid. If variable header is valid, then we must skip the data of variable with the valid size. If the header is invalid, we should only skip the header of variable. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@4555 6f19259b-4bc3-4df7-8a09-765794883524
186 lines
4.4 KiB
C
186 lines
4.4 KiB
C
/*++
|
|
|
|
Copyright (c) 2006 - 2007, 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.
|
|
|
|
Module Name:
|
|
|
|
Variable.h
|
|
|
|
Abstract:
|
|
|
|
Tiano PEIM to provide the variable functionality
|
|
|
|
--*/
|
|
|
|
#ifndef _PEI_VARIABLE_H
|
|
#define _PEI_VARIABLE_H
|
|
|
|
#include <PiPei.h>
|
|
#include <Ppi/ReadOnlyVariable2.h>
|
|
#include <Library/DebugLib.h>
|
|
#include <Library/PeimEntryPoint.h>
|
|
#include <Library/HobLib.h>
|
|
#include <Library/PcdLib.h>
|
|
#include <Library/BaseMemoryLib.h>
|
|
#include <Library/PeiServicesTablePointerLib.h>
|
|
#include <VariableFormat.h>
|
|
|
|
//
|
|
// Define GET_PAD_SIZE to optimize compiler
|
|
//
|
|
#if ((ALIGNMENT == 0) || (ALIGNMENT == 1))
|
|
#define GET_PAD_SIZE(a) (0)
|
|
#else
|
|
#define GET_PAD_SIZE(a) (((~a) + 1) & (ALIGNMENT - 1))
|
|
#endif
|
|
|
|
#define HEADER_ALIGN(Header) (((UINTN) (Header) + HEADER_ALIGNMENT - 1) & (~(HEADER_ALIGNMENT - 1)))
|
|
|
|
typedef struct {
|
|
VARIABLE_HEADER *CurrPtr;
|
|
VARIABLE_HEADER *EndPtr;
|
|
VARIABLE_HEADER *StartPtr;
|
|
} VARIABLE_POINTER_TRACK;
|
|
|
|
#define VARIABLE_INDEX_TABLE_VOLUME 122
|
|
|
|
#define EFI_VARIABLE_INDEX_TABLE_GUID \
|
|
{ 0x8cfdb8c8, 0xd6b2, 0x40f3, { 0x8e, 0x97, 0x02, 0x30, 0x7c, 0xc9, 0x8b, 0x7c } }
|
|
|
|
typedef struct {
|
|
UINT16 Length;
|
|
UINT16 GoneThrough;
|
|
VARIABLE_HEADER *EndPtr;
|
|
VARIABLE_HEADER *StartPtr;
|
|
UINT16 Index[VARIABLE_INDEX_TABLE_VOLUME];
|
|
} VARIABLE_INDEX_TABLE;
|
|
|
|
|
|
//
|
|
// Functions
|
|
//
|
|
EFI_STATUS
|
|
EFIAPI
|
|
PeimInitializeVariableServices (
|
|
IN EFI_FFS_FILE_HEADER *FfsHeader,
|
|
IN EFI_PEI_SERVICES **PeiServices
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
TODO: Add function description
|
|
|
|
Arguments:
|
|
|
|
FfsHeader - TODO: add argument description
|
|
PeiServices - TODO: add argument description
|
|
|
|
Returns:
|
|
|
|
TODO: add return values
|
|
|
|
--*/
|
|
;
|
|
|
|
EFI_STATUS
|
|
EFIAPI
|
|
PeiGetVariable (
|
|
IN CONST EFI_PEI_READ_ONLY_VARIABLE2_PPI *This,
|
|
IN CONST CHAR16 *VariableName,
|
|
IN CONST EFI_GUID *VariableGuid,
|
|
OUT UINT32 *Attributes,
|
|
IN OUT UINTN *DataSize,
|
|
OUT VOID *Data
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
TODO: Add function description
|
|
|
|
Arguments:
|
|
|
|
PeiServices - TODO: add argument description
|
|
VariableName - TODO: add argument description
|
|
VendorGuid - TODO: add argument description
|
|
Attributes - TODO: add argument description
|
|
DataSize - TODO: add argument description
|
|
Data - TODO: add argument description
|
|
|
|
Returns:
|
|
|
|
TODO: add return values
|
|
|
|
--*/
|
|
;
|
|
|
|
EFI_STATUS
|
|
EFIAPI
|
|
PeiGetNextVariableName (
|
|
IN CONST EFI_PEI_READ_ONLY_VARIABLE2_PPI *This,
|
|
IN OUT UINTN *VariableNameSize,
|
|
IN OUT CHAR16 *VariableName,
|
|
IN OUT EFI_GUID *VariableGuid
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
TODO: Add function description
|
|
|
|
Arguments:
|
|
|
|
PeiServices - TODO: add argument description
|
|
VariableNameSize - TODO: add argument description
|
|
VariableName - TODO: add argument description
|
|
VendorGuid - TODO: add argument description
|
|
|
|
Returns:
|
|
|
|
TODO: add return values
|
|
|
|
--*/
|
|
;
|
|
|
|
/**
|
|
Get one variable by the index count.
|
|
|
|
@param IndexTable The pointer to variable index table.
|
|
@param Count The index count of variable in index table.
|
|
|
|
@return The pointer to variable header indexed by count.
|
|
|
|
**/
|
|
VARIABLE_HEADER *
|
|
GetVariableByIndex (
|
|
IN VARIABLE_INDEX_TABLE *IndexTable,
|
|
IN UINT32 Count
|
|
);
|
|
|
|
/**
|
|
Record Variable in VariableIndex HOB.
|
|
|
|
Record Variable in VariableIndex HOB and update the length of variable index table.
|
|
|
|
@param IndexTable The pointer to variable index table.
|
|
@param Variable The pointer to the variable that will be recorded.
|
|
|
|
@retval VOID
|
|
|
|
**/
|
|
VOID
|
|
VariableIndexTableUpdate (
|
|
IN OUT VARIABLE_INDEX_TABLE *IndexTable,
|
|
IN VARIABLE_HEADER *Variable
|
|
);
|
|
|
|
#endif // _PEI_VARIABLE_H
|