Commit a3c2da4d authored by Jacob.Bramley@arm.com's avatar Jacob.Bramley@arm.com

ARM64: avoid duplicate load of double constants

R=bmeurer@chromium.org, ulan@chromium.org

BUG=

Review URL: https://codereview.chromium.org/357973002

git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@22051 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 3d9080a5
...@@ -1274,15 +1274,13 @@ LInstruction* LChunkBuilder::DoCompareNumericAndBranch( ...@@ -1274,15 +1274,13 @@ LInstruction* LChunkBuilder::DoCompareNumericAndBranch(
ASSERT(r.IsDouble()); ASSERT(r.IsDouble());
ASSERT(instr->left()->representation().IsDouble()); ASSERT(instr->left()->representation().IsDouble());
ASSERT(instr->right()->representation().IsDouble()); ASSERT(instr->right()->representation().IsDouble());
// TODO(all): In fact the only case that we can handle more efficiently is if (instr->left()->IsConstant() && instr->right()->IsConstant()) {
// when one of the operand is the constant 0. Currently the MacroAssembler LOperand* left = UseConstant(instr->left());
// will be able to cope with any constant by loading it into an internal LOperand* right = UseConstant(instr->right());
// scratch register. This means that if the constant is used more that once, return new(zone()) LCompareNumericAndBranch(left, right);
// it will be loaded multiple times. Unfortunatly crankshaft already }
// duplicates constant loads, but we should modify the code below once this LOperand* left = UseRegisterAtStart(instr->left());
// issue has been addressed in crankshaft. LOperand* right = UseRegisterAtStart(instr->right());
LOperand* left = UseRegisterOrConstantAtStart(instr->left());
LOperand* right = UseRegisterOrConstantAtStart(instr->right());
return new(zone()) LCompareNumericAndBranch(left, right); return new(zone()) LCompareNumericAndBranch(left, right);
} }
} }
......
...@@ -2484,17 +2484,7 @@ void LCodeGen::DoCompareNumericAndBranch(LCompareNumericAndBranch* instr) { ...@@ -2484,17 +2484,7 @@ void LCodeGen::DoCompareNumericAndBranch(LCompareNumericAndBranch* instr) {
EmitGoto(next_block); EmitGoto(next_block);
} else { } else {
if (instr->is_double()) { if (instr->is_double()) {
if (right->IsConstantOperand()) { __ Fcmp(ToDoubleRegister(left), ToDoubleRegister(right));
__ Fcmp(ToDoubleRegister(left),
ToDouble(LConstantOperand::cast(right)));
} else if (left->IsConstantOperand()) {
// Commute the operands and the condition.
__ Fcmp(ToDoubleRegister(right),
ToDouble(LConstantOperand::cast(left)));
cond = CommuteCondition(cond);
} else {
__ Fcmp(ToDoubleRegister(left), ToDoubleRegister(right));
}
// If a NaN is involved, i.e. the result is unordered (V set), // If a NaN is involved, i.e. the result is unordered (V set),
// jump to false block label. // jump to false block label.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment