8efe0e32b3
This reverts commit 54b141ef9a
.
Reason for revert: closed tree due to: https://ci.chromium.org/p/v8/builders/ci/V8%20Linux%20-%20noi18n%20-%20debug/33838?
Original change's description:
> [wasm][ukm] Add tests for Wasm events (reland)
>
> Ensure that events are triggered when a module is decoded, compiled,
> instantiated and tiered-up.
>
> This is a reland of I9dc87957fc03023c5ab1c4f49e865957c8324e1a.
>
> R=clemensb@chromium.org
>
> Bug: chromium:1092417
> Cq-Include-Trybots: luci.v8.try:v8_linux64_tsan_rel_ng
> Cq-Include-Trybots: luci.v8.try:v8_linux64_tsan_isolates_rel_ng
> Change-Id: Ib5883a338c3756c6f3488fbdd7b6861ecc2ba218
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2367866
> Reviewed-by: Adam Klein <adamk@chromium.org>
> Reviewed-by: Clemens Backes <clemensb@chromium.org>
> Commit-Queue: Emanuel Ziegler <ecmziegler@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#70074}
TBR=adamk@chromium.org,clemensb@chromium.org,ecmziegler@chromium.org
Change-Id: I859c69bacfca9c790ed274140bb9e8d23de26729
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: chromium:1092417
Cq-Include-Trybots: luci.v8.try:v8_linux64_tsan_rel_ng
Cq-Include-Trybots: luci.v8.try:v8_linux64_tsan_isolates_rel_ng
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2425104
Reviewed-by: Francis McCabe <fgm@chromium.org>
Commit-Queue: Francis McCabe <fgm@chromium.org>
Cr-Commit-Position: refs/heads/master@{#70075}
134 lines
4.3 KiB
C++
134 lines
4.3 KiB
C++
// Copyright 2020 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 V8_METRICS_H_
|
|
#define V8_METRICS_H_
|
|
|
|
#include "v8.h" // NOLINT(build/include_directory)
|
|
|
|
namespace v8 {
|
|
namespace metrics {
|
|
|
|
struct WasmModuleDecoded {
|
|
bool async = false;
|
|
bool streamed = false;
|
|
bool success = false;
|
|
size_t module_size_in_bytes = 0;
|
|
size_t function_count = 0;
|
|
int64_t wall_clock_time_in_us = 0;
|
|
};
|
|
|
|
struct WasmModuleCompiled {
|
|
bool async = false;
|
|
bool streamed = false;
|
|
bool cached = false;
|
|
bool deserialized = false;
|
|
bool lazy = false;
|
|
bool success = false;
|
|
size_t code_size_in_bytes = 0;
|
|
size_t liftoff_bailout_count = 0;
|
|
int64_t wall_clock_time_in_us = 0;
|
|
};
|
|
|
|
struct WasmModuleInstantiated {
|
|
bool async = false;
|
|
bool success = false;
|
|
size_t imported_function_count = 0;
|
|
int64_t wall_clock_time_in_us = 0;
|
|
};
|
|
|
|
struct WasmModuleTieredUp {
|
|
bool lazy = false;
|
|
size_t code_size_in_bytes = 0;
|
|
int64_t wall_clock_time_in_us = 0;
|
|
};
|
|
|
|
struct WasmModulesPerIsolate {
|
|
size_t count = 0;
|
|
};
|
|
|
|
#define V8_MAIN_THREAD_METRICS_EVENTS(V) \
|
|
V(WasmModuleDecoded) \
|
|
V(WasmModuleCompiled) \
|
|
V(WasmModuleInstantiated) \
|
|
V(WasmModuleTieredUp)
|
|
|
|
#define V8_THREAD_SAFE_METRICS_EVENTS(V) V(WasmModulesPerIsolate)
|
|
|
|
/**
|
|
* This class serves as a base class for recording event-based metrics in V8.
|
|
* There a two kinds of metrics, those which are expected to be thread-safe and
|
|
* whose implementation is required to fulfill this requirement and those whose
|
|
* implementation does not have that requirement and only needs to be
|
|
* executable on the main thread. If such an event is triggered from a
|
|
* background thread, it will be delayed and executed by the foreground task
|
|
* runner.
|
|
*
|
|
* The thread-safe events are listed in the V8_THREAD_SAFE_METRICS_EVENTS
|
|
* macro above while the main thread event are listed in
|
|
* V8_MAIN_THREAD_METRICS_EVENTS above. For the former, a virtual method
|
|
* AddMainThreadEvent(const E& event, v8::Context::Token token) will be
|
|
* generated and for the latter AddThreadSafeEvent(const E& event).
|
|
*
|
|
* Thread-safe events are not allowed to access the context and therefore do
|
|
* not carry a context ID with them. These IDs can be generated using
|
|
* Recorder::GetContextId() and the ID will be valid throughout the lifetime
|
|
* of the isolate. It is not guaranteed that the ID will still resolve to
|
|
* a valid context using Recorder::GetContext() at the time the metric is
|
|
* recorded. In this case, an empty handle will be returned.
|
|
*
|
|
* The embedder is expected to call v8::Isolate::SetMetricsRecorder()
|
|
* providing its implementation and have the virtual methods overwritten
|
|
* for the events it cares about.
|
|
*/
|
|
class V8_EXPORT Recorder {
|
|
public:
|
|
// A unique identifier for a context in this Isolate.
|
|
// It is guaranteed to not be reused throughout the lifetime of the Isolate.
|
|
class ContextId {
|
|
public:
|
|
ContextId() : id_(kEmptyId) {}
|
|
|
|
bool IsEmpty() const { return id_ == kEmptyId; }
|
|
static const ContextId Empty() { return ContextId{kEmptyId}; }
|
|
|
|
bool operator==(const ContextId& other) const { return id_ == other.id_; }
|
|
bool operator!=(const ContextId& other) const { return id_ != other.id_; }
|
|
|
|
private:
|
|
friend class ::v8::Context;
|
|
friend class ::v8::internal::Isolate;
|
|
|
|
explicit ContextId(uintptr_t id) : id_(id) {}
|
|
|
|
static constexpr uintptr_t kEmptyId = 0;
|
|
uintptr_t id_;
|
|
};
|
|
|
|
virtual ~Recorder() = default;
|
|
|
|
#define ADD_MAIN_THREAD_EVENT(E) \
|
|
virtual void AddMainThreadEvent(const E& event, ContextId context_id) {}
|
|
V8_MAIN_THREAD_METRICS_EVENTS(ADD_MAIN_THREAD_EVENT)
|
|
#undef ADD_MAIN_THREAD_EVENT
|
|
|
|
#define ADD_THREAD_SAFE_EVENT(E) \
|
|
virtual void AddThreadSafeEvent(const E& event) {}
|
|
V8_THREAD_SAFE_METRICS_EVENTS(ADD_THREAD_SAFE_EVENT)
|
|
#undef ADD_THREAD_SAFE_EVENT
|
|
|
|
virtual void NotifyIsolateDisposal() {}
|
|
|
|
// Return the context with the given id or an empty handle if the context
|
|
// was already garbage collected.
|
|
static MaybeLocal<Context> GetContext(Isolate* isolate, ContextId id);
|
|
// Return the unique id corresponding to the given context.
|
|
static ContextId GetContextId(Local<Context> context);
|
|
};
|
|
|
|
} // namespace metrics
|
|
} // namespace v8
|
|
|
|
#endif // V8_METRICS_H_
|