• Dominik Inführ's avatar
    Reland "[test] Avoid disabling of RCS during runtime" · b8146576
    Dominik Inführ authored
    This is a reland of 11045926
    
    The first version of this CL uncovered a TSAN failure when not disabling
    RCS anymore. The problem was that a background thread was still updating
    RCS counters, while the main thread already dumped those values during
    tear down. This CL fixes this by dumping counters only after all
    background threads are stopped.
    
    Original change's description:
    > [test] Avoid disabling of RCS during runtime
    >
    > Test was flaky since disabling of RCS at runtime is unsafe. Some code
    > (e.g. TRACE_GC) is run only in case RCS is enabled and such code paths
    > might also DCHECK that RCS is enabled.
    > A background thread (sweeping in this case) could've already
    > entered such a code path right before RCS is disabled. In this case the
    > guard at the entry still saw that RCS is enabled but subsequent DCHECKs
    > that ensure that RCS is enabled might fail.
    >
    > We could fix this by completing the sweeper tasks before disabling RCS
    > but there might be other similar tasks which might be run at that point
    > in the future (e.g. memory unmapper).
    >
    > Disabling the flag doesn't even seem to be needed for the initial
    > regression test, so it seems simpler to just not disable RCS anymore.
    >
    > Bug: v8:12026
    > Change-Id: I878f7dd9a7a4abb6a501f7a7651a1240ef2082a6
    > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3162043
    > Reviewed-by: Michael Lippautz <mlippautz@chromium.org>
    > Commit-Queue: Dominik Inführ <dinfuehr@chromium.org>
    > Cr-Commit-Position: refs/heads/main@{#76845}
    
    Bug: v8:12026, v8:12234
    Change-Id: I5cb577051d188d17b02ca7da79a3f1d9aa646cae
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3162050
    Commit-Queue: Dominik Inführ <dinfuehr@chromium.org>
    Reviewed-by: 's avatarJakob Gruber <jgruber@chromium.org>
    Reviewed-by: 's avatarMichael Lippautz <mlippautz@chromium.org>
    Cr-Commit-Position: refs/heads/main@{#76859}
    b8146576
Name
Last commit
Last update
..
heap-tester.h Loading commit data...
heap-utils.cc Loading commit data...
heap-utils.h Loading commit data...
test-alloc.cc Loading commit data...
test-array-buffer-tracker.cc Loading commit data...
test-compaction.cc Loading commit data...
test-concurrent-allocation.cc Loading commit data...
test-concurrent-marking.cc Loading commit data...
test-embedder-tracing.cc Loading commit data...
test-external-string-tracker.cc Loading commit data...
test-heap.cc Loading commit data...
test-incremental-marking.cc Loading commit data...
test-invalidated-slots.cc Loading commit data...
test-iterators.cc Loading commit data...
test-lab.cc Loading commit data...
test-mark-compact.cc Loading commit data...
test-memory-measurement.cc Loading commit data...
test-page-promotion.cc Loading commit data...
test-shared-heap.cc Loading commit data...
test-spaces.cc Loading commit data...
test-unmapper.cc Loading commit data...
test-weak-references.cc Loading commit data...
test-write-barrier.cc Loading commit data...