2 The header file for Firmware volume block driver.
4 Copyright (c) 2014 - 2021, Intel Corporation. All rights reserved.<BR>
5 SPDX-License-Identifier: BSD-2-Clause-Patent
9 #ifndef FW_BLOCK_SERVICE_H_
10 #define FW_BLOCK_SERVICE_H_
12 #include <Guid/EventGroup.h>
13 #include <Guid/FirmwareFileSystem2.h>
14 #include <Guid/SystemNvDataGuid.h>
15 #include <Guid/VariableFormat.h>
16 #include <Protocol/DevicePath.h>
17 #include <Protocol/FirmwareVolumeBlock.h>
18 #include <Library/UefiDriverEntryPoint.h>
19 #include <Library/UefiBootServicesTableLib.h>
20 #include <Library/UefiLib.h>
21 #include <Library/BaseLib.h>
22 #include <Library/DebugLib.h>
23 #include <Library/BaseMemoryLib.h>
24 #include <Library/IoLib.h>
25 #include <Library/CacheMaintenanceLib.h>
26 #include <Library/MemoryAllocationLib.h>
27 #include <Library/PcdLib.h>
28 #include <Library/FlashDeviceLib.h>
29 #include <Library/DevicePathLib.h>
30 #include <Library/HobLib.h>
31 #include <Library/DxeServicesLib.h>
32 #include <Guid/NvVariableInfoGuid.h>
33 #include <Register/ArchitecturalMsr.h>
36 // Define two helper macro to extract the Capability field or Status field in FVB
39 #define EFI_FVB2_CAPABILITIES (EFI_FVB2_READ_DISABLED_CAP | \
40 EFI_FVB2_READ_ENABLED_CAP | \
41 EFI_FVB2_WRITE_DISABLED_CAP | \
42 EFI_FVB2_WRITE_ENABLED_CAP | \
46 #define EFI_FVB2_STATUS (EFI_FVB2_READ_STATUS | EFI_FVB2_WRITE_STATUS | EFI_FVB2_LOCK_STATUS)
53 // Note!!!: VolumeHeader must be the last element
56 EFI_FIRMWARE_VOLUME_HEADER VolumeHeader
;
57 } EFI_FW_VOL_INSTANCE
;
61 EFI_FW_VOL_INSTANCE
*FvInstance
;
67 // Fvb Protocol instance data
69 #define FVB_DEVICE_FROM_THIS(a) CR(a, EFI_FW_VOL_BLOCK_DEVICE, FwVolBlockInstance, FVB_DEVICE_SIGNATURE)
70 #define FVB_EXTEND_DEVICE_FROM_THIS(a) CR(a, EFI_FW_VOL_BLOCK_DEVICE, FvbExtension, FVB_DEVICE_SIGNATURE)
71 #define FVB_DEVICE_SIGNATURE SIGNATURE_32('F','V','B','C')
74 MEDIA_FW_VOL_DEVICE_PATH FvDevPath
;
75 EFI_DEVICE_PATH_PROTOCOL EndDevPath
;
76 } FV_PIWG_DEVICE_PATH
;
79 MEMMAP_DEVICE_PATH MemMapDevPath
;
80 EFI_DEVICE_PATH_PROTOCOL EndDevPath
;
81 } FV_MEMMAP_DEVICE_PATH
;
85 EFI_DEVICE_PATH_PROTOCOL
*DevicePath
;
87 EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL FwVolBlockInstance
;
88 } EFI_FW_VOL_BLOCK_DEVICE
;
91 Get a heathy FV header used for variable store recovery
93 @retval The FV header.
96 EFI_FIRMWARE_VOLUME_HEADER
*
111 FvbProtocolGetAttributes (
112 IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL
*This
,
113 OUT EFI_FVB_ATTRIBUTES_2
*Attributes
118 FvbProtocolSetAttributes (
119 IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL
*This
,
120 IN OUT EFI_FVB_ATTRIBUTES_2
*Attributes
125 FvbProtocolGetPhysicalAddress (
126 IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL
*This
,
127 OUT EFI_PHYSICAL_ADDRESS
*Address
132 FvbProtocolGetBlockSize (
133 IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL
*This
,
135 OUT UINTN
*BlockSize
,
136 OUT UINTN
*NumOfBlocks
142 IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL
*This
,
145 IN OUT UINTN
*NumBytes
,
152 IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL
*This
,
155 IN OUT UINTN
*NumBytes
,
161 FvbProtocolEraseBlocks (
162 IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL
*This
,
166 EFI_FW_VOL_INSTANCE
*
173 IN EFI_FW_VOL_INSTANCE
*FwhInstance
,
182 extern FWB_GLOBAL mFvbModuleGlobal
;
183 extern EFI_FW_VOL_BLOCK_DEVICE mFvbDeviceTemplate
;
184 extern FV_MEMMAP_DEVICE_PATH mFvMemmapDevicePathTemplate
;
185 extern FV_PIWG_DEVICE_PATH mFvPIWGDevicePathTemplate
;