2007-06-27 07:49:17 +02:00
|
|
|
/** @file
|
|
|
|
This file declares GUIDed section extraction protocol.
|
|
|
|
|
2007-06-28 14:23:11 +02:00
|
|
|
This interface provides a means of decoding a GUID defined encapsulation
|
2007-06-27 07:49:17 +02:00
|
|
|
section. There may be multiple different GUIDs associated with the GUIDed
|
|
|
|
section extraction protocol. That is, all instances of the GUIDed section
|
|
|
|
extraction protocol must have the same interface structure.
|
|
|
|
|
2007-06-28 14:23:11 +02:00
|
|
|
Copyright (c) 2006, 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
|
2007-06-27 07:49:17 +02:00
|
|
|
|
2007-06-28 14:23:11 +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-27 07:49:17 +02:00
|
|
|
|
|
|
|
Module Name: GuidedSectionExtraction.h
|
|
|
|
|
|
|
|
@par Revision Reference:
|
|
|
|
This protocol is defined in Firmware Volume Specification.
|
|
|
|
Version 0.9
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __GUIDED_SECTION_EXTRACTION_PROTOCOL_H__
|
|
|
|
#define __GUIDED_SECTION_EXTRACTION_PROTOCOL_H__
|
|
|
|
|
2007-06-28 14:23:11 +02:00
|
|
|
#include <PiDxe.h>
|
2007-06-27 07:49:17 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Protocol GUID definition. Each GUIDed section extraction protocol has the
|
|
|
|
// same interface but with different GUID. All the GUIDs is defined here.
|
|
|
|
// May add multiple GUIDs here.
|
|
|
|
//
|
|
|
|
#define EFI_CRC32_GUIDED_SECTION_EXTRACTION_PROTOCOL_GUID \
|
|
|
|
{ \
|
|
|
|
0xFC1BCDB0, 0x7D31, 0x49aa, {0x93, 0x6A, 0xA4, 0x60, 0x0D, 0x9D, 0xD0, 0x83 } \
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Forward reference for pure ANSI compatability
|
|
|
|
//
|
|
|
|
typedef struct _EFI_GUIDED_SECTION_EXTRACTION_PROTOCOL EFI_GUIDED_SECTION_EXTRACTION_PROTOCOL;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Protocol member functions
|
|
|
|
//
|
|
|
|
/**
|
2007-06-28 14:23:11 +02:00
|
|
|
Processes the input section and returns the data contained therein along
|
2007-06-27 07:49:17 +02:00
|
|
|
with the authentication status.
|
|
|
|
|
|
|
|
@param This Indicates the EFI_GUIDED_SECTION_EXTRACTION_PROTOCOL instance.
|
|
|
|
@param InputSection Buffer containing the input GUIDed section to be processed.
|
|
|
|
@param OutputBuffer *OutputBuffer is allocated from boot services pool memory
|
|
|
|
and contains the new section stream.
|
|
|
|
@param OutputSize A pointer to a caller-allocated UINTN in which the size
|
|
|
|
of *OutputBuffer allocation is stored.
|
|
|
|
@param AuthenticationStatus A pointer to a caller-allocated UINT32 that
|
|
|
|
indicates the authentication status of the output buffer.
|
2007-06-28 14:23:11 +02:00
|
|
|
|
2007-06-27 07:49:17 +02:00
|
|
|
@retval EFI_SUCCESS The InputSection was successfully processed and the
|
|
|
|
section contents were returned.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES The system has insufficient resources to
|
|
|
|
process the request.
|
|
|
|
@retval EFI_INVALID_PARAMETER The GUID in InputSection does not match
|
|
|
|
this instance of the GUIDed Section Extraction Protocol.
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *EFI_EXTRACT_GUIDED_SECTION) (
|
|
|
|
IN EFI_GUIDED_SECTION_EXTRACTION_PROTOCOL *This,
|
|
|
|
IN VOID *InputSection,
|
|
|
|
OUT VOID **OutputBuffer,
|
|
|
|
OUT UINTN *OutputSize,
|
|
|
|
OUT UINT32 *AuthenticationStatus
|
|
|
|
);
|
|
|
|
|
|
|
|
//
|
|
|
|
// Protocol definition
|
|
|
|
//
|
|
|
|
/**
|
|
|
|
@par Protocol Description:
|
2007-06-28 14:23:11 +02:00
|
|
|
If a GUID-defined section is encountered when doing section extraction,
|
|
|
|
the section extraction driver calls the appropriate instance of the GUIDed
|
2007-06-27 07:49:17 +02:00
|
|
|
Section Extraction Protocol to extract the section stream contained therein.
|
|
|
|
|
|
|
|
@param ExtractSection
|
2007-06-28 14:23:11 +02:00
|
|
|
Takes the GUIDed section as input and produces the section stream data.
|
2007-06-27 07:49:17 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
struct _EFI_GUIDED_SECTION_EXTRACTION_PROTOCOL {
|
|
|
|
EFI_EXTRACT_GUIDED_SECTION ExtractSection;
|
|
|
|
};
|
|
|
|
|
|
|
|
//
|
|
|
|
// may add other GUID here
|
|
|
|
//
|
|
|
|
extern EFI_GUID gEfiCrc32GuidedSectionExtractionProtocolGuid;
|
|
|
|
|
|
|
|
#endif
|