Commit a79f9031 authored by Ross McIlroy's avatar Ross McIlroy Committed by Commit Bot

[Interpreter] Unify approach to building interpreter handler and Turbofan stubs.

Moves interpreter-generator.cc to a similar model of building handlers as
Turbofan stubs elsewhere, to simplify moving code between stubs / builtins and
bytecode handlers. This removes the "__" hack from the Interpreter generator
code.

Also make SetBytecodeOffset private to InterpreterAssembler and make 
LdaImmutable[Current]ContextSlot and Lda[Current]ContextSlot share
handlers since they are identical.

Change-Id: I9e91e7d37c2ea75513e4dcc3b95b4bb6517f83da
Reviewed-on: https://chromium-review.googlesource.com/471987
Commit-Queue: Ross McIlroy <rmcilroy@chromium.org>
Reviewed-by: 's avatarJakob Kummerow <jkummerow@chromium.org>
Reviewed-by: 's avatarIgor Sheludko <ishell@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44534}
parent 4c3d18a0
...@@ -54,6 +54,10 @@ InterpreterAssembler::InterpreterAssembler(CodeAssemblerState* state, ...@@ -54,6 +54,10 @@ InterpreterAssembler::InterpreterAssembler(CodeAssemblerState* state,
} }
RegisterCallGenerationCallbacks([this] { CallPrologue(); }, RegisterCallGenerationCallbacks([this] { CallPrologue(); },
[this] { CallEpilogue(); }); [this] { CallEpilogue(); });
if (Bytecodes::MakesCallAlongCriticalPath(bytecode)) {
SaveBytecodeOffset();
}
} }
InterpreterAssembler::~InterpreterAssembler() { InterpreterAssembler::~InterpreterAssembler() {
......
...@@ -228,9 +228,6 @@ class V8_EXPORT_PRIVATE InterpreterAssembler : public CodeStubAssembler { ...@@ -228,9 +228,6 @@ class V8_EXPORT_PRIVATE InterpreterAssembler : public CodeStubAssembler {
// Returns the offset from the BytecodeArrayPointer of the current bytecode. // Returns the offset from the BytecodeArrayPointer of the current bytecode.
compiler::Node* BytecodeOffset(); compiler::Node* BytecodeOffset();
// Save the bytecode offset to the interpreter frame.
void SaveBytecodeOffset();
protected: protected:
Bytecode bytecode() const { return bytecode_; } Bytecode bytecode() const { return bytecode_; }
static bool TargetSupportsUnalignedAccess(); static bool TargetSupportsUnalignedAccess();
...@@ -306,6 +303,9 @@ class V8_EXPORT_PRIVATE InterpreterAssembler : public CodeStubAssembler { ...@@ -306,6 +303,9 @@ class V8_EXPORT_PRIVATE InterpreterAssembler : public CodeStubAssembler {
// JumpIfWordNotEqual. // JumpIfWordNotEqual.
void JumpConditional(compiler::Node* condition, compiler::Node* jump_offset); void JumpConditional(compiler::Node* condition, compiler::Node* jump_offset);
// Save the bytecode offset to the interpreter frame.
void SaveBytecodeOffset();
// Updates and returns BytecodeOffset() advanced by the current bytecode's // Updates and returns BytecodeOffset() advanced by the current bytecode's
// size. Traces the exit of the current bytecode. // size. Traces the exit of the current bytecode.
compiler::Node* Advance(); compiler::Node* Advance();
......
This source diff could not be displayed because it is too large. You can view the blob instead.
...@@ -52,7 +52,24 @@ void SetupInterpreter::InstallBytecodeHandlers(Interpreter* interpreter) { ...@@ -52,7 +52,24 @@ void SetupInterpreter::InstallBytecodeHandlers(Interpreter* interpreter) {
bool SetupInterpreter::ReuseExistingHandler(Address* dispatch_table, bool SetupInterpreter::ReuseExistingHandler(Address* dispatch_table,
Bytecode bytecode, Bytecode bytecode,
OperandScale operand_scale) { OperandScale operand_scale) {
// TODO(leszeks): reuse Lda[Immutable][Current]ContextSlot size_t index = Interpreter::GetDispatchTableIndex(bytecode, operand_scale);
switch (bytecode) {
case Bytecode::kLdaImmutableContextSlot:
STATIC_ASSERT(static_cast<int>(Bytecode::kLdaContextSlot) <
static_cast<int>(Bytecode::kLdaImmutableContextSlot));
dispatch_table[index] = dispatch_table[Interpreter::GetDispatchTableIndex(
Bytecode::kLdaContextSlot, operand_scale)];
return true;
case Bytecode::kLdaImmutableCurrentContextSlot:
STATIC_ASSERT(
static_cast<int>(Bytecode::kLdaCurrentContextSlot) <
static_cast<int>(Bytecode::kLdaImmutableCurrentContextSlot));
dispatch_table[index] = dispatch_table[Interpreter::GetDispatchTableIndex(
Bytecode::kLdaCurrentContextSlot, operand_scale)];
return true;
default:
return false;
}
return false; return false;
} }
......
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