mirror of
https://github.com/LongSoft/UEFITool.git
synced 2025-01-22 20:59:04 +08:00
116 lines
2.9 KiB
C
116 lines
2.9 KiB
C
/* EfiTianoCompress.h
|
|
|
|
Copyright (c) 2014, Nikolaj Schlej. All rights reserved.<BR>
|
|
Copyright (c) 2004 - 2008, Intel Corporation. All rights reserved.<BR>
|
|
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:
|
|
|
|
TianoCompress.h
|
|
|
|
Abstract:
|
|
|
|
Header file for compression routine.
|
|
|
|
*/
|
|
|
|
#ifndef EFITIANOCOMPRESS_H
|
|
#define EFITIANOCOMPRESS_H
|
|
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
|
|
#include "../basetypes.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Tiano compression routine.
|
|
|
|
Arguments:
|
|
|
|
SrcBuffer - The buffer storing the source data
|
|
SrcSize - The size of source data
|
|
DstBuffer - The buffer to store the compressed data
|
|
DstSize - On input, the size of DstBuffer; On output,
|
|
the size of the actual compressed data.
|
|
|
|
Returns:
|
|
|
|
EFI_BUFFER_TOO_SMALL - The DstBuffer is too small. this case,
|
|
DstSize contains the size needed.
|
|
EFI_SUCCESS - Compression is successful.
|
|
EFI_OUT_OF_RESOURCES - No resource to complete function.
|
|
EFI_INVALID_PARAMETER - Parameter supplied is wrong.
|
|
|
|
--*/
|
|
EFI_STATUS
|
|
TianoCompress (
|
|
IN CONST VOID *SrcBuffer,
|
|
IN UINT32 SrcSize,
|
|
IN VOID *DstBuffer,
|
|
IN OUT UINT32 *DstSize
|
|
);
|
|
|
|
EFI_STATUS
|
|
TianoCompressLegacy(
|
|
CONST VOID *SrcBuffer,
|
|
UINT32 SrcSize,
|
|
VOID *DstBuffer,
|
|
UINT32 *DstSize
|
|
);
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
EFI 1.1 compression routine.
|
|
|
|
Arguments:
|
|
|
|
SrcBuffer - The buffer storing the source data
|
|
SrcSize - The size of source data
|
|
DstBuffer - The buffer to store the compressed data
|
|
DstSize - On input, the size of DstBuffer; On output,
|
|
the size of the actual compressed data.
|
|
|
|
Returns:
|
|
|
|
EFI_BUFFER_TOO_SMALL - The DstBuffer is too small. this case,
|
|
DstSize contains the size needed.
|
|
EFI_SUCCESS - Compression is successful.
|
|
EFI_OUT_OF_RESOURCES - No resource to complete function.
|
|
EFI_INVALID_PARAMETER - Parameter supplied is wrong.
|
|
|
|
--*/
|
|
EFI_STATUS
|
|
EfiCompress (
|
|
IN CONST VOID *SrcBuffer,
|
|
IN UINT32 SrcSize,
|
|
IN VOID *DstBuffer,
|
|
IN OUT UINT32 *DstSize
|
|
);
|
|
|
|
EFI_STATUS
|
|
EfiCompressLegacy(
|
|
CONST VOID *SrcBuffer,
|
|
UINT32 SrcSize,
|
|
VOID *DstBuffer,
|
|
UINT32 *DstSize
|
|
);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif // EFITIANOCOMPRESS_H
|