11
#include "fuzz_helpers.h"
12
#include "fuzz_data_producer.h"
14
#define LZ4F_STATIC_LINKING_ONLY
16
#include "lz4_helpers.h"
18
static void decompress(LZ4F_dctx* dctx, void* dst, size_t dstCapacity,
19
const void* src, size_t srcSize,
20
const void* dict, size_t dictSize,
21
const LZ4F_decompressOptions_t* opts)
23
LZ4F_resetDecompressionContext(dctx);
25
LZ4F_decompress(dctx, dst, &dstCapacity, src, &srcSize, opts);
27
LZ4F_decompress_usingDict(dctx, dst, &dstCapacity, src, &srcSize,
28
dict, dictSize, opts);
31
int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
33
FUZZ_dataProducer_t *producer = FUZZ_dataProducer_create(data, size);
34
size_t const dstCapacitySeed = FUZZ_dataProducer_retrieve32(producer);
35
size_t const dictSizeSeed = FUZZ_dataProducer_retrieve32(producer);
36
size = FUZZ_dataProducer_remainingBytes(producer);
38
size_t const dstCapacity = FUZZ_getRange_from_uint32(
39
dstCapacitySeed, 0, 4 * size);
40
size_t const largeDictSize = 64 * 1024;
41
size_t const dictSize = FUZZ_getRange_from_uint32(
42
dictSizeSeed, 0, largeDictSize);
44
char* const dst = (char*)malloc(dstCapacity);
45
char* const dict = (char*)malloc(dictSize);
46
LZ4F_decompressOptions_t opts;
48
LZ4F_createDecompressionContext(&dctx, LZ4F_VERSION);
55
memset(dict, 0, dictSize);
59
memset(&opts, 0, sizeof(opts));
61
decompress(dctx, dst, dstCapacity, data, size, NULL, 0, &opts);
63
decompress(dctx, dst, dstCapacity, data, size, NULL, 0, &opts);
65
decompress(dctx, dst, dstCapacity, data, size, dict, dictSize, &opts);
67
decompress(dctx, dst, dstCapacity, data, size, dict, dictSize, &opts);
69
LZ4F_freeDecompressionContext(dctx);
72
FUZZ_dataProducer_free(producer);