Loading...
Searching...
No Matches
v8-callbacks.h
Go to the documentation of this file.
1// Copyright 2021 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 INCLUDE_V8_ISOLATE_CALLBACKS_H_
6#define INCLUDE_V8_ISOLATE_CALLBACKS_H_
7
8#include <stddef.h>
9
10#include <functional>
11#include <string>
12
13#include "cppgc/common.h"
14#include "v8-data.h" // NOLINT(build/include_directory)
15#include "v8-local-handle.h" // NOLINT(build/include_directory)
16#include "v8-promise.h" // NOLINT(build/include_directory)
17#include "v8config.h" // NOLINT(build/include_directory)
18
19#if defined(V8_OS_WIN)
20struct _EXCEPTION_POINTERS;
21#endif
22
23namespace v8 {
24
25template <typename T>
26class FunctionCallbackInfo;
27class Isolate;
28class Message;
29class Module;
30class Object;
31class Promise;
32class ScriptOrModule;
33class String;
34class UnboundScript;
35class Value;
36
43 enum EventType {
50 };
51 // Definition of the code position type. The "POSITION" type means the place
52 // in the source code which are of interest when making stack traces to
53 // pin-point the source location of a stack frame as close as possible.
54 // The "STATEMENT_POSITION" means the place at the beginning of each
55 // statement, and is used to indicate possible break locations.
57
58 // There are three different kinds of CodeType, one for JIT code generated
59 // by the optimizing compiler, one for byte code generated for the
60 // interpreter, and one for code generated from Wasm. For JIT_CODE and
61 // WASM_CODE, |code_start| points to the beginning of jitted assembly code,
62 // while for BYTE_CODE events, |code_start| points to the first bytecode of
63 // the interpreted function.
65
66 // Type of event.
69 // Start of the instructions.
71 // Size of the instructions.
72 size_t code_len;
73 // Script info for CODE_ADDED event.
75 // User-defined data for *_LINE_INFO_* event. It's used to hold the source
76 // code line information which is returned from the
77 // CODE_START_LINE_INFO_RECORDING event. And it's passed to subsequent
78 // CODE_ADD_LINE_POS_INFO and CODE_END_LINE_INFO_RECORDING events.
79 void* user_data;
80
81 struct name_t {
82 // Name of the object associated with the code, note that the string is not
83 // zero-terminated.
84 const char* str;
85 // Number of chars in str.
86 size_t len;
87 };
88
89 struct line_info_t {
90 // PC offset
91 size_t offset;
92 // Code position
93 size_t pos;
94 // The position type.
96 };
97
99 // Source file name.
100 const char* filename;
101 // Length of filename.
103 // Line number table, which maps offsets of JITted code to line numbers of
104 // source file.
106 // Number of entries in the line number table.
108 };
109
111
112 union {
113 // Only valid for CODE_ADDED.
114 struct name_t name;
115
116 // Only valid for CODE_ADD_LINE_POS_INFO
118
119 // New location of instructions. Only valid for CODE_MOVED.
121 };
122
124};
125
131 // Generate callbacks for already existent code.
133
136
142using JitCodeEventHandler = void (*)(const JitCodeEvent* event);
143
144// --- Garbage Collection Callbacks ---
145
154enum GCType {
164
187};
188
189using GCCallback = void (*)(GCType type, GCCallbackFlags flags);
190
191using InterruptCallback = void (*)(Isolate* isolate, void* data);
192
194 bool (*)(Isolate* isolate, Local<String> script_name);
195
203using NearHeapLimitCallback = size_t (*)(void* data, size_t current_heap_limit,
204 size_t initial_heap_limit);
205
209#if defined(V8_OS_WIN)
210using UnhandledExceptionCallback =
211 int (*)(_EXCEPTION_POINTERS* exception_pointers);
212#endif
213
214// --- Counters Callbacks ---
215
216using CounterLookupCallback = int* (*)(const char* name);
217
218using CreateHistogramCallback = void* (*)(const char* name, int min, int max,
219 size_t buckets);
220
221using AddHistogramSampleCallback = void (*)(void* histogram, int sample);
222
223// --- Exceptions ---
224
225using FatalErrorCallback = void (*)(const char* location, const char* message);
226
228 bool is_heap_oom = false;
229 const char* detail = nullptr;
230};
231
232using OOMErrorCallback = void (*)(const char* location,
233 const OOMDetails& details);
234
235using MessageCallback = void (*)(Local<Message> message, Local<Value> data);
236
237// --- Tracing ---
238
239enum LogEventStatus : int { kStart = 0, kEnd = 1, kLog = 2 };
240using LogEventCallback = void (*)(const char* name,
241 int /* LogEventStatus */ status);
242
243// --- Crashkeys Callback ---
244enum class CrashKeyId {
247 kMapSpaceFirstPageAddress V8_ENUM_DEPRECATE_SOON("Map space got removed"),
251 kDumpType,
254};
255
256using AddCrashKeyCallback = void (*)(CrashKeyId id, const std::string& value);
257
258// --- Enter/Leave Script Callback ---
261
262// --- Modify Code Generation From Strings Callback ---
264 // If true, proceed with the codegen algorithm. Otherwise, block it.
265 bool codegen_allowed = false;
266 // Overwrite the original source with this string, if present.
267 // Use the original source if empty.
268 // This field is considered only if codegen_allowed is true.
270};
271
278 Local<Value> source);
281 Local<Value> source,
282 bool is_code_like);
283
284// --- Failed Access Check Callback ---
285
296
298 AccessType type, Local<Value> data);
299
300// --- WebAssembly compilation callbacks ---
302
304 Local<String> source);
305
306// --- Callback for APIs defined on v8-supported objects, but implemented
307// by the embedder. Example: WebAssembly.{compile|instantiate}Streaming ---
309
310// --- Callback for WebAssembly.compileStreaming ---
312
314
315// --- Callback called when async WebAssembly operations finish ---
317 Isolate* isolate, Local<Context> context, Local<Promise::Resolver> resolver,
318 Local<Value> result, WasmAsyncSuccess success);
319
320// --- Callback for loading source map file for Wasm profiling support
322 const char* name);
323
324// --- Callback for checking if WebAssembly imported strings are enabled ---
326
327// --- Callback for checking if the SharedArrayBuffer constructor is enabled ---
329 bool (*)(Local<Context> context);
330
331// --- Callback for checking if the compile hints magic comments are enabled ---
333 bool (*)(Local<Context> context);
334
335// --- Callback for checking if WebAssembly JSPI is enabled ---
336using WasmJSPIEnabledCallback = bool (*)(Local<Context> context);
337
342 kSource,
344};
345
373 Local<Context> context, Local<Data> host_defined_options,
374 Local<Value> resource_name, Local<String> specifier,
375 Local<FixedArray> import_attributes);
376
414 Local<Context> context, Local<Data> host_defined_options,
415 Local<Value> resource_name, Local<String> specifier,
416 ModuleImportPhase phase, Local<FixedArray> import_attributes);
417
423using CompileHintCallback = bool (*)(int, void*);
424
436 Local<Module> module,
437 Local<Object> meta);
438
451 MaybeLocal<Context> (*)(Local<Context> initiator_context);
452
459 Local<Object> obj);
460
469 Local<Value> error,
470 Local<Array> sites);
471
472#if defined(V8_OS_WIN)
509using FilterETWSessionByURLCallback =
510 bool (*)(Local<Context> context, const std::string& etw_filter_payload);
511
512struct FilterETWSessionByURLResult {
513 // If true, enable ETW tracing for the current isolate.
514 bool enable_etw_tracing;
515
516 // If true, also enables ETW tracing for interpreter stack frames.
517 bool trace_interpreter_frames;
518};
519using FilterETWSessionByURL2Callback = FilterETWSessionByURLResult (*)(
520 Local<Context> context, const std::string& etw_filter_payload);
521#endif // V8_OS_WIN
522
523} // namespace v8
524
525#endif // INCLUDE_V8_ISOLATE_CALLBACKS_H_
Definition: v8-function-callback.h:118
Definition: v8-isolate.h:274
Definition: v8-local-handle.h:267
Definition: v8-local-handle.h:635
Definition: libplatform.h:15
void(*)(const JitCodeEvent *event) JitCodeEventHandler
Definition: v8-callbacks.h:142
JitCodeEventOptions
Definition: v8-callbacks.h:129
@ kJitCodeEventEnumExisting
Definition: v8-callbacks.h:132
@ kLastJitCodeEventOption
Definition: v8-callbacks.h:134
@ kJitCodeEventDefault
Definition: v8-callbacks.h:130
void(*)(const char *location, const OOMDetails &details) OOMErrorCallback
Definition: v8-callbacks.h:233
ModifyCodeGenerationFromStringsResult(*)(Local< Context > context, Local< Value > source) ModifyCodeGenerationFromStringsCallback
Definition: v8-callbacks.h:278
bool(*)(Local< Context > context) SharedArrayBufferConstructorEnabledCallback
Definition: v8-callbacks.h:329
GCCallbackFlags
Definition: v8-callbacks.h:179
@ kGCCallbackScheduleIdleGarbageCollection
Definition: v8-callbacks.h:186
@ kGCCallbackFlagConstructRetainedObjectInfos
Definition: v8-callbacks.h:181
@ kGCCallbackFlagForced
Definition: v8-callbacks.h:182
@ kNoGCCallbackFlags
Definition: v8-callbacks.h:180
@ kGCCallbackFlagCollectAllExternalMemory
Definition: v8-callbacks.h:185
@ kGCCallbackFlagSynchronousPhantomCallbackProcessing
Definition: v8-callbacks.h:183
@ kGCCallbackFlagCollectAllAvailableGarbage
Definition: v8-callbacks.h:184
CrashKeyId
Definition: v8-callbacks.h:244
@ kSnapshotChecksumCalculated
@ kCodeSpaceFirstPageAddress
@ kReadonlySpaceFirstPageAddress
LogEventStatus
Definition: v8-callbacks.h:239
@ kEnd
Definition: v8-callbacks.h:239
@ kStart
Definition: v8-callbacks.h:239
@ kLog
Definition: v8-callbacks.h:239
bool(*)(Local< Context > context) WasmJSPIEnabledCallback
Definition: v8-callbacks.h:336
void(*)(Isolate *isolate, Local< Context > context, Local< Promise::Resolver > resolver, Local< Value > result, WasmAsyncSuccess success) WasmAsyncResolvePromiseCallback
Definition: v8-callbacks.h:318
bool(*)(const FunctionCallbackInfo< Value > &) ExtensionCallback
Definition: v8-callbacks.h:301
bool(*)(Local< Context > context) JavaScriptCompileHintsMagicEnabledCallback
Definition: v8-callbacks.h:333
void(*)(const FunctionCallbackInfo< Value > &) WasmStreamingCallback
Definition: v8-callbacks.h:311
void *(*)(const char *name, int min, int max, size_t buckets) CreateHistogramCallback
Definition: v8-callbacks.h:219
void(*)(Local< Context > context, Local< Module > module, Local< Object > meta) HostInitializeImportMetaObjectCallback
Definition: v8-callbacks.h:437
void(*)(Local< Message > message, Local< Value > data) MessageCallback
Definition: v8-callbacks.h:235
void(*)(GCType type, GCCallbackFlags flags) GCCallback
Definition: v8-callbacks.h:189
void(*)(CrashKeyId id, const std::string &value) AddCrashKeyCallback
Definition: v8-callbacks.h:256
void(*)(Isolate *isolate, void *data) InterruptCallback
Definition: v8-callbacks.h:191
void(*)(Isolate *) CallCompletedCallback
Definition: v8-callbacks.h:260
void(*)(void *histogram, int sample) AddHistogramSampleCallback
Definition: v8-callbacks.h:221
bool(*)(Isolate *isolate, Local< String > script_name) PrintCurrentStackTraceFilterCallback
Definition: v8-callbacks.h:194
size_t(*)(void *data, size_t current_heap_limit, size_t initial_heap_limit) NearHeapLimitCallback
Definition: v8-callbacks.h:204
void(*)(Isolate *) BeforeCallEnteredCallback
Definition: v8-callbacks.h:259
bool(*)(Local< Context > context, Local< String > source) AllowWasmCodeGenerationCallback
Definition: v8-callbacks.h:304
void(*)(const char *location, const char *message) FatalErrorCallback
Definition: v8-callbacks.h:225
WasmAsyncSuccess
Definition: v8-callbacks.h:313
GCType
Definition: v8-callbacks.h:154
@ kGCTypeMinorMarkSweep
Definition: v8-callbacks.h:156
@ kGCTypeScavenge
Definition: v8-callbacks.h:155
@ kGCTypeProcessWeakCallbacks
Definition: v8-callbacks.h:159
@ kGCTypeMarkSweepCompact
Definition: v8-callbacks.h:157
@ kGCTypeAll
Definition: v8-callbacks.h:160
@ kGCTypeIncrementalMarking
Definition: v8-callbacks.h:158
bool(*)(int, void *) CompileHintCallback
Definition: v8-callbacks.h:423
void(*)(const FunctionCallbackInfo< Value > &) ApiImplementationCallback
Definition: v8-callbacks.h:308
ModifyCodeGenerationFromStringsResult(*)(Local< Context > context, Local< Value > source, bool is_code_like) ModifyCodeGenerationFromStringsCallback2
Definition: v8-callbacks.h:282
void(*)(Local< Object > target, AccessType type, Local< Value > data) FailedAccessCheckCallback
Definition: v8-callbacks.h:298
bool(*)(Local< Context > context) WasmImportedStringsEnabledCallback
Definition: v8-callbacks.h:325
AccessType
Definition: v8-callbacks.h:289
@ ACCESS_SET
Definition: v8-callbacks.h:291
@ ACCESS_HAS
Definition: v8-callbacks.h:292
@ ACCESS_KEYS
Definition: v8-callbacks.h:294
@ ACCESS_GET
Definition: v8-callbacks.h:290
@ ACCESS_DELETE
Definition: v8-callbacks.h:293
void(*)(const char *name, int status) LogEventCallback
Definition: v8-callbacks.h:241
int *(*)(const char *name) CounterLookupCallback
Definition: v8-callbacks.h:216
bool(*)(Isolate *isolate, Local< Object > obj) IsJSApiWrapperNativeErrorCallback
Definition: v8-callbacks.h:459
ModuleImportPhase
Definition: v8-callbacks.h:341
Definition: v8-callbacks.h:89
size_t offset
Definition: v8-callbacks.h:91
size_t pos
Definition: v8-callbacks.h:93
PositionType position_type
Definition: v8-callbacks.h:95
Definition: v8-callbacks.h:81
const char * str
Definition: v8-callbacks.h:84
size_t len
Definition: v8-callbacks.h:86
Definition: v8-callbacks.h:98
const char * filename
Definition: v8-callbacks.h:100
const line_info_t * line_number_table
Definition: v8-callbacks.h:105
size_t filename_size
Definition: v8-callbacks.h:102
size_t line_number_table_size
Definition: v8-callbacks.h:107
Definition: v8-callbacks.h:42
PositionType
Definition: v8-callbacks.h:56
@ POSITION
Definition: v8-callbacks.h:56
@ STATEMENT_POSITION
Definition: v8-callbacks.h:56
CodeType
Definition: v8-callbacks.h:64
@ JIT_CODE
Definition: v8-callbacks.h:64
@ BYTE_CODE
Definition: v8-callbacks.h:64
@ WASM_CODE
Definition: v8-callbacks.h:64
struct name_t name
Definition: v8-callbacks.h:114
Local< UnboundScript > script
Definition: v8-callbacks.h:74
struct line_info_t line_info
Definition: v8-callbacks.h:117
Isolate * isolate
Definition: v8-callbacks.h:123
void * user_data
Definition: v8-callbacks.h:79
wasm_source_info_t * wasm_source_info
Definition: v8-callbacks.h:110
void * new_code_start
Definition: v8-callbacks.h:120
EventType
Definition: v8-callbacks.h:43
@ CODE_END_LINE_INFO_RECORDING
Definition: v8-callbacks.h:49
@ CODE_ADDED
Definition: v8-callbacks.h:44
@ CODE_MOVED
Definition: v8-callbacks.h:45
@ CODE_ADD_LINE_POS_INFO
Definition: v8-callbacks.h:47
@ CODE_REMOVED
Definition: v8-callbacks.h:46
@ CODE_START_LINE_INFO_RECORDING
Definition: v8-callbacks.h:48
EventType type
Definition: v8-callbacks.h:67
size_t code_len
Definition: v8-callbacks.h:72
void * code_start
Definition: v8-callbacks.h:70
CodeType code_type
Definition: v8-callbacks.h:68
Definition: v8-callbacks.h:263
bool codegen_allowed
Definition: v8-callbacks.h:265
MaybeLocal< String > modified_source
Definition: v8-callbacks.h:269
Definition: v8-callbacks.h:227
const char * detail
Definition: v8-callbacks.h:229
bool is_heap_oom
Definition: v8-callbacks.h:228
#define V8_ENUM_DEPRECATE_SOON(message)
Definition: v8config.h:651