Coverage Report

Created: 2025-12-10 06:39

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
958
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
11
958
  FuzzedDataProvider fuzzed_data(data, size);
12
958
  u_int16_t i, num_iteration;
13
958
  ndpi_ptree_t *t;
14
958
  ndpi_ip_addr_t addr, addr2, addr_added;
15
958
  u_int8_t bits;
16
958
  int rc, is_added = 0;
17
958
  u_int64_t user_data;
18
958
  char buf_ip[256];
19
20
  /* To allow memory allocation failures */
21
958
  fuzz_set_alloc_callbacks_and_seed(size);
22
23
958
  t = ndpi_ptree_create();
24
25
  /* Random insert */
26
958
  num_iteration = fuzzed_data.ConsumeIntegral<u_int8_t>();
27
127k
  for (i = 0; i < num_iteration; i++) {
28
126k
    if (fuzzed_data.ConsumeBool()) {
29
12.9k
      if(fuzzed_data.remaining_bytes() > 16) {
30
12.4k
  memcpy(&addr.ipv6, fuzzed_data.ConsumeBytes<u_int8_t>(16).data(), 16);
31
12.4k
        bits = fuzzed_data.ConsumeIntegralInRange(0, 128);
32
12.4k
      } else {
33
506
        continue;
34
506
      }
35
113k
    } else {
36
113k
      memset(&addr, '\0', sizeof(addr));
37
113k
      addr.ipv4 = fuzzed_data.ConsumeIntegral<u_int32_t>();
38
113k
      bits = fuzzed_data.ConsumeIntegralInRange(0, 32);
39
126k
    };
40
41
    /* Not really ptree stuff, but this seem the right place to fuzz these `ndpi_ip_addr_t` functions */
42
126k
    ndpi_parse_ip_string(ndpi_get_ip_string(&addr, buf_ip, sizeof(buf_ip)), &addr2);
43
44
126k
    rc = ndpi_ptree_insert(t, &addr, bits, 0);
45
    /* Keep one random node really added */
46
126k
    if (rc == 0 && is_added == 0 && fuzzed_data.ConsumeBool()) {
47
549
      is_added = 1;
48
549
      addr_added = addr;
49
549
    }
50
126k
  }
51
52
  /* Some higher level functions */
53
958
  ndpi_load_ptree_file(t, "ipv4_addresses.txt", NDPI_PROTOCOL_TLS);
54
958
  ndpi_load_ptree_file(t, "invalid_filename", NDPI_PROTOCOL_TLS);
55
958
  ndpi_load_ptree_file(t, "ipv6_addresses.txt", NDPI_PROTOCOL_TLS);
56
57
  /* Random search */
58
958
  num_iteration = fuzzed_data.ConsumeIntegral<u_int8_t>();
59
32.2k
  for (i = 0; i < num_iteration; i++) {
60
31.3k
    if (fuzzed_data.ConsumeBool()) {
61
8.93k
      if(fuzzed_data.remaining_bytes() > 16) {
62
8.70k
  memcpy(&addr.ipv6, fuzzed_data.ConsumeBytes<u_int8_t>(16).data(), 16);
63
8.70k
      } else {
64
228
        continue;
65
228
      }
66
22.4k
    } else {
67
22.4k
      memset(&addr, '\0', sizeof(addr));
68
22.4k
      addr.ipv4 = fuzzed_data.ConsumeIntegral<u_int32_t>();
69
31.1k
    };
70
71
31.1k
    ndpi_ptree_match_addr(t, &addr, &user_data);
72
31.1k
  }
73
  /* Search of an added node */
74
958
  if (is_added)
75
549
    ndpi_ptree_match_addr(t, &addr_added, &user_data);
76
77
958
  ndpi_ptree_destroy(t);
78
79
958
  return 0;
80
958
}