Merge pull request #875 from facebook/zstdcat

decode more data before triggering error
This commit is contained in:
Yann Collet 2017-09-29 20:12:25 -07:00 committed by GitHub
commit 657946a913

View File

@ -1213,14 +1213,18 @@ unsigned long long FIO_decompressZstdFrame(dRess_t* ress,
U64 frameSize = 0; U64 frameSize = 0;
U32 storedSkips = 0; U32 storedSkips = 0;
size_t const srcFileLength = strlen(srcFileName);
if (srcFileLength>20) srcFileName += srcFileLength-20; /* display last 20 characters only */
ZSTD_resetDStream(ress->dctx); ZSTD_resetDStream(ress->dctx);
if (strlen(srcFileName)>20) srcFileName += strlen(srcFileName)-20; /* display last 20 characters */
/* Header loading : ensures ZSTD_getFrameHeader() will succeed */ /* Header loading : ensures ZSTD_getFrameHeader() will succeed */
{ size_t const toRead = ZSTD_FRAMEHEADERSIZE_MAX; { size_t const toDecode = ZSTD_FRAMEHEADERSIZE_MAX;
if (ress->srcBufferLoaded < toRead) if (ress->srcBufferLoaded < toDecode) {
ress->srcBufferLoaded += fread(((char*)ress->srcBuffer) + ress->srcBufferLoaded, 1, toRead - ress->srcBufferLoaded, finput); size_t const toRead = toDecode - ress->srcBufferLoaded;
} void* const startPosition = (char*)ress->srcBuffer + ress->srcBufferLoaded;
ress->srcBufferLoaded += fread(startPosition, 1, toRead, finput);
} }
/* Main decompression Loop */ /* Main decompression Loop */
while (1) { while (1) {
@ -1253,14 +1257,17 @@ unsigned long long FIO_decompressZstdFrame(dRess_t* ress,
} }
/* Fill input buffer */ /* Fill input buffer */
{ size_t const toRead = MIN(readSizeHint, ress->srcBufferSize); /* support large skippable frames */ { size_t const toDecode = MIN(readSizeHint, ress->srcBufferSize); /* support large skippable frames */
if (ress->srcBufferLoaded < toRead) if (ress->srcBufferLoaded < toDecode) {
ress->srcBufferLoaded += fread((char*)ress->srcBuffer + ress->srcBufferLoaded, size_t const toRead = toDecode - ress->srcBufferLoaded; /* > 0 */
1, toRead - ress->srcBufferLoaded, finput); void* const startPosition = (char*)ress->srcBuffer + ress->srcBufferLoaded;
if (ress->srcBufferLoaded < toRead) { size_t const readSize = fread(startPosition, 1, toRead, finput);
if (readSize==0) {
DISPLAYLEVEL(1, "%s : Read error (39) : premature end \n", DISPLAYLEVEL(1, "%s : Read error (39) : premature end \n",
srcFileName); srcFileName);
return FIO_ERROR_FRAME_DECODING; return FIO_ERROR_FRAME_DECODING;
}
ress->srcBufferLoaded += readSize;
} } } } } }
FIO_fwriteSparseEnd(ress->dstFile, storedSkips); FIO_fwriteSparseEnd(ress->dstFile, storedSkips);