3 The internal header file includes the common header files, defines
4 internal structure and functions used by RuntimeVariable module.
6 Copyright (c) 2006 - 2008, Intel Corporation
7 All rights reserved. This program and the accompanying materials
8 are licensed and made available under the terms and conditions of the BSD License
9 which accompanies this distribution. The full text of the license may be found at
10 http://opensource.org/licenses/bsd-license.php
12 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
13 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
21 #include <Protocol/VariableWrite.h>
22 #include <Protocol/FaultTolerantWrite.h>
23 #include <Protocol/FirmwareVolumeBlock.h>
24 #include <Protocol/Variable.h>
25 #include <Library/PcdLib.h>
26 #include <Library/UefiDriverEntryPoint.h>
27 #include <Library/DxeServicesTableLib.h>
28 #include <Library/UefiRuntimeLib.h>
29 #include <Library/DebugLib.h>
30 #include <Library/BaseMemoryLib.h>
31 #include <Library/UefiBootServicesTableLib.h>
32 #include <Library/UefiLib.h>
33 #include <Library/BaseLib.h>
34 #include <Library/SynchronizationLib.h>
35 #include <Library/MemoryAllocationLib.h>
36 #include <Guid/GlobalVariable.h>
37 #include <Guid/EventGroup.h>
38 #include <Guid/VariableFormat.h>
40 #define VARIABLE_RECLAIM_THRESHOLD (1024)
43 VARIABLE_HEADER
*CurrPtr
;
44 VARIABLE_HEADER
*EndPtr
;
45 VARIABLE_HEADER
*StartPtr
;
47 } VARIABLE_POINTER_TRACK
;
50 EFI_PHYSICAL_ADDRESS VolatileVariableBase
;
51 EFI_PHYSICAL_ADDRESS NonVolatileVariableBase
;
52 EFI_LOCK VariableServicesLock
;
53 UINT32 ReentrantState
;
57 VARIABLE_GLOBAL VariableGlobal
;
58 UINTN VolatileLastVariableOffset
;
59 UINTN NonVolatileLastVariableOffset
;
60 UINTN CommonVariableTotalSize
;
61 UINTN HwErrVariableTotalSize
;
62 CHAR8 PlatformLangCodes
[256]; //Pre-allocate 256 bytes space to accommodate the PlatformlangCodes.
63 CHAR8 LangCodes
[256]; //Pre-allocate 256 bytes space to accommodate the langCodes.
64 CHAR8 PlatformLang
[8]; //Pre-allocate 8 bytes space to accommodate the Platformlang variable.
65 CHAR8 Lang
[4]; //Pre-allocate 4 bytes space to accommodate the lang variable.
66 EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL
*FvbInstance
;
67 } VARIABLE_MODULE_GLOBAL
;
75 } VARIABLE_CACHE_ENTRY
;
78 Writes a buffer to variable storage space, in the working block.
80 This function writes a buffer to variable storage space into firmware
81 volume block device. The destination is specified by parameter
82 VariableBase. Fault Tolerant Write protocol is used for writing.
84 @param VariableBase Base address of variable to write
85 @param Buffer Point to the data buffer
86 @param BufferSize The number of bytes of the data Buffer
88 @retval EFI_SUCCESS The function completed successfully
89 @retval EFI_NOT_FOUND Fail to locate Fault Tolerant Write protocol
90 @retval EFI_ABORTED The function could not complete successfully
95 IN EFI_PHYSICAL_ADDRESS VariableBase
,