v8
V8 is Google’s open source high-performance JavaScript and WebAssembly engine, written in C++.
Loading...
Searching...
No Matches
fuzzilli.h
Go to the documentation of this file.
1// Copyright 2023 the V8 project authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef V8_FUZZILLI_FUZZILLI_H_
6#define V8_FUZZILLI_FUZZILLI_H_
7
10#include "src/base/strings.h"
11
12// REPRL = read-eval-print-reset-loop
13// These file descriptors are being opened when Fuzzilli uses fork & execve to
14// run V8.
15#define REPRL_CRFD 100 // Control read file decriptor
16#define REPRL_CWFD 101 // Control write file decriptor
17#define REPRL_DRFD 102 // Data read file decriptor
18#define REPRL_DWFD 103 // Data write file decriptor
19
20namespace v8 {
21namespace internal {
22
24 public:
25 explicit FuzzilliExtension(const char* fun_name)
26 : v8::Extension("v8/fuzzilli",
27 BuildSource(buffer_, sizeof(buffer_), fun_name)) {}
29 v8::Isolate* isolate, v8::Local<v8::String> name) override;
30 static void Fuzzilli(const v8::FunctionCallbackInfo<v8::Value>& info);
31
32 private:
33 static const char* BuildSource(char* buf, size_t size, const char* fun_name) {
34 base::SNPrintF(base::VectorOf(buf, size), "native function %s();",
35 fun_name);
36 return buf;
37 }
38
39 char buffer_[50];
40};
41
42} // namespace internal
43} // namespace v8
44
45#endif // V8_FUZZILLI_FUZZILLI_H_
v8::Local< v8::FunctionTemplate > GetNativeFunctionTemplate(v8::Isolate *isolate, v8::Local< v8::String > name) override
Definition fuzzilli.cc:25
FuzzilliExtension(const char *fun_name)
Definition fuzzilli.h:25
static void Fuzzilli(const v8::FunctionCallbackInfo< v8::Value > &info)
Definition fuzzilli.cc:36
static const char * BuildSource(char *buf, size_t size, const char *fun_name)
Definition fuzzilli.h:33
int SNPrintF(Vector< char > str, const char *format,...)
Definition strings.cc:20
constexpr Vector< T > VectorOf(T *start, size_t size)
Definition vector.h:360