Loading...
Searching...
No Matches
v8-metrics.h
Go to the documentation of this file.
1// Copyright 2020 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_METRICS_H_
6#define V8_METRICS_H_
7
8#include <stddef.h>
9#include <stdint.h>
10
11#include <optional>
12#include <vector>
13
14#include "v8-internal.h" // NOLINT(build/include_directory)
15#include "v8-isolate.h" // NOLINT(build/include_directory)
16#include "v8-local-handle.h" // NOLINT(build/include_directory)
17#include "v8config.h" // NOLINT(build/include_directory)
18
19namespace v8 {
20
21class Context;
22class Isolate;
23
24namespace metrics {
25
32};
33
35 int64_t bytes_before = -1;
36 int64_t bytes_after = -1;
37 int64_t bytes_freed = -1;
38};
39
41 int64_t bytes_baseline = -1;
42 int64_t bytes_limit = -1;
43 int64_t bytes_current = -1;
44 int64_t bytes_max = -1;
45};
46
48 int reason = -1;
50 int growing_mode = -1;
51 // The priority of the isolate during the GC cycle. A nullopt value denotes a
52 // mixed priority cycle, meaning the Isolate's priority was changed while the
53 // cycle was in progress.
54 std::optional<v8::Isolate::Priority> priority = std::nullopt;
55 bool reduce_memory = false;
56 bool is_loading = false;
57 bool is_input_handling = false;
85};
86
90};
91
95};
96
97template <typename EventType>
99 std::vector<EventType> events;
100};
101
108
110 int reason = -1;
111 // The priority of the isolate during the GC cycle. A nullopt value denotes a
112 // mixed priority cycle, meaning the Isolate's priority was changed while the
113 // cycle was in progress.
114 std::optional<v8::Isolate::Priority> priority = std::nullopt;
120#if defined(CPPGC_YOUNG_GENERATION)
121 GarbageCollectionPhases total_cpp;
122 GarbageCollectionSizes objects_cpp;
123 GarbageCollectionSizes memory_cpp;
124 double collection_rate_cpp_in_percent = -1.0;
125 double efficiency_cpp_in_bytes_per_us = -1.0;
126 double main_thread_efficiency_cpp_in_bytes_per_us = -1.0;
127#endif // defined(CPPGC_YOUNG_GENERATION)
128};
129
130// Note: These structs do not define any constructor, and declare most fields as
131// const, to force initializing them when using aggregate (designated)
132// initialization.
133// Those structs are meant to be created in V8 and read by embedders.
135 const bool async;
136 const bool streamed;
137 const bool success;
139 const size_t function_count;
140 // Optional field; only set if a high-resolution clock is available.
142};
143
145 const bool async;
146 const bool streamed;
147 const bool cached;
148 const bool deserialized;
149 const bool lazy;
150 const bool success;
151 const size_t code_size_in_bytes;
153 // Optional field; only set if a high-resolution clock is available.
155};
156
158 const bool async;
159 const bool success;
161 // Optional field; only set if a high-resolution clock is available.
163};
164
166 const size_t count;
167};
168
183 public:
184 // A unique identifier for a context in this Isolate.
185 // It is guaranteed to not be reused throughout the lifetime of the Isolate.
186 class ContextId {
187 public:
188 ContextId() : id_(kEmptyId) {}
189
190 bool IsEmpty() const { return id_ == kEmptyId; }
191 static const ContextId Empty() { return ContextId{kEmptyId}; }
192
193 bool operator==(const ContextId& other) const { return id_ == other.id_; }
194 bool operator!=(const ContextId& other) const { return id_ != other.id_; }
195
196 private:
197 friend class ::v8::Context;
198 friend class ::v8::internal::Isolate;
199
200 explicit ContextId(uintptr_t id) : id_(id) {}
201
202 static constexpr uintptr_t kEmptyId = 0;
203 uintptr_t id_;
204 };
205
206 virtual ~Recorder() = default;
207
208 // Main thread events. Those are only triggered on the main thread, and hence
209 // can access the context.
210#define ADD_MAIN_THREAD_EVENT(E) \
211 virtual void AddMainThreadEvent(const E&, ContextId) {}
221#undef ADD_MAIN_THREAD_EVENT
222
223 // Thread-safe events are not allowed to access the context and therefore do
224 // not carry a context ID with them. These IDs can be generated using
225 // Recorder::GetContextId() and the ID will be valid throughout the lifetime
226 // of the isolate. It is not guaranteed that the ID will still resolve to
227 // a valid context using Recorder::GetContext() at the time the metric is
228 // recorded. In this case, an empty handle will be returned.
229#define ADD_THREAD_SAFE_EVENT(E) \
230 virtual void AddThreadSafeEvent(const E&) {}
232#undef ADD_THREAD_SAFE_EVENT
233
234 virtual void NotifyIsolateDisposal() {}
235
236 // Return the context with the given id or an empty handle if the context
237 // was already garbage collected.
239 // Return the unique id corresponding to the given context.
241};
242
255 V8_INLINE static void Reset(Isolate* isolate) {
257 }
258
262 static LongTaskStats Get(Isolate* isolate);
263
264 int64_t gc_full_atomic_wall_clock_duration_us = 0;
265 int64_t gc_full_incremental_wall_clock_duration_us = 0;
266 int64_t gc_young_wall_clock_duration_us = 0;
267 // Only collected with --slow-histograms
268 int64_t v8_execute_us = 0;
269};
270
271} // namespace metrics
272} // namespace v8
273
274#endif // V8_METRICS_H_
Definition: v8-isolate.h:291
Definition: v8-local-handle.h:366
Definition: v8-local-handle.h:734
static void IncrementLongTasksStatsCounter(v8::Isolate *isolate)
Definition: v8-internal.h:1358
Definition: v8-metrics.h:186
ContextId()
Definition: v8-metrics.h:188
bool operator==(const ContextId &other) const
Definition: v8-metrics.h:193
static const ContextId Empty()
Definition: v8-metrics.h:191
bool operator!=(const ContextId &other) const
Definition: v8-metrics.h:194
bool IsEmpty() const
Definition: v8-metrics.h:190
Definition: v8-metrics.h:182
virtual ~Recorder()=default
static MaybeLocal< Context > GetContext(Isolate *isolate, ContextId id)
virtual void NotifyIsolateDisposal()
Definition: v8-metrics.h:234
static ContextId GetContextId(Local< Context > context)
Definition: libplatform.h:15
std::vector< EventType > events
Definition: v8-metrics.h:99
Definition: v8-metrics.h:47
GarbageCollectionPhases main_thread_incremental
Definition: v8-metrics.h:64
double collection_weight_in_percent
Definition: v8-metrics.h:79
double collection_weight_cpp_in_percent
Definition: v8-metrics.h:80
double main_thread_efficiency_cpp_in_bytes_per_us
Definition: v8-metrics.h:78
GarbageCollectionLimits global_consumed
Definition: v8-metrics.h:71
bool is_input_handling
Definition: v8-metrics.h:57
int64_t external_memory_bytes
Definition: v8-metrics.h:72
double collection_rate_cpp_in_percent
Definition: v8-metrics.h:74
GarbageCollectionSizes memory_cpp
Definition: v8-metrics.h:69
GarbageCollectionPhases main_thread_cpp
Definition: v8-metrics.h:61
GarbageCollectionLimits old_generation_consumed
Definition: v8-metrics.h:70
double efficiency_cpp_in_bytes_per_us
Definition: v8-metrics.h:76
GarbageCollectionSizes memory
Definition: v8-metrics.h:68
int64_t total_duration_since_last_mark_compact
Definition: v8-metrics.h:84
bool reduce_memory
Definition: v8-metrics.h:55
GarbageCollectionPhases main_thread_incremental_cpp
Definition: v8-metrics.h:65
double main_thread_efficiency_in_bytes_per_us
Definition: v8-metrics.h:77
GarbageCollectionSizes objects
Definition: v8-metrics.h:66
int64_t incremental_marking_start_stop_wall_clock_duration_in_us
Definition: v8-metrics.h:83
GarbageCollectionPhases main_thread_atomic_cpp
Definition: v8-metrics.h:63
double collection_rate_in_percent
Definition: v8-metrics.h:73
bool is_loading
Definition: v8-metrics.h:56
int growing_mode
Definition: v8-metrics.h:50
GarbageCollectionPhases main_thread
Definition: v8-metrics.h:60
int incremental_marking_reason
Definition: v8-metrics.h:49
std::optional< v8::Isolate::Priority > priority
Definition: v8-metrics.h:54
GarbageCollectionPhases total_cpp
Definition: v8-metrics.h:59
GarbageCollectionPhases total
Definition: v8-metrics.h:58
double main_thread_collection_weight_in_percent
Definition: v8-metrics.h:81
GarbageCollectionPhases main_thread_atomic
Definition: v8-metrics.h:62
int reason
Definition: v8-metrics.h:48
double efficiency_in_bytes_per_us
Definition: v8-metrics.h:75
GarbageCollectionSizes objects_cpp
Definition: v8-metrics.h:67
double main_thread_collection_weight_cpp_in_percent
Definition: v8-metrics.h:82
int64_t cpp_wall_clock_duration_in_us
Definition: v8-metrics.h:89
int64_t wall_clock_duration_in_us
Definition: v8-metrics.h:88
int64_t wall_clock_duration_in_us
Definition: v8-metrics.h:93
int64_t cpp_wall_clock_duration_in_us
Definition: v8-metrics.h:94
Definition: v8-metrics.h:40
int64_t bytes_limit
Definition: v8-metrics.h:42
int64_t bytes_max
Definition: v8-metrics.h:44
int64_t bytes_current
Definition: v8-metrics.h:43
int64_t bytes_baseline
Definition: v8-metrics.h:41
Definition: v8-metrics.h:26
int64_t sweep_wall_clock_duration_in_us
Definition: v8-metrics.h:30
int64_t weak_wall_clock_duration_in_us
Definition: v8-metrics.h:31
int64_t total_wall_clock_duration_in_us
Definition: v8-metrics.h:27
int64_t mark_wall_clock_duration_in_us
Definition: v8-metrics.h:29
int64_t compact_wall_clock_duration_in_us
Definition: v8-metrics.h:28
Definition: v8-metrics.h:34
int64_t bytes_freed
Definition: v8-metrics.h:37
int64_t bytes_after
Definition: v8-metrics.h:36
int64_t bytes_before
Definition: v8-metrics.h:35
Definition: v8-metrics.h:109
int64_t main_thread_wall_clock_duration_in_us
Definition: v8-metrics.h:116
double collection_rate_in_percent
Definition: v8-metrics.h:117
double efficiency_in_bytes_per_us
Definition: v8-metrics.h:118
double main_thread_efficiency_in_bytes_per_us
Definition: v8-metrics.h:119
int reason
Definition: v8-metrics.h:110
int64_t total_wall_clock_duration_in_us
Definition: v8-metrics.h:115
std::optional< v8::Isolate::Priority > priority
Definition: v8-metrics.h:114
Definition: v8-metrics.h:251
static void Reset(Isolate *isolate)
Definition: v8-metrics.h:255
static LongTaskStats Get(Isolate *isolate)
Definition: v8-metrics.h:144
const size_t liftoff_bailout_count
Definition: v8-metrics.h:152
const bool cached
Definition: v8-metrics.h:147
const bool success
Definition: v8-metrics.h:150
const bool deserialized
Definition: v8-metrics.h:148
const bool lazy
Definition: v8-metrics.h:149
const size_t code_size_in_bytes
Definition: v8-metrics.h:151
const bool streamed
Definition: v8-metrics.h:146
int64_t wall_clock_duration_in_us
Definition: v8-metrics.h:154
const bool async
Definition: v8-metrics.h:145
Definition: v8-metrics.h:134
const size_t module_size_in_bytes
Definition: v8-metrics.h:138
const size_t function_count
Definition: v8-metrics.h:139
const bool success
Definition: v8-metrics.h:137
int64_t wall_clock_duration_in_us
Definition: v8-metrics.h:141
const bool async
Definition: v8-metrics.h:135
const bool streamed
Definition: v8-metrics.h:136
Definition: v8-metrics.h:157
const bool success
Definition: v8-metrics.h:159
const bool async
Definition: v8-metrics.h:158
const size_t imported_function_count
Definition: v8-metrics.h:160
int64_t wall_clock_duration_in_us
Definition: v8-metrics.h:162
Definition: v8-metrics.h:165
const size_t count
Definition: v8-metrics.h:166
#define ADD_MAIN_THREAD_EVENT(E)
Definition: v8-metrics.h:210
#define ADD_THREAD_SAFE_EVENT(E)
Definition: v8-metrics.h:229
#define V8_EXPORT
Definition: v8config.h:867
#define V8_INLINE
Definition: v8config.h:511