| /** @file | |
| This file declares GUIDed section extraction protocol. | |
| This interface provides a means of decoding a GUID defined encapsulation | |
| 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. | |
| 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 | |
| THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | |
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |
| 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__ | |
| // | |
| // 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 | |
| // | |
| /** | |
| Processes the input section and returns the data contained therein along | |
| 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. | |
| @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: | |
| If a GUID-defined section is encountered when doing section extraction, | |
| the section extraction driver calls the appropriate instance of the GUIDed | |
| Section Extraction Protocol to extract the section stream contained therein. | |
| @param ExtractSection | |
| Takes the GUIDed section as input and produces the section stream data. | |
| **/ | |
| struct _EFI_GUIDED_SECTION_EXTRACTION_PROTOCOL { | |
| EFI_EXTRACT_GUIDED_SECTION ExtractSection; | |
| }; | |
| // | |
| // may add other GUID here | |
| // | |
| extern EFI_GUID gEfiCrc32GuidedSectionExtractionProtocolGuid; | |
| #endif |