mirror of
https://github.com/emmanuel-marty/lzsa.git
synced 2024-11-29 05:49:20 +00:00
Remove file after restructuring
This commit is contained in:
parent
ee6ab423fc
commit
8ef0396b50
161
src/inmem.c
161
src/inmem.c
@ -1,161 +0,0 @@
|
|||||||
/*
|
|
||||||
* inmem.c - in-memory decompression for benchmarks
|
|
||||||
*
|
|
||||||
* Copyright (C) 2019 Emmanuel Marty
|
|
||||||
*
|
|
||||||
* This software is provided 'as-is', without any express or implied
|
|
||||||
* warranty. In no event will the authors be held liable for any damages
|
|
||||||
* arising from the use of this software.
|
|
||||||
*
|
|
||||||
* Permission is granted to anyone to use this software for any purpose,
|
|
||||||
* including commercial applications, and to alter it and redistribute it
|
|
||||||
* freely, subject to the following restrictions:
|
|
||||||
*
|
|
||||||
* 1. The origin of this software must not be misrepresented; you must not
|
|
||||||
* claim that you wrote the original software. If you use this software
|
|
||||||
* in a product, an acknowledgment in the product documentation would be
|
|
||||||
* appreciated but is not required.
|
|
||||||
* 2. Altered source versions must be plainly marked as such, and must not be
|
|
||||||
* misrepresented as being the original software.
|
|
||||||
* 3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Uses the libdivsufsort library Copyright (c) 2003-2008 Yuta Mori
|
|
||||||
*
|
|
||||||
* Inspired by LZ4 by Yann Collet. https://github.com/lz4/lz4
|
|
||||||
* With help, ideas, optimizations and speed measurements by spke <zxintrospec@gmail.com>
|
|
||||||
* With ideas from Lizard by Przemyslaw Skibinski and Yann Collet. https://github.com/inikep/lizard
|
|
||||||
* Also with ideas from smallz4 by Stephan Brumme. https://create.stephan-brumme.com/smallz4/
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include "inmem.h"
|
|
||||||
#include "lib.h"
|
|
||||||
#include "frame.h"
|
|
||||||
|
|
||||||
#define BLOCK_SIZE 65536
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get maximum decompressed size of compressed data
|
|
||||||
*
|
|
||||||
* @param pFileData compressed data
|
|
||||||
* @param nFileSize compressed size in bytes
|
|
||||||
*
|
|
||||||
* @return maximum decompressed size
|
|
||||||
*/
|
|
||||||
size_t lzsa_inmem_get_max_decompressed_size(const unsigned char *pFileData, size_t nFileSize) {
|
|
||||||
const unsigned char *pCurFileData = pFileData;
|
|
||||||
const unsigned char *pEndFileData = pCurFileData + nFileSize;
|
|
||||||
int nFormatVersion = 0;
|
|
||||||
size_t nMaxDecompressedSize = 0;
|
|
||||||
const int nHeaderSize = lzsa_get_header_size();
|
|
||||||
|
|
||||||
/* Check header */
|
|
||||||
if ((pCurFileData + nHeaderSize) > pEndFileData ||
|
|
||||||
lzsa_decode_header(pCurFileData, nHeaderSize, &nFormatVersion) != 0)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
pCurFileData += nHeaderSize;
|
|
||||||
|
|
||||||
while (pCurFileData < pEndFileData) {
|
|
||||||
unsigned int nBlockDataSize = 0;
|
|
||||||
int nIsUncompressed = 0;
|
|
||||||
const int nFrameSize = lzsa_get_frame_size();
|
|
||||||
|
|
||||||
/* Decode frame header */
|
|
||||||
if ((pCurFileData + nFrameSize) > pEndFileData ||
|
|
||||||
lzsa_decode_frame(pCurFileData, nFrameSize, &nBlockDataSize, &nIsUncompressed) != 0)
|
|
||||||
return -1;
|
|
||||||
pCurFileData += nFrameSize;
|
|
||||||
|
|
||||||
if (!nBlockDataSize)
|
|
||||||
break;
|
|
||||||
|
|
||||||
/* Add one potentially full block to the decompressed size */
|
|
||||||
nMaxDecompressedSize += BLOCK_SIZE;
|
|
||||||
|
|
||||||
if ((pCurFileData + nBlockDataSize) > pEndFileData)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
pCurFileData += nBlockDataSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
return nMaxDecompressedSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Decompress data in memory
|
|
||||||
*
|
|
||||||
* @param pFileData compressed data
|
|
||||||
* @param pOutBuffer buffer for decompressed data
|
|
||||||
* @param nFileSize compressed size in bytes
|
|
||||||
* @param nMaxOutBufferSize maximum capacity of decompression buffer
|
|
||||||
* @param pFormatVersion pointer to format version, updated if this function is successful
|
|
||||||
*
|
|
||||||
* @return actual decompressed size, or -1 for error
|
|
||||||
*/
|
|
||||||
size_t lzsa_inmem_decompress_stream(const unsigned char *pFileData, unsigned char *pOutBuffer, size_t nFileSize, size_t nMaxOutBufferSize, int *pFormatVersion) {
|
|
||||||
const unsigned char *pCurFileData = pFileData;
|
|
||||||
const unsigned char *pEndFileData = pCurFileData + nFileSize;
|
|
||||||
unsigned char *pCurOutBuffer = pOutBuffer;
|
|
||||||
const unsigned char *pEndOutBuffer = pCurOutBuffer + nMaxOutBufferSize;
|
|
||||||
int nFormatVersion = 0;
|
|
||||||
int nPreviousBlockSize;
|
|
||||||
const int nHeaderSize = lzsa_get_header_size();
|
|
||||||
|
|
||||||
/* Check header */
|
|
||||||
if ((pCurFileData + nHeaderSize) > pEndFileData ||
|
|
||||||
lzsa_decode_header(pCurFileData, nHeaderSize, &nFormatVersion) != 0)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
pCurFileData += nHeaderSize;
|
|
||||||
nPreviousBlockSize = 0;
|
|
||||||
|
|
||||||
while (pCurFileData < pEndFileData) {
|
|
||||||
unsigned int nBlockDataSize = 0;
|
|
||||||
int nIsUncompressed = 0;
|
|
||||||
const int nFrameSize = lzsa_get_frame_size();
|
|
||||||
|
|
||||||
/* Decode frame header */
|
|
||||||
if ((pCurFileData + nFrameSize) > pEndFileData ||
|
|
||||||
lzsa_decode_frame(pCurFileData, nFrameSize, &nBlockDataSize, &nIsUncompressed) != 0)
|
|
||||||
return -1;
|
|
||||||
pCurFileData += nFrameSize;
|
|
||||||
|
|
||||||
if (!nBlockDataSize)
|
|
||||||
break;
|
|
||||||
|
|
||||||
if (!nIsUncompressed) {
|
|
||||||
int nDecompressedSize;
|
|
||||||
|
|
||||||
/* Decompress block */
|
|
||||||
if ((pCurFileData + nBlockDataSize) > pEndFileData)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
nDecompressedSize = lzsa_decompressor_expand_block(nFormatVersion, pCurFileData, nBlockDataSize, pCurOutBuffer - nPreviousBlockSize, nPreviousBlockSize, (int)(pEndOutBuffer - pCurOutBuffer + nPreviousBlockSize));
|
|
||||||
if (nDecompressedSize < 0)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
pCurOutBuffer += nDecompressedSize;
|
|
||||||
nPreviousBlockSize = nDecompressedSize;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
/* Copy uncompressed block */
|
|
||||||
if ((pCurFileData + nBlockDataSize) > pEndFileData)
|
|
||||||
return -1;
|
|
||||||
if ((pCurOutBuffer + nBlockDataSize) > pEndOutBuffer)
|
|
||||||
return -1;
|
|
||||||
memcpy(pCurOutBuffer, pCurFileData, nBlockDataSize);
|
|
||||||
pCurOutBuffer += nBlockDataSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
pCurFileData += nBlockDataSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
*pFormatVersion = nFormatVersion;
|
|
||||||
return (int)(pCurOutBuffer - pOutBuffer);
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user