Commit 481c1705 authored by Michael Lippautz's avatar Michael Lippautz Committed by Commit Bot

[RCS] Reuse GCTracer scopes in RCS

This makes all the information that is present for GCTracer also
available to RCS.

Bug: chromium:748569
Change-Id: Ie7e8c3770b81ab1321cad08f6954492b72ef0514
Reviewed-on: https://chromium-review.googlesource.com/585427
Commit-Queue: Michael Lippautz <mlippautz@chromium.org>
Reviewed-by: 's avatarIgor Sheludko <ishell@chromium.org>
Reviewed-by: 's avatarCamillo Bruni <cbruni@chromium.org>
Reviewed-by: 's avatarUlan Degenbaev <ulan@chromium.org>
Cr-Commit-Position: refs/heads/master@{#47043}
parent d624daac
...@@ -435,6 +435,9 @@ void RuntimeCallTimer::Snapshot() { ...@@ -435,6 +435,9 @@ void RuntimeCallTimer::Snapshot() {
RuntimeCallStats::RuntimeCallStats() : in_use_(false) { RuntimeCallStats::RuntimeCallStats() : in_use_(false) {
static const char* const kNames[] = { static const char* const kNames[] = {
#define CALL_BUILTIN_COUNTER(name) "GC_" #name,
FOR_EACH_GC_COUNTER(CALL_BUILTIN_COUNTER) //
#undef CALL_BUILTIN_COUNTER
#define CALL_RUNTIME_COUNTER(name) #name, #define CALL_RUNTIME_COUNTER(name) #name,
FOR_EACH_MANUAL_COUNTER(CALL_RUNTIME_COUNTER) // FOR_EACH_MANUAL_COUNTER(CALL_RUNTIME_COUNTER) //
#undef CALL_RUNTIME_COUNTER #undef CALL_RUNTIME_COUNTER
...@@ -448,7 +451,7 @@ RuntimeCallStats::RuntimeCallStats() : in_use_(false) { ...@@ -448,7 +451,7 @@ RuntimeCallStats::RuntimeCallStats() : in_use_(false) {
FOR_EACH_API_COUNTER(CALL_BUILTIN_COUNTER) // FOR_EACH_API_COUNTER(CALL_BUILTIN_COUNTER) //
#undef CALL_BUILTIN_COUNTER #undef CALL_BUILTIN_COUNTER
#define CALL_BUILTIN_COUNTER(name) #name, #define CALL_BUILTIN_COUNTER(name) #name,
FOR_EACH_HANDLER_COUNTER(CALL_BUILTIN_COUNTER) FOR_EACH_HANDLER_COUNTER(CALL_BUILTIN_COUNTER) //
#undef CALL_BUILTIN_COUNTER #undef CALL_BUILTIN_COUNTER
}; };
for (int i = 0; i < counters_count; i++) { for (int i = 0; i < counters_count; i++) {
...@@ -458,6 +461,9 @@ RuntimeCallStats::RuntimeCallStats() : in_use_(false) { ...@@ -458,6 +461,9 @@ RuntimeCallStats::RuntimeCallStats() : in_use_(false) {
// static // static
const RuntimeCallStats::CounterId RuntimeCallStats::counters[] = { const RuntimeCallStats::CounterId RuntimeCallStats::counters[] = {
#define CALL_BUILTIN_COUNTER(name) &RuntimeCallStats::GC_##name,
FOR_EACH_GC_COUNTER(CALL_BUILTIN_COUNTER) //
#undef CALL_BUILTIN_COUNTER
#define CALL_RUNTIME_COUNTER(name) &RuntimeCallStats::name, #define CALL_RUNTIME_COUNTER(name) &RuntimeCallStats::name,
FOR_EACH_MANUAL_COUNTER(CALL_RUNTIME_COUNTER) // FOR_EACH_MANUAL_COUNTER(CALL_RUNTIME_COUNTER) //
#undef CALL_RUNTIME_COUNTER #undef CALL_RUNTIME_COUNTER
...@@ -472,7 +478,7 @@ const RuntimeCallStats::CounterId RuntimeCallStats::counters[] = { ...@@ -472,7 +478,7 @@ const RuntimeCallStats::CounterId RuntimeCallStats::counters[] = {
FOR_EACH_API_COUNTER(CALL_BUILTIN_COUNTER) // FOR_EACH_API_COUNTER(CALL_BUILTIN_COUNTER) //
#undef CALL_BUILTIN_COUNTER #undef CALL_BUILTIN_COUNTER
#define CALL_BUILTIN_COUNTER(name) &RuntimeCallStats::Handler_##name, #define CALL_BUILTIN_COUNTER(name) &RuntimeCallStats::Handler_##name,
FOR_EACH_HANDLER_COUNTER(CALL_BUILTIN_COUNTER) FOR_EACH_HANDLER_COUNTER(CALL_BUILTIN_COUNTER) //
#undef CALL_BUILTIN_COUNTER #undef CALL_BUILTIN_COUNTER
}; };
......
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
#include "src/base/platform/elapsed-timer.h" #include "src/base/platform/elapsed-timer.h"
#include "src/base/platform/time.h" #include "src/base/platform/time.h"
#include "src/globals.h" #include "src/globals.h"
#include "src/heap-symbols.h"
#include "src/objects.h" #include "src/objects.h"
#include "src/runtime/runtime.h" #include "src/runtime/runtime.h"
#include "src/tracing/trace-event.h" #include "src/tracing/trace-event.h"
...@@ -601,6 +602,8 @@ class RuntimeCallTimer final { ...@@ -601,6 +602,8 @@ class RuntimeCallTimer final {
base::TimeDelta elapsed_; base::TimeDelta elapsed_;
}; };
#define FOR_EACH_GC_COUNTER(V) TRACER_SCOPES(V)
#define FOR_EACH_API_COUNTER(V) \ #define FOR_EACH_API_COUNTER(V) \
V(ArrayBuffer_Cast) \ V(ArrayBuffer_Cast) \
V(ArrayBuffer_Neuter) \ V(ArrayBuffer_Neuter) \
...@@ -778,11 +781,10 @@ class RuntimeCallTimer final { ...@@ -778,11 +781,10 @@ class RuntimeCallTimer final {
V(FunctionCallback) \ V(FunctionCallback) \
V(FunctionPrototypeGetter) \ V(FunctionPrototypeGetter) \
V(FunctionPrototypeSetter) \ V(FunctionPrototypeSetter) \
V(GC) \ V(GC_Custom_AllAvailableGarbage) \
V(GC_AllAvailableGarbage) \ V(GC_Custom_IncrementalMarkingJob) \
V(GC_IncrementalMarkingJob) \ V(GC_Custom_IncrementalMarkingObserver) \
V(GC_IncrementalMarkingObserver) \ V(GC_Custom_SlowAllocateRaw) \
V(GC_SlowAllocateRaw) \
V(GCEpilogueCallback) \ V(GCEpilogueCallback) \
V(GCPrologueCallback) \ V(GCPrologueCallback) \
V(GenericNamedPropertyDefinerCallback) \ V(GenericNamedPropertyDefinerCallback) \
...@@ -888,6 +890,9 @@ class RuntimeCallStats final : public ZoneObject { ...@@ -888,6 +890,9 @@ class RuntimeCallStats final : public ZoneObject {
typedef RuntimeCallCounter RuntimeCallStats::*CounterId; typedef RuntimeCallCounter RuntimeCallStats::*CounterId;
V8_EXPORT_PRIVATE RuntimeCallStats(); V8_EXPORT_PRIVATE RuntimeCallStats();
#define CALL_RUNTIME_COUNTER(name) RuntimeCallCounter GC_##name;
FOR_EACH_GC_COUNTER(CALL_RUNTIME_COUNTER)
#undef CALL_RUNTIME_COUNTER
#define CALL_RUNTIME_COUNTER(name) RuntimeCallCounter name; #define CALL_RUNTIME_COUNTER(name) RuntimeCallCounter name;
FOR_EACH_MANUAL_COUNTER(CALL_RUNTIME_COUNTER) FOR_EACH_MANUAL_COUNTER(CALL_RUNTIME_COUNTER)
#undef CALL_RUNTIME_COUNTER #undef CALL_RUNTIME_COUNTER
......
...@@ -266,4 +266,91 @@ ...@@ -266,4 +266,91 @@
V(is_concat_spreadable_symbol, Symbol.isConcatSpreadable) \ V(is_concat_spreadable_symbol, Symbol.isConcatSpreadable) \
V(to_string_tag_symbol, Symbol.toStringTag) V(to_string_tag_symbol, Symbol.toStringTag)
#define INCREMENTAL_SCOPES(F) \
/* MC_INCREMENTAL is the top-level incremental marking scope. */ \
F(MC_INCREMENTAL) \
F(MC_INCREMENTAL_SWEEPING) \
F(MC_INCREMENTAL_WRAPPER_PROLOGUE) \
F(MC_INCREMENTAL_WRAPPER_TRACING) \
F(MC_INCREMENTAL_FINALIZE) \
F(MC_INCREMENTAL_FINALIZE_BODY) \
F(MC_INCREMENTAL_EXTERNAL_EPILOGUE) \
F(MC_INCREMENTAL_EXTERNAL_PROLOGUE)
#define TRACER_SCOPES(F) \
INCREMENTAL_SCOPES(F) \
F(HEAP_EPILOGUE) \
F(HEAP_EPILOGUE_REDUCE_NEW_SPACE) \
F(HEAP_EXTERNAL_EPILOGUE) \
F(HEAP_EXTERNAL_PROLOGUE) \
F(HEAP_EXTERNAL_WEAK_GLOBAL_HANDLES) \
F(HEAP_PROLOGUE) \
F(MC_CLEAR) \
F(MC_CLEAR_DEPENDENT_CODE) \
F(MC_CLEAR_MAPS) \
F(MC_CLEAR_SLOTS_BUFFER) \
F(MC_CLEAR_STORE_BUFFER) \
F(MC_CLEAR_STRING_TABLE) \
F(MC_CLEAR_WEAK_CELLS) \
F(MC_CLEAR_WEAK_COLLECTIONS) \
F(MC_CLEAR_WEAK_LISTS) \
F(MC_EPILOGUE) \
F(MC_EVACUATE) \
F(MC_EVACUATE_CANDIDATES) \
F(MC_EVACUATE_CLEAN_UP) \
F(MC_EVACUATE_COPY) \
F(MC_EVACUATE_EPILOGUE) \
F(MC_EVACUATE_PROLOGUE) \
F(MC_EVACUATE_REBALANCE) \
F(MC_EVACUATE_UPDATE_POINTERS) \
F(MC_EVACUATE_UPDATE_POINTERS_SLOTS) \
F(MC_EVACUATE_UPDATE_POINTERS_TO_NEW_ROOTS) \
F(MC_EVACUATE_UPDATE_POINTERS_WEAK) \
F(MC_FINISH) \
F(MC_MARK) \
F(MC_MARK_FINISH_INCREMENTAL) \
F(MC_MARK_ROOTS) \
F(MC_MARK_WEAK_CLOSURE) \
F(MC_MARK_WEAK_CLOSURE_EPHEMERAL) \
F(MC_MARK_WEAK_CLOSURE_WEAK_HANDLES) \
F(MC_MARK_WEAK_CLOSURE_WEAK_ROOTS) \
F(MC_MARK_WEAK_CLOSURE_HARMONY) \
F(MC_MARK_WRAPPER_EPILOGUE) \
F(MC_MARK_WRAPPER_PROLOGUE) \
F(MC_MARK_WRAPPER_TRACING) \
F(MC_PROLOGUE) \
F(MC_SWEEP) \
F(MC_SWEEP_CODE) \
F(MC_SWEEP_MAP) \
F(MC_SWEEP_OLD) \
F(MINOR_MC) \
F(MINOR_MC_CLEAR) \
F(MINOR_MC_CLEAR_STRING_TABLE) \
F(MINOR_MC_CLEAR_WEAK_LISTS) \
F(MINOR_MC_EVACUATE) \
F(MINOR_MC_EVACUATE_CLEAN_UP) \
F(MINOR_MC_EVACUATE_COPY) \
F(MINOR_MC_EVACUATE_EPILOGUE) \
F(MINOR_MC_EVACUATE_PROLOGUE) \
F(MINOR_MC_EVACUATE_REBALANCE) \
F(MINOR_MC_EVACUATE_UPDATE_POINTERS) \
F(MINOR_MC_EVACUATE_UPDATE_POINTERS_SLOTS) \
F(MINOR_MC_EVACUATE_UPDATE_POINTERS_TO_NEW_ROOTS) \
F(MINOR_MC_EVACUATE_UPDATE_POINTERS_WEAK) \
F(MINOR_MC_MARK) \
F(MINOR_MC_MARK_GLOBAL_HANDLES) \
F(MINOR_MC_MARK_SEED) \
F(MINOR_MC_MARK_ROOTS) \
F(MINOR_MC_MARK_WEAK) \
F(MINOR_MC_MARKING_DEQUE) \
F(MINOR_MC_RESET_LIVENESS) \
F(MINOR_MC_SWEEPING) \
F(SCAVENGER_FAST_PROMOTE) \
F(SCAVENGER_SCAVENGE) \
F(SCAVENGER_SCAVENGE_WEAK_GLOBAL_HANDLES_IDENTIFY) \
F(SCAVENGER_SCAVENGE_WEAK_GLOBAL_HANDLES_PROCESS) \
F(SCAVENGER_SCAVENGE_PARALLEL) \
F(SCAVENGER_SCAVENGE_ROOTS) \
F(SCAVENGER_SCAVENGE_WEAK)
#endif // V8_HEAP_SYMBOLS_H_ #endif // V8_HEAP_SYMBOLS_H_
...@@ -23,18 +23,19 @@ static size_t CountTotalHolesSize(Heap* heap) { ...@@ -23,18 +23,19 @@ static size_t CountTotalHolesSize(Heap* heap) {
return holes_size; return holes_size;
} }
RuntimeCallStats::CounterId GCTracer::RCSCounterFromScope(Scope::ScopeId id) {
return RuntimeCallStats::counters[kFirstGCIndexInRuntimeCallStats +
static_cast<int>(id)];
}
GCTracer::Scope::Scope(GCTracer* tracer, ScopeId scope) GCTracer::Scope::Scope(GCTracer* tracer, ScopeId scope)
: tracer_(tracer), scope_(scope) { : tracer_(tracer), scope_(scope) {
// All accesses to incremental_marking_scope assume that incremental marking
// scopes come first.
STATIC_ASSERT(FIRST_INCREMENTAL_SCOPE == 0);
start_time_ = tracer_->heap_->MonotonicallyIncreasingTimeInMs(); start_time_ = tracer_->heap_->MonotonicallyIncreasingTimeInMs();
// TODO(cbruni): remove once we fully moved to a trace-based system. // TODO(cbruni): remove once we fully moved to a trace-based system.
if (V8_UNLIKELY(FLAG_runtime_stats)) { if (V8_UNLIKELY(FLAG_runtime_stats)) {
RuntimeCallStats::Enter( RuntimeCallStats::Enter(
tracer_->heap_->isolate()->counters()->runtime_call_stats(), &timer_, tracer_->heap_->isolate()->counters()->runtime_call_stats(), &timer_,
&RuntimeCallStats::GC); GCTracer::RCSCounterFromScope(scope));
} }
} }
...@@ -115,6 +116,14 @@ GCTracer::GCTracer(Heap* heap) ...@@ -115,6 +116,14 @@ GCTracer::GCTracer(Heap* heap)
old_generation_allocation_in_bytes_since_gc_(0), old_generation_allocation_in_bytes_since_gc_(0),
combined_mark_compact_speed_cache_(0.0), combined_mark_compact_speed_cache_(0.0),
start_counter_(0) { start_counter_(0) {
// All accesses to incremental_marking_scope assume that incremental marking
// scopes come first.
STATIC_ASSERT(0 == Scope::FIRST_INCREMENTAL_SCOPE);
// We assume that MC_INCREMENTAL is the first scope so that we can properly
// map it to RuntimeCallStats.
STATIC_ASSERT(0 == Scope::MC_INCREMENTAL);
CHECK(&RuntimeCallStats::GC_MC_INCREMENTAL ==
RuntimeCallStats::counters[GCTracer::kFirstGCIndexInRuntimeCallStats]);
current_.end_time = heap_->MonotonicallyIncreasingTimeInMs(); current_.end_time = heap_->MonotonicallyIncreasingTimeInMs();
} }
...@@ -205,11 +214,6 @@ void GCTracer::Start(GarbageCollector collector, ...@@ -205,11 +214,6 @@ void GCTracer::Start(GarbageCollector collector,
counters->aggregated_memory_heap_committed()->AddSample(start_time, counters->aggregated_memory_heap_committed()->AddSample(start_time,
committed_memory); committed_memory);
counters->aggregated_memory_heap_used()->AddSample(start_time, used_memory); counters->aggregated_memory_heap_used()->AddSample(start_time, used_memory);
// TODO(cbruni): remove once we fully moved to a trace-based system.
if (V8_UNLIKELY(FLAG_runtime_stats)) {
RuntimeCallStats::Enter(heap_->isolate()->counters()->runtime_call_stats(),
&timer_, &RuntimeCallStats::GC);
}
} }
void GCTracer::ResetIncrementalMarkingCounters() { void GCTracer::ResetIncrementalMarkingCounters() {
...@@ -304,12 +308,6 @@ void GCTracer::Stop(GarbageCollector collector) { ...@@ -304,12 +308,6 @@ void GCTracer::Stop(GarbageCollector collector) {
if (FLAG_trace_gc) { if (FLAG_trace_gc) {
heap_->PrintShortHeapStatistics(); heap_->PrintShortHeapStatistics();
} }
// TODO(cbruni): remove once we fully moved to a trace-based system.
if (V8_UNLIKELY(FLAG_runtime_stats)) {
RuntimeCallStats::Leave(heap_->isolate()->counters()->runtime_call_stats(),
&timer_);
}
} }
......
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include "src/base/ring-buffer.h" #include "src/base/ring-buffer.h"
#include "src/counters.h" #include "src/counters.h"
#include "src/globals.h" #include "src/globals.h"
#include "src/heap-symbols.h"
#include "src/heap/heap.h" #include "src/heap/heap.h"
#include "testing/gtest/include/gtest/gtest_prod.h" // nogncheck #include "testing/gtest/include/gtest/gtest_prod.h" // nogncheck
...@@ -24,93 +25,6 @@ inline BytesAndDuration MakeBytesAndDuration(uint64_t bytes, double duration) { ...@@ -24,93 +25,6 @@ inline BytesAndDuration MakeBytesAndDuration(uint64_t bytes, double duration) {
enum ScavengeSpeedMode { kForAllObjects, kForSurvivedObjects }; enum ScavengeSpeedMode { kForAllObjects, kForSurvivedObjects };
#define INCREMENTAL_SCOPES(F) \
/* MC_INCREMENTAL is the top-level incremental marking scope. */ \
F(MC_INCREMENTAL) \
F(MC_INCREMENTAL_SWEEPING) \
F(MC_INCREMENTAL_WRAPPER_PROLOGUE) \
F(MC_INCREMENTAL_WRAPPER_TRACING) \
F(MC_INCREMENTAL_FINALIZE) \
F(MC_INCREMENTAL_FINALIZE_BODY) \
F(MC_INCREMENTAL_EXTERNAL_EPILOGUE) \
F(MC_INCREMENTAL_EXTERNAL_PROLOGUE)
#define TRACER_SCOPES(F) \
INCREMENTAL_SCOPES(F) \
F(HEAP_EPILOGUE) \
F(HEAP_EPILOGUE_REDUCE_NEW_SPACE) \
F(HEAP_EXTERNAL_EPILOGUE) \
F(HEAP_EXTERNAL_PROLOGUE) \
F(HEAP_EXTERNAL_WEAK_GLOBAL_HANDLES) \
F(HEAP_PROLOGUE) \
F(MC_CLEAR) \
F(MC_CLEAR_DEPENDENT_CODE) \
F(MC_CLEAR_MAPS) \
F(MC_CLEAR_SLOTS_BUFFER) \
F(MC_CLEAR_STORE_BUFFER) \
F(MC_CLEAR_STRING_TABLE) \
F(MC_CLEAR_WEAK_CELLS) \
F(MC_CLEAR_WEAK_COLLECTIONS) \
F(MC_CLEAR_WEAK_LISTS) \
F(MC_EPILOGUE) \
F(MC_EVACUATE) \
F(MC_EVACUATE_CANDIDATES) \
F(MC_EVACUATE_CLEAN_UP) \
F(MC_EVACUATE_COPY) \
F(MC_EVACUATE_EPILOGUE) \
F(MC_EVACUATE_PROLOGUE) \
F(MC_EVACUATE_REBALANCE) \
F(MC_EVACUATE_UPDATE_POINTERS) \
F(MC_EVACUATE_UPDATE_POINTERS_SLOTS) \
F(MC_EVACUATE_UPDATE_POINTERS_TO_NEW_ROOTS) \
F(MC_EVACUATE_UPDATE_POINTERS_WEAK) \
F(MC_FINISH) \
F(MC_MARK) \
F(MC_MARK_FINISH_INCREMENTAL) \
F(MC_MARK_ROOTS) \
F(MC_MARK_WEAK_CLOSURE) \
F(MC_MARK_WEAK_CLOSURE_EPHEMERAL) \
F(MC_MARK_WEAK_CLOSURE_WEAK_HANDLES) \
F(MC_MARK_WEAK_CLOSURE_WEAK_ROOTS) \
F(MC_MARK_WEAK_CLOSURE_HARMONY) \
F(MC_MARK_WRAPPER_EPILOGUE) \
F(MC_MARK_WRAPPER_PROLOGUE) \
F(MC_MARK_WRAPPER_TRACING) \
F(MC_PROLOGUE) \
F(MC_SWEEP) \
F(MC_SWEEP_CODE) \
F(MC_SWEEP_MAP) \
F(MC_SWEEP_OLD) \
F(MINOR_MC) \
F(MINOR_MC_CLEAR) \
F(MINOR_MC_CLEAR_STRING_TABLE) \
F(MINOR_MC_CLEAR_WEAK_LISTS) \
F(MINOR_MC_EVACUATE) \
F(MINOR_MC_EVACUATE_CLEAN_UP) \
F(MINOR_MC_EVACUATE_COPY) \
F(MINOR_MC_EVACUATE_EPILOGUE) \
F(MINOR_MC_EVACUATE_PROLOGUE) \
F(MINOR_MC_EVACUATE_REBALANCE) \
F(MINOR_MC_EVACUATE_UPDATE_POINTERS) \
F(MINOR_MC_EVACUATE_UPDATE_POINTERS_SLOTS) \
F(MINOR_MC_EVACUATE_UPDATE_POINTERS_TO_NEW_ROOTS) \
F(MINOR_MC_EVACUATE_UPDATE_POINTERS_WEAK) \
F(MINOR_MC_MARK) \
F(MINOR_MC_MARK_GLOBAL_HANDLES) \
F(MINOR_MC_MARK_SEED) \
F(MINOR_MC_MARK_ROOTS) \
F(MINOR_MC_MARK_WEAK) \
F(MINOR_MC_MARKING_DEQUE) \
F(MINOR_MC_RESET_LIVENESS) \
F(MINOR_MC_SWEEPING) \
F(SCAVENGER_FAST_PROMOTE) \
F(SCAVENGER_SCAVENGE) \
F(SCAVENGER_SCAVENGE_WEAK_GLOBAL_HANDLES_IDENTIFY) \
F(SCAVENGER_SCAVENGE_WEAK_GLOBAL_HANDLES_PROCESS) \
F(SCAVENGER_SCAVENGE_PARALLEL) \
F(SCAVENGER_SCAVENGE_ROOTS) \
F(SCAVENGER_SCAVENGE_WEAK)
#define TRACE_GC(tracer, scope_id) \ #define TRACE_GC(tracer, scope_id) \
GCTracer::Scope::ScopeId gc_tracer_scope_id(scope_id); \ GCTracer::Scope::ScopeId gc_tracer_scope_id(scope_id); \
GCTracer::Scope gc_tracer_scope(tracer, gc_tracer_scope_id); \ GCTracer::Scope gc_tracer_scope(tracer, gc_tracer_scope_id); \
...@@ -153,6 +67,7 @@ class V8_EXPORT_PRIVATE GCTracer { ...@@ -153,6 +67,7 @@ class V8_EXPORT_PRIVATE GCTracer {
FIRST_INCREMENTAL_SCOPE = MC_INCREMENTAL, FIRST_INCREMENTAL_SCOPE = MC_INCREMENTAL,
LAST_INCREMENTAL_SCOPE = MC_INCREMENTAL_EXTERNAL_PROLOGUE, LAST_INCREMENTAL_SCOPE = MC_INCREMENTAL_EXTERNAL_PROLOGUE,
FIRST_SCOPE = MC_INCREMENTAL,
NUMBER_OF_INCREMENTAL_SCOPES = NUMBER_OF_INCREMENTAL_SCOPES =
LAST_INCREMENTAL_SCOPE - FIRST_INCREMENTAL_SCOPE + 1 LAST_INCREMENTAL_SCOPE - FIRST_INCREMENTAL_SCOPE + 1
}; };
...@@ -243,6 +158,9 @@ class V8_EXPORT_PRIVATE GCTracer { ...@@ -243,6 +158,9 @@ class V8_EXPORT_PRIVATE GCTracer {
}; };
static const int kThroughputTimeFrameMs = 5000; static const int kThroughputTimeFrameMs = 5000;
static const int kFirstGCIndexInRuntimeCallStats = 0;
static RuntimeCallStats::CounterId RCSCounterFromScope(Scope::ScopeId id);
explicit GCTracer(Heap* heap); explicit GCTracer(Heap* heap);
...@@ -439,9 +357,6 @@ class V8_EXPORT_PRIVATE GCTracer { ...@@ -439,9 +357,6 @@ class V8_EXPORT_PRIVATE GCTracer {
// Counts how many tracers were started without stopping. // Counts how many tracers were started without stopping.
int start_counter_; int start_counter_;
// Separate timer used for --runtime_call_stats
RuntimeCallTimer timer_;
base::RingBuffer<BytesAndDuration> recorded_minor_gcs_total_; base::RingBuffer<BytesAndDuration> recorded_minor_gcs_total_;
base::RingBuffer<BytesAndDuration> recorded_minor_gcs_survived_; base::RingBuffer<BytesAndDuration> recorded_minor_gcs_survived_;
base::RingBuffer<BytesAndDuration> recorded_compactions_; base::RingBuffer<BytesAndDuration> recorded_compactions_;
......
...@@ -1042,7 +1042,7 @@ void Heap::CollectAllAvailableGarbage(GarbageCollectionReason gc_reason) { ...@@ -1042,7 +1042,7 @@ void Heap::CollectAllAvailableGarbage(GarbageCollectionReason gc_reason) {
InvokeOutOfMemoryCallback(); InvokeOutOfMemoryCallback();
} }
RuntimeCallTimerScope runtime_timer( RuntimeCallTimerScope runtime_timer(
isolate(), &RuntimeCallStats::GC_AllAvailableGarbage); isolate(), &RuntimeCallStats::GC_Custom_AllAvailableGarbage);
if (isolate()->concurrent_recompilation_enabled()) { if (isolate()->concurrent_recompilation_enabled()) {
// The optimizing compiler may be unnecessarily holding on to memory. // The optimizing compiler may be unnecessarily holding on to memory.
DisallowHeapAllocation no_recursive_gc; DisallowHeapAllocation no_recursive_gc;
...@@ -1122,7 +1122,6 @@ bool Heap::CollectGarbage(AllocationSpace space, ...@@ -1122,7 +1122,6 @@ bool Heap::CollectGarbage(AllocationSpace space,
const v8::GCCallbackFlags gc_callback_flags) { const v8::GCCallbackFlags gc_callback_flags) {
// The VM is in the GC state until exiting this function. // The VM is in the GC state until exiting this function.
VMState<GC> state(isolate()); VMState<GC> state(isolate());
RuntimeCallTimerScope runtime_timer(isolate(), &RuntimeCallStats::GC);
const char* collector_reason = NULL; const char* collector_reason = NULL;
GarbageCollector collector = SelectGarbageCollector(space, &collector_reason); GarbageCollector collector = SelectGarbageCollector(space, &collector_reason);
......
...@@ -43,7 +43,7 @@ void IncrementalMarkingJob::Task::Step(Heap* heap) { ...@@ -43,7 +43,7 @@ void IncrementalMarkingJob::Task::Step(Heap* heap) {
void IncrementalMarkingJob::Task::RunInternal() { void IncrementalMarkingJob::Task::RunInternal() {
VMState<GC> state(isolate()); VMState<GC> state(isolate());
RuntimeCallTimerScope runtime_timer( RuntimeCallTimerScope runtime_timer(
isolate(), &RuntimeCallStats::GC_IncrementalMarkingJob); isolate(), &RuntimeCallStats::GC_Custom_IncrementalMarkingJob);
Heap* heap = isolate()->heap(); Heap* heap = isolate()->heap();
IncrementalMarking* incremental_marking = heap->incremental_marking(); IncrementalMarking* incremental_marking = heap->incremental_marking();
......
...@@ -27,7 +27,7 @@ void IncrementalMarking::Observer::Step(int bytes_allocated, Address, size_t) { ...@@ -27,7 +27,7 @@ void IncrementalMarking::Observer::Step(int bytes_allocated, Address, size_t) {
VMState<GC> state(incremental_marking_.heap()->isolate()); VMState<GC> state(incremental_marking_.heap()->isolate());
RuntimeCallTimerScope runtime_timer( RuntimeCallTimerScope runtime_timer(
incremental_marking_.heap()->isolate(), incremental_marking_.heap()->isolate(),
&RuntimeCallStats::GC_IncrementalMarkingObserver); &RuntimeCallStats::GC_Custom_IncrementalMarkingObserver);
incremental_marking_.AdvanceIncrementalMarkingOnAllocation(); incremental_marking_.AdvanceIncrementalMarkingOnAllocation();
} }
......
...@@ -3042,8 +3042,8 @@ HeapObject* CompactionSpace::SweepAndRetryAllocation(int size_in_bytes) { ...@@ -3042,8 +3042,8 @@ HeapObject* CompactionSpace::SweepAndRetryAllocation(int size_in_bytes) {
HeapObject* PagedSpace::SlowAllocateRaw(int size_in_bytes) { HeapObject* PagedSpace::SlowAllocateRaw(int size_in_bytes) {
VMState<GC> state(heap()->isolate()); VMState<GC> state(heap()->isolate());
RuntimeCallTimerScope runtime_timer(heap()->isolate(), RuntimeCallTimerScope runtime_timer(
&RuntimeCallStats::GC_SlowAllocateRaw); heap()->isolate(), &RuntimeCallStats::GC_Custom_SlowAllocateRaw);
return RawSlowAllocateRaw(size_in_bytes); return RawSlowAllocateRaw(size_in_bytes);
} }
......
...@@ -1726,7 +1726,8 @@ code is governed by a BSD-style license that can be found in the LICENSE file. ...@@ -1726,7 +1726,8 @@ code is governed by a BSD-style license that can be found in the LICENSE file.
Group.add('parse', new Group('Parse', /.*Parse.*/, "#FF6600")); Group.add('parse', new Group('Parse', /.*Parse.*/, "#FF6600"));
Group.add('callback', new Group('Blink C++', /.*Callback.*/, "#109618")); Group.add('callback', new Group('Blink C++', /.*Callback.*/, "#109618"));
Group.add('api', new Group('API', /.*API.*/, "#990099")); Group.add('api', new Group('API', /.*API.*/, "#990099"));
Group.add('gc', new Group('GC', /GC|AllocateInTargetSpace/, "#0099C6")); Group.add('gc-custom', new Group('GC-Custom', /GC_Custom_.*/, "#0099C6"));
Group.add('gc', new Group('GC', /GC_.*|AllocateInTargetSpace/, "#00799c"));
Group.add('javascript', new Group('JavaScript', /JS_Execution/, "#DD4477")); Group.add('javascript', new Group('JavaScript', /JS_Execution/, "#DD4477"));
Group.add('runtime', new Group('V8 C++', /.*/, "#88BB00")); Group.add('runtime', new Group('V8 C++', /.*/, "#88BB00"));
var group = var group =
......
...@@ -355,7 +355,8 @@ def read_stats(path, domain, args): ...@@ -355,7 +355,8 @@ def read_stats(path, domain, args):
('Group-Parse', re.compile(".*Parse.*")), ('Group-Parse', re.compile(".*Parse.*")),
('Group-Callback', re.compile(".*Callback.*")), ('Group-Callback', re.compile(".*Callback.*")),
('Group-API', re.compile(".*API.*")), ('Group-API', re.compile(".*API.*")),
('Group-GC', re.compile("GC|AllocateInTargetSpace")), ('Group-GC-Custom', re.compile("GC_Custom_.*")),
('Group-GC', re.compile("GC_.*|AllocateInTargetSpace")),
('Group-JavaScript', re.compile("JS_Execution")), ('Group-JavaScript', re.compile("JS_Execution")),
('Group-Runtime', re.compile(".*"))] ('Group-Runtime', re.compile(".*"))]
with open(path, "rt") as f: with open(path, "rt") as f:
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment