Commit f2d4a23d authored by Michael Lippautz's avatar Michael Lippautz Committed by V8 LUCI CQ

heap: Fix TSAN race in AllocationTrackerForDebugging

The previous CLs stealth-fixed an issue where we wouldn't receive
MoveEvent's even if FLAG_fuzzer_gc_analysis was true.

The fix uncovered a data race which is fixed here.

Bug: v8:12615
Change-Id: I646dc31918d6ebe717716290375e12eac562b4b8
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3452030Reviewed-by: 's avatarDominik Inführ <dinfuehr@chromium.org>
Commit-Queue: Michael Lippautz <mlippautz@chromium.org>
Cr-Commit-Position: refs/heads/main@{#79038}
parent a50d814e
...@@ -738,7 +738,7 @@ class Heap::AllocationTrackerForDebugging final ...@@ -738,7 +738,7 @@ class Heap::AllocationTrackerForDebugging final
void AllocationEvent(Address addr, int size) final { void AllocationEvent(Address addr, int size) final {
if (FLAG_verify_predictable) { if (FLAG_verify_predictable) {
++allocations_count_; allocations_count_.fetch_add(1, std::memory_order_relaxed);
// Advance synthetic time by making a time request. // Advance synthetic time by making a time request.
heap_->MonotonicallyIncreasingTimeInMs(); heap_->MonotonicallyIncreasingTimeInMs();
...@@ -749,9 +749,9 @@ class Heap::AllocationTrackerForDebugging final ...@@ -749,9 +749,9 @@ class Heap::AllocationTrackerForDebugging final
PrintAllocationsHash(); PrintAllocationsHash();
} }
} else if (FLAG_fuzzer_gc_analysis) { } else if (FLAG_fuzzer_gc_analysis) {
++allocations_count_; allocations_count_.fetch_add(1, std::memory_order_relaxed);
} else if (FLAG_trace_allocation_stack_interval > 0) { } else if (FLAG_trace_allocation_stack_interval > 0) {
++allocations_count_; allocations_count_.fetch_add(1, std::memory_order_relaxed);
if (allocations_count_ % FLAG_trace_allocation_stack_interval == 0) { if (allocations_count_ % FLAG_trace_allocation_stack_interval == 0) {
heap_->isolate()->PrintStack(stdout, Isolate::kPrintStackConcise); heap_->isolate()->PrintStack(stdout, Isolate::kPrintStackConcise);
} }
...@@ -760,7 +760,7 @@ class Heap::AllocationTrackerForDebugging final ...@@ -760,7 +760,7 @@ class Heap::AllocationTrackerForDebugging final
void MoveEvent(Address source, Address target, int size) final { void MoveEvent(Address source, Address target, int size) final {
if (FLAG_verify_predictable) { if (FLAG_verify_predictable) {
++allocations_count_; allocations_count_.fetch_add(1, std::memory_order_relaxed);
// Advance synthetic time by making a time request. // Advance synthetic time by making a time request.
heap_->MonotonicallyIncreasingTimeInMs(); heap_->MonotonicallyIncreasingTimeInMs();
...@@ -772,7 +772,7 @@ class Heap::AllocationTrackerForDebugging final ...@@ -772,7 +772,7 @@ class Heap::AllocationTrackerForDebugging final
PrintAllocationsHash(); PrintAllocationsHash();
} }
} else if (FLAG_fuzzer_gc_analysis) { } else if (FLAG_fuzzer_gc_analysis) {
++allocations_count_; allocations_count_.fetch_add(1, std::memory_order_relaxed);
} }
} }
...@@ -803,13 +803,15 @@ class Heap::AllocationTrackerForDebugging final ...@@ -803,13 +803,15 @@ class Heap::AllocationTrackerForDebugging final
void PrintAllocationsHash() { void PrintAllocationsHash() {
uint32_t hash = StringHasher::GetHashCore(raw_allocations_hash_); uint32_t hash = StringHasher::GetHashCore(raw_allocations_hash_);
PrintF("\n### Allocations = %zu, hash = 0x%08x\n", allocations_count_, PrintF("\n### Allocations = %zu, hash = 0x%08x\n",
hash); allocations_count_.load(std::memory_order_relaxed), hash);
} }
Heap* const heap_; Heap* const heap_;
// Count of all allocations performed through C++ bottlenecks. // Count of all allocations performed through C++ bottlenecks. This needs to
size_t allocations_count_ = 0; // be atomic as objects are moved in parallel in the GC which counts as
// allocations.
std::atomic<size_t> allocations_count_;
// Running hash over allocations performed. // Running hash over allocations performed.
uint32_t raw_allocations_hash_ = 0; uint32_t raw_allocations_hash_ = 0;
}; };
......
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