Commit d10f4224 authored by bradnelson's avatar bradnelson Committed by Commit bot

Compile asm->wasm conversion at parse time.

Move compiltion of asm.js code to parse time.

BUG= https://bugs.chromium.org/p/v8/issues/detail?id=4203
TEST=asm-wasm
R=mtrofin@chromium.org
LOG=N

Review-Url: https://codereview.chromium.org/2141813002
Cr-Commit-Position: refs/heads/master@{#37695}
parent 974f4a80
...@@ -74,14 +74,14 @@ MaybeHandle<FixedArray> AsmJs::ConvertAsmToWasm(ParseInfo* info) { ...@@ -74,14 +74,14 @@ MaybeHandle<FixedArray> AsmJs::ConvertAsmToWasm(ParseInfo* info) {
info->literal(), &typer); info->literal(), &typer);
i::Handle<i::FixedArray> foreign_globals; i::Handle<i::FixedArray> foreign_globals;
auto module = builder.Run(&foreign_globals); auto module = builder.Run(&foreign_globals);
size_t byte_length = module->end() - module->begin();
Handle<JSArrayBuffer> buffer = info->isolate()->factory()->NewJSArrayBuffer(); i::MaybeHandle<i::FixedArray> compiled =
JSArrayBuffer::SetupAllocatingData(buffer, info->isolate(), byte_length, CompileModule(info->isolate(), module->begin(), module->end(), &thrower,
false, SharedFlag::kNotShared); internal::wasm::kAsmJsOrigin);
uint8_t* module_bytes = reinterpret_cast<uint8_t*>(buffer->backing_store()); DCHECK(!compiled.is_null());
memcpy(module_bytes, module->begin(), byte_length);
Handle<FixedArray> result = info->isolate()->factory()->NewFixedArray(2); Handle<FixedArray> result = info->isolate()->factory()->NewFixedArray(2);
result->set(0, *buffer); result->set(0, *compiled.ToHandleChecked());
result->set(1, *foreign_globals); result->set(1, *foreign_globals);
return result; return result;
} }
...@@ -90,27 +90,14 @@ MaybeHandle<Object> AsmJs::InstantiateAsmWasm(i::Isolate* isolate, ...@@ -90,27 +90,14 @@ MaybeHandle<Object> AsmJs::InstantiateAsmWasm(i::Isolate* isolate,
Handle<FixedArray> wasm_data, Handle<FixedArray> wasm_data,
Handle<JSArrayBuffer> memory, Handle<JSArrayBuffer> memory,
Handle<JSObject> foreign) { Handle<JSObject> foreign) {
i::Handle<i::JSArrayBuffer> module_bytes( i::Handle<i::FixedArray> compiled(i::FixedArray::cast(wasm_data->get(0)));
i::JSArrayBuffer::cast(wasm_data->get(0)));
i::Handle<i::FixedArray> foreign_globals( i::Handle<i::FixedArray> foreign_globals(
i::FixedArray::cast(wasm_data->get(1))); i::FixedArray::cast(wasm_data->get(1)));
ErrorThrower thrower(isolate, "Asm.js -> WebAssembly instantiation"); ErrorThrower thrower(isolate, "Asm.js -> WebAssembly instantiation");
const byte* module_start =
reinterpret_cast<const byte*>(module_bytes->backing_store());
size_t module_length =
static_cast<size_t>(module_bytes->byte_length()->Number());
const byte* module_end = module_start + module_length;
i::MaybeHandle<i::FixedArray> compiled =
CompileModule(isolate, module_start, module_end, &thrower,
internal::wasm::kAsmJsOrigin);
if (compiled.is_null()) {
return MaybeHandle<Object>();
}
i::MaybeHandle<i::JSObject> maybe_module_object = i::MaybeHandle<i::JSObject> maybe_module_object =
i::wasm::WasmModule::Instantiate(isolate, compiled.ToHandleChecked(), i::wasm::WasmModule::Instantiate(isolate, compiled, foreign, memory);
foreign, memory);
if (maybe_module_object.is_null()) { if (maybe_module_object.is_null()) {
return MaybeHandle<Object>(); return MaybeHandle<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