]> git.proxmox.com Git - mirror_edk2.git/blame - Nt32Pkg/FvbServicesRuntimeDxe/FvbInfo.c
Add FvbServicesRuntimeDxe into Nt32Pkg
[mirror_edk2.git] / Nt32Pkg / FvbServicesRuntimeDxe / FvbInfo.c
CommitLineData
55e6660f 1/*++\r
2\r
3Copyright (c) 2006, 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 FvbInfo.c\r
15\r
16Abstract:\r
17\r
18 Defines data structure that is the volume header found.These data is intent\r
19 to decouple FVB driver with FV header.\r
20\r
21--*/\r
22\r
23//\r
24// The package level header files this module uses\r
25//\r
26#include <PiDxe.h>\r
27#include <WinNtDxe.h>\r
28//\r
29// The protocols, PPI and GUID defintions for this module\r
30//\r
31#include <Guid/EventGroup.h>\r
32#include <Guid/FirmwareFileSystem2.h>\r
33#include <Guid/SystemNvDataGuid.h>\r
34#include <Protocol/FvbExtension.h>\r
35#include <Protocol/FirmwareVolumeBlock.h>\r
36#include <Guid/AlternateFvBlock.h>\r
37#include <Protocol/DevicePath.h>\r
38//\r
39// The Library classes this module consumes\r
40//\r
41#include <Library/UefiLib.h>\r
42#include <Library/UefiDriverEntryPoint.h>\r
43#include <Library/BaseLib.h>\r
44#include <Library/DxeServicesTableLib.h>\r
45#include <Library/UefiRuntimeLib.h>\r
46#include <Library/DebugLib.h>\r
47#include <Library/HobLib.h>\r
48#include <Library/BaseMemoryLib.h>\r
49#include <Library/MemoryAllocationLib.h>\r
50#include <Library/UefiBootServicesTableLib.h>\r
51\r
52#include "FlashLayout.h"\r
53\r
54#define FIRMWARE_BLOCK_SIZE 0x10000\r
55\r
56typedef struct {\r
57 UINT64 FvLength;\r
58 EFI_FIRMWARE_VOLUME_HEADER FvbInfo;\r
59 //\r
60 // EFI_FV_BLOCK_MAP_ENTRY ExtraBlockMap[n];//n=0\r
61 //\r
62 EFI_FV_BLOCK_MAP_ENTRY End[1];\r
63} EFI_FVB_MEDIA_INFO;\r
64\r
65#define FVB_MEDIA_BLOCK_SIZE FIRMWARE_BLOCK_SIZE\r
66#define RECOVERY_BOIS_BLOCK_NUM FIRMWARE_BLOCK_NUMBER\r
67#define SYSTEM_NV_BLOCK_NUM 2\r
68\r
69EFI_FVB_MEDIA_INFO mPlatformFvbMediaInfo[] = {\r
70 //\r
71 // Recovery BOIS FVB\r
72 //\r
73 {\r
74 EFI_WINNT_FIRMWARE_LENGTH,\r
75 {\r
76 {\r
77 0,\r
78 }, // ZeroVector[16]\r
79 EFI_FIRMWARE_FILE_SYSTEM2_GUID,\r
80 FVB_MEDIA_BLOCK_SIZE * RECOVERY_BOIS_BLOCK_NUM,\r
81 EFI_FVH_SIGNATURE,\r
82 EFI_FVB2_READ_ENABLED_CAP |\r
83 EFI_FVB2_READ_STATUS |\r
84 EFI_FVB2_WRITE_ENABLED_CAP |\r
85 EFI_FVB2_WRITE_STATUS |\r
86 EFI_FVB2_ERASE_POLARITY,\r
87 sizeof (EFI_FIRMWARE_VOLUME_HEADER) + sizeof (EFI_FV_BLOCK_MAP_ENTRY),\r
88 0, // CheckSum\r
89 0, // ExtHeaderOffset\r
90 {\r
91 0,\r
92 }, // Reserved[1]\r
93 1, // Revision\r
94 {\r
95 RECOVERY_BOIS_BLOCK_NUM,\r
96 FVB_MEDIA_BLOCK_SIZE,\r
97 }\r
98 },\r
99 {\r
100 0,\r
101 0\r
102 }\r
103 },\r
104 //\r
105 // Systen NvStorage FVB\r
106 //\r
107 {\r
108 EFI_WINNT_RUNTIME_UPDATABLE_LENGTH + EFI_WINNT_FTW_SPARE_BLOCK_LENGTH,\r
109 {\r
110 {\r
111 0,\r
112 }, // ZeroVector[16]\r
113 EFI_SYSTEM_NV_DATA_HOB_GUID,\r
114 FVB_MEDIA_BLOCK_SIZE * SYSTEM_NV_BLOCK_NUM,\r
115 EFI_FVH_SIGNATURE,\r
116 EFI_FVB2_READ_ENABLED_CAP |\r
117 EFI_FVB2_READ_STATUS |\r
118 EFI_FVB2_WRITE_ENABLED_CAP |\r
119 EFI_FVB2_WRITE_STATUS |\r
120 EFI_FVB2_ERASE_POLARITY,\r
121 sizeof (EFI_FIRMWARE_VOLUME_HEADER) + sizeof (EFI_FV_BLOCK_MAP_ENTRY),\r
122 0, // CheckSum\r
123 0, // ExtHeaderOffset\r
124 {\r
125 0,\r
126 }, // Reserved[1]\r
127 1, // Revision\r
128 {\r
129 SYSTEM_NV_BLOCK_NUM,\r
130 FVB_MEDIA_BLOCK_SIZE,\r
131 }\r
132 },\r
133 {\r
134 0,\r
135 0\r
136 }\r
137 }\r
138};\r
139\r
140EFI_STATUS\r
141GetFvbInfo (\r
142 IN UINT64 FvLength,\r
143 OUT EFI_FIRMWARE_VOLUME_HEADER **FvbInfo\r
144 )\r
145{\r
146 UINTN Index;\r
147\r
148 for (Index = 0; Index < sizeof (mPlatformFvbMediaInfo) / sizeof (EFI_FVB_MEDIA_INFO); Index += 1) {\r
149 if (mPlatformFvbMediaInfo[Index].FvLength == FvLength) {\r
150 *FvbInfo = &mPlatformFvbMediaInfo[Index].FvbInfo;\r
151 return EFI_SUCCESS;\r
152 }\r
153 }\r
154\r
155 return EFI_NOT_FOUND;\r
156}\r