iPXE
PiFirmwareVolume.h
Go to the documentation of this file.
1 /** @file
2  The firmware volume related definitions in PI.
3 
4  Copyright (c) 2006 - 2017, Intel Corporation. All rights reserved.<BR>
5  SPDX-License-Identifier: BSD-2-Clause-Patent
6 
7  @par Revision Reference:
8  PI Version 1.6
9 
10 **/
11 
12 #ifndef __PI_FIRMWAREVOLUME_H__
13 #define __PI_FIRMWAREVOLUME_H__
14 
15 FILE_LICENCE ( BSD2_PATENT );
16 FILE_SECBOOT ( PERMITTED );
17 
18 ///
19 /// EFI_FV_FILE_ATTRIBUTES
20 ///
22 
23 //
24 // Value of EFI_FV_FILE_ATTRIBUTES.
25 //
26 #define EFI_FV_FILE_ATTRIB_ALIGNMENT 0x0000001F
27 #define EFI_FV_FILE_ATTRIB_FIXED 0x00000100
28 #define EFI_FV_FILE_ATTRIB_MEMORY_MAPPED 0x00000200
29 
30 ///
31 /// type of EFI FVB attribute
32 ///
34 
35 //
36 // Attributes bit definitions
37 //
38 #define EFI_FVB2_READ_DISABLED_CAP 0x00000001
39 #define EFI_FVB2_READ_ENABLED_CAP 0x00000002
40 #define EFI_FVB2_READ_STATUS 0x00000004
41 #define EFI_FVB2_WRITE_DISABLED_CAP 0x00000008
42 #define EFI_FVB2_WRITE_ENABLED_CAP 0x00000010
43 #define EFI_FVB2_WRITE_STATUS 0x00000020
44 #define EFI_FVB2_LOCK_CAP 0x00000040
45 #define EFI_FVB2_LOCK_STATUS 0x00000080
46 #define EFI_FVB2_STICKY_WRITE 0x00000200
47 #define EFI_FVB2_MEMORY_MAPPED 0x00000400
48 #define EFI_FVB2_ERASE_POLARITY 0x00000800
49 #define EFI_FVB2_READ_LOCK_CAP 0x00001000
50 #define EFI_FVB2_READ_LOCK_STATUS 0x00002000
51 #define EFI_FVB2_WRITE_LOCK_CAP 0x00004000
52 #define EFI_FVB2_WRITE_LOCK_STATUS 0x00008000
53 #define EFI_FVB2_ALIGNMENT 0x001F0000
54 #define EFI_FVB2_ALIGNMENT_1 0x00000000
55 #define EFI_FVB2_ALIGNMENT_2 0x00010000
56 #define EFI_FVB2_ALIGNMENT_4 0x00020000
57 #define EFI_FVB2_ALIGNMENT_8 0x00030000
58 #define EFI_FVB2_ALIGNMENT_16 0x00040000
59 #define EFI_FVB2_ALIGNMENT_32 0x00050000
60 #define EFI_FVB2_ALIGNMENT_64 0x00060000
61 #define EFI_FVB2_ALIGNMENT_128 0x00070000
62 #define EFI_FVB2_ALIGNMENT_256 0x00080000
63 #define EFI_FVB2_ALIGNMENT_512 0x00090000
64 #define EFI_FVB2_ALIGNMENT_1K 0x000A0000
65 #define EFI_FVB2_ALIGNMENT_2K 0x000B0000
66 #define EFI_FVB2_ALIGNMENT_4K 0x000C0000
67 #define EFI_FVB2_ALIGNMENT_8K 0x000D0000
68 #define EFI_FVB2_ALIGNMENT_16K 0x000E0000
69 #define EFI_FVB2_ALIGNMENT_32K 0x000F0000
70 #define EFI_FVB2_ALIGNMENT_64K 0x00100000
71 #define EFI_FVB2_ALIGNMENT_128K 0x00110000
72 #define EFI_FVB2_ALIGNMENT_256K 0x00120000
73 #define EFI_FVB2_ALIGNMENT_512K 0x00130000
74 #define EFI_FVB2_ALIGNMENT_1M 0x00140000
75 #define EFI_FVB2_ALIGNMENT_2M 0x00150000
76 #define EFI_FVB2_ALIGNMENT_4M 0x00160000
77 #define EFI_FVB2_ALIGNMENT_8M 0x00170000
78 #define EFI_FVB2_ALIGNMENT_16M 0x00180000
79 #define EFI_FVB2_ALIGNMENT_32M 0x00190000
80 #define EFI_FVB2_ALIGNMENT_64M 0x001A0000
81 #define EFI_FVB2_ALIGNMENT_128M 0x001B0000
82 #define EFI_FVB2_ALIGNMENT_256M 0x001C0000
83 #define EFI_FVB2_ALIGNMENT_512M 0x001D0000
84 #define EFI_FVB2_ALIGNMENT_1G 0x001E0000
85 #define EFI_FVB2_ALIGNMENT_2G 0x001F0000
86 #define EFI_FVB2_WEAK_ALIGNMENT 0x80000000
87 
88 typedef struct {
89  ///
90  /// The number of sequential blocks which are of the same size.
91  ///
93  ///
94  /// The size of the blocks.
95  ///
98 
99 ///
100 /// Describes the features and layout of the firmware volume.
101 ///
102 typedef struct {
103  ///
104  /// The first 16 bytes are reserved to allow for the reset vector of
105  /// processors whose reset vector is at address 0.
106  ///
107  UINT8 ZeroVector[16];
108  ///
109  /// Declares the file system with which the firmware volume is formatted.
110  ///
112  ///
113  /// Length in bytes of the complete firmware volume, including the header.
114  ///
116  ///
117  /// Set to EFI_FVH_SIGNATURE
118  ///
120  ///
121  /// Declares capabilities and power-on defaults for the firmware volume.
122  ///
124  ///
125  /// Length in bytes of the complete firmware volume header.
126  ///
128  ///
129  /// A 16-bit checksum of the firmware volume header. A valid header sums to zero.
130  ///
132  ///
133  /// Offset, relative to the start of the header, of the extended header
134  /// (EFI_FIRMWARE_VOLUME_EXT_HEADER) or zero if there is no extended header.
135  ///
137  ///
138  /// This field must always be set to zero.
139  ///
141  ///
142  /// Set to 2. Future versions of this specification may define new header fields and will
143  /// increment the Revision field accordingly.
144  ///
146  ///
147  /// An array of run-length encoded FvBlockMapEntry structures. The array is
148  /// terminated with an entry of {0,0}.
149  ///
152 
153 #define EFI_FVH_SIGNATURE SIGNATURE_32 ('_', 'F', 'V', 'H')
154 
155 ///
156 /// Firmware Volume Header Revision definition
157 ///
158 #define EFI_FVH_REVISION 0x02
159 
160 ///
161 /// Extension header pointed by ExtHeaderOffset of volume header.
162 ///
163 typedef struct {
164  ///
165  /// Firmware volume name.
166  ///
168  ///
169  /// Size of the rest of the extension header, including this structure.
170  ///
173 
174 ///
175 /// Entry struture for describing FV extension header
176 ///
177 typedef struct {
178  ///
179  /// Size of this header extension.
180  ///
182  ///
183  /// Type of the header.
184  ///
187 
188 #define EFI_FV_EXT_TYPE_OEM_TYPE 0x01
189 ///
190 /// This extension header provides a mapping between a GUID and an OEM file type.
191 ///
192 typedef struct {
193  ///
194  /// Standard extension entry, with the type EFI_FV_EXT_TYPE_OEM_TYPE.
195  ///
197  ///
198  /// A bit mask, one bit for each file type between 0xC0 (bit 0) and 0xDF (bit 31). If a bit
199  /// is '1', then the GUID entry exists in Types. If a bit is '0' then no GUID entry exists in Types.
200  ///
202  ///
203  /// An array of GUIDs, each GUID representing an OEM file type.
204  ///
205  /// EFI_GUID Types[1];
206  ///
208 
209 #define EFI_FV_EXT_TYPE_GUID_TYPE 0x0002
210 
211 ///
212 /// This extension header EFI_FIRMWARE_VOLUME_EXT_ENTRY_GUID_TYPE provides a vendor specific
213 /// GUID FormatType type which includes a length and a successive series of data bytes.
214 ///
215 typedef struct {
216  ///
217  /// Standard extension entry, with the type EFI_FV_EXT_TYPE_OEM_TYPE.
218  ///
220  ///
221  /// Vendor-specific GUID.
222  ///
224  ///
225  /// An arry of bytes of length Length.
226  ///
227  /// UINT8 Data[1];
228  ///
230 
231 #define EFI_FV_EXT_TYPE_USED_SIZE_TYPE 0x03
232 
233 ///
234 /// The EFI_FIRMWARE_VOLUME_EXT_ENTRY_USED_SIZE_TYPE can be used to find
235 /// out how many EFI_FVB2_ERASE_POLARITY bytes are at the end of the FV.
236 ///
237 typedef struct {
238  ///
239  /// Standard extension entry, with the type EFI_FV_EXT_TYPE_USED_SIZE_TYPE.
240  ///
242  ///
243  /// The number of bytes of the FV that are in uses. The remaining
244  /// EFI_FIRMWARE_VOLUME_HEADER FvLength minus UsedSize bytes in
245  /// the FV must contain the value implied by EFI_FVB2_ERASE_POLARITY.
246  ///
249 
250 #endif
Entry struture for describing FV extension header.
UINT16 Checksum
A 16-bit checksum of the firmware volume header.
UINT32_t Reserved[2]
Must be zero.
Definition: pxe_api.h:76
128 bit buffer containing a unique identifier value.
Definition: Base.h:216
UINT32 UsedSize
The number of bytes of the FV that are in uses.
EFI_GUID FvName
Firmware volume name.
This extension header provides a mapping between a GUID and an OEM file type.
unsigned int UINT32
Definition: ProcessorBind.h:99
unsigned char UINT8
UINT32 Signature
Set to EFI_FVH_SIGNATURE.
EFI_GUID FormatType
Vendor-specific GUID.
UINT32 EFI_FV_FILE_ATTRIBUTES
EFI_FV_FILE_ATTRIBUTES.
FILE_LICENCE(BSD2_PATENT)
EFI_FVB_ATTRIBUTES_2 Attributes
Declares capabilities and power-on defaults for the firmware volume.
UINT16 HeaderLength
Length in bytes of the complete firmware volume header.
UINT32 NumBlocks
The number of sequential blocks which are of the same size.
UINT32 TypeMask
A bit mask, one bit for each file type between 0xC0 (bit 0) and 0xDF (bit 31).
UINT64 FvLength
Length in bytes of the complete firmware volume, including the header.
unsigned short UINT16
This extension header EFI_FIRMWARE_VOLUME_EXT_ENTRY_GUID_TYPE provides a vendor specific GUID FormatT...
UINT16 ExtHeaderOffset
Offset, relative to the start of the header, of the extended header (EFI_FIRMWARE_VOLUME_EXT_HEADER) ...
UINT32 EFI_FVB_ATTRIBUTES_2
type of EFI FVB attribute
UINT16 ExtEntrySize
Size of this header extension.
EFI_FIRMWARE_VOLUME_EXT_ENTRY Hdr
Standard extension entry, with the type EFI_FV_EXT_TYPE_OEM_TYPE.
The EFI_FIRMWARE_VOLUME_EXT_ENTRY_USED_SIZE_TYPE can be used to find out how many EFI_FVB2_ERASE_POLA...
unsigned long long UINT64
Definition: ProcessorBind.h:97
Extension header pointed by ExtHeaderOffset of volume header.
EFI_GUID FileSystemGuid
Declares the file system with which the firmware volume is formatted.
Describes the features and layout of the firmware volume.
UINT32 Length
The size of the blocks.
EFI_FIRMWARE_VOLUME_EXT_ENTRY Hdr
Standard extension entry, with the type EFI_FV_EXT_TYPE_OEM_TYPE.
EFI_FIRMWARE_VOLUME_EXT_ENTRY Hdr
Standard extension entry, with the type EFI_FV_EXT_TYPE_USED_SIZE_TYPE.
UINT32 ExtHeaderSize
Size of the rest of the extension header, including this structure.
UINT16 ExtEntryType
Type of the header.
FILE_SECBOOT(PERMITTED)