Commit 0f4f30a1 authored by mlippautz's avatar mlippautz Committed by Commit bot

Revert of [heap] Tracer: Handle incremental marking scopes (patchset #4...

Revert of [heap] Tracer: Handle incremental marking scopes (patchset #4 id:100001 of https://codereview.chromium.org/2264033002/ )

Reason for revert:
Unittest fails on win32 debug:
https://build.chromium.org/p/client.v8/builders/V8%20Win32%20-%20debug/builds/4188/steps/Check/logs/GCTracerTest.Incremen..

Original issue's description:
> [heap] Tracer: Handle incremental marking scopes
>
> Before this patch all tracing scopes in incremental marking would be reset
> during a gc tracer start/stop cycle. This patch handles scopes the same way it
> does other incremental marking metrics.
>
> Also:
> - Align finalization metric with regular marking metric.
> - Smaller cleanups
>
> BUG=chromium:639818
> R=jochen@chromium.org
>
> Committed: https://crrev.com/300a8f97472b88ff2f94eb977c36b4bf1bedabf1
> Cr-Commit-Position: refs/heads/master@{#38822}

TBR=jochen@chromium.org
# Skipping CQ checks because original CL landed less than 1 days ago.
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=chromium:639818

Review-Url: https://codereview.chromium.org/2275583002
Cr-Commit-Position: refs/heads/master@{#38827}
parent d003bd9b
This diff is collapsed.
...@@ -9,7 +9,6 @@ ...@@ -9,7 +9,6 @@
#include "src/base/platform/platform.h" #include "src/base/platform/platform.h"
#include "src/counters.h" #include "src/counters.h"
#include "src/globals.h" #include "src/globals.h"
#include "testing/gtest/include/gtest/gtest_prod.h"
namespace v8 { namespace v8 {
namespace internal { namespace internal {
...@@ -60,64 +59,54 @@ inline BytesAndDuration MakeBytesAndDuration(uint64_t bytes, double duration) { ...@@ -60,64 +59,54 @@ inline BytesAndDuration MakeBytesAndDuration(uint64_t bytes, double duration) {
enum ScavengeSpeedMode { kForAllObjects, kForSurvivedObjects }; enum ScavengeSpeedMode { kForAllObjects, kForSurvivedObjects };
#define INCREMENTAL_SCOPES(F) \ #define TRACER_SCOPES(F) \
F(MC_INCREMENTAL_WRAPPER_PROLOGUE) \ F(EXTERNAL_WEAK_GLOBAL_HANDLES) \
F(MC_INCREMENTAL_WRAPPER_TRACING) \ F(MC_CLEAR) \
F(MC_INCREMENTAL_FINALIZE) \ F(MC_CLEAR_CODE_FLUSH) \
F(MC_INCREMENTAL_FINALIZE_OBJECT_GROUPING) \ F(MC_CLEAR_DEPENDENT_CODE) \
F(MC_INCREMENTAL_EXTERNAL_EPILOGUE) \ F(MC_CLEAR_GLOBAL_HANDLES) \
F(MC_INCREMENTAL_EXTERNAL_PROLOGUE) F(MC_CLEAR_MAPS) \
F(MC_CLEAR_SLOTS_BUFFER) \
#define TRACER_SCOPES(F) \ F(MC_CLEAR_STORE_BUFFER) \
INCREMENTAL_SCOPES(F) \ F(MC_CLEAR_STRING_TABLE) \
F(EXTERNAL_WEAK_GLOBAL_HANDLES) \ F(MC_CLEAR_WEAK_CELLS) \
F(MC_CLEAR) \ F(MC_CLEAR_WEAK_COLLECTIONS) \
F(MC_CLEAR_CODE_FLUSH) \ F(MC_CLEAR_WEAK_LISTS) \
F(MC_CLEAR_DEPENDENT_CODE) \ F(MC_EVACUATE) \
F(MC_CLEAR_GLOBAL_HANDLES) \ F(MC_EVACUATE_CANDIDATES) \
F(MC_CLEAR_MAPS) \ F(MC_EVACUATE_CLEAN_UP) \
F(MC_CLEAR_SLOTS_BUFFER) \ F(MC_EVACUATE_COPY) \
F(MC_CLEAR_STORE_BUFFER) \ F(MC_EVACUATE_UPDATE_POINTERS) \
F(MC_CLEAR_STRING_TABLE) \ F(MC_EVACUATE_UPDATE_POINTERS_TO_EVACUATED) \
F(MC_CLEAR_WEAK_CELLS) \ F(MC_EVACUATE_UPDATE_POINTERS_TO_NEW) \
F(MC_CLEAR_WEAK_COLLECTIONS) \ F(MC_EVACUATE_UPDATE_POINTERS_WEAK) \
F(MC_CLEAR_WEAK_LISTS) \ F(MC_EXTERNAL_EPILOGUE) \
F(MC_EVACUATE) \ F(MC_EXTERNAL_PROLOGUE) \
F(MC_EVACUATE_CANDIDATES) \ F(MC_FINISH) \
F(MC_EVACUATE_CLEAN_UP) \ F(MC_INCREMENTAL_FINALIZE) \
F(MC_EVACUATE_COPY) \ F(MC_INCREMENTAL_EXTERNAL_EPILOGUE) \
F(MC_EVACUATE_UPDATE_POINTERS) \ F(MC_INCREMENTAL_EXTERNAL_PROLOGUE) \
F(MC_EVACUATE_UPDATE_POINTERS_TO_EVACUATED) \ F(MC_MARK) \
F(MC_EVACUATE_UPDATE_POINTERS_TO_NEW) \ F(MC_MARK_FINISH_INCREMENTAL) \
F(MC_EVACUATE_UPDATE_POINTERS_WEAK) \ F(MC_MARK_PREPARE_CODE_FLUSH) \
F(MC_EXTERNAL_EPILOGUE) \ F(MC_MARK_ROOTS) \
F(MC_EXTERNAL_PROLOGUE) \ F(MC_MARK_WEAK_CLOSURE) \
F(MC_FINISH) \ F(MC_MARK_WEAK_CLOSURE_EPHEMERAL) \
F(MC_MARK) \ F(MC_MARK_WEAK_CLOSURE_WEAK_HANDLES) \
F(MC_MARK_FINISH_INCREMENTAL) \ F(MC_MARK_WEAK_CLOSURE_WEAK_ROOTS) \
F(MC_MARK_PREPARE_CODE_FLUSH) \ F(MC_MARK_WEAK_CLOSURE_HARMONY) \
F(MC_MARK_ROOTS) \ F(MC_SWEEP) \
F(MC_MARK_WEAK_CLOSURE) \ F(MC_SWEEP_CODE) \
F(MC_MARK_WEAK_CLOSURE_EPHEMERAL) \ F(MC_SWEEP_MAP) \
F(MC_MARK_WEAK_CLOSURE_WEAK_HANDLES) \ F(MC_SWEEP_OLD) \
F(MC_MARK_WEAK_CLOSURE_WEAK_ROOTS) \ F(SCAVENGER_CODE_FLUSH_CANDIDATES) \
F(MC_MARK_WEAK_CLOSURE_HARMONY) \ F(SCAVENGER_EXTERNAL_EPILOGUE) \
F(MC_MARK_WRAPPER_EPILOGUE) \ F(SCAVENGER_EXTERNAL_PROLOGUE) \
F(MC_MARK_WRAPPER_PROLOGUE) \ F(SCAVENGER_OBJECT_GROUPS) \
F(MC_MARK_WRAPPER_TRACING) \ F(SCAVENGER_OLD_TO_NEW_POINTERS) \
F(MC_MARK_OBJECT_GROUPING) \ F(SCAVENGER_ROOTS) \
F(MC_SWEEP) \ F(SCAVENGER_SCAVENGE) \
F(MC_SWEEP_CODE) \ F(SCAVENGER_SEMISPACE) \
F(MC_SWEEP_MAP) \
F(MC_SWEEP_OLD) \
F(SCAVENGER_CODE_FLUSH_CANDIDATES) \
F(SCAVENGER_EXTERNAL_EPILOGUE) \
F(SCAVENGER_EXTERNAL_PROLOGUE) \
F(SCAVENGER_OBJECT_GROUPS) \
F(SCAVENGER_OLD_TO_NEW_POINTERS) \
F(SCAVENGER_ROOTS) \
F(SCAVENGER_SCAVENGE) \
F(SCAVENGER_SEMISPACE) \
F(SCAVENGER_WEAK) F(SCAVENGER_WEAK)
#define TRACE_GC(tracer, scope_id) \ #define TRACE_GC(tracer, scope_id) \
...@@ -137,12 +126,7 @@ class GCTracer { ...@@ -137,12 +126,7 @@ class GCTracer {
#define DEFINE_SCOPE(scope) scope, #define DEFINE_SCOPE(scope) scope,
TRACER_SCOPES(DEFINE_SCOPE) TRACER_SCOPES(DEFINE_SCOPE)
#undef DEFINE_SCOPE #undef DEFINE_SCOPE
NUMBER_OF_SCOPES, NUMBER_OF_SCOPES
FIRST_INCREMENTAL_SCOPE = MC_INCREMENTAL_WRAPPER_PROLOGUE,
LAST_INCREMENTAL_SCOPE = MC_INCREMENTAL_EXTERNAL_PROLOGUE,
NUMBER_OF_INCREMENTAL_SCOPES =
LAST_INCREMENTAL_SCOPE - FIRST_INCREMENTAL_SCOPE + 1
}; };
Scope(GCTracer* tracer, ScopeId scope); Scope(GCTracer* tracer, ScopeId scope);
...@@ -213,7 +197,7 @@ class GCTracer { ...@@ -213,7 +197,7 @@ class GCTracer {
// Size of new space objects in constructor. // Size of new space objects in constructor.
intptr_t new_space_object_size; intptr_t new_space_object_size;
// Size of survived new space objects in destructor. // Size of survived new space objects in desctructor.
intptr_t survived_new_space_object_size; intptr_t survived_new_space_object_size;
// Number of incremental marking steps since creation of tracer. // Number of incremental marking steps since creation of tracer.
...@@ -255,35 +239,10 @@ class GCTracer { ...@@ -255,35 +239,10 @@ class GCTracer {
// events // events
double pure_incremental_marking_duration; double pure_incremental_marking_duration;
// Longest incremental marking step since start of marking (start of event). // Longest incremental marking step since start of marking.
// (value at start of event)
double longest_incremental_marking_step; double longest_incremental_marking_step;
// Number of incremental marking finalization steps since creation of
// tracer.
int cumulative_incremental_marking_finalization_steps;
// Cumulative pure duration of incremental marking steps since creation of
// tracer. (value at start of event)
double cumulative_incremental_marking_finalizaton_duration;
// Longest incremental marking finalization step since start of marking
// (start of event).
double longest_incremental_marking_finalization_step;
// Incremental marking finalization steps since
// - last event for SCAVENGER events
// - last INCREMENTAL_MARK_COMPACTOR event for INCREMENTAL_MARK_COMPACTOR
// events
int incremental_marking_finalizaton_steps;
// Duration of incremental marking finalization steps since
// - last event for SCAVENGER events
// - last INCREMENTAL_MARK_COMPACTOR event for INCREMENTAL_MARK_COMPACTOR
// events
double incremental_marking_finalization_duration;
double cumulative_incremental_scopes[Scope::NUMBER_OF_INCREMENTAL_SCOPES];
// Amounts of time spent in different scopes during GC. // Amounts of time spent in different scopes during GC.
double scopes[Scope::NUMBER_OF_SCOPES]; double scopes[Scope::NUMBER_OF_SCOPES];
}; };
...@@ -406,17 +365,6 @@ class GCTracer { ...@@ -406,17 +365,6 @@ class GCTracer {
// Discard all recorded survival events. // Discard all recorded survival events.
void ResetSurvivalEvents(); void ResetSurvivalEvents();
void AddScopeSample(Scope::ScopeId scope, double duration);
private:
FRIEND_TEST(GCTracer, AverageSpeed);
FRIEND_TEST(GCTracerTest, AllocationThroughput);
FRIEND_TEST(GCTracerTest, NewSpaceAllocationThroughput);
FRIEND_TEST(GCTracerTest, NewSpaceAllocationThroughputWithProvidedTime);
FRIEND_TEST(GCTracerTest, OldGenerationAllocationThroughputWithProvidedTime);
FRIEND_TEST(GCTracerTest, RegularScope);
FRIEND_TEST(GCTracerTest, IncrementalScope);
// Returns the average speed of the events in the buffer. // Returns the average speed of the events in the buffer.
// If the buffer is empty, the result is 0. // If the buffer is empty, the result is 0.
// Otherwise, the result is between 1 byte/ms and 1 GB/ms. // Otherwise, the result is between 1 byte/ms and 1 GB/ms.
...@@ -426,6 +374,7 @@ class GCTracer { ...@@ -426,6 +374,7 @@ class GCTracer {
void ResetForTesting(); void ResetForTesting();
private:
// Print one detailed trace line in name=value format. // Print one detailed trace line in name=value format.
// TODO(ernstm): Move to Heap. // TODO(ernstm): Move to Heap.
void PrintNVP() const; void PrintNVP() const;
...@@ -506,10 +455,6 @@ class GCTracer { ...@@ -506,10 +455,6 @@ class GCTracer {
// This timer is precise when run with --print-cumulative-gc-stat // This timer is precise when run with --print-cumulative-gc-stat
double cumulative_marking_duration_; double cumulative_marking_duration_;
// Cumulative duration of incremental marking scopes since the creation of
// the tracer.
double cumulative_incremental_scopes_[Scope::NUMBER_OF_INCREMENTAL_SCOPES];
// Total sweeping time on the main thread. // Total sweeping time on the main thread.
// This timer is precise when run with --print-cumulative-gc-stat // This timer is precise when run with --print-cumulative-gc-stat
// TODO(hpayer): Account for sweeping time on sweeper threads. Add a // TODO(hpayer): Account for sweeping time on sweeper threads. Add a
......
...@@ -557,8 +557,6 @@ void IncrementalMarking::StartMarking() { ...@@ -557,8 +557,6 @@ void IncrementalMarking::StartMarking() {
state_ = MARKING; state_ = MARKING;
if (heap_->UsingEmbedderHeapTracer()) { if (heap_->UsingEmbedderHeapTracer()) {
TRACE_GC(heap()->tracer(),
GCTracer::Scope::MC_INCREMENTAL_WRAPPER_PROLOGUE);
heap_->mark_compact_collector()->embedder_heap_tracer()->TracePrologue(); heap_->mark_compact_collector()->embedder_heap_tracer()->TracePrologue();
} }
...@@ -624,9 +622,6 @@ void IncrementalMarking::MarkRoots() { ...@@ -624,9 +622,6 @@ void IncrementalMarking::MarkRoots() {
void IncrementalMarking::MarkObjectGroups() { void IncrementalMarking::MarkObjectGroups() {
TRACE_GC(heap_->tracer(),
GCTracer::Scope::MC_INCREMENTAL_FINALIZE_OBJECT_GROUPING);
DCHECK(!heap_->UsingEmbedderHeapTracer()); DCHECK(!heap_->UsingEmbedderHeapTracer());
DCHECK(!finalize_marking_completed_); DCHECK(!finalize_marking_completed_);
DCHECK(IsMarking()); DCHECK(IsMarking());
...@@ -1208,8 +1203,6 @@ intptr_t IncrementalMarking::Step(intptr_t allocated_bytes, ...@@ -1208,8 +1203,6 @@ intptr_t IncrementalMarking::Step(intptr_t allocated_bytes,
bytes_processed = ProcessMarkingDeque(bytes_to_process); bytes_processed = ProcessMarkingDeque(bytes_to_process);
if (FLAG_incremental_marking_wrappers && if (FLAG_incremental_marking_wrappers &&
heap_->UsingEmbedderHeapTracer()) { heap_->UsingEmbedderHeapTracer()) {
TRACE_GC(heap()->tracer(),
GCTracer::Scope::MC_INCREMENTAL_WRAPPER_TRACING);
// This currently marks through all registered wrappers and does not // This currently marks through all registered wrappers and does not
// respect bytes_to_process. // respect bytes_to_process.
// TODO(hpayer): Integrate incremental marking of wrappers into // TODO(hpayer): Integrate incremental marking of wrappers into
......
...@@ -814,7 +814,6 @@ void MarkCompactCollector::Prepare() { ...@@ -814,7 +814,6 @@ void MarkCompactCollector::Prepare() {
if (!was_marked_incrementally_) { if (!was_marked_incrementally_) {
if (heap_->UsingEmbedderHeapTracer()) { if (heap_->UsingEmbedderHeapTracer()) {
TRACE_GC(heap()->tracer(), GCTracer::Scope::MC_MARK_WRAPPER_PROLOGUE);
heap_->mark_compact_collector()->embedder_heap_tracer()->TracePrologue(); heap_->mark_compact_collector()->embedder_heap_tracer()->TracePrologue();
} }
} }
...@@ -2082,14 +2081,12 @@ void MarkCompactCollector::ProcessEphemeralMarking( ...@@ -2082,14 +2081,12 @@ void MarkCompactCollector::ProcessEphemeralMarking(
bool work_to_do = true; bool work_to_do = true;
while (work_to_do) { while (work_to_do) {
if (UsingEmbedderHeapTracer()) { if (UsingEmbedderHeapTracer()) {
TRACE_GC(heap()->tracer(), GCTracer::Scope::MC_MARK_WRAPPER_TRACING);
RegisterWrappersWithEmbedderHeapTracer(); RegisterWrappersWithEmbedderHeapTracer();
embedder_heap_tracer()->AdvanceTracing( embedder_heap_tracer()->AdvanceTracing(
0, EmbedderHeapTracer::AdvanceTracingActions( 0, EmbedderHeapTracer::AdvanceTracingActions(
EmbedderHeapTracer::ForceCompletionAction::FORCE_COMPLETION)); EmbedderHeapTracer::ForceCompletionAction::FORCE_COMPLETION));
} }
if (!only_process_harmony_weak_collections) { if (!only_process_harmony_weak_collections) {
TRACE_GC(heap()->tracer(), GCTracer::Scope::MC_MARK_OBJECT_GROUPING);
isolate()->global_handles()->IterateObjectGroups( isolate()->global_handles()->IterateObjectGroups(
visitor, &IsUnmarkedHeapObjectWithHeap); visitor, &IsUnmarkedHeapObjectWithHeap);
MarkImplicitRefGroups(&MarkCompactMarkingVisitor::MarkObject); MarkImplicitRefGroups(&MarkCompactMarkingVisitor::MarkObject);
...@@ -2368,7 +2365,6 @@ void MarkCompactCollector::MarkLiveObjects() { ...@@ -2368,7 +2365,6 @@ void MarkCompactCollector::MarkLiveObjects() {
TRACE_GC(heap()->tracer(), GCTracer::Scope::MC_MARK_WEAK_CLOSURE_HARMONY); TRACE_GC(heap()->tracer(), GCTracer::Scope::MC_MARK_WEAK_CLOSURE_HARMONY);
ProcessEphemeralMarking(&root_visitor, true); ProcessEphemeralMarking(&root_visitor, true);
if (UsingEmbedderHeapTracer()) { if (UsingEmbedderHeapTracer()) {
TRACE_GC(heap()->tracer(), GCTracer::Scope::MC_MARK_WRAPPER_EPILOGUE);
embedder_heap_tracer()->TraceEpilogue(); embedder_heap_tracer()->TraceEpilogue();
} }
} }
......
...@@ -6206,6 +6206,54 @@ TEST(OldSpaceAllocationCounter) { ...@@ -6206,6 +6206,54 @@ TEST(OldSpaceAllocationCounter) {
} }
TEST(NewSpaceAllocationThroughput) {
CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate());
Isolate* isolate = CcTest::i_isolate();
Heap* heap = isolate->heap();
GCTracer* tracer = heap->tracer();
tracer->ResetForTesting();
int time1 = 100;
size_t counter1 = 1000;
tracer->SampleAllocation(time1, counter1, 0);
int time2 = 200;
size_t counter2 = 2000;
tracer->SampleAllocation(time2, counter2, 0);
size_t throughput =
tracer->NewSpaceAllocationThroughputInBytesPerMillisecond();
CHECK_EQ((counter2 - counter1) / (time2 - time1), throughput);
int time3 = 1000;
size_t counter3 = 30000;
tracer->SampleAllocation(time3, counter3, 0);
throughput = tracer->NewSpaceAllocationThroughputInBytesPerMillisecond();
CHECK_EQ((counter3 - counter1) / (time3 - time1), throughput);
}
TEST(NewSpaceAllocationThroughput2) {
CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate());
Isolate* isolate = CcTest::i_isolate();
Heap* heap = isolate->heap();
GCTracer* tracer = heap->tracer();
tracer->ResetForTesting();
int time1 = 100;
size_t counter1 = 1000;
tracer->SampleAllocation(time1, counter1, 0);
int time2 = 200;
size_t counter2 = 2000;
tracer->SampleAllocation(time2, counter2, 0);
size_t throughput =
tracer->NewSpaceAllocationThroughputInBytesPerMillisecond(100);
CHECK_EQ((counter2 - counter1) / (time2 - time1), throughput);
int time3 = 1000;
size_t counter3 = 30000;
tracer->SampleAllocation(time3, counter3, 0);
throughput = tracer->NewSpaceAllocationThroughputInBytesPerMillisecond(100);
CHECK_EQ((counter3 - counter1) / (time3 - time1), throughput);
}
static void CheckLeak(const v8::FunctionCallbackInfo<v8::Value>& args) { static void CheckLeak(const v8::FunctionCallbackInfo<v8::Value>& args) {
Isolate* isolate = CcTest::i_isolate(); Isolate* isolate = CcTest::i_isolate();
Object* message = Object* message =
...@@ -6318,6 +6366,55 @@ TEST(RemoveCodeFromSharedFunctionInfoButNotFromClosure) { ...@@ -6318,6 +6366,55 @@ TEST(RemoveCodeFromSharedFunctionInfoButNotFromClosure) {
"check(g1, g2);"); "check(g1, g2);");
} }
TEST(OldGenerationAllocationThroughput) {
CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate());
Isolate* isolate = CcTest::i_isolate();
Heap* heap = isolate->heap();
GCTracer* tracer = heap->tracer();
tracer->ResetForTesting();
int time1 = 100;
size_t counter1 = 1000;
tracer->SampleAllocation(time1, 0, counter1);
int time2 = 200;
size_t counter2 = 2000;
tracer->SampleAllocation(time2, 0, counter2);
size_t throughput = static_cast<size_t>(
tracer->OldGenerationAllocationThroughputInBytesPerMillisecond(100));
CHECK_EQ((counter2 - counter1) / (time2 - time1), throughput);
int time3 = 1000;
size_t counter3 = 30000;
tracer->SampleAllocation(time3, 0, counter3);
throughput = static_cast<size_t>(
tracer->OldGenerationAllocationThroughputInBytesPerMillisecond(100));
CHECK_EQ((counter3 - counter1) / (time3 - time1), throughput);
}
TEST(AllocationThroughput) {
CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate());
Isolate* isolate = CcTest::i_isolate();
Heap* heap = isolate->heap();
GCTracer* tracer = heap->tracer();
tracer->ResetForTesting();
int time1 = 100;
size_t counter1 = 1000;
tracer->SampleAllocation(time1, counter1, counter1);
int time2 = 200;
size_t counter2 = 2000;
tracer->SampleAllocation(time2, counter2, counter2);
size_t throughput = static_cast<size_t>(
tracer->AllocationThroughputInBytesPerMillisecond(100));
CHECK_EQ(2 * (counter2 - counter1) / (time2 - time1), throughput);
int time3 = 1000;
size_t counter3 = 30000;
tracer->SampleAllocation(time3, counter3, counter3);
throughput = tracer->AllocationThroughputInBytesPerMillisecond(100);
CHECK_EQ(2 * (counter3 - counter1) / (time3 - time1), throughput);
}
TEST(ContextMeasure) { TEST(ContextMeasure) {
CcTest::InitializeVM(); CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate()); v8::HandleScope scope(CcTest::isolate());
......
...@@ -5,17 +5,12 @@ ...@@ -5,17 +5,12 @@
#include <cmath> #include <cmath>
#include <limits> #include <limits>
#include "src/globals.h"
#include "src/heap/gc-tracer.h" #include "src/heap/gc-tracer.h"
#include "src/isolate.h"
#include "test/unittests/test-utils.h"
#include "testing/gtest/include/gtest/gtest.h" #include "testing/gtest/include/gtest/gtest.h"
namespace v8 { namespace v8 {
namespace internal { namespace internal {
typedef TestWithContext GCTracerTest;
TEST(GCTracer, AverageSpeed) { TEST(GCTracer, AverageSpeed) {
RingBuffer<BytesAndDuration> buffer; RingBuffer<BytesAndDuration> buffer;
EXPECT_EQ(100 / 2, EXPECT_EQ(100 / 2,
...@@ -50,141 +45,5 @@ TEST(GCTracer, AverageSpeed) { ...@@ -50,141 +45,5 @@ TEST(GCTracer, AverageSpeed) {
GCTracer::AverageSpeed(buffer, MakeBytesAndDuration(0, 0), buffer.kSize)); GCTracer::AverageSpeed(buffer, MakeBytesAndDuration(0, 0), buffer.kSize));
} }
namespace {
void SampleAndAddAllocaton(v8::internal::GCTracer* tracer, double time_ms,
size_t new_space_counter_bytes,
size_t old_generation_counter_bytes) {
tracer->SampleAllocation(time_ms, new_space_counter_bytes,
old_generation_counter_bytes);
tracer->AddAllocation(time_ms);
}
} // namespace
TEST_F(GCTracerTest, AllocationThroughput) {
GCTracer* tracer = i_isolate()->heap()->tracer();
tracer->ResetForTesting();
int time1 = 100;
size_t counter1 = 1000;
// First sample creates baseline but is not part of the recorded samples.
tracer->SampleAllocation(time1, counter1, counter1);
SampleAndAddAllocaton(tracer, time1, counter1, counter1);
int time2 = 200;
size_t counter2 = 2000;
SampleAndAddAllocaton(tracer, time2, counter2, counter2);
// Will only consider the current sample.
size_t throughput = static_cast<size_t>(
tracer->AllocationThroughputInBytesPerMillisecond(100));
EXPECT_EQ(2 * (counter2 - counter1) / (time2 - time1), throughput);
int time3 = 1000;
size_t counter3 = 30000;
SampleAndAddAllocaton(tracer, time3, counter3, counter3);
// Considers last 2 samples.
throughput = tracer->AllocationThroughputInBytesPerMillisecond(801);
EXPECT_EQ(2 * (counter3 - counter1) / (time3 - time1), throughput);
}
TEST_F(GCTracerTest, NewSpaceAllocationThroughput) {
GCTracer* tracer = i_isolate()->heap()->tracer();
tracer->ResetForTesting();
int time1 = 100;
size_t counter1 = 1000;
SampleAndAddAllocaton(tracer, time1, counter1, 0);
int time2 = 200;
size_t counter2 = 2000;
SampleAndAddAllocaton(tracer, time2, counter2, 0);
size_t throughput =
tracer->NewSpaceAllocationThroughputInBytesPerMillisecond();
EXPECT_EQ((counter2 - counter1) / (time2 - time1), throughput);
int time3 = 1000;
size_t counter3 = 30000;
SampleAndAddAllocaton(tracer, time3, counter3, 0);
throughput = tracer->NewSpaceAllocationThroughputInBytesPerMillisecond();
EXPECT_EQ((counter3 - counter1) / (time3 - time1), throughput);
}
TEST_F(GCTracerTest, NewSpaceAllocationThroughputWithProvidedTime) {
GCTracer* tracer = i_isolate()->heap()->tracer();
tracer->ResetForTesting();
int time1 = 100;
size_t counter1 = 1000;
// First sample creates baseline but is not part of the recorded samples.
SampleAndAddAllocaton(tracer, time1, counter1, 0);
int time2 = 200;
size_t counter2 = 2000;
SampleAndAddAllocaton(tracer, time2, counter2, 0);
// Will only consider the current sample.
size_t throughput =
tracer->NewSpaceAllocationThroughputInBytesPerMillisecond(100);
EXPECT_EQ((counter2 - counter1) / (time2 - time1), throughput);
int time3 = 1000;
size_t counter3 = 30000;
SampleAndAddAllocaton(tracer, time3, counter3, 0);
// Considers last 2 samples.
throughput = tracer->NewSpaceAllocationThroughputInBytesPerMillisecond(801);
EXPECT_EQ((counter3 - counter1) / (time3 - time1), throughput);
}
TEST_F(GCTracerTest, OldGenerationAllocationThroughputWithProvidedTime) {
GCTracer* tracer = i_isolate()->heap()->tracer();
tracer->ResetForTesting();
int time1 = 100;
size_t counter1 = 1000;
// First sample creates baseline but is not part of the recorded samples.
SampleAndAddAllocaton(tracer, time1, 0, counter1);
int time2 = 200;
size_t counter2 = 2000;
SampleAndAddAllocaton(tracer, time2, 0, counter2);
// Will only consider the current sample.
size_t throughput = static_cast<size_t>(
tracer->OldGenerationAllocationThroughputInBytesPerMillisecond(100));
EXPECT_EQ((counter2 - counter1) / (time2 - time1), throughput);
int time3 = 1000;
size_t counter3 = 30000;
SampleAndAddAllocaton(tracer, time3, 0, counter3);
// Considers last 2 samples.
throughput = static_cast<size_t>(
tracer->OldGenerationAllocationThroughputInBytesPerMillisecond(801));
EXPECT_EQ((counter3 - counter1) / (time3 - time1), throughput);
}
TEST_F(GCTracerTest, RegularScope) {
GCTracer* tracer = i_isolate()->heap()->tracer();
{
// Sample not added because it's not within a started tracer.
tracer->AddScopeSample(GCTracer::Scope::MC_MARK, 100);
}
tracer->Start(MARK_COMPACTOR, "gc unittest", "collector unittest");
{ tracer->AddScopeSample(GCTracer::Scope::MC_MARK, 100); }
tracer->Stop(MARK_COMPACTOR);
EXPECT_EQ(
static_cast<size_t>(tracer->current_.scopes[GCTracer::Scope::MC_MARK]),
100u);
}
TEST_F(GCTracerTest, IncrementalScope) {
GCTracer* tracer = i_isolate()->heap()->tracer();
{
// Sample is added because its ScopeId is listed as incremental sample.
tracer->AddScopeSample(GCTracer::Scope::MC_INCREMENTAL_FINALIZE, 100);
}
tracer->Start(MARK_COMPACTOR, "gc unittest", "collector unittest");
// Switch to incremental MC to enable writing back incremental scopes.
tracer->current_.type = GCTracer::Event::INCREMENTAL_MARK_COMPACTOR;
{ tracer->AddScopeSample(GCTracer::Scope::MC_INCREMENTAL_FINALIZE, 100); }
tracer->Stop(MARK_COMPACTOR);
EXPECT_EQ(
static_cast<size_t>(
tracer->current_.scopes[GCTracer::Scope::MC_INCREMENTAL_FINALIZE]),
200u);
}
} // namespace internal } // namespace internal
} // namespace v8 } // namespace v8
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