| OLD | NEW |
| 1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "test/fuzzer/fuzzer-support.h" | 5 #include "test/fuzzer/fuzzer-support.h" |
| 6 | 6 |
| 7 #include <stdio.h> | 7 #include <stdio.h> |
| 8 #include <stdlib.h> | 8 #include <stdlib.h> |
| 9 #include <string.h> | 9 #include <string.h> |
| 10 | 10 |
| 11 #include "include/libplatform/libplatform.h" | 11 #include "include/libplatform/libplatform.h" |
| 12 | 12 |
| 13 #include "src/flags.h" | 13 #include "src/flags.h" |
| 14 | 14 |
| 15 namespace v8_fuzzer { | 15 namespace v8_fuzzer { |
| 16 | 16 |
| 17 namespace { | 17 namespace { |
| 18 | 18 |
| 19 FuzzerSupport* g_fuzzer_support = nullptr; | 19 FuzzerSupport* g_fuzzer_support = nullptr; |
| 20 | 20 |
| 21 void DeleteFuzzerSupport() { | 21 void DeleteFuzzerSupport() { |
| 22 if (g_fuzzer_support) { | 22 if (g_fuzzer_support) { |
| 23 delete g_fuzzer_support; | 23 delete g_fuzzer_support; |
| 24 g_fuzzer_support = nullptr; | 24 g_fuzzer_support = nullptr; |
| 25 } | 25 } |
| 26 } | 26 } |
| 27 | 27 |
| 28 } // namespace | 28 } // namespace |
| 29 | 29 |
| 30 class FuzzerSupport::ArrayBufferAllocator : public v8::ArrayBuffer::Allocator { | |
| 31 public: | |
| 32 virtual void* Allocate(size_t length) { | |
| 33 void* data = AllocateUninitialized(length); | |
| 34 return data == NULL ? data : memset(data, 0, length); | |
| 35 } | |
| 36 virtual void* AllocateUninitialized(size_t length) { return malloc(length); } | |
| 37 virtual void Free(void* data, size_t) { free(data); } | |
| 38 }; | |
| 39 | |
| 40 FuzzerSupport::FuzzerSupport(int* argc, char*** argv) { | 30 FuzzerSupport::FuzzerSupport(int* argc, char*** argv) { |
| 41 v8::internal::FLAG_expose_gc = true; | 31 v8::internal::FLAG_expose_gc = true; |
| 42 v8::V8::SetFlagsFromCommandLine(argc, *argv, true); | 32 v8::V8::SetFlagsFromCommandLine(argc, *argv, true); |
| 43 v8::V8::InitializeICUDefaultLocation((*argv)[0]); | 33 v8::V8::InitializeICUDefaultLocation((*argv)[0]); |
| 44 v8::V8::InitializeExternalStartupData((*argv)[0]); | 34 v8::V8::InitializeExternalStartupData((*argv)[0]); |
| 45 platform_ = v8::platform::CreateDefaultPlatform(); | 35 platform_ = v8::platform::CreateDefaultPlatform(); |
| 46 v8::V8::InitializePlatform(platform_); | 36 v8::V8::InitializePlatform(platform_); |
| 47 v8::V8::Initialize(); | 37 v8::V8::Initialize(); |
| 48 | 38 |
| 49 allocator_ = new ArrayBufferAllocator; | 39 allocator_ = v8::ArrayBuffer::Allocator::NewDefaultAllocator(); |
| 50 v8::Isolate::CreateParams create_params; | 40 v8::Isolate::CreateParams create_params; |
| 51 create_params.array_buffer_allocator = allocator_; | 41 create_params.array_buffer_allocator = allocator_; |
| 52 isolate_ = v8::Isolate::New(create_params); | 42 isolate_ = v8::Isolate::New(create_params); |
| 53 | 43 |
| 54 { | 44 { |
| 55 v8::Isolate::Scope isolate_scope(isolate_); | 45 v8::Isolate::Scope isolate_scope(isolate_); |
| 56 v8::HandleScope handle_scope(isolate_); | 46 v8::HandleScope handle_scope(isolate_); |
| 57 context_.Reset(isolate_, v8::Context::New(isolate_)); | 47 context_.Reset(isolate_, v8::Context::New(isolate_)); |
| 58 } | 48 } |
| 59 } | 49 } |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 95 return handle_scope.Escape(context); | 85 return handle_scope.Escape(context); |
| 96 } | 86 } |
| 97 | 87 |
| 98 } // namespace v8_fuzzer | 88 } // namespace v8_fuzzer |
| 99 | 89 |
| 100 extern "C" int LLVMFuzzerInitialize(int* argc, char*** argv) { | 90 extern "C" int LLVMFuzzerInitialize(int* argc, char*** argv) { |
| 101 v8_fuzzer::g_fuzzer_support = new v8_fuzzer::FuzzerSupport(argc, argv); | 91 v8_fuzzer::g_fuzzer_support = new v8_fuzzer::FuzzerSupport(argc, argv); |
| 102 atexit(&v8_fuzzer::DeleteFuzzerSupport); | 92 atexit(&v8_fuzzer::DeleteFuzzerSupport); |
| 103 return 0; | 93 return 0; |
| 104 } | 94 } |
| OLD | NEW |