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