]> git.proxmox.com Git - mirror_edk2.git/blame - IntelFrameworkModulePkg/Library/GenericBdsLib/InternalBdsLib.h
Move BdsDxe and GenericBdsLib to IntelFrameworkModulePkg, these modules need dependen...
[mirror_edk2.git] / IntelFrameworkModulePkg / Library / GenericBdsLib / InternalBdsLib.h
CommitLineData
5c08e117 1/** @file\r
2 BDS library definition, include the file and data structure\r
3\r
4Copyright (c) 2004 - 2008, Intel Corporation. <BR>\r
5All rights reserved. This program and the accompanying materials\r
6are licensed and made available under the terms and conditions of the BSD License\r
7which accompanies this distribution. The full text of the license may be found at\r
8http://opensource.org/licenses/bsd-license.php\r
9\r
10THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
11WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
12\r
13**/\r
14\r
15#ifndef _INTERNAL_BDS_LIB_H_\r
16#define _INTERNAL_BDS_LIB_H_\r
17\r
18#include <PiDxe.h>\r
19\r
20#include <IndustryStandard/Pci22.h>\r
21\r
22#include <Protocol/BlockIo.h>\r
23#include <Protocol/LoadedImage.h>\r
24#include <Protocol/Cpu.h>\r
25#include <Protocol/SimpleFileSystem.h>\r
26#include <Protocol/DebugPort.h>\r
27#include <Protocol/DevicePath.h>\r
28#include <Protocol/SimpleTextIn.h>\r
29#include <Protocol/LegacyBios.h>\r
30#include <Protocol/SimpleTextOut.h>\r
31#include <Protocol/SimpleNetwork.h>\r
32#include <Protocol/DevicePathToText.h>\r
33#include <Protocol/FirmwareVolume2.h>\r
34#include <Protocol/PciIo.h>\r
35#include <Protocol/AcpiS3Save.h>\r
36#include <Protocol/Performance.h>\r
37#include <Protocol/FirmwareVolumeDispatch.h>\r
38#include <Protocol/OEMBadging.h>\r
39#include <Protocol/ConsoleControl.h>\r
40#include <Protocol/GraphicsOutput.h>\r
41#include <Protocol/UgaDraw.h>\r
42#include <Protocol/HiiFont.h>\r
43#include <Protocol/HiiImage.h>\r
44\r
45\r
46#include <Guid/MemoryTypeInformation.h>\r
47#include <Guid/FileInfo.h>\r
48#include <Guid/GlobalVariable.h>\r
49#include <Guid/PcAnsi.h>\r
50#include <Guid/ShellFile.h>\r
51#include <Guid/GenericPlatformVariable.h>\r
52#include <Guid/Bmp.h>\r
53\r
54#include <Library/PrintLib.h>\r
55#include <Library/DebugLib.h>\r
56#include <Library/BaseMemoryLib.h>\r
57#include <Library/UefiBootServicesTableLib.h>\r
58#include <Library/UefiLib.h>\r
59#include <Library/MemoryAllocationLib.h>\r
60#include <Library/DxeServicesTableLib.h>\r
61#include <Library/UefiRuntimeServicesTableLib.h>\r
62#include <Library/HobLib.h>\r
63#include <Library/BaseLib.h>\r
64#include <Library/DevicePathLib.h>\r
65#include <Library/PerformanceLib.h>\r
66#include <Library/PcdLib.h>\r
67#include <Library/IfrSupportLib.h>\r
68#include <Library/PeCoffGetEntryPointLib.h>\r
69#include <Library/GenericBdsLib.h>\r
70#include <Library/TimerLib.h>\r
71#include <Library/PcdLib.h>\r
72#include <Library/DxeServicesLib.h>\r
73\r
74#define PERFORMANCE_SIGNATURE SIGNATURE_32 ('P', 'e', 'r', 'f')\r
75#define PERF_TOKEN_SIZE 28\r
76#define PERF_TOKEN_LENGTH (PERF_TOKEN_SIZE - 1)\r
77#define PERF_PEI_ENTRY_MAX_NUM 50\r
78\r
79typedef struct {\r
80 CHAR8 Token[PERF_TOKEN_SIZE];\r
81 UINT32 Duration;\r
82} PERF_DATA;\r
83\r
84typedef struct {\r
85 UINT64 BootToOs;\r
86 UINT64 S3Resume;\r
87 UINT32 S3EntryNum;\r
88 PERF_DATA S3Entry[PERF_PEI_ENTRY_MAX_NUM];\r
89 UINT64 CpuFreq;\r
90 UINT64 BDSRaw;\r
91 UINT32 Count;\r
92 UINT32 Signiture;\r
93} PERF_HEADER;\r
94\r
95/**\r
96\r
97 Allocates a block of memory and writes performance data of booting into it.\r
98 OS can processing these record.\r
99 \r
100**/\r
101VOID\r
102WriteBootToOsPerformanceData (\r
103 VOID\r
104 );\r
105\r
106#endif // _BDS_LIB_H_\r