216 lines
6.7 KiB
C
216 lines
6.7 KiB
C
|
// Copyright 2021 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 INCLUDE_V8_STATISTICS_H_
|
||
|
#define INCLUDE_V8_STATISTICS_H_
|
||
|
|
||
|
#include <stddef.h>
|
||
|
#include <stdint.h>
|
||
|
|
||
|
#include <memory>
|
||
|
#include <utility>
|
||
|
#include <vector>
|
||
|
|
||
|
#include "v8-local-handle.h" // NOLINT(build/include_directory)
|
||
|
#include "v8-promise.h" // NOLINT(build/include_directory)
|
||
|
#include "v8config.h" // NOLINT(build/include_directory)
|
||
|
|
||
|
namespace v8 {
|
||
|
|
||
|
class Context;
|
||
|
class Isolate;
|
||
|
|
||
|
namespace internal {
|
||
|
class ReadOnlyHeap;
|
||
|
} // namespace internal
|
||
|
|
||
|
/**
|
||
|
* Controls how the default MeasureMemoryDelegate reports the result of
|
||
|
* the memory measurement to JS. With kSummary only the total size is reported.
|
||
|
* With kDetailed the result includes the size of each native context.
|
||
|
*/
|
||
|
enum class MeasureMemoryMode { kSummary, kDetailed };
|
||
|
|
||
|
/**
|
||
|
* Controls how promptly a memory measurement request is executed.
|
||
|
* By default the measurement is folded with the next scheduled GC which may
|
||
|
* happen after a while and is forced after some timeout.
|
||
|
* The kEager mode starts incremental GC right away and is useful for testing.
|
||
|
* The kLazy mode does not force GC.
|
||
|
*/
|
||
|
enum class MeasureMemoryExecution { kDefault, kEager, kLazy };
|
||
|
|
||
|
/**
|
||
|
* The delegate is used in Isolate::MeasureMemory API.
|
||
|
*
|
||
|
* It specifies the contexts that need to be measured and gets called when
|
||
|
* the measurement is completed to report the results.
|
||
|
*/
|
||
|
class V8_EXPORT MeasureMemoryDelegate {
|
||
|
public:
|
||
|
virtual ~MeasureMemoryDelegate() = default;
|
||
|
|
||
|
/**
|
||
|
* Returns true if the size of the given context needs to be measured.
|
||
|
*/
|
||
|
virtual bool ShouldMeasure(Local<Context> context) = 0;
|
||
|
|
||
|
/**
|
||
|
* This function is called when memory measurement finishes.
|
||
|
*
|
||
|
* \param context_sizes_in_bytes a vector of (context, size) pairs that
|
||
|
* includes each context for which ShouldMeasure returned true and that
|
||
|
* was not garbage collected while the memory measurement was in progress.
|
||
|
*
|
||
|
* \param unattributed_size_in_bytes total size of objects that were not
|
||
|
* attributed to any context (i.e. are likely shared objects).
|
||
|
*/
|
||
|
virtual void MeasurementComplete(
|
||
|
const std::vector<std::pair<Local<Context>, size_t>>&
|
||
|
context_sizes_in_bytes,
|
||
|
size_t unattributed_size_in_bytes) = 0;
|
||
|
|
||
|
/**
|
||
|
* Returns a default delegate that resolves the given promise when
|
||
|
* the memory measurement completes.
|
||
|
*
|
||
|
* \param isolate the current isolate
|
||
|
* \param context the current context
|
||
|
* \param promise_resolver the promise resolver that is given the
|
||
|
* result of the memory measurement.
|
||
|
* \param mode the detail level of the result.
|
||
|
*/
|
||
|
static std::unique_ptr<MeasureMemoryDelegate> Default(
|
||
|
Isolate* isolate, Local<Context> context,
|
||
|
Local<Promise::Resolver> promise_resolver, MeasureMemoryMode mode);
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Collection of shared per-process V8 memory information.
|
||
|
*
|
||
|
* Instances of this class can be passed to
|
||
|
* v8::V8::GetSharedMemoryStatistics to get shared memory statistics from V8.
|
||
|
*/
|
||
|
class V8_EXPORT SharedMemoryStatistics {
|
||
|
public:
|
||
|
SharedMemoryStatistics();
|
||
|
size_t read_only_space_size() { return read_only_space_size_; }
|
||
|
size_t read_only_space_used_size() { return read_only_space_used_size_; }
|
||
|
size_t read_only_space_physical_size() {
|
||
|
return read_only_space_physical_size_;
|
||
|
}
|
||
|
|
||
|
private:
|
||
|
size_t read_only_space_size_;
|
||
|
size_t read_only_space_used_size_;
|
||
|
size_t read_only_space_physical_size_;
|
||
|
|
||
|
friend class V8;
|
||
|
friend class internal::ReadOnlyHeap;
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Collection of V8 heap information.
|
||
|
*
|
||
|
* Instances of this class can be passed to v8::Isolate::GetHeapStatistics to
|
||
|
* get heap statistics from V8.
|
||
|
*/
|
||
|
class V8_EXPORT HeapStatistics {
|
||
|
public:
|
||
|
HeapStatistics();
|
||
|
size_t total_heap_size() { return total_heap_size_; }
|
||
|
size_t total_heap_size_executable() { return total_heap_size_executable_; }
|
||
|
size_t total_physical_size() { return total_physical_size_; }
|
||
|
size_t total_available_size() { return total_available_size_; }
|
||
|
size_t total_global_handles_size() { return total_global_handles_size_; }
|
||
|
size_t used_global_handles_size() { return used_global_handles_size_; }
|
||
|
size_t used_heap_size() { return used_heap_size_; }
|
||
|
size_t heap_size_limit() { return heap_size_limit_; }
|
||
|
size_t malloced_memory() { return malloced_memory_; }
|
||
|
size_t external_memory() { return external_memory_; }
|
||
|
size_t peak_malloced_memory() { return peak_malloced_memory_; }
|
||
|
size_t number_of_native_contexts() { return number_of_native_contexts_; }
|
||
|
size_t number_of_detached_contexts() { return number_of_detached_contexts_; }
|
||
|
|
||
|
/**
|
||
|
* Returns a 0/1 boolean, which signifies whether the V8 overwrite heap
|
||
|
* garbage with a bit pattern.
|
||
|
*/
|
||
|
size_t does_zap_garbage() { return does_zap_garbage_; }
|
||
|
|
||
|
private:
|
||
|
size_t total_heap_size_;
|
||
|
size_t total_heap_size_executable_;
|
||
|
size_t total_physical_size_;
|
||
|
size_t total_available_size_;
|
||
|
size_t used_heap_size_;
|
||
|
size_t heap_size_limit_;
|
||
|
size_t malloced_memory_;
|
||
|
size_t external_memory_;
|
||
|
size_t peak_malloced_memory_;
|
||
|
bool does_zap_garbage_;
|
||
|
size_t number_of_native_contexts_;
|
||
|
size_t number_of_detached_contexts_;
|
||
|
size_t total_global_handles_size_;
|
||
|
size_t used_global_handles_size_;
|
||
|
|
||
|
friend class V8;
|
||
|
friend class Isolate;
|
||
|
};
|
||
|
|
||
|
class V8_EXPORT HeapSpaceStatistics {
|
||
|
public:
|
||
|
HeapSpaceStatistics();
|
||
|
const char* space_name() { return space_name_; }
|
||
|
size_t space_size() { return space_size_; }
|
||
|
size_t space_used_size() { return space_used_size_; }
|
||
|
size_t space_available_size() { return space_available_size_; }
|
||
|
size_t physical_space_size() { return physical_space_size_; }
|
||
|
|
||
|
private:
|
||
|
const char* space_name_;
|
||
|
size_t space_size_;
|
||
|
size_t space_used_size_;
|
||
|
size_t space_available_size_;
|
||
|
size_t physical_space_size_;
|
||
|
|
||
|
friend class Isolate;
|
||
|
};
|
||
|
|
||
|
class V8_EXPORT HeapObjectStatistics {
|
||
|
public:
|
||
|
HeapObjectStatistics();
|
||
|
const char* object_type() { return object_type_; }
|
||
|
const char* object_sub_type() { return object_sub_type_; }
|
||
|
size_t object_count() { return object_count_; }
|
||
|
size_t object_size() { return object_size_; }
|
||
|
|
||
|
private:
|
||
|
const char* object_type_;
|
||
|
const char* object_sub_type_;
|
||
|
size_t object_count_;
|
||
|
size_t object_size_;
|
||
|
|
||
|
friend class Isolate;
|
||
|
};
|
||
|
|
||
|
class V8_EXPORT HeapCodeStatistics {
|
||
|
public:
|
||
|
HeapCodeStatistics();
|
||
|
size_t code_and_metadata_size() { return code_and_metadata_size_; }
|
||
|
size_t bytecode_and_metadata_size() { return bytecode_and_metadata_size_; }
|
||
|
size_t external_script_source_size() { return external_script_source_size_; }
|
||
|
|
||
|
private:
|
||
|
size_t code_and_metadata_size_;
|
||
|
size_t bytecode_and_metadata_size_;
|
||
|
size_t external_script_source_size_;
|
||
|
|
||
|
friend class Isolate;
|
||
|
};
|
||
|
|
||
|
} // namespace v8
|
||
|
|
||
|
#endif // INCLUDE_V8_STATISTICS_H_
|