2011-05-11 20:31:20 +02:00
|
|
|
/*++ @file
|
|
|
|
Firmware volume block driver for Intel Firmware Hub (FWH) device
|
|
|
|
|
|
|
|
Copyright (c) 2006 - 2009, Intel Corporation. All rights reserved.<BR>
|
|
|
|
Portions copyright (c) 2011, Apple Inc. All rights reserved.
|
2019-04-04 01:03:44 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2011-05-11 20:31:20 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _FW_BLOCK_SERVICE_H
|
|
|
|
#define _FW_BLOCK_SERVICE_H
|
|
|
|
|
|
|
|
//
|
|
|
|
// BugBug: Add documentation here for data structure!!!!
|
|
|
|
//
|
|
|
|
#define FVB_PHYSICAL 0
|
|
|
|
#define FVB_VIRTUAL 1
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:53:57 +01:00
|
|
|
EFI_LOCK FvbDevLock;
|
|
|
|
UINTN FvBase[2];
|
|
|
|
UINTN NumOfBlocks;
|
|
|
|
EFI_FIRMWARE_VOLUME_HEADER VolumeHeader;
|
2011-05-11 20:31:20 +02:00
|
|
|
} EFI_FW_VOL_INSTANCE;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:53:57 +01:00
|
|
|
UINT32 NumFv;
|
|
|
|
EFI_FW_VOL_INSTANCE *FvInstance[2];
|
2011-05-11 20:31:20 +02:00
|
|
|
} ESAL_FWB_GLOBAL;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Fvb Protocol instance data
|
|
|
|
//
|
|
|
|
#define FVB_DEVICE_FROM_THIS(a) CR (a, EFI_FW_VOL_BLOCK_DEVICE, FwVolBlockInstance, FVB_DEVICE_SIGNATURE)
|
|
|
|
#define FVB_EXTEND_DEVICE_FROM_THIS(a) CR (a, EFI_FW_VOL_BLOCK_DEVICE, FvbExtension, FVB_DEVICE_SIGNATURE)
|
2021-12-05 23:53:57 +01:00
|
|
|
#define FVB_DEVICE_SIGNATURE SIGNATURE_32 ('F', 'V', 'B', 'N')
|
2011-05-11 20:31:20 +02:00
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:53:57 +01:00
|
|
|
MEMMAP_DEVICE_PATH MemMapDevPath;
|
|
|
|
EFI_DEVICE_PATH_PROTOCOL EndDevPath;
|
2011-05-11 20:31:20 +02:00
|
|
|
} FV_DEVICE_PATH;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:53:57 +01:00
|
|
|
UINTN Signature;
|
|
|
|
FV_DEVICE_PATH DevicePath;
|
|
|
|
UINTN Instance;
|
|
|
|
EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL FwVolBlockInstance;
|
2011-05-11 20:31:20 +02:00
|
|
|
} EFI_FW_VOL_BLOCK_DEVICE;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
GetFvbInfo (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN UINT64 FvLength,
|
|
|
|
OUT EFI_FIRMWARE_VOLUME_HEADER **FvbInfo
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
FvbReadBlock (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN UINTN Instance,
|
|
|
|
IN EFI_LBA Lba,
|
|
|
|
IN UINTN BlockOffset,
|
|
|
|
IN OUT UINTN *NumBytes,
|
|
|
|
IN UINT8 *Buffer,
|
|
|
|
IN ESAL_FWB_GLOBAL *Global,
|
|
|
|
IN BOOLEAN Virtual
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
FvbWriteBlock (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN UINTN Instance,
|
|
|
|
IN EFI_LBA Lba,
|
|
|
|
IN UINTN BlockOffset,
|
|
|
|
IN OUT UINTN *NumBytes,
|
|
|
|
IN UINT8 *Buffer,
|
|
|
|
IN ESAL_FWB_GLOBAL *Global,
|
|
|
|
IN BOOLEAN Virtual
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
FvbEraseBlock (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN UINTN Instance,
|
|
|
|
IN EFI_LBA Lba,
|
|
|
|
IN ESAL_FWB_GLOBAL *Global,
|
|
|
|
IN BOOLEAN Virtual
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
FvbSetVolumeAttributes (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN UINTN Instance,
|
|
|
|
IN OUT EFI_FVB_ATTRIBUTES_2 *Attributes,
|
|
|
|
IN ESAL_FWB_GLOBAL *Global,
|
|
|
|
IN BOOLEAN Virtual
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
FvbGetVolumeAttributes (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN UINTN Instance,
|
|
|
|
OUT EFI_FVB_ATTRIBUTES_2 *Attributes,
|
|
|
|
IN ESAL_FWB_GLOBAL *Global,
|
|
|
|
IN BOOLEAN Virtual
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
FvbGetPhysicalAddress (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN UINTN Instance,
|
|
|
|
OUT EFI_PHYSICAL_ADDRESS *Address,
|
|
|
|
IN ESAL_FWB_GLOBAL *Global,
|
|
|
|
IN BOOLEAN Virtual
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvbInitialize (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN EFI_HANDLE ImageHandle,
|
|
|
|
IN EFI_SYSTEM_TABLE *SystemTable
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
FvbClassAddressChangeEvent (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN EFI_EVENT Event,
|
|
|
|
IN VOID *Context
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
FvbGetLbaAddress (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN UINTN Instance,
|
|
|
|
IN EFI_LBA Lba,
|
|
|
|
OUT UINTN *LbaAddress,
|
|
|
|
OUT UINTN *LbaLength,
|
|
|
|
OUT UINTN *NumOfBlocks,
|
|
|
|
IN ESAL_FWB_GLOBAL *Global,
|
|
|
|
IN BOOLEAN Virtual
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Protocol APIs
|
|
|
|
//
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvbProtocolGetAttributes (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL *This,
|
|
|
|
OUT EFI_FVB_ATTRIBUTES_2 *Attributes
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvbProtocolSetAttributes (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL *This,
|
|
|
|
IN OUT EFI_FVB_ATTRIBUTES_2 *Attributes
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvbProtocolGetPhysicalAddress (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL *This,
|
|
|
|
OUT EFI_PHYSICAL_ADDRESS *Address
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvbProtocolGetBlockSize (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL *This,
|
|
|
|
IN EFI_LBA Lba,
|
|
|
|
OUT UINTN *BlockSize,
|
|
|
|
OUT UINTN *NumOfBlocks
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvbProtocolRead (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL *This,
|
|
|
|
IN EFI_LBA Lba,
|
|
|
|
IN UINTN Offset,
|
|
|
|
IN OUT UINTN *NumBytes,
|
|
|
|
IN UINT8 *Buffer
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvbProtocolWrite (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL *This,
|
|
|
|
IN EFI_LBA Lba,
|
|
|
|
IN UINTN Offset,
|
|
|
|
IN OUT UINTN *NumBytes,
|
|
|
|
IN UINT8 *Buffer
|
2011-05-11 20:31:20 +02:00
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvbProtocolEraseBlocks (
|
2021-12-05 23:53:57 +01:00
|
|
|
IN CONST EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL *This,
|
2011-05-11 20:31:20 +02:00
|
|
|
...
|
|
|
|
)
|
|
|
|
;
|
|
|
|
|
|
|
|
#endif
|