Commit d75e327d authored by Michael Starzinger's avatar Michael Starzinger Committed by Commit Bot

[wasm] Hide code copying from Wasm compiler interface.

This refactoring hides the fact that some wrappers are first generated
in the GC'ed heap and then copied into the native module. It is a first
step towards avoiding the redundant copy.

R=clemensh@chromium.org

Change-Id: I531fa42e8b4c210948d306624007348a39b981e0
Reviewed-on: https://chromium-review.googlesource.com/c/1333673
Commit-Queue: Michael Starzinger <mstarzinger@chromium.org>
Reviewed-by: 's avatarClemens Hammacher <clemensh@chromium.org>
Cr-Commit-Position: refs/heads/master@{#57477}
parent 1ed5214c
...@@ -5031,10 +5031,11 @@ WasmImportCallKind GetWasmImportCallKind(Handle<JSReceiver> target, ...@@ -5031,10 +5031,11 @@ WasmImportCallKind GetWasmImportCallKind(Handle<JSReceiver> target,
return WasmImportCallKind::kUseCallBuiltin; return WasmImportCallKind::kUseCallBuiltin;
} }
MaybeHandle<Code> CompileWasmImportCallWrapper(Isolate* isolate, wasm::WasmCode* CompileWasmImportCallWrapper(Isolate* isolate,
WasmImportCallKind kind, wasm::NativeModule* native_module,
wasm::FunctionSig* sig, WasmImportCallKind kind,
bool source_positions) { wasm::FunctionSig* sig,
bool source_positions) {
DCHECK_NE(WasmImportCallKind::kLinkError, kind); DCHECK_NE(WasmImportCallKind::kLinkError, kind);
DCHECK_NE(WasmImportCallKind::kWasmToWasm, kind); DCHECK_NE(WasmImportCallKind::kWasmToWasm, kind);
...@@ -5080,10 +5081,7 @@ MaybeHandle<Code> CompileWasmImportCallWrapper(Isolate* isolate, ...@@ -5080,10 +5081,7 @@ MaybeHandle<Code> CompileWasmImportCallWrapper(Isolate* isolate,
MaybeHandle<Code> maybe_code = Pipeline::GenerateCodeForWasmStub( MaybeHandle<Code> maybe_code = Pipeline::GenerateCodeForWasmStub(
isolate, incoming, &graph, Code::WASM_TO_JS_FUNCTION, func_name, isolate, incoming, &graph, Code::WASM_TO_JS_FUNCTION, func_name,
AssemblerOptions::Default(isolate), source_position_table); AssemblerOptions::Default(isolate), source_position_table);
Handle<Code> code; Handle<Code> code = maybe_code.ToHandleChecked();
if (!maybe_code.ToHandle(&code)) {
return maybe_code;
}
#ifdef ENABLE_DISASSEMBLER #ifdef ENABLE_DISASSEMBLER
if (FLAG_print_opt_code) { if (FLAG_print_opt_code) {
CodeTracer::Scope tracing_scope(isolate->GetCodeTracer()); CodeTracer::Scope tracing_scope(isolate->GetCodeTracer());
...@@ -5097,12 +5095,16 @@ MaybeHandle<Code> CompileWasmImportCallWrapper(Isolate* isolate, ...@@ -5097,12 +5095,16 @@ MaybeHandle<Code> CompileWasmImportCallWrapper(Isolate* isolate,
func_name); func_name);
} }
return code; // TODO(wasm): No need to compile the code onto the heap and copy back.
wasm::WasmCode* wasm_code = native_module->AddImportCallWrapper(code);
return wasm_code;
} }
MaybeHandle<Code> CompileWasmInterpreterEntry(Isolate* isolate, wasm::WasmCode* CompileWasmInterpreterEntry(Isolate* isolate,
uint32_t func_index, wasm::NativeModule* native_module,
wasm::FunctionSig* sig) { uint32_t func_index,
wasm::FunctionSig* sig) {
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
// Create the Graph // Create the Graph
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
...@@ -5137,10 +5139,7 @@ MaybeHandle<Code> CompileWasmInterpreterEntry(Isolate* isolate, ...@@ -5137,10 +5139,7 @@ MaybeHandle<Code> CompileWasmInterpreterEntry(Isolate* isolate,
MaybeHandle<Code> maybe_code = Pipeline::GenerateCodeForWasmStub( MaybeHandle<Code> maybe_code = Pipeline::GenerateCodeForWasmStub(
isolate, incoming, &graph, Code::WASM_INTERPRETER_ENTRY, isolate, incoming, &graph, Code::WASM_INTERPRETER_ENTRY,
func_name.start(), AssemblerOptions::Default(isolate)); func_name.start(), AssemblerOptions::Default(isolate));
Handle<Code> code; Handle<Code> code = maybe_code.ToHandleChecked();
if (!maybe_code.ToHandle(&code)) {
return maybe_code;
}
#ifdef ENABLE_DISASSEMBLER #ifdef ENABLE_DISASSEMBLER
if (FLAG_print_opt_code) { if (FLAG_print_opt_code) {
CodeTracer::Scope tracing_scope(isolate->GetCodeTracer()); CodeTracer::Scope tracing_scope(isolate->GetCodeTracer());
...@@ -5154,7 +5153,11 @@ MaybeHandle<Code> CompileWasmInterpreterEntry(Isolate* isolate, ...@@ -5154,7 +5153,11 @@ MaybeHandle<Code> CompileWasmInterpreterEntry(Isolate* isolate,
"%.*s", func_name.length(), func_name.start()); "%.*s", func_name.length(), func_name.start());
} }
return maybe_code; // TODO(wasm): No need to compile the code onto the heap and copy back.
wasm::WasmCode* wasm_code =
native_module->AddInterpreterEntry(code, func_index);
return wasm_code;
} }
MaybeHandle<Code> CompileCWasmEntry(Isolate* isolate, wasm::FunctionSig* sig) { MaybeHandle<Code> CompileCWasmEntry(Isolate* isolate, wasm::FunctionSig* sig) {
......
...@@ -84,9 +84,10 @@ WasmImportCallKind GetWasmImportCallKind(Handle<JSReceiver> callable, ...@@ -84,9 +84,10 @@ WasmImportCallKind GetWasmImportCallKind(Handle<JSReceiver> callable,
wasm::FunctionSig* sig); wasm::FunctionSig* sig);
// Compiles an import call wrapper, which allows WASM to call imports. // Compiles an import call wrapper, which allows WASM to call imports.
MaybeHandle<Code> CompileWasmImportCallWrapper(Isolate*, WasmImportCallKind, wasm::WasmCode* CompileWasmImportCallWrapper(Isolate*, wasm::NativeModule*,
wasm::FunctionSig*, WasmImportCallKind,
bool source_positions); wasm::FunctionSig*,
bool source_positions);
// Creates a code object calling a wasm function with the given signature, // Creates a code object calling a wasm function with the given signature,
// callable from JS. // callable from JS.
...@@ -96,8 +97,9 @@ V8_EXPORT_PRIVATE MaybeHandle<Code> CompileJSToWasmWrapper(Isolate*, ...@@ -96,8 +97,9 @@ V8_EXPORT_PRIVATE MaybeHandle<Code> CompileJSToWasmWrapper(Isolate*,
// Compiles a stub that redirects a call to a wasm function to the wasm // Compiles a stub that redirects a call to a wasm function to the wasm
// interpreter. It's ABI compatible with the compiled wasm function. // interpreter. It's ABI compatible with the compiled wasm function.
MaybeHandle<Code> CompileWasmInterpreterEntry(Isolate*, uint32_t func_index, wasm::WasmCode* CompileWasmInterpreterEntry(Isolate*, wasm::NativeModule*,
wasm::FunctionSig*); uint32_t func_index,
wasm::FunctionSig*);
enum CWasmEntryParameters { enum CWasmEntryParameters {
kCodeEntry, kCodeEntry,
......
...@@ -440,6 +440,11 @@ WasmCode* NativeModule::AddInterpreterEntry(Handle<Code> code, ...@@ -440,6 +440,11 @@ WasmCode* NativeModule::AddInterpreterEntry(Handle<Code> code,
return ret; return ret;
} }
WasmCode* NativeModule::AddImportCallWrapper(Handle<Code> code) {
WasmCode* ret = AddAnonymousCode(code, WasmCode::kWasmToJsWrapper);
return ret;
}
WasmCode* NativeModule::AddCodeForTesting(Handle<Code> code) { WasmCode* NativeModule::AddCodeForTesting(Handle<Code> code) {
WasmCode* ret = AddAnonymousCode(code, WasmCode::kFunction); WasmCode* ret = AddAnonymousCode(code, WasmCode::kFunction);
return ret; return ret;
......
...@@ -238,6 +238,9 @@ class V8_EXPORT_PRIVATE NativeModule final { ...@@ -238,6 +238,9 @@ class V8_EXPORT_PRIVATE NativeModule final {
// self-identify as the {index} function. // self-identify as the {index} function.
WasmCode* AddInterpreterEntry(Handle<Code> code, uint32_t index); WasmCode* AddInterpreterEntry(Handle<Code> code, uint32_t index);
// Add an import wrapper for a JS-to-Wasm call.
WasmCode* AddImportCallWrapper(Handle<Code> code);
// Adds anonymous code for testing purposes. // Adds anonymous code for testing purposes.
WasmCode* AddCodeForTesting(Handle<Code> code); WasmCode* AddCodeForTesting(Handle<Code> code);
...@@ -348,7 +351,6 @@ class V8_EXPORT_PRIVATE NativeModule final { ...@@ -348,7 +351,6 @@ class V8_EXPORT_PRIVATE NativeModule final {
friend class WasmCode; friend class WasmCode;
friend class WasmCodeManager; friend class WasmCodeManager;
friend class NativeModuleModificationScope; friend class NativeModuleModificationScope;
friend class WasmImportWrapperCache;
NativeModule(Isolate* isolate, const WasmFeatures& enabled_features, NativeModule(Isolate* isolate, const WasmFeatures& enabled_features,
bool can_request_more, VirtualMemory code_space, bool can_request_more, VirtualMemory code_space,
......
...@@ -628,10 +628,8 @@ void WasmDebugInfo::RedirectToInterpreter(Handle<WasmDebugInfo> debug_info, ...@@ -628,10 +628,8 @@ void WasmDebugInfo::RedirectToInterpreter(Handle<WasmDebugInfo> debug_info,
DCHECK_GT(module->functions.size(), func_index); DCHECK_GT(module->functions.size(), func_index);
if (!interpreted_functions->get(func_index)->IsUndefined(isolate)) continue; if (!interpreted_functions->get(func_index)->IsUndefined(isolate)) continue;
MaybeHandle<Code> new_code = compiler::CompileWasmInterpreterEntry( const wasm::WasmCode* wasm_new_code = compiler::CompileWasmInterpreterEntry(
isolate, func_index, module->functions[func_index].sig); isolate, native_module, func_index, module->functions[func_index].sig);
const wasm::WasmCode* wasm_new_code = native_module->AddInterpreterEntry(
new_code.ToHandleChecked(), func_index);
Handle<Foreign> foreign_holder = isolate->factory()->NewForeign( Handle<Foreign> foreign_holder = isolate->factory()->NewForeign(
wasm_new_code->instruction_start(), TENURED); wasm_new_code->instruction_start(), TENURED);
interpreted_functions->set(func_index, *foreign_holder); interpreted_functions->set(func_index, *foreign_holder);
......
...@@ -27,17 +27,14 @@ class WasmImportWrapperCache { ...@@ -27,17 +27,14 @@ class WasmImportWrapperCache {
WasmCode*& cached = entry_map_[key]; WasmCode*& cached = entry_map_[key];
if (cached == nullptr) { if (cached == nullptr) {
// TODO(wasm): no need to hold the lock while compiling an import wrapper. // TODO(wasm): no need to hold the lock while compiling an import wrapper.
// TODO(wasm): no need to compile the code onto the heap and copy back.
HandleScope scope(isolate); HandleScope scope(isolate);
bool source_positions = native_module_->module()->origin == kAsmJsOrigin; bool source_positions = native_module_->module()->origin == kAsmJsOrigin;
Handle<Code> code = compiler::CompileWasmImportCallWrapper( cached = compiler::CompileWasmImportCallWrapper(
isolate, kind, sig, source_positions) isolate, native_module_, kind, sig, source_positions);
.ToHandleChecked();
auto counters = isolate->counters(); auto counters = isolate->counters();
counters->wasm_generated_code_size()->Increment(code->body_size()); counters->wasm_generated_code_size()->Increment(
counters->wasm_reloc_size()->Increment(code->relocation_info()->length()); cached->instructions().length());
cached = counters->wasm_reloc_size()->Increment(cached->reloc_info().length());
native_module_->AddAnonymousCode(code, WasmCode::kWasmToJsWrapper);
} }
return cached; return cached;
} }
......
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