Index: src/interpreter/bytecode-operands.h |
diff --git a/src/interpreter/bytecode-operands.h b/src/interpreter/bytecode-operands.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..6d77b1d4c6b61384aacd7e1d89395ffe70009901 |
--- /dev/null |
+++ b/src/interpreter/bytecode-operands.h |
@@ -0,0 +1,126 @@ |
+// Copyright 2016 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_OPERANDS_H_ |
+#define V8_INTERPRETER_BYTECODE_OPERANDS_H_ |
+ |
+#include "src/globals.h" |
+ |
+namespace v8 { |
+namespace internal { |
+namespace interpreter { |
+ |
+#define INVALID_OPERAND_TYPE_LIST(V) V(None, OperandTypeInfo::kNone) |
+ |
+#define REGISTER_INPUT_OPERAND_TYPE_LIST(V) \ |
+ V(MaybeReg, OperandTypeInfo::kScalableSignedByte) \ |
+ V(Reg, OperandTypeInfo::kScalableSignedByte) \ |
+ V(RegPair, OperandTypeInfo::kScalableSignedByte) |
+ |
+#define REGISTER_OUTPUT_OPERAND_TYPE_LIST(V) \ |
+ V(RegOut, OperandTypeInfo::kScalableSignedByte) \ |
+ V(RegOutPair, OperandTypeInfo::kScalableSignedByte) \ |
+ V(RegOutTriple, OperandTypeInfo::kScalableSignedByte) |
+ |
+#define SCALAR_OPERAND_TYPE_LIST(V) \ |
+ V(Flag8, OperandTypeInfo::kFixedUnsignedByte) \ |
+ V(IntrinsicId, OperandTypeInfo::kFixedUnsignedByte) \ |
+ V(Idx, OperandTypeInfo::kScalableUnsignedByte) \ |
+ V(UImm, OperandTypeInfo::kScalableUnsignedByte) \ |
+ V(Imm, OperandTypeInfo::kScalableSignedByte) \ |
+ V(RegCount, OperandTypeInfo::kScalableUnsignedByte) \ |
+ V(RuntimeId, OperandTypeInfo::kFixedUnsignedShort) |
+ |
+#define REGISTER_OPERAND_TYPE_LIST(V) \ |
+ REGISTER_INPUT_OPERAND_TYPE_LIST(V) \ |
+ REGISTER_OUTPUT_OPERAND_TYPE_LIST(V) |
+ |
+#define NON_REGISTER_OPERAND_TYPE_LIST(V) \ |
+ INVALID_OPERAND_TYPE_LIST(V) \ |
+ SCALAR_OPERAND_TYPE_LIST(V) |
+ |
+// The list of operand types used by bytecodes. |
+#define OPERAND_TYPE_LIST(V) \ |
+ NON_REGISTER_OPERAND_TYPE_LIST(V) \ |
+ REGISTER_OPERAND_TYPE_LIST(V) |
+ |
+// Enumeration of scaling factors applicable to scalable operands. Code |
+// relies on being able to cast values to integer scaling values. |
+#define OPERAND_SCALE_LIST(V) \ |
+ V(Single, 1) \ |
+ V(Double, 2) \ |
+ V(Quadruple, 4) |
+ |
+enum class OperandScale : uint8_t { |
+#define DECLARE_OPERAND_SCALE(Name, Scale) k##Name = Scale, |
+ OPERAND_SCALE_LIST(DECLARE_OPERAND_SCALE) |
+#undef DECLARE_OPERAND_SCALE |
+ kLast = kQuadruple |
+}; |
+ |
+// Enumeration of the size classes of operand types used by |
+// bytecodes. Code relies on being able to cast values to integer |
+// types to get the size in bytes. |
+enum class OperandSize : uint8_t { |
+ kNone = 0, |
+ kByte = 1, |
+ kShort = 2, |
+ kQuad = 4, |
+ kLast = kQuad |
+}; |
+ |
+// Primitive operand info used that summarize properties of operands. |
+// Columns are Name, IsScalable, IsUnsigned, UnscaledSize. |
+#define OPERAND_TYPE_INFO_LIST(V) \ |
+ V(None, false, false, OperandSize::kNone) \ |
+ V(ScalableSignedByte, true, false, OperandSize::kByte) \ |
+ V(ScalableUnsignedByte, true, true, OperandSize::kByte) \ |
+ V(FixedUnsignedByte, false, true, OperandSize::kByte) \ |
+ V(FixedUnsignedShort, false, true, OperandSize::kShort) |
+ |
+enum class OperandTypeInfo : uint8_t { |
+#define DECLARE_OPERAND_TYPE_INFO(Name, ...) k##Name, |
+ OPERAND_TYPE_INFO_LIST(DECLARE_OPERAND_TYPE_INFO) |
+#undef DECLARE_OPERAND_TYPE_INFO |
+}; |
+ |
+// Enumeration of operand types used by bytecodes. |
+enum class OperandType : uint8_t { |
+#define DECLARE_OPERAND_TYPE(Name, _) k##Name, |
+ OPERAND_TYPE_LIST(DECLARE_OPERAND_TYPE) |
+#undef DECLARE_OPERAND_TYPE |
+#define COUNT_OPERAND_TYPES(x, _) +1 |
+ // The COUNT_OPERAND macro will turn this into kLast = -1 +1 +1... which will |
+ // evaluate to the same value as the last operand. |
+ kLast = -1 OPERAND_TYPE_LIST(COUNT_OPERAND_TYPES) |
+#undef COUNT_OPERAND_TYPES |
+}; |
+ |
+enum class AccumulatorUse : uint8_t { |
+ kNone = 0, |
+ kRead = 1 << 0, |
+ kWrite = 1 << 1, |
+ kReadWrite = kRead | kWrite |
+}; |
+ |
+inline AccumulatorUse operator&(AccumulatorUse lhs, AccumulatorUse rhs) { |
+ int result = static_cast<int>(lhs) & static_cast<int>(rhs); |
+ return static_cast<AccumulatorUse>(result); |
+} |
+ |
+inline AccumulatorUse operator|(AccumulatorUse lhs, AccumulatorUse rhs) { |
+ int result = static_cast<int>(lhs) | static_cast<int>(rhs); |
+ return static_cast<AccumulatorUse>(result); |
+} |
+ |
+std::ostream& operator<<(std::ostream& os, const AccumulatorUse& use); |
+std::ostream& operator<<(std::ostream& os, const OperandScale& operand_scale); |
+std::ostream& operator<<(std::ostream& os, const OperandSize& operand_size); |
+std::ostream& operator<<(std::ostream& os, const OperandType& operand_type); |
+ |
+} // namespace interpreter |
+} // namespace internal |
+} // namespace v8 |
+ |
+#endif // V8_INTERPRETER_BYTECODE_OPERANDS_H_ |