]> git.proxmox.com Git - mirror_edk2.git/blame - MdeModulePkg/Universal/Variable/Pei/Variable.h
1) Replace MACRO with C functions.
[mirror_edk2.git] / MdeModulePkg / Universal / Variable / Pei / Variable.h
CommitLineData
8d3a5c82 1/*++\r
2\r
3Copyright (c) 2006 - 2007, Intel Corporation\r
4All rights reserved. This program and the accompanying materials\r
5are licensed and made available under the terms and conditions of the BSD License\r
6which accompanies this distribution. The full text of the license may be found at\r
7http://opensource.org/licenses/bsd-license.php\r
8\r
9THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
10WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
11\r
12Module Name:\r
13\r
14 Variable.h\r
15\r
16Abstract:\r
17\r
18 Tiano PEIM to provide the variable functionality\r
19\r
20--*/\r
21\r
22#ifndef _PEI_VARIABLE_H\r
23#define _PEI_VARIABLE_H\r
24\r
25#include <PiPei.h>\r
26#include <Ppi/ReadOnlyVariable2.h>\r
27#include <Library/DebugLib.h>\r
28#include <Library/PeimEntryPoint.h>\r
29#include <Library/HobLib.h>\r
30#include <Library/PcdLib.h>\r
31#include <Library/BaseMemoryLib.h>\r
32#include <Library/PeiServicesTablePointerLib.h>\r
3cfb790c 33#include <VariableFormat.h>\r
8d3a5c82 34\r
35//\r
36// Define GET_PAD_SIZE to optimize compiler\r
37//\r
38#if ((ALIGNMENT == 0) || (ALIGNMENT == 1))\r
39#define GET_PAD_SIZE(a) (0)\r
40#else\r
41#define GET_PAD_SIZE(a) (((~a) + 1) & (ALIGNMENT - 1))\r
42#endif\r
43\r
9cad030b 44#define HEADER_ALIGN(Header) (((UINTN) (Header) + HEADER_ALIGNMENT - 1) & (~(HEADER_ALIGNMENT - 1)))\r
45\r
8d3a5c82 46typedef struct {\r
47 VARIABLE_HEADER *CurrPtr;\r
48 VARIABLE_HEADER *EndPtr;\r
49 VARIABLE_HEADER *StartPtr;\r
50} VARIABLE_POINTER_TRACK;\r
51\r
52#define VARIABLE_INDEX_TABLE_VOLUME 122\r
53\r
54#define EFI_VARIABLE_INDEX_TABLE_GUID \\r
55 { 0x8cfdb8c8, 0xd6b2, 0x40f3, { 0x8e, 0x97, 0x02, 0x30, 0x7c, 0xc9, 0x8b, 0x7c } }\r
56\r
57typedef struct {\r
58 UINT16 Length;\r
59 UINT16 GoneThrough;\r
60 VARIABLE_HEADER *EndPtr;\r
61 VARIABLE_HEADER *StartPtr;\r
62 UINT16 Index[VARIABLE_INDEX_TABLE_VOLUME];\r
63} VARIABLE_INDEX_TABLE;\r
64\r
65\r
66//\r
67// Functions\r
68//\r
69EFI_STATUS\r
70EFIAPI\r
71PeimInitializeVariableServices (\r
72 IN EFI_FFS_FILE_HEADER *FfsHeader,\r
73 IN EFI_PEI_SERVICES **PeiServices\r
74 )\r
75/*++\r
76\r
77Routine Description:\r
78\r
79 TODO: Add function description\r
80\r
81Arguments:\r
82\r
83 FfsHeader - TODO: add argument description\r
84 PeiServices - TODO: add argument description\r
85\r
86Returns:\r
87\r
88 TODO: add return values\r
89\r
90--*/\r
91;\r
92\r
93EFI_STATUS\r
94EFIAPI\r
95PeiGetVariable (\r
96 IN CONST EFI_PEI_READ_ONLY_VARIABLE2_PPI *This,\r
97 IN CONST CHAR16 *VariableName,\r
98 IN CONST EFI_GUID *VariableGuid,\r
99 OUT UINT32 *Attributes,\r
100 IN OUT UINTN *DataSize,\r
101 OUT VOID *Data\r
102 )\r
103/*++\r
104\r
105Routine Description:\r
106\r
107 TODO: Add function description\r
108\r
109Arguments:\r
110\r
111 PeiServices - TODO: add argument description\r
112 VariableName - TODO: add argument description\r
113 VendorGuid - TODO: add argument description\r
114 Attributes - TODO: add argument description\r
115 DataSize - TODO: add argument description\r
116 Data - TODO: add argument description\r
117\r
118Returns:\r
119\r
120 TODO: add return values\r
121\r
122--*/\r
123;\r
124\r
125EFI_STATUS\r
126EFIAPI\r
127PeiGetNextVariableName (\r
128 IN CONST EFI_PEI_READ_ONLY_VARIABLE2_PPI *This,\r
129 IN OUT UINTN *VariableNameSize,\r
130 IN OUT CHAR16 *VariableName,\r
131 IN OUT EFI_GUID *VariableGuid\r
132 )\r
133/*++\r
134\r
135Routine Description:\r
136\r
137 TODO: Add function description\r
138\r
139Arguments:\r
140\r
141 PeiServices - TODO: add argument description\r
142 VariableNameSize - TODO: add argument description\r
143 VariableName - TODO: add argument description\r
144 VendorGuid - TODO: add argument description\r
145\r
146Returns:\r
147\r
148 TODO: add return values\r
149\r
150--*/\r
151;\r
152\r
153/**\r
154 Get one variable by the index count.\r
155\r
156 @param IndexTable The pointer to variable index table.\r
157 @param Count The index count of variable in index table.\r
158\r
159 @return The pointer to variable header indexed by count.\r
160\r
161**/\r
162VARIABLE_HEADER *\r
163GetVariableByIndex (\r
164 IN VARIABLE_INDEX_TABLE *IndexTable,\r
165 IN UINT32 Count\r
166 );\r
167\r
168/**\r
169 Record Variable in VariableIndex HOB.\r
170\r
171 Record Variable in VariableIndex HOB and update the length of variable index table.\r
172\r
173 @param IndexTable The pointer to variable index table.\r
174 @param Variable The pointer to the variable that will be recorded.\r
175\r
176 @retval VOID\r
177\r
178**/\r
179VOID\r
180VariableIndexTableUpdate (\r
181 IN OUT VARIABLE_INDEX_TABLE *IndexTable,\r
182 IN VARIABLE_HEADER *Variable\r
183 );\r
184\r
185#endif // _PEI_VARIABLE_H\r