Coverage Report

Created: 2026-06-25 07:00

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
857
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
8
857
  FuzzedDataProvider fuzzed_data(data, size);
9
857
  u_int16_t i, num_iteration, is_added = 0;
10
857
  ndpi_bitmap64_fuse *b;
11
857
  bool rc;
12
857
  u_int64_t value, value_added;
13
14
  /* To allow memory allocation failures */
15
857
  fuzz_set_alloc_callbacks_and_seed(size);
16
17
857
  b = ndpi_bitmap64_fuse_alloc();
18
19
857
  if(fuzzed_data.ConsumeBool())
20
487
    ndpi_bitmap64_fuse_compress(b);
21
22
857
  num_iteration = fuzzed_data.ConsumeIntegral<u_int16_t>();
23
21.2M
  for (i = 0; i < num_iteration; i++) {
24
21.2M
    value = fuzzed_data.ConsumeIntegral<u_int64_t>();
25
26
21.2M
    rc = ndpi_bitmap64_fuse_set(b, value);
27
    /* Keep one random entry really added */
28
21.2M
    if (rc == true && is_added == 0 && fuzzed_data.ConsumeBool()) {
29
459
      value_added = value;
30
459
      is_added = 1;
31
459
    }
32
21.2M
  }
33
34
857
  if(fuzzed_data.ConsumeBool())
35
76
    ndpi_bitmap64_fuse_compress(b);
36
37
  /* "Random" search */
38
857
  num_iteration = fuzzed_data.ConsumeIntegral<u_int8_t>();
39
22.0k
  for (i = 0; i < num_iteration; i++) {
40
21.2k
    value = fuzzed_data.ConsumeIntegral<u_int64_t>();
41
42
21.2k
    ndpi_bitmap64_fuse_isset(b, value);
43
21.2k
  }
44
  /* Search of an added entry */
45
857
  if (is_added) {
46
459
    ndpi_bitmap64_fuse_isset(b, value_added);
47
459
  }
48
49
857
  ndpi_bitmap64_fuse_size(b);
50
51
857
  ndpi_bitmap64_fuse_free(b);
52
53
857
  return 0;
54
857
}