Coverage Report

Created: 2025-12-31 06:13

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
3.35k
extern "C" void fuzz_random_init(const uint8_t *data, size_t size) {
19
3.35k
   assert(prov == NULL);
20
3.35k
   prov = new FuzzedDataProvider(data, size);
21
3.35k
}
22
23
3.35k
extern "C" void fuzz_random_destroy() {
24
3.35k
   assert(prov != NULL);
25
3.35k
  delete prov;
26
3.35k
  prov = NULL;
27
3.35k
}
28
29
16.6k
extern "C" char *get_random_string() {
30
16.6k
   assert(prov != NULL);
31
32
16.6k
   std::string s1 = prov->ConsumeRandomLengthString();
33
16.6k
   char *tmp = (char *)malloc(s1.size() + 1);
34
16.6k
   memcpy(tmp, s1.c_str(), s1.size());
35
16.6k
   tmp[s1.size()] = '\0';
36
16.6k
   return tmp;
37
16.6k
}
38
39
33.0k
extern "C" int fuzz_randomizer_get_int(int min, int max) {
40
33.0k
   assert(prov != NULL);
41
33.0k
   return prov->ConsumeIntegralInRange<int>(min, max);
42
33.0k
} 
43
44
832
extern "C" char *fuzz_random_get_string_max_length(int max_len) {
45
832
  assert(prov != NULL);
46
47
832
  std::string s1 = prov->ConsumeBytesAsString(
48
832
                           prov->ConsumeIntegralInRange<uint32_t>(1, max_len));
49
832
  char *tmp123 = (char*)malloc(s1.size()+1);
50
832
  memcpy(tmp123, s1.c_str(), s1.size());
51
832
  tmp123[s1.size()] = '\0';
52
53
832
  return tmp123;
54
832
}
55
56
2.70k
extern "C" size_t fuzz_get_random_data(void *buf, size_t len) {
57
2.70k
  assert(prov != NULL);
58
2.70k
  size_t ret_val;
59
2.70k
  char *cbuf = (char*)buf;
60
61
2.70k
  if (prov->remaining_bytes() == 0) {
62
317
    return -1;
63
317
  }
64
65
2.38k
  double prob = prov->ConsumeProbability<double>();
66
2.38k
  if (prob < 0.05) {
67
1.12k
    return 0;
68
1.12k
  }
69
70
  //if (len == 1) {
71
  //  ret_val = prov->ConsumeData(buf, 1);
72
  //  return ret_val;
73
  //}
74
1.26k
  ret_val = prov->ConsumeData(buf, len);
75
1.26k
  return ret_val;
76
2.38k
}
77
 
78
79
// Simple garbage collector
80
68.0k
#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
337
extern "C" void gb_init() {
87
337
  pointer_idx = 0;
88
89
34.0k
   for (int i = 0; i < GB_SIZE; i++) {
90
33.7k
     pointer_arr[i] = NULL;
91
33.7k
   }
92
337
}
93
94
337
extern "C" void gb_cleanup() {
95
34.0k
  for(int i = 0; i < GB_SIZE; i++) {
96
33.7k
    if (pointer_arr[i] != NULL) {
97
6.65k
      free(pointer_arr[i]);
98
6.65k
    }
99
33.7k
  }
100
337
}
101
102
6.65k
extern "C" char *gb_get_random_string() {
103
6.65k
  char *tmp = get_random_string();
104
6.65k
  pointer_arr[pointer_idx++] = (void*)tmp;
105
6.65k
  return tmp;
106
6.65k
}
107