| /**@file | |
| Copyright (c) 2006, Intel Corporation. All rights reserved.<BR> | |
| SPDX-License-Identifier: BSD-2-Clause-Patent | |
| Module Name: | |
| FvbInfo.c | |
| Abstract: | |
| Defines data structure that is the volume header found.These data is intent | |
| to decouple FVB driver with FV header. | |
| **/ | |
| // | |
| // The package level header files this module uses | |
| // | |
| #include <Pi/PiFirmwareVolume.h> | |
| // | |
| // The protocols, PPI and GUID definitions for this module | |
| // | |
| #include <Guid/SystemNvDataGuid.h> | |
| // | |
| // The Library classes this module consumes | |
| // | |
| #include <Library/BaseLib.h> | |
| #include <Library/PcdLib.h> | |
| typedef struct { | |
| UINT64 FvLength; | |
| EFI_FIRMWARE_VOLUME_HEADER FvbInfo; | |
| // | |
| // EFI_FV_BLOCK_MAP_ENTRY ExtraBlockMap[n];//n=0 | |
| // | |
| EFI_FV_BLOCK_MAP_ENTRY End[1]; | |
| } EFI_FVB_MEDIA_INFO; | |
| EFI_FVB_MEDIA_INFO mPlatformFvbMediaInfo[] = { | |
| // | |
| // System NvStorage FVB | |
| // | |
| { | |
| FixedPcdGet32 (PcdFlashNvStorageVariableSize) + | |
| FixedPcdGet32 (PcdFlashNvStorageFtwWorkingSize) + | |
| FixedPcdGet32 (PcdFlashNvStorageFtwSpareSize) + | |
| FixedPcdGet32 (PcdOvmfFlashNvStorageEventLogSize), | |
| { | |
| { | |
| 0, | |
| }, // ZeroVector[16] | |
| EFI_SYSTEM_NV_DATA_FV_GUID, | |
| FixedPcdGet32 (PcdFlashNvStorageVariableSize) + | |
| FixedPcdGet32 (PcdFlashNvStorageFtwWorkingSize) + | |
| FixedPcdGet32 (PcdFlashNvStorageFtwSpareSize) + | |
| FixedPcdGet32 (PcdOvmfFlashNvStorageEventLogSize), | |
| EFI_FVH_SIGNATURE, | |
| EFI_FVB2_MEMORY_MAPPED | | |
| EFI_FVB2_READ_ENABLED_CAP | | |
| EFI_FVB2_READ_STATUS | | |
| EFI_FVB2_WRITE_ENABLED_CAP | | |
| EFI_FVB2_WRITE_STATUS | | |
| EFI_FVB2_ERASE_POLARITY | | |
| EFI_FVB2_ALIGNMENT_16, | |
| sizeof (EFI_FIRMWARE_VOLUME_HEADER) + sizeof (EFI_FV_BLOCK_MAP_ENTRY), | |
| 0, // CheckSum | |
| 0, // ExtHeaderOffset | |
| { | |
| 0, | |
| }, // Reserved[1] | |
| 2, // Revision | |
| { | |
| { | |
| (FixedPcdGet32 (PcdFlashNvStorageVariableSize) + | |
| FixedPcdGet32 (PcdFlashNvStorageFtwWorkingSize) + | |
| FixedPcdGet32 (PcdFlashNvStorageFtwSpareSize) + | |
| FixedPcdGet32 (PcdOvmfFlashNvStorageEventLogSize)) / | |
| FixedPcdGet32 (PcdOvmfFirmwareBlockSize), | |
| FixedPcdGet32 (PcdOvmfFirmwareBlockSize), | |
| } | |
| } // BlockMap[1] | |
| }, | |
| { | |
| { | |
| 0, | |
| 0 | |
| } | |
| } // End[1] | |
| } | |
| }; | |
| EFI_STATUS | |
| GetFvbInfo ( | |
| IN UINT64 FvLength, | |
| OUT EFI_FIRMWARE_VOLUME_HEADER **FvbInfo | |
| ) | |
| { | |
| STATIC BOOLEAN Checksummed = FALSE; | |
| UINTN Index; | |
| if (!Checksummed) { | |
| for (Index = 0; | |
| Index < sizeof (mPlatformFvbMediaInfo) / sizeof (EFI_FVB_MEDIA_INFO); | |
| Index += 1) | |
| { | |
| UINT16 Checksum; | |
| mPlatformFvbMediaInfo[Index].FvbInfo.Checksum = 0; | |
| Checksum = CalculateCheckSum16 ( | |
| (UINT16 *)&mPlatformFvbMediaInfo[Index].FvbInfo, | |
| mPlatformFvbMediaInfo[Index].FvbInfo.HeaderLength | |
| ); | |
| mPlatformFvbMediaInfo[Index].FvbInfo.Checksum = Checksum; | |
| } | |
| Checksummed = TRUE; | |
| } | |
| for (Index = 0; | |
| Index < sizeof (mPlatformFvbMediaInfo) / sizeof (EFI_FVB_MEDIA_INFO); | |
| Index += 1) | |
| { | |
| if (mPlatformFvbMediaInfo[Index].FvLength == FvLength) { | |
| *FvbInfo = &mPlatformFvbMediaInfo[Index].FvbInfo; | |
| return EFI_SUCCESS; | |
| } | |
| } | |
| return EFI_NOT_FOUND; | |
| } |