]> git.proxmox.com Git - mirror_edk2.git/blame - DuetPkg/DxeIpl/HobGeneration.h
Fix a security hole in shell binaries:
[mirror_edk2.git] / DuetPkg / DxeIpl / HobGeneration.h
CommitLineData
18b84857 1/** @file\r
ca162103 2\r
d569cbb0 3Copyright (c) 2006 - 2009, Intel Corporation \r
ca162103 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 HobGeneration.h\r
14\r
15Abstract:\r
16\r
17Revision History:\r
18\r
18b84857 19**/\r
ca162103 20\r
21#ifndef _DXELDR_HOB_GENERATION_H_\r
22#define _DXELDR_HOB_GENERATION_H_\r
23\r
24#include "DxeIpl.h"\r
25\r
26#define EFI_MEMORY_BELOW_1MB_START 0x86000\r
27#define EFI_MEMORY_BELOW_1MB_END 0x9F800\r
28#define EFI_MEMORY_STACK_PAGE_NUM 0x20\r
e843cdd7 29#define CONSUMED_MEMORY 0x100000 * 80\r
ca162103 30\r
31#define NV_STORAGE_START 0x15000\r
32#define NV_STORAGE_STATE 0x19000\r
33\r
34#define EFI_LDR_MEMORY_DESCRIPTOR_GUID \\r
9008db4a 35 { 0x7701d7e5, 0x7d1d, 0x4432, {0xa4, 0x68, 0x67, 0x3d, 0xab, 0x8a, 0xde, 0x60}}\r
ca162103 36\r
37#pragma pack(1)\r
38\r
39typedef struct {\r
40 EFI_HOB_GUID_TYPE Hob;\r
41 EFI_MEMORY_TYPE_INFORMATION Info[10];\r
42} MEMORY_TYPE_INFORMATION_HOB;\r
43\r
44typedef struct {\r
45 EFI_HOB_GUID_TYPE Hob;\r
46 EFI_PHYSICAL_ADDRESS Table;\r
47} TABLE_HOB;\r
48\r
49typedef struct {\r
50 EFI_HOB_GUID_TYPE Hob;\r
51 VOID *Interface;\r
52} PROTOCOL_HOB;\r
53\r
54typedef struct {\r
55 EFI_HOB_GUID_TYPE Hob;\r
56 UINTN MemDescCount;\r
57 EFI_MEMORY_DESCRIPTOR *MemDesc;\r
58} MEMORY_DESC_HOB;\r
59\r
60typedef struct {\r
61 EFI_HOB_GUID_TYPE Hob;\r
62 // Note: we get only one PCI Segment now.\r
63 EFI_PCI_EXPRESS_BASE_ADDRESS_INFORMATION PciExpressBaseAddressInfo;\r
64} PCI_EXPRESS_BASE_HOB;\r
65\r
66typedef struct {\r
67 EFI_HOB_GUID_TYPE Hob;\r
68 EFI_ACPI_DESCRIPTION AcpiDescription;\r
69} ACPI_DESCRIPTION_HOB;\r
70\r
71typedef struct {\r
72 EFI_HOB_GUID_TYPE Hob;\r
73 EFI_FLASH_MAP_FS_ENTRY_DATA FvbInfo;\r
74} FVB_HOB;\r
75\r
76typedef struct {\r
77 EFI_HOB_HANDOFF_INFO_TABLE Phit;\r
78 EFI_HOB_FIRMWARE_VOLUME Bfv;\r
79 EFI_HOB_RESOURCE_DESCRIPTOR BfvResource;\r
80 EFI_HOB_CPU Cpu;\r
81 EFI_HOB_MEMORY_ALLOCATION_STACK Stack;\r
82 EFI_HOB_MEMORY_ALLOCATION MemoryAllocation;\r
83 EFI_HOB_RESOURCE_DESCRIPTOR MemoryFreeUnder1MB;\r
84 EFI_HOB_RESOURCE_DESCRIPTOR MemoryAbove1MB;\r
85 EFI_HOB_RESOURCE_DESCRIPTOR MemoryAbove4GB;\r
86 EFI_HOB_MEMORY_ALLOCATION_MODULE DxeCore;\r
d569cbb0 87 EFI_HOB_RESOURCE_DESCRIPTOR MemoryDxeCore;\r
ca162103 88 MEMORY_TYPE_INFORMATION_HOB MemoryTypeInfo;\r
89 TABLE_HOB Acpi;\r
90 TABLE_HOB Acpi20;\r
91 TABLE_HOB Smbios;\r
92 TABLE_HOB Mps;\r
93 /**\r
94 PROTOCOL_HOB FlushInstructionCache;\r
95 PROTOCOL_HOB TransferControl;\r
96 PROTOCOL_HOB PeCoffLoader;\r
97 PROTOCOL_HOB EfiDecompress;\r
98 PROTOCOL_HOB TianoDecompress;\r
99 **/\r
100 PROTOCOL_HOB SerialStatusCode;\r
101 MEMORY_DESC_HOB MemoryDescriptor;\r
102 PCI_EXPRESS_BASE_HOB PciExpress;\r
103 ACPI_DESCRIPTION_HOB AcpiInfo;\r
104 \r
105 EFI_HOB_RESOURCE_DESCRIPTOR NvStorageFvResource;\r
106\r
107 FVB_HOB NvStorageFvb;\r
108 FVB_HOB NvStorage;\r
d569cbb0 109 \r
110 EFI_HOB_RESOURCE_DESCRIPTOR NvFtwFvResource;\r
ca162103 111 FVB_HOB NvFtwFvb;\r
112 FVB_HOB NvFtwWorking;\r
113 FVB_HOB NvFtwSpare;\r
114 \r
115 EFI_HOB_GENERIC_HEADER EndOfHobList;\r
116} HOB_TEMPLATE;\r
117\r
118#pragma pack()\r
119\r
120extern HOB_TEMPLATE *gHob;\r
121\r
122VOID *\r
123PrepareHobStack (\r
124 IN VOID *StackTop\r
125 );\r
126\r
127VOID\r
128PrepareHobBfv (\r
129 VOID *Bfv,\r
130 UINTN BfvLength\r
131 );\r
132\r
133VOID *\r
134PrepareHobMemory (\r
135 IN UINTN NumberOfMemoryMapEntries,\r
136 IN EFI_MEMORY_DESCRIPTOR *EfiMemoryDescriptor\r
137 );\r
138\r
139VOID\r
140PrepareHobDxeCore (\r
141 VOID *DxeCoreEntryPoint,\r
142 EFI_PHYSICAL_ADDRESS DxeCoreImageBase,\r
143 UINT64 DxeCoreLength\r
144 );\r
145\r
146VOID *\r
147PreparePageTable (\r
148 VOID *PageNumberTop,\r
149 UINT8 SizeOfMemorySpace\r
150 );\r
151\r
152VOID *\r
153PrepareHobMemoryDescriptor (\r
154 VOID *MemoryDescriptorTop,\r
155 UINTN MemDescCount,\r
156 EFI_MEMORY_DESCRIPTOR *MemDesc\r
157 );\r
158\r
159VOID\r
160PrepareHobPhit (\r
161 VOID *MemoryTop,\r
162 VOID *FreeMemoryTop\r
163 );\r
164\r
165VOID *\r
166PrepareHobNvStorage (\r
167 VOID *NvStorageTop\r
168 );\r
169\r
170VOID\r
171PrepareHobCpu (\r
172 VOID\r
173 );\r
174\r
175VOID\r
176CompleteHobGeneration (\r
177 VOID\r
178 );\r
179\r
180#endif\r