OpenCore  1.0.4
OpenCore Bootloader
Loading...
Searching...
No Matches
EfiImageFormat.h
Go to the documentation of this file.
1/*++
2
3Copyright (c) 2004, Intel Corporation. All rights reserved.<BR>
4This program and the accompanying materials
5are licensed and made available under the terms and conditions of the BSD License
6which accompanies this distribution. The full text of the license may be found at
7http://opensource.org/licenses/bsd-license.php
8
9THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
10WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
11
12Module Name:
13
14 EfiImageFormat.h
15
16Abstract:
17
18 This file defines the data structures that are architecturally defined for file
19 images loaded via the FirmwareVolume protocol. The Firmware Volume specification
20 is the basis for these definitions.
21
22--*/
23
24#ifndef _EFI_IMAGE_FORMAT_H_
25#define _EFI_IMAGE_FORMAT_H_
26
27//
28// pack all data structures since this is actually a binary format and we cannot
29// allow internal padding in the data structures because of some compilerism..
30//
31#pragma pack(1)
32//
33// ////////////////////////////////////////////////////////////////////////////
34//
35// Architectural file types
36//
37typedef UINT8 EFI_FV_FILETYPE;
38
39#define EFI_FV_FILETYPE_ALL 0x00
40#define EFI_FV_FILETYPE_RAW 0x01
41#define EFI_FV_FILETYPE_FREEFORM 0x02
42#define EFI_FV_FILETYPE_SECURITY_CORE 0x03
43#define EFI_FV_FILETYPE_PEI_CORE 0x04
44#define EFI_FV_FILETYPE_DXE_CORE 0x05
45#define EFI_FV_FILETYPE_PEIM 0x06
46#define EFI_FV_FILETYPE_DRIVER 0x07
47#define EFI_FV_FILETYPE_COMBINED_PEIM_DRIVER 0x08
48#define EFI_FV_FILETYPE_APPLICATION 0x09
49//
50// File type 0x0A is reserved and should not be used
51//
52#define EFI_FV_FILETYPE_FIRMWARE_VOLUME_IMAGE 0x0B
53
54//
55// ////////////////////////////////////////////////////////////////////////////
56//
57// Section types
58//
59typedef UINT8 EFI_SECTION_TYPE;
60
61//
62// ************************************************************
63// The section type EFI_SECTION_ALL is a psuedo type. It is
64// used as a wildcard when retrieving sections. The section
65// type EFI_SECTION_ALL matches all section types.
66// ************************************************************
67//
68#define EFI_SECTION_ALL 0x00
69
70//
71// ************************************************************
72// Encapsulation section Type values
73// ************************************************************
74//
75#define EFI_SECTION_COMPRESSION 0x01
76#define EFI_SECTION_GUID_DEFINED 0x02
77
78//
79// ************************************************************
80// Leaf section Type values
81// ************************************************************
82//
83#define EFI_SECTION_FIRST_LEAF_SECTION_TYPE 0x10
84
85#define EFI_SECTION_PE32 0x10
86#define EFI_SECTION_PIC 0x11
87#define EFI_SECTION_TE 0x12
88#define EFI_SECTION_DXE_DEPEX 0x13
89#define EFI_SECTION_VERSION 0x14
90#define EFI_SECTION_USER_INTERFACE 0x15
91#define EFI_SECTION_COMPATIBILITY16 0x16
92#define EFI_SECTION_FIRMWARE_VOLUME_IMAGE 0x17
93#define EFI_SECTION_FREEFORM_SUBTYPE_GUID 0x18
94#define EFI_SECTION_RAW 0x19
95#define EFI_SECTION_PEI_DEPEX 0x1B
96
97#define EFI_SECTION_LAST_LEAF_SECTION_TYPE 0x1B
98#define EFI_SECTION_LAST_SECTION_TYPE 0x1B
99
100//
101// ////////////////////////////////////////////////////////////////////////////
102//
103// Common section header
104//
105typedef struct {
106 UINT8 Size[3];
107 UINT8 Type;
109
110#define SECTION_SIZE(SectionHeaderPtr) \
111 ((UINT32) (*((UINT32 *) ((EFI_COMMON_SECTION_HEADER *) SectionHeaderPtr)->Size) & 0x00ffffff))
112
113//
114// ////////////////////////////////////////////////////////////////////////////
115//
116// Compression section
117//
118//
119// CompressionType values
120//
121#define EFI_NOT_COMPRESSED 0x00
122#define EFI_STANDARD_COMPRESSION 0x01
123#define EFI_CUSTOMIZED_COMPRESSION 0x02
124
130
131//
132// ////////////////////////////////////////////////////////////////////////////
133//
134// GUID defined section
135//
142
143//
144// Bit values for Attributes
145//
146#define EFI_GUIDED_SECTION_PROCESSING_REQUIRED 0x01
147#define EFI_GUIDED_SECTION_AUTH_STATUS_VALID 0x02
148
149//
150// Bit values for AuthenticationStatus
151//
152#define EFI_AGGREGATE_AUTH_STATUS_PLATFORM_OVERRIDE 0x000001
153#define EFI_AGGREGATE_AUTH_STATUS_IMAGE_SIGNED 0x000002
154#define EFI_AGGREGATE_AUTH_STATUS_NOT_TESTED 0x000004
155#define EFI_AGGREGATE_AUTH_STATUS_TEST_FAILED 0x000008
156#define EFI_AGGREGATE_AUTH_STATUS_ALL 0x00000f
157
158#define EFI_LOCAL_AUTH_STATUS_PLATFORM_OVERRIDE 0x010000
159#define EFI_LOCAL_AUTH_STATUS_IMAGE_SIGNED 0x020000
160#define EFI_LOCAL_AUTH_STATUS_NOT_TESTED 0x040000
161#define EFI_LOCAL_AUTH_STATUS_TEST_FAILED 0x080000
162#define EFI_LOCAL_AUTH_STATUS_ALL 0x0f0000
163
164//
165// ////////////////////////////////////////////////////////////////////////////
166//
167// PE32+ section
168//
172
173//
174// ////////////////////////////////////////////////////////////////////////////
175//
176// PIC section
177//
181
182//
183// ////////////////////////////////////////////////////////////////////////////
184//
185// PEIM header section
186//
190
191//
192// ////////////////////////////////////////////////////////////////////////////
193//
194// DEPEX section
195//
199
200//
201// ////////////////////////////////////////////////////////////////////////////
202//
203// Version section
204//
205typedef struct {
208 INT16 VersionString[1];
210
211//
212// ////////////////////////////////////////////////////////////////////////////
213//
214// User interface section
215//
216typedef struct {
218 INT16 FileNameString[1];
220
221//
222// ////////////////////////////////////////////////////////////////////////////
223//
224// Code16 section
225//
229
230//
231// ////////////////////////////////////////////////////////////////////////////
232//
233// Firmware Volume Image section
234//
238
239//
240// ////////////////////////////////////////////////////////////////////////////
241//
242// Freeform subtype GUID section
243//
248
249//
250// ////////////////////////////////////////////////////////////////////////////
251//
252// Raw section
253//
257
258//
259// undo the pragma from the beginning...
260//
261#pragma pack()
262
278
279//
280// EFI_FV_ATTRIBUTES bit definitions
281//
282typedef UINT64 EFI_FV_ATTRIBUTES;
284typedef UINT32 EFI_FV_WRITE_POLICY;
285
293
294#endif
UINT8 EFI_SECTION_TYPE
UINT64 EFI_FV_ATTRIBUTES
UINT32 EFI_FV_FILE_ATTRIBUTES
UINT32 EFI_FV_WRITE_POLICY
UINT8 EFI_FV_FILETYPE
DMG_SIZE_DEVICE_PATH Size
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_FV_FILE_ATTRIBUTES FileAttributes
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_COMMON_SECTION_HEADER CommonHeader
EFI_DEPEX_SECTION * DependencySection
EFI_PE32_SECTION * Pe32Section
EFI_VERSION_SECTION * VersionSection
EFI_USER_INTERFACE_SECTION * UISection
EFI_FREEFORM_SUBTYPE_GUID_SECTION * FreeformSubtypeSection
EFI_COMPRESSION_SECTION * CompressionSection
EFI_GUID_DEFINED_SECTION * GuidDefinedSection
EFI_PIC_SECTION * PicSection
EFI_FIRMWARE_VOLUME_IMAGE_SECTION * FVImageSection
EFI_RAW_SECTION * RawSection
EFI_CODE16_SECTION * Code16Section
EFI_COMMON_SECTION_HEADER * CommonHeader
EFI_PEIM_HEADER_SECTION * PeimHeaderSection