Coverage Report

Created: 2025-10-12 06:49

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/ndpi/fuzz/fuzz_ds_ptree.cpp
Line
Count
Source
1
#include "ndpi_api.h"
2
#include "fuzz_common_code.h"
3
4
#include <stdint.h>
5
#include <stdio.h>
6
#include <assert.h>
7
#include "fuzzer/FuzzedDataProvider.h"
8
9
10
964
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
11
964
  FuzzedDataProvider fuzzed_data(data, size);
12
964
  u_int16_t i, num_iteration;
13
964
  ndpi_ptree_t *t;
14
964
  ndpi_ip_addr_t addr, addr2, addr_added;
15
964
  u_int8_t bits;
16
964
  int rc, is_added = 0;
17
964
  u_int64_t user_data;
18
964
  char buf_ip[256];
19
20
  /* To allow memory allocation failures */
21
964
  fuzz_set_alloc_callbacks_and_seed(size);
22
23
964
  t = ndpi_ptree_create();
24
25
  /* Random insert */
26
964
  num_iteration = fuzzed_data.ConsumeIntegral<u_int8_t>();
27
126k
  for (i = 0; i < num_iteration; i++) {
28
125k
    if (fuzzed_data.ConsumeBool()) {
29
13.5k
      if(fuzzed_data.remaining_bytes() > 16) {
30
13.0k
  memcpy(&addr.ipv6, fuzzed_data.ConsumeBytes<u_int8_t>(16).data(), 16);
31
13.0k
        bits = fuzzed_data.ConsumeIntegralInRange(0, 128);
32
13.0k
      } else {
33
443
        continue;
34
443
      }
35
112k
    } else {
36
112k
      memset(&addr, '\0', sizeof(addr));
37
112k
      addr.ipv4 = fuzzed_data.ConsumeIntegral<u_int32_t>();
38
112k
      bits = fuzzed_data.ConsumeIntegralInRange(0, 32);
39
125k
    };
40
41
    /* Not really ptree stuff, but this seem the right place to fuzz these `ndpi_ip_addr_t` functions */
42
125k
    ndpi_parse_ip_string(ndpi_get_ip_string(&addr, buf_ip, sizeof(buf_ip)), &addr2);
43
44
125k
    rc = ndpi_ptree_insert(t, &addr, bits, 0);
45
    /* Keep one random node really added */
46
125k
    if (rc == 0 && is_added == 0 && fuzzed_data.ConsumeBool()) {
47
559
      is_added = 1;
48
559
      addr_added = addr;
49
559
    }
50
125k
  }
51
52
  /* Some higher level functions */
53
964
  ndpi_load_ptree_file(t, "ipv4_addresses.txt", NDPI_PROTOCOL_TLS);
54
964
  ndpi_load_ptree_file(t, "invalid_filename", NDPI_PROTOCOL_TLS);
55
964
  ndpi_load_ptree_file(t, "ipv6_addresses.txt", NDPI_PROTOCOL_TLS);
56
57
  /* Random search */
58
964
  num_iteration = fuzzed_data.ConsumeIntegral<u_int8_t>();
59
29.2k
  for (i = 0; i < num_iteration; i++) {
60
28.2k
    if (fuzzed_data.ConsumeBool()) {
61
8.73k
      if(fuzzed_data.remaining_bytes() > 16) {
62
8.47k
  memcpy(&addr.ipv6, fuzzed_data.ConsumeBytes<u_int8_t>(16).data(), 16);
63
8.47k
      } else {
64
260
        continue;
65
260
      }
66
19.5k
    } else {
67
19.5k
      memset(&addr, '\0', sizeof(addr));
68
19.5k
      addr.ipv4 = fuzzed_data.ConsumeIntegral<u_int32_t>();
69
28.0k
    };
70
71
28.0k
    ndpi_ptree_match_addr(t, &addr, &user_data);
72
28.0k
  }
73
  /* Search of an added node */
74
964
  if (is_added)
75
559
    ndpi_ptree_match_addr(t, &addr_added, &user_data);
76
77
964
  ndpi_ptree_destroy(t);
78
79
964
  return 0;
80
964
}