git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@9018 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			148 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			148 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|   Framework Capule related Definition.
 | |
| 
 | |
|   Copyright (c) 2007 - 2009, Intel Corporation
 | |
|   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
 | |
| 
 | |
|   THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
 | |
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
 | |
| 
 | |
|   @par Revision Reference:
 | |
|   Capsule Spec Version 0.9
 | |
| **/
 | |
| 
 | |
| #ifndef _CAPSULE_GUID_H__
 | |
| #define _CAPSULE_GUID_H__
 | |
| 
 | |
| //
 | |
| // This is the GUID of the capsule header of the image on disk.
 | |
| //
 | |
| #define EFI_CAPSULE_GUID \
 | |
|   { \
 | |
|     0x3B6686BD, 0x0D76, 0x4030, {0xB7, 0x0E, 0xB5, 0x51, 0x9E, 0x2F, 0xC5, 0xA0 } \
 | |
|   }
 | |
| 
 | |
| //
 | |
| // This is the GUID of the configuration results file created by the capsule
 | |
| // application.
 | |
| //
 | |
| #define EFI_CONFIG_FILE_NAME_GUID \
 | |
|   { \
 | |
|     0x98B8D59B, 0xE8BA, 0x48EE, {0x98, 0xDD, 0xC2, 0x95, 0x39, 0x2F, 0x1E, 0xDB } \
 | |
|   }
 | |
| 
 | |
| ///
 | |
| /// Bits in the flags field of the capsule header
 | |
| /// This flag is set if the capsule can support setup changes, and cleared if it cannot.
 | |
| ///
 | |
| #define EFI_CAPSULE_HEADER_FLAG_SETUP 0x00000001
 | |
| 
 | |
| #define CAPSULE_BLOCK_DESCRIPTOR_SIGNATURE  SIGNATURE_32 ('C', 'B', 'D', 'S')
 | |
| 
 | |
| //
 | |
| // An array of these structs describe the blocks that make up a capsule for
 | |
| // a capsule update.
 | |
| //
 | |
| typedef struct {
 | |
|   UINT64                Length;     ///< length of the data block
 | |
|   EFI_PHYSICAL_ADDRESS  Data;       ///< physical address of the data block
 | |
|   UINT32                Signature;  ///< CBDS
 | |
|   UINT32                CheckSum;   ///< to sum this structure to 0
 | |
| } FRAMEWORK_EFI_CAPSULE_BLOCK_DESCRIPTOR;
 | |
| 
 | |
| typedef struct {
 | |
|   EFI_GUID  OemGuid;
 | |
|   UINT32    HeaderSize;
 | |
|   //
 | |
|   // UINT8                       OemHdrData[];
 | |
|   //
 | |
| } EFI_CAPSULE_OEM_HEADER;
 | |
| 
 | |
| typedef struct {
 | |
|   ///
 | |
|   /// A defined GUID that indicates the start of a capsule.
 | |
|   ///
 | |
|   EFI_GUID  CapsuleGuid;
 | |
|   ///
 | |
|   /// The size of the EFI_CAPSULE_HEADER structure.
 | |
|   ///
 | |
|   UINT32    HeaderSize;
 | |
|   ///
 | |
|   /// A bit-mapped list describing the capsule's attributes. 
 | |
|   /// All undefined bits should be written as zero (0)
 | |
|   ///
 | |
|   UINT32    Flags;
 | |
|   ///
 | |
|   /// The length in bytes (27,415 for an image containing 27,415 bytes) of the entire image
 | |
|   /// including all headers. If this value is greater than the size of the data presented in
 | |
|   /// the capsule body, the image is separated across multiple media. If this
 | |
|   /// value is less than the size of the data, it is an error.
 | |
|   ///
 | |
|   UINT32    CapsuleImageSize;
 | |
|   ///
 | |
|   /// A zero-based number that enables a capsule to be split into pieces and then
 | |
|   /// recombined for easier transfer across media with limited size. The lower the
 | |
|   /// SequenceNumber, the earlier in the final image that the part of the capsule is to
 | |
|   /// appear. In capsules that are not split, this value shall be zero.
 | |
|   ///
 | |
|   UINT32    SequenceNumber;
 | |
|   ///
 | |
|   /// Used to group the various pieces of a split capsule to ensure that they comprise the
 | |
|   /// same base image. It is valid for this item to be zero, in which case the capsule cannot
 | |
|   /// be split into components.
 | |
|   ///
 | |
|   EFI_GUID  InstanceId;
 | |
|   ///
 | |
|   /// The offset in bytes from the beginning of the header to the start of an EFI string that
 | |
|   /// contains a description of the identity of the subcapsules that make up the capsule. If
 | |
|   /// the capsule is not split, this value should be zero. The same string should be
 | |
|   /// presented for all subcapsules that constitute the same capsule.
 | |
|   ///
 | |
|   UINT32    OffsetToSplitInformation;
 | |
|   ///
 | |
|   /// The offset in bytes from the beginning of the header to the start of the part of the
 | |
|   /// capsule that is to be transferred to DXE.
 | |
|   ///
 | |
|   UINT32    OffsetToCapsuleBody;
 | |
|   ///
 | |
|   /// The offset in bytes from the beginning of the header to the start of the OEM-defined
 | |
|   /// header. This value must be less than OffsetToCapsuleBody.
 | |
|   ///
 | |
|   UINT32    OffsetToOemDefinedHeader;
 | |
|   ///
 | |
|   /// The offset in bytes from the beginning of the header to the start of human-readable
 | |
|   /// text that describes the entity that created the capsule. This value must be less than OffsetToCapsuleBody.
 | |
|   ///
 | |
|   UINT32    OffsetToAuthorInformation;
 | |
|   ///
 | |
|   /// The offset in bytes from the beginning of the header to the start of human-readable
 | |
|   /// text that describes the revision of the capsule and/or the capsule's contents. This
 | |
|   /// value must be less than OffsetToCapsuleBody.
 | |
|   ///
 | |
|   UINT32    OffsetToRevisionInformation;
 | |
|   ///
 | |
|   /// The offset in bytes from the beginning of the header to the start of a one-line (less
 | |
|   /// than 40 Unicode characters in any language) description of the capsule. It is intended
 | |
|   /// to be used by OS-present applications when providing a list of capsules from which
 | |
|   /// the user can choose. This value must be less than OffsetToCapsuleBody.
 | |
|   ///
 | |
|   UINT32    OffsetToShortDescription;
 | |
|   ///
 | |
|   /// The offset in bytes from the beginning of the header to the start of an EFI string
 | |
|   ///
 | |
|   UINT32    OffsetToLongDescription;
 | |
|   ///
 | |
|   /// This field is reserved for future use by this specification. For future compatibility,
 | |
|   /// this field must be set to zero
 | |
|   ///
 | |
|   UINT32    OffsetToApplicableDevices;
 | |
| } FRAMEWORK_EFI_CAPSULE_HEADER;
 | |
| 
 | |
| extern EFI_GUID gEfiCapsuleGuid;
 | |
| extern EFI_GUID gEfiConfigFileNameGuid;
 | |
| 
 | |
| #endif
 |