8724b8d4fd
This change adds an infrastructure to "snapshot" data that is being serialized only once. This data lives in its own per-isolate zone, wrapped in a new CompilerData class. This change reduces the "serialize standard objects" on TypeScript benchmark from ~69ms to ~30ms (more than 50% improvement). Bug: v8:7790 Change-Id: I6ce4f6fb993334969662fdd993d681945a9f3727 Reviewed-on: https://chromium-review.googlesource.com/1238920 Commit-Queue: Maya Lekova <mslekova@chromium.org> Reviewed-by: Jaroslav Sevcik <jarin@chromium.org> Reviewed-by: Georg Neis <neis@chromium.org> Cr-Commit-Position: refs/heads/master@{#56309}
36 lines
1.2 KiB
C++
36 lines
1.2 KiB
C++
// Copyright 2018 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "src/compiler/refs-map.h"
|
|
|
|
namespace v8 {
|
|
namespace internal {
|
|
namespace compiler {
|
|
|
|
using UnderlyingMap =
|
|
base::TemplateHashMapImpl<Address, ObjectData*, AddressMatcher,
|
|
ZoneAllocationPolicy>;
|
|
|
|
RefsMap::RefsMap(uint32_t capacity, AddressMatcher match, Zone* zone)
|
|
: UnderlyingMap(capacity, match, ZoneAllocationPolicy(zone)) {}
|
|
|
|
RefsMap::RefsMap(const RefsMap* other, Zone* zone)
|
|
: UnderlyingMap(other, ZoneAllocationPolicy(zone)) {}
|
|
|
|
RefsMap::Entry* RefsMap::Lookup(const Address& key) const {
|
|
return UnderlyingMap::Lookup(key, Hash(key));
|
|
}
|
|
|
|
RefsMap::Entry* RefsMap::LookupOrInsert(const Address& key, Zone* zone) {
|
|
return UnderlyingMap::LookupOrInsert(key, RefsMap::Hash(key),
|
|
[]() { return nullptr; },
|
|
ZoneAllocationPolicy(zone));
|
|
}
|
|
|
|
uint32_t RefsMap::Hash(Address addr) { return static_cast<uint32_t>(addr); }
|
|
|
|
} // namespace compiler
|
|
} // namespace internal
|
|
} // namespace v8
|