]> git.proxmox.com Git - mirror_edk2.git/blame - MdeModulePkg/Universal/Disk/RamDiskDxe/RamDiskDriver.c
MdeModulePkg/RamDiskDxe: Use BaseLib linked list iteration macros
[mirror_edk2.git] / MdeModulePkg / Universal / Disk / RamDiskDxe / RamDiskDriver.c
CommitLineData
20752cb8
HW
1/** @file\r
2 The driver entry point for RamDiskDxe driver.\r
3\r
4 Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>\r
9c463f6f 5 Copyright (c) Microsoft Corporation.<BR>\r
9d510e61 6 SPDX-License-Identifier: BSD-2-Clause-Patent\r
20752cb8
HW
7\r
8**/\r
9\r
10#include "RamDiskImpl.h"\r
11\r
12//\r
13// Handle for the EFI_RAM_DISK_PROTOCOL instance\r
14//\r
15EFI_HANDLE mRamDiskHandle = NULL;\r
16\r
17//\r
18// The EFI_RAM_DISK_PROTOCOL instances that is installed onto the driver\r
19// handle\r
20//\r
21EFI_RAM_DISK_PROTOCOL mRamDiskProtocol = {\r
22 RamDiskRegister,\r
23 RamDiskUnregister\r
24};\r
25\r
26//\r
27// RamDiskDxe driver maintains a list of registered RAM disks.\r
28//\r
29LIST_ENTRY RegisteredRamDisks;\r
20752cb8 30\r
07a3fecd
HW
31//\r
32// Pointers to the EFI_ACPI_TABLE_PROTOCOL and EFI_ACPI_SDT_PROTOCOL.\r
33//\r
34EFI_ACPI_TABLE_PROTOCOL *mAcpiTableProtocol = NULL;\r
35EFI_ACPI_SDT_PROTOCOL *mAcpiSdtProtocol = NULL;\r
36\r
37\r
38/**\r
39 Check whether EFI_ACPI_TABLE_PROTOCOL and EFI_ACPI_SDT_PROTOCOL are produced.\r
40 If both protocols are produced, publish all the reserved memory type RAM\r
41 disks to the NVDIMM Firmware Interface Table (NFIT).\r
42\r
43 @param[in] Event Event whose notification function is being invoked.\r
44 @param[in] Context The pointer to the notification function's context,\r
45 which is implementation-dependent.\r
46\r
47**/\r
48VOID\r
49EFIAPI\r
50RamDiskAcpiCheck (\r
51 IN EFI_EVENT Event,\r
52 IN VOID *Context\r
53 )\r
54{\r
55 EFI_STATUS Status;\r
56 LIST_ENTRY *Entry;\r
57 RAM_DISK_PRIVATE_DATA *PrivateData;\r
58\r
59 gBS->CloseEvent (Event);\r
60\r
61 //\r
62 // Locate the EFI_ACPI_TABLE_PROTOCOL.\r
63 //\r
64 Status = gBS->LocateProtocol (\r
65 &gEfiAcpiTableProtocolGuid,\r
66 NULL,\r
67 (VOID **)&mAcpiTableProtocol\r
68 );\r
69 if (EFI_ERROR (Status)) {\r
70 DEBUG ((\r
71 EFI_D_INFO,\r
76874be3 72 "RamDiskAcpiCheck: Cannot locate the EFI ACPI Table Protocol, "\r
07a3fecd
HW
73 "unable to publish RAM disks to NFIT.\n"\r
74 ));\r
75 return;\r
76 }\r
77\r
78 //\r
79 // Locate the EFI_ACPI_SDT_PROTOCOL.\r
80 //\r
81 Status = gBS->LocateProtocol (\r
82 &gEfiAcpiSdtProtocolGuid,\r
83 NULL,\r
84 (VOID **)&mAcpiSdtProtocol\r
85 );\r
86 if (EFI_ERROR (Status)) {\r
87 DEBUG ((\r
88 EFI_D_INFO,\r
76874be3 89 "RamDiskAcpiCheck: Cannot locate the EFI ACPI Sdt Protocol, "\r
07a3fecd
HW
90 "unable to publish RAM disks to NFIT.\n"\r
91 ));\r
92 mAcpiTableProtocol = NULL;\r
93 return;\r
94 }\r
95\r
9c463f6f 96 BASE_LIST_FOR_EACH (Entry, &RegisteredRamDisks) {\r
07a3fecd
HW
97 PrivateData = RAM_DISK_PRIVATE_FROM_THIS (Entry);\r
98 RamDiskPublishNfit (PrivateData);\r
99 }\r
100}\r
101\r
20752cb8
HW
102\r
103/**\r
104 The entry point for RamDiskDxe driver.\r
105\r
106 @param[in] ImageHandle The image handle of the driver.\r
107 @param[in] SystemTable The system table.\r
108\r
109 @retval EFI_ALREADY_STARTED The driver already exists in system.\r
110 @retval EFI_OUT_OF_RESOURCES Fail to execute entry point due to lack of\r
111 resources.\r
112 @retval EFI_SUCCES All the related protocols are installed on\r
113 the driver.\r
114\r
115**/\r
116EFI_STATUS\r
117EFIAPI\r
118RamDiskDxeEntryPoint (\r
119 IN EFI_HANDLE ImageHandle,\r
120 IN EFI_SYSTEM_TABLE *SystemTable\r
121 )\r
122{\r
123 EFI_STATUS Status;\r
124 RAM_DISK_CONFIG_PRIVATE_DATA *ConfigPrivate;\r
125 VOID *DummyInterface;\r
07a3fecd 126 EFI_EVENT Event;\r
20752cb8
HW
127\r
128 //\r
129 // If already started, return.\r
130 //\r
131 Status = gBS->LocateProtocol (\r
132 &gEfiRamDiskProtocolGuid,\r
133 NULL,\r
134 &DummyInterface\r
135 );\r
136 if (!EFI_ERROR (Status)) {\r
137 DEBUG ((EFI_D_INFO, "Driver already started!\n"));\r
138 return EFI_ALREADY_STARTED;\r
139 }\r
140\r
141 //\r
142 // Create a private data structure.\r
143 //\r
144 ConfigPrivate = AllocateCopyPool (sizeof (RAM_DISK_CONFIG_PRIVATE_DATA), &mRamDiskConfigPrivateDataTemplate);\r
145 if (ConfigPrivate == NULL) {\r
146 return EFI_OUT_OF_RESOURCES;\r
147 }\r
148\r
149 //\r
150 // Install RAM disk configuration form\r
151 //\r
152 Status = InstallRamDiskConfigForm (ConfigPrivate);\r
153 if (EFI_ERROR (Status)) {\r
154 goto ErrorExit;\r
155 }\r
156\r
157 //\r
158 // Install the EFI_RAM_DISK_PROTOCOL and RAM disk private data onto a\r
159 // new handle\r
160 //\r
161 Status = gBS->InstallMultipleProtocolInterfaces (\r
162 &mRamDiskHandle,\r
163 &gEfiRamDiskProtocolGuid,\r
164 &mRamDiskProtocol,\r
165 &gEfiCallerIdGuid,\r
166 ConfigPrivate,\r
167 NULL\r
168 );\r
169 if (EFI_ERROR (Status)) {\r
170 goto ErrorExit;\r
171 }\r
172\r
173 //\r
174 // Initialize the list of registered RAM disks maintained by the driver\r
175 //\r
176 InitializeListHead (&RegisteredRamDisks);\r
177\r
07a3fecd
HW
178 Status = EfiCreateEventReadyToBootEx (\r
179 TPL_CALLBACK,\r
180 RamDiskAcpiCheck,\r
181 NULL,\r
182 &Event\r
183 );\r
184 ASSERT_EFI_ERROR (Status);\r
185\r
20752cb8
HW
186 return EFI_SUCCESS;\r
187\r
188ErrorExit:\r
189 if (ConfigPrivate != NULL) {\r
190 UninstallRamDiskConfigForm (ConfigPrivate);\r
191 }\r
192\r
193 return Status;\r
194}\r
195\r
196\r
197/**\r
198 Unload the RamDiskDxe driver and its configuration form.\r
199\r
200 @param[in] ImageHandle The driver's image handle.\r
201\r
202 @retval EFI_SUCCESS The RamDiskDxe driver and its configuration\r
203 form is unloaded.\r
204 @retval Others Failed to unload the form.\r
205\r
206**/\r
207EFI_STATUS\r
208EFIAPI\r
209RamDiskDxeUnload (\r
210 IN EFI_HANDLE ImageHandle\r
211 )\r
212{\r
213 EFI_STATUS Status;\r
214 RAM_DISK_CONFIG_PRIVATE_DATA *ConfigPrivate;\r
215\r
216 Status = gBS->HandleProtocol (\r
217 mRamDiskHandle,\r
218 &gEfiCallerIdGuid,\r
219 (VOID **) &ConfigPrivate\r
220 );\r
221 if (EFI_ERROR (Status)) {\r
222 return Status;\r
223 }\r
224\r
225 ASSERT (ConfigPrivate->Signature == RAM_DISK_CONFIG_PRIVATE_DATA_SIGNATURE);\r
226\r
227 //\r
228 // Unregister all registered RAM disks\r
229 //\r
230 UnregisterAllRamDisks ();\r
231\r
232 gBS->UninstallMultipleProtocolInterfaces (\r
233 mRamDiskHandle,\r
234 &gEfiRamDiskProtocolGuid,\r
235 &mRamDiskProtocol,\r
236 &gEfiCallerIdGuid,\r
237 ConfigPrivate,\r
238 NULL\r
239 );\r
240\r
241 UninstallRamDiskConfigForm (ConfigPrivate);\r
242\r
243 return EFI_SUCCESS;\r
244}\r