%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
// Copyright 2016 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/bytecode-liveness-map.h" namespace v8 { namespace internal { namespace compiler { BytecodeLiveness::BytecodeLiveness(int register_count, Zone* zone) : in(zone->New<BytecodeLivenessState>(register_count, zone)), out(zone->New<BytecodeLivenessState>(register_count, zone)) {} BytecodeLivenessMap::BytecodeLivenessMap(int bytecode_size, Zone* zone) : liveness_map_(base::bits::RoundUpToPowerOfTwo32(bytecode_size / 4 + 1), base::KeyEqualityMatcher<int>(), ZoneAllocationPolicy(zone)) {} uint32_t OffsetHash(int offset) { return offset; } BytecodeLiveness& BytecodeLivenessMap::InitializeLiveness(int offset, int register_count, Zone* zone) { return liveness_map_ .LookupOrInsert(offset, OffsetHash(offset), [&]() { return BytecodeLiveness(register_count, zone); }) ->value; } BytecodeLiveness& BytecodeLivenessMap::GetLiveness(int offset) { return liveness_map_.Lookup(offset, OffsetHash(offset))->value; } const BytecodeLiveness& BytecodeLivenessMap::GetLiveness(int offset) const { return liveness_map_.Lookup(offset, OffsetHash(offset))->value; } } // namespace compiler } // namespace internal } // namespace v8