From 1bde5c68a302c99c627f86d8c95226a8a7623ac3 Mon Sep 17 00:00:00 2001 From: Jay Berkenbilt Date: Sat, 22 Jun 2019 10:12:10 -0400 Subject: Add QUtil::read_file_into_memory This code was essentially duplicated between test_driver and standalone_fuzz_target_runner. --- fuzz/standalone_fuzz_target_runner.cc | 36 ++++------------------------------- 1 file changed, 4 insertions(+), 32 deletions(-) (limited to 'fuzz/standalone_fuzz_target_runner.cc') diff --git a/fuzz/standalone_fuzz_target_runner.cc b/fuzz/standalone_fuzz_target_runner.cc index 59fb0438..4b42fc56 100644 --- a/fuzz/standalone_fuzz_target_runner.cc +++ b/fuzz/standalone_fuzz_target_runner.cc @@ -1,46 +1,18 @@ #include -#include -#include #include #include extern "C" int LLVMFuzzerTestOneInput(unsigned char const* data, size_t size); -static void read_file_into_memory( - char const* filename, - PointerHolder& file_buf, size_t& size) -{ - FILE* f = QUtil::safe_fopen(filename, "rb"); - fseek(f, 0, SEEK_END); - size = QIntC::to_size(QUtil::tell(f)); - fseek(f, 0, SEEK_SET); - file_buf = PointerHolder(true, new unsigned char[size]); - unsigned char* buf_p = file_buf.getPointer(); - size_t bytes_read = 0; - size_t len = 0; - while ((len = fread(buf_p + bytes_read, 1, size - bytes_read, f)) > 0) - { - bytes_read += len; - } - if (bytes_read != size) - { - throw std::runtime_error( - std::string("failure reading file ") + filename + - " into memory: read " + - QUtil::uint_to_string(bytes_read) + "; wanted " + - QUtil::uint_to_string(size)); - } - fclose(f); -} - int main(int argc, char **argv) { for (int i = 1; i < argc; i++) { - PointerHolder file_buf; + PointerHolder file_buf; size_t size = 0; - read_file_into_memory(argv[i], file_buf, size); - LLVMFuzzerTestOneInput(file_buf.getPointer(), size); + QUtil::read_file_into_memory(argv[i], file_buf, size); + LLVMFuzzerTestOneInput( + reinterpret_cast(file_buf.getPointer()), size); std::cout << argv[i] << " successful" << std::endl; } return 0; -- cgit v1.2.3-54-g00ecf