| 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,
|
|
|