MdeModulePkg[all]
0.98
|
Data Structures | |
struct | _EFI_SWAP_ADDRESS_RANGE_PROTOCOL |
Macros | |
#define | EFI_SWAP_ADDRESS_RANGE_PROTOCOL_GUID |
#define | EFI_UNSUPPORT_LOCK 0 |
#define | EFI_SOFTWARE_LOCK 1 |
#define | EFI_HARDWARE_LOCK 2 |
Variables | |
EFI_GUID | gEfiSwapAddressRangeProtocolGuid |
The EFI_SWAP_ADDRESS_RANGE_PROTOCOL is used to abstract the swap operation of boot block and backup block of FV. This swap is especially needed when updating the boot block of FV. If a power failure happens during the boot block update, the swapped backup block (now the boot block) can boot the machine with the old boot block backed up in it. The swap operation is platform dependent, so other protocols such as FTW (Fault Tolerant Write) should use this protocol instead of handling hardware directly.
Copyright (c) 2009 - 2018, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent
#define EFI_HARDWARE_LOCK 2 |
#define EFI_SOFTWARE_LOCK 1 |
#define EFI_SWAP_ADDRESS_RANGE_PROTOCOL_GUID |
#define EFI_UNSUPPORT_LOCK 0 |
typedef EFI_STATUS(EFIAPI * EFI_GET_RANGE_LOCATION)(IN EFI_SWAP_ADDRESS_RANGE_PROTOCOL *This, OUT EFI_PHYSICAL_ADDRESS *BootBlockBase, OUT UINTN *BootBlockSize, OUT EFI_PHYSICAL_ADDRESS *BackupBlockBase, OUT UINTN *BackupBlockSize) |
This function gets the address range location of boot block and backup block.
This | Indicates the calling context. |
BootBlockBase | The base address of current boot block. |
BootBlockSize | The size (in bytes) of current boot block. |
BackupBlockBase | The base address of current backup block. |
BackupBlockSize | The size (in bytes) of current backup block. |
EFI_SUCCESS | The call was successful. |
typedef EFI_STATUS(EFIAPI * EFI_GET_RTC_POWER_STATUS)(IN EFI_SWAP_ADDRESS_RANGE_PROTOCOL *This, OUT BOOLEAN *RtcPowerFailed) |
This service checks if a Real Time Clock (RTC) power failure happened.
If parameter RtcPowerFailed is true after the function returns, RTC power supply failed or was removed. It is recommended to check RTC power status before calling GetSwapState().
This | Indicates the calling context. |
RtcPowerFailed | True if the RTC (Real Time Clock) power failed or was removed. |
EFI_SUCCESS | The call was successful. |
typedef EFI_STATUS(EFIAPI * EFI_GET_SWAP_LOCK_CAPABILITY)(IN EFI_SWAP_ADDRESS_RANGE_PROTOCOL *This, OUT EFI_SWAP_LOCK_CAPABILITY *LockCapability) |
This service returns all lock methods for swap operations that the current platform supports. Could be software lock, hardware lock, or unsupport lock. Note that software and hardware lock methods can be used simultaneously.
This | Indicates the calling context. |
LockCapability | The current lock method for swap operations. |
EFI_SUCCESS | The call was successful. |
typedef EFI_STATUS(EFIAPI * EFI_GET_SWAP_STATE)(IN EFI_SWAP_ADDRESS_RANGE_PROTOCOL *This, OUT BOOLEAN *SwapState) |
This service checks if the boot block and backup block has been swapped.
This | Indicates the calling context. |
SwapState | True if the boot block and backup block has been swapped. False if the boot block and backup block has not been swapped. |
EFI_SUCCESS | The call was successful. |
typedef EFI_STATUS(EFIAPI * EFI_SET_SWAP_LOCK)(IN EFI_SWAP_ADDRESS_RANGE_PROTOCOL *This, IN EFI_SWAP_LOCK_CAPABILITY LockCapability, IN BOOLEAN NewLockState) |
This service is used to acquire or release appointed kind of lock for Swap Address Range operations.
Note that software and hardware lock mothod can be used simultaneously.
This | Indicates the calling context. |
LockCapability | Indicates which lock to acquire or release. |
NewLockState | True to acquire lock; False to release lock. |
EFI_SUCCESS | The call was successful. |
typedef EFI_STATUS(EFIAPI * EFI_SET_SWAP_STATE)(IN EFI_SWAP_ADDRESS_RANGE_PROTOCOL *This, IN BOOLEAN NewSwapState) |
This service swaps the boot block and backup block, or swaps them back.
It also acquires and releases software swap lock during operation. The setting of the new swap state is not affected by the old swap state.
This | Indicates the calling context. |
NewSwapState | True to swap real boot block and backup block, False to swap them back. |
EFI_SUCCESS | The call was successful. |
EFI_ABORTED | Set swap state error. |
typedef struct _EFI_SWAP_ADDRESS_RANGE_PROTOCOL EFI_SWAP_ADDRESS_RANGE_PROTOCOL |
typedef UINT8 EFI_SWAP_LOCK_CAPABILITY |
EFI_GUID gEfiSwapAddressRangeProtocolGuid |