Commit c29c6a29 authored by yangguo's avatar yangguo Committed by Commit bot

[serializer] clean up root list items.

The first 32 root list items are a conscious choice in order for the
serializer to encode root references more efficiently.

R=hpayer@chromium.org

Review-Url: https://codereview.chromium.org/2458603002
Cr-Commit-Position: refs/heads/master@{#40630}
parent b7dae10e
...@@ -48,8 +48,6 @@ using v8::MemoryPressureLevel; ...@@ -48,8 +48,6 @@ using v8::MemoryPressureLevel;
V(Map, one_byte_string_map, OneByteStringMap) \ V(Map, one_byte_string_map, OneByteStringMap) \
V(Map, one_byte_internalized_string_map, OneByteInternalizedStringMap) \ V(Map, one_byte_internalized_string_map, OneByteInternalizedStringMap) \
V(Map, scope_info_map, ScopeInfoMap) \ V(Map, scope_info_map, ScopeInfoMap) \
V(Map, module_info_entry_map, ModuleInfoEntryMap) \
V(Map, module_info_map, ModuleInfoMap) \
V(Map, shared_function_info_map, SharedFunctionInfoMap) \ V(Map, shared_function_info_map, SharedFunctionInfoMap) \
V(Map, code_map, CodeMap) \ V(Map, code_map, CodeMap) \
V(Map, function_context_map, FunctionContextMap) \ V(Map, function_context_map, FunctionContextMap) \
...@@ -62,7 +60,6 @@ using v8::MemoryPressureLevel; ...@@ -62,7 +60,6 @@ using v8::MemoryPressureLevel;
V(FixedArray, empty_literals_array, EmptyLiteralsArray) \ V(FixedArray, empty_literals_array, EmptyLiteralsArray) \
V(FixedArray, empty_type_feedback_vector, EmptyTypeFeedbackVector) \ V(FixedArray, empty_type_feedback_vector, EmptyTypeFeedbackVector) \
V(FixedArray, empty_fixed_array, EmptyFixedArray) \ V(FixedArray, empty_fixed_array, EmptyFixedArray) \
V(ScopeInfo, empty_scope_info, EmptyScopeInfo) \
V(DescriptorArray, empty_descriptor_array, EmptyDescriptorArray) \ V(DescriptorArray, empty_descriptor_array, EmptyDescriptorArray) \
/* Entries beyond the first 32 */ \ /* Entries beyond the first 32 */ \
/* The roots above this line should be boring from a GC point of view. */ \ /* The roots above this line should be boring from a GC point of view. */ \
...@@ -93,6 +90,8 @@ using v8::MemoryPressureLevel; ...@@ -93,6 +90,8 @@ using v8::MemoryPressureLevel;
V(Map, message_object_map, JSMessageObjectMap) \ V(Map, message_object_map, JSMessageObjectMap) \
V(Map, external_map, ExternalMap) \ V(Map, external_map, ExternalMap) \
V(Map, bytecode_array_map, BytecodeArrayMap) \ V(Map, bytecode_array_map, BytecodeArrayMap) \
V(Map, module_info_entry_map, ModuleInfoEntryMap) \
V(Map, module_info_map, ModuleInfoMap) \
/* String maps */ \ /* String maps */ \
V(Map, native_source_string_map, NativeSourceStringMap) \ V(Map, native_source_string_map, NativeSourceStringMap) \
V(Map, string_map, StringMap) \ V(Map, string_map, StringMap) \
...@@ -141,6 +140,7 @@ using v8::MemoryPressureLevel; ...@@ -141,6 +140,7 @@ using v8::MemoryPressureLevel;
V(Map, uint8x16_map, Uint8x16Map) \ V(Map, uint8x16_map, Uint8x16Map) \
V(Map, bool8x16_map, Bool8x16Map) \ V(Map, bool8x16_map, Bool8x16Map) \
/* Canonical empty values */ \ /* Canonical empty values */ \
V(ScopeInfo, empty_scope_info, EmptyScopeInfo) \
V(ByteArray, empty_byte_array, EmptyByteArray) \ V(ByteArray, empty_byte_array, EmptyByteArray) \
V(FixedTypedArrayBase, empty_fixed_uint8_array, EmptyFixedUint8Array) \ V(FixedTypedArrayBase, empty_fixed_uint8_array, EmptyFixedUint8Array) \
V(FixedTypedArrayBase, empty_fixed_int8_array, EmptyFixedInt8Array) \ V(FixedTypedArrayBase, empty_fixed_int8_array, EmptyFixedInt8Array) \
......
...@@ -212,6 +212,11 @@ void Serializer::PutRoot(int root_index, HeapObject* object, ...@@ -212,6 +212,11 @@ void Serializer::PutRoot(int root_index, HeapObject* object,
PrintF("\n"); PrintF("\n");
} }
// Assert that the first 32 root array items are a conscious choice. They are
// chosen so that the most common ones can be encoded more efficiently.
STATIC_ASSERT(Heap::kEmptyDescriptorArrayRootIndex ==
kNumberOfRootArrayConstants - 1);
if (how_to_code == kPlain && where_to_point == kStartOfObject && if (how_to_code == kPlain && where_to_point == kStartOfObject &&
root_index < kNumberOfRootArrayConstants && root_index < kNumberOfRootArrayConstants &&
!isolate()->heap()->InNewSpace(object)) { !isolate()->heap()->InNewSpace(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