2008-04-03 06:56:34 +02:00
|
|
|
/** @file
|
2007-06-13 13:11:23 +02:00
|
|
|
This file provides location and format of a firmware volume.
|
|
|
|
|
2018-06-27 15:11:33 +02:00
|
|
|
Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:00 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-06-13 13:11:23 +02:00
|
|
|
|
|
|
|
@par Revision Reference:
|
2008-10-28 14:04:40 +01:00
|
|
|
This PPI is introduced in PI Version 1.0.
|
2007-06-13 13:11:23 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __EFI_PEI_FIRMWARE_VOLUME_INFO_H__
|
|
|
|
#define __EFI_PEI_FIRMWARE_VOLUME_INFO_H__
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define EFI_PEI_FIRMWARE_VOLUME_INFO_PPI_GUID \
|
|
|
|
{ 0x49edb1c1, 0xbf21, 0x4761, { 0xbb, 0x12, 0xeb, 0x0, 0x31, 0xaa, 0xbb, 0x39 } }
|
|
|
|
|
2007-06-18 22:28:02 +02:00
|
|
|
typedef struct _EFI_PEI_FIRMWARE_VOLUME_INFO_PPI EFI_PEI_FIRMWARE_VOLUME_INFO_PPI;
|
2007-06-13 13:11:23 +02:00
|
|
|
|
2008-09-04 11:15:21 +02:00
|
|
|
///
|
2018-06-27 15:11:33 +02:00
|
|
|
/// This PPI describes the location and format of a firmware volume.
|
|
|
|
/// The FvFormat can be EFI_FIRMWARE_FILE_SYSTEM2_GUID or the GUID for
|
|
|
|
/// a user-defined format. The EFI_FIRMWARE_FILE_SYSTEM2_GUID is
|
2008-09-04 11:15:21 +02:00
|
|
|
/// the PI Firmware Volume format.
|
|
|
|
///
|
2007-06-13 13:11:23 +02:00
|
|
|
struct _EFI_PEI_FIRMWARE_VOLUME_INFO_PPI {
|
2008-09-04 11:15:21 +02:00
|
|
|
///
|
|
|
|
/// Unique identifier of the format of the memory-mapped firmware volume.
|
|
|
|
///
|
2007-06-18 22:28:02 +02:00
|
|
|
EFI_GUID FvFormat;
|
2008-09-04 11:15:21 +02:00
|
|
|
///
|
|
|
|
/// Points to a buffer which allows the EFI_PEI_FIRMWARE_VOLUME_PPI to process
|
|
|
|
/// the volume. The format of this buffer is specific to the FvFormat.
|
|
|
|
/// For memory-mapped firmware volumes, this typically points to the first byte
|
|
|
|
/// of the firmware volume.
|
|
|
|
///
|
2007-06-18 22:28:02 +02:00
|
|
|
VOID *FvInfo;
|
2008-09-04 11:15:21 +02:00
|
|
|
///
|
|
|
|
/// Size of the data provided by FvInfo. For memory-mapped firmware volumes,
|
|
|
|
/// this is typically the size of the firmware volume.
|
|
|
|
///
|
2007-06-18 22:28:02 +02:00
|
|
|
UINT32 FvInfoSize;
|
2008-09-04 11:15:21 +02:00
|
|
|
///
|
|
|
|
/// If the firmware volume originally came from a firmware file, then these
|
|
|
|
/// point to the parent firmware volume name and firmware volume file.
|
|
|
|
/// If it did not originally come from a firmware file, these should be NULL.
|
|
|
|
///
|
2007-06-18 22:28:02 +02:00
|
|
|
EFI_GUID *ParentFvName;
|
2008-09-04 11:15:21 +02:00
|
|
|
///
|
|
|
|
/// If the firmware volume originally came from a firmware file, then these
|
|
|
|
/// point to the parent firmware volume name and firmware volume file.
|
|
|
|
/// If it did not originally come from a firmware file, these should be NULL.
|
|
|
|
///
|
2007-06-18 22:28:02 +02:00
|
|
|
EFI_GUID *ParentFileName;
|
2007-06-13 13:11:23 +02:00
|
|
|
};
|
|
|
|
|
2007-06-18 22:28:02 +02:00
|
|
|
extern EFI_GUID gEfiPeiFirmwareVolumeInfoPpiGuid;
|
2007-06-13 13:11:23 +02:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|