Commit 9c362b00 authored by Michael Lippautz's avatar Michael Lippautz Committed by Commit Bot

cppgc: Various cleanups

- Cleanup includes, fix typo, fix qualifiers.
- Fix getter names of MarkerBase when only exposed for testing.

Bug: chromium:1056170
Change-Id: Ibcb0f62414c9c865fa98e6d2b2c9b150aa2a361f
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2281004
Commit-Queue: Omer Katz <omerkatz@chromium.org>
Reviewed-by: 's avatarOmer Katz <omerkatz@chromium.org>
Auto-Submit: Michael Lippautz <mlippautz@chromium.org>
Cr-Commit-Position: refs/heads/master@{#68678}
parent 2e895c13
...@@ -177,7 +177,7 @@ class GarbageCollectedMixin : public internal::GarbageCollectedBase { ...@@ -177,7 +177,7 @@ class GarbageCollectedMixin : public internal::GarbageCollectedBase {
#define MERGE_GARBAGE_COLLECTED_MIXINS() \ #define MERGE_GARBAGE_COLLECTED_MIXINS() \
public: \ public: \
/* When using multiple mixins the methods become */ \ /* When using multiple mixins the methods become */ \
/* ambigous. Providing additional implementations */ \ /* ambiguous. Providing additional implementations */ \
/* disambiguate them again. */ \ /* disambiguate them again. */ \
TraceDescriptor GetTraceDescriptor() const override { \ TraceDescriptor GetTraceDescriptor() const override { \
return {kNotFullyConstructedObject, nullptr}; \ return {kNotFullyConstructedObject, nullptr}; \
......
...@@ -82,8 +82,9 @@ class UnifiedHeapMarker : public cppgc::internal::MarkerBase { ...@@ -82,8 +82,9 @@ class UnifiedHeapMarker : public cppgc::internal::MarkerBase {
UnifiedHeapMarker::UnifiedHeapMarker(cppgc::internal::HeapBase& heap) UnifiedHeapMarker::UnifiedHeapMarker(cppgc::internal::HeapBase& heap)
: cppgc::internal::MarkerBase(heap), : cppgc::internal::MarkerBase(heap),
marking_visitor_(heap, marking_state()), marking_visitor_(heap, mutator_marking_state_),
conservative_marking_visitor_(heap, marking_state(), marking_visitor_) {} conservative_marking_visitor_(heap, mutator_marking_state_,
marking_visitor_) {}
void UnifiedHeapMarker::AddObject(void* object) { void UnifiedHeapMarker::AddObject(void* object) {
mutator_marking_state_.MarkAndPush( mutator_marking_state_.MarkAndPush(
......
...@@ -259,8 +259,9 @@ void MarkerBase::ClearAllWorklistsForTesting() { ...@@ -259,8 +259,9 @@ void MarkerBase::ClearAllWorklistsForTesting() {
Marker::Marker(HeapBase& heap) Marker::Marker(HeapBase& heap)
: MarkerBase(heap), : MarkerBase(heap),
marking_visitor_(heap, marking_state()), marking_visitor_(heap, mutator_marking_state_),
conservative_marking_visitor_(heap, marking_state(), marking_visitor_) {} conservative_marking_visitor_(heap, mutator_marking_state_,
marking_visitor_) {}
} // namespace internal } // namespace internal
} // namespace cppgc } // namespace cppgc
...@@ -8,10 +8,10 @@ ...@@ -8,10 +8,10 @@
#include <memory> #include <memory>
#include "include/cppgc/heap.h" #include "include/cppgc/heap.h"
#include "include/cppgc/trace-trait.h"
#include "include/cppgc/visitor.h" #include "include/cppgc/visitor.h"
#include "src/base/macros.h" #include "src/base/macros.h"
#include "src/base/platform/time.h" #include "src/base/platform/time.h"
#include "src/heap/cppgc/globals.h"
#include "src/heap/cppgc/marking-state.h" #include "src/heap/cppgc/marking-state.h"
#include "src/heap/cppgc/marking-visitor.h" #include "src/heap/cppgc/marking-visitor.h"
#include "src/heap/cppgc/marking-worklists.h" #include "src/heap/cppgc/marking-worklists.h"
...@@ -82,10 +82,13 @@ class V8_EXPORT_PRIVATE MarkerBase { ...@@ -82,10 +82,13 @@ class V8_EXPORT_PRIVATE MarkerBase {
void ProcessWeakness(); void ProcessWeakness();
inline void WriteBarrierForInConstructionObject(ConstAddress);
inline void WriteBarrierForObject(HeapObjectHeader&);
HeapBase& heap() { return heap_; } HeapBase& heap() { return heap_; }
MarkingState& marking_state() { return mutator_marking_state_; }
MarkingWorklists& marking_worklists() { return marking_worklists_; }
MarkingWorklists& MarkingWorklistsForTesting() { return marking_worklists_; }
MarkingState& MarkingStateForTesting() { return mutator_marking_state_; }
cppgc::Visitor& VisitorForTesting() { return visitor(); } cppgc::Visitor& VisitorForTesting() { return visitor(); }
void ClearAllWorklistsForTesting(); void ClearAllWorklistsForTesting();
...@@ -125,6 +128,21 @@ class V8_EXPORT_PRIVATE Marker final : public MarkerBase { ...@@ -125,6 +128,21 @@ class V8_EXPORT_PRIVATE Marker final : public MarkerBase {
ConservativeMarkingVisitor conservative_marking_visitor_; ConservativeMarkingVisitor conservative_marking_visitor_;
}; };
void MarkerBase::WriteBarrierForInConstructionObject(ConstAddress payload) {
MarkingWorklists::NotFullyConstructedWorklist::View
not_fully_constructed_worklist(
marking_worklists_.not_fully_constructed_worklist(),
MarkingWorklists::kMutatorThreadId);
not_fully_constructed_worklist.Push(payload);
}
void MarkerBase::WriteBarrierForObject(HeapObjectHeader& header) {
MarkingWorklists::WriteBarrierWorklist::View write_barrier_worklist(
marking_worklists_.write_barrier_worklist(),
MarkingWorklists::kMutatorThreadId);
write_barrier_worklist.Push(&header);
}
} // namespace internal } // namespace internal
} // namespace cppgc } // namespace cppgc
......
...@@ -4,11 +4,7 @@ ...@@ -4,11 +4,7 @@
#include "src/heap/cppgc/marking-visitor.h" #include "src/heap/cppgc/marking-visitor.h"
#include "include/cppgc/garbage-collected.h"
#include "src/heap/cppgc/heap-object-header.h"
#include "src/heap/cppgc/heap-page.h"
#include "src/heap/cppgc/heap.h" #include "src/heap/cppgc/heap.h"
#include "src/heap/cppgc/liveness-broker.h"
#include "src/heap/cppgc/marking-state.h" #include "src/heap/cppgc/marking-state.h"
namespace cppgc { namespace cppgc {
...@@ -60,8 +56,5 @@ void ConservativeMarkingVisitor::VisitPointer(const void* address) { ...@@ -60,8 +56,5 @@ void ConservativeMarkingVisitor::VisitPointer(const void* address) {
TraceConservativelyIfNeeded(address); TraceConservativelyIfNeeded(address);
} }
MutatorThreadMarkingVisitor::MutatorThreadMarkingVisitor(Marker* marker)
: MarkingVisitor(marker->heap(), marker->marking_state()) {}
} // namespace internal } // namespace internal
} // namespace cppgc } // namespace cppgc
...@@ -18,7 +18,7 @@ class HeapObjectHeader; ...@@ -18,7 +18,7 @@ class HeapObjectHeader;
class Marker; class Marker;
class MarkingState; class MarkingState;
class MarkingVisitor : public VisitorBase { class V8_EXPORT_PRIVATE MarkingVisitor : public VisitorBase {
public: public:
MarkingVisitor(HeapBase&, MarkingState&); MarkingVisitor(HeapBase&, MarkingState&);
~MarkingVisitor() override = default; ~MarkingVisitor() override = default;
...@@ -43,16 +43,11 @@ class ConservativeMarkingVisitor : public ConservativeTracingVisitor, ...@@ -43,16 +43,11 @@ class ConservativeMarkingVisitor : public ConservativeTracingVisitor,
private: private:
void VisitConservatively(HeapObjectHeader&, void VisitConservatively(HeapObjectHeader&,
TraceConservativelyCallback) final; TraceConservativelyCallback) final;
void VisitPointer(const void*) override; void VisitPointer(const void*) final;
MarkingState& marking_state_; MarkingState& marking_state_;
}; };
class V8_EXPORT_PRIVATE MutatorThreadMarkingVisitor : public MarkingVisitor {
public:
explicit MutatorThreadMarkingVisitor(Marker*);
};
} // namespace internal } // namespace internal
} // namespace cppgc } // namespace cppgc
......
...@@ -40,18 +40,11 @@ void MarkValue(const BasePage* page, MarkerBase* marker, const void* value) { ...@@ -40,18 +40,11 @@ void MarkValue(const BasePage* page, MarkerBase* marker, const void* value) {
// It is assumed that objects on not_fully_constructed_worklist_ are not // It is assumed that objects on not_fully_constructed_worklist_ are not
// marked. // marked.
header.Unmark(); header.Unmark();
MarkingWorklists::NotFullyConstructedWorklist::View marker->WriteBarrierForInConstructionObject(header.Payload());
not_fully_constructed_worklist(
marker->marking_worklists().not_fully_constructed_worklist(),
MarkingWorklists::kMutatorThreadId);
not_fully_constructed_worklist.Push(header.Payload());
return; return;
} }
MarkingWorklists::WriteBarrierWorklist::View write_barrier_worklist( marker->WriteBarrierForObject(header);
marker->marking_worklists().write_barrier_worklist(),
MarkingWorklists::kMutatorThreadId);
write_barrier_worklist.Push(&header);
} }
} // namespace } // namespace
......
...@@ -24,7 +24,7 @@ class MarkingVisitorTest : public testing::TestWithHeap { ...@@ -24,7 +24,7 @@ class MarkingVisitorTest : public testing::TestWithHeap {
public: public:
MarkingVisitorTest() MarkingVisitorTest()
: marker_(std::make_unique<Marker>(Heap::From(GetHeap())->AsBase())) {} : marker_(std::make_unique<Marker>(Heap::From(GetHeap())->AsBase())) {}
~MarkingVisitorTest() { marker_->ClearAllWorklistsForTesting(); } ~MarkingVisitorTest() override { marker_->ClearAllWorklistsForTesting(); }
Marker* GetMarker() { return marker_.get(); } Marker* GetMarker() { return marker_.get(); }
...@@ -45,10 +45,16 @@ class GCedWithMixin : public GarbageCollected<GCedWithMixin>, public Mixin { ...@@ -45,10 +45,16 @@ class GCedWithMixin : public GarbageCollected<GCedWithMixin>, public Mixin {
void Trace(cppgc::Visitor*) const override {} void Trace(cppgc::Visitor*) const override {}
}; };
class TestMarkingVisitor : public MarkingVisitor {
public:
explicit TestMarkingVisitor(Marker* marker)
: MarkingVisitor(marker->heap(), marker->MarkingStateForTesting()) {}
};
} // namespace } // namespace
TEST_F(MarkingVisitorTest, MarkedBytesAreInitiallyZero) { TEST_F(MarkingVisitorTest, MarkedBytesAreInitiallyZero) {
EXPECT_EQ(0u, GetMarker()->marking_state().marked_bytes()); EXPECT_EQ(0u, GetMarker()->MarkingStateForTesting().marked_bytes());
} }
// Strong references are marked. // Strong references are marked.
...@@ -57,7 +63,7 @@ TEST_F(MarkingVisitorTest, MarkMember) { ...@@ -57,7 +63,7 @@ TEST_F(MarkingVisitorTest, MarkMember) {
Member<GCed> object(MakeGarbageCollected<GCed>(GetAllocationHandle())); Member<GCed> object(MakeGarbageCollected<GCed>(GetAllocationHandle()));
HeapObjectHeader& header = HeapObjectHeader::FromPayload(object); HeapObjectHeader& header = HeapObjectHeader::FromPayload(object);
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
EXPECT_FALSE(header.IsMarked()); EXPECT_FALSE(header.IsMarked());
...@@ -72,7 +78,7 @@ TEST_F(MarkingVisitorTest, MarkMemberMixin) { ...@@ -72,7 +78,7 @@ TEST_F(MarkingVisitorTest, MarkMemberMixin) {
Member<Mixin> mixin(object); Member<Mixin> mixin(object);
HeapObjectHeader& header = HeapObjectHeader::FromPayload(object); HeapObjectHeader& header = HeapObjectHeader::FromPayload(object);
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
EXPECT_FALSE(header.IsMarked()); EXPECT_FALSE(header.IsMarked());
...@@ -85,7 +91,7 @@ TEST_F(MarkingVisitorTest, MarkPersistent) { ...@@ -85,7 +91,7 @@ TEST_F(MarkingVisitorTest, MarkPersistent) {
Persistent<GCed> object(MakeGarbageCollected<GCed>(GetAllocationHandle())); Persistent<GCed> object(MakeGarbageCollected<GCed>(GetAllocationHandle()));
HeapObjectHeader& header = HeapObjectHeader::FromPayload(object); HeapObjectHeader& header = HeapObjectHeader::FromPayload(object);
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
EXPECT_FALSE(header.IsMarked()); EXPECT_FALSE(header.IsMarked());
...@@ -100,7 +106,7 @@ TEST_F(MarkingVisitorTest, MarkPersistentMixin) { ...@@ -100,7 +106,7 @@ TEST_F(MarkingVisitorTest, MarkPersistentMixin) {
Persistent<Mixin> mixin(object); Persistent<Mixin> mixin(object);
HeapObjectHeader& header = HeapObjectHeader::FromPayload(object); HeapObjectHeader& header = HeapObjectHeader::FromPayload(object);
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
EXPECT_FALSE(header.IsMarked()); EXPECT_FALSE(header.IsMarked());
...@@ -115,7 +121,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakMember) { ...@@ -115,7 +121,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakMember) {
WeakMember<GCed> object(MakeGarbageCollected<GCed>(GetAllocationHandle())); WeakMember<GCed> object(MakeGarbageCollected<GCed>(GetAllocationHandle()));
HeapObjectHeader& header = HeapObjectHeader::FromPayload(object); HeapObjectHeader& header = HeapObjectHeader::FromPayload(object);
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
EXPECT_FALSE(header.IsMarked()); EXPECT_FALSE(header.IsMarked());
...@@ -130,7 +136,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakMemberMixin) { ...@@ -130,7 +136,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakMemberMixin) {
WeakMember<Mixin> mixin(object); WeakMember<Mixin> mixin(object);
HeapObjectHeader& header = HeapObjectHeader::FromPayload(object); HeapObjectHeader& header = HeapObjectHeader::FromPayload(object);
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
EXPECT_FALSE(header.IsMarked()); EXPECT_FALSE(header.IsMarked());
...@@ -144,7 +150,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakPersistent) { ...@@ -144,7 +150,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakPersistent) {
MakeGarbageCollected<GCed>(GetAllocationHandle())); MakeGarbageCollected<GCed>(GetAllocationHandle()));
HeapObjectHeader& header = HeapObjectHeader::FromPayload(object); HeapObjectHeader& header = HeapObjectHeader::FromPayload(object);
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
EXPECT_FALSE(header.IsMarked()); EXPECT_FALSE(header.IsMarked());
...@@ -159,7 +165,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakPersistentMixin) { ...@@ -159,7 +165,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakPersistentMixin) {
WeakPersistent<Mixin> mixin(object); WeakPersistent<Mixin> mixin(object);
HeapObjectHeader& header = HeapObjectHeader::FromPayload(object); HeapObjectHeader& header = HeapObjectHeader::FromPayload(object);
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
EXPECT_FALSE(header.IsMarked()); EXPECT_FALSE(header.IsMarked());
...@@ -204,7 +210,7 @@ class GCedWithMixinWithInConstructionCallback ...@@ -204,7 +210,7 @@ class GCedWithMixinWithInConstructionCallback
} // namespace } // namespace
TEST_F(MarkingVisitorTest, DontMarkMemberInConstruction) { TEST_F(MarkingVisitorTest, DontMarkMemberInConstruction) {
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
GCedWithInConstructionCallback* gced = GCedWithInConstructionCallback* gced =
MakeGarbageCollected<GCedWithInConstructionCallback>( MakeGarbageCollected<GCedWithInConstructionCallback>(
GetAllocationHandle(), GetAllocationHandle(),
...@@ -216,7 +222,7 @@ TEST_F(MarkingVisitorTest, DontMarkMemberInConstruction) { ...@@ -216,7 +222,7 @@ TEST_F(MarkingVisitorTest, DontMarkMemberInConstruction) {
} }
TEST_F(MarkingVisitorTest, DontMarkMemberMixinInConstruction) { TEST_F(MarkingVisitorTest, DontMarkMemberMixinInConstruction) {
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
GCedWithMixinWithInConstructionCallback* gced = GCedWithMixinWithInConstructionCallback* gced =
MakeGarbageCollected<GCedWithMixinWithInConstructionCallback>( MakeGarbageCollected<GCedWithMixinWithInConstructionCallback>(
GetAllocationHandle(), GetAllocationHandle(),
...@@ -228,7 +234,7 @@ TEST_F(MarkingVisitorTest, DontMarkMemberMixinInConstruction) { ...@@ -228,7 +234,7 @@ TEST_F(MarkingVisitorTest, DontMarkMemberMixinInConstruction) {
} }
TEST_F(MarkingVisitorTest, DontMarkWeakMemberInConstruction) { TEST_F(MarkingVisitorTest, DontMarkWeakMemberInConstruction) {
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
GCedWithInConstructionCallback* gced = GCedWithInConstructionCallback* gced =
MakeGarbageCollected<GCedWithInConstructionCallback>( MakeGarbageCollected<GCedWithInConstructionCallback>(
GetAllocationHandle(), GetAllocationHandle(),
...@@ -240,7 +246,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakMemberInConstruction) { ...@@ -240,7 +246,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakMemberInConstruction) {
} }
TEST_F(MarkingVisitorTest, DontMarkWeakMemberMixinInConstruction) { TEST_F(MarkingVisitorTest, DontMarkWeakMemberMixinInConstruction) {
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
GCedWithMixinWithInConstructionCallback* gced = GCedWithMixinWithInConstructionCallback* gced =
MakeGarbageCollected<GCedWithMixinWithInConstructionCallback>( MakeGarbageCollected<GCedWithMixinWithInConstructionCallback>(
GetAllocationHandle(), GetAllocationHandle(),
...@@ -252,7 +258,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakMemberMixinInConstruction) { ...@@ -252,7 +258,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakMemberMixinInConstruction) {
} }
TEST_F(MarkingVisitorTest, DontMarkPersistentInConstruction) { TEST_F(MarkingVisitorTest, DontMarkPersistentInConstruction) {
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
GCedWithInConstructionCallback* gced = GCedWithInConstructionCallback* gced =
MakeGarbageCollected<GCedWithInConstructionCallback>( MakeGarbageCollected<GCedWithInConstructionCallback>(
GetAllocationHandle(), GetAllocationHandle(),
...@@ -264,7 +270,7 @@ TEST_F(MarkingVisitorTest, DontMarkPersistentInConstruction) { ...@@ -264,7 +270,7 @@ TEST_F(MarkingVisitorTest, DontMarkPersistentInConstruction) {
} }
TEST_F(MarkingVisitorTest, DontMarkPersistentMixinInConstruction) { TEST_F(MarkingVisitorTest, DontMarkPersistentMixinInConstruction) {
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
GCedWithMixinWithInConstructionCallback* gced = GCedWithMixinWithInConstructionCallback* gced =
MakeGarbageCollected<GCedWithMixinWithInConstructionCallback>( MakeGarbageCollected<GCedWithMixinWithInConstructionCallback>(
GetAllocationHandle(), GetAllocationHandle(),
...@@ -276,7 +282,7 @@ TEST_F(MarkingVisitorTest, DontMarkPersistentMixinInConstruction) { ...@@ -276,7 +282,7 @@ TEST_F(MarkingVisitorTest, DontMarkPersistentMixinInConstruction) {
} }
TEST_F(MarkingVisitorTest, DontMarkWeakPersistentInConstruction) { TEST_F(MarkingVisitorTest, DontMarkWeakPersistentInConstruction) {
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
GCedWithInConstructionCallback* gced = GCedWithInConstructionCallback* gced =
MakeGarbageCollected<GCedWithInConstructionCallback>( MakeGarbageCollected<GCedWithInConstructionCallback>(
GetAllocationHandle(), GetAllocationHandle(),
...@@ -288,7 +294,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakPersistentInConstruction) { ...@@ -288,7 +294,7 @@ TEST_F(MarkingVisitorTest, DontMarkWeakPersistentInConstruction) {
} }
TEST_F(MarkingVisitorTest, DontMarkWeakPersistentMixinInConstruction) { TEST_F(MarkingVisitorTest, DontMarkWeakPersistentMixinInConstruction) {
MutatorThreadMarkingVisitor visitor(GetMarker()); TestMarkingVisitor visitor(GetMarker());
GCedWithMixinWithInConstructionCallback* gced = GCedWithMixinWithInConstructionCallback* gced =
MakeGarbageCollected<GCedWithMixinWithInConstructionCallback>( MakeGarbageCollected<GCedWithMixinWithInConstructionCallback>(
GetAllocationHandle(), GetAllocationHandle(),
......
...@@ -45,10 +45,11 @@ class ExpectWriteBarrierFires final : private IncrementalMarkingScope { ...@@ -45,10 +45,11 @@ class ExpectWriteBarrierFires final : private IncrementalMarkingScope {
ExpectWriteBarrierFires(MarkerBase* marker, ExpectWriteBarrierFires(MarkerBase* marker,
std::initializer_list<void*> objects) std::initializer_list<void*> objects)
: IncrementalMarkingScope(marker), : IncrementalMarkingScope(marker),
marking_worklist_(marker->marking_worklists().marking_worklist(), marking_worklist_(
marker->MarkingWorklistsForTesting().marking_worklist(),
MarkingWorklists::kMutatorThreadId), MarkingWorklists::kMutatorThreadId),
write_barrier_worklist_( write_barrier_worklist_(
marker->marking_worklists().write_barrier_worklist(), marker->MarkingWorklistsForTesting().write_barrier_worklist(),
MarkingWorklists::kMutatorThreadId), MarkingWorklists::kMutatorThreadId),
objects_(objects) { objects_(objects) {
EXPECT_TRUE(marking_worklist_.IsGlobalPoolEmpty()); EXPECT_TRUE(marking_worklist_.IsGlobalPoolEmpty());
...@@ -96,10 +97,11 @@ class ExpectNoWriteBarrierFires final : private IncrementalMarkingScope { ...@@ -96,10 +97,11 @@ class ExpectNoWriteBarrierFires final : private IncrementalMarkingScope {
ExpectNoWriteBarrierFires(MarkerBase* marker, ExpectNoWriteBarrierFires(MarkerBase* marker,
std::initializer_list<void*> objects) std::initializer_list<void*> objects)
: IncrementalMarkingScope(marker), : IncrementalMarkingScope(marker),
marking_worklist_(marker->marking_worklists().marking_worklist(), marking_worklist_(
marker->MarkingWorklistsForTesting().marking_worklist(),
MarkingWorklists::kMutatorThreadId), MarkingWorklists::kMutatorThreadId),
write_barrier_worklist_( write_barrier_worklist_(
marker->marking_worklists().write_barrier_worklist(), marker->MarkingWorklistsForTesting().write_barrier_worklist(),
MarkingWorklists::kMutatorThreadId) { MarkingWorklists::kMutatorThreadId) {
EXPECT_TRUE(marking_worklist_.IsGlobalPoolEmpty()); EXPECT_TRUE(marking_worklist_.IsGlobalPoolEmpty());
EXPECT_TRUE(write_barrier_worklist_.IsGlobalPoolEmpty()); EXPECT_TRUE(write_barrier_worklist_.IsGlobalPoolEmpty());
......
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