Chromium Code Reviews| Index: test/fuzzer/fuzzer.cc |
| diff --git a/test/fuzzer/fuzzer.cc b/test/fuzzer/fuzzer.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..30d89c15f804d2142ed3bbcf1bffa805513db887 |
| --- /dev/null |
| +++ b/test/fuzzer/fuzzer.cc |
| @@ -0,0 +1,51 @@ |
| +// Copyright 2016 the V8 project authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include <stddef.h> |
| +#include <stdint.h> |
| +#include <stdio.h> |
| +#include <stdlib.h> |
| + |
| +extern "C" int LLVMFuzzerInitialize(int* argc, char*** argv); |
| +extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size); |
| + |
| + |
| +int main(int argc, char* argv[]) { |
| + if (LLVMFuzzerInitialize(&argc, &argv)) { |
| + fprintf(stderr, "Failed to initialize fuzzer target\n"); |
| + return 1; |
| + } |
| + |
| + if (argc != 2) { |
| + fprintf(stderr, "USAGE: %s <input>\n", argv[0]); |
| + return 1; |
| + } |
| + |
| + FILE* input = fopen(argv[1], "rb"); |
| + |
| + if (!input) { |
| + fprintf(stderr, "Failed to open '%s'\n", argv[1]); |
| + return 1; |
| + } |
| + |
| + fseek(input, 0, SEEK_END); |
| + long size = ftell(input); |
| + fseek(input, 0, SEEK_SET); |
| + |
| + uint8_t* data = reinterpret_cast<uint8_t*>(malloc(size)); |
| + if (!data) { |
| + fclose(input); |
| + fprintf(stderr, "Failed to allocate %ld bytes\n", size); |
| + return 1; |
| + } |
| + |
| + fread(data, 1, size, input); |
|
Jarin
2016/01/22 13:50:18
As gcc suggests, check that the return value is th
|
| + fclose(input); |
| + |
| + int result = LLVMFuzzerTestOneInput(data, size); |
| + |
| + free(data); |
| + |
| + return result; |
| +} |