nodejs/deps/v8/test/fuzzer/wasm/interpreter/interpreter-fuzzer-common.h
Michaël Zasso 918fe04351
deps: update V8 to 13.6.233.8
PR-URL: https://github.com/nodejs/node/pull/58070
Reviewed-By: Antoine du Hamel <duhamelantoine1995@gmail.com>
Reviewed-By: Darshan Sen <raisinten@gmail.com>
Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com>
Reviewed-By: Rafael Gonzaga <rafael.nunu@hotmail.com>
2025-05-02 15:06:53 +02:00

39 lines
1.2 KiB
C++

// Copyright 2024 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.
#ifndef WASM_FAST_INTERPRETER_FUZZER_COMMON_H_
#define WASM_FAST_INTERPRETER_FUZZER_COMMON_H_
#include <stddef.h>
#include <stdint.h>
#include <memory>
#include <random>
#include "src/wasm/module-decoder.h"
#include "src/wasm/wasm-module-builder.h"
namespace v8::internal::wasm::fuzzing {
std::mt19937_64 MersenneTwister(const char* data, size_t size);
// Instantiates and interprets exported functions within module_object if
// possible
int FastInterpretAndExecuteModule(Isolate* isolate,
DirectHandle<WasmModuleObject> module_object,
std::mt19937_64 g);
void InitializeDrumbrakeForFuzzing();
typedef std::function<bool(Isolate*, Zone*, v8::base::Vector<const uint8_t>,
ZoneBuffer*)>
GenerateModuleFunc;
int LLVMFuzzerTestOneInputCommon(const uint8_t* data, size_t size,
GenerateModuleFunc generate_module);
} // namespace v8::internal::wasm::fuzzing
#endif // WASM_FAST_INTERPRETER_FUZZER_COMMON_H_