| Index: src/interpreter/bytecode-peephole-optimizer.h
|
| diff --git a/src/interpreter/bytecode-peephole-optimizer.h b/src/interpreter/bytecode-peephole-optimizer.h
|
| index 95c9d57795e3029f5d49efa9699715d02bd8a67d..e6ada2aa1ef244c4f3c07c176f80ac26df4994ca 100644
|
| --- a/src/interpreter/bytecode-peephole-optimizer.h
|
| +++ b/src/interpreter/bytecode-peephole-optimizer.h
|
| @@ -1,11 +1,10 @@
|
| -// Copyright 2016 the V8 project authors. All rights reserved.
|
| +// Copyright 2015 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.
|
|
|
| #ifndef V8_INTERPRETER_BYTECODE_PEEPHOLE_OPTIMIZER_H_
|
| #define V8_INTERPRETER_BYTECODE_PEEPHOLE_OPTIMIZER_H_
|
|
|
| -#include "src/interpreter/bytecode-peephole-table.h"
|
| #include "src/interpreter/bytecode-pipeline.h"
|
|
|
| namespace v8 {
|
| @@ -13,7 +12,6 @@
|
| namespace interpreter {
|
|
|
| class ConstantArrayBuilder;
|
| -class BytecodePeepholeActionAndData;
|
|
|
| // An optimization stage for performing peephole optimizations on
|
| // generated bytecode. The optimizer may buffer one bytecode
|
| @@ -34,25 +32,30 @@
|
| Handle<FixedArray> handler_table) override;
|
|
|
| private:
|
| -#define DECLARE_ACTION(Action) \
|
| - void Action(BytecodeNode* const node, \
|
| - const PeepholeActionAndData* const action_data = nullptr);
|
| - PEEPHOLE_ACTION_LIST(DECLARE_ACTION)
|
| -#undef DECLARE_ACTION
|
| + BytecodeNode* OptimizeAndEmitLast(BytecodeNode* current);
|
| + BytecodeNode* Optimize(BytecodeNode* current);
|
| + void Flush();
|
|
|
| - void ApplyPeepholeAction(BytecodeNode* const node);
|
| - void Flush();
|
| + void TryToRemoveLastExpressionPosition(const BytecodeNode* const current);
|
| + bool TransformCurrentBytecode(BytecodeNode* const current);
|
| + bool TransformLastAndCurrentBytecodes(BytecodeNode* const current);
|
| + bool CanElideCurrent(const BytecodeNode* const current) const;
|
| + bool CanElideLast(const BytecodeNode* const current) const;
|
| bool CanElideLastBasedOnSourcePosition(
|
| const BytecodeNode* const current) const;
|
| +
|
| + // Simple substitution methods.
|
| + bool RemoveToBooleanFromJump(BytecodeNode* const current);
|
| + bool RemoveToBooleanFromLogicalNot(BytecodeNode* const current);
|
| +
|
| void InvalidateLast();
|
| bool LastIsValid() const;
|
| void SetLast(const BytecodeNode* const node);
|
|
|
| + bool LastBytecodePutsNameInAccumulator() const;
|
| +
|
| Handle<Object> GetConstantForIndexOperand(const BytecodeNode* const node,
|
| int index) const;
|
| -
|
| - BytecodePipelineStage* next_stage() const { return next_stage_; }
|
| - BytecodeNode* last() { return &last_; }
|
|
|
| ConstantArrayBuilder* constant_array_builder_;
|
| BytecodePipelineStage* next_stage_;
|
|
|