Commit 70b838c1 authored by Dan Elphick's avatar Dan Elphick Committed by Commit Bot

[explicit isolates] Convert wasm/ to use ReadOnlyRoots

In future the RO_SPACE root accessors in Heap will become private, so
instead convert them all to use ReadOnlyRoots.

Bug: v8:7786
Change-Id: Ib3c45c1023d76bec5e1f4bc8f971062880b6c53f
Reviewed-on: https://chromium-review.googlesource.com/1126240Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
Commit-Queue: Dan Elphick <delphick@chromium.org>
Cr-Commit-Position: refs/heads/master@{#54221}
parent ce409375
...@@ -1041,7 +1041,7 @@ void WebAssemblyTableGrow(const v8::FunctionCallbackInfo<v8::Value>& args) { ...@@ -1041,7 +1041,7 @@ void WebAssemblyTableGrow(const v8::FunctionCallbackInfo<v8::Value>& args) {
i::Handle<i::FixedArray> new_array = i::Handle<i::FixedArray> new_array =
i_isolate->factory()->NewFixedArray(new_size); i_isolate->factory()->NewFixedArray(new_size);
for (int i = 0; i < old_size; ++i) new_array->set(i, old_array->get(i)); for (int i = 0; i < old_size; ++i) new_array->set(i, old_array->get(i));
i::Object* null = i_isolate->heap()->null_value(); i::Object* null = i::ReadOnlyRoots(i_isolate).null_value();
for (int i = old_size; i < new_size; ++i) new_array->set(i, null); for (int i = old_size; i < new_size; ++i) new_array->set(i, null);
receiver->set_functions(*new_array); receiver->set_functions(*new_array);
} }
......
...@@ -191,7 +191,7 @@ Handle<WasmModuleObject> WasmModuleObject::New( ...@@ -191,7 +191,7 @@ Handle<WasmModuleObject> WasmModuleObject::New(
} }
module_object->set_script(*script); module_object->set_script(*script);
module_object->set_weak_instance_list( module_object->set_weak_instance_list(
isolate->heap()->empty_weak_array_list()); ReadOnlyRoots(isolate).empty_weak_array_list());
if (!asm_js_offset_table.is_null()) { if (!asm_js_offset_table.is_null()) {
module_object->set_asm_js_offset_table(*asm_js_offset_table); module_object->set_asm_js_offset_table(*asm_js_offset_table);
} }
...@@ -724,7 +724,7 @@ Handle<WasmTableObject> WasmTableObject::New(Isolate* isolate, uint32_t initial, ...@@ -724,7 +724,7 @@ Handle<WasmTableObject> WasmTableObject::New(Isolate* isolate, uint32_t initial,
isolate->factory()->NewJSObject(table_ctor)); isolate->factory()->NewJSObject(table_ctor));
*js_functions = isolate->factory()->NewFixedArray(initial); *js_functions = isolate->factory()->NewFixedArray(initial);
Object* null = isolate->heap()->null_value(); Object* null = ReadOnlyRoots(isolate).null_value();
for (int i = 0; i < static_cast<int>(initial); ++i) { for (int i = 0; i < static_cast<int>(initial); ++i) {
(*js_functions)->set(i, null); (*js_functions)->set(i, null);
} }
...@@ -733,7 +733,7 @@ Handle<WasmTableObject> WasmTableObject::New(Isolate* isolate, uint32_t initial, ...@@ -733,7 +733,7 @@ Handle<WasmTableObject> WasmTableObject::New(Isolate* isolate, uint32_t initial,
Handle<Object> max = isolate->factory()->NewNumber(maximum); Handle<Object> max = isolate->factory()->NewNumber(maximum);
table_obj->set_maximum_length(*max); table_obj->set_maximum_length(*max);
table_obj->set_dispatch_tables(isolate->heap()->empty_fixed_array()); table_obj->set_dispatch_tables(ReadOnlyRoots(isolate).empty_fixed_array());
return Handle<WasmTableObject>::cast(table_obj); return Handle<WasmTableObject>::cast(table_obj);
} }
...@@ -790,7 +790,7 @@ void WasmTableObject::Set(Isolate* isolate, Handle<WasmTableObject> table, ...@@ -790,7 +790,7 @@ void WasmTableObject::Set(Isolate* isolate, Handle<WasmTableObject> table,
Handle<FixedArray> array(table->functions(), isolate); Handle<FixedArray> array(table->functions(), isolate);
if (function.is_null()) { if (function.is_null()) {
ClearDispatchTables(isolate, table, table_index); // Degenerate case. ClearDispatchTables(isolate, table, table_index); // Degenerate case.
array->set(table_index, isolate->heap()->null_value()); array->set(table_index, ReadOnlyRoots(isolate).null_value());
return; return;
} }
...@@ -1098,7 +1098,7 @@ void IndirectFunctionTableEntry::clear() { ...@@ -1098,7 +1098,7 @@ void IndirectFunctionTableEntry::clear() {
instance_->indirect_function_table_sig_ids()[index_] = -1; instance_->indirect_function_table_sig_ids()[index_] = -1;
instance_->indirect_function_table_targets()[index_] = 0; instance_->indirect_function_table_targets()[index_] = 0;
instance_->indirect_function_table_instances()->set( instance_->indirect_function_table_instances()->set(
index_, instance_->GetIsolate()->heap()->undefined_value()); index_, ReadOnlyRoots(instance_->GetIsolate()).undefined_value());
} }
void IndirectFunctionTableEntry::set(int sig_id, WasmInstanceObject* instance, void IndirectFunctionTableEntry::set(int sig_id, WasmInstanceObject* instance,
...@@ -1242,8 +1242,8 @@ Handle<WasmInstanceObject> WasmInstanceObject::New( ...@@ -1242,8 +1242,8 @@ Handle<WasmInstanceObject> WasmInstanceObject::New(
instance->set_indirect_function_table_targets(nullptr); instance->set_indirect_function_table_targets(nullptr);
instance->set_native_context(*isolate->native_context()); instance->set_native_context(*isolate->native_context());
instance->set_module_object(*module_object); instance->set_module_object(*module_object);
instance->set_undefined_value(isolate->heap()->undefined_value()); instance->set_undefined_value(ReadOnlyRoots(isolate).undefined_value());
instance->set_null_value(isolate->heap()->null_value()); instance->set_null_value(ReadOnlyRoots(isolate).null_value());
// Insert the new instance into the modules weak list of instances. // Insert the new instance into the modules weak list of instances.
// TODO(mstarzinger): Allow to reuse holes in the {WeakArrayList} below. // TODO(mstarzinger): Allow to reuse holes in the {WeakArrayList} below.
......
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