[PATCH] D54180: [fuzzer] Read files as binary
Jonathan Metzman via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Nov 6 15:28:00 PST 2018
This revision was automatically updated to reflect the committed changes.
Closed by commit rCRT346279: [fuzzer] Read files as binary (authored by metzman, committed by ).
Herald added subscribers: Sanitizers, llvm-commits.
Changed prior to commit:
https://reviews.llvm.org/D54180?vs=172868&id=172869#toc
Repository:
rCRT Compiler Runtime
https://reviews.llvm.org/D54180
Files:
lib/fuzzer/FuzzerIO.cpp
lib/fuzzer/afl/afl_driver.cpp
test/fuzzer/ReadBinaryTest.cpp
test/fuzzer/read-binary.test
Index: test/fuzzer/ReadBinaryTest.cpp
===================================================================
--- test/fuzzer/ReadBinaryTest.cpp
+++ test/fuzzer/ReadBinaryTest.cpp
@@ -0,0 +1,18 @@
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+
+// Simple test for a fuzzer. Tests that fuzzer can read a file containing
+// carriage returns.
+#include <cstddef>
+#include <cstdint>
+#include <iostream>
+#include <string>
+
+extern "C" int LLVMFuzzerTestOneInput(const uint8_t* Data, size_t Size) {
+ std::string InputStr(reinterpret_cast<const char*>(Data), Size);
+ std::string MagicStr("Hello\r\nWorld\r\n");
+ if (InputStr == MagicStr) {
+ std::cout << "BINGO!";
+ }
+ return 0;
+}
Index: test/fuzzer/read-binary.test
===================================================================
--- test/fuzzer/read-binary.test
+++ test/fuzzer/read-binary.test
@@ -0,0 +1,7 @@
+# Test that libFuzzer reads files properly.
+
+# Account for the fact that echo will add a trailing newline.
+RUN: echo -e "Hello\r\nWorld\r" > %t-testcase
+RUN: %cpp_compiler %S/ReadBinaryTest.cpp -o %t-fuzzer
+RUN: %run %t-fuzzer %t-testcase | FileCheck %s
+CHECK: BINGO!
Index: lib/fuzzer/afl/afl_driver.cpp
===================================================================
--- lib/fuzzer/afl/afl_driver.cpp
+++ lib/fuzzer/afl/afl_driver.cpp
@@ -289,7 +289,7 @@
// Execute any files provided as parameters.
int ExecuteFilesOnyByOne(int argc, char **argv) {
for (int i = 1; i < argc; i++) {
- std::ifstream in(argv[i]);
+ std::ifstream in(argv[i], std::ios::binary);
in.seekg(0, in.end);
size_t length = in.tellg();
in.seekg (0, in.beg);
Index: lib/fuzzer/FuzzerIO.cpp
===================================================================
--- lib/fuzzer/FuzzerIO.cpp
+++ lib/fuzzer/FuzzerIO.cpp
@@ -31,7 +31,7 @@
}
Unit FileToVector(const std::string &Path, size_t MaxSize, bool ExitOnError) {
- std::ifstream T(Path);
+ std::ifstream T(Path, std::ios::binary);
if (ExitOnError && !T) {
Printf("No such directory: %s; exiting\n", Path.c_str());
exit(1);
@@ -51,7 +51,7 @@
}
std::string FileToString(const std::string &Path) {
- std::ifstream T(Path);
+ std::ifstream T(Path, std::ios::binary);
return std::string((std::istreambuf_iterator<char>(T)),
std::istreambuf_iterator<char>());
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D54180.172869.patch
Type: text/x-patch
Size: 2413 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20181106/e9044a02/attachment.bin>
More information about the llvm-commits
mailing list