Commit e3da3c67 authored by Peter Marshall's avatar Peter Marshall Committed by Commit Bot

[cleanup] Reduce binary size by removing macros in V8HeapExplorer.

This change saves 55 KiB binary size.

Bug: v8:8238
Change-Id: I01ba8ea7de2884f178577ba007496b35d8578acc
Reviewed-on: https://chromium-review.googlesource.com/1254122Reviewed-by: 's avatarYang Guo <yangguo@chromium.org>
Commit-Queue: Peter Marshall <petermarshall@chromium.org>
Cr-Commit-Position: refs/heads/master@{#56317}
parent f51e1d92
...@@ -1878,17 +1878,25 @@ void V8HeapExplorer::SetGcSubrootReference(Root root, const char* description, ...@@ -1878,17 +1878,25 @@ void V8HeapExplorer::SetGcSubrootReference(Root root, const char* description,
SetUserGlobalReference(global); SetUserGlobalReference(global);
} }
// This static array is used to prevent excessive code-size in
// GetStrongGcSubrootName below, which would happen if we called emplace() for
// every root in a macro.
static const char* root_names[] = {
#define ROOT_NAME(type, name, CamelName) #name,
READ_ONLY_ROOT_LIST(ROOT_NAME) MUTABLE_ROOT_LIST(ROOT_NAME)
#undef ROOT_NAME
};
STATIC_ASSERT(static_cast<uint16_t>(RootIndex::kRootListLength) ==
arraysize(root_names));
const char* V8HeapExplorer::GetStrongGcSubrootName(Object* object) { const char* V8HeapExplorer::GetStrongGcSubrootName(Object* object) {
ReadOnlyRoots roots(heap_);
if (strong_gc_subroot_names_.empty()) { if (strong_gc_subroot_names_.empty()) {
#define MUTABLE_ROOT_NAME(type, name, CamelName) \ for (uint16_t i = 0; i < static_cast<uint16_t>(RootIndex::kRootListLength);
strong_gc_subroot_names_.emplace(heap_->name(), #name); i++) {
#define RO_ROOT_NAME(type, name, CamelName) \ const char* name = root_names[i];
strong_gc_subroot_names_.emplace(roots.name(), #name); RootIndex index = static_cast<RootIndex>(i);
MUTABLE_ROOT_LIST(MUTABLE_ROOT_NAME) strong_gc_subroot_names_.emplace(heap_->root(index), name);
READ_ONLY_ROOT_LIST(RO_ROOT_NAME) }
#undef MUTABLE_ROOT_NAME
#undef RO_ROOT_NAME
CHECK(!strong_gc_subroot_names_.empty()); CHECK(!strong_gc_subroot_names_.empty());
} }
auto it = strong_gc_subroot_names_.find(object); auto it = strong_gc_subroot_names_.find(object);
......
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