]> git.proxmox.com Git - mirror_edk2.git/blame - MdeModulePkg/Include/Protocol/EsrtManagement.h
UefiCpuPkg: Move AsmRelocateApLoopStart from Mpfuncs.nasm to AmdSev.nasm
[mirror_edk2.git] / MdeModulePkg / Include / Protocol / EsrtManagement.h
CommitLineData
8d51e87d
CZ
1/** @file\r
2 The Esrt Management Protocol used to register/set/update an updatable firmware resource .\r
3\r
d1102dba 4Copyright (c) 2015 - 2018, Intel Corporation. All rights reserved.<BR>\r
9d510e61 5SPDX-License-Identifier: BSD-2-Clause-Patent\r
8d51e87d
CZ
6\r
7**/\r
8\r
9#ifndef _ESRT_MANAGEMENT_H_\r
10#define _ESRT_MANAGEMENT_H_\r
11\r
12#include <Guid/SystemResourceTable.h>\r
13\r
14///\r
15/// Global ID for the ESRT_MANAGEMENT_PROTOCOL.\r
16///\r
17#define ESRT_MANAGEMENT_PROTOCOL_GUID \\r
18 { \\r
19 0xa340c064, 0x723c, 0x4a9c, { 0xa4, 0xdd, 0xd5, 0xb4, 0x7a, 0x26, 0xfb, 0xb0 } \\r
20 }\r
21\r
22///\r
23/// Forward declaration for the _ESRT_MANAGEMENT_PROTOCOL.\r
24///\r
1436aea4 25typedef struct _ESRT_MANAGEMENT_PROTOCOL ESRT_MANAGEMENT_PROTOCOL;\r
8d51e87d
CZ
26\r
27/**\r
d1102dba
LG
28 Get Variable name and data by Esrt Entry FwClass\r
29\r
30 @param[in] FwClass FwClass of Esrt entry to get\r
31 @param[in out] Entry Esrt entry returned\r
8d51e87d 32\r
8d51e87d
CZ
33 @retval EFI_SUCCESS The variable saving this Esrt Entry exists.\r
34 @retval EF_NOT_FOUND No correct variable found.\r
35\r
36**/\r
37typedef\r
38EFI_STATUS\r
39(EFIAPI *GET_ESRT_ENTRY)(\r
40 IN EFI_GUID *FwClass,\r
41 IN OUT EFI_SYSTEM_RESOURCE_ENTRY *Entry\r
42 );\r
d1102dba 43\r
8d51e87d
CZ
44/**\r
45 Update one ESRT entry in ESRT Cache.\r
46\r
47 @param[in] Entry Esrt entry to be updated\r
d1102dba 48\r
8d51e87d
CZ
49 @retval EFI_SUCCESS Successfully update an ESRT entry in cache.\r
50 @retval EFI_INVALID_PARAMETER Entry does't exist in ESRT Cache\r
51 @retval EFI_WRITE_PROTECTED ESRT Cache repositoy is locked\r
52\r
53**/\r
54typedef\r
55EFI_STATUS\r
56(EFIAPI *UPDATE_ESRT_ENTRY)(\r
57 IN EFI_SYSTEM_RESOURCE_ENTRY *Entry\r
58 );\r
59\r
8d51e87d 60/**\r
d1102dba
LG
61 Non-FMP instance to unregister Esrt Entry from ESRT Cache.\r
62\r
63 @param[in] FwClass FwClass of Esrt entry to Unregister\r
8d51e87d 64\r
d1102dba 65 @retval EFI_SUCCESS Insert all entries Successfully\r
8d51e87d
CZ
66 @retval EFI_NOT_FOUND FwClass does not exsit\r
67\r
68**/\r
69typedef\r
70EFI_STATUS\r
71(EFIAPI *UNREGISTER_ESRT_ENTRY)(\r
72 IN EFI_GUID *FwClass\r
73 );\r
74\r
8d51e87d
CZ
75/**\r
76 Non-FMP instance to register one ESRT entry into ESRT Cache.\r
77\r
78 @param[in] Entry Esrt entry to be set\r
79\r
80 @retval EFI_SUCCESS Successfully set a variable.\r
81 @retval EFI_INVALID_PARAMETER ESRT Entry is already exist\r
82 @retval EFI_OUT_OF_RESOURCES Non-FMP ESRT repository is full\r
83\r
84**/\r
85typedef\r
86EFI_STATUS\r
87(EFIAPI *REGISTER_ESRT_ENTRY)(\r
88 IN EFI_SYSTEM_RESOURCE_ENTRY *Entry\r
89 );\r
90\r
8d51e87d
CZ
91/**\r
92 This function syn up Cached ESRT with data from FMP instances\r
93 Function should be called after Connect All in order to locate all FMP protocols\r
94 installed\r
95\r
96 @retval EFI_SUCCESS Successfully sync cache repository from FMP instances\r
97 @retval EFI_NOT_FOUND No FMP Instance are found\r
98 @retval EFI_OUT_OF_RESOURCES Resource allocaton fail\r
99\r
100**/\r
101typedef\r
102EFI_STATUS\r
103(EFIAPI *SYNC_ESRT_FMP)(\r
104 VOID\r
105 );\r
106\r
8d51e87d 107/**\r
d1102dba 108 This function locks up Esrt repository to be readonly. It should be called\r
8d51e87d
CZ
109 before gEfiEndOfDxeEventGroupGuid event signaled\r
110\r
d1102dba 111 @retval EFI_SUCCESS Locks up FMP Non-FMP repository successfully\r
8d51e87d
CZ
112\r
113**/\r
114typedef\r
115EFI_STATUS\r
116(EFIAPI *LOCK_ESRT_REPOSITORY)(\r
117 VOID\r
118 );\r
119\r
8d51e87d 120struct _ESRT_MANAGEMENT_PROTOCOL {\r
1436aea4
MK
121 GET_ESRT_ENTRY GetEsrtEntry;\r
122 UPDATE_ESRT_ENTRY UpdateEsrtEntry;\r
123 REGISTER_ESRT_ENTRY RegisterEsrtEntry;\r
124 UNREGISTER_ESRT_ENTRY UnRegisterEsrtEntry;\r
125 SYNC_ESRT_FMP SyncEsrtFmp;\r
126 LOCK_ESRT_REPOSITORY LockEsrtRepository;\r
8d51e87d
CZ
127};\r
128\r
1436aea4 129extern EFI_GUID gEsrtManagementProtocolGuid;\r
8d51e87d
CZ
130\r
131#endif // #ifndef _ESRT_MANAGEMENT_H_\r