Skip to content

Commit

Permalink
ossfuzz: add fuzz for LZ4_decompress_safe_partial_usingDict
Browse files Browse the repository at this point in the history
Signed-off-by: Qi Wang <wangqi@linux.alibaba.com>
  • Loading branch information
yawqi committed Jun 7, 2022
1 parent f29e288 commit dacd14c
Show file tree
Hide file tree
Showing 2 changed files with 79 additions and 4 deletions.
18 changes: 17 additions & 1 deletion ossfuzz/decompress_fuzzer.c
Original file line number Diff line number Diff line change
Expand Up @@ -49,11 +49,27 @@ int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
LZ4_decompress_safe_usingDict((char const*)dataAfterDict, dst, size,
dstCapacity, smallDict, smallDictSize);
/* Large prefix. */
LZ4_decompress_safe_usingDict((char const*)data, dst, size,
LZ4_decompress_safe_usingDict((char const*)dataAfterDict, dst, size,
dstCapacity, largeDict, largeDictSize);
/* Partial decompression. */
LZ4_decompress_safe_partial((char const*)data, dst, size,
dstCapacity, dstCapacity);
/* Partial decompression using each possible dictionary configuration. */
/* Partial decompression with no dictionary. */
LZ4_decompress_safe_partial_usingDict((char const*)data, dst, size,
dstCapacity, dstCapacity, NULL, 0);
/* Partial decompression with small external dictionary. */
LZ4_decompress_safe_partial_usingDict((char const*)data, dst, size,
dstCapacity, dstCapacity, smallDict, smallDictSize);
/* Partial decompression with large external dictionary. */
LZ4_decompress_safe_partial_usingDict((char const*)data, dst, size,
dstCapacity, dstCapacity, largeDict, largeDictSize);
/* Partial decompression with small prefix. */
LZ4_decompress_safe_partial_usingDict((char const*)dataAfterDict, dst, size,
dstCapacity, dstCapacity, smallDict, smallDictSize);
/* Partial decompression wtih large prefix. */
LZ4_decompress_safe_partial_usingDict((char const*)dataAfterDict, dst, size,
dstCapacity, dstCapacity, largeDict, largeDictSize);
free(dst);
free(dict);
FUZZ_dataProducer_free(producer);
Expand Down
65 changes: 62 additions & 3 deletions ossfuzz/round_trip_fuzzer.c
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,13 @@ int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)

size_t const partialCapacity = FUZZ_getRange_from_uint32(partialCapacitySeed, 0, size);
size_t const dstCapacity = LZ4_compressBound(size);

char* const dst = (char*)malloc(dstCapacity);
size_t const largeSize = 64 * 1024 - 1;
size_t const smallSize = 1024;
char* const dstPlusLargePrefix = (char*)malloc(dstCapacity + largeSize);
char* const dstPlusSmallPrefix = dstPlusLargePrefix + largeSize - smallSize;
char* const largeDict = (char*)malloc(largeSize);
char* const smallDict = largeDict + largeSize - smallSize;
char* const dst = dstPlusLargePrefix + largeSize;
char* const rt = (char*)malloc(size);

FUZZ_ASSERT(dst);
Expand All @@ -47,7 +52,61 @@ int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
FUZZ_ASSERT_MSG(!memcmp(data, partial, partialSize), "Corruption!");
free(partial);
}

/* Partial decompression using dict with no dict. */
{
char* const partial = (char*)malloc(partialCapacity);
FUZZ_ASSERT(partial);
int const partialSize = LZ4_decompress_safe_partial_usingDict(
dst, partial, dstSize, partialCapacity, partialCapacity, NULL, 0);
FUZZ_ASSERT(partialSize >= 0);
FUZZ_ASSERT_MSG(partialSize == partialCapacity, "Incorrect size");
FUZZ_ASSERT_MSG(!memcmp(data, partial, partialSize), "Corruption!");
free(partial);
}
/* Partial decompression using dict with small prefix as dict */
{
char* const partial = (char*)malloc(partialCapacity);
FUZZ_ASSERT(partial);
int const partialSize = LZ4_decompress_safe_partial_usingDict(
dst, partial, dstSize, partialCapacity, partialCapacity, dstPlusSmallPrefix, smallSize);
FUZZ_ASSERT(partialSize >= 0);
FUZZ_ASSERT_MSG(partialSize == partialCapacity, "Incorrect size");
FUZZ_ASSERT_MSG(!memcmp(data, partial, partialSize), "Corruption!");
free(partial);
}
/* Partial decompression using dict with large prefix as dict */
{
char* const partial = (char*)malloc(partialCapacity);
FUZZ_ASSERT(partial);
int const partialSize = LZ4_decompress_safe_partial_usingDict(
dst, partial, dstSize, partialCapacity, partialCapacity, dstPlusLargePrefix, largeSize);
FUZZ_ASSERT(partialSize >= 0);
FUZZ_ASSERT_MSG(partialSize == partialCapacity, "Incorrect size");
FUZZ_ASSERT_MSG(!memcmp(data, partial, partialSize), "Corruption!");
free(partial);
}
/* Partial decompression using dict with small external dict */
{
char* const partial = (char*)malloc(partialCapacity);
FUZZ_ASSERT(partial);
int const partialSize = LZ4_decompress_safe_partial_usingDict(
dst, partial, dstSize, partialCapacity, partialCapacity, smallDict, smallSize);
FUZZ_ASSERT(partialSize >= 0);
FUZZ_ASSERT_MSG(partialSize == partialCapacity, "Incorrect size");
FUZZ_ASSERT_MSG(!memcmp(data, partial, partialSize), "Corruption!");
free(partial);
}
/* Partial decompression using dict with large external dict */
{
char* const partial = (char*)malloc(partialCapacity);
FUZZ_ASSERT(partial);
int const partialSize = LZ4_decompress_safe_partial_usingDict(
dst, partial, dstSize, partialCapacity, partialCapacity, largeDict, largeSize);
FUZZ_ASSERT(partialSize >= 0);
FUZZ_ASSERT_MSG(partialSize == partialCapacity, "Incorrect size");
FUZZ_ASSERT_MSG(!memcmp(data, partial, partialSize), "Corruption!");
free(partial);
}

free(dst);
free(rt);
Expand Down

0 comments on commit dacd14c

Please sign in to comment.