* enough for SuperBlock compression.
* In such case, fall back to normal compression. This is possible because
* targetCBlockSize is best effort not a guarantee. */
- if (cSize == ERROR(dstSize_tooSmall) || (dstCapacity - cSize) < 4) {
- /* We check (dstCapacity - cSize) < 4 above because we have to make sure
+ if (cSize != ERROR(dstSize_tooSmall) && (dstCapacity - cSize) >= 4)
+ /* We check (dstCapacity - cSize) >= 4 above because we have to make sure
* to leave enough room for the checksum that will eventually get added in
* the epilogue. Otherwise, we're just going to throw the dstSize_tooSmall
* error there instead of here */
+ return cSize;
+ else {
BYTE* const ostart = (BYTE*)dst;
/* If ZSTD_noCompressSuperBlock fails with dstSize_tooSmall,
* compress normally.
zc->entropyWorkspace, HUF_WORKSPACE_SIZE /* statically allocated in resetCCtx */,
zc->bmi2);
+ FORWARD_IF_ERROR(cSize);
if (cSize == 0) {
/* If compressSequences didn't work, we just output a regular
* uncompressed block */
MEM_writeLE24(ostart, cBlockHeader24);
cSize += ZSTD_blockHeaderSize;
}
- } else return cSize;
+ }
}
if (!ZSTD_isError(cSize) && cSize != 0) {