/* 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(
        CONST VOID   *SrcBuffer,
        UINT32  SrcSize,
        VOID   *DstBuffer,
        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(
        CONST VOID   *SrcBuffer,
        UINT32  SrcSize,
        VOID   *DstBuffer,
        UINT32  *DstSize
        )
        ;
    EFI_STATUS
        EfiCompressLegacy(
        CONST VOID   *SrcBuffer,
        UINT32  SrcSize,
        VOID   *DstBuffer,
        UINT32  *DstSize
        )
        ;

#ifdef __cplusplus
}
#endif
#endif