Index: src/mips/lithium-mips.h |
diff --git a/src/mips/lithium-mips.h b/src/mips/lithium-mips.h |
index 759cae2de7b7ad626768bc76136363b041ee5f18..7f87b028d06c647bc117f24574c64233102faaef 100644 |
--- a/src/mips/lithium-mips.h |
+++ b/src/mips/lithium-mips.h |
@@ -135,6 +135,7 @@ class LCodeGen; |
V(MathMinMax) \ |
V(ModI) \ |
V(MulI) \ |
+ V(MultiplyAddD) \ |
V(NumberTagD) \ |
V(NumberTagI) \ |
V(NumberTagU) \ |
@@ -608,6 +609,24 @@ class LMulI: public LTemplateInstruction<1, 2, 1> { |
}; |
+// Instruction for computing multiplier * multiplicand + addend. |
+class LMultiplyAddD: public LTemplateInstruction<1, 3, 0> { |
+ public: |
+ LMultiplyAddD(LOperand* addend, LOperand* multiplier, |
+ LOperand* multiplicand) { |
+ inputs_[0] = addend; |
+ inputs_[1] = multiplier; |
+ inputs_[2] = multiplicand; |
+ } |
+ |
+ LOperand* addend() { return inputs_[0]; } |
+ LOperand* multiplier() { return inputs_[1]; } |
+ LOperand* multiplicand() { return inputs_[2]; } |
+ |
+ DECLARE_CONCRETE_INSTRUCTION(MultiplyAddD, "multiply-add-d") |
+}; |
+ |
+ |
class LCmpIDAndBranch: public LControlInstruction<2, 0> { |
public: |
LCmpIDAndBranch(LOperand* left, LOperand* right) { |
@@ -2433,6 +2452,8 @@ class LChunkBuilder BASE_EMBEDDED { |
HYDROGEN_CONCRETE_INSTRUCTION_LIST(DECLARE_DO) |
#undef DECLARE_DO |
+ LInstruction* DoMultiplyAdd(HMul* mul, HValue* addend); |
+ |
private: |
enum Status { |
UNUSED, |