2008-04-03 06:56:34 +02:00
|
|
|
/** @file
|
2020-02-07 02:07:40 +01:00
|
|
|
Provides decompression services to the PEI Foundation.
|
2007-06-13 13:11:23 +02:00
|
|
|
|
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 __DECOMPRESS_PPI_H__
|
|
|
|
#define __DECOMPRESS_PPI_H__
|
|
|
|
|
|
|
|
#define EFI_PEI_DECOMPRESS_PPI_GUID \
|
2007-06-18 22:28:02 +02:00
|
|
|
{ 0x1a36e4e7, 0xfab6, 0x476a, { 0x8e, 0x75, 0x69, 0x5a, 0x5, 0x76, 0xfd, 0xd7 } }
|
2007-06-13 13:11:23 +02:00
|
|
|
|
2021-12-05 23:54:05 +01:00
|
|
|
typedef struct _EFI_PEI_DECOMPRESS_PPI EFI_PEI_DECOMPRESS_PPI;
|
2007-06-13 13:11:23 +02:00
|
|
|
|
2018-06-27 15:11:33 +02:00
|
|
|
/**
|
2008-07-16 12:44:37 +02:00
|
|
|
Decompress a single compression section in a firmware file.
|
2018-06-27 15:11:33 +02:00
|
|
|
|
2007-06-13 13:11:23 +02:00
|
|
|
Decompresses the data in a compressed section and returns it
|
|
|
|
as a series of standard PI Firmware File Sections. The
|
|
|
|
required memory is allocated from permanent memory.
|
|
|
|
|
2008-09-04 11:15:21 +02:00
|
|
|
@param This Points to this instance of the
|
|
|
|
EFI_PEI_DECOMPRESS_PEI PPI.
|
|
|
|
@param InputSection Points to the compressed section.
|
|
|
|
@param OutputBuffer Holds the returned pointer to the
|
|
|
|
decompressed sections.
|
|
|
|
@param OutputSize Holds the returned size of the decompress
|
|
|
|
section streams.
|
2007-06-13 13:11:23 +02:00
|
|
|
|
2007-06-18 22:28:02 +02:00
|
|
|
@retval EFI_SUCCESS The section was decompressed
|
|
|
|
successfully. OutputBuffer contains the
|
|
|
|
resulting data and OutputSize contains
|
|
|
|
the resulting size.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Unable to allocate sufficient
|
2007-06-13 13:11:23 +02:00
|
|
|
memory to hold the decompressed data.
|
2007-06-18 22:28:02 +02:00
|
|
|
@retval EFI_UNSUPPORTED The compression type specified
|
|
|
|
in the compression header is unsupported.
|
2008-09-04 11:15:21 +02:00
|
|
|
|
2007-06-13 13:11:23 +02:00
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *EFI_PEI_DECOMPRESS_DECOMPRESS)(
|
2008-09-04 11:15:21 +02:00
|
|
|
IN CONST EFI_PEI_DECOMPRESS_PPI *This,
|
|
|
|
IN CONST EFI_COMPRESSION_SECTION *InputSection,
|
|
|
|
OUT VOID **OutputBuffer,
|
|
|
|
OUT UINTN *OutputSize
|
2021-12-05 23:54:05 +01:00
|
|
|
);
|
2007-06-13 13:11:23 +02:00
|
|
|
|
2008-09-04 11:15:21 +02:00
|
|
|
///
|
|
|
|
/// This PPI's single member function decompresses a compression
|
|
|
|
/// encapsulated section. It is used by the PEI Foundation to
|
|
|
|
/// process sectioned files. Prior to the installation of this PPI,
|
|
|
|
/// compression sections will be ignored.
|
|
|
|
///
|
2007-06-13 13:11:23 +02:00
|
|
|
struct _EFI_PEI_DECOMPRESS_PPI {
|
2021-12-05 23:54:05 +01:00
|
|
|
EFI_PEI_DECOMPRESS_DECOMPRESS Decompress;
|
2007-06-13 13:11:23 +02:00
|
|
|
};
|
|
|
|
|
2021-12-05 23:54:05 +01:00
|
|
|
extern EFI_GUID gEfiPeiDecompressPpiGuid;
|
2007-06-13 13:11:23 +02:00
|
|
|
|
|
|
|
#endif
|