Commit 1ca0eea2 authored by Mircea Trofin's avatar Mircea Trofin Committed by Commit Bot

[wasm] Correctly reconstitute ModuleEnv from runtime data

When lazy-compiling, it is important we reconstitute the
ModuleEnv accurately. Besides addressing a bug, this change
also does away with the need to relocate memory and globals
parameters (in lazy compilation), by using "the right ones" upfront.

Bug: chromium:753496
Change-Id: I1412a499f05d02d49319fced1b3047698328f3b5
Reviewed-on: https://chromium-review.googlesource.com/609376Reviewed-by: 's avatarBrad Nelson <bradnelson@chromium.org>
Commit-Queue: Brad Nelson <bradnelson@chromium.org>
Cr-Commit-Position: refs/heads/master@{#47280}
parent ef3ad19b
...@@ -221,6 +221,19 @@ ModuleEnv CreateModuleEnvFromRuntimeObject( ...@@ -221,6 +221,19 @@ ModuleEnv CreateModuleEnvFromRuntimeObject(
wasm::ModuleEnv module_env(compiled_module->module(), wasm::ModuleEnv module_env(compiled_module->module(),
BUILTIN_CODE(isolate, WasmCompileLazy)); BUILTIN_CODE(isolate, WasmCompileLazy));
// We set unchecked because the data on the compiled module
// is authoritative.
module_env.SetMemSizeUnchecked(compiled_module->has_embedded_mem_size()
? compiled_module->embedded_mem_size()
: 0);
module_env.set_mem_start(
reinterpret_cast<byte*>(compiled_module->has_embedded_mem_start()
? compiled_module->embedded_mem_start()
: 0));
module_env.set_globals_start(reinterpret_cast<byte*>(
compiled_module->has_globals_start() ? compiled_module->globals_start()
: 0));
DCHECK_EQ(compiled_module->has_function_tables(), DCHECK_EQ(compiled_module->has_function_tables(),
compiled_module->has_signature_tables()); compiled_module->has_signature_tables());
...@@ -1037,22 +1050,6 @@ void LazyCompilationOrchestrator::CompileFunction( ...@@ -1037,22 +1050,6 @@ void LazyCompilationOrchestrator::CompileFunction(
// Now specialize the generated code for this instance. // Now specialize the generated code for this instance.
Zone specialization_zone(isolate->allocator(), ZONE_NAME); Zone specialization_zone(isolate->allocator(), ZONE_NAME);
CodeSpecialization code_specialization(isolate, &specialization_zone); CodeSpecialization code_specialization(isolate, &specialization_zone);
if (module_env.module()->globals_size) {
Address globals_start =
reinterpret_cast<Address>(compiled_module->globals_start());
code_specialization.RelocateGlobals(module_env.globals_start(),
globals_start);
}
if (instance->has_memory_buffer()) {
Address mem_start =
reinterpret_cast<Address>(instance->memory_buffer()->backing_store());
int mem_size = instance->memory_buffer()->byte_length()->Number();
DCHECK_IMPLIES(mem_start == nullptr, mem_size == 0);
if (mem_start != nullptr) {
code_specialization.RelocateMemoryReferences(
module_env.mem_start(), module_env.mem_size(), mem_start, mem_size);
}
}
code_specialization.RelocateDirectCalls(instance); code_specialization.RelocateDirectCalls(instance);
code_specialization.ApplyToWasmCode(*code, SKIP_ICACHE_FLUSH); code_specialization.ApplyToWasmCode(*code, SKIP_ICACHE_FLUSH);
Assembler::FlushICache(isolate, code->instruction_start(), Assembler::FlushICache(isolate, code->instruction_start(),
......
// Copyright 2017 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.
function Module(stdlib, foreign, heap) {
"use asm";
var MEM64 = new stdlib.Float64Array(heap);
function foo(i) {
i = i | 0;
MEM64[032 ] = +(i >>> 7 ) / 2.;
return +MEM64[0];
}
return { foo: foo };
}
var foo = Module(this, {}, new ArrayBuffer( "" ? this : this)).foo;
assertEquals(NaN, foo(1));
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