[handles] Improve node bounds allocation
Reserve node bounds upfront instead of growing the vector. Bug: v8:13372, chromium:1379837 Change-Id: Ibf2e9b984c476358f9f5cc7f11feeac620ae40ae Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3998817 Reviewed-by: Anton Bikineev <bikineev@chromium.org> Commit-Queue: Michael Lippautz <mlippautz@chromium.org> Cr-Commit-Position: refs/heads/main@{#84010}
This commit is contained in:
parent
2792a669e4
commit
c0dba826d8
@ -414,7 +414,7 @@ class TracedHandlesImpl final {
|
|||||||
void SetIsMarking(bool);
|
void SetIsMarking(bool);
|
||||||
void SetIsSweepingOnMutatorThread(bool);
|
void SetIsSweepingOnMutatorThread(bool);
|
||||||
|
|
||||||
TracedHandles::NodeBounds GetNodeBounds() const;
|
const TracedHandles::NodeBounds GetNodeBounds() const;
|
||||||
|
|
||||||
void UpdateListOfYoungNodes();
|
void UpdateListOfYoungNodes();
|
||||||
void ClearListOfYoungNodes();
|
void ClearListOfYoungNodes();
|
||||||
@ -592,8 +592,9 @@ void TracedHandlesImpl::SetIsSweepingOnMutatorThread(bool value) {
|
|||||||
is_sweeping_on_mutator_thread_ = value;
|
is_sweeping_on_mutator_thread_ = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
TracedHandles::NodeBounds TracedHandlesImpl::GetNodeBounds() const {
|
const TracedHandles::NodeBounds TracedHandlesImpl::GetNodeBounds() const {
|
||||||
TracedHandles::NodeBounds block_bounds;
|
TracedHandles::NodeBounds block_bounds;
|
||||||
|
block_bounds.reserve(blocks_.Size());
|
||||||
for (const auto* block : blocks_) {
|
for (const auto* block : blocks_) {
|
||||||
block_bounds.push_back(
|
block_bounds.push_back(
|
||||||
{block->nodes_begin_address(), block->nodes_end_address()});
|
{block->nodes_begin_address(), block->nodes_end_address()});
|
||||||
@ -765,7 +766,7 @@ void TracedHandles::SetIsSweepingOnMutatorThread(bool value) {
|
|||||||
impl_->SetIsSweepingOnMutatorThread(value);
|
impl_->SetIsSweepingOnMutatorThread(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
TracedHandles::NodeBounds TracedHandles::GetNodeBounds() const {
|
const TracedHandles::NodeBounds TracedHandles::GetNodeBounds() const {
|
||||||
return impl_->GetNodeBounds();
|
return impl_->GetNodeBounds();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ class V8_EXPORT_PRIVATE TracedHandles final {
|
|||||||
GlobalHandleStoreMode store_mode);
|
GlobalHandleStoreMode store_mode);
|
||||||
|
|
||||||
using NodeBounds = std::vector<std::pair<const void*, const void*>>;
|
using NodeBounds = std::vector<std::pair<const void*, const void*>>;
|
||||||
NodeBounds GetNodeBounds() const;
|
const NodeBounds GetNodeBounds() const;
|
||||||
|
|
||||||
void SetIsMarking(bool);
|
void SetIsMarking(bool);
|
||||||
void SetIsSweepingOnMutatorThread(bool);
|
void SetIsSweepingOnMutatorThread(bool);
|
||||||
|
@ -27,7 +27,7 @@ class GlobalHandleMarkingVisitor final : public ::heap::base::StackVisitor {
|
|||||||
Heap& heap_;
|
Heap& heap_;
|
||||||
MarkingState& marking_state_;
|
MarkingState& marking_state_;
|
||||||
MarkingWorklists::Local& local_marking_worklist_;
|
MarkingWorklists::Local& local_marking_worklist_;
|
||||||
TracedHandles::NodeBounds traced_node_bounds_;
|
const TracedHandles::NodeBounds traced_node_bounds_;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // V8_HEAP_GLOBAL_HANDLE_MARKING_VISITOR_H_
|
#endif // V8_HEAP_GLOBAL_HANDLE_MARKING_VISITOR_H_
|
||||||
|
Loading…
Reference in New Issue
Block a user