/* Copyright 2021 Google LLC Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ #include #include FuzzedDataProvider *prov = NULL; extern "C" void fuzz_random_init(const uint8_t *data, size_t size) { assert(prov == NULL); prov = new FuzzedDataProvider(data, size); } extern "C" void fuzz_random_destroy() { assert(prov != NULL); delete prov; prov = NULL; } extern "C" char *get_random_string() { assert(prov != NULL); std::string s1 = prov->ConsumeRandomLengthString(); char *tmp = (char *)malloc(s1.size() + 1); memcpy(tmp, s1.c_str(), s1.size()); tmp[s1.size()] = '\0'; return tmp; } extern "C" int fuzz_randomizer_get_int(int min, int max) { assert(prov != NULL); return prov->ConsumeIntegralInRange(min, max); } extern "C" char *fuzz_random_get_string_max_length(int max_len) { assert(prov != NULL); std::string s1 = prov->ConsumeBytesAsString( prov->ConsumeIntegralInRange(1, max_len)); char *tmp123 = (char*)malloc(s1.size()+1); memcpy(tmp123, s1.c_str(), s1.size()); tmp123[s1.size()] = '\0'; return tmp123; } extern "C" size_t fuzz_get_random_data(void *buf, size_t len) { assert(prov != NULL); size_t ret_val; char *cbuf = (char*)buf; if (prov->remaining_bytes() == 0) { return -1; } double prob = prov->ConsumeProbability(); if (prob < 0.05) { return 0; } //if (len == 1) { // ret_val = prov->ConsumeData(buf, 1); // return ret_val; //} ret_val = prov->ConsumeData(buf, len); return ret_val; } // Simple garbage collector #define GB_SIZE 100 void *pointer_arr[GB_SIZE]; static int pointer_idx = 0; // If the garbage collector is used then this must be called as first thing // during a fuzz run. extern "C" void gb_init() { pointer_idx = 0; for (int i = 0; i < GB_SIZE; i++) { pointer_arr[i] = NULL; } } extern "C" void gb_cleanup() { for(int i = 0; i < GB_SIZE; i++) { if (pointer_arr[i] != NULL) { free(pointer_arr[i]); } } } extern "C" char *gb_get_random_string() { char *tmp = get_random_string(); pointer_arr[pointer_idx++] = (void*)tmp; return tmp; }