Coverage Report

Created: 2025-11-06 06:43

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/ndpi/fuzz/fuzz_ds_bitmap64_fuse.cpp
Line
Count
Source
1
#include "ndpi_api.h"
2
#include "fuzz_common_code.h"
3
4
#include <stdint.h>
5
#include "fuzzer/FuzzedDataProvider.h"
6
7
766
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
8
766
  FuzzedDataProvider fuzzed_data(data, size);
9
766
  u_int16_t i, num_iteration, is_added = 0;
10
766
  ndpi_bitmap64_fuse *b;
11
766
  bool rc;
12
766
  u_int64_t value, value_added;
13
14
  /* To allow memory allocation failures */
15
766
  fuzz_set_alloc_callbacks_and_seed(size);
16
17
766
  b = ndpi_bitmap64_fuse_alloc();
18
19
766
  if(fuzzed_data.ConsumeBool())
20
435
    ndpi_bitmap64_fuse_compress(b);
21
22
766
  num_iteration = fuzzed_data.ConsumeIntegral<u_int16_t>();
23
17.9M
  for (i = 0; i < num_iteration; i++) {
24
17.9M
    value = fuzzed_data.ConsumeIntegral<u_int64_t>();
25
26
17.9M
    rc = ndpi_bitmap64_fuse_set(b, value);
27
    /* Keep one random entry really added */
28
17.9M
    if (rc == true && is_added == 0 && fuzzed_data.ConsumeBool()) {
29
377
      value_added = value;
30
377
      is_added = 1;
31
377
    }
32
17.9M
  }
33
34
766
  if(fuzzed_data.ConsumeBool())
35
72
    ndpi_bitmap64_fuse_compress(b);
36
37
  /* "Random" search */
38
766
  num_iteration = fuzzed_data.ConsumeIntegral<u_int8_t>();
39
17.0k
  for (i = 0; i < num_iteration; i++) {
40
16.2k
    value = fuzzed_data.ConsumeIntegral<u_int64_t>();
41
42
16.2k
    ndpi_bitmap64_fuse_isset(b, value);
43
16.2k
  }
44
  /* Search of an added entry */
45
766
  if (is_added) {
46
377
    ndpi_bitmap64_fuse_isset(b, value_added);
47
377
  }
48
49
766
  ndpi_bitmap64_fuse_size(b);
50
51
766
  ndpi_bitmap64_fuse_free(b);
52
53
766
  return 0;
54
766
}