fuzz: extend fuzzing coverage (#2052)

Added/merged some traces.
Improved Socks identification
This commit is contained in:
Ivan Nardi 2023-07-18 07:41:56 +02:00 committed by GitHub
parent 09548bb7cf
commit 3edfad01a1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
17 changed files with 92 additions and 35 deletions

35
fuzz/fuzz_ds_cmsketch.cpp Normal file
View file

@ -0,0 +1,35 @@
#include "ndpi_api.h"
#include "fuzz_common_code.h"
#include <stdint.h>
#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<u_int8_t>();
num_lookup = fuzzed_data.ConsumeIntegral<u_int8_t>();
sketch = ndpi_cm_sketch_init(num_hashes);
if (sketch) {
for (i = 0; i < num_iteration; i++) {
ndpi_cm_sketch_add(sketch, fuzzed_data.ConsumeIntegral<u_int32_t>());
}
for (i = 0; i < num_lookup; i++) {
ndpi_cm_sketch_count(sketch, fuzzed_data.ConsumeIntegral<u_int32_t>());
}
ndpi_cm_sketch_destroy(sketch);
}
return 0;
}