From 3edfad01a1bb22b33bd5bafa0ceeb13e27f03e67 Mon Sep 17 00:00:00 2001 From: Ivan Nardi <12729895+IvanNardi@users.noreply.github.com> Date: Tue, 18 Jul 2023 07:41:56 +0200 Subject: fuzz: extend fuzzing coverage (#2052) Added/merged some traces. Improved Socks identification --- fuzz/fuzz_ds_cmsketch.cpp | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 fuzz/fuzz_ds_cmsketch.cpp (limited to 'fuzz/fuzz_ds_cmsketch.cpp') diff --git a/fuzz/fuzz_ds_cmsketch.cpp b/fuzz/fuzz_ds_cmsketch.cpp new file mode 100644 index 000000000..1181b1593 --- /dev/null +++ b/fuzz/fuzz_ds_cmsketch.cpp @@ -0,0 +1,35 @@ +#include "ndpi_api.h" +#include "fuzz_common_code.h" + +#include +#include "fuzzer/FuzzedDataProvider.h" + +extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) { + FuzzedDataProvider fuzzed_data(data, size); + struct ndpi_cm_sketch *sketch; + u_int16_t i, num_hashes, num_iteration, num_lookup; + + /* Just to have some data */ + if (fuzzed_data.remaining_bytes() < 1024) + return -1; + + /* To allow memory allocation failures */ + fuzz_set_alloc_callbacks_and_seed(size); + + num_hashes = fuzzed_data.ConsumeIntegralInRange(0, 8192); + num_iteration = fuzzed_data.ConsumeIntegral(); + num_lookup = fuzzed_data.ConsumeIntegral(); + + sketch = ndpi_cm_sketch_init(num_hashes); + if (sketch) { + for (i = 0; i < num_iteration; i++) { + ndpi_cm_sketch_add(sketch, fuzzed_data.ConsumeIntegral()); + } + for (i = 0; i < num_lookup; i++) { + ndpi_cm_sketch_count(sketch, fuzzed_data.ConsumeIntegral()); + } + ndpi_cm_sketch_destroy(sketch); + } + + return 0; +} -- cgit v1.2.3