Coverage Report

Created: 2025-11-02 06:47

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