]> git.proxmox.com Git - mirror_edk2.git/blame_incremental - MdeModulePkg/Universal/CapsuleRuntimeDxe/CapsuleRuntimeDxe.inf
MdeModulePkg/CapsuleRuntimeDxe: clean the capsule payload to DRAM
[mirror_edk2.git] / MdeModulePkg / Universal / CapsuleRuntimeDxe / CapsuleRuntimeDxe.inf
... / ...
CommitLineData
1## @file\r
2# Capsule Runtime Driver produces two UEFI capsule runtime services: (UpdateCapsule, QueryCapsuleCapabilities).\r
3#\r
4# It installs the Capsule Architectural Protocol defined in PI1.0a to signify \r
5# the capsule runtime services are ready.\r
6# \r
7# Copyright (c) 2006 - 2017, Intel Corporation. All rights reserved.<BR>\r
8# This program and the accompanying materials\r
9# are licensed and made available under the terms and conditions of the BSD License\r
10# which accompanies this distribution. The full text of the license may be found at\r
11# http://opensource.org/licenses/bsd-license.php\r
12# \r
13# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
14# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
15# \r
16##\r
17\r
18[Defines]\r
19 INF_VERSION = 0x00010005\r
20 BASE_NAME = CapsuleRuntimeDxe\r
21 MODULE_UNI_FILE = CapsuleRuntimeDxe.uni\r
22 FILE_GUID = 42857F0A-13F2-4B21-8A23-53D3F714B840\r
23 MODULE_TYPE = DXE_RUNTIME_DRIVER\r
24 VERSION_STRING = 1.0\r
25 ENTRY_POINT = CapsuleServiceInitialize\r
26\r
27#\r
28# The following information is for reference only and not required by the build tools.\r
29#\r
30# VALID_ARCHITECTURES = IA32 X64 IPF EBC ARM AARCH64\r
31#\r
32\r
33[Sources]\r
34 CapsuleService.c\r
35 CapsuleService.h\r
36\r
37[Sources.Ia32, Sources.IPF, Sources.EBC]\r
38 SaveLongModeContext.c\r
39 CapsuleReset.c\r
40\r
41[Sources.X64]\r
42 X64/SaveLongModeContext.c\r
43 CapsuleReset.c\r
44\r
45[Sources.ARM, Sources.AARCH64]\r
46 SaveLongModeContext.c\r
47 Arm/CapsuleReset.c\r
48\r
49[Packages]\r
50 MdePkg/MdePkg.dec\r
51 MdeModulePkg/MdeModulePkg.dec\r
52\r
53[LibraryClasses]\r
54 UefiBootServicesTableLib\r
55 PcdLib\r
56 DebugLib\r
57 UefiRuntimeServicesTableLib\r
58 UefiDriverEntryPoint\r
59 CapsuleLib\r
60 UefiRuntimeLib\r
61 BaseLib\r
62 PrintLib\r
63 BaseMemoryLib\r
64\r
65[LibraryClasses.X64]\r
66 UefiLib\r
67 BaseMemoryLib\r
68\r
69[LibraryClasses.ARM, LibraryClasses.AARCH64]\r
70 CacheMaintenanceLib\r
71\r
72[Guids]\r
73 ## SOMETIMES_PRODUCES ## Variable:L"CapsuleUpdateData" # (Process across reset capsule image) for capsule updated data\r
74 ## SOMETIMES_PRODUCES ## Variable:L"CapsuleLongModeBuffer" # The long mode buffer used by IA32 Capsule PEIM to call X64 CapsuleCoalesce code to handle >4GB capsule blocks\r
75 gEfiCapsuleVendorGuid\r
76 gEfiFmpCapsuleGuid ## SOMETIMES_CONSUMES ## GUID # FMP capsule GUID\r
77\r
78[Protocols]\r
79 gEfiCapsuleArchProtocolGuid ## PRODUCES\r
80\r
81[Protocols.X64]\r
82 ## UNDEFINED ## NOTIFY\r
83 ## SOMETIMES_CONSUMES\r
84 gEdkiiVariableLockProtocolGuid\r
85\r
86[FeaturePcd]\r
87 gEfiMdeModulePkgTokenSpaceGuid.PcdSupportUpdateCapsuleReset ## CONSUMES\r
88\r
89[FeaturePcd.X64]\r
90 gEfiMdeModulePkgTokenSpaceGuid.PcdDxeIplSwitchToLongMode ## CONSUMES\r
91\r
92[Pcd]\r
93 gEfiMdeModulePkgTokenSpaceGuid.PcdMaxSizeNonPopulateCapsule ## SOMETIMES_CONSUMES\r
94 gEfiMdeModulePkgTokenSpaceGuid.PcdMaxSizePopulateCapsule ## SOMETIMES_CONSUMES # Populate Image requires reset support.\r
95\r
96[Pcd.X64]\r
97 gEfiMdeModulePkgTokenSpaceGuid.PcdCapsulePeiLongModeStackSize ## SOMETIMES_CONSUMES\r
98 gEfiMdeModulePkgTokenSpaceGuid.PcdUse1GPageTable ## SOMETIMES_CONSUMES\r
99\r
100[Depex]\r
101 gEfiVariableWriteArchProtocolGuid # Depends on variable write functionality to produce capsule data variable\r
102\r
103# [Hob.X64]\r
104# UNDEFINED ## SOMETIMES_CONSUMES # CPU\r
105\r
106[UserExtensions.TianoCore."ExtraFiles"]\r
107 CapsuleRuntimeDxeExtra.uni\r