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_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
947
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
11
947
  FuzzedDataProvider fuzzed_data(data, size);
12
947
  u_int16_t i, num_iteration;
13
947
  ndpi_ptree_t *t;
14
947
  ndpi_ip_addr_t addr, addr2, addr_added;
15
947
  u_int8_t bits;
16
947
  int rc, is_added = 0;
17
947
  u_int64_t user_data;
18
947
  char buf_ip[256];
19
20
  /* To allow memory allocation failures */
21
947
  fuzz_set_alloc_callbacks_and_seed(size);
22
23
947
  t = ndpi_ptree_create();
24
25
  /* Random insert */
26
947
  num_iteration = fuzzed_data.ConsumeIntegral<u_int8_t>();
27
123k
  for (i = 0; i < num_iteration; i++) {
28
122k
    if (fuzzed_data.ConsumeBool()) {
29
12.1k
      if(fuzzed_data.remaining_bytes() > 16) {
30
11.6k
  memcpy(&addr.ipv6, fuzzed_data.ConsumeBytes<u_int8_t>(16).data(), 16);
31
11.6k
        bits = fuzzed_data.ConsumeIntegralInRange(0, 128);
32
11.6k
      } else {
33
510
        continue;
34
510
      }
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
548
      is_added = 1;
48
548
      addr_added = addr;
49
548
    }
50
121k
  }
51
52
  /* Some higher level functions */
53
947
  ndpi_load_ptree_file(t, "ipv4_addresses.txt", NDPI_PROTOCOL_TLS);
54
947
  ndpi_load_ptree_file(t, "invalid_filename", NDPI_PROTOCOL_TLS);
55
947
  ndpi_load_ptree_file(t, "ipv6_addresses.txt", NDPI_PROTOCOL_TLS);
56
57
  /* Random search */
58
947
  num_iteration = fuzzed_data.ConsumeIntegral<u_int8_t>();
59
29.0k
  for (i = 0; i < num_iteration; i++) {
60
28.1k
    if (fuzzed_data.ConsumeBool()) {
61
8.16k
      if(fuzzed_data.remaining_bytes() > 16) {
62
7.94k
  memcpy(&addr.ipv6, fuzzed_data.ConsumeBytes<u_int8_t>(16).data(), 16);
63
7.94k
      } else {
64
221
        continue;
65
221
      }
66
19.9k
    } else {
67
19.9k
      memset(&addr, '\0', sizeof(addr));
68
19.9k
      addr.ipv4 = fuzzed_data.ConsumeIntegral<u_int32_t>();
69
27.9k
    };
70
71
27.9k
    ndpi_ptree_match_addr(t, &addr, &user_data);
72
27.9k
  }
73
  /* Search of an added node */
74
947
  if (is_added)
75
548
    ndpi_ptree_match_addr(t, &addr_added, &user_data);
76
77
947
  ndpi_ptree_destroy(t);
78
79
947
  return 0;
80
947
}