]> git.proxmox.com Git - mirror_edk2.git/blame - EdkCompatibilityPkg/Foundation/Protocol/Performance/Performance.h
Program SD Cards into 4-bit mode (support for this is required in the spec). This...
[mirror_edk2.git] / EdkCompatibilityPkg / Foundation / Protocol / Performance / Performance.h
CommitLineData
3eb9473e 1/*++\r
2\r
f57387d5
HT
3Copyright (c) 2004, Intel Corporation. All rights reserved.<BR>\r
4This program and the accompanying materials \r
3eb9473e 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 Performance.h\r
15\r
16Abstract:\r
17\r
18 \r
19--*/\r
20\r
21#ifndef _EFI_PERFORMANCE_H_\r
22#define _EFI_PERFORMANCE_H_\r
23\r
24#define EFI_PERFORMANCE_PROTOCOL_GUID \\r
7ccf38a3 25 { 0xFFECFFFF, 0x923C, 0x14d2, {0x9E, 0x3F, 0x22, 0xA0, 0xC9, 0x69, 0x56, 0x3B} }\r
3eb9473e 26\r
27#define EFI_NULL_GUID \\r
7ccf38a3 28 { 0x00000000, 0x0000, 0x0000, {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00} }\r
3eb9473e 29\r
30\r
31EFI_FORWARD_DECLARATION (EFI_PERFORMANCE_PROTOCOL);\r
32\r
33#define DXE_TOK L"DXE"\r
34#define SHELL_TOK L"SHELL"\r
35#define PEI_TOK L"PEI"\r
36#define BDS_TOK L"BDS"\r
37#define DRIVERBINDING_START_TOK L"DriverBinding:Start"\r
38#define DRIVERBINDING_SUPPORT_TOK L"DriverBinding:Support"\r
39#define START_IMAGE_TOK L"StartImage"\r
40#define LOAD_IMAGE_TOK L"LoadImage"\r
41\r
42#define DXE_PHASE 0\r
43#define SHELL_PHASE 1\r
44#define PEI_PHASE 2\r
45\r
46#define EFI_PERF_TOKEN_LENGTH 32\r
47#define EFI_PERF_HOST_LENGTH 32\r
48#define EFI_PERF_PDBFILENAME_LENGTH 28\r
49\r
50typedef struct {\r
51 EFI_HANDLE Handle; \r
52 UINT16 Token[EFI_PERF_TOKEN_LENGTH];\r
53 UINT16 Host[EFI_PERF_HOST_LENGTH];\r
54 UINT64 StartTick;\r
55 UINT64 EndTick;\r
56 EFI_GUID GuidName;\r
b233cbe5 57 CHAR8 PdbFileName[EFI_PERF_PDBFILENAME_LENGTH];\r
3eb9473e 58 UINT8 Phase;\r
59} EFI_GAUGE_DATA ;\r
60\r
61\r
62typedef \r
63EFI_STATUS\r
64(EFIAPI * EFI_PERF_START_GAUGE) (\r
65 IN EFI_PERFORMANCE_PROTOCOL *This,\r
66 IN EFI_HANDLE Handle,\r
67 IN UINT16 *Token,\r
68 IN UINT16 *Host,\r
69 IN UINT64 Ticker\r
70 );\r
71\r
72typedef \r
73EFI_STATUS\r
74(EFIAPI * EFI_PERF_END_GAUGE) (\r
75 IN EFI_PERFORMANCE_PROTOCOL *This,\r
76 IN EFI_HANDLE Handle,\r
77 IN UINT16 *Token,\r
78 IN UINT16 *Host,\r
79 IN UINT64 Ticker\r
80 );\r
81\r
82\r
83typedef \r
84EFI_GAUGE_DATA *\r
85(EFIAPI * EFI_PERF_GET_GAUGE) (\r
86 IN EFI_PERFORMANCE_PROTOCOL *This,\r
87 IN EFI_HANDLE Handle, \r
88 IN UINT16 *Token, \r
89 IN UINT16 *Host, \r
90 IN EFI_GAUGE_DATA *PrevGauge \r
91 );\r
92\r
93\r
9c092841 94struct _EFI_PERFORMANCE_PROTOCOL {\r
3eb9473e 95 EFI_PERF_START_GAUGE StartGauge;\r
96 EFI_PERF_END_GAUGE EndGauge;\r
97 EFI_PERF_GET_GAUGE GetGauge;\r
9c092841 98};\r
3eb9473e 99\r
100extern EFI_GUID gEfiPerformanceProtocolGuid;\r
101\r
102#endif\r
103\r