2007-06-28 00:53:31 +02:00
|
|
|
/** @file
|
|
|
|
Firmeware Volume BLock Service Library
|
2007-06-19 12:55:24 +02:00
|
|
|
|
2007-07-13 05:21:40 +02:00
|
|
|
Copyright (c) 2006 - 2007, Intel Corporation.<BR>
|
2007-06-28 00:53:31 +02:00
|
|
|
All rights reserved. This program and the accompanying materials
|
|
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
which accompanies this distribution. The full text of the license may be found at
|
|
|
|
http://opensource.org/licenses/bsd-license.php
|
2007-06-19 12:55:24 +02:00
|
|
|
|
2007-06-28 00:53:31 +02:00
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
2007-06-19 12:55:24 +02:00
|
|
|
|
2007-06-28 00:53:31 +02:00
|
|
|
**/
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
#ifndef __EDK_FVB_SERVICE_LIB_H__
|
|
|
|
#define __EDK_FVB_SERVICE_LIB_H__
|
|
|
|
|
2007-07-13 05:21:40 +02:00
|
|
|
/**
|
2008-07-21 14:53:53 +02:00
|
|
|
Reads specified number of bytes into a buffer from the specified block.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
2008-07-21 14:53:53 +02:00
|
|
|
@param[in] Instance The FV instance to be read from.
|
2007-07-13 05:21:40 +02:00
|
|
|
@param[in] Lba The logical block address to be read from
|
|
|
|
@param[in] Offset Offset into the block at which to begin reading
|
2008-07-21 14:53:53 +02:00
|
|
|
@param[in, out] NumBytes Pointer that on input contains the total size of
|
2007-07-13 05:21:40 +02:00
|
|
|
the buffer. On output, it contains the total number
|
2008-07-21 14:53:53 +02:00
|
|
|
of bytes read.
|
2007-07-13 05:21:40 +02:00
|
|
|
@param[in] Buffer Pointer to a caller allocated buffer that will be
|
2008-07-21 14:53:53 +02:00
|
|
|
used to hold the data read.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
|
|
|
@retval EFI_EFI_SUCCESS Buffer contains data read from FVB
|
|
|
|
@retval EFI_INVALID_PARAMETER invalid parameter
|
|
|
|
|
|
|
|
**/
|
2007-06-19 12:55:24 +02:00
|
|
|
EFI_STATUS
|
2008-07-21 09:26:20 +02:00
|
|
|
EFIAPI
|
2007-06-19 12:55:24 +02:00
|
|
|
EfiFvbReadBlock (
|
|
|
|
IN UINTN Instance,
|
|
|
|
IN EFI_LBA Lba,
|
|
|
|
IN UINTN Offset,
|
|
|
|
IN OUT UINTN *NumBytes,
|
|
|
|
IN UINT8 *Buffer
|
2007-07-13 05:21:40 +02:00
|
|
|
);
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
|
2007-07-13 05:21:40 +02:00
|
|
|
/**
|
2008-07-21 14:53:53 +02:00
|
|
|
Writes specified number of bytes from the input buffer to the block.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
2008-07-21 14:53:53 +02:00
|
|
|
@param[in] Instance The FV instance to be read from.
|
2007-07-13 05:21:40 +02:00
|
|
|
@param[in] Lba The logical block address to be write to
|
|
|
|
@param[in] Offset Offset into the block at which to begin writing
|
2008-07-21 14:53:53 +02:00
|
|
|
@param[in, out] NumBytes Pointer that on input contains the total size of
|
2007-07-13 05:21:40 +02:00
|
|
|
the buffer. On output, it contains the total number
|
|
|
|
of bytes actually written.
|
|
|
|
@param[in] Buffer Pointer to a caller allocated buffer that contains
|
2008-07-21 14:53:53 +02:00
|
|
|
the source for the write.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
|
|
|
@retval EFI_EFI_SUCCESS Buffer written to FVB
|
|
|
|
@retval EFI_INVALID_PARAMETER invalid parameter
|
|
|
|
|
|
|
|
**/
|
2007-06-19 12:55:24 +02:00
|
|
|
EFI_STATUS
|
2008-07-21 09:26:20 +02:00
|
|
|
EFIAPI
|
2007-06-19 12:55:24 +02:00
|
|
|
EfiFvbWriteBlock (
|
|
|
|
IN UINTN Instance,
|
|
|
|
IN EFI_LBA Lba,
|
|
|
|
IN UINTN Offset,
|
|
|
|
IN OUT UINTN *NumBytes,
|
|
|
|
IN UINT8 *Buffer
|
2007-07-13 05:21:40 +02:00
|
|
|
);
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
|
2007-07-13 05:21:40 +02:00
|
|
|
/**
|
2008-07-21 14:53:53 +02:00
|
|
|
Erases and initializes a firmware volume block.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
2008-07-21 14:53:53 +02:00
|
|
|
@param[in] Instance The FV instance to be erased.
|
|
|
|
@param[in] Lba The logical block address to be erased.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
|
|
|
@retval EFI_EFI_SUCCESS Lba was erased
|
|
|
|
@retval EFI_INVALID_PARAMETER invalid parameter
|
|
|
|
|
|
|
|
**/
|
2007-06-19 12:55:24 +02:00
|
|
|
EFI_STATUS
|
2008-07-21 09:26:20 +02:00
|
|
|
EFIAPI
|
2007-06-19 12:55:24 +02:00
|
|
|
EfiFvbEraseBlock (
|
|
|
|
IN UINTN Instance,
|
|
|
|
IN EFI_LBA Lba
|
2007-07-13 05:21:40 +02:00
|
|
|
);
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
|
2007-07-13 05:21:40 +02:00
|
|
|
/**
|
|
|
|
Retrieves attributes, insures positive polarity of attribute bits, returns
|
2008-07-21 14:53:53 +02:00
|
|
|
resulting attributes in output parameter.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
2008-07-21 14:53:53 +02:00
|
|
|
@param[in] Instance The FV instance.
|
2007-07-13 05:21:40 +02:00
|
|
|
@param[out] Attributes The FV instance whose attributes is going to be
|
2008-07-21 14:53:53 +02:00
|
|
|
returned.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
|
|
|
@retval EFI_EFI_SUCCESS Valid Attributes were returned
|
|
|
|
@retval EFI_INVALID_PARAMETER invalid parameter
|
|
|
|
|
|
|
|
**/
|
2007-06-19 12:55:24 +02:00
|
|
|
EFI_STATUS
|
2008-07-21 09:26:20 +02:00
|
|
|
EFIAPI
|
2007-06-19 12:55:24 +02:00
|
|
|
EfiFvbGetVolumeAttributes (
|
|
|
|
IN UINTN Instance,
|
|
|
|
OUT EFI_FVB_ATTRIBUTES *Attributes
|
2007-07-13 05:21:40 +02:00
|
|
|
);
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
|
2007-07-13 05:21:40 +02:00
|
|
|
/**
|
|
|
|
Modifies the current settings of the firmware volume according to the
|
2008-07-21 14:53:53 +02:00
|
|
|
input parameter, and returns the new setting of the volume.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
2008-07-21 14:53:53 +02:00
|
|
|
@param[in] Instance The FV instance.
|
|
|
|
@param[in, out]Attributes On input, it is a pointer to EFI_FVB_ATTRIBUTES
|
2007-07-13 05:21:40 +02:00
|
|
|
containing the desired firmware volume settings.
|
|
|
|
On successful return, it contains the new settings
|
2008-07-21 14:53:53 +02:00
|
|
|
of the firmware volume.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
|
|
|
@retval EFI_EFI_SUCCESS Attributes were updated
|
|
|
|
@retval EFI_INVALID_PARAMETER invalid parameter
|
|
|
|
|
|
|
|
**/
|
2007-06-19 12:55:24 +02:00
|
|
|
EFI_STATUS
|
2008-07-21 09:26:20 +02:00
|
|
|
EFIAPI
|
2007-06-19 12:55:24 +02:00
|
|
|
EfiFvbSetVolumeAttributes (
|
2007-08-22 11:33:34 +02:00
|
|
|
IN UINTN Instance,
|
|
|
|
IN OUT EFI_FVB_ATTRIBUTES *Attributes
|
2007-07-13 05:21:40 +02:00
|
|
|
);
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
|
2007-07-13 05:21:40 +02:00
|
|
|
/**
|
2008-07-21 14:53:53 +02:00
|
|
|
Retrieves the physical address of a memory mapped FV.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
|
|
|
@param[in] Instance The FV instance
|
|
|
|
@param[out] BaseAddress Pointer to a caller allocated EFI_PHYSICAL_ADDRESS
|
|
|
|
that on successful return, contains the base address
|
|
|
|
of the firmware volume.
|
|
|
|
|
|
|
|
@retval EFI_EFI_SUCCESS BaseAddress was returned
|
|
|
|
@retval EFI_INVALID_PARAMETER invalid parameter
|
|
|
|
|
|
|
|
**/
|
2007-06-19 12:55:24 +02:00
|
|
|
EFI_STATUS
|
2008-07-21 09:26:20 +02:00
|
|
|
EFIAPI
|
2007-06-19 12:55:24 +02:00
|
|
|
EfiFvbGetPhysicalAddress (
|
|
|
|
IN UINTN Instance,
|
|
|
|
OUT EFI_PHYSICAL_ADDRESS *BaseAddress
|
2007-07-13 05:21:40 +02:00
|
|
|
);
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
|
2007-07-13 05:21:40 +02:00
|
|
|
/**
|
2008-07-21 14:53:53 +02:00
|
|
|
Retrieve the size of a logical block.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
|
|
|
@param[in] Instance The FV instance
|
|
|
|
@param[in] Lba Indicates which block to return the size for.
|
2008-07-21 14:53:53 +02:00
|
|
|
@param[out] BlockSize A pointer to a caller allocated UINTN in which
|
|
|
|
the size of the block is returned.
|
2007-07-13 05:21:40 +02:00
|
|
|
@param[out] NumOfBlocks a pointer to a caller allocated UINTN in which the
|
|
|
|
number of consecutive blocks starting with Lba is
|
|
|
|
returned. All blocks in this range have a size of
|
2008-07-21 14:53:53 +02:00
|
|
|
BlockSize.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
|
|
|
@retval EFI_EFI_SUCCESS BlockSize and NumOfBlocks returned
|
|
|
|
@retval EFI_INVALID_PARAMETER invalid parameter
|
|
|
|
|
|
|
|
**/
|
2007-06-19 12:55:24 +02:00
|
|
|
EFI_STATUS
|
2008-07-21 09:26:20 +02:00
|
|
|
EFIAPI
|
2007-06-19 12:55:24 +02:00
|
|
|
EfiFvbGetBlockSize (
|
|
|
|
IN UINTN Instance,
|
|
|
|
IN EFI_LBA Lba,
|
|
|
|
OUT UINTN *BlockSize,
|
|
|
|
OUT UINTN *NumOfBlocks
|
2007-07-13 05:21:40 +02:00
|
|
|
);
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
|
2007-07-13 05:21:40 +02:00
|
|
|
/**
|
2008-07-21 14:53:53 +02:00
|
|
|
Erases and initializes a specified range of a firmware volume.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
2008-07-21 14:53:53 +02:00
|
|
|
@param[in] Instance The FV instance.
|
|
|
|
@param[in] StartLba The starting logical block index to be erased.
|
2007-07-13 05:21:40 +02:00
|
|
|
@param[in] OffsetStartLba Offset into the starting block at which to
|
2008-07-21 14:53:53 +02:00
|
|
|
begin erasing.
|
|
|
|
@param[in] LastLba The last logical block index to be erased.
|
|
|
|
@param[in] OffsetLastLba Offset into the last block at which to end erasing.
|
2007-07-13 05:21:40 +02:00
|
|
|
|
|
|
|
@retval EFI_EFI_SUCCESS Range was erased
|
|
|
|
@retval EFI_INVALID_PARAMETER invalid parameter
|
|
|
|
@retval EFI_UNSUPPORTED Range can not be erased
|
|
|
|
|
|
|
|
**/
|
2007-06-19 12:55:24 +02:00
|
|
|
EFI_STATUS
|
2008-07-21 09:26:20 +02:00
|
|
|
EFIAPI
|
2007-06-19 12:55:24 +02:00
|
|
|
EfiFvbEraseCustomBlockRange (
|
|
|
|
IN UINTN Instance,
|
|
|
|
IN EFI_LBA StartLba,
|
|
|
|
IN UINTN OffsetStartLba,
|
|
|
|
IN EFI_LBA LastLba,
|
|
|
|
IN UINTN OffsetLastLba
|
2007-07-13 05:21:40 +02:00
|
|
|
);
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
#endif
|