Coverage Report

Created: 2026-06-07 06:23

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/fuzz_randomizer.cpp
Line
Count
Source
1
/* Copyright 2021 Google LLC
2
Licensed under the Apache License, Version 2.0 (the "License");
3
you may not use this file except in compliance with the License.
4
You may obtain a copy of the License at
5
      http://www.apache.org/licenses/LICENSE-2.0
6
Unless required by applicable law or agreed to in writing, software
7
distributed under the License is distributed on an "AS IS" BASIS,
8
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
9
See the License for the specific language governing permissions and
10
limitations under the License.
11
*/
12
13
#include <fuzzer/FuzzedDataProvider.h>
14
#include <assert.h>
15
16
FuzzedDataProvider *prov = NULL;
17
18
4.14k
extern "C" void fuzz_random_init(const uint8_t *data, size_t size) {
19
4.14k
   assert(prov == NULL);
20
4.14k
   prov = new FuzzedDataProvider(data, size);
21
4.14k
}
22
23
4.14k
extern "C" void fuzz_random_destroy() {
24
4.14k
   assert(prov != NULL);
25
4.14k
  delete prov;
26
4.14k
  prov = NULL;
27
4.14k
}
28
29
21.5k
extern "C" char *get_random_string() {
30
21.5k
   assert(prov != NULL);
31
32
21.5k
   std::string s1 = prov->ConsumeRandomLengthString();
33
21.5k
   char *tmp = (char *)malloc(s1.size() + 1);
34
21.5k
   memcpy(tmp, s1.c_str(), s1.size());
35
21.5k
   tmp[s1.size()] = '\0';
36
21.5k
   return tmp;
37
21.5k
}
38
39
40.9k
extern "C" int fuzz_randomizer_get_int(int min, int max) {
40
40.9k
   assert(prov != NULL);
41
40.9k
   return prov->ConsumeIntegralInRange<int>(min, max);
42
40.9k
} 
43
44
913
extern "C" char *fuzz_random_get_string_max_length(int max_len) {
45
913
  assert(prov != NULL);
46
47
913
  std::string s1 = prov->ConsumeBytesAsString(
48
913
                           prov->ConsumeIntegralInRange<uint32_t>(1, max_len));
49
913
  char *tmp123 = (char*)malloc(s1.size()+1);
50
913
  memcpy(tmp123, s1.c_str(), s1.size());
51
913
  tmp123[s1.size()] = '\0';
52
53
913
  return tmp123;
54
913
}
55
56
3.02k
extern "C" size_t fuzz_get_random_data(void *buf, size_t len) {
57
3.02k
  assert(prov != NULL);
58
3.02k
  size_t ret_val;
59
3.02k
  char *cbuf = (char*)buf;
60
61
3.02k
  if (prov->remaining_bytes() == 0) {
62
337
    return -1;
63
337
  }
64
65
2.68k
  double prob = prov->ConsumeProbability<double>();
66
2.68k
  if (prob < 0.05) {
67
1.33k
    return 0;
68
1.33k
  }
69
70
  //if (len == 1) {
71
  //  ret_val = prov->ConsumeData(buf, 1);
72
  //  return ret_val;
73
  //}
74
1.35k
  ret_val = prov->ConsumeData(buf, len);
75
1.35k
  return ret_val;
76
2.68k
}
77
 
78
79
// Simple garbage collector
80
97.7k
#define GB_SIZE 100
81
void *pointer_arr[GB_SIZE];
82
static int pointer_idx = 0;
83
84
// If the garbage collector is used then this must be called as first thing
85
// during a fuzz run.
86
484
extern "C" void gb_init() {
87
484
  pointer_idx = 0;
88
89
48.8k
   for (int i = 0; i < GB_SIZE; i++) {
90
48.4k
     pointer_arr[i] = NULL;
91
48.4k
   }
92
484
}
93
94
484
extern "C" void gb_cleanup() {
95
48.8k
  for(int i = 0; i < GB_SIZE; i++) {
96
48.4k
    if (pointer_arr[i] != NULL) {
97
9.64k
      free(pointer_arr[i]);
98
9.64k
    }
99
48.4k
  }
100
484
}
101
102
9.64k
extern "C" char *gb_get_random_string() {
103
9.64k
  char *tmp = get_random_string();
104
9.64k
  pointer_arr[pointer_idx++] = (void*)tmp;
105
9.64k
  return tmp;
106
9.64k
}
107