Index: src/x87/lithium-x87.h |
diff --git a/src/x87/lithium-x87.h b/src/x87/lithium-x87.h |
index 233eaf23f6762f0e71c09f69261b106d2268b8b3..216d7363e5dad8e1a697b07f5662bbccf739cac3 100644 |
--- a/src/x87/lithium-x87.h |
+++ b/src/x87/lithium-x87.h |
@@ -413,6 +413,7 @@ class LGoto FINAL : public LTemplateInstruction<0, 0, 0> { |
} |
bool jumps_to_join() const { return block_->predecessors()->length() > 1; } |
+ HBasicBlock* block() const { return block_; } |
private: |
HBasicBlock* block_; |
@@ -984,15 +985,13 @@ class LMathSqrt FINAL : public LTemplateInstruction<1, 1, 0> { |
}; |
-class LMathPowHalf FINAL : public LTemplateInstruction<1, 1, 1> { |
+class LMathPowHalf FINAL : public LTemplateInstruction<1, 1, 0> { |
public: |
- LMathPowHalf(LOperand* value, LOperand* temp) { |
+ explicit LMathPowHalf(LOperand* value) { |
inputs_[0] = value; |
- temps_[0] = temp; |
} |
LOperand* value() { return inputs_[0]; } |
- LOperand* temp() { return temps_[0]; } |
DECLARE_CONCRETE_INSTRUCTION(MathPowHalf, "math-pow-half") |
}; |
@@ -1025,15 +1024,13 @@ class LCmpHoleAndBranch FINAL : public LControlInstruction<1, 0> { |
}; |
-class LCompareMinusZeroAndBranch FINAL : public LControlInstruction<1, 1> { |
+class LCompareMinusZeroAndBranch FINAL : public LControlInstruction<1, 0> { |
public: |
- LCompareMinusZeroAndBranch(LOperand* value, LOperand* temp) { |
+ explicit LCompareMinusZeroAndBranch(LOperand* value) { |
inputs_[0] = value; |
- temps_[0] = temp; |
} |
LOperand* value() { return inputs_[0]; } |
- LOperand* temp() { return temps_[0]; } |
DECLARE_CONCRETE_INSTRUCTION(CompareMinusZeroAndBranch, |
"cmp-minus-zero-and-branch") |
@@ -1508,15 +1505,17 @@ class LAddI FINAL : public LTemplateInstruction<1, 2, 0> { |
}; |
-class LMathMinMax FINAL : public LTemplateInstruction<1, 2, 0> { |
+class LMathMinMax FINAL : public LTemplateInstruction<1, 2, 1> { |
public: |
- LMathMinMax(LOperand* left, LOperand* right) { |
+ LMathMinMax(LOperand* left, LOperand* right, LOperand* temp) { |
inputs_[0] = left; |
inputs_[1] = right; |
+ temps_[0] = temp; |
} |
LOperand* left() { return inputs_[0]; } |
LOperand* right() { return inputs_[1]; } |
+ LOperand* temp() {return temps_[0]; } |
DECLARE_CONCRETE_INSTRUCTION(MathMinMax, "math-min-max") |
DECLARE_HYDROGEN_ACCESSOR(MathMinMax) |
@@ -2037,11 +2036,12 @@ class LCallRuntime FINAL : public LTemplateInstruction<1, 1, 0> { |
DECLARE_HYDROGEN_ACCESSOR(CallRuntime) |
virtual bool ClobbersDoubleRegisters(Isolate* isolate) const OVERRIDE { |
- return true; |
+ return save_doubles() == kDontSaveFPRegs; |
} |
const Runtime::Function* function() const { return hydrogen()->function(); } |
int arity() const { return hydrogen()->argument_count(); } |
+ SaveFPRegsMode save_doubles() const { return hydrogen()->save_doubles(); } |
}; |
@@ -2881,6 +2881,8 @@ class LChunkBuilder FINAL : public LChunkBuilderBase { |
LInstruction* DefineSameAsFirst(LTemplateResultInstruction<1>* instr); |
LInstruction* DefineFixed(LTemplateResultInstruction<1>* instr, |
Register reg); |
+ LInstruction* DefineFixed(LTemplateResultInstruction<1>* instr, |
+ X87Register reg); |
LInstruction* DefineX87TOS(LTemplateResultInstruction<1>* instr); |
// Assigns an environment to an instruction. An instruction which can |
// deoptimize must have an environment. |