Commit 8ee003e1 authored by Clemens Hammacher's avatar Clemens Hammacher Committed by Commit Bot

[wasm] Refactor generation of stub table

Instantiating a JumpTableAssembler has some overhead (at least one heap
allocation), so use a single JumpTableAssembler to generate the whole
table, just as the lazy compile table.

R=mstarzinger@chromium.org

Bug: v8:9477
Change-Id: I66622909ac06e6bda9fca3e71c83d4c9d1ded500
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1706054Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
Commit-Queue: Clemens Hammacher <clemensh@chromium.org>
Cr-Commit-Position: refs/heads/master@{#62762}
parent 10f8ecb4
...@@ -100,16 +100,20 @@ class V8_EXPORT_PRIVATE JumpTableAssembler : public MacroAssembler { ...@@ -100,16 +100,20 @@ class V8_EXPORT_PRIVATE JumpTableAssembler : public MacroAssembler {
FlushInstructionCache(base, lazy_compile_table_size); FlushInstructionCache(base, lazy_compile_table_size);
} }
static void EmitRuntimeStubSlot(Address base, uint32_t slot_index, static void GenerateRuntimeStubTable(Address base, Address* targets,
Address builtin_target, int num_stubs) {
WasmCode::FlushICache flush_i_cache) { uint32_t table_size = num_stubs * kJumpTableStubSlotSize;
Address slot = base + StubSlotIndexToOffset(slot_index); // Assume enough space, so the Assembler does not try to grow the buffer.
JumpTableAssembler jtasm(slot); JumpTableAssembler jtasm(base, table_size + 256);
jtasm.EmitRuntimeStubSlot(builtin_target); int offset = 0;
jtasm.NopBytes(kJumpTableStubSlotSize - jtasm.pc_offset()); for (int index = 0; index < num_stubs; ++index) {
if (flush_i_cache) { DCHECK_EQ(offset, StubSlotIndexToOffset(index));
FlushInstructionCache(slot, kJumpTableStubSlotSize); DCHECK_EQ(offset, jtasm.pc_offset());
jtasm.EmitRuntimeStubSlot(targets[index]);
offset += kJumpTableStubSlotSize;
jtasm.NopBytes(offset - jtasm.pc_offset());
} }
FlushInstructionCache(base, table_size);
} }
static void PatchJumpTableSlot(Address base, uint32_t slot_index, static void PatchJumpTableSlot(Address base, uint32_t slot_index,
......
...@@ -729,23 +729,22 @@ void NativeModule::SetRuntimeStubs(Isolate* isolate) { ...@@ -729,23 +729,22 @@ void NativeModule::SetRuntimeStubs(Isolate* isolate) {
WasmCode::kRuntimeStubCount)); WasmCode::kRuntimeStubCount));
Address base = jump_table->instruction_start(); Address base = jump_table->instruction_start();
EmbeddedData embedded_data = EmbeddedData::FromBlob(); EmbeddedData embedded_data = EmbeddedData::FromBlob();
#define RUNTIME_STUB(Name) {Builtins::k##Name, WasmCode::k##Name}, #define RUNTIME_STUB(Name) Builtins::k##Name,
#define RUNTIME_STUB_TRAP(Name) RUNTIME_STUB(ThrowWasm##Name) #define RUNTIME_STUB_TRAP(Name) RUNTIME_STUB(ThrowWasm##Name)
std::pair<Builtins::Name, WasmCode::RuntimeStubId> wasm_runtime_stubs[] = { Builtins::Name wasm_runtime_stubs[WasmCode::kRuntimeStubCount] = {
WASM_RUNTIME_STUB_LIST(RUNTIME_STUB, RUNTIME_STUB_TRAP)}; WASM_RUNTIME_STUB_LIST(RUNTIME_STUB, RUNTIME_STUB_TRAP)};
#undef RUNTIME_STUB #undef RUNTIME_STUB
#undef RUNTIME_STUB_TRAP #undef RUNTIME_STUB_TRAP
for (auto pair : wasm_runtime_stubs) { Address builtin_address[WasmCode::kRuntimeStubCount];
CHECK(embedded_data.ContainsBuiltin(pair.first)); for (int i = 0; i < WasmCode::kRuntimeStubCount; ++i) {
Address builtin = embedded_data.InstructionStartOfBuiltin(pair.first); Builtins::Name builtin = wasm_runtime_stubs[i];
JumpTableAssembler::EmitRuntimeStubSlot(base, pair.second, builtin, CHECK(embedded_data.ContainsBuiltin(builtin));
WasmCode::kNoFlushICache); builtin_address[i] = embedded_data.InstructionStartOfBuiltin(builtin);
uint32_t slot_offset = runtime_stub_entries_[i] =
JumpTableAssembler::StubSlotIndexToOffset(pair.second); base + JumpTableAssembler::StubSlotIndexToOffset(i);
runtime_stub_entries_[pair.second] = base + slot_offset;
} }
FlushInstructionCache(jump_table->instructions().begin(), JumpTableAssembler::GenerateRuntimeStubTable(base, builtin_address,
jump_table->instructions().size()); WasmCode::kRuntimeStubCount);
DCHECK_NULL(runtime_stub_table_); DCHECK_NULL(runtime_stub_table_);
runtime_stub_table_ = jump_table; runtime_stub_table_ = jump_table;
#else // V8_EMBEDDED_BUILTINS #else // V8_EMBEDDED_BUILTINS
......
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